UNPKG

@fivethree/core

Version:
199 lines 18.2 kB
/** * @fileoverview added by tsickle * Generated from: lib/icon/icon.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, Input, ChangeDetectionStrategy, Output, EventEmitter, HostBinding } from '@angular/core'; import { trigger, transition, animate, state, style } from '@angular/animations'; export class FivIcon { constructor() { this._badge = 0; this.state = 'normal'; this.off = false; this.animationDisabled = false; this.transitionDone = new EventEmitter(); this.indicatorState = 'scale'; this.badgeState = 'scale'; } /** * @return {?} */ get name() { return this._name; } /** * @param {?} name * @return {?} */ set name(name) { if (this._name) { this.transform(name); } else { this._name = name; } } /** * @return {?} */ get badge() { return this._badge; } /** * @param {?} value * @return {?} */ set badge(value) { this.transformIndicator(value); } /** * @param {?} dot * @return {?} */ set dot(dot) { this._dot = dot; if (dot) { this.indicatorState = 'normal'; } } /** * @return {?} */ get dot() { return this._dot; } /** * @return {?} */ ngOnInit() { } /** * @param {?} name * @return {?} */ transform(name) { this.temp = name; this.state = 'rotate'; } /** * @param {?} value * @return {?} */ transformIndicator(value) { if (this.dot) { this._badge = value; return; } if (value === 0) { this._badge = value; this.badgeState = 'scale'; } else { if (this.badgeState === 'scale') { this.badgeState = 'normal'; this._badge = value; } else { this.tempValue = value; this.badgeState = 'scale'; } } } /** * @param {?} event * @return {?} */ rotateAnimDone(event) { if (event.fromState === 'normal' && event.toState === 'rotate') { this._name = this.temp; this.state = 'normal'; } if (event.fromState === 'rotate' && event.toState === 'normal') { this.transitionDone.emit(this._name); } } /** * @param {?} event * @return {?} */ incrementDone(event) { if (event.fromState === 'normal' && event.toState === 'scale') { if (this.tempValue > 0) { this.badgeState = 'normal'; this._badge = this.tempValue; } else { this._badge = this.tempValue; } } } } FivIcon.decorators = [ { type: Component, args: [{ selector: 'fiv-icon', template: "<ion-icon [slot]=\"slot\" class=\"icon\" [@rotateAnim]=\"state\" (@rotateAnim.done)=\"rotateAnimDone($event)\" [name]=\"_name\"\n [color]=\"color\"></ion-icon>\n<span [@scaleAnim]=\"indicatorState\" *ngIf=\"dot\" class=\"indicator-dot\"></span>\n<span class=\"off-background\" *ngIf=\"off\"></span>\n<span class=\"off\" *ngIf=\"off\"></span>\n<span *ngIf=\"smallIcon && badge == 0 && !dot\" class=\"indicator-small-icon\">\n <ion-icon [color]=\"color\" slot=\"icon-only\" [name]=\"smallIcon\"></ion-icon>\n</span>\n<span *ngIf=\"badge > 0 && !dot\" [@scaleAnim]=\"badgeState\" (@scaleAnim.done)=\"incrementDone($event)\"\n class=\"indicator-badge\">\n <span *ngIf=\"badge <= 9\">{{badge}}</span>\n <span *ngIf=\"badge > 9\">9+</span>\n</span>", changeDetection: ChangeDetectionStrategy.OnPush, animations: [ trigger('rotateAnim', [ transition('normal => rotate', [animate('125ms ease-out')]), transition('rotate => normal', [animate('125ms ease-in')]), state('rotate', style({ opacity: '0', transform: 'scale(0) rotateZ(45deg)' })), state('normal', style({ opacity: '1', transform: 'scale(1) rotateZ(0deg)' })) ]), trigger('scaleAnim', [ transition('void => normal', [ style({ opacity: '0', transform: 'scale(0)' }), animate('125ms ease-out', style({ opacity: '1', transform: 'scale(1)' })) ]), transition('normal => scale', [animate('125ms ease-out')]), transition('scale => normal', [animate('125ms ease-in')]), state('scale', style({ opacity: '0', transform: 'scale(0)' })), state('normal', style({ opacity: '1', transform: 'scale(1)' })) ]) ], styles: [":host{--fiv-padding-end:0;--fiv-padding-start:0;--fiv-position-top:-2px;--fiv-position-right:-6px;--fiv-icon-height:28px;--fiv-icon-width:28px;--fiv-small-icon-height:18px;--fiv-small-icon-width:18px;--fiv-small-icon-font-size:0.8em;--fiv-badge-height:18px;--fiv-badge-width:18px;--fiv-badge-font-size:0.6em;--fiv-dot-height:18px;--fiv-dot-width:18px;position:relative;display:inline-block}.icon{margin:0;font-size:1.8em;color:var(--fiv-icon-color,var(--ion-color-dark));padding-right:var(--fiv-padding-end);padding-left:var(--fiv-padding-start);height:var(--fiv-icon-height);width:var(--fiv-icon-width)}.indicator-badge{position:absolute;top:var(--fiv-position-top);right:var(--fiv-position-right);height:var(--fiv-badge-height);width:var(--fiv-badge-width);background-color:var(--fiv-badge-background-color,var(--ion-color-primary));color:var(--fiv-badge-color,var(--ion-color-light));border-radius:14px;z-index:13}.indicator-badge *{position:absolute;transform:translateX(-50%) translateY(-50%);left:50%;top:50%;font-size:var(--fiv-badge-font-size)}.indicator-dot{position:absolute;top:var(--fiv-position-top);right:var(--fiv-position-right);height:var(--fiv-dot-height);width:var(--fiv-dot-width);background-color:var(--fiv-dot-background-color,var(--ion-color-primary));border-radius:100%;z-index:11}.indicator-small-icon{position:absolute;top:var(--fiv-position-top);right:var(--fiv-position-right);height:var(--fiv-small-icon-height);width:var(--fiv-small-icon-width);background-color:var(--fiv-small-icon-background-color,var(--ion-color-primary));color:var(--fiv-small-icon-color,var(--ion-color-light));border-radius:14px;z-index:13}.indicator-small-icon *{position:absolute;transform:translateX(-50%) translateY(-50%);left:50%;top:50%;font-size:var(--fiv-small-icon-font-size)}.off{width:120%;height:2px;background:var(--fiv-off-color,var(--fiv-icon-color,var(--ion-color-dark)));position:absolute;left:0;transform:rotateZ(45deg) translateY(10px) translateX(6px)}.off-background{width:120%;height:2px;background:#000;position:absolute;background-color:var(--fiv-off-background-color,var(--ion-color-light));left:2px;transform:rotateZ(45deg) translateY(10px) translateX(6px)}"] }] } ]; /** @nocollapse */ FivIcon.ctorParameters = () => []; FivIcon.propDecorators = { color: [{ type: Input }], slot: [{ type: Input }], smallIcon: [{ type: Input }], off: [{ type: Input }], animationDisabled: [{ type: Input }, { type: HostBinding, args: ['@.disabled',] }], transitionDone: [{ type: Output }], name: [{ type: Input }], badge: [{ type: Input }], dot: [{ type: Input }] }; if (false) { /** @type {?} */ FivIcon.prototype._name; /** @type {?} */ FivIcon.prototype._badge; /** @type {?} */ FivIcon.prototype._dot; /** @type {?} */ FivIcon.prototype.tempValue; /** @type {?} */ FivIcon.prototype.state; /** @type {?} */ FivIcon.prototype.temp; /** @type {?} */ FivIcon.prototype.color; /** @type {?} */ FivIcon.prototype.slot; /** @type {?} */ FivIcon.prototype.smallIcon; /** @type {?} */ FivIcon.prototype.off; /** @type {?} */ FivIcon.prototype.animationDisabled; /** @type {?} */ FivIcon.prototype.transitionDone; /** @type {?} */ FivIcon.prototype.indicatorState; /** @type {?} */ FivIcon.prototype.badgeState; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon.component.js","sourceRoot":"ng://@fivethree/core/","sources":["lib/icon/icon.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  Input,\n  ChangeDetectionStrategy,\n  Output,\n  EventEmitter,\n  HostBinding\n} from '@angular/core';\nimport {\n  trigger,\n  transition,\n  animate,\n  state,\n  style\n} from '@angular/animations';\n\n@Component({\n  selector: 'fiv-icon',\n  templateUrl: './icon.component.html',\n  styleUrls: ['./icon.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  animations: [\n    trigger('rotateAnim', [\n      transition('normal => rotate', [animate('125ms ease-out')]),\n      transition('rotate => normal', [animate('125ms ease-in')]),\n      state(\n        'rotate',\n        style({ opacity: '0', transform: 'scale(0) rotateZ(45deg)' })\n      ),\n      state(\n        'normal',\n        style({ opacity: '1', transform: 'scale(1) rotateZ(0deg)' })\n      )\n    ]),\n    trigger('scaleAnim', [\n      transition('void => normal', [\n        style({ opacity: '0', transform: 'scale(0)' }),\n        animate(\n          '125ms ease-out',\n          style({ opacity: '1', transform: 'scale(1)' })\n        )\n      ]),\n      transition('normal => scale', [animate('125ms ease-out')]),\n      transition('scale => normal', [animate('125ms ease-in')]),\n      state('scale', style({ opacity: '0', transform: 'scale(0)' })),\n      state('normal', style({ opacity: '1', transform: 'scale(1)' }))\n    ])\n  ]\n})\nexport class FivIcon implements OnInit {\n  _name: string;\n  _badge = 0;\n  _dot: boolean;\n  tempValue: number;\n  state: 'normal' | 'rotate' = 'normal';\n  temp: string;\n  @Input() color: string;\n\n  @Input() slot: string;\n  @Input() smallIcon: string;\n  @Input() off = false;\n\n  @Input()\n  @HostBinding('@.disabled')\n  animationDisabled = false;\n\n  @Output() transitionDone = new EventEmitter<string>();\n\n  indicatorState: 'normal' | 'scale' = 'scale';\n  badgeState: 'normal' | 'scale' = 'scale';\n\n  @Input()\n  get name(): string {\n    return this._name;\n  }\n  set name(name: string) {\n    if (this._name) {\n      this.transform(name);\n    } else {\n      this._name = name;\n    }\n  }\n\n  @Input()\n  get badge(): number {\n    return this._badge;\n  }\n  set badge(value: number) {\n    this.transformIndicator(value);\n  }\n\n  @Input()\n  set dot(dot: boolean) {\n    this._dot = dot;\n    if (dot) {\n      this.indicatorState = 'normal';\n    }\n  }\n  get dot(): boolean {\n    return this._dot;\n  }\n\n  constructor() {}\n\n  ngOnInit() {}\n\n  transform(name: string) {\n    this.temp = name;\n    this.state = 'rotate';\n  }\n\n  transformIndicator(value: number) {\n    if (this.dot) {\n      this._badge = value;\n      return;\n    }\n    if (value === 0) {\n      this._badge = value;\n      this.badgeState = 'scale';\n    } else {\n      if (this.badgeState === 'scale') {\n        this.badgeState = 'normal';\n        this._badge = value;\n      } else {\n        this.tempValue = value;\n        this.badgeState = 'scale';\n      }\n    }\n  }\n\n  rotateAnimDone(event) {\n    if (event.fromState === 'normal' && event.toState === 'rotate') {\n      this._name = this.temp;\n      this.state = 'normal';\n    }\n\n    if (event.fromState === 'rotate' && event.toState === 'normal') {\n      this.transitionDone.emit(this._name);\n    }\n  }\n\n  incrementDone(event) {\n    if (event.fromState === 'normal' && event.toState === 'scale') {\n      if (this.tempValue > 0) {\n        this.badgeState = 'normal';\n        this._badge = this.tempValue;\n      } else {\n        this._badge = this.tempValue;\n      }\n    }\n  }\n}\n"]}