radio.js 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. import { ChangeDetectorRef, Directive, ElementRef, forwardRef, Input, Renderer2 } from '@angular/core';
  6. import { NG_VALUE_ACCESSOR } from '@angular/forms';
  7. import { NgbButtonLabel } from './label';
  8. /** @type {?} */
  9. var NGB_RADIO_VALUE_ACCESSOR = {
  10. provide: NG_VALUE_ACCESSOR,
  11. useExisting: forwardRef((/**
  12. * @return {?}
  13. */
  14. function () { return NgbRadioGroup; })),
  15. multi: true
  16. };
  17. /** @type {?} */
  18. var nextId = 0;
  19. /**
  20. * Allows to easily create Bootstrap-style radio buttons.
  21. *
  22. * Integrates with forms, so the value of a checked button is bound to the underlying form control
  23. * either in a reactive or template-driven way.
  24. */
  25. var NgbRadioGroup = /** @class */ (function () {
  26. function NgbRadioGroup() {
  27. this._radios = new Set();
  28. this._value = null;
  29. /**
  30. * Name of the radio group applied to radio input elements.
  31. *
  32. * Will be applied to all radio input elements inside the group,
  33. * unless [`NgbRadio`](#/components/buttons/api#NgbRadio)'s specify names themselves.
  34. *
  35. * If not provided, will be generated in the `ngb-radio-xx` format.
  36. */
  37. this.name = "ngb-radio-" + nextId++;
  38. this.onChange = (/**
  39. * @param {?} _
  40. * @return {?}
  41. */
  42. function (_) { });
  43. this.onTouched = (/**
  44. * @return {?}
  45. */
  46. function () { });
  47. }
  48. Object.defineProperty(NgbRadioGroup.prototype, "disabled", {
  49. get: /**
  50. * @return {?}
  51. */
  52. function () { return this._disabled; },
  53. set: /**
  54. * @param {?} isDisabled
  55. * @return {?}
  56. */
  57. function (isDisabled) { this.setDisabledState(isDisabled); },
  58. enumerable: true,
  59. configurable: true
  60. });
  61. /**
  62. * @param {?} radio
  63. * @return {?}
  64. */
  65. NgbRadioGroup.prototype.onRadioChange = /**
  66. * @param {?} radio
  67. * @return {?}
  68. */
  69. function (radio) {
  70. this.writeValue(radio.value);
  71. this.onChange(radio.value);
  72. };
  73. /**
  74. * @return {?}
  75. */
  76. NgbRadioGroup.prototype.onRadioValueUpdate = /**
  77. * @return {?}
  78. */
  79. function () { this._updateRadiosValue(); };
  80. /**
  81. * @param {?} radio
  82. * @return {?}
  83. */
  84. NgbRadioGroup.prototype.register = /**
  85. * @param {?} radio
  86. * @return {?}
  87. */
  88. function (radio) { this._radios.add(radio); };
  89. /**
  90. * @param {?} fn
  91. * @return {?}
  92. */
  93. NgbRadioGroup.prototype.registerOnChange = /**
  94. * @param {?} fn
  95. * @return {?}
  96. */
  97. function (fn) { this.onChange = fn; };
  98. /**
  99. * @param {?} fn
  100. * @return {?}
  101. */
  102. NgbRadioGroup.prototype.registerOnTouched = /**
  103. * @param {?} fn
  104. * @return {?}
  105. */
  106. function (fn) { this.onTouched = fn; };
  107. /**
  108. * @param {?} isDisabled
  109. * @return {?}
  110. */
  111. NgbRadioGroup.prototype.setDisabledState = /**
  112. * @param {?} isDisabled
  113. * @return {?}
  114. */
  115. function (isDisabled) {
  116. this._disabled = isDisabled;
  117. this._updateRadiosDisabled();
  118. };
  119. /**
  120. * @param {?} radio
  121. * @return {?}
  122. */
  123. NgbRadioGroup.prototype.unregister = /**
  124. * @param {?} radio
  125. * @return {?}
  126. */
  127. function (radio) { this._radios.delete(radio); };
  128. /**
  129. * @param {?} value
  130. * @return {?}
  131. */
  132. NgbRadioGroup.prototype.writeValue = /**
  133. * @param {?} value
  134. * @return {?}
  135. */
  136. function (value) {
  137. this._value = value;
  138. this._updateRadiosValue();
  139. };
  140. /**
  141. * @private
  142. * @return {?}
  143. */
  144. NgbRadioGroup.prototype._updateRadiosValue = /**
  145. * @private
  146. * @return {?}
  147. */
  148. function () {
  149. var _this = this;
  150. this._radios.forEach((/**
  151. * @param {?} radio
  152. * @return {?}
  153. */
  154. function (radio) { return radio.updateValue(_this._value); }));
  155. };
  156. /**
  157. * @private
  158. * @return {?}
  159. */
  160. NgbRadioGroup.prototype._updateRadiosDisabled = /**
  161. * @private
  162. * @return {?}
  163. */
  164. function () { this._radios.forEach((/**
  165. * @param {?} radio
  166. * @return {?}
  167. */
  168. function (radio) { return radio.updateDisabled(); })); };
  169. NgbRadioGroup.decorators = [
  170. { type: Directive, args: [{ selector: '[ngbRadioGroup]', host: { 'role': 'radiogroup' }, providers: [NGB_RADIO_VALUE_ACCESSOR] },] }
  171. ];
  172. NgbRadioGroup.propDecorators = {
  173. name: [{ type: Input }]
  174. };
  175. return NgbRadioGroup;
  176. }());
  177. export { NgbRadioGroup };
  178. if (false) {
  179. /**
  180. * @type {?}
  181. * @private
  182. */
  183. NgbRadioGroup.prototype._radios;
  184. /**
  185. * @type {?}
  186. * @private
  187. */
  188. NgbRadioGroup.prototype._value;
  189. /**
  190. * @type {?}
  191. * @private
  192. */
  193. NgbRadioGroup.prototype._disabled;
  194. /**
  195. * Name of the radio group applied to radio input elements.
  196. *
  197. * Will be applied to all radio input elements inside the group,
  198. * unless [`NgbRadio`](#/components/buttons/api#NgbRadio)'s specify names themselves.
  199. *
  200. * If not provided, will be generated in the `ngb-radio-xx` format.
  201. * @type {?}
  202. */
  203. NgbRadioGroup.prototype.name;
  204. /** @type {?} */
  205. NgbRadioGroup.prototype.onChange;
  206. /** @type {?} */
  207. NgbRadioGroup.prototype.onTouched;
  208. }
  209. /**
  210. * A directive that marks an input of type "radio" as a part of the
  211. * [`NgbRadioGroup`](#/components/buttons/api#NgbRadioGroup).
  212. */
  213. var NgbRadio = /** @class */ (function () {
  214. function NgbRadio(_group, _label, _renderer, _element, _cd) {
  215. this._group = _group;
  216. this._label = _label;
  217. this._renderer = _renderer;
  218. this._element = _element;
  219. this._cd = _cd;
  220. this._value = null;
  221. this._group.register(this);
  222. this.updateDisabled();
  223. }
  224. Object.defineProperty(NgbRadio.prototype, "value", {
  225. get: /**
  226. * @return {?}
  227. */
  228. function () { return this._value; },
  229. /**
  230. * The form control value when current radio button is checked.
  231. */
  232. set: /**
  233. * The form control value when current radio button is checked.
  234. * @param {?} value
  235. * @return {?}
  236. */
  237. function (value) {
  238. this._value = value;
  239. /** @type {?} */
  240. var stringValue = value ? value.toString() : '';
  241. this._renderer.setProperty(this._element.nativeElement, 'value', stringValue);
  242. this._group.onRadioValueUpdate();
  243. },
  244. enumerable: true,
  245. configurable: true
  246. });
  247. Object.defineProperty(NgbRadio.prototype, "disabled", {
  248. get: /**
  249. * @return {?}
  250. */
  251. function () { return this._group.disabled || this._disabled; },
  252. /**
  253. * If `true`, current radio button will be disabled.
  254. */
  255. set: /**
  256. * If `true`, current radio button will be disabled.
  257. * @param {?} isDisabled
  258. * @return {?}
  259. */
  260. function (isDisabled) {
  261. this._disabled = isDisabled !== false;
  262. this.updateDisabled();
  263. },
  264. enumerable: true,
  265. configurable: true
  266. });
  267. Object.defineProperty(NgbRadio.prototype, "focused", {
  268. set: /**
  269. * @param {?} isFocused
  270. * @return {?}
  271. */
  272. function (isFocused) {
  273. if (this._label) {
  274. this._label.focused = isFocused;
  275. }
  276. if (!isFocused) {
  277. this._group.onTouched();
  278. }
  279. },
  280. enumerable: true,
  281. configurable: true
  282. });
  283. Object.defineProperty(NgbRadio.prototype, "checked", {
  284. get: /**
  285. * @return {?}
  286. */
  287. function () { return this._checked; },
  288. enumerable: true,
  289. configurable: true
  290. });
  291. Object.defineProperty(NgbRadio.prototype, "nameAttr", {
  292. get: /**
  293. * @return {?}
  294. */
  295. function () { return this.name || this._group.name; },
  296. enumerable: true,
  297. configurable: true
  298. });
  299. /**
  300. * @return {?}
  301. */
  302. NgbRadio.prototype.ngOnDestroy = /**
  303. * @return {?}
  304. */
  305. function () { this._group.unregister(this); };
  306. /**
  307. * @return {?}
  308. */
  309. NgbRadio.prototype.onChange = /**
  310. * @return {?}
  311. */
  312. function () { this._group.onRadioChange(this); };
  313. /**
  314. * @param {?} value
  315. * @return {?}
  316. */
  317. NgbRadio.prototype.updateValue = /**
  318. * @param {?} value
  319. * @return {?}
  320. */
  321. function (value) {
  322. // label won't be updated, if it is inside the OnPush component when [ngModel] changes
  323. if (this.value !== value) {
  324. this._cd.markForCheck();
  325. }
  326. this._checked = this.value === value;
  327. this._label.active = this._checked;
  328. };
  329. /**
  330. * @return {?}
  331. */
  332. NgbRadio.prototype.updateDisabled = /**
  333. * @return {?}
  334. */
  335. function () { this._label.disabled = this.disabled; };
  336. NgbRadio.decorators = [
  337. { type: Directive, args: [{
  338. selector: '[ngbButton][type=radio]',
  339. host: {
  340. '[checked]': 'checked',
  341. '[disabled]': 'disabled',
  342. '[name]': 'nameAttr',
  343. '(change)': 'onChange()',
  344. '(focus)': 'focused = true',
  345. '(blur)': 'focused = false'
  346. }
  347. },] }
  348. ];
  349. /** @nocollapse */
  350. NgbRadio.ctorParameters = function () { return [
  351. { type: NgbRadioGroup },
  352. { type: NgbButtonLabel },
  353. { type: Renderer2 },
  354. { type: ElementRef },
  355. { type: ChangeDetectorRef }
  356. ]; };
  357. NgbRadio.propDecorators = {
  358. name: [{ type: Input }],
  359. value: [{ type: Input, args: ['value',] }],
  360. disabled: [{ type: Input, args: ['disabled',] }]
  361. };
  362. return NgbRadio;
  363. }());
  364. export { NgbRadio };
  365. if (false) {
  366. /**
  367. * @type {?}
  368. * @private
  369. */
  370. NgbRadio.prototype._checked;
  371. /**
  372. * @type {?}
  373. * @private
  374. */
  375. NgbRadio.prototype._disabled;
  376. /**
  377. * @type {?}
  378. * @private
  379. */
  380. NgbRadio.prototype._value;
  381. /**
  382. * The value for the 'name' property of the input element.
  383. *
  384. * All inputs of the radio group should have the same name. If not specified,
  385. * the name of the enclosing group is used.
  386. * @type {?}
  387. */
  388. NgbRadio.prototype.name;
  389. /**
  390. * @type {?}
  391. * @private
  392. */
  393. NgbRadio.prototype._group;
  394. /**
  395. * @type {?}
  396. * @private
  397. */
  398. NgbRadio.prototype._label;
  399. /**
  400. * @type {?}
  401. * @private
  402. */
  403. NgbRadio.prototype._renderer;
  404. /**
  405. * @type {?}
  406. * @private
  407. */
  408. NgbRadio.prototype._element;
  409. /**
  410. * @type {?}
  411. * @private
  412. */
  413. NgbRadio.prototype._cd;
  414. }
  415. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio.js","sourceRoot":"ng://@ng-bootstrap/ng-bootstrap/","sources":["buttons/radio.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Directive, ElementRef, forwardRef, Input, OnDestroy, Renderer2} from '@angular/core';\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from '@angular/forms';\n\nimport {NgbButtonLabel} from './label';\n\nconst NGB_RADIO_VALUE_ACCESSOR = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => NgbRadioGroup),\n  multi: true\n};\n\nlet nextId = 0;\n\n/**\n * Allows to easily create Bootstrap-style radio buttons.\n *\n * Integrates with forms, so the value of a checked button is bound to the underlying form control\n * either in a reactive or template-driven way.\n */\n@Directive({selector: '[ngbRadioGroup]', host: {'role': 'radiogroup'}, providers: [NGB_RADIO_VALUE_ACCESSOR]})\nexport class NgbRadioGroup implements ControlValueAccessor {\n  private _radios: Set<NgbRadio> = new Set<NgbRadio>();\n  private _value = null;\n  private _disabled: boolean;\n\n  get disabled() { return this._disabled; }\n  set disabled(isDisabled: boolean) { this.setDisabledState(isDisabled); }\n\n  /**\n   * Name of the radio group applied to radio input elements.\n   *\n   * Will be applied to all radio input elements inside the group,\n   * unless [`NgbRadio`](#/components/buttons/api#NgbRadio)'s specify names themselves.\n   *\n   * If not provided, will be generated in the `ngb-radio-xx` format.\n   */\n  @Input() name = `ngb-radio-${nextId++}`;\n\n  onChange = (_: any) => {};\n  onTouched = () => {};\n\n  onRadioChange(radio: NgbRadio) {\n    this.writeValue(radio.value);\n    this.onChange(radio.value);\n  }\n\n  onRadioValueUpdate() { this._updateRadiosValue(); }\n\n  register(radio: NgbRadio) { this._radios.add(radio); }\n\n  registerOnChange(fn: (value: any) => any): void { this.onChange = fn; }\n\n  registerOnTouched(fn: () => any): void { this.onTouched = fn; }\n\n  setDisabledState(isDisabled: boolean): void {\n    this._disabled = isDisabled;\n    this._updateRadiosDisabled();\n  }\n\n  unregister(radio: NgbRadio) { this._radios.delete(radio); }\n\n  writeValue(value) {\n    this._value = value;\n    this._updateRadiosValue();\n  }\n\n  private _updateRadiosValue() { this._radios.forEach((radio) => radio.updateValue(this._value)); }\n  private _updateRadiosDisabled() { this._radios.forEach((radio) => radio.updateDisabled()); }\n}\n\n\n/**\n * A directive that marks an input of type \"radio\" as a part of the\n * [`NgbRadioGroup`](#/components/buttons/api#NgbRadioGroup).\n */\n@Directive({\n  selector: '[ngbButton][type=radio]',\n  host: {\n    '[checked]': 'checked',\n    '[disabled]': 'disabled',\n    '[name]': 'nameAttr',\n    '(change)': 'onChange()',\n    '(focus)': 'focused = true',\n    '(blur)': 'focused = false'\n  }\n})\nexport class NgbRadio implements OnDestroy {\n  private _checked: boolean;\n  private _disabled: boolean;\n  private _value: any = null;\n\n  /**\n   * The value for the 'name' property of the input element.\n   *\n   * All inputs of the radio group should have the same name. If not specified,\n   * the name of the enclosing group is used.\n   */\n  @Input() name: string;\n\n  /**\n   * The form control value when current radio button is checked.\n   */\n  @Input('value')\n  set value(value: any) {\n    this._value = value;\n    const stringValue = value ? value.toString() : '';\n    this._renderer.setProperty(this._element.nativeElement, 'value', stringValue);\n    this._group.onRadioValueUpdate();\n  }\n\n  /**\n   * If `true`, current radio button will be disabled.\n   */\n  @Input('disabled')\n  set disabled(isDisabled: boolean) {\n    this._disabled = isDisabled !== false;\n    this.updateDisabled();\n  }\n\n  set focused(isFocused: boolean) {\n    if (this._label) {\n      this._label.focused = isFocused;\n    }\n    if (!isFocused) {\n      this._group.onTouched();\n    }\n  }\n\n  get checked() { return this._checked; }\n\n  get disabled() { return this._group.disabled || this._disabled; }\n\n  get value() { return this._value; }\n\n  get nameAttr() { return this.name || this._group.name; }\n\n  constructor(\n      private _group: NgbRadioGroup, private _label: NgbButtonLabel, private _renderer: Renderer2,\n      private _element: ElementRef<HTMLInputElement>, private _cd: ChangeDetectorRef) {\n    this._group.register(this);\n    this.updateDisabled();\n  }\n\n  ngOnDestroy() { this._group.unregister(this); }\n\n  onChange() { this._group.onRadioChange(this); }\n\n  updateValue(value) {\n    // label won't be updated, if it is inside the OnPush component when [ngModel] changes\n    if (this.value !== value) {\n      this._cd.markForCheck();\n    }\n\n    this._checked = this.value === value;\n    this._label.active = this._checked;\n  }\n\n  updateDisabled() { this._label.disabled = this.disabled; }\n}\n"]}