UNPKG

@fivethree/core

Version:
385 lines 34.8 kB
/** * @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"]}