bar.component.js 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221
  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. var BarComponent = /** @class */ (function () {
  11. function BarComponent(el, progress, renderer) {
  12. this.el = el;
  13. this.renderer = renderer;
  14. this.addClass = true;
  15. this.percent = 0;
  16. this.progress = progress;
  17. }
  18. Object.defineProperty(BarComponent.prototype, "type", {
  19. /** provide one of the four supported contextual classes: `success`, `info`, `warning`, `danger` */
  20. get: /**
  21. * provide one of the four supported contextual classes: `success`, `info`, `warning`, `danger`
  22. * @return {?}
  23. */
  24. function () {
  25. return this._type;
  26. },
  27. set: /**
  28. * @param {?} v
  29. * @return {?}
  30. */
  31. function (v) {
  32. this._type = v;
  33. this.applyTypeClasses();
  34. },
  35. enumerable: true,
  36. configurable: true
  37. });
  38. Object.defineProperty(BarComponent.prototype, "value", {
  39. /** current value of progress bar */
  40. get: /**
  41. * current value of progress bar
  42. * @return {?}
  43. */
  44. function () {
  45. return this._value;
  46. },
  47. set: /**
  48. * @param {?} v
  49. * @return {?}
  50. */
  51. function (v) {
  52. if (!v && v !== 0) {
  53. return;
  54. }
  55. this._value = v;
  56. this.recalculatePercentage();
  57. },
  58. enumerable: true,
  59. configurable: true
  60. });
  61. Object.defineProperty(BarComponent.prototype, "setBarWidth", {
  62. get: /**
  63. * @return {?}
  64. */
  65. function () {
  66. this.recalculatePercentage();
  67. return this.percent;
  68. },
  69. enumerable: true,
  70. configurable: true
  71. });
  72. Object.defineProperty(BarComponent.prototype, "isBs3", {
  73. get: /**
  74. * @return {?}
  75. */
  76. function () {
  77. return isBs3();
  78. },
  79. enumerable: true,
  80. configurable: true
  81. });
  82. /**
  83. * @return {?}
  84. */
  85. BarComponent.prototype.ngOnInit = /**
  86. * @return {?}
  87. */
  88. function () {
  89. this.progress.addBar(this);
  90. };
  91. /**
  92. * @return {?}
  93. */
  94. BarComponent.prototype.ngOnDestroy = /**
  95. * @return {?}
  96. */
  97. function () {
  98. this.progress.removeBar(this);
  99. };
  100. /**
  101. * @return {?}
  102. */
  103. BarComponent.prototype.recalculatePercentage = /**
  104. * @return {?}
  105. */
  106. function () {
  107. this.percent = +(this.value / this.progress.max * 100).toFixed(2);
  108. /** @type {?} */
  109. var totalPercentage = this.progress.bars
  110. .reduce((/**
  111. * @param {?} total
  112. * @param {?} bar
  113. * @return {?}
  114. */
  115. function (total, bar) {
  116. return total + bar.percent;
  117. }), 0);
  118. if (totalPercentage > 100) {
  119. this.percent -= totalPercentage - 100;
  120. }
  121. };
  122. /**
  123. * @private
  124. * @return {?}
  125. */
  126. BarComponent.prototype.applyTypeClasses = /**
  127. * @private
  128. * @return {?}
  129. */
  130. function () {
  131. if (this._prevType) {
  132. /** @type {?} */
  133. var barTypeClass = "progress-bar-" + this._prevType;
  134. /** @type {?} */
  135. var bgClass = "bg-" + this._prevType;
  136. this.renderer.removeClass(this.el.nativeElement, barTypeClass);
  137. this.renderer.removeClass(this.el.nativeElement, bgClass);
  138. this._prevType = null;
  139. }
  140. if (this._type) {
  141. /** @type {?} */
  142. var barTypeClass = "progress-bar-" + this._type;
  143. /** @type {?} */
  144. var bgClass = "bg-" + this._type;
  145. this.renderer.addClass(this.el.nativeElement, barTypeClass);
  146. this.renderer.addClass(this.el.nativeElement, bgClass);
  147. this._prevType = this._type;
  148. }
  149. };
  150. BarComponent.decorators = [
  151. { type: Component, args: [{
  152. selector: 'bar',
  153. template: "<ng-content></ng-content>\n",
  154. host: {
  155. role: 'progressbar',
  156. 'aria-valuemin': '0',
  157. '[class.progress-bar-animated]': '!isBs3 && animate',
  158. '[class.progress-bar-striped]': 'striped',
  159. '[class.active]': 'isBs3 && animate',
  160. '[attr.aria-valuenow]': 'value',
  161. '[attr.aria-valuetext]': 'percent ? percent.toFixed(0) + "%" : ""',
  162. '[attr.aria-valuemax]': 'max',
  163. '[style.height.%]': '"100"'
  164. }
  165. }] }
  166. ];
  167. /** @nocollapse */
  168. BarComponent.ctorParameters = function () { return [
  169. { type: ElementRef },
  170. { type: ProgressbarComponent, decorators: [{ type: Host }] },
  171. { type: Renderer2 }
  172. ]; };
  173. BarComponent.propDecorators = {
  174. type: [{ type: Input }],
  175. value: [{ type: Input }],
  176. setBarWidth: [{ type: HostBinding, args: ['style.width.%',] }],
  177. addClass: [{ type: HostBinding, args: ['class.progress-bar',] }]
  178. };
  179. return BarComponent;
  180. }());
  181. export { BarComponent };
  182. if (false) {
  183. /** @type {?} */
  184. BarComponent.prototype.max;
  185. /** @type {?} */
  186. BarComponent.prototype.addClass;
  187. /** @type {?} */
  188. BarComponent.prototype.striped;
  189. /** @type {?} */
  190. BarComponent.prototype.animate;
  191. /** @type {?} */
  192. BarComponent.prototype.percent;
  193. /** @type {?} */
  194. BarComponent.prototype.progress;
  195. /**
  196. * @type {?}
  197. * @protected
  198. */
  199. BarComponent.prototype._value;
  200. /**
  201. * @type {?}
  202. * @protected
  203. */
  204. BarComponent.prototype._type;
  205. /**
  206. * @type {?}
  207. * @private
  208. */
  209. BarComponent.prototype._prevType;
  210. /**
  211. * @type {?}
  212. * @private
  213. */
  214. BarComponent.prototype.el;
  215. /**
  216. * @type {?}
  217. * @private
  218. */
  219. BarComponent.prototype.renderer;
  220. }
  221. //# 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;;;AAI5C;IAiEE,sBACU,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,sBACI,8BAAI;QAFR,mGAAmG;;;;;QACnG;YAEE,OAAO,IAAI,CAAC,KAAK,CAAC;QACpB,CAAC;;;;;QAED,UAAS,CAAS;YAChB,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;YACf,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC1B,CAAC;;;OALA;IAQD,sBACI,+BAAK;QAFT,oCAAoC;;;;;QACpC;YAEE,OAAO,IAAI,CAAC,MAAM,CAAC;QACrB,CAAC;;;;;QAED,UAAU,CAAS;YACjB,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;gBACjB,OAAO;aACR;YACD,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;YAChB,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC/B,CAAC;;;OARA;IAUD,sBACI,qCAAW;;;;QADf;YAEE,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAE7B,OAAO,IAAI,CAAC,OAAO,CAAC;QACtB,CAAC;;;OAAA;IAID,sBAAI,+BAAK;;;;QAAT;YACE,OAAO,KAAK,EAAE,CAAC;QACjB,CAAC;;;OAAA;;;;IAmBD,+BAAQ;;;IAAR;QACE,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;;;;IAED,kCAAW;;;IAAX;QACE,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC;;;;IAED,4CAAqB;;;IAArB;QACE,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;;YAE5D,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,uCAAgB;;;;IAAxB;QACE,IAAI,IAAI,CAAC,SAAS,EAAE;;gBACZ,YAAY,GAAG,kBAAgB,IAAI,CAAC,SAAW;;gBAC/C,OAAO,GAAG,QAAM,IAAI,CAAC,SAAW;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;;gBACR,YAAY,GAAG,kBAAgB,IAAI,CAAC,KAAO;;gBAC3C,OAAO,GAAG,QAAM,IAAI,CAAC,KAAO;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;;gBA9GF,SAAS,SAAC;oBACT,QAAQ,EAAE,KAAK;oBACf,uCAAmC;oBACnC,IAAI,EAAE;wBACJ,IAAI,EAAE,aAAa;wBACnB,eAAe,EAAE,GAAG;wBACpB,+BAA+B,EAAE,mBAAmB;wBACpD,8BAA8B,EAAE,SAAS;wBACzC,gBAAgB,EAAE,kBAAkB;wBACpC,sBAAsB,EAAE,OAAO;wBAC/B,uBAAuB,EAAE,yCAAyC;wBAClE,sBAAsB,EAAE,KAAK;wBAC7B,kBAAkB,EAAE,OAAO;qBAC5B;iBACF;;;;gBAvBC,UAAU;gBAIH,oBAAoB,uBAwExB,IAAI;gBA3EP,SAAS;;;uBA2BR,KAAK;wBAWL,KAAK;8BAaL,WAAW,SAAC,eAAe;2BAO3B,WAAW,SAAC,oBAAoB;;IA6DnC,mBAAC;CAAA,AA/GD,IA+GC;SAhGY,YAAY;;;IACvB,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"]}