New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

autocomplete-entry

Package Overview
Dependencies
Maintainers
1
Versions
30
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

autocomplete-entry - npm Package Compare versions

Comparing version 0.0.1 to 1.0.1

151

bundles/autocomplete-entry.umd.js
(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

3

esm2015/public-api.js
/*
* 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';
# 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

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc