bar.component.js 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. import { Component, Host, HostBinding, Input, ElementRef, Renderer2 } from '@angular/core';
  6. import { ProgressbarComponent } from './progressbar.component';
  7. import { isBs3 } from 'ngx-bootstrap/utils';
  8. // todo: number pipe
  9. // todo: use query from progress?
  10. export class BarComponent {
  11. /**
  12. * @param {?} el
  13. * @param {?} progress
  14. * @param {?} renderer
  15. */
  16. constructor(el, progress, renderer) {
  17. this.el = el;
  18. this.renderer = renderer;
  19. this.addClass = true;
  20. this.percent = 0;
  21. this.progress = progress;
  22. }
  23. /**
  24. * provide one of the four supported contextual classes: `success`, `info`, `warning`, `danger`
  25. * @return {?}
  26. */
  27. get type() {
  28. return this._type;
  29. }
  30. /**
  31. * @param {?} v
  32. * @return {?}
  33. */
  34. set type(v) {
  35. this._type = v;
  36. this.applyTypeClasses();
  37. }
  38. /**
  39. * current value of progress bar
  40. * @return {?}
  41. */
  42. get value() {
  43. return this._value;
  44. }
  45. /**
  46. * @param {?} v
  47. * @return {?}
  48. */
  49. set value(v) {
  50. if (!v && v !== 0) {
  51. return;
  52. }
  53. this._value = v;
  54. this.recalculatePercentage();
  55. }
  56. /**
  57. * @return {?}
  58. */
  59. get setBarWidth() {
  60. this.recalculatePercentage();
  61. return this.percent;
  62. }
  63. /**
  64. * @return {?}
  65. */
  66. get isBs3() {
  67. return isBs3();
  68. }
  69. /**
  70. * @return {?}
  71. */
  72. ngOnInit() {
  73. this.progress.addBar(this);
  74. }
  75. /**
  76. * @return {?}
  77. */
  78. ngOnDestroy() {
  79. this.progress.removeBar(this);
  80. }
  81. /**
  82. * @return {?}
  83. */
  84. recalculatePercentage() {
  85. this.percent = +(this.value / this.progress.max * 100).toFixed(2);
  86. /** @type {?} */
  87. const totalPercentage = this.progress.bars
  88. .reduce((/**
  89. * @param {?} total
  90. * @param {?} bar
  91. * @return {?}
  92. */
  93. function (total, bar) {
  94. return total + bar.percent;
  95. }), 0);
  96. if (totalPercentage > 100) {
  97. this.percent -= totalPercentage - 100;
  98. }
  99. }
  100. /**
  101. * @private
  102. * @return {?}
  103. */
  104. applyTypeClasses() {
  105. if (this._prevType) {
  106. /** @type {?} */
  107. const barTypeClass = `progress-bar-${this._prevType}`;
  108. /** @type {?} */
  109. const bgClass = `bg-${this._prevType}`;
  110. this.renderer.removeClass(this.el.nativeElement, barTypeClass);
  111. this.renderer.removeClass(this.el.nativeElement, bgClass);
  112. this._prevType = null;
  113. }
  114. if (this._type) {
  115. /** @type {?} */
  116. const barTypeClass = `progress-bar-${this._type}`;
  117. /** @type {?} */
  118. const bgClass = `bg-${this._type}`;
  119. this.renderer.addClass(this.el.nativeElement, barTypeClass);
  120. this.renderer.addClass(this.el.nativeElement, bgClass);
  121. this._prevType = this._type;
  122. }
  123. }
  124. }
  125. BarComponent.decorators = [
  126. { type: Component, args: [{
  127. selector: 'bar',
  128. template: "<ng-content></ng-content>\n",
  129. host: {
  130. role: 'progressbar',
  131. 'aria-valuemin': '0',
  132. '[class.progress-bar-animated]': '!isBs3 && animate',
  133. '[class.progress-bar-striped]': 'striped',
  134. '[class.active]': 'isBs3 && animate',
  135. '[attr.aria-valuenow]': 'value',
  136. '[attr.aria-valuetext]': 'percent ? percent.toFixed(0) + "%" : ""',
  137. '[attr.aria-valuemax]': 'max',
  138. '[style.height.%]': '"100"'
  139. }
  140. }] }
  141. ];
  142. /** @nocollapse */
  143. BarComponent.ctorParameters = () => [
  144. { type: ElementRef },
  145. { type: ProgressbarComponent, decorators: [{ type: Host }] },
  146. { type: Renderer2 }
  147. ];
  148. BarComponent.propDecorators = {
  149. type: [{ type: Input }],
  150. value: [{ type: Input }],
  151. setBarWidth: [{ type: HostBinding, args: ['style.width.%',] }],
  152. addClass: [{ type: HostBinding, args: ['class.progress-bar',] }]
  153. };
  154. if (false) {
  155. /** @type {?} */
  156. BarComponent.prototype.max;
  157. /** @type {?} */
  158. BarComponent.prototype.addClass;
  159. /** @type {?} */
  160. BarComponent.prototype.striped;
  161. /** @type {?} */
  162. BarComponent.prototype.animate;
  163. /** @type {?} */
  164. BarComponent.prototype.percent;
  165. /** @type {?} */
  166. BarComponent.prototype.progress;
  167. /**
  168. * @type {?}
  169. * @protected
  170. */
  171. BarComponent.prototype._value;
  172. /**
  173. * @type {?}
  174. * @protected
  175. */
  176. BarComponent.prototype._type;
  177. /**
  178. * @type {?}
  179. * @private
  180. */
  181. BarComponent.prototype._prevType;
  182. /**
  183. * @type {?}
  184. * @private
  185. */
  186. BarComponent.prototype.el;
  187. /**
  188. * @type {?}
  189. * @private
  190. */
  191. BarComponent.prototype.renderer;
  192. }
  193. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bar.component.js","sourceRoot":"ng://ngx-bootstrap/progressbar/","sources":["bar.component.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EACL,SAAS,EACT,IAAI,EACJ,WAAW,EACX,KAAK,EAGL,UAAU,EACV,SAAS,EACV,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,oBAAoB,EAAE,MAAM,yBAAyB,CAAC;AAC/D,OAAO,EAAE,KAAK,EAAE,MAAM,qBAAqB,CAAC;;;AAmB5C,MAAM,OAAO,YAAY;;;;;;IAkDvB,YACU,EAAc,EACd,QAA8B,EAC9B,QAAmB;QAFnB,OAAE,GAAF,EAAE,CAAY;QAEd,aAAQ,GAAR,QAAQ,CAAW;QAlBM,aAAQ,GAAG,IAAI,CAAC;QAQnD,YAAO,GAAG,CAAC,CAAC;QAYV,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAC3B,CAAC;;;;;IApDD,IACI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;;;;;IAED,IAAI,IAAI,CAAC,CAAS;QAChB,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;QACf,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;;;;;IAGD,IACI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;;;;;IAED,IAAI,KAAK,CAAC,CAAS;QACjB,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;YACjB,OAAO;SACR;QACD,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;QAChB,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,CAAC;;;;IAED,IACI,WAAW;QACb,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAE7B,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;;;;IAID,IAAI,KAAK;QACP,OAAO,KAAK,EAAE,CAAC;IACjB,CAAC;;;;IAmBD,QAAQ;QACN,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;;;;IAED,WAAW;QACT,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC;;;;IAED,qBAAqB;QACnB,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;;cAE5D,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI;aACvC,MAAM;;;;;QAAC,UAAU,KAAa,EAAE,GAAiB;YAChD,OAAO,KAAK,GAAG,GAAG,CAAC,OAAO,CAAC;QAC7B,CAAC,GAAE,CAAC,CAAC;QAEP,IAAI,eAAe,GAAG,GAAG,EAAE;YACzB,IAAI,CAAC,OAAO,IAAI,eAAe,GAAG,GAAG,CAAC;SACvC;IACH,CAAC;;;;;IAEO,gBAAgB;QACtB,IAAI,IAAI,CAAC,SAAS,EAAE;;kBACZ,YAAY,GAAG,gBAAgB,IAAI,CAAC,SAAS,EAAE;;kBAC/C,OAAO,GAAG,MAAM,IAAI,CAAC,SAAS,EAAE;YACtC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC;YAC/D,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;YAC1D,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;SACvB;QAED,IAAI,IAAI,CAAC,KAAK,EAAE;;kBACR,YAAY,GAAG,gBAAgB,IAAI,CAAC,KAAK,EAAE;;kBAC3C,OAAO,GAAG,MAAM,IAAI,CAAC,KAAK,EAAE;YAClC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC;YAC5D,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;YACvD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC;SAC7B;IACH,CAAC;;;YA9GF,SAAS,SAAC;gBACT,QAAQ,EAAE,KAAK;gBACf,uCAAmC;gBACnC,IAAI,EAAE;oBACJ,IAAI,EAAE,aAAa;oBACnB,eAAe,EAAE,GAAG;oBACpB,+BAA+B,EAAE,mBAAmB;oBACpD,8BAA8B,EAAE,SAAS;oBACzC,gBAAgB,EAAE,kBAAkB;oBACpC,sBAAsB,EAAE,OAAO;oBAC/B,uBAAuB,EAAE,yCAAyC;oBAClE,sBAAsB,EAAE,KAAK;oBAC7B,kBAAkB,EAAE,OAAO;iBAC5B;aACF;;;;YAvBC,UAAU;YAIH,oBAAoB,uBAwExB,IAAI;YA3EP,SAAS;;;mBA2BR,KAAK;oBAWL,KAAK;0BAaL,WAAW,SAAC,eAAe;uBAO3B,WAAW,SAAC,oBAAoB;;;;IAlCjC,2BAAY;;IAkCZ,gCAAmD;;IAMnD,+BAAiB;;IACjB,+BAAiB;;IACjB,+BAAY;;IACZ,gCAA+B;;;;;IAE/B,8BAAyB;;;;;IACzB,6BAAwB;;;;;IACxB,iCAA0B;;;;;IAGxB,0BAAsB;;;;;IAEtB,gCAA2B","sourcesContent":["import {\n  Component,\n  Host,\n  HostBinding,\n  Input,\n  OnDestroy,\n  OnInit,\n  ElementRef,\n  Renderer2\n} from '@angular/core';\n\nimport { ProgressbarComponent } from './progressbar.component';\nimport { isBs3 } from 'ngx-bootstrap/utils';\n\n// todo: number pipe\n// todo: use query from progress?\n@Component({\n  selector: 'bar',\n  templateUrl: './bar.component.html',\n  host: {\n    role: 'progressbar',\n    'aria-valuemin': '0',\n    '[class.progress-bar-animated]': '!isBs3 && animate',\n    '[class.progress-bar-striped]': 'striped',\n    '[class.active]': 'isBs3 && animate',\n    '[attr.aria-valuenow]': 'value',\n    '[attr.aria-valuetext]': 'percent ? percent.toFixed(0) + \"%\" : \"\"',\n    '[attr.aria-valuemax]': 'max',\n    '[style.height.%]': '\"100\"'\n  }\n})\nexport class BarComponent implements OnInit, OnDestroy {\n  max: number;\n\n  /** provide one of the four supported contextual classes: `success`, `info`, `warning`, `danger` */\n  @Input()\n  get type(): string {\n    return this._type;\n  }\n\n  set type(v: string) {\n    this._type = v;\n    this.applyTypeClasses();\n  }\n\n  /** current value of progress bar */\n  @Input()\n  get value(): number {\n    return this._value;\n  }\n\n  set value(v: number) {\n    if (!v && v !== 0) {\n      return;\n    }\n    this._value = v;\n    this.recalculatePercentage();\n  }\n\n  @HostBinding('style.width.%')\n  get setBarWidth() {\n    this.recalculatePercentage();\n\n    return this.percent;\n  }\n\n  @HostBinding('class.progress-bar') addClass = true;\n\n  get isBs3(): boolean {\n    return isBs3();\n  }\n\n  striped: boolean;\n  animate: boolean;\n  percent = 0;\n  progress: ProgressbarComponent;\n\n  protected _value: number;\n  protected _type: string;\n  private _prevType: string;\n\n  constructor(\n    private el: ElementRef,\n    @Host() progress: ProgressbarComponent,\n    private renderer: Renderer2\n  ) {\n    this.progress = progress;\n  }\n\n  ngOnInit(): void {\n    this.progress.addBar(this);\n  }\n\n  ngOnDestroy(): void {\n    this.progress.removeBar(this);\n  }\n\n  recalculatePercentage(): void {\n    this.percent = +(this.value / this.progress.max * 100).toFixed(2);\n\n    const totalPercentage = this.progress.bars\n      .reduce(function (total: number, bar: BarComponent): number {\n        return total + bar.percent;\n      }, 0);\n\n    if (totalPercentage > 100) {\n      this.percent -= totalPercentage - 100;\n    }\n  }\n\n  private applyTypeClasses(): void {\n    if (this._prevType) {\n      const barTypeClass = `progress-bar-${this._prevType}`;\n      const bgClass = `bg-${this._prevType}`;\n      this.renderer.removeClass(this.el.nativeElement, barTypeClass);\n      this.renderer.removeClass(this.el.nativeElement, bgClass);\n      this._prevType = null;\n    }\n\n    if (this._type) {\n      const barTypeClass = `progress-bar-${this._type}`;\n      const bgClass = `bg-${this._type}`;\n      this.renderer.addClass(this.el.nativeElement, barTypeClass);\n      this.renderer.addClass(this.el.nativeElement, bgClass);\n      this._prevType = this._type;\n    }\n  }\n}\n"]}