ngx-bootstrap 6.1.0 → 6.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (154) hide show
  1. package/CHANGELOG.md +27 -0
  2. package/accordion/bundles/ngx-bootstrap-accordion.umd.js.map +1 -1
  3. package/accordion/bundles/ngx-bootstrap-accordion.umd.min.js.map +1 -1
  4. package/accordion/fesm2015/ngx-bootstrap-accordion.js.map +1 -1
  5. package/accordion/fesm5/ngx-bootstrap-accordion.js.map +1 -1
  6. package/accordion/package.json +1 -1
  7. package/alert/package.json +1 -1
  8. package/buttons/bundles/ngx-bootstrap-buttons.umd.js.map +1 -1
  9. package/buttons/bundles/ngx-bootstrap-buttons.umd.min.js.map +1 -1
  10. package/buttons/fesm2015/ngx-bootstrap-buttons.js.map +1 -1
  11. package/buttons/fesm5/ngx-bootstrap-buttons.js.map +1 -1
  12. package/buttons/package.json +1 -1
  13. package/carousel/bundles/ngx-bootstrap-carousel.umd.js.map +1 -1
  14. package/carousel/bundles/ngx-bootstrap-carousel.umd.min.js.map +1 -1
  15. package/carousel/fesm2015/ngx-bootstrap-carousel.js.map +1 -1
  16. package/carousel/fesm5/ngx-bootstrap-carousel.js.map +1 -1
  17. package/carousel/package.json +1 -1
  18. package/chronos/bundles/ngx-bootstrap-chronos.umd.js.map +1 -1
  19. package/chronos/bundles/ngx-bootstrap-chronos.umd.min.js.map +1 -1
  20. package/chronos/fesm2015/ngx-bootstrap-chronos.js.map +1 -1
  21. package/chronos/fesm5/ngx-bootstrap-chronos.js.map +1 -1
  22. package/chronos/package.json +1 -1
  23. package/collapse/package.json +1 -1
  24. package/component-loader/package.json +1 -1
  25. package/datepicker/base/bs-datepicker-container.d.ts +4 -1
  26. package/datepicker/bs-datepicker.config.d.ts +16 -0
  27. package/datepicker/bs-datepicker.css +108 -0
  28. package/datepicker/bs-datepicker.css.map +3 -3
  29. package/datepicker/bundles/ngx-bootstrap-datepicker.umd.js +59 -9
  30. package/datepicker/bundles/ngx-bootstrap-datepicker.umd.js.map +1 -1
  31. package/datepicker/bundles/ngx-bootstrap-datepicker.umd.min.js +1 -1
  32. package/datepicker/bundles/ngx-bootstrap-datepicker.umd.min.js.map +1 -1
  33. package/datepicker/esm2015/base/bs-datepicker-container.js +9 -3
  34. package/datepicker/esm2015/bs-datepicker.config.js +37 -1
  35. package/datepicker/esm2015/reducer/bs-datepicker.reducer.js +2 -2
  36. package/datepicker/esm2015/themes/bs/bs-custom-dates-view.component.js +5 -2
  37. package/datepicker/esm2015/themes/bs/bs-datepicker-container.component.js +7 -3
  38. package/datepicker/esm2015/themes/bs/bs-datepicker-inline-container.component.js +2 -2
  39. package/datepicker/esm2015/themes/bs/bs-daterangepicker-container.component.js +3 -2
  40. package/datepicker/esm2015/themes/bs/bs-daterangepicker-inline-container.component.js +2 -2
  41. package/datepicker/esm5/base/bs-datepicker-container.js +9 -3
  42. package/datepicker/esm5/bs-datepicker.config.js +37 -1
  43. package/datepicker/esm5/reducer/bs-datepicker.reducer.js +2 -2
  44. package/datepicker/esm5/themes/bs/bs-custom-dates-view.component.js +5 -2
  45. package/datepicker/esm5/themes/bs/bs-datepicker-container.component.js +7 -3
  46. package/datepicker/esm5/themes/bs/bs-datepicker-inline-container.component.js +2 -2
  47. package/datepicker/esm5/themes/bs/bs-daterangepicker-container.component.js +3 -2
  48. package/datepicker/esm5/themes/bs/bs-daterangepicker-inline-container.component.js +2 -2
  49. package/datepicker/fesm2015/ngx-bootstrap-datepicker.js +59 -9
  50. package/datepicker/fesm2015/ngx-bootstrap-datepicker.js.map +1 -1
  51. package/datepicker/fesm5/ngx-bootstrap-datepicker.js +59 -9
  52. package/datepicker/fesm5/ngx-bootstrap-datepicker.js.map +1 -1
  53. package/datepicker/ngx-bootstrap-datepicker.metadata.json +1 -1
  54. package/datepicker/package.json +1 -1
  55. package/datepicker/themes/bs/bs-custom-dates-view.component.d.ts +1 -0
  56. package/datepicker/utils/scss/mixins.css.map +2 -2
  57. package/datepicker/utils/scss/mixins.scss +98 -0
  58. package/datepicker/utils/scss/variables.css.map +1 -1
  59. package/datepicker/utils/scss/variables.scss +14 -0
  60. package/dropdown/bundles/ngx-bootstrap-dropdown.umd.js.map +1 -1
  61. package/dropdown/bundles/ngx-bootstrap-dropdown.umd.min.js.map +1 -1
  62. package/dropdown/fesm2015/ngx-bootstrap-dropdown.js.map +1 -1
  63. package/dropdown/fesm5/ngx-bootstrap-dropdown.js.map +1 -1
  64. package/dropdown/package.json +1 -1
  65. package/locale/package.json +1 -1
  66. package/mini-ngrx/package.json +1 -1
  67. package/modal/bs-modal-ref.service.d.ts +2 -2
  68. package/modal/bs-modal.service.d.ts +3 -1
  69. package/modal/bundles/ngx-bootstrap-modal.umd.js +19 -8
  70. package/modal/bundles/ngx-bootstrap-modal.umd.js.map +1 -1
  71. package/modal/bundles/ngx-bootstrap-modal.umd.min.js +1 -1
  72. package/modal/bundles/ngx-bootstrap-modal.umd.min.js.map +1 -1
  73. package/modal/esm2015/bs-modal-ref.service.js +5 -1
  74. package/modal/esm2015/bs-modal.service.js +7 -2
  75. package/modal/esm2015/modal-container.component.js +2 -1
  76. package/modal/esm2015/modal-options.class.js +6 -3
  77. package/modal/esm2015/modal.directive.js +2 -2
  78. package/modal/esm2015/models/index.js +3 -1
  79. package/modal/esm2015/ngx-bootstrap-modal.js +3 -3
  80. package/modal/esm2015/public_api.js +2 -2
  81. package/modal/esm5/bs-modal-ref.service.js +4 -1
  82. package/modal/esm5/bs-modal.service.js +8 -4
  83. package/modal/esm5/modal-container.component.js +2 -1
  84. package/modal/esm5/modal-options.class.js +6 -3
  85. package/modal/esm5/modal.directive.js +2 -2
  86. package/modal/esm5/models/index.js +3 -1
  87. package/modal/esm5/ngx-bootstrap-modal.js +3 -3
  88. package/modal/esm5/public_api.js +2 -2
  89. package/modal/fesm2015/ngx-bootstrap-modal.js +18 -5
  90. package/modal/fesm2015/ngx-bootstrap-modal.js.map +1 -1
  91. package/modal/fesm5/ngx-bootstrap-modal.js +18 -7
  92. package/modal/fesm5/ngx-bootstrap-modal.js.map +1 -1
  93. package/modal/modal-options.class.d.ts +2 -2
  94. package/modal/models/index.d.ts +1 -0
  95. package/modal/ngx-bootstrap-modal.d.ts +1 -1
  96. package/modal/ngx-bootstrap-modal.metadata.json +1 -1
  97. package/modal/package.json +1 -1
  98. package/modal/public_api.d.ts +1 -1
  99. package/package.json +2 -2
  100. package/pagination/bundles/ngx-bootstrap-pagination.umd.js.map +1 -1
  101. package/pagination/bundles/ngx-bootstrap-pagination.umd.min.js.map +1 -1
  102. package/pagination/fesm2015/ngx-bootstrap-pagination.js.map +1 -1
  103. package/pagination/fesm5/ngx-bootstrap-pagination.js.map +1 -1
  104. package/pagination/package.json +1 -1
  105. package/popover/bundles/ngx-bootstrap-popover.umd.js.map +1 -1
  106. package/popover/bundles/ngx-bootstrap-popover.umd.min.js.map +1 -1
  107. package/popover/fesm2015/ngx-bootstrap-popover.js.map +1 -1
  108. package/popover/fesm5/ngx-bootstrap-popover.js.map +1 -1
  109. package/popover/package.json +1 -1
  110. package/positioning/package.json +1 -1
  111. package/progressbar/bar.component.d.ts +4 -7
  112. package/progressbar/bundles/ngx-bootstrap-progressbar.umd.js +40 -64
  113. package/progressbar/bundles/ngx-bootstrap-progressbar.umd.js.map +1 -1
  114. package/progressbar/bundles/ngx-bootstrap-progressbar.umd.min.js +1 -1
  115. package/progressbar/bundles/ngx-bootstrap-progressbar.umd.min.js.map +1 -1
  116. package/progressbar/esm2015/bar.component.js +33 -48
  117. package/progressbar/esm2015/progressbar.component.js +5 -8
  118. package/progressbar/esm5/bar.component.js +37 -58
  119. package/progressbar/esm5/progressbar.component.js +5 -8
  120. package/progressbar/fesm2015/ngx-bootstrap-progressbar.js +36 -54
  121. package/progressbar/fesm2015/ngx-bootstrap-progressbar.js.map +1 -1
  122. package/progressbar/fesm5/ngx-bootstrap-progressbar.js +40 -64
  123. package/progressbar/fesm5/ngx-bootstrap-progressbar.js.map +1 -1
  124. package/progressbar/ngx-bootstrap-progressbar.metadata.json +1 -1
  125. package/progressbar/package.json +1 -1
  126. package/progressbar/progressbar.component.d.ts +1 -1
  127. package/rating/package.json +1 -1
  128. package/sortable/package.json +1 -1
  129. package/tabs/package.json +1 -1
  130. package/timepicker/bundles/ngx-bootstrap-timepicker.umd.js +3 -3
  131. package/timepicker/bundles/ngx-bootstrap-timepicker.umd.js.map +1 -1
  132. package/timepicker/bundles/ngx-bootstrap-timepicker.umd.min.js.map +1 -1
  133. package/timepicker/esm2015/timepicker.component.js +2 -2
  134. package/timepicker/esm2015/timepicker.config.js +3 -3
  135. package/timepicker/esm5/timepicker.component.js +2 -2
  136. package/timepicker/esm5/timepicker.config.js +3 -3
  137. package/timepicker/fesm2015/ngx-bootstrap-timepicker.js +3 -3
  138. package/timepicker/fesm2015/ngx-bootstrap-timepicker.js.map +1 -1
  139. package/timepicker/fesm5/ngx-bootstrap-timepicker.js +3 -3
  140. package/timepicker/fesm5/ngx-bootstrap-timepicker.js.map +1 -1
  141. package/timepicker/package.json +1 -1
  142. package/timepicker/timepicker.component.d.ts +1 -1
  143. package/timepicker/timepicker.config.d.ts +1 -1
  144. package/tooltip/bundles/ngx-bootstrap-tooltip.umd.js.map +1 -1
  145. package/tooltip/bundles/ngx-bootstrap-tooltip.umd.min.js.map +1 -1
  146. package/tooltip/fesm2015/ngx-bootstrap-tooltip.js.map +1 -1
  147. package/tooltip/fesm5/ngx-bootstrap-tooltip.js.map +1 -1
  148. package/tooltip/package.json +1 -1
  149. package/typeahead/bundles/ngx-bootstrap-typeahead.umd.js.map +1 -1
  150. package/typeahead/bundles/ngx-bootstrap-typeahead.umd.min.js.map +1 -1
  151. package/typeahead/fesm2015/ngx-bootstrap-typeahead.js.map +1 -1
  152. package/typeahead/fesm5/ngx-bootstrap-typeahead.js.map +1 -1
  153. package/typeahead/package.json +1 -1
  154. package/utils/package.json +1 -1
@@ -47,10 +47,10 @@
47
47
  var ProgressbarComponent = /** @class */ (function () {
48
48
  function ProgressbarComponent(config) {
49
49
  this.isStacked = false;
50
+ this._max = 100;
50
51
  this.addClass = true;
51
52
  /* tslint:disable-next-line:no-any */
52
53
  this.bars = [];
53
- this._max = 100;
54
54
  Object.assign(this, config);
55
55
  }
56
56
  Object.defineProperty(ProgressbarComponent.prototype, "animate", {
@@ -173,7 +173,7 @@
173
173
  ProgressbarComponent.decorators = [
174
174
  { type: core.Component, args: [{
175
175
  selector: 'progressbar',
176
- template: "<bar [type]=\"type\" [value]=\"_value\" *ngIf=\"!isStacked\">\n <ng-content></ng-content>\n</bar>\n<ng-template [ngIf]=\"isStacked\">\n <bar *ngFor=\"let item of _value\" [type]=\"item.type\" [value]=\"item.value\">{{ item.label }}</bar>\n</ng-template>\n",
176
+ template: "<bar [type]=\"type\" [value]=\"_value\" [max]=\"_max\" *ngIf=\"!isStacked\">\n <ng-content></ng-content>\n</bar>\n<ng-template [ngIf]=\"isStacked\">\n <bar *ngFor=\"let item of _value\" [type]=\"item.type\" [value]=\"item.value\" [max]=\"item.max\">{{ item.label }}</bar>\n</ng-template>\n",
177
177
  styles: ["\n :host {\n width: 100%;\n display: flex;\n }\n "]
178
178
  }] }
179
179
  ];
@@ -204,16 +204,13 @@
204
204
  /** @type {?} */
205
205
  ProgressbarComponent.prototype._animate;
206
206
  /** @type {?} */
207
+ ProgressbarComponent.prototype._max;
208
+ /** @type {?} */
207
209
  ProgressbarComponent.prototype._value;
208
210
  /** @type {?} */
209
211
  ProgressbarComponent.prototype.addClass;
210
212
  /** @type {?} */
211
213
  ProgressbarComponent.prototype.bars;
212
- /**
213
- * @type {?}
214
- * @protected
215
- */
216
- ProgressbarComponent.prototype._max;
217
214
  }
218
215
 
219
216
  /**
@@ -230,49 +227,6 @@
230
227
  this.percent = 0;
231
228
  this.progress = progress;
232
229
  }
233
- Object.defineProperty(BarComponent.prototype, "type", {
234
- /** provide one of the four supported contextual classes: `success`, `info`, `warning`, `danger` */
235
- get: /**
236
- * provide one of the four supported contextual classes: `success`, `info`, `warning`, `danger`
237
- * @return {?}
238
- */
239
- function () {
240
- return this._type;
241
- },
242
- set: /**
243
- * @param {?} v
244
- * @return {?}
245
- */
246
- function (v) {
247
- this._type = v;
248
- this.applyTypeClasses();
249
- },
250
- enumerable: true,
251
- configurable: true
252
- });
253
- Object.defineProperty(BarComponent.prototype, "value", {
254
- /** current value of progress bar */
255
- get: /**
256
- * current value of progress bar
257
- * @return {?}
258
- */
259
- function () {
260
- return this._value;
261
- },
262
- set: /**
263
- * @param {?} v
264
- * @return {?}
265
- */
266
- function (v) {
267
- if (!v && v !== 0) {
268
- return;
269
- }
270
- this._value = v;
271
- this.recalculatePercentage();
272
- },
273
- enumerable: true,
274
- configurable: true
275
- });
276
230
  Object.defineProperty(BarComponent.prototype, "setBarWidth", {
277
231
  get: /**
278
232
  * @return {?}
@@ -312,6 +266,27 @@
312
266
  function () {
313
267
  this.progress.removeBar(this);
314
268
  };
269
+ /**
270
+ * @param {?} changes
271
+ * @return {?}
272
+ */
273
+ BarComponent.prototype.ngOnChanges = /**
274
+ * @param {?} changes
275
+ * @return {?}
276
+ */
277
+ function (changes) {
278
+ if (changes.value) {
279
+ if (!changes.value.currentValue && changes.value.currentValue !== 0) {
280
+ return;
281
+ }
282
+ this.value = changes.value.currentValue;
283
+ this.recalculatePercentage();
284
+ }
285
+ if (changes.type) {
286
+ this.type = changes.type.currentValue;
287
+ this.applyTypeClasses();
288
+ }
289
+ };
315
290
  /**
316
291
  * @return {?}
317
292
  */
@@ -352,14 +327,14 @@
352
327
  this.renderer.removeClass(this.el.nativeElement, bgClass);
353
328
  this._prevType = null;
354
329
  }
355
- if (this._type) {
330
+ if (this.type) {
356
331
  /** @type {?} */
357
- var barTypeClass = "progress-bar-" + this._type;
332
+ var barTypeClass = "progress-bar-" + this.type;
358
333
  /** @type {?} */
359
- var bgClass = "bg-" + this._type;
334
+ var bgClass = "bg-" + this.type;
360
335
  this.renderer.addClass(this.el.nativeElement, barTypeClass);
361
336
  this.renderer.addClass(this.el.nativeElement, bgClass);
362
- this._prevType = this._type;
337
+ this._prevType = this.type;
363
338
  }
364
339
  };
365
340
  BarComponent.decorators = [
@@ -386,6 +361,7 @@
386
361
  { type: core.Renderer2 }
387
362
  ]; };
388
363
  BarComponent.propDecorators = {
364
+ max: [{ type: core.Input }],
389
365
  type: [{ type: core.Input }],
390
366
  value: [{ type: core.Input }],
391
367
  setBarWidth: [{ type: core.HostBinding, args: ['style.width.%',] }],
@@ -396,6 +372,16 @@
396
372
  if (false) {
397
373
  /** @type {?} */
398
374
  BarComponent.prototype.max;
375
+ /**
376
+ * provide one of the four supported contextual classes: `success`, `info`, `warning`, `danger`
377
+ * @type {?}
378
+ */
379
+ BarComponent.prototype.type;
380
+ /**
381
+ * current value of progress bar
382
+ * @type {?}
383
+ */
384
+ BarComponent.prototype.value;
399
385
  /** @type {?} */
400
386
  BarComponent.prototype.addClass;
401
387
  /** @type {?} */
@@ -406,16 +392,6 @@
406
392
  BarComponent.prototype.percent;
407
393
  /** @type {?} */
408
394
  BarComponent.prototype.progress;
409
- /**
410
- * @type {?}
411
- * @protected
412
- */
413
- BarComponent.prototype._value;
414
- /**
415
- * @type {?}
416
- * @protected
417
- */
418
- BarComponent.prototype._type;
419
395
  /**
420
396
  * @type {?}
421
397
  * @private
@@ -1 +1 @@
1
- {"version":3,"file":"ngx-bootstrap-progressbar.umd.js","sources":["ng://ngx-bootstrap/progressbar/progressbar.config.ts","ng://ngx-bootstrap/progressbar/progressbar.component.ts","ng://ngx-bootstrap/progressbar/bar.component.ts","ng://ngx-bootstrap/progressbar/progressbar.module.ts"],"sourcesContent":["import { Injectable } from '@angular/core';\n\n@Injectable({\n providedIn: 'root'\n})\nexport class ProgressbarConfig {\n /** if `true` changing value of progress bar will be animated */\n animate: Boolean = false;\n /** maximum total value of progress element */\n max = 100;\n}\n","import { Component, HostBinding, Input } from '@angular/core';\nimport { ProgressbarConfig } from './progressbar.config';\nimport { ProgressbarType } from './progressbar-type.interface';\nimport { isBs3 } from 'ngx-bootstrap/utils';\nimport { BarComponent } from './bar.component';\n\n@Component({\n selector: 'progressbar',\n templateUrl: './progressbar.component.html',\n styles: [\n `\n :host {\n width: 100%;\n display: flex;\n }\n `\n ]\n})\nexport class ProgressbarComponent {\n /** if `true` changing value of progress bar will be animated */\n @Input()\n set animate(value: boolean) {\n this._animate = value;\n this.bars.forEach((b: BarComponent) => {\n b.animate = value;\n });\n }\n /** If `true`, striped classes are applied */\n @Input()\n set striped(value: boolean) {\n this._striped = value;\n this.bars.forEach((b: BarComponent) => {\n b.striped = value;\n });\n }\n\n /** provide one of the four supported contextual classes: `success`, `info`, `warning`, `danger` */\n @Input() type: ProgressbarType;\n /** current value of progress bar. Could be a number or array of objects\n * like {\"value\":15,\"type\":\"info\",\"label\":\"15 %\"}\n */\n @Input()\n /* tslint:disable-next-line:no-any */\n set value(value: number | any[]) {\n this.isStacked = Array.isArray(value);\n this._value = value;\n }\n isStacked = false;\n _striped: boolean;\n _animate: boolean;\n /* tslint:disable-next-line:no-any */\n _value: number | any[];\n get isBs3(): boolean {\n return isBs3();\n }\n\n /** maximum total value of progress element */\n @HostBinding('attr.max')\n @Input()\n get max(): number {\n return this._max;\n }\n\n set max(v: number) {\n this._max = v;\n this.bars.forEach((bar: BarComponent) => {\n bar.recalculatePercentage();\n });\n }\n\n @HostBinding('class.progress') addClass = true;\n\n /* tslint:disable-next-line:no-any */\n bars: BarComponent[] = [];\n\n protected _max = 100;\n\n constructor(config: ProgressbarConfig) {\n Object.assign(this, config);\n }\n addBar(bar: BarComponent): void {\n bar.animate = this._animate;\n bar.striped = this._striped;\n\n this.bars.push(bar);\n }\n\n removeBar(bar: BarComponent): void {\n this.bars.splice(this.bars.indexOf(bar), 1);\n }\n}\n","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","import { CommonModule } from '@angular/common';\nimport { NgModule, ModuleWithProviders } from '@angular/core';\n\nimport { BarComponent } from './bar.component';\nimport { ProgressbarComponent } from './progressbar.component';\n\n@NgModule({\n imports: [CommonModule],\n declarations: [BarComponent, ProgressbarComponent],\n exports: [BarComponent, ProgressbarComponent]\n})\nexport class ProgressbarModule {\n static forRoot(): ModuleWithProviders<ProgressbarModule> {\n return { ngModule: ProgressbarModule, providers: [] };\n }\n}\n"],"names":["Injectable","isBs3","Component","Input","HostBinding","ElementRef","Host","Renderer2","NgModule","CommonModule"],"mappings":"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"}
1
+ {"version":3,"file":"ngx-bootstrap-progressbar.umd.js","sources":["ng://ngx-bootstrap/progressbar/progressbar.config.ts","ng://ngx-bootstrap/progressbar/progressbar.component.ts","ng://ngx-bootstrap/progressbar/bar.component.ts","ng://ngx-bootstrap/progressbar/progressbar.module.ts"],"sourcesContent":["import { Injectable } from '@angular/core';\n\n@Injectable({\n providedIn: 'root'\n})\nexport class ProgressbarConfig {\n /** if `true` changing value of progress bar will be animated */\n animate: Boolean = false;\n /** maximum total value of progress element */\n max = 100;\n}\n","import { Component, HostBinding, Input } from '@angular/core';\nimport { ProgressbarConfig } from './progressbar.config';\nimport { ProgressbarType } from './progressbar-type.interface';\nimport { isBs3 } from 'ngx-bootstrap/utils';\nimport { BarComponent } from './bar.component';\n\n@Component({\n selector: 'progressbar',\n templateUrl: './progressbar.component.html',\n styles: [\n `\n :host {\n width: 100%;\n display: flex;\n }\n `\n ]\n})\nexport class ProgressbarComponent {\n /** if `true` changing value of progress bar will be animated */\n @Input()\n set animate(value: boolean) {\n this._animate = value;\n this.bars.forEach((b: BarComponent) => {\n b.animate = value;\n });\n }\n /** If `true`, striped classes are applied */\n @Input()\n set striped(value: boolean) {\n this._striped = value;\n this.bars.forEach((b: BarComponent) => {\n b.striped = value;\n });\n }\n\n /** provide one of the four supported contextual classes: `success`, `info`, `warning`, `danger` */\n @Input() type: ProgressbarType;\n /** current value of progress bar. Could be a number or array of objects\n * like {\"value\":15,\"type\":\"info\",\"label\":\"15 %\"}\n */\n @Input()\n /* tslint:disable-next-line:no-any */\n set value(value: number | any[]) {\n this.isStacked = Array.isArray(value);\n this._value = value;\n }\n isStacked = false;\n _striped: boolean;\n _animate: boolean;\n _max = 100;\n\n /* tslint:disable-next-line:no-any */\n _value: number | any[];\n get isBs3(): boolean {\n return isBs3();\n }\n\n /** maximum total value of progress element */\n @HostBinding('attr.max')\n @Input()\n get max(): number {\n return this._max;\n }\n\n set max(v: number) {\n this._max = v;\n this.bars.forEach((bar: BarComponent) => {\n bar.recalculatePercentage();\n });\n }\n\n @HostBinding('class.progress') addClass = true;\n\n /* tslint:disable-next-line:no-any */\n bars: BarComponent[] = [];\n constructor(config: ProgressbarConfig) {\n Object.assign(this, config);\n }\n addBar(bar: BarComponent): void {\n bar.animate = this._animate;\n bar.striped = this._striped;\n\n this.bars.push(bar);\n }\n\n removeBar(bar: BarComponent): void {\n this.bars.splice(this.bars.indexOf(bar), 1);\n }\n}\n","import {\n Component,\n Host,\n HostBinding,\n Input,\n OnDestroy,\n OnInit,\n ElementRef,\n Renderer2, SimpleChanges\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 @Input() max: number;\n /** provide one of the four supported contextual classes: `success`, `info`, `warning`, `danger` */\n @Input() type: string;\n\n /** current value of progress bar */\n @Input() value: number;\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 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 ngOnChanges(changes: SimpleChanges) {\n if (changes.value) {\n if (!changes.value.currentValue && changes.value.currentValue !== 0) {\n return;\n }\n this.value = changes.value.currentValue;\n this.recalculatePercentage();\n }\n\n if (changes.type) {\n this.type = changes.type.currentValue;\n this.applyTypeClasses();\n }\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","import { CommonModule } from '@angular/common';\nimport { NgModule, ModuleWithProviders } from '@angular/core';\n\nimport { BarComponent } from './bar.component';\nimport { ProgressbarComponent } from './progressbar.component';\n\n@NgModule({\n imports: [CommonModule],\n declarations: [BarComponent, ProgressbarComponent],\n exports: [BarComponent, ProgressbarComponent]\n})\nexport class ProgressbarModule {\n static forRoot(): ModuleWithProviders<ProgressbarModule> {\n return { ngModule: ProgressbarModule, providers: [] };\n }\n}\n"],"names":["Injectable","isBs3","Component","Input","HostBinding","ElementRef","Host","Renderer2","NgModule","CommonModule"],"mappings":";;;;;;;;;;;QAEA;;;;YAKE,YAAO,GAAY,KAAK,CAAC;;;;YAEzB,QAAG,GAAG,GAAG,CAAC;SACX;;oBARAA,eAAU,SAAC;wBACV,UAAU,EAAE,MAAM;qBACnB;;;gCAJD;KAEA,IAQC;;;;;;QAHC,oCAAyB;;;;;QAEzB,gCAAU;;;;;;;;QCmEV,8BAAY,MAAyB;YA7BrC,cAAS,GAAG,KAAK,CAAC;YAGlB,SAAI,GAAG,GAAG,CAAC;YAsBoB,aAAQ,GAAG,IAAI,CAAC;;YAG/C,SAAI,GAAmB,EAAE,CAAC;YAExB,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;SAC7B;QA1DD,sBACI,yCAAO;;;;;;;YADX,UACY,KAAc;gBACxB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;gBACtB,IAAI,CAAC,IAAI,CAAC,OAAO;;;;gBAAC,UAAC,CAAe;oBAChC,CAAC,CAAC,OAAO,GAAG,KAAK,CAAC;iBACnB,EAAC,CAAC;aACJ;;;WAAA;QAED,sBACI,yCAAO;;;;;;;YADX,UACY,KAAc;gBACxB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;gBACtB,IAAI,CAAC,IAAI,CAAC,OAAO;;;;gBAAC,UAAC,CAAe;oBAChC,CAAC,CAAC,OAAO,GAAG,KAAK,CAAC;iBACnB,EAAC,CAAC;aACJ;;;WAAA;QAOD,sBAEI,uCAAK;;;;;;;;;;YAFT,UAEU,KAAqB;gBAC7B,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;gBACtC,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;aACrB;;;WAAA;QAQD,sBAAI,uCAAK;;;;YAAT;gBACE,OAAOC,WAAK,EAAE,CAAC;aAChB;;;WAAA;QAGD,sBAEI,qCAAG;;;;;;YAFP;gBAGE,OAAO,IAAI,CAAC,IAAI,CAAC;aAClB;;;;;YAED,UAAQ,CAAS;gBACf,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;gBACd,IAAI,CAAC,IAAI,CAAC,OAAO;;;;gBAAC,UAAC,GAAiB;oBAClC,GAAG,CAAC,qBAAqB,EAAE,CAAC;iBAC7B,EAAC,CAAC;aACJ;;;WAPA;;;;;QAgBD,qCAAM;;;;QAAN,UAAO,GAAiB;YACtB,GAAG,CAAC,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC;YAC5B,GAAG,CAAC,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC;YAE5B,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;SACrB;;;;;QAED,wCAAS;;;;QAAT,UAAU,GAAiB;YACzB,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;SAC7C;;oBAlFFC,cAAS,SAAC;wBACT,QAAQ,EAAE,aAAa;wBACvB,+SAA2C;iCAEzC,oEAKD;qBAEF;;;;oBAhBQ,iBAAiB;;;8BAmBvBC,UAAK;8BAQLA,UAAK;2BASLA,UAAK;4BAILA,UAAK;0BAkBLC,gBAAW,SAAC,UAAU,cACtBD,UAAK;+BAYLC,gBAAW,SAAC,gBAAgB;;QAiB/B,2BAAC;KAnFD,IAmFC;;;;;;QApDC,oCAA+B;;QAU/B,yCAAkB;;QAClB,wCAAkB;;QAClB,wCAAkB;;QAClB,oCAAW;;QAGX,sCAAuB;;QAmBvB,wCAA+C;;QAG/C,oCAA0B;;;;;;;IC3E5B;;;QA2DE,sBACU,EAAc,EACd,QAA8B,EAC9B,QAAmB;YAFnB,OAAE,GAAF,EAAE,CAAY;YAEd,aAAQ,GAAR,QAAQ,CAAW;YAhBM,aAAQ,GAAG,IAAI,CAAC;YAQnD,YAAO,GAAG,CAAC,CAAC;YAUV,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;SAC1B;QA1BD,sBACI,qCAAW;;;;YADf;gBAEE,IAAI,CAAC,qBAAqB,EAAE,CAAC;gBAE7B,OAAO,IAAI,CAAC,OAAO,CAAC;aACrB;;;WAAA;QAID,sBAAI,+BAAK;;;;YAAT;gBACE,OAAOH,WAAK,EAAE,CAAC;aAChB;;;WAAA;;;;QAiBD,+BAAQ;;;QAAR;YACE,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;SAC5B;;;;QAED,kCAAW;;;QAAX;YACE,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;SAC/B;;;;;QAED,kCAAW;;;;QAAX,UAAY,OAAsB;YAChC,IAAI,OAAO,CAAC,KAAK,EAAE;gBACjB,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,YAAY,IAAI,OAAO,CAAC,KAAK,CAAC,YAAY,KAAK,CAAC,EAAE;oBACnE,OAAO;iBACR;gBACD,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,YAAY,CAAC;gBACxC,IAAI,CAAC,qBAAqB,EAAE,CAAC;aAC9B;YAED,IAAI,OAAO,CAAC,IAAI,EAAE;gBAChB,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC;gBACtC,IAAI,CAAC,gBAAgB,EAAE,CAAC;aACzB;SACF;;;;QAED,4CAAqB;;;QAArB;YACE,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,GAAG,GAAG,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;;gBAE5D,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI;iBACvC,MAAM;;;;;YAAC,UAAU,KAAa,EAAE,GAAiB;gBAChD,OAAO,KAAK,GAAG,GAAG,CAAC,OAAO,CAAC;aAC5B,GAAE,CAAC,CAAC;YAEP,IAAI,eAAe,GAAG,GAAG,EAAE;gBACzB,IAAI,CAAC,OAAO,IAAI,eAAe,GAAG,GAAG,CAAC;aACvC;SACF;;;;;QAEO,uCAAgB;;;;QAAxB;YACE,IAAI,IAAI,CAAC,SAAS,EAAE;;oBACZ,YAAY,GAAG,kBAAgB,IAAI,CAAC,SAAW;;oBAC/C,OAAO,GAAG,QAAM,IAAI,CAAC,SAAW;gBACtC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC;gBAC/D,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;gBAC1D,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;aACvB;YAED,IAAI,IAAI,CAAC,IAAI,EAAE;;oBACP,YAAY,GAAG,kBAAgB,IAAI,CAAC,IAAM;;oBAC1C,OAAO,GAAG,QAAM,IAAI,CAAC,IAAM;gBACjC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC;gBAC5D,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;gBACvD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC;aAC5B;SACF;;oBAvGFC,cAAS,SAAC;wBACT,QAAQ,EAAE,KAAK;wBACf,uCAAmC;wBACnC,IAAI,EAAE;4BACJ,IAAI,EAAE,aAAa;4BACnB,eAAe,EAAE,GAAG;4BACpB,+BAA+B,EAAE,mBAAmB;4BACpD,8BAA8B,EAAE,SAAS;4BACzC,gBAAgB,EAAE,kBAAkB;4BACpC,sBAAsB,EAAE,OAAO;4BAC/B,uBAAuB,EAAE,yCAAyC;4BAClE,sBAAsB,EAAE,KAAK;4BAC7B,kBAAkB,EAAE,OAAO;yBAC5B;qBACF;;;;oBAvBCG,eAAU;oBAIH,oBAAoB,uBAkDxBC,SAAI;oBArDPC,cAAS;;;0BAwBRJ,UAAK;2BAELA,UAAK;4BAGLA,UAAK;kCAELC,gBAAW,SAAC,eAAe;+BAO3BA,gBAAW,SAAC,oBAAoB;;QA0EnC,mBAAC;KAxGD,IAwGC;;;QAxFC,2BAAqB;;;;;QAErB,4BAAsB;;;;;QAGtB,6BAAuB;;QASvB,gCAAmD;;QAMnD,+BAAiB;;QACjB,+BAAiB;;QACjB,+BAAY;;QACZ,gCAA+B;;;;;QAE/B,iCAA0B;;;;;QAGxB,0BAAsB;;;;;QAEtB,gCAA2B;;;;;;;;QCxD/B;SASC;;;;QAHQ,yBAAO;;;QAAd;YACE,OAAO,EAAE,QAAQ,EAAE,iBAAiB,EAAE,SAAS,EAAE,EAAE,EAAE,CAAC;SACvD;;oBARFI,aAAQ,SAAC;wBACR,OAAO,EAAE,CAACC,mBAAY,CAAC;wBACvB,YAAY,EAAE,CAAC,YAAY,EAAE,oBAAoB,CAAC;wBAClD,OAAO,EAAE,CAAC,YAAY,EAAE,oBAAoB,CAAC;qBAC9C;;QAKD,wBAAC;KATD;;;;;;;;;;;;;;;"}
@@ -1,2 +1,2 @@
1
- !function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("ngx-bootstrap/utils"),require("@angular/common")):"function"==typeof define&&define.amd?define("ngx-bootstrap/progressbar",["exports","@angular/core","ngx-bootstrap/utils","@angular/common"],t):t(((e=e||self)["ngx-bootstrap"]=e["ngx-bootstrap"]||{},e["ngx-bootstrap"].progressbar={}),e.ng.core,e.utils,e.ng.common)}(this,(function(e,t,r,n){"use strict";var s=function(){function e(){this.animate=!1,this.max=100}return e.decorators=[{type:t.Injectable,args:[{providedIn:"root"}]}],e.ɵprov=t["ɵɵdefineInjectable"]({factory:function(){return new e},token:e,providedIn:"root"}),e}();var a=function(){function e(e){this.isStacked=!1,this.addClass=!0,this.bars=[],this._max=100,Object.assign(this,e)}return Object.defineProperty(e.prototype,"animate",{set:function(e){this._animate=e,this.bars.forEach((function(t){t.animate=e}))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"striped",{set:function(e){this._striped=e,this.bars.forEach((function(t){t.striped=e}))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"value",{set:function(e){this.isStacked=Array.isArray(e),this._value=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"isBs3",{get:function(){return r.isBs3()},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"max",{get:function(){return this._max},set:function(e){this._max=e,this.bars.forEach((function(e){e.recalculatePercentage()}))},enumerable:!0,configurable:!0}),e.prototype.addBar=function(e){e.animate=this._animate,e.striped=this._striped,this.bars.push(e)},e.prototype.removeBar=function(e){this.bars.splice(this.bars.indexOf(e),1)},e.decorators=[{type:t.Component,args:[{selector:"progressbar",template:'<bar [type]="type" [value]="_value" *ngIf="!isStacked">\n <ng-content></ng-content>\n</bar>\n<ng-template [ngIf]="isStacked">\n <bar *ngFor="let item of _value" [type]="item.type" [value]="item.value">{{ item.label }}</bar>\n</ng-template>\n',styles:["\n :host {\n width: 100%;\n display: flex;\n }\n "]}]}],e.ctorParameters=function(){return[{type:s}]},e.propDecorators={animate:[{type:t.Input}],striped:[{type:t.Input}],type:[{type:t.Input}],value:[{type:t.Input}],max:[{type:t.HostBinding,args:["attr.max"]},{type:t.Input}],addClass:[{type:t.HostBinding,args:["class.progress"]}]},e}();var o=function(){function e(e,t,r){this.el=e,this.renderer=r,this.addClass=!0,this.percent=0,this.progress=t}return Object.defineProperty(e.prototype,"type",{get:function(){return this._type},set:function(e){this._type=e,this.applyTypeClasses()},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"value",{get:function(){return this._value},set:function(e){(e||0===e)&&(this._value=e,this.recalculatePercentage())},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"setBarWidth",{get:function(){return this.recalculatePercentage(),this.percent},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"isBs3",{get:function(){return r.isBs3()},enumerable:!0,configurable:!0}),e.prototype.ngOnInit=function(){this.progress.addBar(this)},e.prototype.ngOnDestroy=function(){this.progress.removeBar(this)},e.prototype.recalculatePercentage=function(){this.percent=+(this.value/this.progress.max*100).toFixed(2);var e=this.progress.bars.reduce((function(e,t){return e+t.percent}),0);e>100&&(this.percent-=e-100)},e.prototype.applyTypeClasses=function(){if(this._prevType){var e="progress-bar-"+this._prevType,t="bg-"+this._prevType;this.renderer.removeClass(this.el.nativeElement,e),this.renderer.removeClass(this.el.nativeElement,t),this._prevType=null}if(this._type){e="progress-bar-"+this._type,t="bg-"+this._type;this.renderer.addClass(this.el.nativeElement,e),this.renderer.addClass(this.el.nativeElement,t),this._prevType=this._type}},e.decorators=[{type:t.Component,args:[{selector:"bar",template:"<ng-content></ng-content>\n",host:{role:"progressbar","aria-valuemin":"0","[class.progress-bar-animated]":"!isBs3 && animate","[class.progress-bar-striped]":"striped","[class.active]":"isBs3 && animate","[attr.aria-valuenow]":"value","[attr.aria-valuetext]":'percent ? percent.toFixed(0) + "%" : ""',"[attr.aria-valuemax]":"max","[style.height.%]":'"100"'}}]}],e.ctorParameters=function(){return[{type:t.ElementRef},{type:a,decorators:[{type:t.Host}]},{type:t.Renderer2}]},e.propDecorators={type:[{type:t.Input}],value:[{type:t.Input}],setBarWidth:[{type:t.HostBinding,args:["style.width.%"]}],addClass:[{type:t.HostBinding,args:["class.progress-bar"]}]},e}();var i=function(){function e(){}return e.forRoot=function(){return{ngModule:e,providers:[]}},e.decorators=[{type:t.NgModule,args:[{imports:[n.CommonModule],declarations:[o,a],exports:[o,a]}]}],e}();e.BarComponent=o,e.ProgressbarComponent=a,e.ProgressbarConfig=s,e.ProgressbarModule=i,Object.defineProperty(e,"__esModule",{value:!0})}));
1
+ !function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("ngx-bootstrap/utils"),require("@angular/common")):"function"==typeof define&&define.amd?define("ngx-bootstrap/progressbar",["exports","@angular/core","ngx-bootstrap/utils","@angular/common"],t):t(((e=e||self)["ngx-bootstrap"]=e["ngx-bootstrap"]||{},e["ngx-bootstrap"].progressbar={}),e.ng.core,e.utils,e.ng.common)}(this,(function(e,t,r,n){"use strict";var s=function(){function e(){this.animate=!1,this.max=100}return e.decorators=[{type:t.Injectable,args:[{providedIn:"root"}]}],e.ɵprov=t["ɵɵdefineInjectable"]({factory:function(){return new e},token:e,providedIn:"root"}),e}();var a=function(){function e(e){this.isStacked=!1,this._max=100,this.addClass=!0,this.bars=[],Object.assign(this,e)}return Object.defineProperty(e.prototype,"animate",{set:function(e){this._animate=e,this.bars.forEach((function(t){t.animate=e}))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"striped",{set:function(e){this._striped=e,this.bars.forEach((function(t){t.striped=e}))},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"value",{set:function(e){this.isStacked=Array.isArray(e),this._value=e},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"isBs3",{get:function(){return r.isBs3()},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"max",{get:function(){return this._max},set:function(e){this._max=e,this.bars.forEach((function(e){e.recalculatePercentage()}))},enumerable:!0,configurable:!0}),e.prototype.addBar=function(e){e.animate=this._animate,e.striped=this._striped,this.bars.push(e)},e.prototype.removeBar=function(e){this.bars.splice(this.bars.indexOf(e),1)},e.decorators=[{type:t.Component,args:[{selector:"progressbar",template:'<bar [type]="type" [value]="_value" [max]="_max" *ngIf="!isStacked">\n <ng-content></ng-content>\n</bar>\n<ng-template [ngIf]="isStacked">\n <bar *ngFor="let item of _value" [type]="item.type" [value]="item.value" [max]="item.max">{{ item.label }}</bar>\n</ng-template>\n',styles:["\n :host {\n width: 100%;\n display: flex;\n }\n "]}]}],e.ctorParameters=function(){return[{type:s}]},e.propDecorators={animate:[{type:t.Input}],striped:[{type:t.Input}],type:[{type:t.Input}],value:[{type:t.Input}],max:[{type:t.HostBinding,args:["attr.max"]},{type:t.Input}],addClass:[{type:t.HostBinding,args:["class.progress"]}]},e}();var o=function(){function e(e,t,r){this.el=e,this.renderer=r,this.addClass=!0,this.percent=0,this.progress=t}return Object.defineProperty(e.prototype,"setBarWidth",{get:function(){return this.recalculatePercentage(),this.percent},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"isBs3",{get:function(){return r.isBs3()},enumerable:!0,configurable:!0}),e.prototype.ngOnInit=function(){this.progress.addBar(this)},e.prototype.ngOnDestroy=function(){this.progress.removeBar(this)},e.prototype.ngOnChanges=function(e){if(e.value){if(!e.value.currentValue&&0!==e.value.currentValue)return;this.value=e.value.currentValue,this.recalculatePercentage()}e.type&&(this.type=e.type.currentValue,this.applyTypeClasses())},e.prototype.recalculatePercentage=function(){this.percent=+(this.value/this.progress.max*100).toFixed(2);var e=this.progress.bars.reduce((function(e,t){return e+t.percent}),0);e>100&&(this.percent-=e-100)},e.prototype.applyTypeClasses=function(){if(this._prevType){var e="progress-bar-"+this._prevType,t="bg-"+this._prevType;this.renderer.removeClass(this.el.nativeElement,e),this.renderer.removeClass(this.el.nativeElement,t),this._prevType=null}if(this.type){e="progress-bar-"+this.type,t="bg-"+this.type;this.renderer.addClass(this.el.nativeElement,e),this.renderer.addClass(this.el.nativeElement,t),this._prevType=this.type}},e.decorators=[{type:t.Component,args:[{selector:"bar",template:"<ng-content></ng-content>\n",host:{role:"progressbar","aria-valuemin":"0","[class.progress-bar-animated]":"!isBs3 && animate","[class.progress-bar-striped]":"striped","[class.active]":"isBs3 && animate","[attr.aria-valuenow]":"value","[attr.aria-valuetext]":'percent ? percent.toFixed(0) + "%" : ""',"[attr.aria-valuemax]":"max","[style.height.%]":'"100"'}}]}],e.ctorParameters=function(){return[{type:t.ElementRef},{type:a,decorators:[{type:t.Host}]},{type:t.Renderer2}]},e.propDecorators={max:[{type:t.Input}],type:[{type:t.Input}],value:[{type:t.Input}],setBarWidth:[{type:t.HostBinding,args:["style.width.%"]}],addClass:[{type:t.HostBinding,args:["class.progress-bar"]}]},e}();var i=function(){function e(){}return e.forRoot=function(){return{ngModule:e,providers:[]}},e.decorators=[{type:t.NgModule,args:[{imports:[n.CommonModule],declarations:[o,a],exports:[o,a]}]}],e}();e.BarComponent=o,e.ProgressbarComponent=a,e.ProgressbarConfig=s,e.ProgressbarModule=i,Object.defineProperty(e,"__esModule",{value:!0})}));
2
2
  //# sourceMappingURL=ngx-bootstrap-progressbar.umd.min.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["ng://ngx-bootstrap/progressbar/progressbar.config.ts","ng://ngx-bootstrap/progressbar/progressbar.component.ts","ng://ngx-bootstrap/progressbar/bar.component.ts","ng://ngx-bootstrap/progressbar/progressbar.module.ts"],"names":["ProgressbarConfig","this","animate","max","Injectable","args","providedIn","ProgressbarComponent","config","isStacked","addClass","bars","_max","Object","assign","defineProperty","prototype","value","_animate","forEach","b","_striped","striped","Array","isArray","_value","isBs3","v","bar","recalculatePercentage","addBar","push","removeBar","splice","indexOf","Component","selector","template","Input","HostBinding","type","BarComponent","el","progress","renderer","percent","_type","applyTypeClasses","ngOnInit","ngOnDestroy","toFixed","totalPercentage","reduce","total","_prevType","barTypeClass","bgClass","removeClass","nativeElement","host","role","aria-valuemin","[class.progress-bar-animated]","[class.progress-bar-striped]","[class.active]","[attr.aria-valuenow]","[attr.aria-valuetext]","[attr.aria-valuemax]","[style.height.%]","ElementRef","decorators","Host","Renderer2","ProgressbarModule","forRoot","ngModule","providers","NgModule","imports","CommonModule","declarations","exports"],"mappings":"keAEA,SAAAA,IAKEC,KAAAC,SAAmB,EAEnBD,KAAAE,IAAM,+BAPPC,EAAAA,WAAUC,KAAA,CAAC,CACVC,WAAY,+HC0EZ,SAAAC,EAAYC,GA9BZP,KAAAQ,WAAY,EAuBmBR,KAAAS,UAAW,EAG1CT,KAAAU,KAAuB,GAEbV,KAAAW,KAAO,IAGfC,OAAOC,OAAOb,KAAMO,GAYxB,OAtEEK,OAAAE,eACIR,EAAAS,UAAA,UAAO,KADX,SACYC,GACVhB,KAAKiB,SAAWD,EAChBhB,KAAKU,KAAKQ,SAAO,SAAEC,GACjBA,EAAElB,QAAUe,sCAIhBJ,OAAAE,eACIR,EAAAS,UAAA,UAAO,KADX,SACYC,GACVhB,KAAKoB,SAAWJ,EAChBhB,KAAKU,KAAKQ,SAAO,SAAEC,GACjBA,EAAEE,QAAUL,sCAShBJ,OAAAE,eAEIR,EAAAS,UAAA,QAAK,KAFT,SAEUC,GACRhB,KAAKQ,UAAYc,MAAMC,QAAQP,GAC/BhB,KAAKwB,OAASR,mCAOhBJ,OAAAE,eAAIR,EAAAS,UAAA,QAAK,KAAT,WACE,OAAOU,EAAAA,yCAITb,OAAAE,eAEIR,EAAAS,UAAA,MAAG,KAFP,WAGE,OAAOf,KAAKW,UAGd,SAAQe,GACN1B,KAAKW,KAAOe,EACZ1B,KAAKU,KAAKQ,SAAO,SAAES,GACjBA,EAAIC,4DAcRtB,EAAAS,UAAAc,OAAA,SAAOF,GACLA,EAAI1B,QAAUD,KAAKiB,SACnBU,EAAIN,QAAUrB,KAAKoB,SAEnBpB,KAAKU,KAAKoB,KAAKH,IAGjBrB,EAAAS,UAAAgB,UAAA,SAAUJ,GACR3B,KAAKU,KAAKsB,OAAOhC,KAAKU,KAAKuB,QAAQN,GAAM,wBAlF5CO,EAAAA,UAAS9B,KAAA,CAAC,CACT+B,SAAU,cACVC,SAAA,8PAEE,mHATKrC,sCAmBNsC,EAAAA,uBAQAA,EAAAA,oBASAA,EAAAA,qBAIAA,EAAAA,mBAgBAC,EAAAA,YAAWlC,KAAA,CAAC,aAAU,CAAAmC,KACtBF,EAAAA,wBAYAC,EAAAA,YAAWlC,KAAA,CAAC,qBAoBfE,sBCTE,SAAAkC,EACUC,EACAC,EACAC,GAFA3C,KAAAyC,GAAAA,EAEAzC,KAAA2C,SAAAA,EAlByB3C,KAAAS,UAAW,EAQ9CT,KAAA4C,QAAU,EAYR5C,KAAK0C,SAAWA,EAyCpB,OA5FE9B,OAAAE,eACI0B,EAAAzB,UAAA,OAAI,KADR,WAEE,OAAOf,KAAK6C,WAGd,SAASnB,GACP1B,KAAK6C,MAAQnB,EACb1B,KAAK8C,oDAIPlC,OAAAE,eACI0B,EAAAzB,UAAA,QAAK,KADT,WAEE,OAAOf,KAAKwB,YAGd,SAAUE,IACHA,GAAW,IAANA,KAGV1B,KAAKwB,OAASE,EACd1B,KAAK4B,0DAGPhB,OAAAE,eACI0B,EAAAzB,UAAA,cAAW,KADf,WAIE,OAFAf,KAAK4B,wBAEE5B,KAAK4C,yCAKdhC,OAAAE,eAAI0B,EAAAzB,UAAA,QAAK,KAAT,WACE,OAAOU,EAAAA,yCAoBTe,EAAAzB,UAAAgC,SAAA,WACE/C,KAAK0C,SAASb,OAAO7B,OAGvBwC,EAAAzB,UAAAiC,YAAA,WACEhD,KAAK0C,SAASX,UAAU/B,OAG1BwC,EAAAzB,UAAAa,sBAAA,WACE5B,KAAK4C,UAAY5C,KAAKgB,MAAQhB,KAAK0C,SAASxC,IAAM,KAAK+C,QAAQ,OAEzDC,EAAkBlD,KAAK0C,SAAShC,KACnCyC,QAAM,SAAWC,EAAezB,GAC/B,OAAOyB,EAAQzB,EAAIiB,UAClB,GAEDM,EAAkB,MACpBlD,KAAK4C,SAAWM,EAAkB,MAI9BV,EAAAzB,UAAA+B,iBAAR,WACE,GAAI9C,KAAKqD,UAAW,KACZC,EAAe,gBAAgBtD,KAAKqD,UACpCE,EAAU,MAAMvD,KAAKqD,UAC3BrD,KAAK2C,SAASa,YAAYxD,KAAKyC,GAAGgB,cAAeH,GACjDtD,KAAK2C,SAASa,YAAYxD,KAAKyC,GAAGgB,cAAeF,GACjDvD,KAAKqD,UAAY,KAGnB,GAAIrD,KAAK6C,MAAO,CACRS,EAAe,gBAAgBtD,KAAK6C,MACpCU,EAAU,MAAMvD,KAAK6C,MAC3B7C,KAAK2C,SAASlC,SAAST,KAAKyC,GAAGgB,cAAeH,GAC9CtD,KAAK2C,SAASlC,SAAST,KAAKyC,GAAGgB,cAAeF,GAC9CvD,KAAKqD,UAAYrD,KAAK6C,4BA5G3BX,EAAAA,UAAS9B,KAAA,CAAC,CACT+B,SAAU,MACVC,SAAA,8BACAsB,KAAM,CACJC,KAAM,cACNC,gBAAiB,IACjBC,gCAAiC,oBACjCC,+BAAgC,UAChCC,iBAAkB,mBAClBC,uBAAwB,QACxBC,wBAAyB,0CACzBC,uBAAwB,MACxBC,mBAAoB,sDArBtBC,EAAAA,kBAIO9D,EAAoB+D,WAAA,CAAA,CAAA9B,KAwExB+B,EAAAA,cA3EHC,EAAAA,2CA2BClC,EAAAA,qBAWAA,EAAAA,2BAaAC,EAAAA,YAAWlC,KAAA,CAAC,mCAOZkC,EAAAA,YAAWlC,KAAA,CAAC,yBA6DfoC,sBCzHA,SAAAgC,KASA,OAHSA,EAAAC,QAAP,WACE,MAAO,CAAEC,SAAUF,EAAmBG,UAAW,yBAPpDC,EAAAA,SAAQxE,KAAA,CAAC,CACRyE,QAAS,CAACC,EAAAA,cACVC,aAAc,CAACvC,EAAclC,GAC7B0E,QAAS,CAACxC,EAAclC,OAM1BkE","sourcesContent":["import { Injectable } from '@angular/core';\n\n@Injectable({\n providedIn: 'root'\n})\nexport class ProgressbarConfig {\n /** if `true` changing value of progress bar will be animated */\n animate: Boolean = false;\n /** maximum total value of progress element */\n max = 100;\n}\n","import { Component, HostBinding, Input } from '@angular/core';\nimport { ProgressbarConfig } from './progressbar.config';\nimport { ProgressbarType } from './progressbar-type.interface';\nimport { isBs3 } from 'ngx-bootstrap/utils';\nimport { BarComponent } from './bar.component';\n\n@Component({\n selector: 'progressbar',\n templateUrl: './progressbar.component.html',\n styles: [\n `\n :host {\n width: 100%;\n display: flex;\n }\n `\n ]\n})\nexport class ProgressbarComponent {\n /** if `true` changing value of progress bar will be animated */\n @Input()\n set animate(value: boolean) {\n this._animate = value;\n this.bars.forEach((b: BarComponent) => {\n b.animate = value;\n });\n }\n /** If `true`, striped classes are applied */\n @Input()\n set striped(value: boolean) {\n this._striped = value;\n this.bars.forEach((b: BarComponent) => {\n b.striped = value;\n });\n }\n\n /** provide one of the four supported contextual classes: `success`, `info`, `warning`, `danger` */\n @Input() type: ProgressbarType;\n /** current value of progress bar. Could be a number or array of objects\n * like {\"value\":15,\"type\":\"info\",\"label\":\"15 %\"}\n */\n @Input()\n /* tslint:disable-next-line:no-any */\n set value(value: number | any[]) {\n this.isStacked = Array.isArray(value);\n this._value = value;\n }\n isStacked = false;\n _striped: boolean;\n _animate: boolean;\n /* tslint:disable-next-line:no-any */\n _value: number | any[];\n get isBs3(): boolean {\n return isBs3();\n }\n\n /** maximum total value of progress element */\n @HostBinding('attr.max')\n @Input()\n get max(): number {\n return this._max;\n }\n\n set max(v: number) {\n this._max = v;\n this.bars.forEach((bar: BarComponent) => {\n bar.recalculatePercentage();\n });\n }\n\n @HostBinding('class.progress') addClass = true;\n\n /* tslint:disable-next-line:no-any */\n bars: BarComponent[] = [];\n\n protected _max = 100;\n\n constructor(config: ProgressbarConfig) {\n Object.assign(this, config);\n }\n addBar(bar: BarComponent): void {\n bar.animate = this._animate;\n bar.striped = this._striped;\n\n this.bars.push(bar);\n }\n\n removeBar(bar: BarComponent): void {\n this.bars.splice(this.bars.indexOf(bar), 1);\n }\n}\n","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","import { CommonModule } from '@angular/common';\nimport { NgModule, ModuleWithProviders } from '@angular/core';\n\nimport { BarComponent } from './bar.component';\nimport { ProgressbarComponent } from './progressbar.component';\n\n@NgModule({\n imports: [CommonModule],\n declarations: [BarComponent, ProgressbarComponent],\n exports: [BarComponent, ProgressbarComponent]\n})\nexport class ProgressbarModule {\n static forRoot(): ModuleWithProviders<ProgressbarModule> {\n return { ngModule: ProgressbarModule, providers: [] };\n }\n}\n"]}
1
+ {"version":3,"sources":["ng://ngx-bootstrap/progressbar/progressbar.config.ts","ng://ngx-bootstrap/progressbar/progressbar.component.ts","ng://ngx-bootstrap/progressbar/bar.component.ts","ng://ngx-bootstrap/progressbar/progressbar.module.ts"],"names":["ProgressbarConfig","this","animate","max","Injectable","args","providedIn","ProgressbarComponent","config","isStacked","_max","addClass","bars","Object","assign","defineProperty","prototype","value","_animate","forEach","b","_striped","striped","Array","isArray","_value","isBs3","v","bar","recalculatePercentage","addBar","push","removeBar","splice","indexOf","Component","selector","template","Input","HostBinding","type","BarComponent","el","progress","renderer","percent","ngOnInit","ngOnDestroy","ngOnChanges","changes","currentValue","applyTypeClasses","toFixed","totalPercentage","reduce","total","_prevType","barTypeClass","bgClass","removeClass","nativeElement","host","role","aria-valuemin","[class.progress-bar-animated]","[class.progress-bar-striped]","[class.active]","[attr.aria-valuenow]","[attr.aria-valuetext]","[attr.aria-valuemax]","[style.height.%]","ElementRef","decorators","Host","Renderer2","ProgressbarModule","forRoot","ngModule","providers","NgModule","imports","CommonModule","declarations","exports"],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\n\n@Injectable({\n providedIn: 'root'\n})\nexport class ProgressbarConfig {\n /** if `true` changing value of progress bar will be animated */\n animate: Boolean = false;\n /** maximum total value of progress element */\n max = 100;\n}\n","import { Component, HostBinding, Input } from '@angular/core';\nimport { ProgressbarConfig } from './progressbar.config';\nimport { ProgressbarType } from './progressbar-type.interface';\nimport { isBs3 } from 'ngx-bootstrap/utils';\nimport { BarComponent } from './bar.component';\n\n@Component({\n selector: 'progressbar',\n templateUrl: './progressbar.component.html',\n styles: [\n `\n :host {\n width: 100%;\n display: flex;\n }\n `\n ]\n})\nexport class ProgressbarComponent {\n /** if `true` changing value of progress bar will be animated */\n @Input()\n set animate(value: boolean) {\n this._animate = value;\n this.bars.forEach((b: BarComponent) => {\n b.animate = value;\n });\n }\n /** If `true`, striped classes are applied */\n @Input()\n set striped(value: boolean) {\n this._striped = value;\n this.bars.forEach((b: BarComponent) => {\n b.striped = value;\n });\n }\n\n /** provide one of the four supported contextual classes: `success`, `info`, `warning`, `danger` */\n @Input() type: ProgressbarType;\n /** current value of progress bar. Could be a number or array of objects\n * like {\"value\":15,\"type\":\"info\",\"label\":\"15 %\"}\n */\n @Input()\n /* tslint:disable-next-line:no-any */\n set value(value: number | any[]) {\n this.isStacked = Array.isArray(value);\n this._value = value;\n }\n isStacked = false;\n _striped: boolean;\n _animate: boolean;\n _max = 100;\n\n /* tslint:disable-next-line:no-any */\n _value: number | any[];\n get isBs3(): boolean {\n return isBs3();\n }\n\n /** maximum total value of progress element */\n @HostBinding('attr.max')\n @Input()\n get max(): number {\n return this._max;\n }\n\n set max(v: number) {\n this._max = v;\n this.bars.forEach((bar: BarComponent) => {\n bar.recalculatePercentage();\n });\n }\n\n @HostBinding('class.progress') addClass = true;\n\n /* tslint:disable-next-line:no-any */\n bars: BarComponent[] = [];\n constructor(config: ProgressbarConfig) {\n Object.assign(this, config);\n }\n addBar(bar: BarComponent): void {\n bar.animate = this._animate;\n bar.striped = this._striped;\n\n this.bars.push(bar);\n }\n\n removeBar(bar: BarComponent): void {\n this.bars.splice(this.bars.indexOf(bar), 1);\n }\n}\n","import {\n Component,\n Host,\n HostBinding,\n Input,\n OnDestroy,\n OnInit,\n ElementRef,\n Renderer2, SimpleChanges\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 @Input() max: number;\n /** provide one of the four supported contextual classes: `success`, `info`, `warning`, `danger` */\n @Input() type: string;\n\n /** current value of progress bar */\n @Input() value: number;\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 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 ngOnChanges(changes: SimpleChanges) {\n if (changes.value) {\n if (!changes.value.currentValue && changes.value.currentValue !== 0) {\n return;\n }\n this.value = changes.value.currentValue;\n this.recalculatePercentage();\n }\n\n if (changes.type) {\n this.type = changes.type.currentValue;\n this.applyTypeClasses();\n }\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","import { CommonModule } from '@angular/common';\nimport { NgModule, ModuleWithProviders } from '@angular/core';\n\nimport { BarComponent } from './bar.component';\nimport { ProgressbarComponent } from './progressbar.component';\n\n@NgModule({\n imports: [CommonModule],\n declarations: [BarComponent, ProgressbarComponent],\n exports: [BarComponent, ProgressbarComponent]\n})\nexport class ProgressbarModule {\n static forRoot(): ModuleWithProviders<ProgressbarModule> {\n return { ngModule: ProgressbarModule, providers: [] };\n }\n}\n"]}
@@ -20,39 +20,6 @@ export class BarComponent {
20
20
  this.percent = 0;
21
21
  this.progress = progress;
22
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
23
  /**
57
24
  * @return {?}
58
25
  */
@@ -78,6 +45,23 @@ export class BarComponent {
78
45
  ngOnDestroy() {
79
46
  this.progress.removeBar(this);
80
47
  }
48
+ /**
49
+ * @param {?} changes
50
+ * @return {?}
51
+ */
52
+ ngOnChanges(changes) {
53
+ if (changes.value) {
54
+ if (!changes.value.currentValue && changes.value.currentValue !== 0) {
55
+ return;
56
+ }
57
+ this.value = changes.value.currentValue;
58
+ this.recalculatePercentage();
59
+ }
60
+ if (changes.type) {
61
+ this.type = changes.type.currentValue;
62
+ this.applyTypeClasses();
63
+ }
64
+ }
81
65
  /**
82
66
  * @return {?}
83
67
  */
@@ -111,14 +95,14 @@ export class BarComponent {
111
95
  this.renderer.removeClass(this.el.nativeElement, bgClass);
112
96
  this._prevType = null;
113
97
  }
114
- if (this._type) {
98
+ if (this.type) {
115
99
  /** @type {?} */
116
- const barTypeClass = `progress-bar-${this._type}`;
100
+ const barTypeClass = `progress-bar-${this.type}`;
117
101
  /** @type {?} */
118
- const bgClass = `bg-${this._type}`;
102
+ const bgClass = `bg-${this.type}`;
119
103
  this.renderer.addClass(this.el.nativeElement, barTypeClass);
120
104
  this.renderer.addClass(this.el.nativeElement, bgClass);
121
- this._prevType = this._type;
105
+ this._prevType = this.type;
122
106
  }
123
107
  }
124
108
  }
@@ -146,6 +130,7 @@ BarComponent.ctorParameters = () => [
146
130
  { type: Renderer2 }
147
131
  ];
148
132
  BarComponent.propDecorators = {
133
+ max: [{ type: Input }],
149
134
  type: [{ type: Input }],
150
135
  value: [{ type: Input }],
151
136
  setBarWidth: [{ type: HostBinding, args: ['style.width.%',] }],
@@ -154,6 +139,16 @@ BarComponent.propDecorators = {
154
139
  if (false) {
155
140
  /** @type {?} */
156
141
  BarComponent.prototype.max;
142
+ /**
143
+ * provide one of the four supported contextual classes: `success`, `info`, `warning`, `danger`
144
+ * @type {?}
145
+ */
146
+ BarComponent.prototype.type;
147
+ /**
148
+ * current value of progress bar
149
+ * @type {?}
150
+ */
151
+ BarComponent.prototype.value;
157
152
  /** @type {?} */
158
153
  BarComponent.prototype.addClass;
159
154
  /** @type {?} */
@@ -164,16 +159,6 @@ if (false) {
164
159
  BarComponent.prototype.percent;
165
160
  /** @type {?} */
166
161
  BarComponent.prototype.progress;
167
- /**
168
- * @type {?}
169
- * @protected
170
- */
171
- BarComponent.prototype._value;
172
- /**
173
- * @type {?}
174
- * @protected
175
- */
176
- BarComponent.prototype._type;
177
162
  /**
178
163
  * @type {?}
179
164
  * @private
@@ -190,4 +175,4 @@ if (false) {
190
175
  */
191
176
  BarComponent.prototype.renderer;
192
177
  }
193
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bar.component.js","sourceRoot":"ng://ngx-bootstrap/progressbar/","sources":["bar.component.ts"],"names":[],"mappings":"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","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"]}
178
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bar.component.js","sourceRoot":"ng://ngx-bootstrap/progressbar/","sources":["bar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Host,\n  HostBinding,\n  Input,\n  OnDestroy,\n  OnInit,\n  ElementRef,\n  Renderer2, SimpleChanges\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  @Input() max: number;\n  /** provide one of the four supported contextual classes: `success`, `info`, `warning`, `danger` */\n  @Input() type: string;\n\n  /** current value of progress bar */\n  @Input() value: number;\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  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  ngOnChanges(changes: SimpleChanges) {\n    if (changes.value) {\n      if (!changes.value.currentValue && changes.value.currentValue !== 0) {\n        return;\n      }\n      this.value = changes.value.currentValue;\n      this.recalculatePercentage();\n    }\n\n    if (changes.type) {\n      this.type = changes.type.currentValue;\n      this.applyTypeClasses();\n    }\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"]}
@@ -11,10 +11,10 @@ export class ProgressbarComponent {
11
11
  */
12
12
  constructor(config) {
13
13
  this.isStacked = false;
14
+ this._max = 100;
14
15
  this.addClass = true;
15
16
  /* tslint:disable-next-line:no-any */
16
17
  this.bars = [];
17
- this._max = 100;
18
18
  Object.assign(this, config);
19
19
  }
20
20
  /**
@@ -104,7 +104,7 @@ export class ProgressbarComponent {
104
104
  ProgressbarComponent.decorators = [
105
105
  { type: Component, args: [{
106
106
  selector: 'progressbar',
107
- template: "<bar [type]=\"type\" [value]=\"_value\" *ngIf=\"!isStacked\">\n <ng-content></ng-content>\n</bar>\n<ng-template [ngIf]=\"isStacked\">\n <bar *ngFor=\"let item of _value\" [type]=\"item.type\" [value]=\"item.value\">{{ item.label }}</bar>\n</ng-template>\n",
107
+ template: "<bar [type]=\"type\" [value]=\"_value\" [max]=\"_max\" *ngIf=\"!isStacked\">\n <ng-content></ng-content>\n</bar>\n<ng-template [ngIf]=\"isStacked\">\n <bar *ngFor=\"let item of _value\" [type]=\"item.type\" [value]=\"item.value\" [max]=\"item.max\">{{ item.label }}</bar>\n</ng-template>\n",
108
108
  styles: [`
109
109
  :host {
110
110
  width: 100%;
@@ -138,15 +138,12 @@ if (false) {
138
138
  /** @type {?} */
139
139
  ProgressbarComponent.prototype._animate;
140
140
  /** @type {?} */
141
+ ProgressbarComponent.prototype._max;
142
+ /** @type {?} */
141
143
  ProgressbarComponent.prototype._value;
142
144
  /** @type {?} */
143
145
  ProgressbarComponent.prototype.addClass;
144
146
  /** @type {?} */
145
147
  ProgressbarComponent.prototype.bars;
146
- /**
147
- * @type {?}
148
- * @protected
149
- */
150
- ProgressbarComponent.prototype._max;
151
148
  }
152
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZ3Jlc3NiYXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWJvb3RzdHJhcC9wcm9ncmVzc2Jhci8iLCJzb3VyY2VzIjpbInByb2dyZXNzYmFyLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzlELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBRXpELE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQWU1QyxNQUFNLE9BQU8sb0JBQW9COzs7O0lBMkQvQixZQUFZLE1BQXlCO1FBOUJyQyxjQUFTLEdBQUcsS0FBSyxDQUFDO1FBdUJhLGFBQVEsR0FBRyxJQUFJLENBQUM7O1FBRy9DLFNBQUksR0FBbUIsRUFBRSxDQUFDO1FBRWhCLFNBQUksR0FBRyxHQUFHLENBQUM7UUFHbkIsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsTUFBTSxDQUFDLENBQUM7SUFDOUIsQ0FBQzs7Ozs7O0lBM0RELElBQ0ksT0FBTyxDQUFDLEtBQWM7UUFDeEIsSUFBSSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUM7UUFDdEIsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPOzs7O1FBQUMsQ0FBQyxDQUFlLEVBQUUsRUFBRTtZQUNwQyxDQUFDLENBQUMsT0FBTyxHQUFHLEtBQUssQ0FBQztRQUNwQixDQUFDLEVBQUMsQ0FBQztJQUNMLENBQUM7Ozs7OztJQUVELElBQ0ksT0FBTyxDQUFDLEtBQWM7UUFDeEIsSUFBSSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUM7UUFDdEIsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPOzs7O1FBQUMsQ0FBQyxDQUFlLEVBQUUsRUFBRTtZQUNwQyxDQUFDLENBQUMsT0FBTyxHQUFHLEtBQUssQ0FBQztRQUNwQixDQUFDLEVBQUMsQ0FBQztJQUNMLENBQUM7Ozs7Ozs7SUFPRCxJQUVJLEtBQUssQ0FBQyxLQUFxQjtRQUM3QixJQUFJLENBQUMsU0FBUyxHQUFHLEtBQUssQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDdEMsSUFBSSxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUM7SUFDdEIsQ0FBQzs7OztJQU1ELElBQUksS0FBSztRQUNQLE9BQU8sS0FBSyxFQUFFLENBQUM7SUFDakIsQ0FBQzs7Ozs7SUFHRCxJQUVJLEdBQUc7UUFDTCxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUM7SUFDbkIsQ0FBQzs7Ozs7SUFFRCxJQUFJLEdBQUcsQ0FBQyxDQUFTO1FBQ2YsSUFBSSxDQUFDLElBQUksR0FBRyxDQUFDLENBQUM7UUFDZCxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU87Ozs7UUFBQyxDQUFDLEdBQWlCLEVBQUUsRUFBRTtZQUN0QyxHQUFHLENBQUMscUJBQXFCLEVBQUUsQ0FBQztRQUM5QixDQUFDLEVBQUMsQ0FBQztJQUNMLENBQUM7Ozs7O0lBWUQsTUFBTSxDQUFDLEdBQWlCO1FBQ3RCLEdBQUcsQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQztRQUM1QixHQUFHLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUM7UUFFNUIsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDdEIsQ0FBQzs7Ozs7SUFFRCxTQUFTLENBQUMsR0FBaUI7UUFDekIsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDOUMsQ0FBQzs7O1lBbkZGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsYUFBYTtnQkFDdkIsNlFBQTJDO3lCQUV6Qzs7Ozs7R0FLRDthQUVGOzs7O1lBaEJRLGlCQUFpQjs7O3NCQW1CdkIsS0FBSztzQkFRTCxLQUFLO21CQVNMLEtBQUs7b0JBSUwsS0FBSztrQkFnQkwsV0FBVyxTQUFDLFVBQVUsY0FDdEIsS0FBSzt1QkFZTCxXQUFXLFNBQUMsZ0JBQWdCOzs7Ozs7O0lBakM3QixvQ0FBK0I7O0lBVS9CLHlDQUFrQjs7SUFDbEIsd0NBQWtCOztJQUNsQix3Q0FBa0I7O0lBRWxCLHNDQUF1Qjs7SUFtQnZCLHdDQUErQzs7SUFHL0Msb0NBQTBCOzs7OztJQUUxQixvQ0FBcUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEhvc3RCaW5kaW5nLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUHJvZ3Jlc3NiYXJDb25maWcgfSBmcm9tICcuL3Byb2dyZXNzYmFyLmNvbmZpZyc7XG5pbXBvcnQgeyBQcm9ncmVzc2JhclR5cGUgfSBmcm9tICcuL3Byb2dyZXNzYmFyLXR5cGUuaW50ZXJmYWNlJztcbmltcG9ydCB7IGlzQnMzIH0gZnJvbSAnbmd4LWJvb3RzdHJhcC91dGlscyc7XG5pbXBvcnQgeyBCYXJDb21wb25lbnQgfSBmcm9tICcuL2Jhci5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdwcm9ncmVzc2JhcicsXG4gIHRlbXBsYXRlVXJsOiAnLi9wcm9ncmVzc2Jhci5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlczogW1xuICAgIGBcbiAgICA6aG9zdCB7XG4gICAgICB3aWR0aDogMTAwJTtcbiAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgfVxuICBgXG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgUHJvZ3Jlc3NiYXJDb21wb25lbnQge1xuICAvKiogaWYgYHRydWVgIGNoYW5naW5nIHZhbHVlIG9mIHByb2dyZXNzIGJhciB3aWxsIGJlIGFuaW1hdGVkICovXG4gIEBJbnB1dCgpXG4gIHNldCBhbmltYXRlKHZhbHVlOiBib29sZWFuKSB7XG4gICAgdGhpcy5fYW5pbWF0ZSA9IHZhbHVlO1xuICAgIHRoaXMuYmFycy5mb3JFYWNoKChiOiBCYXJDb21wb25lbnQpID0+IHtcbiAgICAgIGIuYW5pbWF0ZSA9IHZhbHVlO1xuICAgIH0pO1xuICB9XG4gIC8qKiBJZiBgdHJ1ZWAsIHN0cmlwZWQgY2xhc3NlcyBhcmUgYXBwbGllZCAqL1xuICBASW5wdXQoKVxuICBzZXQgc3RyaXBlZCh2YWx1ZTogYm9vbGVhbikge1xuICAgIHRoaXMuX3N0cmlwZWQgPSB2YWx1ZTtcbiAgICB0aGlzLmJhcnMuZm9yRWFjaCgoYjogQmFyQ29tcG9uZW50KSA9PiB7XG4gICAgICBiLnN0cmlwZWQgPSB2YWx1ZTtcbiAgICB9KTtcbiAgfVxuXG4gIC8qKiBwcm92aWRlIG9uZSBvZiB0aGUgZm91ciBzdXBwb3J0ZWQgY29udGV4dHVhbCBjbGFzc2VzOiBgc3VjY2Vzc2AsIGBpbmZvYCwgYHdhcm5pbmdgLCBgZGFuZ2VyYCAqL1xuICBASW5wdXQoKSB0eXBlOiBQcm9ncmVzc2JhclR5cGU7XG4gIC8qKiBjdXJyZW50IHZhbHVlIG9mIHByb2dyZXNzIGJhci4gQ291bGQgYmUgYSBudW1iZXIgb3IgYXJyYXkgb2Ygb2JqZWN0c1xuICAgKiBsaWtlIHtcInZhbHVlXCI6MTUsXCJ0eXBlXCI6XCJpbmZvXCIsXCJsYWJlbFwiOlwiMTUgJVwifVxuICAgKi9cbiAgQElucHV0KClcbiAgLyogdHNsaW50OmRpc2FibGUtbmV4dC1saW5lOm5vLWFueSAqL1xuICBzZXQgdmFsdWUodmFsdWU6IG51bWJlciB8IGFueVtdKSB7XG4gICAgdGhpcy5pc1N0YWNrZWQgPSBBcnJheS5pc0FycmF5KHZhbHVlKTtcbiAgICB0aGlzLl92YWx1ZSA9IHZhbHVlO1xuICB9XG4gIGlzU3RhY2tlZCA9IGZhbHNlO1xuICBfc3RyaXBlZDogYm9vbGVhbjtcbiAgX2FuaW1hdGU6IGJvb2xlYW47XG4gIC8qIHRzbGludDpkaXNhYmxlLW5leHQtbGluZTpuby1hbnkgKi9cbiAgX3ZhbHVlOiBudW1iZXIgfCBhbnlbXTtcbiAgZ2V0IGlzQnMzKCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiBpc0JzMygpO1xuICB9XG5cbiAgLyoqIG1heGltdW0gdG90YWwgdmFsdWUgb2YgcHJvZ3Jlc3MgZWxlbWVudCAqL1xuICBASG9zdEJpbmRpbmcoJ2F0dHIubWF4JylcbiAgQElucHV0KClcbiAgZ2V0IG1heCgpOiBudW1iZXIge1xuICAgIHJldHVybiB0aGlzLl9tYXg7XG4gIH1cblxuICBzZXQgbWF4KHY6IG51bWJlcikge1xuICAgIHRoaXMuX21heCA9IHY7XG4gICAgdGhpcy5iYXJzLmZvckVhY2goKGJhcjogQmFyQ29tcG9uZW50KSA9PiB7XG4gICAgICBiYXIucmVjYWxjdWxhdGVQZXJjZW50YWdlKCk7XG4gICAgfSk7XG4gIH1cblxuICBASG9zdEJpbmRpbmcoJ2NsYXNzLnByb2dyZXNzJykgYWRkQ2xhc3MgPSB0cnVlO1xuXG4gIC8qIHRzbGludDpkaXNhYmxlLW5leHQtbGluZTpuby1hbnkgKi9cbiAgYmFyczogQmFyQ29tcG9uZW50W10gPSBbXTtcblxuICBwcm90ZWN0ZWQgX21heCA9IDEwMDtcblxuICBjb25zdHJ1Y3Rvcihjb25maWc6IFByb2dyZXNzYmFyQ29uZmlnKSB7XG4gICAgT2JqZWN0LmFzc2lnbih0aGlzLCBjb25maWcpO1xuICB9XG4gIGFkZEJhcihiYXI6IEJhckNvbXBvbmVudCk6IHZvaWQge1xuICAgIGJhci5hbmltYXRlID0gdGhpcy5fYW5pbWF0ZTtcbiAgICBiYXIuc3RyaXBlZCA9IHRoaXMuX3N0cmlwZWQ7XG5cbiAgICB0aGlzLmJhcnMucHVzaChiYXIpO1xuICB9XG5cbiAgcmVtb3ZlQmFyKGJhcjogQmFyQ29tcG9uZW50KTogdm9pZCB7XG4gICAgdGhpcy5iYXJzLnNwbGljZSh0aGlzLmJhcnMuaW5kZXhPZihiYXIpLCAxKTtcbiAgfVxufVxuIl19
149
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZ3Jlc3NiYXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vbmd4LWJvb3RzdHJhcC9wcm9ncmVzc2Jhci8iLCJzb3VyY2VzIjpbInByb2dyZXNzYmFyLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzlELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBRXpELE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQWU1QyxNQUFNLE9BQU8sb0JBQW9COzs7O0lBMEQvQixZQUFZLE1BQXlCO1FBN0JyQyxjQUFTLEdBQUcsS0FBSyxDQUFDO1FBR2xCLFNBQUksR0FBRyxHQUFHLENBQUM7UUFzQm9CLGFBQVEsR0FBRyxJQUFJLENBQUM7O1FBRy9DLFNBQUksR0FBbUIsRUFBRSxDQUFDO1FBRXhCLE1BQU0sQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQzlCLENBQUM7Ozs7OztJQTFERCxJQUNJLE9BQU8sQ0FBQyxLQUFjO1FBQ3hCLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ3RCLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTzs7OztRQUFDLENBQUMsQ0FBZSxFQUFFLEVBQUU7WUFDcEMsQ0FBQyxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUM7UUFDcEIsQ0FBQyxFQUFDLENBQUM7SUFDTCxDQUFDOzs7Ozs7SUFFRCxJQUNJLE9BQU8sQ0FBQyxLQUFjO1FBQ3hCLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ3RCLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTzs7OztRQUFDLENBQUMsQ0FBZSxFQUFFLEVBQUU7WUFDcEMsQ0FBQyxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUM7UUFDcEIsQ0FBQyxFQUFDLENBQUM7SUFDTCxDQUFDOzs7Ozs7O0lBT0QsSUFFSSxLQUFLLENBQUMsS0FBcUI7UUFDN0IsSUFBSSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3RDLElBQUksQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFDO0lBQ3RCLENBQUM7Ozs7SUFRRCxJQUFJLEtBQUs7UUFDUCxPQUFPLEtBQUssRUFBRSxDQUFDO0lBQ2pCLENBQUM7Ozs7O0lBR0QsSUFFSSxHQUFHO1FBQ0wsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDO0lBQ25CLENBQUM7Ozs7O0lBRUQsSUFBSSxHQUFHLENBQUMsQ0FBUztRQUNmLElBQUksQ0FBQyxJQUFJLEdBQUcsQ0FBQyxDQUFDO1FBQ2QsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPOzs7O1FBQUMsQ0FBQyxHQUFpQixFQUFFLEVBQUU7WUFDdEMsR0FBRyxDQUFDLHFCQUFxQixFQUFFLENBQUM7UUFDOUIsQ0FBQyxFQUFDLENBQUM7SUFDTCxDQUFDOzs7OztJQVNELE1BQU0sQ0FBQyxHQUFpQjtRQUN0QixHQUFHLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUM7UUFDNUIsR0FBRyxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDO1FBRTVCLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3RCLENBQUM7Ozs7O0lBRUQsU0FBUyxDQUFDLEdBQWlCO1FBQ3pCLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQzlDLENBQUM7OztZQWxGRixTQUFTLFNBQUM7Z0JBQ1QsUUFBUSxFQUFFLGFBQWE7Z0JBQ3ZCLCtTQUEyQzt5QkFFekM7Ozs7O0dBS0Q7YUFFRjs7OztZQWhCUSxpQkFBaUI7OztzQkFtQnZCLEtBQUs7c0JBUUwsS0FBSzttQkFTTCxLQUFLO29CQUlMLEtBQUs7a0JBa0JMLFdBQVcsU0FBQyxVQUFVLGNBQ3RCLEtBQUs7dUJBWUwsV0FBVyxTQUFDLGdCQUFnQjs7Ozs7OztJQW5DN0Isb0NBQStCOztJQVUvQix5Q0FBa0I7O0lBQ2xCLHdDQUFrQjs7SUFDbEIsd0NBQWtCOztJQUNsQixvQ0FBVzs7SUFHWCxzQ0FBdUI7O0lBbUJ2Qix3Q0FBK0M7O0lBRy9DLG9DQUEwQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBQcm9ncmVzc2JhckNvbmZpZyB9IGZyb20gJy4vcHJvZ3Jlc3NiYXIuY29uZmlnJztcbmltcG9ydCB7IFByb2dyZXNzYmFyVHlwZSB9IGZyb20gJy4vcHJvZ3Jlc3NiYXItdHlwZS5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgaXNCczMgfSBmcm9tICduZ3gtYm9vdHN0cmFwL3V0aWxzJztcbmltcG9ydCB7IEJhckNvbXBvbmVudCB9IGZyb20gJy4vYmFyLmNvbXBvbmVudCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3Byb2dyZXNzYmFyJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3Byb2dyZXNzYmFyLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVzOiBbXG4gICAgYFxuICAgIDpob3N0IHtcbiAgICAgIHdpZHRoOiAxMDAlO1xuICAgICAgZGlzcGxheTogZmxleDtcbiAgICB9XG4gIGBcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBQcm9ncmVzc2JhckNvbXBvbmVudCB7XG4gIC8qKiBpZiBgdHJ1ZWAgY2hhbmdpbmcgdmFsdWUgb2YgcHJvZ3Jlc3MgYmFyIHdpbGwgYmUgYW5pbWF0ZWQgKi9cbiAgQElucHV0KClcbiAgc2V0IGFuaW1hdGUodmFsdWU6IGJvb2xlYW4pIHtcbiAgICB0aGlzLl9hbmltYXRlID0gdmFsdWU7XG4gICAgdGhpcy5iYXJzLmZvckVhY2goKGI6IEJhckNvbXBvbmVudCkgPT4ge1xuICAgICAgYi5hbmltYXRlID0gdmFsdWU7XG4gICAgfSk7XG4gIH1cbiAgLyoqIElmIGB0cnVlYCwgc3RyaXBlZCBjbGFzc2VzIGFyZSBhcHBsaWVkICovXG4gIEBJbnB1dCgpXG4gIHNldCBzdHJpcGVkKHZhbHVlOiBib29sZWFuKSB7XG4gICAgdGhpcy5fc3RyaXBlZCA9IHZhbHVlO1xuICAgIHRoaXMuYmFycy5mb3JFYWNoKChiOiBCYXJDb21wb25lbnQpID0+IHtcbiAgICAgIGIuc3RyaXBlZCA9IHZhbHVlO1xuICAgIH0pO1xuICB9XG5cbiAgLyoqIHByb3ZpZGUgb25lIG9mIHRoZSBmb3VyIHN1cHBvcnRlZCBjb250ZXh0dWFsIGNsYXNzZXM6IGBzdWNjZXNzYCwgYGluZm9gLCBgd2FybmluZ2AsIGBkYW5nZXJgICovXG4gIEBJbnB1dCgpIHR5cGU6IFByb2dyZXNzYmFyVHlwZTtcbiAgLyoqIGN1cnJlbnQgdmFsdWUgb2YgcHJvZ3Jlc3MgYmFyLiBDb3VsZCBiZSBhIG51bWJlciBvciBhcnJheSBvZiBvYmplY3RzXG4gICAqIGxpa2Uge1widmFsdWVcIjoxNSxcInR5cGVcIjpcImluZm9cIixcImxhYmVsXCI6XCIxNSAlXCJ9XG4gICAqL1xuICBASW5wdXQoKVxuICAvKiB0c2xpbnQ6ZGlzYWJsZS1uZXh0LWxpbmU6bm8tYW55ICovXG4gIHNldCB2YWx1ZSh2YWx1ZTogbnVtYmVyIHwgYW55W10pIHtcbiAgICB0aGlzLmlzU3RhY2tlZCA9IEFycmF5LmlzQXJyYXkodmFsdWUpO1xuICAgIHRoaXMuX3ZhbHVlID0gdmFsdWU7XG4gIH1cbiAgaXNTdGFja2VkID0gZmFsc2U7XG4gIF9zdHJpcGVkOiBib29sZWFuO1xuICBfYW5pbWF0ZTogYm9vbGVhbjtcbiAgX21heCA9IDEwMDtcblxuICAvKiB0c2xpbnQ6ZGlzYWJsZS1uZXh0LWxpbmU6bm8tYW55ICovXG4gIF92YWx1ZTogbnVtYmVyIHwgYW55W107XG4gIGdldCBpc0JzMygpOiBib29sZWFuIHtcbiAgICByZXR1cm4gaXNCczMoKTtcbiAgfVxuXG4gIC8qKiBtYXhpbXVtIHRvdGFsIHZhbHVlIG9mIHByb2dyZXNzIGVsZW1lbnQgKi9cbiAgQEhvc3RCaW5kaW5nKCdhdHRyLm1heCcpXG4gIEBJbnB1dCgpXG4gIGdldCBtYXgoKTogbnVtYmVyIHtcbiAgICByZXR1cm4gdGhpcy5fbWF4O1xuICB9XG5cbiAgc2V0IG1heCh2OiBudW1iZXIpIHtcbiAgICB0aGlzLl9tYXggPSB2O1xuICAgIHRoaXMuYmFycy5mb3JFYWNoKChiYXI6IEJhckNvbXBvbmVudCkgPT4ge1xuICAgICAgYmFyLnJlY2FsY3VsYXRlUGVyY2VudGFnZSgpO1xuICAgIH0pO1xuICB9XG5cbiAgQEhvc3RCaW5kaW5nKCdjbGFzcy5wcm9ncmVzcycpIGFkZENsYXNzID0gdHJ1ZTtcblxuICAvKiB0c2xpbnQ6ZGlzYWJsZS1uZXh0LWxpbmU6bm8tYW55ICovXG4gIGJhcnM6IEJhckNvbXBvbmVudFtdID0gW107XG4gIGNvbnN0cnVjdG9yKGNvbmZpZzogUHJvZ3Jlc3NiYXJDb25maWcpIHtcbiAgICBPYmplY3QuYXNzaWduKHRoaXMsIGNvbmZpZyk7XG4gIH1cbiAgYWRkQmFyKGJhcjogQmFyQ29tcG9uZW50KTogdm9pZCB7XG4gICAgYmFyLmFuaW1hdGUgPSB0aGlzLl9hbmltYXRlO1xuICAgIGJhci5zdHJpcGVkID0gdGhpcy5fc3RyaXBlZDtcblxuICAgIHRoaXMuYmFycy5wdXNoKGJhcik7XG4gIH1cblxuICByZW1vdmVCYXIoYmFyOiBCYXJDb21wb25lbnQpOiB2b2lkIHtcbiAgICB0aGlzLmJhcnMuc3BsaWNlKHRoaXMuYmFycy5pbmRleE9mKGJhciksIDEpO1xuICB9XG59XG4iXX0=