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