autocomplete-entry
Advanced tools
Comparing version 0.0.1 to 1.0.1
(function (global, factory) { | ||
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core')) : | ||
typeof define === 'function' && define.amd ? define('autocomplete-entry', ['exports', '@angular/core'], factory) : | ||
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global["autocomplete-entry"] = {}, global.ng.core)); | ||
})(this, (function (exports, i0) { 'use strict'; | ||
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@angular/forms'), require('rxjs'), require('rxjs/operators'), require('@angular/material/form-field'), require('@angular/material/autocomplete'), require('@angular/material/core'), require('@angular/material/select'), require('@angular/common'), require('@angular/material/input')) : | ||
typeof define === 'function' && define.amd ? define('autocomplete-entry', ['exports', '@angular/core', '@angular/forms', 'rxjs', 'rxjs/operators', '@angular/material/form-field', '@angular/material/autocomplete', '@angular/material/core', '@angular/material/select', '@angular/common', '@angular/material/input'], factory) : | ||
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global["autocomplete-entry"] = {}, global.ng.core, global.ng.forms, global.rxjs, global.rxjs.operators, global.ng.material.formField, global.ng.material.autocomplete, global.ng.material.core, global.ng.material.select, global.ng.common, global.ng.material.input)); | ||
})(this, (function (exports, i0, i1, rxjs, operators, i2, i3, i4, i5, i6, i7) { 'use strict'; | ||
@@ -26,34 +26,108 @@ function _interopNamespace(e) { | ||
var i0__namespace = /*#__PURE__*/_interopNamespace(i0); | ||
var i1__namespace = /*#__PURE__*/_interopNamespace(i1); | ||
var i2__namespace = /*#__PURE__*/_interopNamespace(i2); | ||
var i3__namespace = /*#__PURE__*/_interopNamespace(i3); | ||
var i4__namespace = /*#__PURE__*/_interopNamespace(i4); | ||
var i5__namespace = /*#__PURE__*/_interopNamespace(i5); | ||
var i6__namespace = /*#__PURE__*/_interopNamespace(i6); | ||
var i7__namespace = /*#__PURE__*/_interopNamespace(i7); | ||
var AutocompleteEntryService = /** @class */ (function () { | ||
function AutocompleteEntryService() { | ||
} | ||
return AutocompleteEntryService; | ||
}()); | ||
AutocompleteEntryService.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0__namespace, type: AutocompleteEntryService, deps: [], target: i0__namespace.ɵɵFactoryTarget.Injectable }); | ||
AutocompleteEntryService.ɵprov = i0__namespace.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0__namespace, type: AutocompleteEntryService, providedIn: 'root' }); | ||
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0__namespace, type: AutocompleteEntryService, decorators: [{ | ||
type: i0.Injectable, | ||
args: [{ | ||
providedIn: 'root' | ||
}] | ||
}], ctorParameters: function () { return []; } }); | ||
var INPUT_VALUE_ACCESSOR = { | ||
provide: i1.NG_VALUE_ACCESSOR, | ||
useExisting: i0.forwardRef(function () { return AutocompleteEntryComponent; }), | ||
multi: true | ||
}; | ||
var AutocompleteEntryComponent = /** @class */ (function () { | ||
function AutocompleteEntryComponent() { | ||
function AutocompleteEntryComponent(fb) { | ||
this.fb = fb; | ||
this._data = rxjs.of([]); | ||
this._disabled = false; | ||
this.filteredOptions = rxjs.of([]); | ||
this.autocomplete = false; | ||
this.required = false; | ||
this.style = ''; | ||
this.placeholder = ''; | ||
this.label = ''; | ||
this.selectedItem = this.fb.control([null]); | ||
this.onChange = function (_) { }; | ||
this.onTouched = function () { }; | ||
} | ||
Object.defineProperty(AutocompleteEntryComponent.prototype, "data", { | ||
get: function () { | ||
return this._data; | ||
}, | ||
set: function (value) { | ||
this._data = (rxjs.isObservable(value)) ? value : rxjs.of(value); | ||
}, | ||
enumerable: false, | ||
configurable: true | ||
}); | ||
Object.defineProperty(AutocompleteEntryComponent.prototype, "disabled", { | ||
get: function () { | ||
return this._disabled; | ||
}, | ||
set: function (value) { | ||
this._disabled = value; | ||
}, | ||
enumerable: false, | ||
configurable: true | ||
}); | ||
AutocompleteEntryComponent.prototype.ngOnInit = function () { | ||
var _this = this; | ||
if (this.required) | ||
this.selectedItem.setValidators(i1.Validators.required); | ||
this.filteredOptions = this.selectedItem.valueChanges.pipe(operators.startWith(''), operators.mergeMap(function (findItem) { return _this.data.pipe(operators.map(function (items) { return items.filter(function (item) { | ||
return (item === null || item === void 0 ? void 0 : item.toLowerCase().includes(findItem === null || findItem === void 0 ? void 0 : findItem.toLowerCase())); | ||
}); })); })); | ||
}; | ||
AutocompleteEntryComponent.prototype.writeValue = function (value) { | ||
this.selectedItem.patchValue(value); | ||
}; | ||
AutocompleteEntryComponent.prototype.registerOnChange = function (fn) { | ||
this.onChange = fn; | ||
}; | ||
AutocompleteEntryComponent.prototype.registerOnTouched = function (fn) { | ||
this.onTouched = fn; | ||
}; | ||
AutocompleteEntryComponent.prototype.setDisabledState = function (isDisabled) { | ||
this.disabled = isDisabled; | ||
}; | ||
AutocompleteEntryComponent.prototype.onEnter = function (value) { | ||
this.onChange(value); | ||
}; | ||
AutocompleteEntryComponent.prototype.onSelected = function (option) { | ||
this.onChange(option.source.value); | ||
}; | ||
AutocompleteEntryComponent.prototype.onBlur = function (value) { | ||
this.onChange(value); | ||
}; | ||
return AutocompleteEntryComponent; | ||
}()); | ||
AutocompleteEntryComponent.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0__namespace, type: AutocompleteEntryComponent, deps: [], target: i0__namespace.ɵɵFactoryTarget.Component }); | ||
AutocompleteEntryComponent.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: AutocompleteEntryComponent, selector: "lib-autocomplete-entry", ngImport: i0__namespace, template: "\n <p>\n autocomplete-entry works!\n </p>\n ", isInline: true }); | ||
AutocompleteEntryComponent.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0__namespace, type: AutocompleteEntryComponent, deps: [{ token: i1__namespace.FormBuilder }], target: i0__namespace.ɵɵFactoryTarget.Component }); | ||
AutocompleteEntryComponent.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: AutocompleteEntryComponent, selector: "wav-autocomplete-entry", inputs: { data: "data", disabled: "disabled", autocomplete: "autocomplete", required: "required", appearance: "appearance", style: "style", placeholder: "placeholder", label: "label" }, providers: [INPUT_VALUE_ACCESSOR], ngImport: i0__namespace, template: "\n<div *ngIf=\"autocomplete\">\n <mat-form-field [appearance]=\"appearance\" [style]=\"style\">\n\n <mat-label *ngIf=\"label\">{{ label }}</mat-label>\n\n <input type=\"text\"\n matInput\n #inputData\n [placeholder]=\"placeholder\"\n [formControl]=\"selectedItem\"\n [matAutocomplete]=\"auto\"\n (keyup.enter)=\"onEnter(inputData.value)\"\n (blur)=\"onBlur(inputData.value)\"\n >\n <mat-autocomplete autoActiveFirstOption #auto=\"matAutocomplete\"\n >\n <mat-option\n *ngFor=\"let item of (filteredOptions | async)\"\n [value]=\"item\"\n (onSelectionChange)=\"onSelected($event)\"\n >\n {{item}}\n </mat-option>\n\n </mat-autocomplete>\n\n </mat-form-field>\n</div>\n\n<div *ngIf=\"!autocomplete\">\n\n <mat-form-field [appearance]=\"appearance\" [style]=\"style\">\n\n <mat-label *ngIf=\"label\">{{ label }}</mat-label>\n\n <mat-select>\n <mat-option\n *ngFor=\"let item of (filteredOptions | async)\"\n [value]=\"item\"\n (onSelectionChange)=\"onSelected($event)\"\n >\n {{item}}\n </mat-option>\n </mat-select>\n\n </mat-form-field>\n\n</div>\n", styles: [""], components: [{ type: i2__namespace.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i3__namespace.MatAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple"], exportAs: ["matAutocomplete"] }, { type: i4__namespace.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { type: i5__namespace.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }], directives: [{ type: i6__namespace.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2__namespace.MatLabel, selector: "mat-label" }, { type: i7__namespace.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i1__namespace.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i3__namespace.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { type: i1__namespace.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1__namespace.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i6__namespace.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "async": i6__namespace.AsyncPipe } }); | ||
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0__namespace, type: AutocompleteEntryComponent, decorators: [{ | ||
type: i0.Component, | ||
args: [{ | ||
selector: 'lib-autocomplete-entry', | ||
template: "\n <p>\n autocomplete-entry works!\n </p>\n ", | ||
styles: [] | ||
selector: 'wav-autocomplete-entry', | ||
templateUrl: './autocomplete-entry.component.html', | ||
styleUrls: ['./autocomplete-entry.component.scss'], | ||
providers: [INPUT_VALUE_ACCESSOR] | ||
}] | ||
}], ctorParameters: function () { return []; } }); | ||
}], ctorParameters: function () { return [{ type: i1__namespace.FormBuilder }]; }, propDecorators: { data: [{ | ||
type: i0.Input | ||
}], disabled: [{ | ||
type: i0.Input | ||
}], autocomplete: [{ | ||
type: i0.Input | ||
}], required: [{ | ||
type: i0.Input | ||
}], appearance: [{ | ||
type: i0.Input | ||
}], style: [{ | ||
type: i0.Input | ||
}], placeholder: [{ | ||
type: i0.Input | ||
}], label: [{ | ||
type: i0.Input | ||
}] } }); | ||
@@ -66,4 +140,16 @@ var AutocompleteEntryModule = /** @class */ (function () { | ||
AutocompleteEntryModule.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0__namespace, type: AutocompleteEntryModule, deps: [], target: i0__namespace.ɵɵFactoryTarget.NgModule }); | ||
AutocompleteEntryModule.ɵmod = i0__namespace.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0__namespace, type: AutocompleteEntryModule, declarations: [AutocompleteEntryComponent], exports: [AutocompleteEntryComponent] }); | ||
AutocompleteEntryModule.ɵinj = i0__namespace.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0__namespace, type: AutocompleteEntryModule, imports: [[]] }); | ||
AutocompleteEntryModule.ɵmod = i0__namespace.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0__namespace, type: AutocompleteEntryModule, declarations: [AutocompleteEntryComponent], imports: [i6.CommonModule, | ||
i2.MatFormFieldModule, | ||
i7.MatInputModule, | ||
i3.MatAutocompleteModule, | ||
i1.ReactiveFormsModule, | ||
i5.MatSelectModule], exports: [AutocompleteEntryComponent] }); | ||
AutocompleteEntryModule.ɵinj = i0__namespace.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0__namespace, type: AutocompleteEntryModule, imports: [[ | ||
i6.CommonModule, | ||
i2.MatFormFieldModule, | ||
i7.MatInputModule, | ||
i3.MatAutocompleteModule, | ||
i1.ReactiveFormsModule, | ||
i5.MatSelectModule, | ||
]] }); | ||
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0__namespace, type: AutocompleteEntryModule, decorators: [{ | ||
@@ -75,3 +161,10 @@ type: i0.NgModule, | ||
], | ||
imports: [], | ||
imports: [ | ||
i6.CommonModule, | ||
i2.MatFormFieldModule, | ||
i7.MatInputModule, | ||
i3.MatAutocompleteModule, | ||
i1.ReactiveFormsModule, | ||
i5.MatSelectModule, | ||
], | ||
exports: [ | ||
@@ -93,3 +186,3 @@ AutocompleteEntryComponent | ||
exports.AutocompleteEntryModule = AutocompleteEntryModule; | ||
exports.AutocompleteEntryService = AutocompleteEntryService; | ||
exports.INPUT_VALUE_ACCESSOR = INPUT_VALUE_ACCESSOR; | ||
@@ -96,0 +189,0 @@ Object.defineProperty(exports, '__esModule', { value: true }); |
@@ -1,26 +0,101 @@ | ||
import { Component } from '@angular/core'; | ||
import { Component, forwardRef, Input } from '@angular/core'; | ||
import { NG_VALUE_ACCESSOR, Validators } from '@angular/forms'; | ||
import { isObservable, of } from 'rxjs'; | ||
import { map, mergeMap, startWith } from 'rxjs/operators'; | ||
import * as i0 from "@angular/core"; | ||
import * as i1 from "@angular/forms"; | ||
import * as i2 from "@angular/material/form-field"; | ||
import * as i3 from "@angular/material/autocomplete"; | ||
import * as i4 from "@angular/material/core"; | ||
import * as i5 from "@angular/material/select"; | ||
import * as i6 from "@angular/common"; | ||
import * as i7 from "@angular/material/input"; | ||
export const INPUT_VALUE_ACCESSOR = { | ||
provide: NG_VALUE_ACCESSOR, | ||
useExisting: forwardRef(() => AutocompleteEntryComponent), | ||
multi: true | ||
}; | ||
export class AutocompleteEntryComponent { | ||
constructor() { } | ||
constructor(fb) { | ||
this.fb = fb; | ||
this._data = of([]); | ||
this._disabled = false; | ||
this.filteredOptions = of([]); | ||
this.autocomplete = false; | ||
this.required = false; | ||
this.style = ''; | ||
this.placeholder = ''; | ||
this.label = ''; | ||
this.selectedItem = this.fb.control([null]); | ||
this.onChange = (_) => { }; | ||
this.onTouched = () => { }; | ||
} | ||
set data(value) { | ||
this._data = (isObservable(value)) ? value : of(value); | ||
} | ||
get data() { | ||
return this._data; | ||
} | ||
set disabled(value) { | ||
this._disabled = value; | ||
} | ||
get disabled() { | ||
return this._disabled; | ||
} | ||
ngOnInit() { | ||
if (this.required) | ||
this.selectedItem.setValidators(Validators.required); | ||
this.filteredOptions = this.selectedItem.valueChanges.pipe(startWith(''), mergeMap(findItem => this.data.pipe(map(items => items.filter(item => { | ||
return (item === null || item === void 0 ? void 0 : item.toLowerCase().includes(findItem === null || findItem === void 0 ? void 0 : findItem.toLowerCase())); | ||
}))))); | ||
} | ||
writeValue(value) { | ||
this.selectedItem.patchValue(value); | ||
} | ||
registerOnChange(fn) { | ||
this.onChange = fn; | ||
} | ||
registerOnTouched(fn) { | ||
this.onTouched = fn; | ||
} | ||
setDisabledState(isDisabled) { | ||
this.disabled = isDisabled; | ||
} | ||
onEnter(value) { | ||
this.onChange(value); | ||
} | ||
onSelected(option) { | ||
this.onChange(option.source.value); | ||
} | ||
onBlur(value) { | ||
this.onChange(value); | ||
} | ||
} | ||
AutocompleteEntryComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: AutocompleteEntryComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); | ||
AutocompleteEntryComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: AutocompleteEntryComponent, selector: "lib-autocomplete-entry", ngImport: i0, template: ` | ||
<p> | ||
autocomplete-entry works! | ||
</p> | ||
`, isInline: true }); | ||
AutocompleteEntryComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: AutocompleteEntryComponent, deps: [{ token: i1.FormBuilder }], target: i0.ɵɵFactoryTarget.Component }); | ||
AutocompleteEntryComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: AutocompleteEntryComponent, selector: "wav-autocomplete-entry", inputs: { data: "data", disabled: "disabled", autocomplete: "autocomplete", required: "required", appearance: "appearance", style: "style", placeholder: "placeholder", label: "label" }, providers: [INPUT_VALUE_ACCESSOR], ngImport: i0, template: "\n<div *ngIf=\"autocomplete\">\n <mat-form-field [appearance]=\"appearance\" [style]=\"style\">\n\n <mat-label *ngIf=\"label\">{{ label }}</mat-label>\n\n <input type=\"text\"\n matInput\n #inputData\n [placeholder]=\"placeholder\"\n [formControl]=\"selectedItem\"\n [matAutocomplete]=\"auto\"\n (keyup.enter)=\"onEnter(inputData.value)\"\n (blur)=\"onBlur(inputData.value)\"\n >\n <mat-autocomplete autoActiveFirstOption #auto=\"matAutocomplete\"\n >\n <mat-option\n *ngFor=\"let item of (filteredOptions | async)\"\n [value]=\"item\"\n (onSelectionChange)=\"onSelected($event)\"\n >\n {{item}}\n </mat-option>\n\n </mat-autocomplete>\n\n </mat-form-field>\n</div>\n\n<div *ngIf=\"!autocomplete\">\n\n <mat-form-field [appearance]=\"appearance\" [style]=\"style\">\n\n <mat-label *ngIf=\"label\">{{ label }}</mat-label>\n\n <mat-select>\n <mat-option\n *ngFor=\"let item of (filteredOptions | async)\"\n [value]=\"item\"\n (onSelectionChange)=\"onSelected($event)\"\n >\n {{item}}\n </mat-option>\n </mat-select>\n\n </mat-form-field>\n\n</div>\n", styles: [""], components: [{ type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i3.MatAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple"], exportAs: ["matAutocomplete"] }, { type: i4.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { type: i5.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatLabel, selector: "mat-label" }, { type: i7.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i3.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "async": i6.AsyncPipe } }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: AutocompleteEntryComponent, decorators: [{ | ||
type: Component, | ||
args: [{ | ||
selector: 'lib-autocomplete-entry', | ||
template: ` | ||
<p> | ||
autocomplete-entry works! | ||
</p> | ||
`, | ||
styles: [] | ||
selector: 'wav-autocomplete-entry', | ||
templateUrl: './autocomplete-entry.component.html', | ||
styleUrls: ['./autocomplete-entry.component.scss'], | ||
providers: [INPUT_VALUE_ACCESSOR] | ||
}] | ||
}], ctorParameters: function () { return []; } }); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b2NvbXBsZXRlLWVudHJ5LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2F1dG9jb21wbGV0ZS1lbnRyeS9zcmMvbGliL2F1dG9jb21wbGV0ZS1lbnRyeS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQzs7QUFZbEQsTUFBTSxPQUFPLDBCQUEwQjtJQUVyQyxnQkFBZ0IsQ0FBQztJQUVqQixRQUFRO0lBQ1IsQ0FBQzs7d0hBTFUsMEJBQTBCOzRHQUExQiwwQkFBMEIsOERBUjNCOzs7O0dBSVQ7NEZBSVUsMEJBQTBCO2tCQVZ0QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSx3QkFBd0I7b0JBQ2xDLFFBQVEsRUFBRTs7OztHQUlUO29CQUNELE1BQU0sRUFBRSxFQUNQO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbGliLWF1dG9jb21wbGV0ZS1lbnRyeScsXG4gIHRlbXBsYXRlOiBgXG4gICAgPHA+XG4gICAgICBhdXRvY29tcGxldGUtZW50cnkgd29ya3MhXG4gICAgPC9wPlxuICBgLFxuICBzdHlsZXM6IFtcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBBdXRvY29tcGxldGVFbnRyeUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgY29uc3RydWN0b3IoKSB7IH1cblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgfVxuXG59XG4iXX0= | ||
}], ctorParameters: function () { return [{ type: i1.FormBuilder }]; }, propDecorators: { data: [{ | ||
type: Input | ||
}], disabled: [{ | ||
type: Input | ||
}], autocomplete: [{ | ||
type: Input | ||
}], required: [{ | ||
type: Input | ||
}], appearance: [{ | ||
type: Input | ||
}], style: [{ | ||
type: Input | ||
}], placeholder: [{ | ||
type: Input | ||
}], label: [{ | ||
type: Input | ||
}] } }); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete-entry.component.js","sourceRoot":"","sources":["../../../../projects/autocomplete-entry/src/lib/autocomplete-entry.component.ts","../../../../projects/autocomplete-entry/src/lib/autocomplete-entry.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, Input, OnInit, ViewChild } from '@angular/core';\nimport { FormBuilder, NG_VALUE_ACCESSOR, Validators } from '@angular/forms';\nimport { MatOptionSelectionChange } from '@angular/material/core';\nimport { isObservable, Observable, of } from 'rxjs';\nimport { map, mergeMap, startWith } from 'rxjs/operators';\n\nexport const INPUT_VALUE_ACCESSOR: any = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => AutocompleteEntryComponent),\n  multi: true\n}\n\n@Component({\n  selector: 'wav-autocomplete-entry',\n  templateUrl: './autocomplete-entry.component.html',\n  styleUrls: ['./autocomplete-entry.component.scss'],\n  providers: [INPUT_VALUE_ACCESSOR]\n})\nexport class AutocompleteEntryComponent implements OnInit {\n\n  _data: Observable<any[]> = of([])\n  @Input() set data(value: any[] | Observable<any[]>) {\n    this._data = (isObservable(value)) ? value : of(value)\n  }\n\n  get data(): Observable<any[]> {\n    return this._data\n  }\n\n  _disabled = false\n  @Input() set disabled(value: boolean) {\n    this._disabled = value\n  }\n\n  get disabled() {\n    return this._disabled\n  }\n\n  filteredOptions: Observable<any[]> = of([])\n\n  @Input() autocomplete = false\n  @Input() required = false\n  @Input() appearance: any\n  @Input() style = ''\n  @Input() placeholder = ''\n  @Input() label = ''\n\n  selectedItem = this.fb.control([null])\n\n  private onChange: Function\n  private onTouched: Function\n\n  constructor(\n    private fb: FormBuilder,\n  ) {\n    this.onChange = (_: any) => {}\n    this.onTouched = () => {}\n  }\n\n  ngOnInit() {\n\n    if(this.required) this.selectedItem.setValidators(Validators.required)\n\n    this.filteredOptions = this.selectedItem.valueChanges.pipe(\n      startWith(''),\n      mergeMap(findItem => this.data.pipe(\n        map(items => items.filter(item => {\n          return (item?.toLowerCase().includes(findItem?.toLowerCase()))\n        })),\n      )),\n    )\n\n  }\n\n  writeValue(value: any) {\n    this.selectedItem.patchValue(value)\n  }\n  registerOnChange(fn: (_: any) => void) {\n    this.onChange = fn\n  }\n\n  registerOnTouched(fn: () => void) {\n    this.onTouched = fn\n  }\n\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled\n  }\n\n  onEnter(value: string) {\n    this.onChange(value)\n  }\n\n  onSelected(option: MatOptionSelectionChange) {\n    this.onChange(option.source.value)\n  }\n\n  onBlur(value: string) {\n    this.onChange(value)\n  }\n\n}\n","\n<div *ngIf=\"autocomplete\">\n  <mat-form-field [appearance]=\"appearance\" [style]=\"style\">\n\n    <mat-label *ngIf=\"label\">{{ label }}</mat-label>\n\n    <input type=\"text\"\n      matInput\n      #inputData\n      [placeholder]=\"placeholder\"\n      [formControl]=\"selectedItem\"\n      [matAutocomplete]=\"auto\"\n      (keyup.enter)=\"onEnter(inputData.value)\"\n      (blur)=\"onBlur(inputData.value)\"\n    >\n    <mat-autocomplete autoActiveFirstOption #auto=\"matAutocomplete\"\n    >\n      <mat-option\n        *ngFor=\"let item of (filteredOptions | async)\"\n        [value]=\"item\"\n        (onSelectionChange)=\"onSelected($event)\"\n      >\n        {{item}}\n      </mat-option>\n\n    </mat-autocomplete>\n\n  </mat-form-field>\n</div>\n\n<div *ngIf=\"!autocomplete\">\n\n  <mat-form-field [appearance]=\"appearance\" [style]=\"style\">\n\n    <mat-label *ngIf=\"label\">{{ label }}</mat-label>\n\n    <mat-select>\n      <mat-option\n        *ngFor=\"let item of (filteredOptions | async)\"\n        [value]=\"item\"\n        (onSelectionChange)=\"onSelected($event)\"\n      >\n        {{item}}\n      </mat-option>\n    </mat-select>\n\n  </mat-form-field>\n\n</div>\n"]} |
import { NgModule } from '@angular/core'; | ||
import { CommonModule } from '@angular/common'; | ||
import { ReactiveFormsModule } from '@angular/forms'; | ||
import { MatFormFieldModule } from '@angular/material/form-field'; | ||
import { MatInputModule } from '@angular/material/input'; | ||
import { MatAutocompleteModule } from '@angular/material/autocomplete'; | ||
import { MatSelectModule } from '@angular/material/select'; | ||
import { AutocompleteEntryComponent } from './autocomplete-entry.component'; | ||
@@ -7,4 +13,16 @@ import * as i0 from "@angular/core"; | ||
AutocompleteEntryModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: AutocompleteEntryModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); | ||
AutocompleteEntryModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: AutocompleteEntryModule, declarations: [AutocompleteEntryComponent], exports: [AutocompleteEntryComponent] }); | ||
AutocompleteEntryModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: AutocompleteEntryModule, imports: [[]] }); | ||
AutocompleteEntryModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: AutocompleteEntryModule, declarations: [AutocompleteEntryComponent], imports: [CommonModule, | ||
MatFormFieldModule, | ||
MatInputModule, | ||
MatAutocompleteModule, | ||
ReactiveFormsModule, | ||
MatSelectModule], exports: [AutocompleteEntryComponent] }); | ||
AutocompleteEntryModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: AutocompleteEntryModule, imports: [[ | ||
CommonModule, | ||
MatFormFieldModule, | ||
MatInputModule, | ||
MatAutocompleteModule, | ||
ReactiveFormsModule, | ||
MatSelectModule, | ||
]] }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: AutocompleteEntryModule, decorators: [{ | ||
@@ -16,3 +34,10 @@ type: NgModule, | ||
], | ||
imports: [], | ||
imports: [ | ||
CommonModule, | ||
MatFormFieldModule, | ||
MatInputModule, | ||
MatAutocompleteModule, | ||
ReactiveFormsModule, | ||
MatSelectModule, | ||
], | ||
exports: [ | ||
@@ -23,2 +48,2 @@ AutocompleteEntryComponent | ||
}] }); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b2NvbXBsZXRlLWVudHJ5Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2F1dG9jb21wbGV0ZS1lbnRyeS9zcmMvbGliL2F1dG9jb21wbGV0ZS1lbnRyeS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQzs7QUFjNUUsTUFBTSxPQUFPLHVCQUF1Qjs7cUhBQXZCLHVCQUF1QjtzSEFBdkIsdUJBQXVCLGlCQVJoQywwQkFBMEIsYUFLMUIsMEJBQTBCO3NIQUdqQix1QkFBdUIsWUFOekIsRUFDUjs0RkFLVSx1QkFBdUI7a0JBVm5DLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLDBCQUEwQjtxQkFDM0I7b0JBQ0QsT0FBTyxFQUFFLEVBQ1I7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLDBCQUEwQjtxQkFDM0I7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQXV0b2NvbXBsZXRlRW50cnlDb21wb25lbnQgfSBmcm9tICcuL2F1dG9jb21wbGV0ZS1lbnRyeS5jb21wb25lbnQnO1xuXG5cblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgQXV0b2NvbXBsZXRlRW50cnlDb21wb25lbnRcbiAgXSxcbiAgaW1wb3J0czogW1xuICBdLFxuICBleHBvcnRzOiBbXG4gICAgQXV0b2NvbXBsZXRlRW50cnlDb21wb25lbnRcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBBdXRvY29tcGxldGVFbnRyeU1vZHVsZSB7IH1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b2NvbXBsZXRlLWVudHJ5Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2F1dG9jb21wbGV0ZS1lbnRyeS9zcmMvbGliL2F1dG9jb21wbGV0ZS1lbnRyeS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFL0MsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDckQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUUzRCxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQzs7QUFtQjVFLE1BQU0sT0FBTyx1QkFBdUI7O3FIQUF2Qix1QkFBdUI7c0hBQXZCLHVCQUF1QixpQkFkaEMsMEJBQTBCLGFBRzFCLFlBQVk7UUFDWixrQkFBa0I7UUFDbEIsY0FBYztRQUNkLHFCQUFxQjtRQUNyQixtQkFBbUI7UUFDbkIsZUFBZSxhQUdmLDBCQUEwQjtzSEFHakIsdUJBQXVCLFlBWnpCO1lBQ1AsWUFBWTtZQUNaLGtCQUFrQjtZQUNsQixjQUFjO1lBQ2QscUJBQXFCO1lBQ3JCLG1CQUFtQjtZQUNuQixlQUFlO1NBQ2hCOzRGQUtVLHVCQUF1QjtrQkFoQm5DLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLDBCQUEwQjtxQkFDM0I7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osa0JBQWtCO3dCQUNsQixjQUFjO3dCQUNkLHFCQUFxQjt3QkFDckIsbUJBQW1CO3dCQUNuQixlQUFlO3FCQUNoQjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsMEJBQTBCO3FCQUMzQjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbIlxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbmltcG9ydCB7IFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBNYXRGb3JtRmllbGRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9mb3JtLWZpZWxkJztcbmltcG9ydCB7IE1hdElucHV0TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaW5wdXQnO1xuaW1wb3J0IHsgTWF0QXV0b2NvbXBsZXRlTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYXV0b2NvbXBsZXRlJztcbmltcG9ydCB7IE1hdFNlbGVjdE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3NlbGVjdCc7XG5cbmltcG9ydCB7IEF1dG9jb21wbGV0ZUVudHJ5Q29tcG9uZW50IH0gZnJvbSAnLi9hdXRvY29tcGxldGUtZW50cnkuY29tcG9uZW50JztcblxuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBBdXRvY29tcGxldGVFbnRyeUNvbXBvbmVudFxuICBdLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIE1hdEZvcm1GaWVsZE1vZHVsZSxcbiAgICBNYXRJbnB1dE1vZHVsZSxcbiAgICBNYXRBdXRvY29tcGxldGVNb2R1bGUsXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcbiAgICBNYXRTZWxlY3RNb2R1bGUsXG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICBBdXRvY29tcGxldGVFbnRyeUNvbXBvbmVudFxuICBdXG59KVxuZXhwb3J0IGNsYXNzIEF1dG9jb21wbGV0ZUVudHJ5TW9kdWxlIHsgfVxuIl19 |
/* | ||
* Public API Surface of autocomplete-entry | ||
*/ | ||
export * from './lib/autocomplete-entry.service'; | ||
export * from './lib/autocomplete-entry.component'; | ||
export * from './lib/autocomplete-entry.module'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2F1dG9jb21wbGV0ZS1lbnRyeS9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsa0NBQWtDLENBQUM7QUFDakQsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLGlDQUFpQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBhdXRvY29tcGxldGUtZW50cnlcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9hdXRvY29tcGxldGUtZW50cnkuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hdXRvY29tcGxldGUtZW50cnkuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2F1dG9jb21wbGV0ZS1lbnRyeS5tb2R1bGUnO1xuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2F1dG9jb21wbGV0ZS1lbnRyeS9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsb0NBQW9DLENBQUM7QUFDbkQsY0FBYyxpQ0FBaUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgYXV0b2NvbXBsZXRlLWVudHJ5XG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9saWIvYXV0b2NvbXBsZXRlLWVudHJ5LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hdXRvY29tcGxldGUtZW50cnkubW9kdWxlJztcbiJdfQ== |
import * as i0 from '@angular/core'; | ||
import { Injectable, Component, NgModule } from '@angular/core'; | ||
import { forwardRef, Component, Input, NgModule } from '@angular/core'; | ||
import * as i1 from '@angular/forms'; | ||
import { NG_VALUE_ACCESSOR, Validators, ReactiveFormsModule } from '@angular/forms'; | ||
import { of, isObservable } from 'rxjs'; | ||
import { startWith, mergeMap, map } from 'rxjs/operators'; | ||
import * as i2 from '@angular/material/form-field'; | ||
import { MatFormFieldModule } from '@angular/material/form-field'; | ||
import * as i3 from '@angular/material/autocomplete'; | ||
import { MatAutocompleteModule } from '@angular/material/autocomplete'; | ||
import * as i4 from '@angular/material/core'; | ||
import * as i5 from '@angular/material/select'; | ||
import { MatSelectModule } from '@angular/material/select'; | ||
import * as i6 from '@angular/common'; | ||
import { CommonModule } from '@angular/common'; | ||
import * as i7 from '@angular/material/input'; | ||
import { MatInputModule } from '@angular/material/input'; | ||
class AutocompleteEntryService { | ||
constructor() { } | ||
} | ||
AutocompleteEntryService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: AutocompleteEntryService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); | ||
AutocompleteEntryService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: AutocompleteEntryService, providedIn: 'root' }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: AutocompleteEntryService, decorators: [{ | ||
type: Injectable, | ||
args: [{ | ||
providedIn: 'root' | ||
}] | ||
}], ctorParameters: function () { return []; } }); | ||
const INPUT_VALUE_ACCESSOR = { | ||
provide: NG_VALUE_ACCESSOR, | ||
useExisting: forwardRef(() => AutocompleteEntryComponent), | ||
multi: true | ||
}; | ||
class AutocompleteEntryComponent { | ||
constructor() { } | ||
constructor(fb) { | ||
this.fb = fb; | ||
this._data = of([]); | ||
this._disabled = false; | ||
this.filteredOptions = of([]); | ||
this.autocomplete = false; | ||
this.required = false; | ||
this.style = ''; | ||
this.placeholder = ''; | ||
this.label = ''; | ||
this.selectedItem = this.fb.control([null]); | ||
this.onChange = (_) => { }; | ||
this.onTouched = () => { }; | ||
} | ||
set data(value) { | ||
this._data = (isObservable(value)) ? value : of(value); | ||
} | ||
get data() { | ||
return this._data; | ||
} | ||
set disabled(value) { | ||
this._disabled = value; | ||
} | ||
get disabled() { | ||
return this._disabled; | ||
} | ||
ngOnInit() { | ||
if (this.required) | ||
this.selectedItem.setValidators(Validators.required); | ||
this.filteredOptions = this.selectedItem.valueChanges.pipe(startWith(''), mergeMap(findItem => this.data.pipe(map(items => items.filter(item => { | ||
return (item === null || item === void 0 ? void 0 : item.toLowerCase().includes(findItem === null || findItem === void 0 ? void 0 : findItem.toLowerCase())); | ||
}))))); | ||
} | ||
writeValue(value) { | ||
this.selectedItem.patchValue(value); | ||
} | ||
registerOnChange(fn) { | ||
this.onChange = fn; | ||
} | ||
registerOnTouched(fn) { | ||
this.onTouched = fn; | ||
} | ||
setDisabledState(isDisabled) { | ||
this.disabled = isDisabled; | ||
} | ||
onEnter(value) { | ||
this.onChange(value); | ||
} | ||
onSelected(option) { | ||
this.onChange(option.source.value); | ||
} | ||
onBlur(value) { | ||
this.onChange(value); | ||
} | ||
} | ||
AutocompleteEntryComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: AutocompleteEntryComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); | ||
AutocompleteEntryComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: AutocompleteEntryComponent, selector: "lib-autocomplete-entry", ngImport: i0, template: ` | ||
<p> | ||
autocomplete-entry works! | ||
</p> | ||
`, isInline: true }); | ||
AutocompleteEntryComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: AutocompleteEntryComponent, deps: [{ token: i1.FormBuilder }], target: i0.ɵɵFactoryTarget.Component }); | ||
AutocompleteEntryComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: AutocompleteEntryComponent, selector: "wav-autocomplete-entry", inputs: { data: "data", disabled: "disabled", autocomplete: "autocomplete", required: "required", appearance: "appearance", style: "style", placeholder: "placeholder", label: "label" }, providers: [INPUT_VALUE_ACCESSOR], ngImport: i0, template: "\n<div *ngIf=\"autocomplete\">\n <mat-form-field [appearance]=\"appearance\" [style]=\"style\">\n\n <mat-label *ngIf=\"label\">{{ label }}</mat-label>\n\n <input type=\"text\"\n matInput\n #inputData\n [placeholder]=\"placeholder\"\n [formControl]=\"selectedItem\"\n [matAutocomplete]=\"auto\"\n (keyup.enter)=\"onEnter(inputData.value)\"\n (blur)=\"onBlur(inputData.value)\"\n >\n <mat-autocomplete autoActiveFirstOption #auto=\"matAutocomplete\"\n >\n <mat-option\n *ngFor=\"let item of (filteredOptions | async)\"\n [value]=\"item\"\n (onSelectionChange)=\"onSelected($event)\"\n >\n {{item}}\n </mat-option>\n\n </mat-autocomplete>\n\n </mat-form-field>\n</div>\n\n<div *ngIf=\"!autocomplete\">\n\n <mat-form-field [appearance]=\"appearance\" [style]=\"style\">\n\n <mat-label *ngIf=\"label\">{{ label }}</mat-label>\n\n <mat-select>\n <mat-option\n *ngFor=\"let item of (filteredOptions | async)\"\n [value]=\"item\"\n (onSelectionChange)=\"onSelected($event)\"\n >\n {{item}}\n </mat-option>\n </mat-select>\n\n </mat-form-field>\n\n</div>\n", styles: [""], components: [{ type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i3.MatAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple"], exportAs: ["matAutocomplete"] }, { type: i4.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { type: i5.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatLabel, selector: "mat-label" }, { type: i7.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i3.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "async": i6.AsyncPipe } }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: AutocompleteEntryComponent, decorators: [{ | ||
type: Component, | ||
args: [{ | ||
selector: 'lib-autocomplete-entry', | ||
template: ` | ||
<p> | ||
autocomplete-entry works! | ||
</p> | ||
`, | ||
styles: [] | ||
selector: 'wav-autocomplete-entry', | ||
templateUrl: './autocomplete-entry.component.html', | ||
styleUrls: ['./autocomplete-entry.component.scss'], | ||
providers: [INPUT_VALUE_ACCESSOR] | ||
}] | ||
}], ctorParameters: function () { return []; } }); | ||
}], ctorParameters: function () { return [{ type: i1.FormBuilder }]; }, propDecorators: { data: [{ | ||
type: Input | ||
}], disabled: [{ | ||
type: Input | ||
}], autocomplete: [{ | ||
type: Input | ||
}], required: [{ | ||
type: Input | ||
}], appearance: [{ | ||
type: Input | ||
}], style: [{ | ||
type: Input | ||
}], placeholder: [{ | ||
type: Input | ||
}], label: [{ | ||
type: Input | ||
}] } }); | ||
@@ -43,4 +111,16 @@ class AutocompleteEntryModule { | ||
AutocompleteEntryModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: AutocompleteEntryModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); | ||
AutocompleteEntryModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: AutocompleteEntryModule, declarations: [AutocompleteEntryComponent], exports: [AutocompleteEntryComponent] }); | ||
AutocompleteEntryModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: AutocompleteEntryModule, imports: [[]] }); | ||
AutocompleteEntryModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: AutocompleteEntryModule, declarations: [AutocompleteEntryComponent], imports: [CommonModule, | ||
MatFormFieldModule, | ||
MatInputModule, | ||
MatAutocompleteModule, | ||
ReactiveFormsModule, | ||
MatSelectModule], exports: [AutocompleteEntryComponent] }); | ||
AutocompleteEntryModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: AutocompleteEntryModule, imports: [[ | ||
CommonModule, | ||
MatFormFieldModule, | ||
MatInputModule, | ||
MatAutocompleteModule, | ||
ReactiveFormsModule, | ||
MatSelectModule, | ||
]] }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: AutocompleteEntryModule, decorators: [{ | ||
@@ -52,3 +132,10 @@ type: NgModule, | ||
], | ||
imports: [], | ||
imports: [ | ||
CommonModule, | ||
MatFormFieldModule, | ||
MatInputModule, | ||
MatAutocompleteModule, | ||
ReactiveFormsModule, | ||
MatSelectModule, | ||
], | ||
exports: [ | ||
@@ -68,3 +155,3 @@ AutocompleteEntryComponent | ||
export { AutocompleteEntryComponent, AutocompleteEntryModule, AutocompleteEntryService }; | ||
export { AutocompleteEntryComponent, AutocompleteEntryModule, INPUT_VALUE_ACCESSOR }; | ||
//# sourceMappingURL=autocomplete-entry.js.map |
import { OnInit } from '@angular/core'; | ||
import { FormBuilder } from '@angular/forms'; | ||
import { MatOptionSelectionChange } from '@angular/material/core'; | ||
import { Observable } from 'rxjs'; | ||
import * as i0 from "@angular/core"; | ||
export declare const INPUT_VALUE_ACCESSOR: any; | ||
export declare class AutocompleteEntryComponent implements OnInit { | ||
constructor(); | ||
private fb; | ||
_data: Observable<any[]>; | ||
set data(value: any[] | Observable<any[]>); | ||
get data(): Observable<any[]>; | ||
_disabled: boolean; | ||
set disabled(value: boolean); | ||
get disabled(): boolean; | ||
filteredOptions: Observable<any[]>; | ||
autocomplete: boolean; | ||
required: boolean; | ||
appearance: any; | ||
style: string; | ||
placeholder: string; | ||
label: string; | ||
selectedItem: import("@angular/forms").FormControl; | ||
private onChange; | ||
private onTouched; | ||
constructor(fb: FormBuilder); | ||
ngOnInit(): void; | ||
writeValue(value: any): void; | ||
registerOnChange(fn: (_: any) => void): void; | ||
registerOnTouched(fn: () => void): void; | ||
setDisabledState(isDisabled: boolean): void; | ||
onEnter(value: string): void; | ||
onSelected(option: MatOptionSelectionChange): void; | ||
onBlur(value: string): void; | ||
static ɵfac: i0.ɵɵFactoryDeclaration<AutocompleteEntryComponent, never>; | ||
static ɵcmp: i0.ɵɵComponentDeclaration<AutocompleteEntryComponent, "lib-autocomplete-entry", never, {}, {}, never, never>; | ||
static ɵcmp: i0.ɵɵComponentDeclaration<AutocompleteEntryComponent, "wav-autocomplete-entry", never, { "data": "data"; "disabled": "disabled"; "autocomplete": "autocomplete"; "required": "required"; "appearance": "appearance"; "style": "style"; "placeholder": "placeholder"; "label": "label"; }, {}, never, never>; | ||
} |
import * as i0 from "@angular/core"; | ||
import * as i1 from "./autocomplete-entry.component"; | ||
import * as i2 from "@angular/common"; | ||
import * as i3 from "@angular/material/form-field"; | ||
import * as i4 from "@angular/material/input"; | ||
import * as i5 from "@angular/material/autocomplete"; | ||
import * as i6 from "@angular/forms"; | ||
import * as i7 from "@angular/material/select"; | ||
export declare class AutocompleteEntryModule { | ||
static ɵfac: i0.ɵɵFactoryDeclaration<AutocompleteEntryModule, never>; | ||
static ɵmod: i0.ɵɵNgModuleDeclaration<AutocompleteEntryModule, [typeof i1.AutocompleteEntryComponent], never, [typeof i1.AutocompleteEntryComponent]>; | ||
static ɵmod: i0.ɵɵNgModuleDeclaration<AutocompleteEntryModule, [typeof i1.AutocompleteEntryComponent], [typeof i2.CommonModule, typeof i3.MatFormFieldModule, typeof i4.MatInputModule, typeof i5.MatAutocompleteModule, typeof i6.ReactiveFormsModule, typeof i7.MatSelectModule], [typeof i1.AutocompleteEntryComponent]>; | ||
static ɵinj: i0.ɵɵInjectorDeclaration<AutocompleteEntryModule>; | ||
} |
{ | ||
"name": "autocomplete-entry", | ||
"version": "0.0.1", | ||
"version": "1.0.1", | ||
"description": "This Angular Component (Module) allows you to have an autocomplete or select menu. You can provide an array of objects or an Observable array of objects", | ||
"author": "Mike Boni <wavecoders@gmail.com> (http://wavecoders.ca)", | ||
"license": "ISC", | ||
"keywords": [ | ||
"angular", | ||
"autocomplete", | ||
"material", | ||
"menu", | ||
"selection", | ||
"dropdown" | ||
], | ||
"homepage": "https://wavecoders.ca", | ||
"peerDependencies": { | ||
@@ -5,0 +17,0 @@ "@angular/common": "^12.2.0", |
@@ -1,3 +0,2 @@ | ||
export * from './lib/autocomplete-entry.service'; | ||
export * from './lib/autocomplete-entry.component'; | ||
export * from './lib/autocomplete-entry.module'; |
108
README.md
# AutocompleteEntry | ||
This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 12.2.0. | ||
This Angular Module (Component) allows you to have an autocomplete or select menu. You can provide an array of objects or an Observable array of objects. This formControl will return the selected or entered item. Blur and Enter also have been implemented. | ||
## Code scaffolding | ||
![image](https://github.com/wavecoders/npm/raw/master/projects/color-selection/?raw=true) | ||
Run `ng generate component component-name --project autocomplete-entry` to generate a new component. You can also use `ng generate directive|pipe|service|class|guard|interface|enum|module --project autocomplete-entry`. | ||
> Note: Don't forget to add `--project autocomplete-entry` or else it will be added to the default project in your `angular.json` file. | ||
## Installation | ||
``` | ||
npm install autocomplete-entry | ||
``` | ||
## Build | ||
## Scaffolding | ||
Run `ng build autocomplete-entry` to build the project. The build artifacts will be stored in the `dist/` directory. | ||
Import the module into your project under imports | ||
## Publishing | ||
``` | ||
imports: [ | ||
BrowserModule, | ||
AppRoutingModule, | ||
AutocompleteEntryModule | ||
], | ||
``` | ||
After building your library with `ng build autocomplete-entry`, go to the dist folder `cd dist/autocomplete-entry` and run `npm publish`. | ||
## Use | ||
## Running unit tests | ||
To use in your component, use the following tag | ||
Run `ng test autocomplete-entry` to execute the unit tests via [Karma](https://karma-runner.github.io). | ||
``` | ||
<app-autocomplete-selection></app-autocomplete-selection> | ||
``` | ||
## Further help | ||
## Inputs | ||
To get more help on the Angular CLI use `ng help` or go check out the [Angular CLI Overview and Command Reference](https://angular.io/cli) page. | ||
### Standard inputs | ||
>data STRING[] Data for autocomplete STRING[] | Observable | ||
>autocomplete TRUE - Auto Filter Complete Entry | ||
FALSE - Standard Dropdown Menu BOOLEAN | ||
>placeholder inside label for the input field STRING | ||
>label label for the fiels STRING | ||
### Optional | ||
>required Add validation for required BOOLEAN | ||
>appearance Input Field Appearance STRING (outline, filled) | ||
>style Styles for input field STRING - ex: width:400px; color:red | ||
Here is an example | ||
``` | ||
<wav-autocomplete-selection | ||
formControlName="country" | ||
[data]="countries" | ||
[autocomplete]="true" | ||
[placeholder]="'Canada'" | ||
[label]="'Country'" | ||
></wav-autocomplete-selection> | ||
``` | ||
Here is an example with 2 autocomplete types and different options. | ||
The button will display in the console the selection whether its entered or selected. | ||
``` | ||
<div [formGroup]="autoForm" style="padding: 24px;"> | ||
<wav-autocomplete-selection | ||
formControlName="country1" | ||
[data]="countries" | ||
[autocomplete]="true" | ||
[required]="true" | ||
[appearance]="'outline'" | ||
[style]="'width:400px; color:red'" | ||
[placeholder]="'Canada'" | ||
[label]="'Country'" | ||
></wav-autocomplete-selection> | ||
<wav-autocomplete-selection | ||
formControlName="country2" | ||
[data]="countries" | ||
[autocomplete]="false" | ||
[required]="false" | ||
[appearance]="'outline'" | ||
[style]="'width:400px; color:red'" | ||
[placeholder]="'Canada'" | ||
[label]="'Country'" | ||
></wav-autocomplete-selection> | ||
<button mat-button (click)="onSubmit()">Submit</button> | ||
</div> | ||
``` | ||
In the component we define the menu's contents and define the form | ||
``` | ||
countries = ['Canada', 'United States', 'Russia', 'China'] | ||
country = '' | ||
autoForm = this.fb.group({ | ||
country1: [null], country2: [null] | ||
}) | ||
``` | ||
The onSubmit action connectd to the button click event | ||
``` | ||
onSubmit() { | ||
this.autoForm.markAllAsTouched() | ||
if(this.autoForm.valid) console.log('valid:',this.autoForm.value) | ||
console.log(this.autoForm.value, this.autoForm.valid) | ||
} | ||
``` |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
Long strings
Supply chain riskContains long string literals, which may be a sign of obfuscated or packed code.
Found 1 instance in 1 package
No contributors or author data
MaintenancePackage does not specify a list of contributors or an author in package.json.
Found 1 instance in 1 package
No License Found
License(Experimental) License information could not be found.
Found 1 instance in 1 package
No v1
QualityPackage is not semver >=1. This means it is not stable and does not support ^ ranges.
Found 1 instance in 1 package
No website
QualityPackage does not have a website.
Found 1 instance in 1 package
66759
0
577
1
0
109
14
4
1