@datarailsshared/datarailsshared 1.6.371 → 1.6.373

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.
@@ -25,7 +25,10 @@ function DrProgressBarComponent_ng_template_5_Template(rf, ctx) { if (rf & 1) {
25
25
  const _c0 = ["*"];
26
26
  export class DrProgressBarComponent {
27
27
  constructor() {
28
- this.roundProgress = false;
28
+ /**
29
+ * Integer number of decimal places for progressPercent (0-100, default: 2)
30
+ */
31
+ this.progressPrecision = 2;
29
32
  /**
30
33
  * Option to hide value label
31
34
  */
@@ -77,14 +80,22 @@ export class DrProgressBarComponent {
77
80
  if (this.total <= 0) {
78
81
  return 0;
79
82
  }
80
- return this.clampProgress((this.progress / this.total) * 100);
83
+ const raw = (this.progress / this.total) * 100;
84
+ const clamped = this.clampProgress(raw);
85
+ const precision = Math.min(100, Math.max(0, Math.floor(this.progressPrecision)));
86
+ if (precision === 0) {
87
+ return Math.round(clamped);
88
+ }
89
+ if (Number.isInteger(clamped)) {
90
+ return clamped;
91
+ }
92
+ return Number(clamped.toFixed(precision));
81
93
  }
82
94
  clampProgress(value) {
83
95
  if (Number.isNaN(value)) {
84
96
  return 0;
85
97
  }
86
- const clampedValue = Math.min(100, Math.max(0, value));
87
- return this.roundProgress ? Math.round(clampedValue) : clampedValue;
98
+ return Math.min(100, Math.max(0, value));
88
99
  }
89
100
  clampNonNegativeNumber(value, fallbackValue) {
90
101
  const numericValue = typeof value === 'number' ? value : Number(value);
@@ -102,7 +113,7 @@ export class DrProgressBarComponent {
102
113
  } }, hostVars: 7, hostBindings: function DrProgressBarComponent_HostBindings(rf, ctx) { if (rf & 2) {
103
114
  i0.ɵɵattribute("role", ctx.role)("aria-valuemin", ctx.ariaValueMin)("aria-valuemax", ctx.ariaValueMax)("aria-valuenow", ctx.ariaValueNow)("aria-label", ctx.ariaLabel);
104
115
  i0.ɵɵclassMap(ctx.theme);
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) {
116
+ } }, inputs: { progress: "progress", total: "total", progressPrecision: "progressPrecision", 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) {
106
117
  i0.ɵɵprojectionDef();
107
118
  i0.ɵɵelementStart(0, "div", 0);
108
119
  i0.ɵɵelement(1, "div", 1);
@@ -126,7 +137,7 @@ export class DrProgressBarComponent {
126
137
  type: Input
127
138
  }], total: [{
128
139
  type: Input
129
- }], roundProgress: [{
140
+ }], progressPrecision: [{
130
141
  type: Input
131
142
  }], customValueTemplate: [{
132
143
  type: ContentChild,
@@ -157,4 +168,4 @@ export class DrProgressBarComponent {
157
168
  type: HostBinding,
158
169
  args: ['attr.aria-label']
159
170
  }] }); })();
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"]}
171
+ //# 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    /**\n     * Integer number of decimal places for progressPercent (0-100, default: 2)\n     */\n    @Input()\n    progressPrecision = 2;\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        const raw = (this.progress / this.total) * 100;\n        const clamped = this.clampProgress(raw);\n        const precision = Math.min(100, Math.max(0, Math.floor(this.progressPrecision)));\n        if (precision === 0) {\n            return Math.round(clamped);\n        }\n        if (Number.isInteger(clamped)) {\n            return clamped;\n        }\n        return Number(clamped.toFixed(precision));\n    }\n\n    private clampProgress(value: number): number {\n        if (Number.isNaN(value)) {\n            return 0;\n        }\n\n        return Math.min(100, Math.max(0, value));\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"]}
@@ -15547,7 +15547,10 @@ function DrProgressBarComponent_ng_template_5_Template(rf, ctx) { if (rf & 1) {
15547
15547
  const _c0$n = ["*"];
15548
15548
  class DrProgressBarComponent {
15549
15549
  constructor() {
15550
- this.roundProgress = false;
15550
+ /**
15551
+ * Integer number of decimal places for progressPercent (0-100, default: 2)
15552
+ */
15553
+ this.progressPrecision = 2;
15551
15554
  /**
15552
15555
  * Option to hide value label
15553
15556
  */
@@ -15599,14 +15602,22 @@ class DrProgressBarComponent {
15599
15602
  if (this.total <= 0) {
15600
15603
  return 0;
15601
15604
  }
15602
- return this.clampProgress((this.progress / this.total) * 100);
15605
+ const raw = (this.progress / this.total) * 100;
15606
+ const clamped = this.clampProgress(raw);
15607
+ const precision = Math.min(100, Math.max(0, Math.floor(this.progressPrecision)));
15608
+ if (precision === 0) {
15609
+ return Math.round(clamped);
15610
+ }
15611
+ if (Number.isInteger(clamped)) {
15612
+ return clamped;
15613
+ }
15614
+ return Number(clamped.toFixed(precision));
15603
15615
  }
15604
15616
  clampProgress(value) {
15605
15617
  if (Number.isNaN(value)) {
15606
15618
  return 0;
15607
15619
  }
15608
- const clampedValue = Math.min(100, Math.max(0, value));
15609
- return this.roundProgress ? Math.round(clampedValue) : clampedValue;
15620
+ return Math.min(100, Math.max(0, value));
15610
15621
  }
15611
15622
  clampNonNegativeNumber(value, fallbackValue) {
15612
15623
  const numericValue = typeof value === 'number' ? value : Number(value);
@@ -15624,7 +15635,7 @@ class DrProgressBarComponent {
15624
15635
  } }, hostVars: 7, hostBindings: function DrProgressBarComponent_HostBindings(rf, ctx) { if (rf & 2) {
15625
15636
  i0.ɵɵattribute("role", ctx.role)("aria-valuemin", ctx.ariaValueMin)("aria-valuemax", ctx.ariaValueMax)("aria-valuenow", ctx.ariaValueNow)("aria-label", ctx.ariaLabel);
15626
15637
  i0.ɵɵclassMap(ctx.theme);
15627
- } }, inputs: { progress: "progress", total: "total", roundProgress: "roundProgress", showValue: "showValue", theme: "theme", customAriaLabel: ["aria-label", "customAriaLabel"] }, standalone: true, features: [i0.ɵɵStandaloneFeature], ngContentSelectors: _c0$n, 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) {
15638
+ } }, inputs: { progress: "progress", total: "total", progressPrecision: "progressPrecision", showValue: "showValue", theme: "theme", customAriaLabel: ["aria-label", "customAriaLabel"] }, standalone: true, features: [i0.ɵɵStandaloneFeature], ngContentSelectors: _c0$n, 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) {
15628
15639
  i0.ɵɵprojectionDef();
15629
15640
  i0.ɵɵelementStart(0, "div", 0);
15630
15641
  i0.ɵɵelement(1, "div", 1);
@@ -15648,7 +15659,7 @@ class DrProgressBarComponent {
15648
15659
  type: Input
15649
15660
  }], total: [{
15650
15661
  type: Input
15651
- }], roundProgress: [{
15662
+ }], progressPrecision: [{
15652
15663
  type: Input
15653
15664
  }], customValueTemplate: [{
15654
15665
  type: ContentChild,