@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
792 lines • 72.8 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { CommonModule } from '@angular/common';
import { Component, ElementRef, EventEmitter, HostBinding, Input, NgModule, Output, Renderer2, ViewChild, ContentChild, AfterViewInit } from '@angular/core';
import { IgxProcessBarTextTemplateDirective, IgxProgressBarGradientDirective, } from './progressbar.common';
const ONE_PERCENT = 0.01;
const MIN_VALUE = 0;
export var IgxTextAlign;
(function (IgxTextAlign) {
IgxTextAlign["START"] = "start";
IgxTextAlign["CENTER"] = "center";
IgxTextAlign["END"] = "end";
})(IgxTextAlign || (IgxTextAlign = {}));
export var IgxProgressType;
(function (IgxProgressType) {
IgxProgressType["DANGER"] = "danger";
IgxProgressType["INFO"] = "info";
IgxProgressType["WARNING"] = "warning";
IgxProgressType["SUCCESS"] = "success";
})(IgxProgressType || (IgxProgressType = {}));
export class BaseProgress {
constructor() {
/**
* @hidden
*/
this.requestAnimationId = undefined;
/**
* @hidden
*/
this._valueInPercent = MIN_VALUE;
/**
* @hidden
*/
this._max = 100;
/**
* @hidden
*/
this._value = MIN_VALUE;
/**
* @hidden
*/
this._animate = true;
}
/**
*Returns the `IgxLinearProgressBarComponent`/`IgxCircularProgressBarComponent` value in percentage.
*```typescript
*@ViewChild("MyProgressBar")
*public progressBar: IgxLinearProgressBarComponent; // IgxCircularProgressBarComponent
*public valuePercent(event){
* let percentValue = this.progressBar.valueInPercent;
* alert(percentValue);
*}
*```
*/
get valueInPercent() {
return this._valueInPercent;
}
/**
*Sets the `IgxLinearProgressBarComponent`/`IgxCircularProgressBarComponent` value in percentage.
*```typescript
*@ViewChild("MyProgressBar")
*public progressBar: IgxLinearProgressBarComponent; // IgxCircularProgressBarComponent
* public setValue(event){
* this.progressBar.valueInPercent = 56;
*}
* //...
*```
*```html
*<button igxButton="fab" igxRipple="" (click)="setValue()">setValue</button>
*```
*/
set valueInPercent(value) {
this._valueInPercent = value;
}
/**
* @hidden
*/
runAnimation(val, step) {
this.requestAnimationId = requestAnimationFrame(() => this.updateProgressSmoothly.call(this, val, step));
}
/**
* @hidden
*/
updateProgressSmoothly(val, step) {
this._value += step;
const passedValue = convertInPercentage(val, this._max);
const progressValue = convertInPercentage(this._value, this._max);
if (this.valueInPercent === passedValue) {
this.updateProgress(val);
cancelAnimationFrame(this.requestAnimationId);
}
else if (this.isInLimitRange(progressValue, passedValue, step)) {
this.updateProgress(val);
cancelAnimationFrame(this.requestAnimationId);
}
else {
this.valueInPercent = progressValue;
this.requestAnimationId = requestAnimationFrame(() => this.updateProgressSmoothly.call(this, val, step));
}
}
/**
* @hidden
*/
updateProgressDirectly(val) {
this._value = val;
this.valueInPercent = convertInPercentage(this._value, this._max);
}
/**
* @hidden
*/
directionFlow(currentValue, prevValue, step) {
if (currentValue < prevValue) {
return step;
}
return -step;
}
/**
* @hidden
*/
isInLimitRange(val, comparator, step) {
return this.isExceedingUpperLimit(val, comparator, step) || this.isExceedingLowerLimit(val, comparator, step);
}
/**
* @hidden
*
*
* @param val
* @param comparator
* @param step
*/
isExceedingUpperLimit(val, comparator, step) {
return val > comparator && step > 0;
}
/**
* @hidden
*
* @param val
* @param comparator
* @param step
*/
isExceedingLowerLimit(val, comparator, step) {
return val < comparator && step < 0;
}
/**
* @hidden
* @param step
*/
updateProgress(val) {
this._value = val;
this.valueInPercent = convertInPercentage(this._value, this._max);
}
}
let NEXT_LINEAR_ID = 0;
let NEXT_CIRCULAR_ID = 0;
let NEXT_GRADIENT_ID = 0;
let IgxLinearProgressBarComponent = class IgxLinearProgressBarComponent extends BaseProgress {
constructor() {
super();
this.valueMin = 0;
this.cssClass = 'igx-linear-bar';
/**
*Set `IgxLinearProgressBarComponent` to have striped style. By default it is set to false.
*```html
*<igx-linear-bar [striped]="true" [max]="200" [value]="50"></igx-linear-bar>
*```
*/
this.striped = false;
/**
*Set `IgxLinearProgressBarComponent` to have indeterminate. By default it is set to false.
*```html
*<igx-linear-bar [indeterminate]="true"></igx-linear-bar>
*```
*/
this.indeterminate = false;
/**An @Input property that sets the value of the `role` attribute. If not provided it will be automatically set to `progressbar`.
* ```html
*<igx-linear-bar role="progressbar"></igx-linear-bar>
* ```
*/
this.role = 'progressbar';
/**An @Input property that sets the value of `id` attribute. If not provided it will be automatically generated.
* ```html
*<igx-linear-bar [id]="'igx-linear-bar-55'" [striped]="true" [max]="200" [value]="50"></igx-linear-bar>
* ```
*/
this.id = `igx-linear-bar-${NEXT_LINEAR_ID++}`;
/**
*Set the position that defines where the text is aligned.
Possible options - `IgxTextAlign.START` (default), `IgxTextAlign.CENTER`, `IgxTextAlign.END`.
*```typescript
*public positionCenter: IgxTextAlign;
*public ngOnInit() {
* this.positionCenter = IgxTextAlign.CENTER;
*}
* //...
*```
* ```html
*<igx-linear-bar type="warning" [text]="'Custom text'" [textAlign]="positionCenter" [striped]="true"></igx-linear-bar>
*```
*/
this.textAlign = IgxTextAlign.START;
/**
*Set the text to be visible. By default it is set to true.
* ```html
*<igx-linear-bar type="default" [textVisibility]="false"></igx-linear-bar>
*```
*/
this.textVisibility = true;
/**
*Set the position that defines if the text should be aligned above the progress line. By default is set to false.
*```html
*<igx-linear-bar type="danger" [textTop]="true"></igx-linear-bar>
*```
*/
this.textTop = false;
/**
*Set type of the `IgxLinearProgressBarComponent`. Possible options - `default`, `success`, `info`, `warning`, and `danger`.
*```html
*<igx-linear-bar [striped]="false" [max]="100" [value]="0" type="danger"></igx-linear-bar>
*```
*/
this.type = 'default';
/**
*An event, which is triggered after a progress is changed.
*```typescript
*public progressChange(event) {
* alert("Progress made!");
*}
* //...
*```
*```html
*<igx-linear-bar (onProgressChanged)="progressChange($event)" type="success">
*```
*/
this.onProgressChanged = new EventEmitter();
}
/**
*Animation on progress `IgxLinearProgressBarComponent`. By default it is set to true.
*```html
*<igx-linear-bar [animate]="false" [striped]="true" [max]="200" [value]="50"></igx-linear-bar>
*```
*/
set animate(animate) {
this._animate = animate;
}
/**
*Returns whether the `IgxLinearProgressBarComponent` has animation true/false.
*```typescript
*@ViewChild("MyProgressBar")
*public progressBar: IgxLinearProgressBarComponent;
*public animationStatus(event) {
* let animationStatus = this.progressBar.animate;
* alert(animationStatus);
*}
*```
*/
get animate() {
return this._animate;
}
/**
*Set maximum value that can be passed. By default it is set to 100.
*```html
*<igx-linear-bar [striped]="false" [max]="200" [value]="0"></igx-linear-bar>
*```
*/
set max(maxNum) {
this._max = maxNum;
}
/**
*Returns the the maximum progress value of the `IgxLinearProgressBarComponent`.
*```typescript
*@ViewChild("MyProgressBar")
*public progressBar: IgxLinearProgressBarComponent;
*public maxValue(event) {
* let max = this.progressBar.max;
* alert(max);
*}
*```
*/
get max() {
return this._max;
}
/**
*Returns the value which update the progress indicator of the `IgxLinearProgressBarComponent`.
*```typescript
*@ViewChild("MyProgressBar")
*public progressBar: IgxLinearProgressBarComponent;
*public stepValue(event) {
* let step = this.progressBar.step;
* alert(step);
*}
*```
*/
get step() {
if (this._step) {
return this._step;
}
return this._max * ONE_PERCENT;
}
/**
*Sets the value by which progress indicator is updated. By default it is 1% of the maximum value.
*```html
*<igx-linear-bar [striped]="false" [max]="200" [value]="0" [step]="1"></igx-linear-bar>
*```
*/
set step(val) {
this._step = Number(val);
}
/**
*Returns value that indicates the current `IgxLinearProgressBarComponent` position.
*```typescript
*@ViewChild("MyProgressBar")
*public progressBar: IgxLinearProgressBarComponent;
*public getValue(event) {
* let value = this.progressBar.value;
* alert(value);
*}
*```
*/
get value() {
return this._value;
}
/**
*Set value that indicates the current `IgxLinearProgressBarComponent` position.
*```html
*<igx-linear-bar [striped]="false" [max]="200" [value]="50"></igx-linear-bar>
*```
*/
set value(val) {
val = Number(val);
if (this._value === val || this.indeterminate) {
return;
}
const valueInRange = getValueInProperRange(val, this.max);
if (isNaN(valueInRange)) {
return;
}
const changedValues = {
currentValue: valueInRange,
previousValue: this._value
};
const updateValue = super.directionFlow(this._value, val, this.step);
if (this._animate && val >= this.step) {
super.runAnimation(valueInRange, updateValue);
}
else {
super.updateProgressDirectly(valueInRange);
}
this.onProgressChanged.emit(changedValues);
}
/**
* @hidden
*/
get danger() {
return this.type === IgxProgressType.DANGER;
}
/**
* @hidden
*/
get info() {
return this.type === IgxProgressType.INFO;
}
/**
* @hidden
*/
get warning() {
return this.type === IgxProgressType.WARNING;
}
/**
* @hidden
*/
get success() {
return this.type === IgxProgressType.SUCCESS;
}
};
__decorate([
Input(),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [Boolean])
], IgxLinearProgressBarComponent.prototype, "animate", null);
__decorate([
HostBinding('attr.aria-valuemax'),
Input(),
__metadata("design:type", Number),
__metadata("design:paramtypes", [Number])
], IgxLinearProgressBarComponent.prototype, "max", null);
__decorate([
Input(),
__metadata("design:type", Number),
__metadata("design:paramtypes", [Number])
], IgxLinearProgressBarComponent.prototype, "step", null);
__decorate([
HostBinding('attr.aria-valuemin'),
__metadata("design:type", Object)
], IgxLinearProgressBarComponent.prototype, "valueMin", void 0);
__decorate([
HostBinding('class.igx-linear-bar'),
__metadata("design:type", Object)
], IgxLinearProgressBarComponent.prototype, "cssClass", void 0);
__decorate([
HostBinding('class.igx-linear-bar--striped'),
Input(),
__metadata("design:type", Object)
], IgxLinearProgressBarComponent.prototype, "striped", void 0);
__decorate([
HostBinding('class.igx-linear-bar--indeterminate'),
Input(),
__metadata("design:type", Object)
], IgxLinearProgressBarComponent.prototype, "indeterminate", void 0);
__decorate([
HostBinding('attr.role'),
Input(),
__metadata("design:type", Object)
], IgxLinearProgressBarComponent.prototype, "role", void 0);
__decorate([
HostBinding('attr.id'),
Input(),
__metadata("design:type", Object)
], IgxLinearProgressBarComponent.prototype, "id", void 0);
__decorate([
Input(),
__metadata("design:type", String)
], IgxLinearProgressBarComponent.prototype, "textAlign", void 0);
__decorate([
Input(),
__metadata("design:type", Object)
], IgxLinearProgressBarComponent.prototype, "textVisibility", void 0);
__decorate([
Input(),
__metadata("design:type", Object)
], IgxLinearProgressBarComponent.prototype, "textTop", void 0);
__decorate([
Input(),
__metadata("design:type", String)
], IgxLinearProgressBarComponent.prototype, "text", void 0);
__decorate([
Input(),
__metadata("design:type", Object)
], IgxLinearProgressBarComponent.prototype, "type", void 0);
__decorate([
HostBinding('attr.aria-valuenow'),
Input(),
__metadata("design:type", Number),
__metadata("design:paramtypes", [Object])
], IgxLinearProgressBarComponent.prototype, "value", null);
__decorate([
Output(),
__metadata("design:type", Object)
], IgxLinearProgressBarComponent.prototype, "onProgressChanged", void 0);
__decorate([
HostBinding('class.igx-linear-bar--danger'),
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], IgxLinearProgressBarComponent.prototype, "danger", null);
__decorate([
HostBinding('class.igx-linear-bar--info'),
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], IgxLinearProgressBarComponent.prototype, "info", null);
__decorate([
HostBinding('class.igx-linear-bar--warning'),
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], IgxLinearProgressBarComponent.prototype, "warning", null);
__decorate([
HostBinding('class.igx-linear-bar--success'),
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], IgxLinearProgressBarComponent.prototype, "success", null);
IgxLinearProgressBarComponent = __decorate([
Component({
selector: 'igx-linear-bar',
template: "<div class=\"igx-linear-bar__base\">\n <div class=\"igx-linear-bar__indicator\"\n [style.width.%]=\"valueInPercent\"></div>\n</div>\n\n<span\n class=\"igx-linear-bar__value\"\n [ngClass]=\"{\n 'igx-linear-bar__value--start': textAlign === 'start',\n 'igx-linear-bar__value--center': textAlign === 'center',\n 'igx-linear-bar__value--end': textAlign === 'end',\n 'igx-linear-bar__value--top': textTop,\n 'igx-linear-bar__value--hidden': !textVisibility\n }\">\n {{text ? text : valueInPercent + '%'}}\n</span>\n"
}),
__metadata("design:paramtypes", [])
], IgxLinearProgressBarComponent);
export { IgxLinearProgressBarComponent };
let IgxCircularProgressBarComponent = class IgxCircularProgressBarComponent extends BaseProgress {
constructor(renderer) {
super();
this.renderer = renderer;
this.STROKE_OPACITY_DVIDER = 100;
this.STROKE_OPACITY_ADDITION = .2;
/** @hidden */
this.cssClass = 'igx-circular-bar';
/**
*An event, which is triggered after a progress is changed.
*```typescript
*public progressChange(event) {
* alert("Progress made!");
*}
* //...
*```
*```html
*<igx-circular-bar [value]="currentValue" (onProgressChanged)="progressChange($event)"></igx-circular-bar>
*```
*/
this.onProgressChanged = new EventEmitter();
/**
*An @Input property that sets the value of `id` attribute. If not provided it will be automatically generated.
*```html
*<igx-circular-bar [id]="'igx-circular-bar-55'" [value]="50"></igx-circular-bar>
*```
*/
this.id = `igx-circular-bar-${NEXT_CIRCULAR_ID++}`;
/**
* @hidden
*/
this.gradientId = `igx-circular-gradient-${NEXT_GRADIENT_ID++}`;
/**
*An @Input property that sets the value of the `indeterminate` attribute. If not provided it will be automatically set to false.
*```html
*<igx-circular-bar [indeterminate]="true"></igx-circular-bar>
*```
*/
this.indeterminate = false;
/**
*Sets the text visibility. By default it is set to true.
*```html
*<igx-circular-bar [textVisibility]="false"></igx-circular-bar>
*```
*/
this.textVisibility = true;
this._circleRadius = 46;
this._circumference = 2 * Math.PI * this._circleRadius;
}
/**
* @hidden
*/
get context() {
return {
$implicit: { value: this.value, valueInPercent: this.valueInPercent, max: this.max }
};
}
/**
*Animation on progress `IgxCircularProgressBarComponent`. By default it is set to true.
*```html
*<igx-circular-bar [animate]="false" [value]="50"></igx-circular-bar>
*```
*/
set animate(animate) {
this._animate = animate;
}
/**
*Returns whether the `IgxCircularProgressBarComponent` has animation true/false.
*```typescript
*@ViewChild("MyProgressBar")
*public progressBar: IgxCircularProgressBarComponent;
*public animationStatus(event) {
* let animationStatus = this.progressBar.animate;
* alert(animationStatus);
*}
*```
*/
get animate() {
return this._animate;
}
/**
*Set maximum value that can be passed. By default it is set to 100.
*```html
*<igx-circular-bar [max]="200" [value]="0"></igx-circular-bar>
*```
*/
set max(maxNum) {
this._max = maxNum;
}
/**
*Returns the the maximum progress value of the `IgxCircularProgressBarComponent`.
*```typescript
*@ViewChild("MyProgressBar")
*public progressBar: IgxCircularProgressBarComponent;
*public maxValue(event) {
* let max = this.progressBar.max;
* alert(max);
*}
*```
*```html
*<igx-circular-bar [max]="245" [animate]="false" [value]="currentValue"></igx-circular-bar>
*```
*/
get max() {
return this._max;
}
/**
*Returns the value which update the progress indicator of the `IgxCircularProgressBarComponent`.
*```typescript
*@ViewChild("MyProgressBar")
*public progressBar: IgxCircularProgressBarComponent;
*public stepValue(event) {
* let step = this.progressBar.step;
* alert(step);
*}
*```
*/
get step() {
if (this._step) {
return this._step;
}
return this._max * ONE_PERCENT;
}
/**
*Sets the value by which progress indicator is updated. By default it is 1% of the maximum value.
*```html
*<igx-circular-bar [striped]="false" [max]="200" [value]="0" [step]="1"></igx-circular-bar>
*```
*/
set step(val) {
this._step = Number(val);
}
/**
*Returns value that indicates the current `IgxCircularProgressBarComponent` position.
*```typescript
*@ViewChild("MyProgressBar")
*public progressBar: IgxCircularProgressBarComponent;
*public getValue(event) {
* let value = this.progressBar.value;
* alert(value);
*}
*```
*```html
*<button igxButton="fab" igxRipple="" (click)="getValue()">Click</button>
*```
*/
get value() {
return this._value;
}
/**
*Set value that indicates the current `IgxCircularProgressBarComponent` position.
*```html
*<igx-circular-bar [value]="50"></igx-circular-bar>
*```
*/
set value(val) {
val = Number(val);
if (this._value === val || this.indeterminate) {
return;
}
const valueInProperRange = getValueInProperRange(val, this.max);
if (isNaN(valueInProperRange)) {
return;
}
const changedValues = {
currentValue: valueInProperRange,
previousValue: this._value
};
const updateValue = super.directionFlow(this._value, val, this.step);
if (this.animate && val >= this.step) {
super.runAnimation(valueInProperRange, updateValue);
}
else {
this.updateProgressDirectly(valueInProperRange);
}
this.onProgressChanged.emit(changedValues);
}
ngAfterViewInit() {
this.renderer.setStyle(this._svgCircle.nativeElement, 'stroke', `url(#${this.gradientId})`);
}
/**
* @hidden
*/
updateProgressSmoothly(val, step) {
// Set frames for the animation
const FRAMES = [{
strokeDashoffset: this.getProgress(this._value),
strokeOpacity: (this._value / this.STROKE_OPACITY_DVIDER) + this.STROKE_OPACITY_ADDITION
}, {
strokeDashoffset: this.getProgress(this.valueInPercent),
strokeOpacity: (this.valueInPercent / this.STROKE_OPACITY_DVIDER) + this.STROKE_OPACITY_ADDITION
}];
this._svgCircle.nativeElement.animate(FRAMES, {
easing: 'ease-out',
fill: 'forwards'
});
super.updateProgressSmoothly(val, step);
}
/**
* @hidden
*/
get textContent() {
return this.text;
}
/**
* @hidden
*/
updateProgressDirectly(val) {
super.updateProgressDirectly(val);
this.renderer.setStyle(this._svgCircle.nativeElement, 'stroke-dashoffset', this.getProgress(this.valueInPercent));
this.renderer.setStyle(this._svgCircle.nativeElement, 'stroke-opacity', (this.valueInPercent / this.STROKE_OPACITY_DVIDER) + this.STROKE_OPACITY_ADDITION);
}
getProgress(percentage) {
// Reverse the sign here: '-' should become '+' in RTL mode
return this._circumference - (percentage * this._circumference / 100);
}
};
IgxCircularProgressBarComponent.ctorParameters = () => [
{ type: Renderer2 }
];
__decorate([
HostBinding('class.igx-circular-bar'),
__metadata("design:type", Object)
], IgxCircularProgressBarComponent.prototype, "cssClass", void 0);
__decorate([
Output(),
__metadata("design:type", Object)
], IgxCircularProgressBarComponent.prototype, "onProgressChanged", void 0);
__decorate([
HostBinding('attr.id'),
Input(),
__metadata("design:type", Object)
], IgxCircularProgressBarComponent.prototype, "id", void 0);
__decorate([
HostBinding('class.igx-circular-bar--indeterminate'),
Input(),
__metadata("design:type", Object)
], IgxCircularProgressBarComponent.prototype, "indeterminate", void 0);
__decorate([
Input(),
__metadata("design:type", Object)
], IgxCircularProgressBarComponent.prototype, "textVisibility", void 0);
__decorate([
Input(),
__metadata("design:type", String)
], IgxCircularProgressBarComponent.prototype, "text", void 0);
__decorate([
ContentChild(IgxProcessBarTextTemplateDirective, { read: IgxProcessBarTextTemplateDirective }),
__metadata("design:type", IgxProcessBarTextTemplateDirective)
], IgxCircularProgressBarComponent.prototype, "textTemplate", void 0);
__decorate([
ContentChild(IgxProgressBarGradientDirective, { read: IgxProgressBarGradientDirective }),
__metadata("design:type", IgxProgressBarGradientDirective)
], IgxCircularProgressBarComponent.prototype, "gradientTemplate", void 0);
__decorate([
Input(),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [Boolean])
], IgxCircularProgressBarComponent.prototype, "animate", null);
__decorate([
Input(),
__metadata("design:type", Number),
__metadata("design:paramtypes", [Number])
], IgxCircularProgressBarComponent.prototype, "max", null);
__decorate([
Input(),
__metadata("design:type", Number),
__metadata("design:paramtypes", [Number])
], IgxCircularProgressBarComponent.prototype, "step", null);
__decorate([
Input(),
__metadata("design:type", Number),
__metadata("design:paramtypes", [Number])
], IgxCircularProgressBarComponent.prototype, "value", null);
__decorate([
ViewChild('circle', { static: true }),
__metadata("design:type", ElementRef)
], IgxCircularProgressBarComponent.prototype, "_svgCircle", void 0);
IgxCircularProgressBarComponent = __decorate([
Component({
selector: 'igx-circular-bar',
template: "<svg #svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" version=\"1.1\"\n viewBox=\"0 0 100 100\"\n preserveAspectRatio=\"xMidYMid meet\"\n role=\"progressbar\"\n aria-valuemin=\"0\"\n [attr.aria-valuemax]=\"max\"\n [attr.aria-valuenow]=\"value\">\n <svg:circle class=\"igx-circular-bar__inner\" cx=\"50\" cy=\"50\" r=\"46\" />\n <svg:circle #circle class=\"igx-circular-bar__outer\" cx=\"50\" cy=\"50\" r=\"46\" />\n <svg:text *ngIf=\"textVisibility\" text-anchor=\"middle\" x=\"50\" y=\"60\">\n <ng-container *ngTemplateOutlet=\"textTemplate ? textTemplate.template : defaultTextTemplate;\n context: context\">\n </ng-container>\n </svg:text>\n\n <svg:defs>\n <ng-container\n *ngTemplateOutlet=\"gradientTemplate ? gradientTemplate.template : defaultGradientTemplate;\n context: { $implicit: gradientId }\">\n </ng-container>\n </svg:defs>\n\n <ng-template #defaultTextTemplate>\n <svg:tspan class=\"igx-circular-bar__text\">\n {{textContent ? textContent: valueInPercent + '%'}}\n </svg:tspan>\n </ng-template>\n\n <ng-template #defaultGradientTemplate>\n <svg:linearGradient [id]=\"gradientId\" gradientTransform=\"rotate(90)\">\n <stop offset=\"0%\" class=\"igx-circular-bar__gradient-start\" />\n <stop offset=\"100%\" class=\"igx-circular-bar__gradient-end\" />\n </svg:linearGradient>\n </ng-template>\n</svg>\n\n"
}),
__metadata("design:paramtypes", [Renderer2])
], IgxCircularProgressBarComponent);
export { IgxCircularProgressBarComponent };
export function getValueInProperRange(value, max, min = 0) {
return Math.max(Math.min(value, max), min);
}
export function convertInPercentage(value, max) {
return Math.floor(100 * value / max);
}
/**
* @hidden
*/
let IgxProgressBarModule = class IgxProgressBarModule {
};
IgxProgressBarModule = __decorate([
NgModule({
declarations: [
IgxLinearProgressBarComponent,
IgxCircularProgressBarComponent,
IgxProcessBarTextTemplateDirective,
IgxProgressBarGradientDirective,
],
exports: [
IgxLinearProgressBarComponent,
IgxCircularProgressBarComponent,
IgxProcessBarTextTemplateDirective,
IgxProgressBarGradientDirective,
],
imports: [CommonModule]
})
], IgxProgressBarModule);
export { IgxProgressBarModule };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"progressbar.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/progressbar/progressbar.component.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EACH,SAAS,EACT,UAAU,EACV,YAAY,EACZ,WAAW,EACX,KAAK,EACL,QAAQ,EACR,MAAM,EACN,SAAS,EACT,SAAS,EACT,YAAY,EACZ,aAAa,EAChB,MAAM,eAAe,CAAC;AACvB,OAAO,EACH,kCAAkC,EAClC,+BAA+B,GAClC,MAAM,sBAAsB,CAAC;AAG9B,MAAM,WAAW,GAAG,IAAI,CAAC;AACzB,MAAM,SAAS,GAAG,CAAC,CAAC;AAEpB,MAAM,CAAN,IAAY,YAIX;AAJD,WAAY,YAAY;IACpB,+BAAe,CAAA;IACf,iCAAiB,CAAA;IACjB,2BAAW,CAAA;AACf,CAAC,EAJW,YAAY,KAAZ,YAAY,QAIvB;AAED,MAAM,CAAN,IAAY,eAKX;AALD,WAAY,eAAe;IACvB,oCAAiB,CAAA;IACjB,gCAAa,CAAA;IACb,sCAAmB,CAAA;IACnB,sCAAmB,CAAA;AACvB,CAAC,EALW,eAAe,KAAf,eAAe,QAK1B;AAOD,MAAM,OAAgB,YAAY;IAAlC;QACI;;WAEG;QACK,uBAAkB,GAAW,SAAS,CAAC;QAE/C;;WAEG;QACO,oBAAe,GAAG,SAAS,CAAC;QACtC;;WAEG;QACO,SAAI,GAAG,GAAG,CAAC;QACrB;;WAEG;QACO,WAAM,GAAG,SAAS,CAAC;QAC7B;;WAEG;QACO,aAAQ,GAAG,IAAI,CAAC;IA4H9B,CAAC;IArHG;;;;;;;;;;OAUG;IACH,IAAW,cAAc;QACrB,OAAO,IAAI,CAAC,eAAe,CAAC;IAChC,CAAC;IAED;;;;;;;;;;;;;OAaG;IACH,IAAW,cAAc,CAAC,KAAa;QACnC,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;IACjC,CAAC;IAED;;OAEG;IACO,YAAY,CAAC,GAAW,EAAE,IAAY;QAC5C,IAAI,CAAC,kBAAkB,GAAG,qBAAqB,CAC3C,GAAG,EAAE,CAAC,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,IAAI,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC,CAAC;IACjE,CAAC;IAED;;OAEG;IACO,sBAAsB,CAAC,GAAW,EAAE,IAAY;QACtD,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC;QACpB,MAAM,WAAW,GAAG,mBAAmB,CAAC,GAAG,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;QACxD,MAAM,aAAa,GAAG,mBAAmB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;QAClE,IAAI,IAAI,CAAC,cAAc,KAAK,WAAW,EAAE;YACrC,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;YACzB,oBAAoB,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;SACjD;aAAM,IAAI,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,WAAW,EAAE,IAAI,CAAC,EAAE;YAC9D,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;YACzB,oBAAoB,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;SACjD;aAAM;YACH,IAAI,CAAC,cAAc,GAAG,aAAa,CAAC;YACpC,IAAI,CAAC,kBAAkB,GAAG,qBAAqB,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,IAAI,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC,CAAC;SAC5G;IACL,CAAC;IAED;;OAEG;IACO,sBAAsB,CAAC,GAAW;QACxC,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC;QAClB,IAAI,CAAC,cAAc,GAAG,mBAAmB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;IACtE,CAAC;IAED;;OAEG;IACO,aAAa,CAAC,YAAoB,EAAE,SAAiB,EAAE,IAAY;QACzE,IAAI,YAAY,GAAG,SAAS,EAAE;YAC1B,OAAO,IAAI,CAAC;SACf;QAED,OAAO,CAAC,IAAI,CAAC;IACjB,CAAC;IAED;;OAEG;IACK,cAAc,CAAC,GAAW,EAAE,UAAkB,EAAE,IAAY;QAChE,OAAO,IAAI,CAAC,qBAAqB,CAAC,GAAG,EAAE,UAAU,EAAE,IAAI,CAAC,IAAI,IAAI,CAAC,qBAAqB,CAAC,GAAG,EAAE,UAAU,EAAE,IAAI,CAAC,CAAC;IAClH,CAAC;IAED;;;;;;;OAOG;IACK,qBAAqB,CAAC,GAAW,EAAE,UAAkB,EAAE,IAAY;QACvE,OAAO,GAAG,GAAG,UAAU,IAAI,IAAI,GAAG,CAAC,CAAC;IACxC,CAAC;IAED;;;;;;OAMG;IACK,qBAAqB,CAAC,GAAW,EAAE,UAAkB,EAAE,IAAY;QACvE,OAAO,GAAG,GAAG,UAAU,IAAI,IAAI,GAAG,CAAC,CAAC;IACxC,CAAC;IAED;;;OAGG;IACK,cAAc,CAAC,GAAW;QAC9B,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC;QAClB,IAAI,CAAC,cAAc,GAAG,mBAAmB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;IACtE,CAAC;CACJ;AACD,IAAI,cAAc,GAAG,CAAC,CAAC;AACvB,IAAI,gBAAgB,GAAG,CAAC,CAAC;AACzB,IAAI,gBAAgB,GAAG,CAAC,CAAC;AAKzB,IAAa,6BAA6B,GAA1C,MAAa,6BAA8B,SAAQ,YAAY;IAqF3D;QACI,KAAK,EAAE,CAAC;QAIL,aAAQ,GAAG,CAAC,CAAC;QAGb,aAAQ,GAAG,gBAAgB,CAAC;QAEnC;;;;;WAKG;QAGI,YAAO,GAAG,KAAK,CAAC;QAEvB;;;;;WAKG;QAGI,kBAAa,GAAG,KAAK,CAAC;QAE7B;;;;WAIG;QAGI,SAAI,GAAG,aAAa,CAAC;QAE5B;;;;WAIG;QAGI,OAAE,GAAG,kBAAkB,cAAc,EAAE,EAAE,CAAC;QAEjD;;;;;;;;;;;;;WAaG;QAEI,cAAS,GAAiB,YAAY,CAAC,KAAK,CAAC;QAEpD;;;;;WAKG;QAEI,mBAAc,GAAG,IAAI,CAAC;QAE7B;;;;;WAKG;QAEI,YAAO,GAAG,KAAK,CAAC;QAWvB;;;;;WAKG;QAGI,SAAI,GAAG,SAAS,CAAC;QAkDxB;;;;;;;;;;;WAWG;QACc,sBAAiB,GAAG,IAAI,YAAY,EAA4B,CAAC;IAhKlF,CAAC;IArFD;;;;;OAKG;IAEH,IAAI,OAAO,CAAC,OAAgB;QACxB,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;IAC5B,CAAC;IAED;;;;;;;;;;OAUG;IACH,IAAI,OAAO;QACP,OAAO,IAAI,CAAC,QAAQ,CAAC;IACzB,CAAC;IAED;;;;;OAKG;IAGH,IAAI,GAAG,CAAC,MAAc;QAClB,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC;IACvB,CAAC;IAED;;;;;;;;;;OAUG;IACH,IAAI,GAAG;QACH,OAAO,IAAI,CAAC,IAAI,CAAC;IACrB,CAAC;IAED;;;;;;;;;;OAUG;IAEH,IAAI,IAAI;QACJ,IAAI,IAAI,CAAC,KAAK,EAAE;YACZ,OAAO,IAAI,CAAC,KAAK,CAAC;SACrB;QAED,OAAO,IAAI,CAAC,IAAI,GAAG,WAAW,CAAC;IACnC,CAAC;IAED;;;;;OAKG;IACH,IAAI,IAAI,CAAC,GAAW;QAChB,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC;IAC7B,CAAC;IAwGD;;;;;;;;;;MAUE;IAGF,IAAI,KAAK;QACL,OAAO,IAAI,CAAC,MAAM,CAAC;IACvB,CAAC;IAED;;;;;OAKG;IACH,IAAI,KAAK,CAAC,GAAG;QACT,GAAG,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC;QAClB,IAAI,IAAI,CAAC,MAAM,KAAK,GAAG,IAAI,IAAI,CAAC,aAAa,EAAE;YAC3C,OAAO;SACV;QAED,MAAM,YAAY,GAAG,qBAAqB,CAAC,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;QAC1D,IAAI,KAAK,CAAC,YAAY,CAAC,EAAE;YACrB,OAAO;SACV;QACD,MAAM,aAAa,GAAG;YAClB,YAAY,EAAE,YAAY;YAC1B,aAAa,EAAE,IAAI,CAAC,MAAM;SAC7B,CAAC;QAEF,MAAM,WAAW,GAAG,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;QACrE,IAAI,IAAI,CAAC,QAAQ,IAAI,GAAG,IAAI,IAAI,CAAC,IAAI,EAAE;YACnC,KAAK,CAAC,YAAY,CAAC,YAAY,EAAE,WAAW,CAAC,CAAC;SACjD;aAAM;YACH,KAAK,CAAC,sBAAsB,CAAC,YAAY,CAAC,CAAC;SAC9C;QAED,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IAC/C,CAAC;IAgBD;;OAEG;IAEH,IAAW,MAAM;QACb,OAAO,IAAI,CAAC,IAAI,KAAK,eAAe,CAAC,MAAM,CAAC;IAChD,CAAC;IAED;;OAEG;IAEH,IAAW,IAAI;QACX,OAAO,IAAI,CAAC,IAAI,KAAK,eAAe,CAAC,IAAI,CAAC;IAC9C,CAAC;IAED;;OAEG;IAEH,IAAW,OAAO;QACd,OAAO,IAAI,CAAC,IAAI,KAAK,eAAe,CAAC,OAAO,CAAC;IACjD,CAAC;IAED;;OAEG;IAEH,IAAW,OAAO;QACd,OAAO,IAAI,CAAC,IAAI,KAAK,eAAe,CAAC,OAAO,CAAC;IACjD,CAAC;CACJ,CAAA;AA/QG;IADC,KAAK,EAAE;;;4DAGP;AAyBD;IAFC,WAAW,CAAC,oBAAoB,CAAC;IACjC,KAAK,EAAE;;;wDAGP;AA6BD;IADC,KAAK,EAAE;;;yDAOP;AAiBD;IADC,WAAW,CAAC,oBAAoB,CAAC;;+DACd;AAGpB;IADC,WAAW,CAAC,sBAAsB,CAAC;;+DACD;AAUnC;IAFC,WAAW,CAAC,+BAA+B,CAAC;IAC5C,KAAK,EAAE;;8DACe;AAUvB;IAFC,WAAW,CAAC,qCAAqC,CAAC;IAClD,KAAK,EAAE;;oEACqB;AAS7B;IAFC,WAAW,CAAC,WAAW,CAAC;IACxB,KAAK,EAAE;;2DACoB;AAS5B;IAFC,WAAW,CAAC,SAAS,CAAC;IACtB,KAAK,EAAE;;yDACyC;AAiBjD;IADC,KAAK,EAAE;;gEAC4C;AASpD;IADC,KAAK,EAAE;;qEACqB;AAS7B;IADC,KAAK,EAAE;;8DACe;AASvB;IADC,KAAK,EAAE;;2DACY;AAUpB;IADC,KAAK,EAAE;;2DACgB;AAexB;IAFC,WAAW,CAAC,oBAAoB,CAAC;IACjC,KAAK,EAAE;;;0DAGP;AA6CS;IAAT,MAAM,EAAE;;wEAAyE;AAMlF;IADC,WAAW,CAAC,8BAA8B,CAAC;;;2DAG3C;AAMD;IADC,WAAW,CAAC,4BAA4B,CAAC;;;yDAGzC;AAMD;IADC,WAAW,CAAC,+BAA+B,CAAC;;;4DAG5C;AAMD;IADC,WAAW,CAAC,+BAA+B,CAAC;;;4DAG5C;AAvRQ,6BAA6B;IAJzC,SAAS,CAAC;QACP,QAAQ,EAAE,gBAAgB;QAC1B,mkBAAkD;KACrD,CAAC;;GACW,6BAA6B,CAwRzC;SAxRY,6BAA6B;AA8R1C,IAAa,+BAA+B,GAA5C,MAAa,+BAAgC,SAAQ,YAAY;IAkO7D,YAAoB,QAAmB;QACnC,KAAK,EAAE,CAAC;QADQ,aAAQ,GAAR,QAAQ,CAAW;QAhOtB,0BAAqB,GAAG,GAAG,CAAC;QAC5B,4BAAuB,GAAG,EAAE,CAAC;QAE9C,cAAc;QAEP,aAAQ,GAAG,kBAAkB,CAAC;QAErC;;;;;;;;;;;WAWG;QAEI,sBAAiB,GAAG,IAAI,YAAY,EAA4B,CAAC;QAExE;;;;;WAKG;QAGI,OAAE,GAAG,oBAAoB,gBAAgB,EAAE,EAAE,CAAC;QAErD;;WAEG;QACI,eAAU,GAAG,yBAAyB,gBAAgB,EAAE,EAAE,CAAC;QAElE;;;;;WAKG;QAGI,kBAAa,GAAG,KAAK,CAAC;QAE7B;;;;;WAKG;QAEI,mBAAc,GAAG,IAAI,CAAC;QAqKrB,kBAAa,GAAG,EAAE,CAAC;QACnB,mBAAc,GAAG,CAAC,GAAG,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,aAAa,CAAC;IAM1D,CAAC;IAxJD;;MAEE;IACF,IAAW,OAAO;QACd,OAAO;YACH,SAAS,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,cAAc,EAAE,IAAI,CAAC,cAAc,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE;SACvF,CAAC;IACN,CAAC;IAED;;;;;OAKG;IAEH,IAAI,OAAO,CAAC,OAAgB;QACxB,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;IAC5B,CAAC;IAED;;;;;;;;;;OAUG;IACH,IAAI,OAAO;QACP,OAAO,IAAI,CAAC,QAAQ,CAAC;IACzB,CAAC;IAED;;;;;OAKG;IAEH,IAAI,GAAG,CAAC,MAAc;QAClB,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC;IACvB,CAAC;IAED;;;;;;;;;;;;;OAaG;IACH,IAAI,GAAG;QACH,OAAO,IAAI,CAAC,IAAI,CAAC;IACrB,CAAC;IAED;;;;;;;;;;OAUG;IAEH,IAAI,IAAI;QACJ,IAAI,IAAI,CAAC,KAAK,EAAE;YACZ,OAAO,IAAI,CAAC,KAAK,CAAC;SACrB;QAED,OAAO,IAAI,CAAC,IAAI,GAAG,WAAW,CAAC;IACnC,CAAC;IAED;;;;;MAKE;IACF,IAAI,IAAI,CAAC,GAAW;QAChB,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC;IAC7B,CAAC;IAED;;;;;;;;;;;;;OAaG;IAEH,IAAI,KAAK;QACL,OAAO,IAAI,CAAC,MAAM,CAAC;IACvB,CAAC;IAED;;;;;OAKG;IACH,IAAI,KAAK,CAAC,GAAW;QACjB,GAAG,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC;QAClB,IAAI,IAAI,CAAC,MAAM,KAAK,GAAG,IAAI,IAAI,CAAC,aAAa,EAAE;YAC3C,OAAO;SACV;QAED,MAAM,kBAAkB,GAAG,qBAAqB,CAAC,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;QAChE,IAAI,KAAK,CAAC,kBAAkB,CAAC,EAAE;YAC3B,OAAO;SACV;QAED,MAAM,aAAa,GAAG;YAClB,YAAY,EAAE,kBAAkB;YAChC,aAAa,EAAE,IAAI,CAAC,MAAM;SAC7B,CAAC;QAEF,MAAM,WAAW,GAAG,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;QACrE,IAAI,IAAI,CAAC,OAAO,IAAI,GAAG,IAAI,IAAI,CAAC,IAAI,EAAE;YAClC,KAAK,CAAC,YAAY,CAAC,kBAAkB,EAAE,WAAW,CAAC,CAAC;SACvD;aAAM;YACH,IAAI,CAAC,sBAAsB,CAAC,kBAAkB,CAAC,CAAC;SACnD;QAED,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IAC/C,CAAC;IAWD,eAAe;QACX,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAClB,IAAI,CAAC,UAAU,CAAC,aAAa,EAC7B,QAAQ,EACR,QAAQ,IAAI,CAAC,UAAU,GAAG,CAC7B,CAAC;IACN,CAAC;IAED;;OAEG;IACI,sBAAsB,CAAC,GAAW,EAAE,IAAY;QACnD,+BAA+B;QAC/B,MAAM,MAAM,GAAG,CAAC;gBACZ,gBAAgB,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC;gBAC/C,aAAa,EAAE,CAAC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,qBAAqB,CAAC,GAAG,IAAI,CAAC,uBAAuB;aAC3F,EAAE;gBACC,gBAAgB,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,CAAC;gBACvD,aAAa,EAAE,CAAC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,qBAAqB,CAAC,GAAG,IAAI,CAAC,uBAAuB;aACnG,CAAC,CAAC;QACH,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,EAAE;YAC1C,MAAM,EAAE,UAAU;YAClB,IAAI,EAAE,UAAU;SACnB,CAAC,CAAC;QAEH,KAAK,CAAC,sBAAsB,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;IAC5C,CAAC;IAED;;MAEE;IACF,IAAW,WAAW;QAClB,OAAO,IAAI,CAAC,IAAI,CAAC;IACrB,CAAC;IAED;;MAEE;IACK,sBAAsB,CAAC,GAAW;QACrC,KAAK,CAAC,sBAAsB,CAAC,GAAG,CAAC,CAAC;QAElC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAClB,IAAI,CAAC,UAAU,CAAC,aAAa,EAC7B,mBAAmB,EACnB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC;QAE3C,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAClB,IAAI,CAAC,UAAU,CAAC,aAAa,EAC7B,gBAAgB,EAChB,CAAC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,qBAAqB,CAAC,GAAG,IAAI,CAAC,uBAAuB,CAAC,CAAC;IAC3F,CAAC;IAEO,WAAW,CAAC,UAAkB;QAClC,2DAA2D;QAC3D,OAAO,IAAI,CAAC,cAAc,GAAG,CAAC,UAAU,GAAG,IAAI,CAAC,cAAc,GAAG,GAAG,CAAC,CAAC;IAC1E,CAAC;CACJ,CAAA;;YA5DiC,SAAS;;AA3NvC;IADC,WAAW,CAAC,wBAAwB,CAAC;;iEACD;AAerC;IADC,MAAM,EAAE;;0EAC+D;AAUxE;IAFC,WAAW,CAAC,SAAS,CAAC;IACtB,KAAK,EAAE;;2DAC6C;AAerD;IAFC,WAAW,CAAC,uCAAuC,CAAC;IACpD,KAAK,EAAE;;sEACqB;AAS7B;IADC,KAAK,EAAE;;uEACqB;AAY7B;IADC,KAAK,EAAE;;6DACY;AAGpB;IADC,YAAY,CAAC,kCAAkC,EAAE,EAAE,IAAI,EAAE,kCAAkC,EAAE,CAAC;8BAC1E,kCAAkC;qEAAC;AAGxD;IADC,YAAY,CAAC,+BAA+B,EAAE,EAAE,IAAI,EAAE,+BAA+B,EAAE,CAAC;8BAChE,+BAA+B;yEAAC;AAkBzD;IADC,KAAK,EAAE;;;8DAGP;AAwBD;IADC,KAAK,EAAE;;;0DAGP;AAgCD;IADC,KAAK,EAAE;;;2DAOP;AA2BD;IADC,KAAK,EAAE;;;4DAGP;AAqCsC;IAAtC,SAAS,CAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;8BAAqB,UAAU;mEAAC;AAhO7D,+BAA+B;IAJ3C,SAAS,CAAC;QACP,QAAQ,EAAE,kBAAkB;QAC5B,igDAAoD;KACvD,CAAC;qCAmOgC,SAAS;GAlO9B,+BAA+B,CA8R3C;SA9RY,+BAA+B;AAgS5C,MAAM,UAAU,qBAAqB,CAAC,KAAa,EAAE,GAAW,EAAE,GAAG,GAAG,CAAC;IACrE,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC;AAC/C,CAAC;AAED,MAAM,UAAU,mBAAmB,CAAC,KAAa,EAAE,GAAW;IAC1D,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,KAAK,GAAG,GAAG,CAAC,CAAC;AACzC,CAAC;AAED;;GAEG;AAgBH,IAAa,oBAAoB,GAAjC,MAAa,oBAAoB;CAAI,CAAA;AAAxB,oBAAoB;IAfhC,QAAQ,CAAC;QACN,YAAY,EAAE;YACV,6BAA6B;YAC7B,+BAA+B;YAC/B,kCAAkC;YAClC,+BAA+B;SAClC;QACD,OAAO,EAAE;YACL,6BAA6B;YAC7B,+BAA+B;YAC/B,kCAAkC;YAClC,+BAA+B;SAClC;QACD,OAAO,EAAE,CAAC,YAAY,CAAC;KAC1B,CAAC;GACW,oBAAoB,CAAI;SAAxB,oBAAoB","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Input,\n    NgModule,\n    Output,\n    Renderer2,\n    ViewChild,\n    ContentChild,\n    AfterViewInit\n} from '@angular/core';\nimport {\n    IgxProcessBarTextTemplateDirective,\n    IgxProgressBarGradientDirective,\n} from './progressbar.common';\nimport { IBaseEventArgs } from '../core/utils';\n\nconst ONE_PERCENT = 0.01;\nconst MIN_VALUE = 0;\n\nexport enum IgxTextAlign {\n    START = 'start',\n    CENTER = 'center',\n    END = 'end'\n}\n\nexport enum IgxProgressType {\n    DANGER = 'danger',\n    INFO = 'info',\n    WARNING = 'warning',\n    SUCCESS = 'success'\n}\n\nexport interface IChangeProgressEventArgs extends IBaseEventArgs {\n    previousValue: number;\n    currentValue: number;\n}\n\nexport abstract class BaseProgress {\n    /**\n     * @hidden\n     */\n    private requestAnimationId: number = undefined;\n\n    /**\n     * @hidden\n     */\n    protected _valueInPercent = MIN_VALUE;\n    /**\n     * @hidden\n     */\n    protected _max = 100;\n    /**\n     * @hidden\n     */\n    protected _value = MIN_VALUE;\n    /**\n     * @hidden\n     */\n    protected _animate = true;\n\n    /**\n     * @hidden\n     */\n    protected _step;\n\n    /**\n     *Returns the `IgxLinearProgressBarComponent`/`IgxCircularProgressBarComponent` value in percentage.\n     *```typescript\n     *@ViewChild(\"MyProgressBar\")\n     *public progressBar: IgxLinearProgressBarComponent; // IgxCircularProgressBarComponent\n     *public valuePercent(event){\n     *    let percentValue = this.progressBar.valueInPercent;\n     *    alert(percentValue);\n     *}\n     *```\n     */\n    public get valueInPercent(): number {\n        return this._valueInPercent;\n    }\n\n    /**\n     *Sets the `IgxLinearProgressBarComponent`/`IgxCircularProgressBarComponent` value in percentage.\n     *```typescript\n     *@ViewChild(\"MyProgressBar\")\n     *public progressBar: IgxLinearProgressBarComponent; // IgxCircularProgressBarComponent\n     *    public setValue(event){\n     *    this.progressBar.valueInPercent = 56;\n     *}\n     * //...\n     *```\n     *```html\n     *<button igxButton=\"fab\" igxRipple=\"\" (click)=\"setValue()\">setValue</button>\n     *```\n     */\n    public set valueInPercent(value: number) {\n        this._valueInPercent = value;\n    }\n\n    /**\n     * @hidden\n     */\n    protected runAnimation(val: number, step: number) {\n        this.requestAnimationId = requestAnimationFrame(\n            () => this.updateProgressSmoothly.call(this, val, step));\n    }\n\n    /**\n     * @hidden\n     */\n    protected updateProgressSmoothly(val: number, step: number) {\n        this._value += step;\n        const passedValue = convertInPercentage(val, this._max);\n        const progressValue = convertInPercentage(this._value, this._max);\n        if (this.valueInPercent === passedValue) {\n            this.updateProgress(val);\n            cancelAnimationFrame(this.requestAnimationId);\n        } else if (this.isInLimitRange(progressValue, passedValue, step)) {\n            this.updateProgress(val);\n            cancelAnimationFrame(this.requestAnimationId);\n        } else {\n            this.valueInPercent = progressValue;\n            this.requestAnimationId = requestAnimationFrame(() => this.updateProgressSmoothly.call(this, val, step));\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    protected updateProgressDirectly(val: number) {\n        this._value = val;\n        this.valueInPercent = convertInPercentage(this._value, this._max);\n    }\n\n    /**\n     * @hidden\n     */\n    protected directionFlow(currentValue: number, prevValue: number, step: number): number {\n        if (currentValue < prevValue) {\n            return step;\n        }\n\n        return -step;\n    }\n\n    /**\n     * @hidden\n     */\n    private isInLimitRange(val: number, comparator: number, step: number) {\n        return this.isExceedingUpperLimit(val, comparator, step) || this.isExceedingLowerLimit(val, comparator, step);\n    }\n\n    /**\n     * @hidden\n     *\n     *\n     * @param val\n     * @param comparator\n     * @param step\n     */\n    private isExceedingUpperLimit(val: number, comparator: number, step: number) {\n        return val > comparator && step > 0;\n    }\n\n    /**\n     * @hidden\n     *\n     * @param val\n     * @param comparator\n     * @param step\n     */\n    private isExceedingLowerLimit(val: number, comparator: number, step: number) {\n        return val < comparator && step < 0;\n    }\n\n    /**\n     * @hidden\n     * @param step\n     */\n    private updateProgress(val: number) {\n        this._value = val;\n        this.valueInPercent = convertInPercentage(this._value, this._max);\n    }\n}\nlet NEXT_LINEAR_ID = 0;\nlet NEXT_CIRCULAR_ID = 0;\nlet NEXT_GRADIENT_ID = 0;\n@Component({\n    selector: 'igx-linear-bar',\n    templateUrl: 'templates/linear-bar.component.html'\n})\nexport class IgxLinearProgressBarComponent extends BaseProgress {\n\n    /**\n     *Animation on progress `IgxLinearProgressBarComponent`. By default it is set to true.\n     *```html\n     *<igx-linear-bar [animate]=\"false\" [striped]=\"true\" [max]=\"200\" [value]=\"50\"></igx-linear-bar>\n     *```\n     */\n    @Input()\n    set animate(animate: boolean) {\n        this._animate = animate;\n    }\n\n    /**\n     *Returns whether the `IgxLinearProgressBarComponent` has animation true/false.\n     *```typescript\n     *@ViewChild(\"MyP