radio.js 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333
  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. const NGB_RADIO_VALUE_ACCESSOR = {
  10. provide: NG_VALUE_ACCESSOR,
  11. useExisting: forwardRef((/**
  12. * @return {?}
  13. */
  14. () => NgbRadioGroup)),
  15. multi: true
  16. };
  17. /** @type {?} */
  18. let 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. export class NgbRadioGroup {
  26. constructor() {
  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. (_) => { });
  43. this.onTouched = (/**
  44. * @return {?}
  45. */
  46. () => { });
  47. }
  48. /**
  49. * @return {?}
  50. */
  51. get disabled() { return this._disabled; }
  52. /**
  53. * @param {?} isDisabled
  54. * @return {?}
  55. */
  56. set disabled(isDisabled) { this.setDisabledState(isDisabled); }
  57. /**
  58. * @param {?} radio
  59. * @return {?}
  60. */
  61. onRadioChange(radio) {
  62. this.writeValue(radio.value);
  63. this.onChange(radio.value);
  64. }
  65. /**
  66. * @return {?}
  67. */
  68. onRadioValueUpdate() { this._updateRadiosValue(); }
  69. /**
  70. * @param {?} radio
  71. * @return {?}
  72. */
  73. register(radio) { this._radios.add(radio); }
  74. /**
  75. * @param {?} fn
  76. * @return {?}
  77. */
  78. registerOnChange(fn) { this.onChange = fn; }
  79. /**
  80. * @param {?} fn
  81. * @return {?}
  82. */
  83. registerOnTouched(fn) { this.onTouched = fn; }
  84. /**
  85. * @param {?} isDisabled
  86. * @return {?}
  87. */
  88. setDisabledState(isDisabled) {
  89. this._disabled = isDisabled;
  90. this._updateRadiosDisabled();
  91. }
  92. /**
  93. * @param {?} radio
  94. * @return {?}
  95. */
  96. unregister(radio) { this._radios.delete(radio); }
  97. /**
  98. * @param {?} value
  99. * @return {?}
  100. */
  101. writeValue(value) {
  102. this._value = value;
  103. this._updateRadiosValue();
  104. }
  105. /**
  106. * @private
  107. * @return {?}
  108. */
  109. _updateRadiosValue() { this._radios.forEach((/**
  110. * @param {?} radio
  111. * @return {?}
  112. */
  113. (radio) => radio.updateValue(this._value))); }
  114. /**
  115. * @private
  116. * @return {?}
  117. */
  118. _updateRadiosDisabled() { this._radios.forEach((/**
  119. * @param {?} radio
  120. * @return {?}
  121. */
  122. (radio) => radio.updateDisabled())); }
  123. }
  124. NgbRadioGroup.decorators = [
  125. { type: Directive, args: [{ selector: '[ngbRadioGroup]', host: { 'role': 'radiogroup' }, providers: [NGB_RADIO_VALUE_ACCESSOR] },] }
  126. ];
  127. NgbRadioGroup.propDecorators = {
  128. name: [{ type: Input }]
  129. };
  130. if (false) {
  131. /**
  132. * @type {?}
  133. * @private
  134. */
  135. NgbRadioGroup.prototype._radios;
  136. /**
  137. * @type {?}
  138. * @private
  139. */
  140. NgbRadioGroup.prototype._value;
  141. /**
  142. * @type {?}
  143. * @private
  144. */
  145. NgbRadioGroup.prototype._disabled;
  146. /**
  147. * Name of the radio group applied to radio input elements.
  148. *
  149. * Will be applied to all radio input elements inside the group,
  150. * unless [`NgbRadio`](#/components/buttons/api#NgbRadio)'s specify names themselves.
  151. *
  152. * If not provided, will be generated in the `ngb-radio-xx` format.
  153. * @type {?}
  154. */
  155. NgbRadioGroup.prototype.name;
  156. /** @type {?} */
  157. NgbRadioGroup.prototype.onChange;
  158. /** @type {?} */
  159. NgbRadioGroup.prototype.onTouched;
  160. }
  161. /**
  162. * A directive that marks an input of type "radio" as a part of the
  163. * [`NgbRadioGroup`](#/components/buttons/api#NgbRadioGroup).
  164. */
  165. export class NgbRadio {
  166. /**
  167. * @param {?} _group
  168. * @param {?} _label
  169. * @param {?} _renderer
  170. * @param {?} _element
  171. * @param {?} _cd
  172. */
  173. constructor(_group, _label, _renderer, _element, _cd) {
  174. this._group = _group;
  175. this._label = _label;
  176. this._renderer = _renderer;
  177. this._element = _element;
  178. this._cd = _cd;
  179. this._value = null;
  180. this._group.register(this);
  181. this.updateDisabled();
  182. }
  183. /**
  184. * The form control value when current radio button is checked.
  185. * @param {?} value
  186. * @return {?}
  187. */
  188. set value(value) {
  189. this._value = value;
  190. /** @type {?} */
  191. const stringValue = value ? value.toString() : '';
  192. this._renderer.setProperty(this._element.nativeElement, 'value', stringValue);
  193. this._group.onRadioValueUpdate();
  194. }
  195. /**
  196. * If `true`, current radio button will be disabled.
  197. * @param {?} isDisabled
  198. * @return {?}
  199. */
  200. set disabled(isDisabled) {
  201. this._disabled = isDisabled !== false;
  202. this.updateDisabled();
  203. }
  204. /**
  205. * @param {?} isFocused
  206. * @return {?}
  207. */
  208. set focused(isFocused) {
  209. if (this._label) {
  210. this._label.focused = isFocused;
  211. }
  212. if (!isFocused) {
  213. this._group.onTouched();
  214. }
  215. }
  216. /**
  217. * @return {?}
  218. */
  219. get checked() { return this._checked; }
  220. /**
  221. * @return {?}
  222. */
  223. get disabled() { return this._group.disabled || this._disabled; }
  224. /**
  225. * @return {?}
  226. */
  227. get value() { return this._value; }
  228. /**
  229. * @return {?}
  230. */
  231. get nameAttr() { return this.name || this._group.name; }
  232. /**
  233. * @return {?}
  234. */
  235. ngOnDestroy() { this._group.unregister(this); }
  236. /**
  237. * @return {?}
  238. */
  239. onChange() { this._group.onRadioChange(this); }
  240. /**
  241. * @param {?} value
  242. * @return {?}
  243. */
  244. updateValue(value) {
  245. // label won't be updated, if it is inside the OnPush component when [ngModel] changes
  246. if (this.value !== value) {
  247. this._cd.markForCheck();
  248. }
  249. this._checked = this.value === value;
  250. this._label.active = this._checked;
  251. }
  252. /**
  253. * @return {?}
  254. */
  255. updateDisabled() { this._label.disabled = this.disabled; }
  256. }
  257. NgbRadio.decorators = [
  258. { type: Directive, args: [{
  259. selector: '[ngbButton][type=radio]',
  260. host: {
  261. '[checked]': 'checked',
  262. '[disabled]': 'disabled',
  263. '[name]': 'nameAttr',
  264. '(change)': 'onChange()',
  265. '(focus)': 'focused = true',
  266. '(blur)': 'focused = false'
  267. }
  268. },] }
  269. ];
  270. /** @nocollapse */
  271. NgbRadio.ctorParameters = () => [
  272. { type: NgbRadioGroup },
  273. { type: NgbButtonLabel },
  274. { type: Renderer2 },
  275. { type: ElementRef },
  276. { type: ChangeDetectorRef }
  277. ];
  278. NgbRadio.propDecorators = {
  279. name: [{ type: Input }],
  280. value: [{ type: Input, args: ['value',] }],
  281. disabled: [{ type: Input, args: ['disabled',] }]
  282. };
  283. if (false) {
  284. /**
  285. * @type {?}
  286. * @private
  287. */
  288. NgbRadio.prototype._checked;
  289. /**
  290. * @type {?}
  291. * @private
  292. */
  293. NgbRadio.prototype._disabled;
  294. /**
  295. * @type {?}
  296. * @private
  297. */
  298. NgbRadio.prototype._value;
  299. /**
  300. * The value for the 'name' property of the input element.
  301. *
  302. * All inputs of the radio group should have the same name. If not specified,
  303. * the name of the enclosing group is used.
  304. * @type {?}
  305. */
  306. NgbRadio.prototype.name;
  307. /**
  308. * @type {?}
  309. * @private
  310. */
  311. NgbRadio.prototype._group;
  312. /**
  313. * @type {?}
  314. * @private
  315. */
  316. NgbRadio.prototype._label;
  317. /**
  318. * @type {?}
  319. * @private
  320. */
  321. NgbRadio.prototype._renderer;
  322. /**
  323. * @type {?}
  324. * @private
  325. */
  326. NgbRadio.prototype._element;
  327. /**
  328. * @type {?}
  329. * @private
  330. */
  331. NgbRadio.prototype._cd;
  332. }
  333. //# 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"]}