UNPKG

@fivethree/core

Version:
254 lines 17 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'; var FivSearchbar = /** @class */ (function () { function FivSearchbar(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'; } Object.defineProperty(FivSearchbar.prototype, "small", { get: /** * @return {?} */ function () { return this._small; }, set: /** * @param {?} s * @return {?} */ function (s) { if (s && !this._small) { this.shrink(); } else if (!s && this._small) { this.grow(); } this._small = s; }, enumerable: true, configurable: true }); /** * @return {?} */ FivSearchbar.prototype.ngOnInit = /** * @return {?} */ function () { this.state = this._small ? 'small' : 'normal'; }; /** * @return {?} */ FivSearchbar.prototype.shrink = /** * @return {?} */ function () { this.state = 'small'; }; /** * @return {?} */ FivSearchbar.prototype.grow = /** * @return {?} */ function () { this.state = 'normal'; }; /** * @return {?} */ FivSearchbar.prototype.openSearchbar = /** * @return {?} */ function () { if (this._small) { this.state = 'normal'; } this._open(); }; /** * @return {?} */ FivSearchbar.prototype.toggleSearchbar = /** * @return {?} */ function () { if (this.searching) { this.closeSearchbar(); } else { this.openSearchbar(); } }; /** * @param {?} event * @return {?} */ FivSearchbar.prototype.searchBarStateChange = /** * @param {?} event * @return {?} */ function (event) { if (event.fromState === 'normal' && event.toState === 'small') { } if (event.fromState === 'small' && event.toState === 'normal') { } }; /** * @private * @return {?} */ FivSearchbar.prototype._open = /** * @private * @return {?} */ function () { this.searching = true; this.titleVisible = false; this.open.emit(); }; /** * @return {?} */ FivSearchbar.prototype.closeSearchbar = /** * @return {?} */ function () { if (this.small) { this.state = 'small'; } this.searching = false; this.fivClose.emit(); }; /** * @param {?} event * @return {?} */ FivSearchbar.prototype.searchAnimDone = /** * @param {?} event * @return {?} */ function (event) { if (event.fromState !== 'void') { this.closeButtonVisible = true; } }; /** * @param {?} event * @return {?} */ FivSearchbar.prototype.closeAnimDone = /** * @param {?} event * @return {?} */ function (event) { if (event.fromState !== 'void') { this.searching = false; } }; /** * @param {?} event * @param {?} input * @return {?} */ FivSearchbar.prototype.seachbarAnimDone = /** * @param {?} event * @param {?} input * @return {?} */ function (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 = function () { return [ { 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 }] }; return FivSearchbar; }()); export { FivSearchbar }; 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"]}