UNPKG

@clr/angular

Version:

Angular components for Clarity

177 lines 15.4 kB
/* * Copyright (c) 2016-2025 Broadcom. All Rights Reserved. * The term "Broadcom" refers to Broadcom Inc. and/or its subsidiaries. * This software is released under MIT license. * The full license information can be found in LICENSE in the root directory of this project. */ import { Component, HostBinding, Input } from '@angular/core'; import { isBooleanAttributeSet } from '../../utils/component/is-boolean-attribute-set'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; export class ClrProgressBar { constructor() { this.max = 100; /* * No need to convert to `number` cause we could have * floating point and parseInt will round the numbers * * working with string won't have any side-effects, * we don't do any math so string will do the job. */ this.value = 0; this.externalId = ''; } get id() { return this._ID; } set id(value) { this._ID = value; this.externalId = null; } get progressClass() { return true; } set clrCompact(value) { this._compact = isBooleanAttributeSet(value); } get compactClass() { return this._compact; } set clrLabeled(value) { this._labeled = isBooleanAttributeSet(value); } get labeledClass() { return this._labeled; } set clrFade(value) { this._fade = isBooleanAttributeSet(value); } get fadeClass() { return this._fade; } set clrLoop(value) { this._loop = isBooleanAttributeSet(value); } get loopClass() { return this._loop; } get warningClass() { return this.color === 'warning'; } get successClass() { return this.color === 'success'; } get dangerClass() { return this.color === 'danger'; } set clrFlash(value) { this._flash = isBooleanAttributeSet(value); } get flashClass() { return this._flash; } /** @deprecated since 2.0, remove in 4.0 */ set clrFlashDanger(value) { this._flashDanger = isBooleanAttributeSet(value); } get flashDangerClass() { return this._flashDanger; } /** * Make sure that we always will have something that is readable * for the screen reader */ get displayValue() { if (this.displayval) { return this.displayval; } return `${this.value || 0}%`; } /** * Display optional text only when labeled is eneabled */ displayStringValue() { return this._labeled; } } ClrProgressBar.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.2", ngImport: i0, type: ClrProgressBar, deps: [], target: i0.ɵɵFactoryTarget.Component }); ClrProgressBar.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.2", type: ClrProgressBar, selector: "clr-progress-bar", inputs: { max: ["clrMax", "max"], displayval: ["clrDisplayval", "displayval"], color: ["clrColor", "color"], value: ["clrValue", "value"], id: "id", clrCompact: "clrCompact", clrLabeled: "clrLabeled", clrFade: "clrFade", clrLoop: "clrLoop", clrFlash: "clrFlash", clrFlashDanger: "clrFlashDanger" }, host: { properties: { "attr.id": "this.externalId", "class.progress": "this.progressClass", "class.compact": "this.compactClass", "class.labeled": "this.labeledClass", "class.progress-fade": "this.fadeClass", "class.loop": "this.loopClass", "class.warning": "this.warningClass", "class.success": "this.successClass", "class.danger": "this.dangerClass", "class.flash": "this.flashClass", "class.flash-danger": "this.flashDangerClass" } }, ngImport: i0, template: ` <progress [id]="id" [attr.max]="max" [attr.value]="value" [attr.data-displayval]="displayValue"></progress> <span *ngIf="displayStringValue()">{{ displayValue }}</span> `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.2", ngImport: i0, type: ClrProgressBar, decorators: [{ type: Component, args: [{ selector: 'clr-progress-bar', template: ` <progress [id]="id" [attr.max]="max" [attr.value]="value" [attr.data-displayval]="displayValue"></progress> <span *ngIf="displayStringValue()">{{ displayValue }}</span> `, }] }], propDecorators: { max: [{ type: Input, args: ['clrMax'] }], displayval: [{ type: Input, args: ['clrDisplayval'] }], color: [{ type: Input, args: ['clrColor'] }], value: [{ type: Input, args: ['clrValue'] }], externalId: [{ type: HostBinding, args: ['attr.id'] }], id: [{ type: Input }], progressClass: [{ type: HostBinding, args: ['class.progress'] }], clrCompact: [{ type: Input, args: ['clrCompact'] }], compactClass: [{ type: HostBinding, args: ['class.compact'] }], clrLabeled: [{ type: Input, args: ['clrLabeled'] }], labeledClass: [{ type: HostBinding, args: ['class.labeled'] }], clrFade: [{ type: Input, args: ['clrFade'] }], fadeClass: [{ type: HostBinding, args: ['class.progress-fade'] }], clrLoop: [{ type: Input, args: ['clrLoop'] }], loopClass: [{ type: HostBinding, args: ['class.loop'] }], warningClass: [{ type: HostBinding, args: ['class.warning'] }], successClass: [{ type: HostBinding, args: ['class.success'] }], dangerClass: [{ type: HostBinding, args: ['class.danger'] }], clrFlash: [{ type: Input, args: ['clrFlash'] }], flashClass: [{ type: HostBinding, args: ['class.flash'] }], clrFlashDanger: [{ type: Input, args: ['clrFlashDanger'] }], flashDangerClass: [{ type: HostBinding, args: ['class.flash-danger'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"progress-bar.js","sourceRoot":"","sources":["../../../../../projects/angular/src/progress/progress-bars/progress-bar.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2016-2025 Broadcom. All Rights Reserved.\n * The term \"Broadcom\" refers to Broadcom Inc. and/or its subsidiaries.\n * This software is released under MIT license.\n * The full license information can be found in LICENSE in the root directory of this project.\n */\n\nimport { Component, HostBinding, Input } from '@angular/core';\n\nimport { isBooleanAttributeSet } from '../../utils/component/is-boolean-attribute-set';\n\n@Component({\n  selector: 'clr-progress-bar',\n  template: `\n    <progress [id]=\"id\" [attr.max]=\"max\" [attr.value]=\"value\" [attr.data-displayval]=\"displayValue\"></progress>\n    <span *ngIf=\"displayStringValue()\">{{ displayValue }}</span>\n  `,\n})\nexport class ClrProgressBar {\n  @Input('clrMax') max: number | string = 100;\n  @Input('clrDisplayval') displayval: string;\n  @Input('clrColor') color: string;\n\n  /*\n   * No need to convert to `number` cause we could have\n   * floating point and parseInt will round the numbers\n   *\n   * working with string won't have any side-effects,\n   * we don't do any math so string will do the job.\n   */\n  @Input('clrValue') value: number | string = 0;\n\n  @HostBinding('attr.id') externalId = '';\n\n  private _ID: string;\n  private _labeled: boolean;\n  private _fade: boolean;\n  private _loop: boolean;\n  private _flash: boolean;\n  private _flashDanger: boolean;\n  private _compact: boolean;\n\n  @Input()\n  get id() {\n    return this._ID;\n  }\n  set id(value: string) {\n    this._ID = value;\n    this.externalId = null;\n  }\n\n  @HostBinding('class.progress')\n  get progressClass() {\n    return true;\n  }\n\n  @Input('clrCompact')\n  set clrCompact(value: boolean | string) {\n    this._compact = isBooleanAttributeSet(value);\n  }\n\n  @HostBinding('class.compact')\n  get compactClass() {\n    return this._compact;\n  }\n\n  @Input('clrLabeled')\n  set clrLabeled(value: boolean | string) {\n    this._labeled = isBooleanAttributeSet(value);\n  }\n\n  @HostBinding('class.labeled')\n  get labeledClass() {\n    return this._labeled;\n  }\n\n  @Input('clrFade')\n  set clrFade(value: boolean | string) {\n    this._fade = isBooleanAttributeSet(value);\n  }\n\n  @HostBinding('class.progress-fade')\n  get fadeClass() {\n    return this._fade;\n  }\n\n  @Input('clrLoop')\n  set clrLoop(value: boolean | string) {\n    this._loop = isBooleanAttributeSet(value);\n  }\n\n  @HostBinding('class.loop')\n  get loopClass() {\n    return this._loop;\n  }\n\n  @HostBinding('class.warning')\n  get warningClass() {\n    return this.color === 'warning';\n  }\n\n  @HostBinding('class.success')\n  get successClass() {\n    return this.color === 'success';\n  }\n\n  @HostBinding('class.danger')\n  get dangerClass() {\n    return this.color === 'danger';\n  }\n\n  @Input('clrFlash')\n  set clrFlash(value: boolean | string) {\n    this._flash = isBooleanAttributeSet(value);\n  }\n\n  @HostBinding('class.flash')\n  get flashClass() {\n    return this._flash;\n  }\n\n  /** @deprecated since 2.0, remove in 4.0 */\n  @Input('clrFlashDanger')\n  set clrFlashDanger(value: boolean | string) {\n    this._flashDanger = isBooleanAttributeSet(value);\n  }\n\n  @HostBinding('class.flash-danger')\n  get flashDangerClass() {\n    return this._flashDanger;\n  }\n\n  /**\n   * Make sure that we always will have something that is readable\n   * for the screen reader\n   */\n  get displayValue() {\n    if (this.displayval) {\n      return this.displayval;\n    }\n    return `${this.value || 0}%`;\n  }\n\n  /**\n   * Display optional text only when labeled is eneabled\n   */\n  displayStringValue() {\n    return this._labeled;\n  }\n}\n"]}