@fivethree/core
Version:
Fivethree Core Components
212 lines • 15.5 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';
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"]}