@fivethree/core
Version:
Fivethree Core Components
213 lines • 15.5 kB
JavaScript
/**
* @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"]}