rating.js 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, EventEmitter, forwardRef, Input, Output, TemplateRef, ViewEncapsulation } from '@angular/core';
  6. import { NgbRatingConfig } from './rating-config';
  7. import { getValueInRange } from '../util/util';
  8. import { Key } from '../util/key';
  9. import { NG_VALUE_ACCESSOR } from '@angular/forms';
  10. /**
  11. * The context for the custom star display template defined in the `starTemplate`.
  12. * @record
  13. */
  14. export function StarTemplateContext() { }
  15. if (false) {
  16. /**
  17. * The star fill percentage, an integer in the `[0, 100]` range.
  18. * @type {?}
  19. */
  20. StarTemplateContext.prototype.fill;
  21. /**
  22. * Index of the star, starts with `0`.
  23. * @type {?}
  24. */
  25. StarTemplateContext.prototype.index;
  26. }
  27. /** @type {?} */
  28. var NGB_RATING_VALUE_ACCESSOR = {
  29. provide: NG_VALUE_ACCESSOR,
  30. useExisting: forwardRef((/**
  31. * @return {?}
  32. */
  33. function () { return NgbRating; })),
  34. multi: true
  35. };
  36. /**
  37. * A directive that helps visualising and interacting with a star rating bar.
  38. */
  39. var NgbRating = /** @class */ (function () {
  40. function NgbRating(config, _changeDetectorRef) {
  41. this._changeDetectorRef = _changeDetectorRef;
  42. this.contexts = [];
  43. this.disabled = false;
  44. /**
  45. * An event emitted when the user is hovering over a given rating.
  46. *
  47. * Event payload equals to the rating being hovered over.
  48. */
  49. this.hover = new EventEmitter();
  50. /**
  51. * An event emitted when the user stops hovering over a given rating.
  52. *
  53. * Event payload equals to the rating of the last item being hovered over.
  54. */
  55. this.leave = new EventEmitter();
  56. /**
  57. * An event emitted when the user selects a new rating.
  58. *
  59. * Event payload equals to the newly selected rating.
  60. */
  61. this.rateChange = new EventEmitter(true);
  62. this.onChange = (/**
  63. * @param {?} _
  64. * @return {?}
  65. */
  66. function (_) { });
  67. this.onTouched = (/**
  68. * @return {?}
  69. */
  70. function () { });
  71. this.max = config.max;
  72. this.readonly = config.readonly;
  73. }
  74. /**
  75. * @return {?}
  76. */
  77. NgbRating.prototype.ariaValueText = /**
  78. * @return {?}
  79. */
  80. function () { return this.nextRate + " out of " + this.max; };
  81. /**
  82. * @param {?} value
  83. * @return {?}
  84. */
  85. NgbRating.prototype.enter = /**
  86. * @param {?} value
  87. * @return {?}
  88. */
  89. function (value) {
  90. if (!this.readonly && !this.disabled) {
  91. this._updateState(value);
  92. }
  93. this.hover.emit(value);
  94. };
  95. /**
  96. * @return {?}
  97. */
  98. NgbRating.prototype.handleBlur = /**
  99. * @return {?}
  100. */
  101. function () { this.onTouched(); };
  102. /**
  103. * @param {?} value
  104. * @return {?}
  105. */
  106. NgbRating.prototype.handleClick = /**
  107. * @param {?} value
  108. * @return {?}
  109. */
  110. function (value) { this.update(this.resettable && this.rate === value ? 0 : value); };
  111. /**
  112. * @param {?} event
  113. * @return {?}
  114. */
  115. NgbRating.prototype.handleKeyDown = /**
  116. * @param {?} event
  117. * @return {?}
  118. */
  119. function (event) {
  120. // tslint:disable-next-line:deprecation
  121. switch (event.which) {
  122. case Key.ArrowDown:
  123. case Key.ArrowLeft:
  124. this.update(this.rate - 1);
  125. break;
  126. case Key.ArrowUp:
  127. case Key.ArrowRight:
  128. this.update(this.rate + 1);
  129. break;
  130. case Key.Home:
  131. this.update(0);
  132. break;
  133. case Key.End:
  134. this.update(this.max);
  135. break;
  136. default:
  137. return;
  138. }
  139. // note 'return' in default case
  140. event.preventDefault();
  141. };
  142. /**
  143. * @param {?} changes
  144. * @return {?}
  145. */
  146. NgbRating.prototype.ngOnChanges = /**
  147. * @param {?} changes
  148. * @return {?}
  149. */
  150. function (changes) {
  151. if (changes['rate']) {
  152. this.update(this.rate);
  153. }
  154. };
  155. /**
  156. * @return {?}
  157. */
  158. NgbRating.prototype.ngOnInit = /**
  159. * @return {?}
  160. */
  161. function () {
  162. this.contexts = Array.from({ length: this.max }, (/**
  163. * @param {?} v
  164. * @param {?} k
  165. * @return {?}
  166. */
  167. function (v, k) { return ({ fill: 0, index: k }); }));
  168. this._updateState(this.rate);
  169. };
  170. /**
  171. * @param {?} fn
  172. * @return {?}
  173. */
  174. NgbRating.prototype.registerOnChange = /**
  175. * @param {?} fn
  176. * @return {?}
  177. */
  178. function (fn) { this.onChange = fn; };
  179. /**
  180. * @param {?} fn
  181. * @return {?}
  182. */
  183. NgbRating.prototype.registerOnTouched = /**
  184. * @param {?} fn
  185. * @return {?}
  186. */
  187. function (fn) { this.onTouched = fn; };
  188. /**
  189. * @return {?}
  190. */
  191. NgbRating.prototype.reset = /**
  192. * @return {?}
  193. */
  194. function () {
  195. this.leave.emit(this.nextRate);
  196. this._updateState(this.rate);
  197. };
  198. /**
  199. * @param {?} isDisabled
  200. * @return {?}
  201. */
  202. NgbRating.prototype.setDisabledState = /**
  203. * @param {?} isDisabled
  204. * @return {?}
  205. */
  206. function (isDisabled) { this.disabled = isDisabled; };
  207. /**
  208. * @param {?} value
  209. * @param {?=} internalChange
  210. * @return {?}
  211. */
  212. NgbRating.prototype.update = /**
  213. * @param {?} value
  214. * @param {?=} internalChange
  215. * @return {?}
  216. */
  217. function (value, internalChange) {
  218. if (internalChange === void 0) { internalChange = true; }
  219. /** @type {?} */
  220. var newRate = getValueInRange(value, this.max, 0);
  221. if (!this.readonly && !this.disabled && this.rate !== newRate) {
  222. this.rate = newRate;
  223. this.rateChange.emit(this.rate);
  224. }
  225. if (internalChange) {
  226. this.onChange(this.rate);
  227. this.onTouched();
  228. }
  229. this._updateState(this.rate);
  230. };
  231. /**
  232. * @param {?} value
  233. * @return {?}
  234. */
  235. NgbRating.prototype.writeValue = /**
  236. * @param {?} value
  237. * @return {?}
  238. */
  239. function (value) {
  240. this.update(value, false);
  241. this._changeDetectorRef.markForCheck();
  242. };
  243. /**
  244. * @private
  245. * @param {?} index
  246. * @return {?}
  247. */
  248. NgbRating.prototype._getFillValue = /**
  249. * @private
  250. * @param {?} index
  251. * @return {?}
  252. */
  253. function (index) {
  254. /** @type {?} */
  255. var diff = this.nextRate - index;
  256. if (diff >= 1) {
  257. return 100;
  258. }
  259. if (diff < 1 && diff > 0) {
  260. return parseInt((diff * 100).toFixed(2), 10);
  261. }
  262. return 0;
  263. };
  264. /**
  265. * @private
  266. * @param {?} nextValue
  267. * @return {?}
  268. */
  269. NgbRating.prototype._updateState = /**
  270. * @private
  271. * @param {?} nextValue
  272. * @return {?}
  273. */
  274. function (nextValue) {
  275. var _this = this;
  276. this.nextRate = nextValue;
  277. this.contexts.forEach((/**
  278. * @param {?} context
  279. * @param {?} index
  280. * @return {?}
  281. */
  282. function (context, index) { return context.fill = _this._getFillValue(index); }));
  283. };
  284. NgbRating.decorators = [
  285. { type: Component, args: [{
  286. selector: 'ngb-rating',
  287. changeDetection: ChangeDetectionStrategy.OnPush,
  288. encapsulation: ViewEncapsulation.None,
  289. host: {
  290. 'class': 'd-inline-flex',
  291. 'tabindex': '0',
  292. 'role': 'slider',
  293. 'aria-valuemin': '0',
  294. '[attr.aria-valuemax]': 'max',
  295. '[attr.aria-valuenow]': 'nextRate',
  296. '[attr.aria-valuetext]': 'ariaValueText()',
  297. '[attr.aria-disabled]': 'readonly ? true : null',
  298. '(blur)': 'handleBlur()',
  299. '(keydown)': 'handleKeyDown($event)',
  300. '(mouseleave)': 'reset()'
  301. },
  302. template: "\n <ng-template #t let-fill=\"fill\">{{ fill === 100 ? '&#9733;' : '&#9734;' }}</ng-template>\n <ng-template ngFor [ngForOf]=\"contexts\" let-index=\"index\">\n <span class=\"sr-only\">({{ index < nextRate ? '*' : ' ' }})</span>\n <span (mouseenter)=\"enter(index + 1)\" (click)=\"handleClick(index + 1)\" [style.cursor]=\"readonly || disabled ? 'default' : 'pointer'\">\n <ng-template [ngTemplateOutlet]=\"starTemplate || starTemplateFromContent || t\" [ngTemplateOutletContext]=\"contexts[index]\">\n </ng-template>\n </span>\n </ng-template>\n ",
  303. providers: [NGB_RATING_VALUE_ACCESSOR]
  304. }] }
  305. ];
  306. /** @nocollapse */
  307. NgbRating.ctorParameters = function () { return [
  308. { type: NgbRatingConfig },
  309. { type: ChangeDetectorRef }
  310. ]; };
  311. NgbRating.propDecorators = {
  312. max: [{ type: Input }],
  313. rate: [{ type: Input }],
  314. readonly: [{ type: Input }],
  315. resettable: [{ type: Input }],
  316. starTemplate: [{ type: Input }],
  317. starTemplateFromContent: [{ type: ContentChild, args: [TemplateRef, { static: false },] }],
  318. hover: [{ type: Output }],
  319. leave: [{ type: Output }],
  320. rateChange: [{ type: Output }]
  321. };
  322. return NgbRating;
  323. }());
  324. export { NgbRating };
  325. if (false) {
  326. /** @type {?} */
  327. NgbRating.prototype.contexts;
  328. /** @type {?} */
  329. NgbRating.prototype.disabled;
  330. /** @type {?} */
  331. NgbRating.prototype.nextRate;
  332. /**
  333. * The maximal rating that can be given.
  334. * @type {?}
  335. */
  336. NgbRating.prototype.max;
  337. /**
  338. * The current rating. Could be a decimal value like `3.75`.
  339. * @type {?}
  340. */
  341. NgbRating.prototype.rate;
  342. /**
  343. * If `true`, the rating can't be changed.
  344. * @type {?}
  345. */
  346. NgbRating.prototype.readonly;
  347. /**
  348. * If `true`, the rating can be reset to `0` by mouse clicking currently set rating.
  349. * @type {?}
  350. */
  351. NgbRating.prototype.resettable;
  352. /**
  353. * The template to override the way each star is displayed.
  354. *
  355. * Alternatively put an `<ng-template>` as the only child of your `<ngb-rating>` element
  356. * @type {?}
  357. */
  358. NgbRating.prototype.starTemplate;
  359. /** @type {?} */
  360. NgbRating.prototype.starTemplateFromContent;
  361. /**
  362. * An event emitted when the user is hovering over a given rating.
  363. *
  364. * Event payload equals to the rating being hovered over.
  365. * @type {?}
  366. */
  367. NgbRating.prototype.hover;
  368. /**
  369. * An event emitted when the user stops hovering over a given rating.
  370. *
  371. * Event payload equals to the rating of the last item being hovered over.
  372. * @type {?}
  373. */
  374. NgbRating.prototype.leave;
  375. /**
  376. * An event emitted when the user selects a new rating.
  377. *
  378. * Event payload equals to the newly selected rating.
  379. * @type {?}
  380. */
  381. NgbRating.prototype.rateChange;
  382. /** @type {?} */
  383. NgbRating.prototype.onChange;
  384. /** @type {?} */
  385. NgbRating.prototype.onTouched;
  386. /**
  387. * @type {?}
  388. * @private
  389. */
  390. NgbRating.prototype._changeDetectorRef;
  391. }
  392. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rating.js","sourceRoot":"ng://@ng-bootstrap/ng-bootstrap/","sources":["rating/rating.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  EventEmitter,\n  forwardRef,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges,\n  TemplateRef,\n  ViewEncapsulation\n} from '@angular/core';\nimport {NgbRatingConfig} from './rating-config';\nimport {getValueInRange} from '../util/util';\nimport {Key} from '../util/key';\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from '@angular/forms';\n\n/**\n * The context for the custom star display template defined in the `starTemplate`.\n */\nexport interface StarTemplateContext {\n  /**\n   * The star fill percentage, an integer in the `[0, 100]` range.\n   */\n  fill: number;\n\n  /**\n   * Index of the star, starts with `0`.\n   */\n  index: number;\n}\n\nconst NGB_RATING_VALUE_ACCESSOR = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => NgbRating),\n  multi: true\n};\n\n/**\n * A directive that helps visualising and interacting with a star rating bar.\n */\n@Component({\n  selector: 'ngb-rating',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  host: {\n    'class': 'd-inline-flex',\n    'tabindex': '0',\n    'role': 'slider',\n    'aria-valuemin': '0',\n    '[attr.aria-valuemax]': 'max',\n    '[attr.aria-valuenow]': 'nextRate',\n    '[attr.aria-valuetext]': 'ariaValueText()',\n    '[attr.aria-disabled]': 'readonly ? true : null',\n    '(blur)': 'handleBlur()',\n    '(keydown)': 'handleKeyDown($event)',\n    '(mouseleave)': 'reset()'\n  },\n  template: `\n    <ng-template #t let-fill=\"fill\">{{ fill === 100 ? '&#9733;' : '&#9734;' }}</ng-template>\n    <ng-template ngFor [ngForOf]=\"contexts\" let-index=\"index\">\n      <span class=\"sr-only\">({{ index < nextRate ? '*' : ' ' }})</span>\n      <span (mouseenter)=\"enter(index + 1)\" (click)=\"handleClick(index + 1)\" [style.cursor]=\"readonly || disabled ? 'default' : 'pointer'\">\n        <ng-template [ngTemplateOutlet]=\"starTemplate || starTemplateFromContent || t\" [ngTemplateOutletContext]=\"contexts[index]\">\n        </ng-template>\n      </span>\n    </ng-template>\n  `,\n  providers: [NGB_RATING_VALUE_ACCESSOR]\n})\nexport class NgbRating implements ControlValueAccessor,\n    OnInit, OnChanges {\n  contexts: StarTemplateContext[] = [];\n  disabled = false;\n  nextRate: number;\n\n\n  /**\n   * The maximal rating that can be given.\n   */\n  @Input() max: number;\n\n  /**\n   * The current rating. Could be a decimal value like `3.75`.\n   */\n  @Input() rate: number;\n\n  /**\n   * If `true`, the rating can't be changed.\n   */\n  @Input() readonly: boolean;\n\n  /**\n   * If `true`, the rating can be reset to `0` by mouse clicking currently set rating.\n   */\n  @Input() resettable: boolean;\n\n  /**\n   * The template to override the way each star is displayed.\n   *\n   * Alternatively put an `<ng-template>` as the only child of your `<ngb-rating>` element\n   */\n  @Input() starTemplate: TemplateRef<StarTemplateContext>;\n  @ContentChild(TemplateRef, {static: false}) starTemplateFromContent: TemplateRef<StarTemplateContext>;\n\n  /**\n   * An event emitted when the user is hovering over a given rating.\n   *\n   * Event payload equals to the rating being hovered over.\n   */\n  @Output() hover = new EventEmitter<number>();\n\n  /**\n   * An event emitted when the user stops hovering over a given rating.\n   *\n   * Event payload equals to the rating of the last item being hovered over.\n   */\n  @Output() leave = new EventEmitter<number>();\n\n  /**\n   * An event emitted when the user selects a new rating.\n   *\n   * Event payload equals to the newly selected rating.\n   */\n  @Output() rateChange = new EventEmitter<number>(true);\n\n  onChange = (_: any) => {};\n  onTouched = () => {};\n\n  constructor(config: NgbRatingConfig, private _changeDetectorRef: ChangeDetectorRef) {\n    this.max = config.max;\n    this.readonly = config.readonly;\n  }\n\n  ariaValueText() { return `${this.nextRate} out of ${this.max}`; }\n\n  enter(value: number): void {\n    if (!this.readonly && !this.disabled) {\n      this._updateState(value);\n    }\n    this.hover.emit(value);\n  }\n\n  handleBlur() { this.onTouched(); }\n\n  handleClick(value: number) { this.update(this.resettable && this.rate === value ? 0 : value); }\n\n  handleKeyDown(event: KeyboardEvent) {\n    // tslint:disable-next-line:deprecation\n    switch (event.which) {\n      case Key.ArrowDown:\n      case Key.ArrowLeft:\n        this.update(this.rate - 1);\n        break;\n      case Key.ArrowUp:\n      case Key.ArrowRight:\n        this.update(this.rate + 1);\n        break;\n      case Key.Home:\n        this.update(0);\n        break;\n      case Key.End:\n        this.update(this.max);\n        break;\n      default:\n        return;\n    }\n\n    // note 'return' in default case\n    event.preventDefault();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['rate']) {\n      this.update(this.rate);\n    }\n  }\n\n  ngOnInit(): void {\n    this.contexts = Array.from({length: this.max}, (v, k) => ({fill: 0, index: k}));\n    this._updateState(this.rate);\n  }\n\n  registerOnChange(fn: (value: any) => any): void { this.onChange = fn; }\n\n  registerOnTouched(fn: () => any): void { this.onTouched = fn; }\n\n  reset(): void {\n    this.leave.emit(this.nextRate);\n    this._updateState(this.rate);\n  }\n\n  setDisabledState(isDisabled: boolean) { this.disabled = isDisabled; }\n\n  update(value: number, internalChange = true): void {\n    const newRate = getValueInRange(value, this.max, 0);\n    if (!this.readonly && !this.disabled && this.rate !== newRate) {\n      this.rate = newRate;\n      this.rateChange.emit(this.rate);\n    }\n    if (internalChange) {\n      this.onChange(this.rate);\n      this.onTouched();\n    }\n    this._updateState(this.rate);\n  }\n\n  writeValue(value) {\n    this.update(value, false);\n    this._changeDetectorRef.markForCheck();\n  }\n\n  private _getFillValue(index: number): number {\n    const diff = this.nextRate - index;\n\n    if (diff >= 1) {\n      return 100;\n    }\n    if (diff < 1 && diff > 0) {\n      return parseInt((diff * 100).toFixed(2), 10);\n    }\n\n    return 0;\n  }\n\n  private _updateState(nextValue: number) {\n    this.nextRate = nextValue;\n    this.contexts.forEach((context, index) => context.fill = this._getFillValue(index));\n  }\n}\n"]}