UNPKG

@fivethree/core

Version:
213 lines 15.5 kB
/** * @fileoverview added by tsickle * Generated from: lib/refresher/refresher-content/refresher-content.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, Input, ViewChild, ElementRef, Output, EventEmitter, Renderer2 } from '@angular/core'; import { animate, style, AnimationBuilder } from '@angular/animations'; import { FivSpinner } from '../../spinner/spinner.component'; var FivRefresherContent = /** @class */ (function () { function FivRefresherContent(element, renderer, builder) { this.element = element; this.renderer = renderer; this.builder = builder; this._progress = 0; this.fivComplete = new EventEmitter(); this.fivRefresh = new EventEmitter(); this.fivHidden = new EventEmitter(); this.fivShowed = new EventEmitter(); this.fivProgress = new EventEmitter(); this.visible = false; } Object.defineProperty(FivRefresherContent.prototype, "progress", { get: /** * @return {?} */ function () { return this._progress; }, set: /** * @param {?} progress * @return {?} */ function (progress) { this._progress = progress; if (progress < 1) { this.renderer.setStyle(this.spinnerRef.nativeElement, 'transform', "rotateZ(" + 360 * progress + "deg)"); } }, enumerable: true, configurable: true }); /** * @return {?} */ FivRefresherContent.prototype.ngOnInit = /** * @return {?} */ function () { }; /** * @return {?} */ FivRefresherContent.prototype.load = /** * @return {?} */ function () { this.visible = true; this.spinner.spin(); this.fivRefresh.emit(this); }; /** * @return {?} */ FivRefresherContent.prototype.unload = /** * @return {?} */ function () { this.spinner.stop(); }; /** * @return {?} */ FivRefresherContent.prototype.show = /** * @return {?} */ function () { var _this = this; if (!this.visible) { this.visible = true; /** @type {?} */ var animation = this.builder.build([ style({ transform: 'scale(0)' }), animate('0ms ease-out', style({ transform: 'scale(1)' })) ]); /** @type {?} */ var player_1 = animation.create(this.background.nativeElement); player_1.play(); player_1.onDone((/** * @return {?} */ function () { _this.fivShowed.emit(_this); player_1.destroy(); })); } }; /** * @return {?} */ FivRefresherContent.prototype.hide = /** * @return {?} */ function () { var _this = this; if (this.visible) { /** @type {?} */ var transform = "scale(1)"; /** @type {?} */ var animation = this.builder.build([ style({ transform: transform }), animate('175ms ease-in', style({ transform: "scale(0)" })) ]); /** @type {?} */ var player_2 = animation.create(this.background.nativeElement); player_2.play(); player_2.onDone((/** * @return {?} */ function () { _this.fivHidden.emit(_this); _this.visible = false; player_2.destroy(); })); } }; /** * @return {?} */ FivRefresherContent.prototype.complete = /** * @return {?} */ function () { this.unload(); this.fivComplete.emit(this); }; /** * @param {?} progress * @return {?} */ FivRefresherContent.prototype.setValue = /** * @param {?} progress * @return {?} */ function (progress) { this.spinner.setValue(progress); }; /** * @return {?} */ FivRefresherContent.prototype.reset = /** * @return {?} */ function () { this.spinner.setMode('indeterminate'); }; FivRefresherContent.decorators = [ { type: Component, args: [{ selector: 'fiv-refresher-content', template: "<div #background class=\"spinner-background\" [ngClass]=\"{'hidden': progress === 0}\">\n <fiv-spinner #spinner (fivProgress)=\"fivProgress.emit($event)\" (fivComplete)=\"complete()\" [circleRadius]=\"8\"\n [diameter]=\"20\" [strokeWidth]=\"2\"></fiv-spinner>\n</div>", styles: [":host{--fiv-spinner-size:40px;position:absolute;width:var(--fiv-spinner-size);height:var(--fiv-spinner-size);top:calc(-1 * var(--fiv-spinner-size));left:calc(50% - var(--fiv-spinner-size)/ 2);z-index:9}.spinner-background:not(.hidden){box-shadow:0 4px 6px 0 rgba(0,0,0,.14),0 4px 5px rgba(0,0,0,.1)}.spinner-background{position:absolute;width:40px;height:40px;background:var(--fiv-spin-background);border-radius:50%}.spinner-background fiv-spinner{position:absolute;top:10px;left:10px}"] }] } ]; /** @nocollapse */ FivRefresherContent.ctorParameters = function () { return [ { type: ElementRef }, { type: Renderer2 }, { type: AnimationBuilder } ]; }; FivRefresherContent.propDecorators = { progress: [{ type: Input }], fivComplete: [{ type: Output }], fivRefresh: [{ type: Output }], fivHidden: [{ type: Output }], fivShowed: [{ type: Output }], fivProgress: [{ type: Output }], spinner: [{ type: ViewChild, args: ['spinner', { static: false },] }], spinnerRef: [{ type: ViewChild, args: ['spinner', { static: true, read: ElementRef },] }], background: [{ type: ViewChild, args: ['background', { static: false },] }] }; return FivRefresherContent; }()); export { FivRefresherContent }; if (false) { /** @type {?} */ FivRefresherContent.prototype._progress; /** @type {?} */ FivRefresherContent.prototype.fivComplete; /** @type {?} */ FivRefresherContent.prototype.fivRefresh; /** @type {?} */ FivRefresherContent.prototype.fivHidden; /** @type {?} */ FivRefresherContent.prototype.fivShowed; /** @type {?} */ FivRefresherContent.prototype.fivProgress; /** @type {?} */ FivRefresherContent.prototype.spinner; /** @type {?} */ FivRefresherContent.prototype.spinnerRef; /** @type {?} */ FivRefresherContent.prototype.background; /** @type {?} */ FivRefresherContent.prototype.visible; /** @type {?} */ FivRefresherContent.prototype.element; /** * @type {?} * @private */ FivRefresherContent.prototype.renderer; /** @type {?} */ FivRefresherContent.prototype.builder; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"refresher-content.component.js","sourceRoot":"ng://@fivethree/core/","sources":["lib/refresher/refresher-content/refresher-content.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  Input,\n  ViewChild,\n  ElementRef,\n  Output,\n  EventEmitter,\n  Renderer2\n} from '@angular/core';\nimport { animate, style, AnimationBuilder } from '@angular/animations';\nimport { FivSpinner } from '../../spinner/spinner.component';\n\n@Component({\n  selector: 'fiv-refresher-content',\n  templateUrl: './refresher-content.component.html',\n  styleUrls: ['./refresher-content.component.scss']\n})\nexport class FivRefresherContent implements OnInit {\n  _progress = 0;\n  @Input() set progress(progress) {\n    this._progress = progress;\n    if (progress < 1) {\n      this.renderer.setStyle(\n        this.spinnerRef.nativeElement,\n        'transform',\n        `rotateZ(${360 * progress}deg)`\n      );\n    }\n  }\n\n  get progress() {\n    return this._progress;\n  }\n\n  @Output() fivComplete: EventEmitter<FivRefresherContent> = new EventEmitter<\n    FivRefresherContent\n  >();\n  @Output() fivRefresh: EventEmitter<FivRefresherContent> = new EventEmitter<\n    FivRefresherContent\n  >();\n  @Output() fivHidden: EventEmitter<FivRefresherContent> = new EventEmitter<\n    FivRefresherContent\n  >();\n  @Output() fivShowed: EventEmitter<FivRefresherContent> = new EventEmitter<\n    FivRefresherContent\n  >();\n  @Output() fivProgress: EventEmitter<number> = new EventEmitter<number>();\n\n  @ViewChild('spinner', { static: false }) spinner: FivSpinner;\n  @ViewChild('spinner', { static: true, read: ElementRef })\n  spinnerRef: ElementRef;\n  @ViewChild('background', { static: false }) background: ElementRef;\n\n  visible = false;\n\n  constructor(\n    public element: ElementRef,\n    private renderer: Renderer2,\n    public builder: AnimationBuilder\n  ) {}\n\n  ngOnInit() {}\n\n  load() {\n    this.visible = true;\n    this.spinner.spin();\n    this.fivRefresh.emit(this);\n  }\n\n  unload() {\n    this.spinner.stop();\n  }\n\n  show() {\n    if (!this.visible) {\n      this.visible = true;\n      const animation = this.builder.build([\n        style({ transform: 'scale(0)' }),\n        animate('0ms ease-out', style({ transform: 'scale(1)' }))\n      ]);\n\n      const player = animation.create(this.background.nativeElement);\n      player.play();\n      player.onDone(() => {\n        this.fivShowed.emit(this);\n        player.destroy();\n      });\n    }\n  }\n\n  hide() {\n    if (this.visible) {\n      const transform = `scale(1)`;\n      const animation = this.builder.build([\n        style({ transform: transform }),\n        animate('175ms ease-in', style({ transform: `scale(0)` }))\n      ]);\n\n      const player = animation.create(this.background.nativeElement);\n      player.play();\n      player.onDone(() => {\n        this.fivHidden.emit(this);\n        this.visible = false;\n        player.destroy();\n      });\n    }\n  }\n\n  complete() {\n    this.unload();\n    this.fivComplete.emit(this);\n  }\n\n  setValue(progress: number) {\n    this.spinner.setValue(progress);\n  }\n\n  reset() {\n    this.spinner.setMode('indeterminate');\n  }\n}\n"]}