UNPKG

@fivethree/core

Version:
212 lines 15.5 kB
/** * @fileoverview added by tsickle * Generated from: lib/searchbar/searchbar.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, Input, EventEmitter, Output, Renderer2 } from '@angular/core'; import { trigger, transition, style, animate, state } from '@angular/animations'; export class FivSearchbar { /** * @param {?} renderer */ constructor(renderer) { this.renderer = renderer; this.searching = false; this.titleVisible = true; this.closeButtonVisible = false; this.smallWidth = 120; this.searchIcon = 'search'; this.closeIcon = 'close'; this._small = false; this.fivInputChange = new EventEmitter(); this.fivClose = new EventEmitter(); this.open = new EventEmitter(); this.state = 'normal'; } /** * @param {?} s * @return {?} */ set small(s) { if (s && !this._small) { this.shrink(); } else if (!s && this._small) { this.grow(); } this._small = s; } /** * @return {?} */ get small() { return this._small; } /** * @return {?} */ ngOnInit() { this.state = this._small ? 'small' : 'normal'; } /** * @return {?} */ shrink() { this.state = 'small'; } /** * @return {?} */ grow() { this.state = 'normal'; } /** * @return {?} */ openSearchbar() { if (this._small) { this.state = 'normal'; } this._open(); } /** * @return {?} */ toggleSearchbar() { if (this.searching) { this.closeSearchbar(); } else { this.openSearchbar(); } } /** * @param {?} event * @return {?} */ searchBarStateChange(event) { if (event.fromState === 'normal' && event.toState === 'small') { } if (event.fromState === 'small' && event.toState === 'normal') { } } /** * @private * @return {?} */ _open() { this.searching = true; this.titleVisible = false; this.open.emit(); } /** * @return {?} */ closeSearchbar() { if (this.small) { this.state = 'small'; } this.searching = false; this.fivClose.emit(); } /** * @param {?} event * @return {?} */ searchAnimDone(event) { if (event.fromState !== 'void') { this.closeButtonVisible = true; } } /** * @param {?} event * @return {?} */ closeAnimDone(event) { if (event.fromState !== 'void') { this.searching = false; } } /** * @param {?} event * @param {?} input * @return {?} */ seachbarAnimDone(event, input) { if (event.fromState !== 'void') { this.titleVisible = true; } else { input.setFocus(); } } } FivSearchbar.decorators = [ { type: Component, args: [{ selector: 'fiv-searchbar', template: "<ion-toolbar [@searchbarAnim]=\"{value:state, params: {width: smallWidth}}\"\n (@searchbarAnim.done)=\"searchBarStateChange($event)\" [ngClass]=\"{'small': state === 'small'}\">\n <ion-buttons slot=\"start\">\n <ng-content select=\"[start]\"></ng-content>\n\n </ion-buttons>\n <ion-title [@titleAnim] *ngIf=\"titleVisible && state !== 'small'\">{{title}}</ion-title>\n <ion-input (ionChange)=\"fivInputChange.emit($event)\" [placeholder]=\"!titleVisible ? placeholder : ''\" autofocus #input\n class=\"searchbarbar\" [@titleAnim] (@titleAnim.done)=\"seachbarAnimDone($event,input)\" *ngIf=\"searching\">\n </ion-input>\n\n <ion-buttons slot=\"end\">\n <ion-button (click)=\"toggleSearchbar()\">\n <fiv-icon slot=\"icon-only\" [name]=\"searching ? closeIcon : searchIcon\"></fiv-icon>\n </ion-button>\n <ng-content select=\"[end]\"></ng-content>\n </ion-buttons>\n</ion-toolbar>", animations: [ trigger('searchbarAnim', [ transition('small => normal', [animate('125ms ease-out')]), transition('normal => small', [animate('95ms ease-in')]), state('small', style({ width: '{{width}}px' }), { params: { width: 120 } }), state('normal', style({ width: '100%' })) ]), trigger('titleAnim', [ transition('void => *', [ style({ opacity: '0', transform: 'translateY(-20%)' }), animate('175ms ease-out', style({ opacity: '1', transform: 'translateY(0)' })) ]) ]) ], styles: [":host{position:relative;display:block;width:100%;--fiv-toolbar-background:var(--ion-color-light)}ion-toolbar{box-shadow:0 1px 4px rgba(0,0,0,.25);transition:border-bottom-right-radius 85ms;margin-top:env(safe-area-inset-top);--background:var(--fiv-toolbar-background)}ion-toolbar.small{border-bottom-right-radius:12px}.searchbarbar{float:right}"] }] } ]; /** @nocollapse */ FivSearchbar.ctorParameters = () => [ { type: Renderer2 } ]; FivSearchbar.propDecorators = { title: [{ type: Input }], placeholder: [{ type: Input }], smallWidth: [{ type: Input }], searchIcon: [{ type: Input }], closeIcon: [{ type: Input }], small: [{ type: Input }], fivInputChange: [{ type: Output }], fivClose: [{ type: Output }], open: [{ type: Output }] }; if (false) { /** @type {?} */ FivSearchbar.prototype.searching; /** @type {?} */ FivSearchbar.prototype.titleVisible; /** @type {?} */ FivSearchbar.prototype.closeButtonVisible; /** @type {?} */ FivSearchbar.prototype.title; /** @type {?} */ FivSearchbar.prototype.placeholder; /** @type {?} */ FivSearchbar.prototype.smallWidth; /** @type {?} */ FivSearchbar.prototype.searchIcon; /** @type {?} */ FivSearchbar.prototype.closeIcon; /** @type {?} */ FivSearchbar.prototype._small; /** @type {?} */ FivSearchbar.prototype.fivInputChange; /** @type {?} */ FivSearchbar.prototype.fivClose; /** @type {?} */ FivSearchbar.prototype.open; /** @type {?} */ FivSearchbar.prototype.state; /** @type {?} */ FivSearchbar.prototype.renderer; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"searchbar.component.js","sourceRoot":"ng://@fivethree/core/","sources":["lib/searchbar/searchbar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  Input,\n  EventEmitter,\n  Output,\n  Renderer2\n} from '@angular/core';\nimport {\n  trigger,\n  transition,\n  style,\n  animate,\n  state\n} from '@angular/animations';\nimport { IonInput } from '@ionic/angular';\n\n@Component({\n  selector: 'fiv-searchbar',\n  templateUrl: './searchbar.component.html',\n  styleUrls: ['./searchbar.component.scss'],\n  animations: [\n    trigger('searchbarAnim', [\n      transition('small => normal', [animate('125ms ease-out')]),\n      transition('normal => small', [animate('95ms ease-in')]),\n      state('small', style({ width: '{{width}}px' }), {\n        params: { width: 120 }\n      }),\n      state('normal', style({ width: '100%' }))\n    ]),\n    trigger('titleAnim', [\n      transition('void => *', [\n        style({ opacity: '0', transform: 'translateY(-20%)' }),\n        animate(\n          '175ms ease-out',\n          style({ opacity: '1', transform: 'translateY(0)' })\n        )\n      ])\n    ])\n  ]\n})\nexport class FivSearchbar implements OnInit {\n  searching = false;\n  titleVisible = true;\n  closeButtonVisible = false;\n  @Input() title: string;\n  @Input() placeholder: string;\n  @Input() smallWidth = 120;\n  @Input() searchIcon = 'search';\n  @Input() closeIcon = 'close';\n\n  _small = false;\n  @Input() set small(s: boolean) {\n    if (s && !this._small) {\n      this.shrink();\n    } else if (!s && this._small) {\n      this.grow();\n    }\n    this._small = s;\n  }\n  get small() {\n    return this._small;\n  }\n  @Output() fivInputChange: EventEmitter<any> = new EventEmitter();\n  @Output() fivClose: EventEmitter<any> = new EventEmitter();\n  @Output() open: EventEmitter<any> = new EventEmitter();\n\n  state: 'small' | 'normal' = 'normal';\n\n  constructor(public renderer: Renderer2) {}\n\n  ngOnInit() {\n    this.state = this._small ? 'small' : 'normal';\n  }\n\n  shrink() {\n    this.state = 'small';\n  }\n  grow() {\n    this.state = 'normal';\n  }\n\n  openSearchbar() {\n    if (this._small) {\n      this.state = 'normal';\n    }\n    this._open();\n  }\n\n  toggleSearchbar() {\n    if (this.searching) {\n      this.closeSearchbar();\n    } else {\n      this.openSearchbar();\n    }\n  }\n\n  searchBarStateChange(event) {\n    if (event.fromState === 'normal' && event.toState === 'small') {\n    }\n\n    if (event.fromState === 'small' && event.toState === 'normal') {\n    }\n  }\n\n  private _open() {\n    this.searching = true;\n    this.titleVisible = false;\n    this.open.emit();\n  }\n\n  closeSearchbar() {\n    if (this.small) {\n      this.state = 'small';\n    }\n    this.searching = false;\n    this.fivClose.emit();\n  }\n\n  searchAnimDone(event) {\n    if (event.fromState !== 'void') {\n      this.closeButtonVisible = true;\n    }\n  }\n\n  closeAnimDone(event) {\n    if (event.fromState !== 'void') {\n      this.searching = false;\n    }\n  }\n\n  seachbarAnimDone(event, input: IonInput) {\n    if (event.fromState !== 'void') {\n      this.titleVisible = true;\n    } else {\n      input.setFocus();\n    }\n  }\n}\n"]}