@fivethree/core
Version:
Fivethree Core Components
385 lines • 34.8 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: lib/spinner/spinner.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { DomSanitizer } from '@angular/platform-browser';
import { AnimationBuilder, style, animate } from '@angular/animations';
import { takeUntil } from 'rxjs/operators';
import { Component, Input, Optional, Inject, ChangeDetectionStrategy, ViewEncapsulation, ElementRef, ChangeDetectorRef, EventEmitter, Output, ViewChild, HostBinding } from '@angular/core';
import { DOCUMENT } from '@angular/common';
import { timer, interval } from 'rxjs';
/** @type {?} */
var BASE_SIZE = 100;
var FivSpinner = /** @class */ (function () {
function FivSpinner(_document, _elementRef, change, builder, sanitizer) {
this._document = _document;
this._elementRef = _elementRef;
this.change = change;
this.builder = builder;
this.sanitizer = sanitizer;
this._diameter = BASE_SIZE;
this._strokeWidth = 10;
this._value = 0;
this.fivProgress = new EventEmitter();
this.fivComplete = new EventEmitter();
this.mode = 'indeterminate';
this.circleRadius = 45;
this._color = 'var(--fiv-spin-color)';
}
Object.defineProperty(FivSpinner.prototype, "class", {
get: /**
* @return {?}
*/
function () {
return (this.mode +
' fiv-spinner fiv-progress-spinner fiv-progress-spinner-indeterminate-animation');
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
FivSpinner.prototype.ngOnInit = /**
* @return {?}
*/
function () { };
Object.defineProperty(FivSpinner.prototype, "viewBox", {
get: /**
* @return {?}
*/
function () {
/** @type {?} */
var viewBox = this.circleRadius * 2 + this.strokeWidth;
return "0 0 " + viewBox + " " + viewBox;
},
enumerable: true,
configurable: true
});
Object.defineProperty(FivSpinner.prototype, "strokeCircumference", {
/** The stroke circumference of the svg circle. */
get: /**
* The stroke circumference of the svg circle.
* @return {?}
*/
function () {
return 2 * Math.PI * this.circleRadius;
},
enumerable: true,
configurable: true
});
Object.defineProperty(FivSpinner.prototype, "strokeDashOffset", {
/** The dash offset of the svg circle. */
get: /**
* The dash offset of the svg circle.
* @return {?}
*/
function () {
if (this.mode === 'determinate') {
return (this.strokeCircumference * (100 - this._value)) / 100;
}
return null;
},
enumerable: true,
configurable: true
});
Object.defineProperty(FivSpinner.prototype, "circleStrokeWidth", {
/** Stroke width of the circle in percent. */
get: /**
* Stroke width of the circle in percent.
* @return {?}
*/
function () {
return (this.strokeWidth / this.diameter) * 100;
},
enumerable: true,
configurable: true
});
Object.defineProperty(FivSpinner.prototype, "value", {
/** Value of the progress circle. */
get: /**
* Value of the progress circle.
* @return {?}
*/
function () {
return this.mode === 'determinate' ? this._value : 0;
},
set: /**
* @param {?} newValue
* @return {?}
*/
function (newValue) {
this._value = Math.max(0, Math.min(100, newValue));
},
enumerable: true,
configurable: true
});
Object.defineProperty(FivSpinner.prototype, "diameter", {
get: /**
* @return {?}
*/
function () {
return this._diameter;
},
set: /**
* @param {?} size
* @return {?}
*/
function (size) {
this._diameter = size;
if (!FivSpinner.diameters.has(this._diameter)) {
this._attachStyleNode();
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(FivSpinner.prototype, "strokeWidth", {
/** Stroke width of the progress spinner. */
get: /**
* Stroke width of the progress spinner.
* @return {?}
*/
function () {
return this._strokeWidth || this.diameter / 10;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._strokeWidth = value;
},
enumerable: true,
configurable: true
});
/** Dynamically generates a style tag containing the correct animation for this diameter. */
/**
* Dynamically generates a style tag containing the correct animation for this diameter.
* @private
* @return {?}
*/
FivSpinner.prototype._attachStyleNode = /**
* Dynamically generates a style tag containing the correct animation for this diameter.
* @private
* @return {?}
*/
function () {
/** @type {?} */
var styleTag = FivSpinner.styleTag;
if (!styleTag) {
styleTag = this._document.createElement('style');
this._document.head.appendChild(styleTag);
FivSpinner.styleTag = styleTag;
}
if (styleTag && styleTag.sheet) {
((/** @type {?} */ (styleTag.sheet))).insertRule(this._getAnimationText(), 0);
}
FivSpinner.diameters.add(this.diameter);
};
/** Generates animation styles adjusted for the spinner's diameter. */
/**
* Generates animation styles adjusted for the spinner's diameter.
* @private
* @return {?}
*/
FivSpinner.prototype._getAnimationText = /**
* Generates animation styles adjusted for the spinner's diameter.
* @private
* @return {?}
*/
function () {
/** @type {?} */
var INDETERMINATE_ANIMATION_TEMPLATE = "\n @keyframes fiv-progress-spinner-stroke-rotate-DIAMETER {\n 0% { stroke-dashoffset: START_VALUE; transform: rotate(0); }\n 12.5% { stroke-dashoffset: END_VALUE; transform: rotate(0); }\n 12.5001% { stroke-dashoffset: END_VALUE; transform: rotateX(180deg) rotate(72.5deg); }\n 25% { stroke-dashoffset: START_VALUE; transform: rotateX(180deg) rotate(72.5deg); }\n 25.0001% { stroke-dashoffset: START_VALUE; transform: rotate(270deg); }\n 37.5% { stroke-dashoffset: END_VALUE; transform: rotate(270deg); }\n 37.5001% { stroke-dashoffset: END_VALUE; transform: rotateX(180deg) rotate(161.5deg); }\n 50% { stroke-dashoffset: START_VALUE; transform: rotateX(180deg) rotate(161.5deg); }\n 50.0001% { stroke-dashoffset: START_VALUE; transform: rotate(180deg); }\n 62.5% { stroke-dashoffset: END_VALUE; transform: rotate(180deg); }\n 62.5001% { stroke-dashoffset: END_VALUE; transform: rotateX(180deg) rotate(251.5deg); }\n 75% { stroke-dashoffset: START_VALUE; transform: rotateX(180deg) rotate(251.5deg); }\n 75.0001% { stroke-dashoffset: START_VALUE; transform: rotate(90deg); }\n 87.5% { stroke-dashoffset: END_VALUE; transform: rotate(90deg); }\n 87.5001% { stroke-dashoffset: END_VALUE; transform: rotateX(180deg) rotate(341.5deg); }\n 100% { stroke-dashoffset: START_VALUE; transform: rotateX(180deg) rotate(341.5deg); }\n }\n ";
return (INDETERMINATE_ANIMATION_TEMPLATE
// Animation should begin at 5% and end at 80%
.replace(/START_VALUE/g, "" + 0.95 * this.strokeCircumference)
.replace(/END_VALUE/g, "" + 0.2 * this.strokeCircumference)
.replace(/DIAMETER/g, "" + this.diameter));
};
/**
* @param {?} duration
* @return {?}
*/
FivSpinner.prototype.completeIn = /**
* @param {?} duration
* @return {?}
*/
function (duration) {
var _this = this;
this.mode = 'determinate';
this.change.detectChanges();
/** @type {?} */
var animation = this.builder.build([
style({
'stroke-dasharray': 180,
'stroke-dashoffset': 90,
transformOrigin: 'center',
stroke: 'var(--fiv-spin-color)'
}),
animate(duration + "ms ease-out", style({
'stroke-dasharray': 315,
'stroke-dashoffset': 0,
transformOrigin: 'center',
stroke: 'var(--fiv-spin-color)',
opacity: 0
}))
]);
/** @type {?} */
var player = animation.create(this.determinateCircle.nativeElement);
player.play();
player.onDone((/**
* @return {?}
*/
function () {
_this.fivComplete.emit(_this);
_this._value = 0;
}));
/** @type {?} */
var i = interval(duration / 100);
/** @type {?} */
var t = timer(duration + duration / 50);
/** @type {?} */
var progress = i.pipe(takeUntil(t));
progress.subscribe((/**
* @param {?} p
* @return {?}
*/
function (p) {
_this.fivProgress.emit(p);
}));
};
/**
* @param {?} progress
* @return {?}
*/
FivSpinner.prototype.setValue = /**
* @param {?} progress
* @return {?}
*/
function (progress) {
this.mode = 'determinate';
this._value = progress;
this.change.detectChanges();
};
/**
* @return {?}
*/
FivSpinner.prototype.spin = /**
* @return {?}
*/
function () {
this.mode = 'indeterminate';
this.change.detectChanges();
};
/**
* @return {?}
*/
FivSpinner.prototype.stop = /**
* @return {?}
*/
function () {
this._value = 0;
this.change.detectChanges();
};
/**
* @param {?} mode
* @return {?}
*/
FivSpinner.prototype.setMode = /**
* @param {?} mode
* @return {?}
*/
function (mode) {
this.mode = mode;
this.change.detectChanges();
};
FivSpinner.diameters = new Set([BASE_SIZE]);
FivSpinner.styleTag = null;
FivSpinner.decorators = [
{ type: Component, args: [{
selector: 'fiv-spinner',
template: "<svg [style.width.px]=\"diameter\" [style.height.px]=\"diameter\" [attr.viewBox]=\"viewBox\"\n preserveAspectRatio=\"xMidYMid meet\" focusable=\"false\" [ngSwitch]=\"mode == 'indeterminate'\">\n <circle [attr.stroke]=\"_color\" *ngSwitchCase=\"true\" cx=\"50%\" cy=\"50%\" [attr.r]=\"circleRadius\"\n [style.animation-name]=\"'fiv-progress-spinner-stroke-rotate-' + diameter\"\n [style.stroke-dashoffset.px]=\"strokeDashOffset\" [style.stroke-dasharray.px]=\"strokeCircumference\"\n [style.stroke-width.%]=\"circleStrokeWidth\"></circle>\n\n <circle [attr.stroke]=\"_color\" class=\"determinate-circle\" #determinateCircle *ngSwitchCase=\"false\" cx=\"50%\" cy=\"50%\"\n [attr.r]=\"circleRadius\" [style.stroke-dashoffset.px]=\"strokeDashOffset\"\n [style.stroke-dasharray.px]=\"strokeCircumference\" [style.stroke-width.%]=\"circleStrokeWidth\"></circle>\n</svg>",
// tslint:disable-next-line:use-host-property-decorator
host: {
'[style.width.px]': 'diameter',
'[style.height.px]': 'diameter'
},
changeDetection: ChangeDetectionStrategy.OnPush,
encapsulation: ViewEncapsulation.None,
styles: ["fiv-spinner{display:block;position:relative}fiv-spinner svg{position:absolute;transform:rotate(-90deg);top:0;left:0;transform-origin:center;overflow:visible}fiv-spinner circle{fill:transparent;transform-origin:center;transition:stroke-dashoffset 225ms linear}fiv-spinner.fiv-progress-spinner-indeterminate-animation.determinate circle{transition-property:stroke;-webkit-animation-duration:4s;animation-duration:4s;-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out;-webkit-animation-iteration-count:infinite;animation-iteration-count:infinite}fiv-spinner.fiv-progress-spinner-indeterminate-animation.indeterminate{-webkit-animation:2s linear infinite fiv-progress-spinner-linear-rotate;animation:2s linear infinite fiv-progress-spinner-linear-rotate}fiv-spinner.fiv-progress-spinner-indeterminate-animation.indeterminate circle{transition-property:stroke;-webkit-animation-duration:4s;animation-duration:4s;-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out;-webkit-animation-iteration-count:infinite;animation-iteration-count:infinite}@-webkit-keyframes fiv-progress-spinner-linear-rotate{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}@keyframes fiv-progress-spinner-linear-rotate{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}@-webkit-keyframes fiv-progress-spinner-stroke-rotate-100{0%{stroke-dashoffset:268.6061718819px;transform:rotate(0)}12.5%{stroke-dashoffset:56.5486677646px;transform:rotate(0)}12.5001%{stroke-dashoffset:56.5486677646px;transform:rotateX(180deg) rotate(72.5deg)}25%{stroke-dashoffset:268.6061718819px;transform:rotateX(180deg) rotate(72.5deg)}25.0001%{stroke-dashoffset:268.6061718819px;transform:rotate(270deg)}37.5%{stroke-dashoffset:56.5486677646px;transform:rotate(270deg)}37.5001%{stroke-dashoffset:56.5486677646px;transform:rotateX(180deg) rotate(161.5deg)}50%{stroke-dashoffset:268.6061718819px;transform:rotateX(180deg) rotate(161.5deg)}50.0001%{stroke-dashoffset:268.6061718819px;transform:rotate(180deg)}62.5%{stroke-dashoffset:56.5486677646px;transform:rotate(180deg)}62.5001%{stroke-dashoffset:56.5486677646px;transform:rotateX(180deg) rotate(251.5deg)}75%{stroke-dashoffset:268.6061718819px;transform:rotateX(180deg) rotate(251.5deg)}75.0001%{stroke-dashoffset:268.6061718819px;transform:rotate(90deg)}87.5%{stroke-dashoffset:56.5486677646px;transform:rotate(90deg)}87.5001%{stroke-dashoffset:56.5486677646px;transform:rotateX(180deg) rotate(341.5deg)}100%{stroke-dashoffset:268.6061718819px;transform:rotateX(180deg) rotate(341.5deg)}}@keyframes fiv-progress-spinner-stroke-rotate-100{0%{stroke-dashoffset:268.6061718819px;transform:rotate(0)}12.5%{stroke-dashoffset:56.5486677646px;transform:rotate(0)}12.5001%{stroke-dashoffset:56.5486677646px;transform:rotateX(180deg) rotate(72.5deg)}25%{stroke-dashoffset:268.6061718819px;transform:rotateX(180deg) rotate(72.5deg)}25.0001%{stroke-dashoffset:268.6061718819px;transform:rotate(270deg)}37.5%{stroke-dashoffset:56.5486677646px;transform:rotate(270deg)}37.5001%{stroke-dashoffset:56.5486677646px;transform:rotateX(180deg) rotate(161.5deg)}50%{stroke-dashoffset:268.6061718819px;transform:rotateX(180deg) rotate(161.5deg)}50.0001%{stroke-dashoffset:268.6061718819px;transform:rotate(180deg)}62.5%{stroke-dashoffset:56.5486677646px;transform:rotate(180deg)}62.5001%{stroke-dashoffset:56.5486677646px;transform:rotateX(180deg) rotate(251.5deg)}75%{stroke-dashoffset:268.6061718819px;transform:rotateX(180deg) rotate(251.5deg)}75.0001%{stroke-dashoffset:268.6061718819px;transform:rotate(90deg)}87.5%{stroke-dashoffset:56.5486677646px;transform:rotate(90deg)}87.5001%{stroke-dashoffset:56.5486677646px;transform:rotateX(180deg) rotate(341.5deg)}100%{stroke-dashoffset:268.6061718819px;transform:rotateX(180deg) rotate(341.5deg)}}"]
}] }
];
/** @nocollapse */
FivSpinner.ctorParameters = function () { return [
{ type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [DOCUMENT,] }] },
{ type: ElementRef },
{ type: ChangeDetectorRef },
{ type: AnimationBuilder },
{ type: DomSanitizer }
]; };
FivSpinner.propDecorators = {
fivProgress: [{ type: Output }],
fivComplete: [{ type: Output }],
determinateCircle: [{ type: ViewChild, args: ['determinateCircle', { static: false },] }],
mode: [{ type: Input }],
circleRadius: [{ type: Input }],
class: [{ type: HostBinding, args: ['class',] }],
value: [{ type: Input }],
diameter: [{ type: Input }],
strokeWidth: [{ type: Input }]
};
return FivSpinner;
}());
export { FivSpinner };
if (false) {
/**
* @type {?}
* @private
*/
FivSpinner.diameters;
/**
* @type {?}
* @private
*/
FivSpinner.styleTag;
/**
* @type {?}
* @private
*/
FivSpinner.prototype._diameter;
/** @type {?} */
FivSpinner.prototype._strokeWidth;
/** @type {?} */
FivSpinner.prototype._value;
/** @type {?} */
FivSpinner.prototype.fivProgress;
/** @type {?} */
FivSpinner.prototype.fivComplete;
/** @type {?} */
FivSpinner.prototype.determinateCircle;
/** @type {?} */
FivSpinner.prototype.mode;
/** @type {?} */
FivSpinner.prototype.circleRadius;
/** @type {?} */
FivSpinner.prototype._color;
/**
* @type {?}
* @private
*/
FivSpinner.prototype._document;
/** @type {?} */
FivSpinner.prototype._elementRef;
/** @type {?} */
FivSpinner.prototype.change;
/**
* @type {?}
* @private
*/
FivSpinner.prototype.builder;
/** @type {?} */
FivSpinner.prototype.sanitizer;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"spinner.component.js","sourceRoot":"ng://@fivethree/core/","sources":["lib/spinner/spinner.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { DomSanitizer } from '@angular/platform-browser';\nimport { AnimationBuilder, style, animate } from '@angular/animations';\nimport { takeUntil } from 'rxjs/operators';\nimport {\n  Component,\n  OnInit,\n  Input,\n  Optional,\n  Inject,\n  ChangeDetectionStrategy,\n  ViewEncapsulation,\n  ElementRef,\n  ChangeDetectorRef,\n  EventEmitter,\n  Output,\n  ViewChild,\n  HostBinding,\n  Renderer2\n} from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\nimport { timer, interval } from 'rxjs';\nconst BASE_SIZE = 100;\n\n@Component({\n  selector: 'fiv-spinner',\n  templateUrl: './spinner.component.html',\n  styleUrls: ['./spinner.component.scss'],\n  // tslint:disable-next-line:use-host-property-decorator\n  host: {\n    '[style.width.px]': 'diameter',\n    '[style.height.px]': 'diameter'\n  },\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None\n})\nexport class FivSpinner implements OnInit {\n  private static diameters = new Set<number>([BASE_SIZE]);\n  private static styleTag: HTMLStyleElement | null = null;\n  private _diameter = BASE_SIZE;\n  _strokeWidth = 10;\n  _value = 0;\n\n  @Output() fivProgress = new EventEmitter<number>();\n  @Output() fivComplete = new EventEmitter<FivSpinner>();\n  @ViewChild('determinateCircle', { static: false })\n  determinateCircle: ElementRef;\n  @Input() mode: 'indeterminate' | 'determinate' = 'indeterminate';\n  @Input() circleRadius = 45;\n  _color = 'var(--fiv-spin-color)';\n\n  @HostBinding('class') get class() {\n    return (\n      this.mode +\n      ' fiv-spinner fiv-progress-spinner fiv-progress-spinner-indeterminate-animation'\n    );\n  }\n\n  constructor(\n    @Optional() @Inject(DOCUMENT) private _document: any,\n    public _elementRef: ElementRef,\n    public change: ChangeDetectorRef,\n    private builder: AnimationBuilder,\n    public sanitizer: DomSanitizer\n  ) {}\n\n  ngOnInit() {}\n\n  get viewBox() {\n    const viewBox = this.circleRadius * 2 + this.strokeWidth;\n    return `0 0 ${viewBox} ${viewBox}`;\n  }\n\n  /** The stroke circumference of the svg circle. */\n  get strokeCircumference(): number {\n    return 2 * Math.PI * this.circleRadius;\n  }\n\n  /** The dash offset of the svg circle. */\n  get strokeDashOffset() {\n    if (this.mode === 'determinate') {\n      return (this.strokeCircumference * (100 - this._value)) / 100;\n    }\n\n    return null;\n  }\n\n  /** Stroke width of the circle in percent. */\n  get circleStrokeWidth() {\n    return (this.strokeWidth / this.diameter) * 100;\n  }\n\n  /** Value of the progress circle. */\n  @Input()\n  get value(): number {\n    return this.mode === 'determinate' ? this._value : 0;\n  }\n  set value(newValue: number) {\n    this._value = Math.max(0, Math.min(100, newValue));\n  }\n\n  @Input()\n  get diameter(): number {\n    return this._diameter;\n  }\n  set diameter(size: number) {\n    this._diameter = size;\n\n    if (!FivSpinner.diameters.has(this._diameter)) {\n      this._attachStyleNode();\n    }\n  }\n\n  /** Stroke width of the progress spinner. */\n  @Input()\n  get strokeWidth(): number {\n    return this._strokeWidth || this.diameter / 10;\n  }\n  set strokeWidth(value: number) {\n    this._strokeWidth = value;\n  }\n\n  /** Dynamically generates a style tag containing the correct animation for this diameter. */\n  private _attachStyleNode(): void {\n    let styleTag = FivSpinner.styleTag;\n\n    if (!styleTag) {\n      styleTag = this._document.createElement('style');\n      this._document.head.appendChild(styleTag);\n      FivSpinner.styleTag = styleTag;\n    }\n\n    if (styleTag && styleTag.sheet) {\n      (styleTag.sheet as CSSStyleSheet).insertRule(this._getAnimationText(), 0);\n    }\n\n    FivSpinner.diameters.add(this.diameter);\n  }\n\n  /** Generates animation styles adjusted for the spinner's diameter. */\n  private _getAnimationText(): string {\n    const INDETERMINATE_ANIMATION_TEMPLATE = `\n    @keyframes fiv-progress-spinner-stroke-rotate-DIAMETER {\n       0%      { stroke-dashoffset: START_VALUE;  transform: rotate(0); }\n       12.5%   { stroke-dashoffset: END_VALUE;    transform: rotate(0); }\n       12.5001%  { stroke-dashoffset: END_VALUE;    transform: rotateX(180deg) rotate(72.5deg); }\n       25%     { stroke-dashoffset: START_VALUE;  transform: rotateX(180deg) rotate(72.5deg); }\n       25.0001%   { stroke-dashoffset: START_VALUE;  transform: rotate(270deg); }\n       37.5%   { stroke-dashoffset: END_VALUE;    transform: rotate(270deg); }\n       37.5001%  { stroke-dashoffset: END_VALUE;    transform: rotateX(180deg) rotate(161.5deg); }\n       50%     { stroke-dashoffset: START_VALUE;  transform: rotateX(180deg) rotate(161.5deg); }\n       50.0001%  { stroke-dashoffset: START_VALUE;  transform: rotate(180deg); }\n       62.5%   { stroke-dashoffset: END_VALUE;    transform: rotate(180deg); }\n       62.5001%  { stroke-dashoffset: END_VALUE;    transform: rotateX(180deg) rotate(251.5deg); }\n       75%     { stroke-dashoffset: START_VALUE;  transform: rotateX(180deg) rotate(251.5deg); }\n       75.0001%  { stroke-dashoffset: START_VALUE;  transform: rotate(90deg); }\n       87.5%   { stroke-dashoffset: END_VALUE;    transform: rotate(90deg); }\n       87.5001%  { stroke-dashoffset: END_VALUE;    transform: rotateX(180deg) rotate(341.5deg); }\n       100%    { stroke-dashoffset: START_VALUE;  transform: rotateX(180deg) rotate(341.5deg); }\n     }\n   `;\n    return (\n      INDETERMINATE_ANIMATION_TEMPLATE\n        // Animation should begin at 5% and end at 80%\n        .replace(/START_VALUE/g, `${0.95 * this.strokeCircumference}`)\n        .replace(/END_VALUE/g, `${0.2 * this.strokeCircumference}`)\n        .replace(/DIAMETER/g, `${this.diameter}`)\n    );\n  }\n\n  completeIn(duration: number) {\n    this.mode = 'determinate';\n    this.change.detectChanges();\n\n    const animation = this.builder.build([\n      style({\n        'stroke-dasharray': 180,\n        'stroke-dashoffset': 90,\n        transformOrigin: 'center',\n        stroke: 'var(--fiv-spin-color)'\n      }),\n      animate(\n        `${duration}ms ease-out`,\n        style({\n          'stroke-dasharray': 315,\n          'stroke-dashoffset': 0,\n          transformOrigin: 'center',\n          stroke: 'var(--fiv-spin-color)',\n          opacity: 0\n        })\n      )\n    ]);\n\n    const player = animation.create(this.determinateCircle.nativeElement);\n    player.play();\n    player.onDone(() => {\n      this.fivComplete.emit(this);\n      this._value = 0;\n    });\n\n    const i = interval(duration / 100);\n    const t = timer(duration + duration / 50);\n    const progress = i.pipe(takeUntil(t));\n\n    progress.subscribe(p => {\n      this.fivProgress.emit(p);\n    });\n  }\n  setValue(progress: number): any {\n    this.mode = 'determinate';\n    this._value = progress;\n    this.change.detectChanges();\n  }\n\n  spin() {\n    this.mode = 'indeterminate';\n    this.change.detectChanges();\n  }\n\n  stop() {\n    this._value = 0;\n    this.change.detectChanges();\n  }\n\n  setMode(mode) {\n    this.mode = mode;\n    this.change.detectChanges();\n  }\n}\n"]}