carbon-components-angular
Version:
Next generation components
247 lines • 19.2 kB
JavaScript
import { Component, HostBinding, Input, TemplateRef } from "@angular/core";
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
import * as i2 from "carbon-components-angular/icon";
/**
* Get started with importing the module:
*
* ```typescript
* import { ProgressBarModule } from 'carbon-components-angular';
* ```
*
* [See demo](../../?path=/story/components-progress-bar--basic)
*/
export class ProgressBar {
constructor() {
this.id = `progress-bar-${ProgressBar.progressBarCounter++}`;
this.helperId = `progress-bar-helper-${ProgressBar.progressBarCounter}`;
/**
* Maximum value
*/
this.max = 100;
/**
* Alignment variant of the progress bar, default is `default`
*/
this.type = "default";
/**
* Current status of the progress bar, default is `active`
*/
this.status = "active";
/**
* Size of the progress bar, default is `big`
*/
this.size = "big";
/**
* Set to `true` to visually hide the label while keeping it available to assistive technologies.
*/
this.hideLabel = false;
this.defaultClass = true;
this._value = undefined;
}
/**
* Current value
*/
set value(num) {
this._value = num;
// Validate number
if (num > this.max) {
this._value = this.max;
}
if (num < 0) {
this._value = 0;
}
// Set values based on current state
if (this.isError) {
this._value = 0;
}
else if (this.isFinished) {
this._value = this.max;
}
}
get value() {
return this._value;
}
get percentage() {
return `scaleX(${this.value / this.max})`;
}
// Size
get bigBar() {
return this.size === "big";
}
get smallBar() {
return this.size === "small";
}
// Type
get defaultType() {
return this.type === "default";
}
get indentedType() {
return this.type === "indented";
}
get inlineType() {
return this.type === "inline";
}
// Status
get isFinished() {
return this.status === "finished";
}
get isError() {
return this.status === "error";
}
get indeterminate() {
return this.value === undefined && !this.isFinished && !this.isError;
}
isTemplate(value) {
return value instanceof TemplateRef;
}
}
ProgressBar.progressBarCounter = 0;
ProgressBar.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ProgressBar, deps: [], target: i0.ɵɵFactoryTarget.Component });
ProgressBar.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ProgressBar, selector: "cds-progress-bar, ibm-progress-bar", inputs: { value: "value", id: "id", label: "label", helperText: "helperText", max: "max", type: "type", status: "status", size: "size", hideLabel: "hideLabel" }, host: { properties: { "class.cds--progress-bar--big": "this.bigBar", "class.cds--progress-bar--small": "this.smallBar", "class.cds--progress-bar--default": "this.defaultType", "class.cds--progress-bar--indented": "this.indentedType", "class.cds--progress-bar--inline": "this.inlineType", "class.cds--progress-bar--finished": "this.isFinished", "class.cds--progress-bar--error": "this.isError", "class.cds--progress-bar--indeterminate": "this.indeterminate", "class.cds--progress-bar": "this.defaultClass" } }, ngImport: i0, template: `
<div
*ngIf="label"
class="cds--progress-bar__label"
[ngClass]="{'cds--visually-hidden': hideLabel}"
[id]="id">
<span class="cds--progress-bar__label-text">
<ng-container *ngIf="!isTemplate(label)">{{label}}</ng-container>
<ng-template *ngIf="isTemplate(label)" [ngTemplateOutlet]="label"></ng-template>
</span>
<svg
*ngIf="isFinished"
fill="currentColor"
cdsIcon="checkmark--filled"
class="cds--progress-bar__status-icon">
</svg>
<svg
*ngIf="isError"
fill="currentColor"
cdsIcon="error--filled"
class="cds--progress-bar__status-icon">
</svg>
</div>
<div
class="cds--progress-bar__track"
role="progressbar"
[attr.aria-busy]="!isFinished"
[attr.aria-invalid]="isError"
[attr.aria-labelledby]="id"
[attr.aria-describedby]="helperText ? helperId : null"
[attr.aria-valuemin]="!indeterminate ? 0 : null"
[attr.aria-valuemax]="!indeterminate ? max : null"
[attr.aria-valuenow]="!indeterminate ? value : null">
<div
class="cds--progress-bar__bar"
[ngStyle]="{
'transform': !isFinished && !isError ? percentage : null
}">
</div>
</div>
<div
[id]="helperId"
*ngIf="helperText"
class="cds--progress-bar__helper-text">
<ng-container *ngIf="!isTemplate(helperText)">{{helperText}}</ng-container>
<ng-template *ngIf="isTemplate(helperText)" [ngTemplateOutlet]="helperText"></ng-template>
</div>
`, isInline: true, dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2.IconDirective, selector: "[cdsIcon], [ibmIcon]", inputs: ["ibmIcon", "cdsIcon", "size", "title", "ariaLabel", "ariaLabelledBy", "ariaHidden", "isFocusable"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ProgressBar, decorators: [{
type: Component,
args: [{
selector: "cds-progress-bar, ibm-progress-bar",
template: `
<div
*ngIf="label"
class="cds--progress-bar__label"
[ngClass]="{'cds--visually-hidden': hideLabel}"
[id]="id">
<span class="cds--progress-bar__label-text">
<ng-container *ngIf="!isTemplate(label)">{{label}}</ng-container>
<ng-template *ngIf="isTemplate(label)" [ngTemplateOutlet]="label"></ng-template>
</span>
<svg
*ngIf="isFinished"
fill="currentColor"
cdsIcon="checkmark--filled"
class="cds--progress-bar__status-icon">
</svg>
<svg
*ngIf="isError"
fill="currentColor"
cdsIcon="error--filled"
class="cds--progress-bar__status-icon">
</svg>
</div>
<div
class="cds--progress-bar__track"
role="progressbar"
[attr.aria-busy]="!isFinished"
[attr.aria-invalid]="isError"
[attr.aria-labelledby]="id"
[attr.aria-describedby]="helperText ? helperId : null"
[attr.aria-valuemin]="!indeterminate ? 0 : null"
[attr.aria-valuemax]="!indeterminate ? max : null"
[attr.aria-valuenow]="!indeterminate ? value : null">
<div
class="cds--progress-bar__bar"
[ngStyle]="{
'transform': !isFinished && !isError ? percentage : null
}">
</div>
</div>
<div
[id]="helperId"
*ngIf="helperText"
class="cds--progress-bar__helper-text">
<ng-container *ngIf="!isTemplate(helperText)">{{helperText}}</ng-container>
<ng-template *ngIf="isTemplate(helperText)" [ngTemplateOutlet]="helperText"></ng-template>
</div>
`
}]
}], propDecorators: { value: [{
type: Input
}], bigBar: [{
type: HostBinding,
args: ["class.cds--progress-bar--big"]
}], smallBar: [{
type: HostBinding,
args: ["class.cds--progress-bar--small"]
}], defaultType: [{
type: HostBinding,
args: ["class.cds--progress-bar--default"]
}], indentedType: [{
type: HostBinding,
args: ["class.cds--progress-bar--indented"]
}], inlineType: [{
type: HostBinding,
args: ["class.cds--progress-bar--inline"]
}], isFinished: [{
type: HostBinding,
args: ["class.cds--progress-bar--finished"]
}], isError: [{
type: HostBinding,
args: ["class.cds--progress-bar--error"]
}], indeterminate: [{
type: HostBinding,
args: ["class.cds--progress-bar--indeterminate"]
}], id: [{
type: Input
}], label: [{
type: Input
}], helperText: [{
type: Input
}], max: [{
type: Input
}], type: [{
type: Input
}], status: [{
type: Input
}], size: [{
type: Input
}], hideLabel: [{
type: Input
}], defaultClass: [{
type: HostBinding,
args: ["class.cds--progress-bar"]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"progress-bar.component.js","sourceRoot":"","sources":["../../../src/progress-bar/progress-bar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tComponent,\n\tHostBinding,\n\tInput,\n\tTemplateRef\n} from \"@angular/core\";\n\n/**\n * Get started with importing the module:\n *\n * ```typescript\n * import { ProgressBarModule } from 'carbon-components-angular';\n * ```\n *\n * [See demo](../../?path=/story/components-progress-bar--basic)\n */\n@Component({\n\tselector: \"cds-progress-bar, ibm-progress-bar\",\n\ttemplate: `\n\t\t<div\n\t\t\t*ngIf=\"label\"\n\t\t\tclass=\"cds--progress-bar__label\"\n\t\t\t[ngClass]=\"{'cds--visually-hidden': hideLabel}\"\n\t\t\t[id]=\"id\">\n\t\t\t<span class=\"cds--progress-bar__label-text\">\n\t\t\t\t<ng-container *ngIf=\"!isTemplate(label)\">{{label}}</ng-container>\n\t\t\t\t<ng-template *ngIf=\"isTemplate(label)\" [ngTemplateOutlet]=\"label\"></ng-template>\n\t\t\t</span>\n\t\t\t<svg\n\t\t\t\t*ngIf=\"isFinished\"\n\t\t\t\tfill=\"currentColor\"\n\t\t\t\tcdsIcon=\"checkmark--filled\"\n\t\t\t\tclass=\"cds--progress-bar__status-icon\">\n\t\t\t</svg>\n\t\t\t<svg\n\t\t\t\t*ngIf=\"isError\"\n\t\t\t\tfill=\"currentColor\"\n\t\t\t\tcdsIcon=\"error--filled\"\n\t\t\t\tclass=\"cds--progress-bar__status-icon\">\n\t\t\t</svg>\n\t\t</div>\n\t\t<div\n\t\t\tclass=\"cds--progress-bar__track\"\n\t\t\trole=\"progressbar\"\n\t\t\t[attr.aria-busy]=\"!isFinished\"\n\t\t\t[attr.aria-invalid]=\"isError\"\n\t\t\t[attr.aria-labelledby]=\"id\"\n\t\t\t[attr.aria-describedby]=\"helperText ? helperId : null\"\n\t\t\t[attr.aria-valuemin]=\"!indeterminate ? 0 : null\"\n\t\t\t[attr.aria-valuemax]=\"!indeterminate ? max : null\"\n\t\t\t[attr.aria-valuenow]=\"!indeterminate ? value : null\">\n\t\t\t<div\n\t\t\t\tclass=\"cds--progress-bar__bar\"\n\t\t\t\t[ngStyle]=\"{\n\t\t\t\t\t'transform': !isFinished && !isError ? percentage : null\n\t\t\t\t}\">\n\t\t\t</div>\n\t\t</div>\n\t\t<div\n\t\t\t[id]=\"helperId\"\n\t\t\t*ngIf=\"helperText\"\n\t\t\tclass=\"cds--progress-bar__helper-text\">\n\t\t\t<ng-container *ngIf=\"!isTemplate(helperText)\">{{helperText}}</ng-container>\n\t\t\t<ng-template *ngIf=\"isTemplate(helperText)\" [ngTemplateOutlet]=\"helperText\"></ng-template>\n\t\t</div>\n\t`\n})\nexport class ProgressBar {\n\t/**\n\t * Current value\n\t */\n\t@Input() set value(num: number | undefined) {\n\t\tthis._value = num;\n\t\t// Validate number\n\t\tif (num > this.max) {\n\t\t\tthis._value = this.max;\n\t\t}\n\t\tif (num < 0) {\n\t\t\tthis._value = 0;\n\t\t}\n\t\t// Set values based on current state\n\t\tif (this.isError) {\n\t\t\tthis._value = 0;\n\t\t} else if (this.isFinished) {\n\t\t\tthis._value = this.max;\n\t\t}\n\t}\n\n\tget value() {\n\t\treturn this._value;\n\t}\n\n\tget percentage() {\n\t\treturn `scaleX(${this.value / this.max})`;\n\t}\n\t// Size\n\t@HostBinding(\"class.cds--progress-bar--big\") get bigBar() {\n\t\treturn this.size === \"big\";\n\t}\n\t@HostBinding(\"class.cds--progress-bar--small\") get smallBar() {\n\t\treturn this.size === \"small\";\n\t}\n\t// Type\n\t@HostBinding(\"class.cds--progress-bar--default\") get defaultType() {\n\t\treturn this.type === \"default\";\n\t}\n\t@HostBinding(\"class.cds--progress-bar--indented\") get indentedType() {\n\t\treturn this.type === \"indented\";\n\t}\n\t@HostBinding(\"class.cds--progress-bar--inline\") get inlineType() {\n\t\treturn this.type === \"inline\";\n\t}\n\t// Status\n\t@HostBinding(\"class.cds--progress-bar--finished\") get isFinished() {\n\t\treturn this.status === \"finished\";\n\t}\n\t@HostBinding(\"class.cds--progress-bar--error\") get isError() {\n\t\treturn this.status === \"error\";\n\t}\n\t@HostBinding(\"class.cds--progress-bar--indeterminate\") get indeterminate() {\n\t\treturn this.value === undefined && !this.isFinished && !this.isError;\n\t}\n\tstatic progressBarCounter = 0;\n\n\t@Input() id = `progress-bar-${ProgressBar.progressBarCounter++}`;\n\thelperId = `progress-bar-helper-${ProgressBar.progressBarCounter}`;\n\t/**\n\t * Description of the progress bar\n\t */\n\t@Input() label: string | TemplateRef<any>;\n\t/**\n\t * Current progress textual representation\n\t */\n\t@Input() helperText: string | TemplateRef<any>;\n\t/**\n\t * Maximum value\n\t */\n\t@Input() max = 100;\n\t/**\n\t * Alignment variant of the progress bar, default is `default`\n\t */\n\t@Input() type: \"default\" | \"inline\" | \"indented\" = \"default\";\n\t/**\n\t * Current status of the progress bar, default is `active`\n\t */\n\t@Input() status: \"active\" | \"finished\" | \"error\" = \"active\";\n\t/**\n\t * Size of the progress bar, default is `big`\n\t */\n\t@Input() size: \"small\" | \"big\" = \"big\";\n\n\t/**\n\t * Set to `true` to visually hide the label while keeping it available to assistive technologies.\n\t */\n\t@Input() hideLabel = false;\n\n\t@HostBinding(\"class.cds--progress-bar\") defaultClass = true;\n\tprivate _value = undefined;\n\n\tisTemplate(value) {\n\t\treturn value instanceof TemplateRef;\n\t}\n}\n"]}