air-lib
Version:
This is Air's angular component library
1,172 lines (1,156 loc) • 107 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, Input, Output, EventEmitter, ElementRef, forwardRef } from '@angular/core';
import { DomSanitizer } from '@angular/platform-browser';
import { SelectItem } from './select-item';
import { stripTags } from './select-pipes';
import { escapeRegexp } from './common';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
// Customization: NEW STRING:
import { MessageEvent } from '../../../services/Broadcaster/message-event';
import { AutocompleteCountSettings } from '../../../entities/auto-complete-count-settings';
/** @type {?} */
const styles = `
.ui-select-toggle {
position: relative;
}
/* Fix Bootstrap dropdown position when inside a input-group */
.input-group > .dropdown {
/* Instead of relative */
position: static;
}
.ui-select-match > .btn {
/* Instead of center because of .btn */
text-align: left !important;
}
.ui-select-match > .caret {
position: absolute;
top: 45%;
right: 15px;
}
.ui-disabled {
background-color: transparent;
border-radius: 0;
position: absolute;
width: 100%;
height: 100%;
z-index: 5;
opacity: 0;
top: 0;
left: 0;
cursor: not-allowed;
}
.ui-select-choices {
width: 100%;
height: auto;
max-height: 200px;
overflow-x: hidden;
margin-top: 0;
}
.ui-select-multiple .ui-select-choices {
margin-top: 1px;
}
.ui-select-choices-row>a {
display: block;
padding: 3px 20px;
clear: both;
font-weight: 400;
line-height: 1.42857143;
color: #333;
white-space: nowrap;
}
.ui-select-choices-row.active>a {
color: #000;
text-decoration: none;
outline: 0;
background-color: #f5f5f5;
}
.ui-select-multiple {
height: auto;
padding:3px 3px 0 3px;
}
.ui-select-multiple input.ui-select-search {
background-color: transparent !important; /* To prevent double background when disabled */
border: none;
outline: none;
box-shadow: none;
height: 1.6666em;
padding: 0;
margin-bottom: 3px;
}
.ui-select-match .close {
font-size: 1.6em;
line-height: 0.75;
}
.ui-select-multiple .ui-select-match-item {
outline: 0;
margin: 0 3px 3px 0;
}
.ui-select-toggle > .caret {
position: absolute;
height: 10px;
top: 50%;
right: 10px;
margin-top: -2px;
}
.autocomplete-count{
font-weight: 400;
}
.ui-select-choices-row:hover {
background-color: #f5f5f5;
}
.text-muted{
color: #cccccc;
}
`;
export class SelectComponent {
// Customization: NEW STRINGS:
/**
* @param {?} element
* @param {?} sanitizer
* @param {?} messageEvent
*/
constructor(element, sanitizer, messageEvent) {
this.sanitizer = sanitizer;
this.messageEvent = messageEvent;
this.editInputData = true;
this.allowClear = false;
this.placeholder = '';
this.idField = 'id';
this.textField = 'text';
this.multiple = false;
this.isSearch = false;
this.allowSearchIcons = false;
this.hasError = false;
this.searchPrepared = new EventEmitter();
// Customization: NEW STRINGS:
this.componentId = '';
this.enterKeySuppress = false;
this.opened = new EventEmitter();
this.closed = new EventEmitter();
this.inputText = new EventEmitter();
this.data = new EventEmitter();
this.selected = new EventEmitter();
this.removed = new EventEmitter();
this.typed = new EventEmitter();
this.options = [];
this.itemObjects = [];
this.inputMode = false;
this.optionsOpened = false;
this.inputValue = '';
this._items = [];
this._disabled = false;
this._active = [];
this.propagateChange = (_) => { };
// Customization: COMMENTED STRINGS:
// public constructor(element: ElementRef, private sanitizer: DomSanitizer) {
this.element = element;
this.clickedOutside = this.clickedOutside.bind(this);
}
/**
* @param {?} value
* @return {?}
*/
set items(value) {
if (!value) {
this._items = this.itemObjects = [];
}
else {
this._items = value.filter((item) => {
// if ((typeof item === 'string' && item) || (typeof item === 'object' && item && item.text && item.id)) {
if ((typeof item === 'string') || (typeof item === 'object' && item.text)) {
return item;
}
});
this.itemObjects = this._items.map((item) => new SelectItem(item));
// Customization: NEW STRING:
this.options = this.itemObjects;
}
}
/**
* @param {?} value
* @return {?}
*/
set disabled(value) {
this._disabled = value;
if (this._disabled === true) {
this.hideOptions();
}
}
/**
* @return {?}
*/
get disabled() {
return this._disabled;
}
/**
* @param {?} selectedItems
* @return {?}
*/
set active(selectedItems) {
// Customization: NEW STRINGS:
if (this.activeOption) {
this.activeOption.id = '';
this.activeOption.text = '';
}
if (!selectedItems || selectedItems.length === 0) {
this._active = [];
}
else {
/** @type {?} */
const areItemsStrings = typeof selectedItems[0] === 'string';
this._active = selectedItems.map((item) => {
/** @type {?} */
const data = areItemsStrings
? item
: { id: item[this.idField], text: item[this.textField] };
return new SelectItem(data);
});
}
}
/**
* @param {?} searchTitle
* @return {?}
*/
set title(searchTitle) {
if (searchTitle) {
this._title = searchTitle;
}
}
/**
* @return {?}
*/
get title() {
return this._title;
}
/**
* @param {?} autocompleteCountSettings
* @return {?}
*/
set autocompleteCountSettings(autocompleteCountSettings) {
if (autocompleteCountSettings) {
this.optionsAutocomplete = autocompleteCountSettings;
}
}
/**
* @param {?} value
* @return {?}
*/
set searchString(value) {
if (value) {
this.inputValue = value;
}
}
/**
* @return {?}
*/
get active() {
return this._active;
}
/**
* @return {?}
*/
get firstItemHasChildren() {
return this.itemObjects[0] && this.itemObjects[0].hasChildren();
}
/**
* @param {?} obj
* @return {?}
*/
writeValue(obj) {
this.active = obj;
}
/**
* @param {?} fn
* @return {?}
*/
registerOnChange(fn) {
this.propagateChange = fn;
}
/**
* @param {?} fn
* @return {?}
*/
registerOnTouched(fn) {
// throw new Error("Method not implemented.");
}
/**
* @param {?} isDisabled
* @return {?}
*/
setDisabledState(isDisabled) {
// throw new Error("Method not implemented.");
}
/**
* @param {?} value
* @param {?=} e
* @return {?}
*/
selectMatch(value, e = null) {
if (value.id.indexOf('noclick') > -1) {
return;
}
if (e) {
e.stopPropagation();
e.preventDefault();
}
if (this.options.length <= 0) {
return;
}
if (this.multiple === true) {
this.active.push(value);
this.data.next(this.active);
}
if (this.multiple === false) {
this.active[0] = value;
this.data.next(this.active[0]);
}
this.doEvent('selected', value);
this.hideOptions();
if (this.multiple === true) {
this.focusToInput('');
}
else {
this.focusToInput(stripTags(value.text));
this.element.nativeElement.querySelector('.ui-select-container').focus();
}
}
/**
* @param {?} html
* @return {?}
*/
sanitize(html) {
return this.sanitizer.bypassSecurityTrustHtml(html);
}
/**
* @param {?} e
* @param {?=} isUpMode
* @return {?}
*/
inputEvent(e, isUpMode = false) {
// Customization: NEW STRING:
if (e.type === 'keyup') {
/** @type {?} */
const inputText = document.getElementById(this.componentId + '-input-text');
if (this.inputText && inputText) {
this.inputText.emit(inputText.value);
this.searchText = inputText.value;
}
}
// tab
if (e.keyCode === 9) {
return;
}
if (!this.isSearch && isUpMode && (e.keyCode === 37 || e.keyCode === 39 || e.keyCode === 38 ||
e.keyCode === 40)) {
e.preventDefault();
return;
}
// backspace
if (!isUpMode && e.keyCode === 8) {
/** @type {?} */
const el = this.element.nativeElement
.querySelector('div.ui-select-container > input');
if (!el.value || el.value.length <= 0) {
if (this.active.length > 0) {
this.remove(this.active[this.active.length - 1]);
}
e.preventDefault();
}
}
// esc
if (!isUpMode && e.keyCode === 27) {
this.hideOptions();
this.element.nativeElement.children[0].focus();
e.preventDefault();
return;
}
// del
if (!isUpMode && e.keyCode === 46) {
if (this.active.length > 0) {
this.remove(this.active[this.active.length - 1]);
}
e.preventDefault();
}
// left
if (!isUpMode && e.keyCode === 37 && this._items.length > 0) {
this.behavior.first();
e.preventDefault();
return;
}
// right
if (!isUpMode && e.keyCode === 39 && this._items.length > 0) {
this.behavior.last();
e.preventDefault();
return;
}
// up
if (!isUpMode && e.keyCode === 38) {
this.behavior.prev();
e.preventDefault();
return;
}
// down
if (!isUpMode && e.keyCode === 40) {
this.behavior.next();
e.preventDefault();
return;
}
// enter
if (e.keyCode === 13) {
// Customization: NEW STRINGS:
if (this.isSearch) {
this.selectionPrepared(e.target.value);
}
else {
if (this.active.indexOf(this.activeOption) === -1) {
this.selectActiveMatch();
this.behavior.next();
}
e.preventDefault();
return;
}
}
/** @type {?} */
const target = e.target || e.srcElement;
if (target && target.value) {
this.inputValue = target.value;
this.behavior.filter(new RegExp(escapeRegexp(this.inputValue), 'ig'));
this.doEvent('typed', this.inputValue);
}
}
/**
* @return {?}
*/
ngOnInit() {
this.behavior = (this.firstItemHasChildren) ?
new ChildrenBehavior(this) : new GenericBehavior(this);
// Customization: NEW STRING:
this.registerBroadcastEvent();
}
/**
* @param {?} item
* @return {?}
*/
remove(item) {
if (this._disabled === true) {
return;
}
if (this.multiple === true && this.active) {
/** @type {?} */
const index = this.active.indexOf(item);
this.active.splice(index, 1);
this.data.next(this.active);
this.doEvent('removed', item);
}
if (this.multiple === false) {
this.active = [];
this.data.next(this.active);
this.removed.emit(this.active);
}
}
/**
* @param {?} type
* @param {?} value
* @return {?}
*/
doEvent(type, value) {
if (((/** @type {?} */ (this)))[type] && value) {
((/** @type {?} */ (this)))[type].next(value);
}
if (type === 'selected') {
this.propagateChange(value);
}
}
/**
* @return {?}
*/
clickedOutside() {
this.inputMode = false;
this.optionsOpened = false;
// Customization: NEW STRING:
this.closed.emit();
}
/**
* @param {?} e
* @return {?}
*/
matchClick(e) {
if (this._disabled === true) {
return;
}
this.inputMode = !this.inputMode;
if (this.inputMode === true && ((this.multiple === true && e) || this.multiple === false)) {
/** @type {?} */
let editableValue = '';
if (e.target.textContent && this.editInputData) {
editableValue = e.target.textContent;
// @ts-ignore
this.searchSettings.presetList.forEach(item => {
if (item.text === editableValue) {
editableValue = '';
}
});
// @ts-ignore
if (editableValue === this.searchSettings.placeholder) {
editableValue = '';
}
}
else {
editableValue = '';
}
this.focusToInput(editableValue);
this.open();
}
}
/**
* @param {?} event
* @return {?}
*/
mainClick(event) {
if (this.inputMode === true || this._disabled === true) {
return;
}
if (event.keyCode === 46) {
event.preventDefault();
this.inputEvent(event);
return;
}
if (event.keyCode === 8) {
event.preventDefault();
this.inputEvent(event, true);
return;
}
if (event.keyCode === 9 || event.keyCode === 13 ||
event.keyCode === 27 || (event.keyCode >= 37 && event.keyCode <= 40)) {
event.preventDefault();
return;
}
this.inputMode = true;
/** @type {?} */
const value = String
.fromCharCode(96 <= event.keyCode && event.keyCode <= 105 ? event.keyCode - 48 : event.keyCode)
.toLowerCase();
this.focusToInput(value);
this.open();
/** @type {?} */
const target = event.target || event.srcElement;
target.value = value;
this.inputEvent(event);
}
/**
* @param {?} value
* @return {?}
*/
selectActive(value) {
this.activeOption = value;
}
/**
* @param {?} value
* @return {?}
*/
isActive(value) {
return this.activeOption && (this.activeOption.text === value.text);
}
/**
* @param {?=} value
* @return {?}
*/
focusToInput(value = '') {
setTimeout(() => {
/** @type {?} */
const el = this.element.nativeElement.querySelector('div.ui-select-container > input');
if (el) {
el.focus();
el.value = value;
}
}, 0);
}
/**
* @private
* @return {?}
*/
open() {
this.options = this.itemObjects
.filter((option) => (this.multiple === false ||
this.multiple === true && !this.active.find((o) => option.text === o.text)));
if (this.options.length > 0) {
this.behavior.first();
}
this.optionsOpened = true;
// Customization: NEW STRINGS:
this.emitBroadcastEvent();
this.opened.emit();
}
/**
* @private
* @return {?}
*/
hideOptions() {
this.inputMode = false;
this.optionsOpened = false;
}
/**
* @private
* @return {?}
*/
selectActiveMatch() {
this.selectMatch(this.activeOption);
}
// Customization: NEW STRINGS:
/**
* @private
* @return {?}
*/
registerBroadcastEvent() {
this.messageEvent.on()
.subscribe(message => {
if (message !== this.componentId) {
this.clickedOutside();
}
});
}
/**
* @private
* @return {?}
*/
emitBroadcastEvent() {
this.messageEvent.fire(this.componentId);
}
/**
* @param {?} value
* @return {?}
*/
selectionPrepared(value) {
this.searchPrepared.emit(value);
this.hideOptions();
}
}
SelectComponent.decorators = [
{ type: Component, args: [{
// tslint:disable-next-line:component-selector
selector: 'ng-select',
// Customization: NEW STRING:
providers: [MessageEvent,
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => SelectComponent),
multi: true
}
],
template: `
<div tabindex="0"
*ngIf="multiple === false"
(keyup)="mainClick($event)"
[offClick]="clickedOutside"
class="ui-select-container dropdown open" [ngClass]="{'ui-select-focusud':inputMode, 'has-error': hasError}">
<div [ngClass]="{'ui-disabled': disabled}"></div>
<div *ngIf="title" class='title-input'>{{title}}</div>
<div class="ui-select-match"
*ngIf="!inputMode">
<span tabindex="-1"
class="btn btn-default btn-secondary form-control ui-select-toggle"
(click)="matchClick($event)"
style="outline: 0;">
<span *ngIf="active.length <= 0 || active[0].id ==''" class="ui-select-placeholder text-muted">{{placeholder}}</span>
<span *ngIf="active.length > 0" class="ui-select-match-text"
[ngClass]="{'ui-select-allow-clear': allowClear && active.length > 0}"
[innerHTML]="sanitize(active[0].text)"></span>
<i class="dropdown-toggle pull-right"></i>
<i *ngIf="!isSearch" class="caret pull-right"></i>
</span>
</div>
<div class='ui-block-icons'>
<a *ngIf="allowClear && active.length>0" class="icons rotate45" (click)="remove(activeOption)">
<i class="ui-close">+</i>
</a>
<a *ngIf="allowSearchIcons && active.length > 0" class="icons" (click)="selectionPrepared(searchText)">
<i class="fa fa-search" aria-hidden="true"></i>
</a>
</div>
<input #search type="text" autocomplete="false" tabindex="-1" id="{{componentId}}-input-text"
(keyup)="inputEvent($event, true)"
[disabled]="disabled"
class="form-control ui-select-search"
*ngIf="inputMode"
placeholder="{{active.length <= 0 ? placeholder : ''}}">
<!-- options template -->
<ul *ngIf="optionsOpened && options && options.length > 0 && !firstItemHasChildren"
class="ui-select-choices dropdown-menu" role="menu">
<li *ngFor="let o of options" role="menuitem">
<div class="ui-select-choices-row"
(click)="selectMatch(o, $event)" [ngClass]="{'active': o.text == active[0]?.text}">
<a href="javascript:void(0)" class="dropdown-item">
<div [innerHtml]="sanitize(o.text | highlight:inputValue)"></div>
</a>
</div>
</li>
<li *ngIf="optionsAutocomplete?.hasAutocompleteCount">
<div class="autocomplete-count color-link p-l-30"><i [innerHTML]="optionsAutocomplete?.autocompleteCountString"></i></div>
</li>
</ul>
<ul *ngIf="optionsOpened && options && options.length > 0 && firstItemHasChildren"
class="ui-select-choices dropdown-menu" role="menu">
<li *ngFor="let c of options; let index=index" role="menuitem">
<div class="divider dropdown-divider" *ngIf="index > 0"></div>
<div class="dropdown-header">{{c.text}}</div>
<div *ngFor="let o of c.children"
class="ui-select-choices-row"
[class.active]="isActive(o)"
(mouseenter)="selectActive(o)"
(click)="selectMatch(o, $event)"
[ngClass]="{'active': isActive(o)}">
<a href="javascript:void(0)" class="dropdown-item">
<div [innerHtml]="sanitize(o.text | highlight:inputValue)"></div>
</a>
</div>
</li>
</ul>
</div>
<div tabindex="0"
*ngIf="multiple === true"
(keyup)="mainClick($event)"
(focus)="focusToInput('')"
[offClick]="clickedOutside"
class="ui-select-container ui-select-multiple dropdown form-control open">
<div [ngClass]="{'ui-disabled': disabled}"></div>
<span class="ui-select-match">
<span *ngFor="let a of active">
<span class="ui-select-match-item btn btn-default btn-secondary btn-xs"
tabindex="-1"
type="button"
[ngClass]="{'btn-default': true}">
<a class="close"
style="margin-left: 5px; padding: 0;"
(click)="remove(a)">×</a>
<span>{{a.text}}</span>
</span>
</span>
</span>
<input type="text"
(keydown)="inputEvent($event)"
(keyup)="inputEvent($event, true)"
(click)="matchClick($event)"
[disabled]="disabled"
id="{{componentId}}-input-text"
autocomplete="false"
autocorrect="off"
autocapitalize="off"
spellcheck="false"
class="form-control ui-select-search"
placeholder="{{active.length <= 0 ? placeholder : ''}}"
role="combobox">
<!-- options template -->
<ul *ngIf="optionsOpened && options && options.length > 0 && !firstItemHasChildren"
class="ui-select-choices dropdown-menu" role="menu">
<li *ngFor="let o of options" role="menuitem">
<div class="ui-select-choices-row"
[class.active]="isActive(o)"
(mouseenter)="selectActive(o)"
(click)="selectMatch(o, $event)">
<a href="javascript:void(0)" class="dropdown-item">
<div [innerHtml]="sanitize(o.text | highlight:inputValue)"></div>
</a>
</div>
</li>
</ul>
<ul *ngIf="optionsOpened && options && options.length > 0 && firstItemHasChildren"
class="ui-select-choices dropdown-menu" role="menu">
<li *ngFor="let c of options; let index=index" role="menuitem">
<div class="divider dropdown-divider" *ngIf="index > 0"></div>
<div class="dropdown-header">{{c.text}}</div>
<div *ngFor="let o of c.children"
class="ui-select-choices-row"
[class.active]="isActive(o)"
(mouseenter)="selectActive(o)"
(click)="selectMatch(o, $event)"
[ngClass]="{'active': isActive(o)}">
<a href="javascript:void(0)" class="dropdown-item">
<div [innerHtml]="sanitize(o.text | highlight:inputValue)"></div>
</a>
</div>
</li>
</ul>
</div>
`,
styles: [styles]
}] }
];
SelectComponent.ctorParameters = () => [
{ type: ElementRef },
{ type: DomSanitizer },
{ type: MessageEvent }
];
SelectComponent.propDecorators = {
items: [{ type: Input }],
disabled: [{ type: Input }],
active: [{ type: Input }],
title: [{ type: Input }],
autocompleteCountSettings: [{ type: Input }],
searchString: [{ type: Input }],
editInputData: [{ type: Input }],
searchSettings: [{ type: Input }],
allowClear: [{ type: Input }],
placeholder: [{ type: Input }],
idField: [{ type: Input }],
textField: [{ type: Input }],
multiple: [{ type: Input }],
isSearch: [{ type: Input }],
allowSearchIcons: [{ type: Input }],
hasError: [{ type: Input }],
searchPrepared: [{ type: Output }],
componentId: [{ type: Input }],
enterKeySuppress: [{ type: Input }],
opened: [{ type: Output }],
closed: [{ type: Output }],
inputText: [{ type: Output }],
data: [{ type: Output }],
selected: [{ type: Output }],
removed: [{ type: Output }],
typed: [{ type: Output }]
};
if (false) {
/** @type {?} */
SelectComponent.prototype.editInputData;
/** @type {?} */
SelectComponent.prototype.searchSettings;
/** @type {?} */
SelectComponent.prototype.allowClear;
/** @type {?} */
SelectComponent.prototype.placeholder;
/** @type {?} */
SelectComponent.prototype.idField;
/** @type {?} */
SelectComponent.prototype.textField;
/** @type {?} */
SelectComponent.prototype.multiple;
/** @type {?} */
SelectComponent.prototype.isSearch;
/**
* @type {?}
* @private
*/
SelectComponent.prototype._title;
/** @type {?} */
SelectComponent.prototype.allowSearchIcons;
/** @type {?} */
SelectComponent.prototype.hasError;
/** @type {?} */
SelectComponent.prototype.searchPrepared;
/** @type {?} */
SelectComponent.prototype.searchText;
/** @type {?} */
SelectComponent.prototype.optionsAutocomplete;
/** @type {?} */
SelectComponent.prototype.componentId;
/** @type {?} */
SelectComponent.prototype.enterKeySuppress;
/** @type {?} */
SelectComponent.prototype.opened;
/** @type {?} */
SelectComponent.prototype.closed;
/** @type {?} */
SelectComponent.prototype.inputText;
/** @type {?} */
SelectComponent.prototype.data;
/** @type {?} */
SelectComponent.prototype.selected;
/** @type {?} */
SelectComponent.prototype.removed;
/** @type {?} */
SelectComponent.prototype.typed;
/** @type {?} */
SelectComponent.prototype.options;
/** @type {?} */
SelectComponent.prototype.itemObjects;
/** @type {?} */
SelectComponent.prototype.activeOption;
/** @type {?} */
SelectComponent.prototype.element;
/** @type {?} */
SelectComponent.prototype.inputMode;
/** @type {?} */
SelectComponent.prototype.optionsOpened;
/**
* @type {?}
* @private
*/
SelectComponent.prototype.behavior;
/** @type {?} */
SelectComponent.prototype.inputValue;
/**
* @type {?}
* @private
*/
SelectComponent.prototype._items;
/**
* @type {?}
* @private
*/
SelectComponent.prototype._disabled;
/**
* @type {?}
* @private
*/
SelectComponent.prototype._active;
/** @type {?} */
SelectComponent.prototype.propagateChange;
/**
* @type {?}
* @private
*/
SelectComponent.prototype.sanitizer;
/**
* @type {?}
* @private
*/
SelectComponent.prototype.messageEvent;
}
export class Behavior {
/**
* @param {?} actor
*/
constructor(actor) {
this.optionsMap = new Map();
this.actor = actor;
}
/**
* @return {?}
*/
fillOptionsMap() {
this.optionsMap.clear();
/** @type {?} */
let startPos = 0;
this.actor.itemObjects
.map((item) => {
startPos = item.fillChildrenHash(this.optionsMap, startPos);
});
}
/**
* @param {?=} optionsMap
* @return {?}
*/
ensureHighlightVisible(optionsMap = null) {
/** @type {?} */
const container = this.actor.element.nativeElement.querySelector('.ui-select-choices-content');
if (!container) {
return;
}
/** @type {?} */
const choices = container.querySelectorAll('.ui-select-choices-row');
if (choices.length < 1) {
return;
}
/** @type {?} */
const activeIndex = this.getActiveIndex(optionsMap);
if (activeIndex < 0) {
return;
}
/** @type {?} */
const highlighted = choices[activeIndex];
if (!highlighted) {
return;
}
/** @type {?} */
const posY = highlighted.offsetTop + highlighted.clientHeight - container.scrollTop;
/** @type {?} */
const height = container.offsetHeight;
if (posY > height) {
container.scrollTop += posY - height;
}
else if (posY < highlighted.clientHeight) {
container.scrollTop -= highlighted.clientHeight - posY;
}
}
/**
* @private
* @param {?=} optionsMap
* @return {?}
*/
getActiveIndex(optionsMap = null) {
/** @type {?} */
let ai = this.actor.options.indexOf(this.actor.activeOption);
if (ai < 0 && optionsMap !== null) {
/** @type {?} */
const a = optionsMap.get(this.actor.activeOption.id);
if (a) {
ai = a;
}
else {
ai = 0;
}
}
return ai;
}
}
if (false) {
/** @type {?} */
Behavior.prototype.optionsMap;
/** @type {?} */
Behavior.prototype.actor;
}
export class GenericBehavior extends Behavior {
/**
* @param {?} actor
*/
constructor(actor) {
super(actor);
}
/**
* @return {?}
*/
first() {
this.actor.activeOption = this.actor.options[0];
super.ensureHighlightVisible();
}
/**
* @return {?}
*/
last() {
this.actor.activeOption = this.actor.options[this.actor.options.length - 1];
super.ensureHighlightVisible();
}
/**
* @return {?}
*/
prev() {
/** @type {?} */
const index = this.actor.options.indexOf(this.actor.activeOption);
this.actor.activeOption = this.actor
.options[index - 1 < 0 ? this.actor.options.length - 1 : index - 1];
super.ensureHighlightVisible();
}
/**
* @return {?}
*/
next() {
/** @type {?} */
const index = this.actor.options.indexOf(this.actor.activeOption);
this.actor.activeOption = this.actor
.options[index + 1 > this.actor.options.length - 1 ? 0 : index + 1];
super.ensureHighlightVisible();
}
/**
* @param {?} query
* @return {?}
*/
filter(query) {
/** @type {?} */
const options = this.actor.itemObjects
.filter((option) => {
return stripTags(option.text).match(query) &&
(this.actor.multiple === false ||
(this.actor.multiple === true && this.actor.active.map((item) => item.id).indexOf(option.id) < 0));
});
this.actor.options = options;
if (this.actor.options.length > 0) {
this.actor.activeOption = this.actor.options[0];
super.ensureHighlightVisible();
}
}
}
export class ChildrenBehavior extends Behavior {
/**
* @param {?} actor
*/
constructor(actor) {
super(actor);
}
/**
* @return {?}
*/
first() {
this.actor.activeOption = this.actor.options[0].children[0];
this.fillOptionsMap();
this.ensureHighlightVisible(this.optionsMap);
}
/**
* @return {?}
*/
last() {
this.actor.activeOption =
this.actor
.options[this.actor.options.length - 1]
.children[this.actor.options[this.actor.options.length - 1].children.length - 1];
this.fillOptionsMap();
this.ensureHighlightVisible(this.optionsMap);
}
/**
* @return {?}
*/
prev() {
/** @type {?} */
const indexParent = this.actor.options
.findIndex((option) => this.actor.activeOption.parent && this.actor.activeOption.parent.id === option.id);
/** @type {?} */
const index = this.actor.options[indexParent].children
.findIndex((option) => this.actor.activeOption && this.actor.activeOption.id === option.id);
this.actor.activeOption = this.actor.options[indexParent].children[index - 1];
if (!this.actor.activeOption) {
if (this.actor.options[indexParent - 1]) {
this.actor.activeOption = this.actor
.options[indexParent - 1]
.children[this.actor.options[indexParent - 1].children.length - 1];
}
}
if (!this.actor.activeOption) {
this.last();
}
this.fillOptionsMap();
this.ensureHighlightVisible(this.optionsMap);
}
/**
* @return {?}
*/
next() {
/** @type {?} */
const indexParent = this.actor.options
.findIndex((option) => this.actor.activeOption.parent && this.actor.activeOption.parent.id === option.id);
/** @type {?} */
const index = this.actor.options[indexParent].children
.findIndex((option) => this.actor.activeOption && this.actor.activeOption.id === option.id);
this.actor.activeOption = this.actor.options[indexParent].children[index + 1];
if (!this.actor.activeOption) {
if (this.actor.options[indexParent + 1]) {
this.actor.activeOption = this.actor.options[indexParent + 1].children[0];
}
}
if (!this.actor.activeOption) {
this.first();
}
this.fillOptionsMap();
this.ensureHighlightVisible(this.optionsMap);
}
/**
* @param {?} query
* @return {?}
*/
filter(query) {
/** @type {?} */
const options = [];
/** @type {?} */
const optionsMap = new Map();
/** @type {?} */
let startPos = 0;
// tslint:disable-next-line:prefer-const
for (let si of this.actor.itemObjects) {
/** @type {?} */
const children = si.children.filter((option) => query.test(option.text));
startPos = si.fillChildrenHash(optionsMap, startPos);
if (children.length > 0) {
/** @type {?} */
const newSi = si.getSimilar();
newSi.children = children;
options.push(newSi);
}
}
this.actor.options = options;
if (this.actor.options.length > 0) {
this.actor.activeOption = this.actor.options[0].children[0];
super.ensureHighlightVisible(optionsMap);
}
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.js","sourceRoot":"ng://air-lib/","sources":["lib/components/ng2-select-custom/select/select.ts"],"names":[],"mappings":"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