@clr/angular
Version:
Angular components for Clarity
177 lines • 15.4 kB
JavaScript
/*
* 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"]}