UNPKG

@coreui/angular

Version:

CoreUI Components Library for Angular

113 lines 13.6 kB
import { booleanAttribute, computed, Directive, effect, ElementRef, inject, Input, numberAttribute, Renderer2, signal } from '@angular/core'; import * as i0 from "@angular/core"; export class ProgressBarDirective { constructor() { this.#renderer = inject(Renderer2); this.#hostElement = inject(ElementRef); this.#max = signal(100); this.#min = 0; this.#value = signal(undefined); this.#width = signal(undefined); this.percent = computed(() => { return +((((this.#value() ?? this.#width() ?? 0) - this.#min) / (this.#max() - this.#min)) * 100).toFixed(this.precision); }); this.#valuesEffect = effect(() => { const host = this.#hostElement.nativeElement; if (this.#value() === undefined || this.#width()) { for (const name of ['aria-valuenow', 'aria-valuemax', 'aria-valuemin', 'role']) { this.#renderer.removeAttribute(host, name); } } else { this.#renderer.setAttribute(host, 'aria-valuenow', String(this.#value())); this.#renderer.setAttribute(host, 'aria-valuemin', String(this.#min)); this.#renderer.setAttribute(host, 'aria-valuemax', String(this.#max())); this.#renderer.setAttribute(host, 'role', this.role); } const tagName = host.tagName; if (this.percent() >= 0 && ((this.stacked && tagName === 'C-PROGRESS') || (!this.stacked && tagName !== 'C-PROGRESS'))) { this.#renderer.setStyle(host, 'width', `${this.percent()}%`); } else { this.#renderer.removeStyle(host, 'width'); } }); // TODO: check if this is necessary. this.precision = 0; /** * Stacked ProgressBars. * @type boolean * @default false */ this.stacked = false; /** * Set default html role attribute. * @type string */ this.role = 'progressbar'; } #renderer; #hostElement; #max; #min; #value; #width; #valuesEffect; /** * The percent value the ProgressBar. * @type number * @default 0 */ set value(value) { this.#value.set(value); } get value() { return this.#value(); } set width(value) { this.#width.set(value); } /** * The max value of the ProgressBar. * @type number * @default 100 */ set max(max) { this.#max.set(isNaN(max) || max <= 0 ? 100 : max); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: ProgressBarDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.2.12", type: ProgressBarDirective, isStandalone: true, selector: "[cProgressBar]", inputs: { animated: ["animated", "animated", booleanAttribute], color: "color", precision: ["precision", "precision", numberAttribute], value: ["value", "value", numberAttribute], width: ["width", "width", numberAttribute], variant: "variant", max: ["max", "max", numberAttribute], stacked: ["stacked", "stacked", booleanAttribute], role: "role" }, ngImport: i0 }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: ProgressBarDirective, decorators: [{ type: Directive, args: [{ selector: '[cProgressBar]', standalone: true }] }], propDecorators: { animated: [{ type: Input, args: [{ transform: booleanAttribute }] }], color: [{ type: Input }], precision: [{ type: Input, args: [{ transform: numberAttribute }] }], value: [{ type: Input, args: [{ transform: numberAttribute }] }], width: [{ type: Input, args: [{ transform: numberAttribute }] }], variant: [{ type: Input }], max: [{ type: Input, args: [{ transform: numberAttribute }] }], stacked: [{ type: Input, args: [{ transform: booleanAttribute }] }], role: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"progress-bar.directive.js","sourceRoot":"","sources":["../../../../../projects/coreui-angular/src/lib/progress/progress-bar.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  booleanAttribute,\n  computed,\n  Directive,\n  effect,\n  EffectRef,\n  ElementRef,\n  inject,\n  Input,\n  numberAttribute,\n  Renderer2,\n  signal,\n  WritableSignal\n} from '@angular/core';\nimport { Colors } from '../coreui.types';\nimport { IProgressBar } from './progress.type';\n\n@Directive({\n  selector: '[cProgressBar]',\n  standalone: true\n})\nexport class ProgressBarDirective implements IProgressBar {\n  readonly #renderer = inject(Renderer2);\n  readonly #hostElement = inject(ElementRef);\n\n  readonly #max = signal(100);\n  readonly #min = 0;\n  readonly #value: WritableSignal<number | undefined> = signal(undefined);\n  readonly #width: WritableSignal<number | undefined> = signal(undefined);\n\n  readonly percent = computed(() => {\n    return +((((this.#value() ?? this.#width() ?? 0) - this.#min) / (this.#max() - this.#min)) * 100).toFixed(\n      this.precision\n    );\n  });\n\n  readonly #valuesEffect: EffectRef = effect(() => {\n    const host: HTMLElement = this.#hostElement.nativeElement;\n    if (this.#value() === undefined || this.#width()) {\n      for (const name of ['aria-valuenow', 'aria-valuemax', 'aria-valuemin', 'role']) {\n        this.#renderer.removeAttribute(host, name);\n      }\n    } else {\n      this.#renderer.setAttribute(host, 'aria-valuenow', String(this.#value()));\n      this.#renderer.setAttribute(host, 'aria-valuemin', String(this.#min));\n      this.#renderer.setAttribute(host, 'aria-valuemax', String(this.#max()));\n      this.#renderer.setAttribute(host, 'role', this.role);\n    }\n    const tagName = host.tagName;\n    if (\n      this.percent() >= 0 &&\n      ((this.stacked && tagName === 'C-PROGRESS') || (!this.stacked && tagName !== 'C-PROGRESS'))\n    ) {\n      this.#renderer.setStyle(host, 'width', `${this.percent()}%`);\n    } else {\n      this.#renderer.removeStyle(host, 'width');\n    }\n  });\n\n  /**\n   * Use to animate the stripes right to left via CSS3 animations.\n   * @type boolean\n   */\n  @Input({ transform: booleanAttribute }) animated?: boolean;\n\n  /**\n   * Sets the color context of the component to one of CoreUI’s themed colors.\n   * @values 'primary', 'secondary', 'success', 'danger', 'warning', 'info', 'dark', 'light'\n   */\n  @Input() color?: Colors;\n\n  // TODO: check if this is necessary.\n  @Input({ transform: numberAttribute }) precision: number = 0;\n\n  /**\n   * The percent value the ProgressBar.\n   * @type number\n   * @default 0\n   */\n  @Input({ transform: numberAttribute })\n  set value(value: number | undefined) {\n    this.#value.set(value);\n  }\n\n  get value() {\n    return this.#value();\n  }\n\n  @Input({ transform: numberAttribute })\n  set width(value: number | undefined) {\n    this.#width.set(value);\n  }\n\n  /**\n   * Set the progress bar variant to optional striped.\n   * @values 'striped'\n   * @default undefined\n   */\n  @Input() variant?: 'striped';\n\n  /**\n   * The max value of the ProgressBar.\n   * @type number\n   * @default 100\n   */\n  @Input({ transform: numberAttribute })\n  set max(max: number) {\n    this.#max.set(isNaN(max) || max <= 0 ? 100 : max);\n  }\n\n  /**\n   * Stacked ProgressBars.\n   * @type boolean\n   * @default false\n   */\n  @Input({ transform: booleanAttribute }) stacked?: boolean = false;\n\n  /**\n   * Set default html role attribute.\n   * @type string\n   */\n  @Input() role: string = 'progressbar';\n}\n"]}