@datarailsshared/datarailsshared 1.6.316 → 1.6.318

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.
@@ -1,19 +1,31 @@
1
- import { Component, HostBinding, Input } from '@angular/core';
1
+ import { Component, ContentChild, HostBinding, Input, TemplateRef } from '@angular/core';
2
2
  import { CommonModule } from '@angular/common';
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "@angular/common";
5
+ function DrProgressBarComponent_ng_container_4_ng_container_1_Template(rf, ctx) { if (rf & 1) {
6
+ i0.ɵɵelementContainer(0);
7
+ } }
5
8
  function DrProgressBarComponent_ng_container_4_Template(rf, ctx) { if (rf & 1) {
6
9
  i0.ɵɵelementContainerStart(0);
7
- i0.ɵɵtext(1);
10
+ i0.ɵɵtemplate(1, DrProgressBarComponent_ng_container_4_ng_container_1_Template, 1, 0, "ng-container", 5);
8
11
  i0.ɵɵelementContainerEnd();
9
12
  } if (rf & 2) {
10
13
  const ctx_r0 = i0.ɵɵnextContext();
14
+ const _r1 = i0.ɵɵreference(6);
15
+ let tmp_0_0;
11
16
  i0.ɵɵadvance(1);
12
- i0.ɵɵtextInterpolate1("", ctx_r0.progress || 0, "%");
17
+ i0.ɵɵproperty("ngTemplateOutlet", (tmp_0_0 = ctx_r0.customValueTemplate) !== null && tmp_0_0 !== undefined ? tmp_0_0 : _r1)("ngTemplateOutletContext", ctx_r0.valueTemplateContext);
18
+ } }
19
+ function DrProgressBarComponent_ng_template_5_Template(rf, ctx) { if (rf & 1) {
20
+ i0.ɵɵtext(0);
21
+ } if (rf & 2) {
22
+ const progressPercent_r4 = ctx.progressPercent;
23
+ i0.ɵɵtextInterpolate1("", progressPercent_r4, "%");
13
24
  } }
14
25
  const _c0 = ["*"];
15
26
  export class DrProgressBarComponent {
16
27
  constructor() {
28
+ this.roundProgress = false;
17
29
  /**
18
30
  * Option to hide value label
19
31
  */
@@ -21,43 +33,104 @@ export class DrProgressBarComponent {
21
33
  this.theme = 'light';
22
34
  this.role = 'progressbar';
23
35
  this.ariaValueMin = 0;
24
- this.ariaValueMax = 100;
36
+ this._rawProgress = 0;
37
+ this._total = 100;
38
+ }
39
+ /**
40
+ * Progress value from 0 to total
41
+ */
42
+ set progress(value) {
43
+ this._rawProgress = this.clampNonNegativeNumber(value, 0);
44
+ }
45
+ get progress() {
46
+ return Math.min(this._rawProgress, this.total);
47
+ }
48
+ set total(value) {
49
+ this._total = this.clampNonNegativeNumber(value, 100);
50
+ }
51
+ get total() {
52
+ return this._total;
53
+ }
54
+ get ariaValueMax() {
55
+ return this.total;
25
56
  }
26
57
  get ariaValueNow() {
27
- return this.progress || 0;
58
+ return this.progress;
28
59
  }
29
60
  get ariaLabel() {
30
- const progressValue = this.progress || 0;
31
61
  if (this.customAriaLabel) {
32
- return `${this.customAriaLabel}: ${progressValue}% complete`;
62
+ return this.customAriaLabel
63
+ .replace(/\{progress\}/g, this.progress.toString())
64
+ .replace(/\{total\}/g, this.total.toString())
65
+ .replace(/\{progressPercent\}/g, this.progressPercent.toString());
66
+ }
67
+ return `Progress: ${this.progressPercent}% complete`;
68
+ }
69
+ get valueTemplateContext() {
70
+ return {
71
+ progress: this.progress,
72
+ total: this.total,
73
+ progressPercent: this.progressPercent,
74
+ };
75
+ }
76
+ get progressPercent() {
77
+ if (this.total <= 0) {
78
+ return 0;
33
79
  }
34
- return `Progress: ${progressValue}% complete`;
80
+ return this.clampProgress((this.progress / this.total) * 100);
81
+ }
82
+ clampProgress(value) {
83
+ if (Number.isNaN(value)) {
84
+ return 0;
85
+ }
86
+ const clampedValue = Math.min(100, Math.max(0, value));
87
+ return this.roundProgress ? Math.round(clampedValue) : clampedValue;
88
+ }
89
+ clampNonNegativeNumber(value, fallbackValue) {
90
+ const numericValue = typeof value === 'number' ? value : Number(value);
91
+ if (Number.isNaN(numericValue) || !Number.isFinite(numericValue)) {
92
+ return fallbackValue;
93
+ }
94
+ return Math.max(0, numericValue);
35
95
  }
36
96
  /** @nocollapse */ static { this.ɵfac = function DrProgressBarComponent_Factory(t) { return new (t || DrProgressBarComponent)(); }; }
37
- /** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrProgressBarComponent, selectors: [["dr-progress-bar"]], hostVars: 7, hostBindings: function DrProgressBarComponent_HostBindings(rf, ctx) { if (rf & 2) {
97
+ /** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrProgressBarComponent, selectors: [["dr-progress-bar"]], contentQueries: function DrProgressBarComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
98
+ i0.ɵɵcontentQuery(dirIndex, TemplateRef, 5);
99
+ } if (rf & 2) {
100
+ let _t;
101
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.customValueTemplate = _t.first);
102
+ } }, hostVars: 7, hostBindings: function DrProgressBarComponent_HostBindings(rf, ctx) { if (rf & 2) {
38
103
  i0.ɵɵattribute("role", ctx.role)("aria-valuemin", ctx.ariaValueMin)("aria-valuemax", ctx.ariaValueMax)("aria-valuenow", ctx.ariaValueNow)("aria-label", ctx.ariaLabel);
39
104
  i0.ɵɵclassMap(ctx.theme);
40
- } }, inputs: { progress: "progress", showValue: "showValue", theme: "theme", customAriaLabel: ["aria-label", "customAriaLabel"] }, standalone: true, features: [i0.ɵɵStandaloneFeature], ngContentSelectors: _c0, decls: 5, vars: 3, consts: [["aria-hidden", "true", 1, "progress-bar__background"], [1, "progress-bar__background__fill"], ["aria-hidden", "true", 1, "progress-bar__value"], [4, "ngIf"]], template: function DrProgressBarComponent_Template(rf, ctx) { if (rf & 1) {
105
+ } }, inputs: { progress: "progress", total: "total", roundProgress: "roundProgress", showValue: "showValue", theme: "theme", customAriaLabel: ["aria-label", "customAriaLabel"] }, standalone: true, features: [i0.ɵɵStandaloneFeature], ngContentSelectors: _c0, decls: 7, vars: 3, consts: [["aria-hidden", "true", 1, "progress-bar__background"], [1, "progress-bar__background__fill"], ["aria-hidden", "true", 1, "progress-bar__value"], [4, "ngIf"], ["defaultValueTemplate", ""], [4, "ngTemplateOutlet", "ngTemplateOutletContext"]], template: function DrProgressBarComponent_Template(rf, ctx) { if (rf & 1) {
41
106
  i0.ɵɵprojectionDef();
42
107
  i0.ɵɵelementStart(0, "div", 0);
43
108
  i0.ɵɵelement(1, "div", 1);
44
109
  i0.ɵɵelementEnd();
45
110
  i0.ɵɵelementStart(2, "span", 2);
46
111
  i0.ɵɵprojection(3);
47
- i0.ɵɵtemplate(4, DrProgressBarComponent_ng_container_4_Template, 2, 1, "ng-container", 3);
112
+ i0.ɵɵtemplate(4, DrProgressBarComponent_ng_container_4_Template, 2, 2, "ng-container", 3);
48
113
  i0.ɵɵelementEnd();
114
+ i0.ɵɵtemplate(5, DrProgressBarComponent_ng_template_5_Template, 1, 1, "ng-template", null, 4, i0.ɵɵtemplateRefExtractor);
49
115
  } if (rf & 2) {
50
116
  i0.ɵɵadvance(1);
51
- i0.ɵɵstyleProp("width", (ctx.progress || 0) + "%");
117
+ i0.ɵɵstyleProp("width", ctx.progressPercent + "%");
52
118
  i0.ɵɵadvance(3);
53
119
  i0.ɵɵproperty("ngIf", ctx.showValue);
54
- } }, dependencies: [CommonModule, i1.NgIf], styles: ["[_nghost-%COMP%]{display:flex;align-items:center;width:100%;gap:16px;height:6px}.progress-bar__value[_ngcontent-%COMP%]{display:flex;align-items:center;color:#333;font-size:14px;line-height:24px;font-weight:400}.progress-bar__background[_ngcontent-%COMP%]{display:flex;flex-grow:1;position:relative;background:#dfe0e3;border-radius:20px;height:inherit}.progress-bar__background__fill[_ngcontent-%COMP%]{transition:all .5s;position:absolute;left:0;top:0;width:0;height:100%;background:#4646ce;border-radius:20px}.dark[_nghost-%COMP%] .progress-bar__value[_ngcontent-%COMP%]{color:#fff}"] }); }
120
+ } }, dependencies: [CommonModule, i1.NgIf, i1.NgTemplateOutlet], styles: ["[_nghost-%COMP%]{display:flex;align-items:center;width:100%;gap:16px;height:6px}.progress-bar__value[_ngcontent-%COMP%]{display:flex;align-items:center;color:#333;font-size:14px;line-height:24px;font-weight:400}.progress-bar__value[_ngcontent-%COMP%]:empty{display:none}.progress-bar__background[_ngcontent-%COMP%]{display:flex;flex-grow:1;position:relative;background:#dfe0e3;border-radius:20px;height:inherit}.progress-bar__background__fill[_ngcontent-%COMP%]{transition:all .5s;position:absolute;left:0;top:0;width:0;height:100%;background:#4646ce;border-radius:20px}.dark[_nghost-%COMP%] .progress-bar__value[_ngcontent-%COMP%]{color:#fff}"] }); }
55
121
  }
56
122
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrProgressBarComponent, [{
57
123
  type: Component,
58
- args: [{ selector: 'dr-progress-bar', standalone: true, imports: [CommonModule], template: "<div class=\"progress-bar__background\" aria-hidden=\"true\">\n <div class=\"progress-bar__background__fill\" [style.width]=\"(progress || 0) + '%'\"></div>\n</div>\n<span class=\"progress-bar__value\" aria-hidden=\"true\">\n <ng-content></ng-content>\n <ng-container *ngIf=\"showValue\">{{ progress || 0 }}%</ng-container>\n</span>\n", styles: [":host{display:flex;align-items:center;width:100%;gap:16px;height:6px}.progress-bar__value{display:flex;align-items:center;color:#333;font-size:14px;line-height:24px;font-weight:400}.progress-bar__background{display:flex;flex-grow:1;position:relative;background:#dfe0e3;border-radius:20px;height:inherit}.progress-bar__background__fill{transition:all .5s;position:absolute;left:0;top:0;width:0;height:100%;background:#4646ce;border-radius:20px}:host(.dark) .progress-bar__value{color:#fff}\n"] }]
124
+ args: [{ selector: 'dr-progress-bar', standalone: true, imports: [CommonModule], template: "<div class=\"progress-bar__background\" aria-hidden=\"true\">\n <div class=\"progress-bar__background__fill\" [style.width]=\"progressPercent + '%'\"></div>\n</div>\n<span class=\"progress-bar__value\" aria-hidden=\"true\">\n <ng-content></ng-content>\n <ng-container *ngIf=\"showValue\">\n <ng-container\n *ngTemplateOutlet=\"customValueTemplate ?? defaultValueTemplate; context: valueTemplateContext\"></ng-container>\n </ng-container>\n</span>\n<ng-template #defaultValueTemplate let-progressPercent=\"progressPercent\">{{ progressPercent }}%</ng-template>\n", styles: [":host{display:flex;align-items:center;width:100%;gap:16px;height:6px}.progress-bar__value{display:flex;align-items:center;color:#333;font-size:14px;line-height:24px;font-weight:400}.progress-bar__value:empty{display:none}.progress-bar__background{display:flex;flex-grow:1;position:relative;background:#dfe0e3;border-radius:20px;height:inherit}.progress-bar__background__fill{transition:all .5s;position:absolute;left:0;top:0;width:0;height:100%;background:#4646ce;border-radius:20px}:host(.dark) .progress-bar__value{color:#fff}\n"] }]
59
125
  }], null, { progress: [{
60
126
  type: Input
127
+ }], total: [{
128
+ type: Input
129
+ }], roundProgress: [{
130
+ type: Input
131
+ }], customValueTemplate: [{
132
+ type: ContentChild,
133
+ args: [TemplateRef]
61
134
  }], showValue: [{
62
135
  type: Input
63
136
  }], theme: [{
@@ -84,4 +157,4 @@ export class DrProgressBarComponent {
84
157
  type: HostBinding,
85
158
  args: ['attr.aria-label']
86
159
  }] }); })();
87
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItcHJvZ3Jlc3MtYmFyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLXByb2dyZXNzLWJhci9kci1wcm9ncmVzcy1iYXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGF0YXJhaWxzc2hhcmVkL3NyYy9saWIvZHItcHJvZ3Jlc3MtYmFyL2RyLXByb2dyZXNzLWJhci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDOUQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDOzs7O0lDSTNDLDZCQUFnQztJQUFBLFlBQW9CO0lBQUEsMEJBQWU7OztJQUFuQyxlQUFvQjtJQUFwQixvREFBb0I7OztBRE94RCxNQUFNLE9BQU8sc0JBQXNCO0lBUG5DO1FBY0k7O1dBRUc7UUFFSCxjQUFTLEdBQUcsSUFBSSxDQUFDO1FBSWpCLFVBQUssR0FBc0IsT0FBTyxDQUFDO1FBUzFCLFNBQUksR0FBRyxhQUFhLENBQUM7UUFHckIsaUJBQVksR0FBRyxDQUFDLENBQUM7UUFHakIsaUJBQVksR0FBRyxHQUFHLENBQUM7S0FlL0I7SUFiRyxJQUNJLFlBQVk7UUFDWixPQUFPLElBQUksQ0FBQyxRQUFRLElBQUksQ0FBQyxDQUFDO0lBQzlCLENBQUM7SUFFRCxJQUNJLFNBQVM7UUFDVCxNQUFNLGFBQWEsR0FBRyxJQUFJLENBQUMsUUFBUSxJQUFJLENBQUMsQ0FBQztRQUN6QyxJQUFJLElBQUksQ0FBQyxlQUFlLEVBQUU7WUFDdEIsT0FBTyxHQUFHLElBQUksQ0FBQyxlQUFlLEtBQUssYUFBYSxZQUFZLENBQUM7U0FDaEU7UUFDRCxPQUFPLGFBQWEsYUFBYSxZQUFZLENBQUM7SUFDbEQsQ0FBQzswR0E1Q1Esc0JBQXNCO21HQUF0QixzQkFBc0I7Ozs7O1lDWm5DLDhCQUF5RDtZQUNyRCx5QkFBd0Y7WUFDNUYsaUJBQU07WUFDTiwrQkFBcUQ7WUFDakQsa0JBQXlCO1lBQ3pCLHlGQUFtRTtZQUN2RSxpQkFBTzs7WUFMeUMsZUFBcUM7WUFBckMsa0RBQXFDO1lBSWxFLGVBQWU7WUFBZixvQ0FBZTs0QkRLcEIsWUFBWTs7dUZBRWIsc0JBQXNCO2NBUGxDLFNBQVM7MkJBQ0ksaUJBQWlCLGNBR2YsSUFBSSxXQUNQLENBQUMsWUFBWSxDQUFDO2dCQU92QixRQUFRO2tCQURQLEtBQUs7WUFPTixTQUFTO2tCQURSLEtBQUs7WUFLTixLQUFLO2tCQUZKLEtBQUs7O2tCQUNMLFdBQVc7bUJBQUMsT0FBTztZQU9wQixlQUFlO2tCQURkLEtBQUs7bUJBQUMsWUFBWTtZQUlWLElBQUk7a0JBRFosV0FBVzttQkFBQyxXQUFXO1lBSWYsWUFBWTtrQkFEcEIsV0FBVzttQkFBQyxvQkFBb0I7WUFJeEIsWUFBWTtrQkFEcEIsV0FBVzttQkFBQyxvQkFBb0I7WUFJN0IsWUFBWTtrQkFEZixXQUFXO21CQUFDLG9CQUFvQjtZQU03QixTQUFTO2tCQURaLFdBQVc7bUJBQUMsaUJBQWlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBIb3N0QmluZGluZywgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbmV4cG9ydCB0eXBlIFRQcm9ncmVzc0JhclRoZW1lID0gJ2xpZ2h0JyB8ICdkYXJrJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdkci1wcm9ncmVzcy1iYXInLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9kci1wcm9ncmVzcy1iYXIuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL2RyLXByb2dyZXNzLWJhci5jb21wb25lbnQuc2NzcyddLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG59KVxuZXhwb3J0IGNsYXNzIERyUHJvZ3Jlc3NCYXJDb21wb25lbnQge1xuICAgIC8qKlxuICAgICAqIFByb2dyZXNzIHZhbHVlIGZyb20gMCB0byAxMDBcbiAgICAgKi9cbiAgICBASW5wdXQoKVxuICAgIHByb2dyZXNzPzogbnVtYmVyO1xuXG4gICAgLyoqXG4gICAgICogT3B0aW9uIHRvIGhpZGUgdmFsdWUgbGFiZWxcbiAgICAgKi9cbiAgICBASW5wdXQoKVxuICAgIHNob3dWYWx1ZSA9IHRydWU7XG5cbiAgICBASW5wdXQoKVxuICAgIEBIb3N0QmluZGluZygnY2xhc3MnKVxuICAgIHRoZW1lOiBUUHJvZ3Jlc3NCYXJUaGVtZSA9ICdsaWdodCc7XG5cbiAgICAvKipcbiAgICAgKiBDdXN0b20gYWNjZXNzaWJsZSBsYWJlbCBmb3Igc2NyZWVuIHJlYWRlcnNcbiAgICAgKi9cbiAgICBASW5wdXQoJ2FyaWEtbGFiZWwnKVxuICAgIGN1c3RvbUFyaWFMYWJlbD86IHN0cmluZztcblxuICAgIEBIb3N0QmluZGluZygnYXR0ci5yb2xlJylcbiAgICByZWFkb25seSByb2xlID0gJ3Byb2dyZXNzYmFyJztcblxuICAgIEBIb3N0QmluZGluZygnYXR0ci5hcmlhLXZhbHVlbWluJylcbiAgICByZWFkb25seSBhcmlhVmFsdWVNaW4gPSAwO1xuXG4gICAgQEhvc3RCaW5kaW5nKCdhdHRyLmFyaWEtdmFsdWVtYXgnKVxuICAgIHJlYWRvbmx5IGFyaWFWYWx1ZU1heCA9IDEwMDtcblxuICAgIEBIb3N0QmluZGluZygnYXR0ci5hcmlhLXZhbHVlbm93JylcbiAgICBnZXQgYXJpYVZhbHVlTm93KCk6IG51bWJlciB7XG4gICAgICAgIHJldHVybiB0aGlzLnByb2dyZXNzIHx8IDA7XG4gICAgfVxuXG4gICAgQEhvc3RCaW5kaW5nKCdhdHRyLmFyaWEtbGFiZWwnKVxuICAgIGdldCBhcmlhTGFiZWwoKTogc3RyaW5nIHtcbiAgICAgICAgY29uc3QgcHJvZ3Jlc3NWYWx1ZSA9IHRoaXMucHJvZ3Jlc3MgfHwgMDtcbiAgICAgICAgaWYgKHRoaXMuY3VzdG9tQXJpYUxhYmVsKSB7XG4gICAgICAgICAgICByZXR1cm4gYCR7dGhpcy5jdXN0b21BcmlhTGFiZWx9OiAke3Byb2dyZXNzVmFsdWV9JSBjb21wbGV0ZWA7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIGBQcm9ncmVzczogJHtwcm9ncmVzc1ZhbHVlfSUgY29tcGxldGVgO1xuICAgIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJwcm9ncmVzcy1iYXJfX2JhY2tncm91bmRcIiBhcmlhLWhpZGRlbj1cInRydWVcIj5cbiAgICA8ZGl2IGNsYXNzPVwicHJvZ3Jlc3MtYmFyX19iYWNrZ3JvdW5kX19maWxsXCIgW3N0eWxlLndpZHRoXT1cIihwcm9ncmVzcyB8fCAwKSArICclJ1wiPjwvZGl2PlxuPC9kaXY+XG48c3BhbiBjbGFzcz1cInByb2dyZXNzLWJhcl9fdmFsdWVcIiBhcmlhLWhpZGRlbj1cInRydWVcIj5cbiAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4gICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cInNob3dWYWx1ZVwiPnt7IHByb2dyZXNzIHx8IDAgfX0lPC9uZy1jb250YWluZXI+XG48L3NwYW4+XG4iXX0=
160
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-progress-bar.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-progress-bar/dr-progress-bar.component.ts","../../../../../projects/datarailsshared/src/lib/dr-progress-bar/dr-progress-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ContentChild, HostBinding, Input, TemplateRef } from '@angular/core';\nimport { CommonModule } from '@angular/common';\n\nexport type TProgressBarTheme = 'light' | 'dark';\nexport type TProgressBarValueTemplateContext = {\n    progress: number;\n    total: number;\n    progressPercent: number;\n};\n\n@Component({\n    selector: 'dr-progress-bar',\n    templateUrl: './dr-progress-bar.component.html',\n    styleUrls: ['./dr-progress-bar.component.scss'],\n    standalone: true,\n    imports: [CommonModule],\n})\nexport class DrProgressBarComponent {\n    /**\n     * Progress value from 0 to total\n     */\n    @Input()\n    set progress(value: number | undefined) {\n        this._rawProgress = this.clampNonNegativeNumber(value, 0);\n    }\n    get progress(): number {\n        return Math.min(this._rawProgress, this.total);\n    }\n\n    @Input()\n    set total(value: number | undefined) {\n        this._total = this.clampNonNegativeNumber(value, 100);\n    }\n    get total(): number {\n        return this._total;\n    }\n\n    @Input()\n    roundProgress = false;\n\n    @ContentChild(TemplateRef)\n    customValueTemplate?: TemplateRef<TProgressBarValueTemplateContext>;\n\n    /**\n     * Option to hide value label\n     */\n    @Input()\n    showValue = true;\n\n    @Input()\n    @HostBinding('class')\n    theme: TProgressBarTheme = 'light';\n\n    /**\n     * Custom accessible label for screen readers\n     */\n    @Input('aria-label')\n    customAriaLabel?: string;\n\n    @HostBinding('attr.role')\n    readonly role = 'progressbar';\n\n    @HostBinding('attr.aria-valuemin')\n    readonly ariaValueMin = 0;\n\n    @HostBinding('attr.aria-valuemax')\n    get ariaValueMax(): number {\n        return this.total;\n    }\n\n    @HostBinding('attr.aria-valuenow')\n    get ariaValueNow(): number {\n        return this.progress;\n    }\n\n    @HostBinding('attr.aria-label')\n    get ariaLabel(): string {\n        if (this.customAriaLabel) {\n            return this.customAriaLabel\n                .replace(/\\{progress\\}/g, this.progress.toString())\n                .replace(/\\{total\\}/g, this.total.toString())\n                .replace(/\\{progressPercent\\}/g, this.progressPercent.toString());\n        }\n\n        return `Progress: ${this.progressPercent}% complete`;\n    }\n\n    get valueTemplateContext(): TProgressBarValueTemplateContext {\n        return {\n            progress: this.progress,\n            total: this.total,\n            progressPercent: this.progressPercent,\n        };\n    }\n\n    get progressPercent(): number {\n        if (this.total <= 0) {\n            return 0;\n        }\n\n        return this.clampProgress((this.progress / this.total) * 100);\n    }\n\n    private clampProgress(value: number): number {\n        if (Number.isNaN(value)) {\n            return 0;\n        }\n\n        const clampedValue = Math.min(100, Math.max(0, value));\n        return this.roundProgress ? Math.round(clampedValue) : clampedValue;\n    }\n\n    private clampNonNegativeNumber(value: unknown, fallbackValue: number): number {\n        const numericValue = typeof value === 'number' ? value : Number(value);\n        if (Number.isNaN(numericValue) || !Number.isFinite(numericValue)) {\n            return fallbackValue;\n        }\n\n        return Math.max(0, numericValue);\n    }\n\n    private _rawProgress = 0;\n    private _total = 100;\n}\n","<div class=\"progress-bar__background\" aria-hidden=\"true\">\n    <div class=\"progress-bar__background__fill\" [style.width]=\"progressPercent + '%'\"></div>\n</div>\n<span class=\"progress-bar__value\" aria-hidden=\"true\">\n    <ng-content></ng-content>\n    <ng-container *ngIf=\"showValue\">\n        <ng-container\n            *ngTemplateOutlet=\"customValueTemplate ?? defaultValueTemplate; context: valueTemplateContext\"></ng-container>\n    </ng-container>\n</span>\n<ng-template #defaultValueTemplate let-progressPercent=\"progressPercent\">{{ progressPercent }}%</ng-template>\n"]}
@@ -15183,18 +15183,30 @@ class DrGalleryComponent {
15183
15183
  args: ['carouselItem']
15184
15184
  }] }); })();
15185
15185
 
15186
+ function DrProgressBarComponent_ng_container_4_ng_container_1_Template(rf, ctx) { if (rf & 1) {
15187
+ i0.ɵɵelementContainer(0);
15188
+ } }
15186
15189
  function DrProgressBarComponent_ng_container_4_Template(rf, ctx) { if (rf & 1) {
15187
15190
  i0.ɵɵelementContainerStart(0);
15188
- i0.ɵɵtext(1);
15191
+ i0.ɵɵtemplate(1, DrProgressBarComponent_ng_container_4_ng_container_1_Template, 1, 0, "ng-container", 5);
15189
15192
  i0.ɵɵelementContainerEnd();
15190
15193
  } if (rf & 2) {
15191
15194
  const ctx_r0 = i0.ɵɵnextContext();
15195
+ const _r1 = i0.ɵɵreference(6);
15196
+ let tmp_0_0;
15192
15197
  i0.ɵɵadvance(1);
15193
- i0.ɵɵtextInterpolate1("", ctx_r0.progress || 0, "%");
15198
+ i0.ɵɵproperty("ngTemplateOutlet", (tmp_0_0 = ctx_r0.customValueTemplate) !== null && tmp_0_0 !== undefined ? tmp_0_0 : _r1)("ngTemplateOutletContext", ctx_r0.valueTemplateContext);
15199
+ } }
15200
+ function DrProgressBarComponent_ng_template_5_Template(rf, ctx) { if (rf & 1) {
15201
+ i0.ɵɵtext(0);
15202
+ } if (rf & 2) {
15203
+ const progressPercent_r4 = ctx.progressPercent;
15204
+ i0.ɵɵtextInterpolate1("", progressPercent_r4, "%");
15194
15205
  } }
15195
15206
  const _c0$m = ["*"];
15196
15207
  class DrProgressBarComponent {
15197
15208
  constructor() {
15209
+ this.roundProgress = false;
15198
15210
  /**
15199
15211
  * Option to hide value label
15200
15212
  */
@@ -15202,43 +15214,104 @@ class DrProgressBarComponent {
15202
15214
  this.theme = 'light';
15203
15215
  this.role = 'progressbar';
15204
15216
  this.ariaValueMin = 0;
15205
- this.ariaValueMax = 100;
15217
+ this._rawProgress = 0;
15218
+ this._total = 100;
15219
+ }
15220
+ /**
15221
+ * Progress value from 0 to total
15222
+ */
15223
+ set progress(value) {
15224
+ this._rawProgress = this.clampNonNegativeNumber(value, 0);
15225
+ }
15226
+ get progress() {
15227
+ return Math.min(this._rawProgress, this.total);
15228
+ }
15229
+ set total(value) {
15230
+ this._total = this.clampNonNegativeNumber(value, 100);
15231
+ }
15232
+ get total() {
15233
+ return this._total;
15234
+ }
15235
+ get ariaValueMax() {
15236
+ return this.total;
15206
15237
  }
15207
15238
  get ariaValueNow() {
15208
- return this.progress || 0;
15239
+ return this.progress;
15209
15240
  }
15210
15241
  get ariaLabel() {
15211
- const progressValue = this.progress || 0;
15212
15242
  if (this.customAriaLabel) {
15213
- return `${this.customAriaLabel}: ${progressValue}% complete`;
15243
+ return this.customAriaLabel
15244
+ .replace(/\{progress\}/g, this.progress.toString())
15245
+ .replace(/\{total\}/g, this.total.toString())
15246
+ .replace(/\{progressPercent\}/g, this.progressPercent.toString());
15247
+ }
15248
+ return `Progress: ${this.progressPercent}% complete`;
15249
+ }
15250
+ get valueTemplateContext() {
15251
+ return {
15252
+ progress: this.progress,
15253
+ total: this.total,
15254
+ progressPercent: this.progressPercent,
15255
+ };
15256
+ }
15257
+ get progressPercent() {
15258
+ if (this.total <= 0) {
15259
+ return 0;
15260
+ }
15261
+ return this.clampProgress((this.progress / this.total) * 100);
15262
+ }
15263
+ clampProgress(value) {
15264
+ if (Number.isNaN(value)) {
15265
+ return 0;
15266
+ }
15267
+ const clampedValue = Math.min(100, Math.max(0, value));
15268
+ return this.roundProgress ? Math.round(clampedValue) : clampedValue;
15269
+ }
15270
+ clampNonNegativeNumber(value, fallbackValue) {
15271
+ const numericValue = typeof value === 'number' ? value : Number(value);
15272
+ if (Number.isNaN(numericValue) || !Number.isFinite(numericValue)) {
15273
+ return fallbackValue;
15214
15274
  }
15215
- return `Progress: ${progressValue}% complete`;
15275
+ return Math.max(0, numericValue);
15216
15276
  }
15217
15277
  /** @nocollapse */ static { this.ɵfac = function DrProgressBarComponent_Factory(t) { return new (t || DrProgressBarComponent)(); }; }
15218
- /** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrProgressBarComponent, selectors: [["dr-progress-bar"]], hostVars: 7, hostBindings: function DrProgressBarComponent_HostBindings(rf, ctx) { if (rf & 2) {
15278
+ /** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrProgressBarComponent, selectors: [["dr-progress-bar"]], contentQueries: function DrProgressBarComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
15279
+ i0.ɵɵcontentQuery(dirIndex, TemplateRef, 5);
15280
+ } if (rf & 2) {
15281
+ let _t;
15282
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.customValueTemplate = _t.first);
15283
+ } }, hostVars: 7, hostBindings: function DrProgressBarComponent_HostBindings(rf, ctx) { if (rf & 2) {
15219
15284
  i0.ɵɵattribute("role", ctx.role)("aria-valuemin", ctx.ariaValueMin)("aria-valuemax", ctx.ariaValueMax)("aria-valuenow", ctx.ariaValueNow)("aria-label", ctx.ariaLabel);
15220
15285
  i0.ɵɵclassMap(ctx.theme);
15221
- } }, inputs: { progress: "progress", showValue: "showValue", theme: "theme", customAriaLabel: ["aria-label", "customAriaLabel"] }, standalone: true, features: [i0.ɵɵStandaloneFeature], ngContentSelectors: _c0$m, decls: 5, vars: 3, consts: [["aria-hidden", "true", 1, "progress-bar__background"], [1, "progress-bar__background__fill"], ["aria-hidden", "true", 1, "progress-bar__value"], [4, "ngIf"]], template: function DrProgressBarComponent_Template(rf, ctx) { if (rf & 1) {
15286
+ } }, inputs: { progress: "progress", total: "total", roundProgress: "roundProgress", showValue: "showValue", theme: "theme", customAriaLabel: ["aria-label", "customAriaLabel"] }, standalone: true, features: [i0.ɵɵStandaloneFeature], ngContentSelectors: _c0$m, decls: 7, vars: 3, consts: [["aria-hidden", "true", 1, "progress-bar__background"], [1, "progress-bar__background__fill"], ["aria-hidden", "true", 1, "progress-bar__value"], [4, "ngIf"], ["defaultValueTemplate", ""], [4, "ngTemplateOutlet", "ngTemplateOutletContext"]], template: function DrProgressBarComponent_Template(rf, ctx) { if (rf & 1) {
15222
15287
  i0.ɵɵprojectionDef();
15223
15288
  i0.ɵɵelementStart(0, "div", 0);
15224
15289
  i0.ɵɵelement(1, "div", 1);
15225
15290
  i0.ɵɵelementEnd();
15226
15291
  i0.ɵɵelementStart(2, "span", 2);
15227
15292
  i0.ɵɵprojection(3);
15228
- i0.ɵɵtemplate(4, DrProgressBarComponent_ng_container_4_Template, 2, 1, "ng-container", 3);
15293
+ i0.ɵɵtemplate(4, DrProgressBarComponent_ng_container_4_Template, 2, 2, "ng-container", 3);
15229
15294
  i0.ɵɵelementEnd();
15295
+ i0.ɵɵtemplate(5, DrProgressBarComponent_ng_template_5_Template, 1, 1, "ng-template", null, 4, i0.ɵɵtemplateRefExtractor);
15230
15296
  } if (rf & 2) {
15231
15297
  i0.ɵɵadvance(1);
15232
- i0.ɵɵstyleProp("width", (ctx.progress || 0) + "%");
15298
+ i0.ɵɵstyleProp("width", ctx.progressPercent + "%");
15233
15299
  i0.ɵɵadvance(3);
15234
15300
  i0.ɵɵproperty("ngIf", ctx.showValue);
15235
- } }, dependencies: [CommonModule, i1$1.NgIf], styles: ["[_nghost-%COMP%]{display:flex;align-items:center;width:100%;gap:16px;height:6px}.progress-bar__value[_ngcontent-%COMP%]{display:flex;align-items:center;color:#333;font-size:14px;line-height:24px;font-weight:400}.progress-bar__background[_ngcontent-%COMP%]{display:flex;flex-grow:1;position:relative;background:#dfe0e3;border-radius:20px;height:inherit}.progress-bar__background__fill[_ngcontent-%COMP%]{transition:all .5s;position:absolute;left:0;top:0;width:0;height:100%;background:#4646ce;border-radius:20px}.dark[_nghost-%COMP%] .progress-bar__value[_ngcontent-%COMP%]{color:#fff}"] }); }
15301
+ } }, dependencies: [CommonModule, i1$1.NgIf, i1$1.NgTemplateOutlet], styles: ["[_nghost-%COMP%]{display:flex;align-items:center;width:100%;gap:16px;height:6px}.progress-bar__value[_ngcontent-%COMP%]{display:flex;align-items:center;color:#333;font-size:14px;line-height:24px;font-weight:400}.progress-bar__value[_ngcontent-%COMP%]:empty{display:none}.progress-bar__background[_ngcontent-%COMP%]{display:flex;flex-grow:1;position:relative;background:#dfe0e3;border-radius:20px;height:inherit}.progress-bar__background__fill[_ngcontent-%COMP%]{transition:all .5s;position:absolute;left:0;top:0;width:0;height:100%;background:#4646ce;border-radius:20px}.dark[_nghost-%COMP%] .progress-bar__value[_ngcontent-%COMP%]{color:#fff}"] }); }
15236
15302
  }
15237
15303
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrProgressBarComponent, [{
15238
15304
  type: Component,
15239
- args: [{ selector: 'dr-progress-bar', standalone: true, imports: [CommonModule], template: "<div class=\"progress-bar__background\" aria-hidden=\"true\">\n <div class=\"progress-bar__background__fill\" [style.width]=\"(progress || 0) + '%'\"></div>\n</div>\n<span class=\"progress-bar__value\" aria-hidden=\"true\">\n <ng-content></ng-content>\n <ng-container *ngIf=\"showValue\">{{ progress || 0 }}%</ng-container>\n</span>\n", styles: [":host{display:flex;align-items:center;width:100%;gap:16px;height:6px}.progress-bar__value{display:flex;align-items:center;color:#333;font-size:14px;line-height:24px;font-weight:400}.progress-bar__background{display:flex;flex-grow:1;position:relative;background:#dfe0e3;border-radius:20px;height:inherit}.progress-bar__background__fill{transition:all .5s;position:absolute;left:0;top:0;width:0;height:100%;background:#4646ce;border-radius:20px}:host(.dark) .progress-bar__value{color:#fff}\n"] }]
15305
+ args: [{ selector: 'dr-progress-bar', standalone: true, imports: [CommonModule], template: "<div class=\"progress-bar__background\" aria-hidden=\"true\">\n <div class=\"progress-bar__background__fill\" [style.width]=\"progressPercent + '%'\"></div>\n</div>\n<span class=\"progress-bar__value\" aria-hidden=\"true\">\n <ng-content></ng-content>\n <ng-container *ngIf=\"showValue\">\n <ng-container\n *ngTemplateOutlet=\"customValueTemplate ?? defaultValueTemplate; context: valueTemplateContext\"></ng-container>\n </ng-container>\n</span>\n<ng-template #defaultValueTemplate let-progressPercent=\"progressPercent\">{{ progressPercent }}%</ng-template>\n", styles: [":host{display:flex;align-items:center;width:100%;gap:16px;height:6px}.progress-bar__value{display:flex;align-items:center;color:#333;font-size:14px;line-height:24px;font-weight:400}.progress-bar__value:empty{display:none}.progress-bar__background{display:flex;flex-grow:1;position:relative;background:#dfe0e3;border-radius:20px;height:inherit}.progress-bar__background__fill{transition:all .5s;position:absolute;left:0;top:0;width:0;height:100%;background:#4646ce;border-radius:20px}:host(.dark) .progress-bar__value{color:#fff}\n"] }]
15240
15306
  }], null, { progress: [{
15241
15307
  type: Input
15308
+ }], total: [{
15309
+ type: Input
15310
+ }], roundProgress: [{
15311
+ type: Input
15312
+ }], customValueTemplate: [{
15313
+ type: ContentChild,
15314
+ args: [TemplateRef]
15242
15315
  }], showValue: [{
15243
15316
  type: Input
15244
15317
  }], theme: [{