ngx-tags
Version:
To install this library, run:
338 lines • 24.3 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, ViewEncapsulation, TemplateRef, Input, EventEmitter, Output, forwardRef } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import { NgxTagsValueAccessor } from './ngxTagsValueAccessor';
/* tslint:disable:component-selector */
var NgTagComponent = /** @class */ (function (_super) {
tslib_1.__extends(NgTagComponent, _super);
function NgTagComponent() {
var _this = _super.call(this) || this;
_this.isMenuOpen = false;
_this.inputTag = '';
_this.placeholder = 'add a tag';
_this.actionTypes = {
'add': 'add',
'delete': 'delete',
'update': 'update',
};
_this.tagLabel = 'tagLabel';
_this.tagValue = 'tagValue';
_this.clearOnBlur = true;
_this.allowDupes = false;
_this.onlyFromDropdown = false;
_this.tagEditable = false;
_this.change = new EventEmitter();
return _this;
}
Object.defineProperty(NgTagComponent.prototype, "tags", {
get: /**
* @return {?}
*/
function () {
return this._value;
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
NgTagComponent.prototype.whenClickedOut = /**
* @return {?}
*/
function () {
this.isMenuOpen = false;
};
/**
* @param {?} e
* @return {?}
*/
NgTagComponent.prototype.enter = /**
* @param {?} e
* @return {?}
*/
function (e) {
if (this.onlyFromDropdown) {
e.stopProgation();
return false;
}
if (this.inputTag.trim()) {
this.addToModal(this.inputTag);
this.clearInput();
}
};
/**
* @param {?} $event
* @return {?}
*/
NgTagComponent.prototype.save = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
this._value[$event.index][this.tagLabel] = $event.item.trim();
this.emitChange(this.actionTypes.update, this._value[$event.index]);
};
/**
* @return {?}
*/
NgTagComponent.prototype.blur = /**
* @return {?}
*/
function () {
if (this.clearOnBlur) {
this.clearInput();
}
};
/**
* @return {?}
*/
NgTagComponent.prototype.clearInput = /**
* @return {?}
*/
function () {
this.inputTag = '';
};
/**
* @param {?} indx
* @return {?}
*/
NgTagComponent.prototype.del = /**
* @param {?} indx
* @return {?}
*/
function (indx) {
if (this.canDeleteTags) {
this._value.splice(indx, 1);
this.emitChange(this.actionTypes.delete, this._value);
}
};
/**
* @return {?}
*/
NgTagComponent.prototype.backspace = /**
* @return {?}
*/
function () {
if (!this.removeLastOnBackspace && !this.inputTag.trim()) {
this._value.pop();
}
};
/**
* @return {?}
*/
NgTagComponent.prototype.input = /**
* @return {?}
*/
function () {
/** @type {?} */
var _inputTag = this.inputTag.trim();
if (_inputTag) {
this._options = this.filterByInput(this.options);
this.isMenuOpen = true;
}
};
/**
* @private
* @param {?} items
* @return {?}
*/
NgTagComponent.prototype.filterByInput = /**
* @private
* @param {?} items
* @return {?}
*/
function (items) {
var _this = this;
return items.filter((/**
* @param {?} item
* @return {?}
*/
function (item) {
/** @type {?} */
var val = (typeof item !== 'string' && _this.tagLabel) ? item[_this.tagLabel] : item;
if (val.toLowerCase().includes(_this.inputTag.trim().toLowerCase())) {
return true;
}
return false;
}));
};
/**
* @param {?} item
* @return {?}
*/
NgTagComponent.prototype.select = /**
* @param {?} item
* @return {?}
*/
function (item) {
this.addToModal(item.value);
this.clearInput();
this.whenClickedOut();
};
/**
* @private
* @param {?} item
* @return {?}
*/
NgTagComponent.prototype.addToModal = /**
* @private
* @param {?} item
* @return {?}
*/
function (item) {
if (this.hasReachedMaxTags()) {
return;
}
/** @type {?} */
var itemToAdd = this.createTag(item);
if (!this.allowDupes) {
if (this.isDuplicate(itemToAdd)) {
this._value.push(itemToAdd);
this.emitChange(this.actionTypes.add, itemToAdd);
}
}
else {
this._value.push(itemToAdd);
this.emitChange(this.actionTypes.add, itemToAdd);
}
};
/**
* @private
* @param {?} tag
* @return {?}
*/
NgTagComponent.prototype.createTag = /**
* @private
* @param {?} tag
* @return {?}
*/
function (tag) {
var _a;
if (typeof tag !== 'string') {
return tag;
}
else {
return _a = {},
_a[this.tagValue] = tag,
_a[this.tagLabel] = tag,
_a;
}
};
/**
* @return {?}
*/
NgTagComponent.prototype.hasReachedMaxTags = /**
* @return {?}
*/
function () {
return this.maxTags ? (this.maxTags === this._value.length) : false;
};
/**
* @param {?} item
* @return {?}
*/
NgTagComponent.prototype.isDuplicate = /**
* @param {?} item
* @return {?}
*/
function (item) {
return this._value.indexOf(item) === -1 ? true : false;
};
/**
* @private
* @param {?} type
* @param {?} value
* @return {?}
*/
NgTagComponent.prototype.emitChange = /**
* @private
* @param {?} type
* @param {?} value
* @return {?}
*/
function (type, value) {
this.change.emit({ type: type, value: value });
};
NgTagComponent.decorators = [
{ type: Component, args: [{
selector: 'ngx-tags',
template: "<section class=\"ngx-tags\">\n <section class=\"tag-container\" [closeMenu]=\"isMenuOpen\" (whenClickedOut)=\"whenClickedOut()\" [ngClass]=\"{'ngx-tags-disabled':disabled}\" >\n <span class=\"tag\" *ngFor=\"let tag of tags;let $index = index\" [ngClass]=\"{'tag-readonly': tag.readonly}\">\n <ng-container [ngTemplateOutletContext]=\"{ item: tag, index: $index,tagLabel:tagLabel,tagEditable:tagEditable }\"\n [ngTemplateOutlet]=\"tagTemplate ? tagTemplate:defaultTagItemTemplate\">\n </ng-container>\n <a href=\"#\" class=\"close\" [hidden]=\"!canDeleteTags\" (click)=\"del($index)\"></a>\n </span>\n <span class=\"tag-input\" >\n <input type=\"text\" *ngIf=\"canAddTags\" [(ngModel)]=\"inputTag\" (blur)=\"blur()\"\n [placeholder]=\"placeholder\" (keydown.enter)=\"enter($event)\" (keydown.backspace)=\"backspace()\"\n (input)=\"input()\">\n </span>\n </section>\n <ngx-tags-dropdown [items]=\"_options\" [dropdownItemTemplate]=\"dropdownItemTemplate\" [tagLabel]=\"tagLabel\" [inputTag]=\"inputTag\" (select)=\"select($event) \" [hidden]=\"!isMenuOpen\"></ngx-tags-dropdown>\n</section>\n\n<ng-template #defaultTagItemTemplate let-item=\"item\" let-tagLabel=\"tagLabel\" let-input=\"input\" let-tagEditable=\"tagEditable\" let-index=\"index\">\n <ngx-tag [item]=\"item\" [tagEditable]=\"tagEditable\" [tagLabel]=\"tagLabel\" [index]=\"index\" (change)=\"save($event)\"></ngx-tag>\n</ng-template>",
providers: [{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef((/**
* @return {?}
*/
function () { return NgTagComponent; })),
multi: true
}],
encapsulation: ViewEncapsulation.None,
styles: [".ngx-tags{position:relative;display:block;width:100%}.ngx-tags .ngx-tags-disabled{opacity:.7;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none}.ngx-tags .tag-container{display:block;width:100%;padding:.375rem .75rem;font-size:1rem;line-height:1.5;color:#495057;background-color:#fff;background-clip:padding-box;border:1px solid #ced4da;border-radius:.25rem;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out;box-sizing:border-box}.ngx-tags .tag-container .tag,.ngx-tags .tag-container .tag-input{background:#9dc1ff;padding:.25rem;border-radius:.25rem;margin-right:.25rem;display:inline-flex;align-items:center;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content}.ngx-tags .tag-container .tag-input{background:#fff}.ngx-tags .tag-container .tag-input input{border:none;outline:0;min-width:140px;max-width:100%;height:100%;margin-left:4px;box-sizing:border-box;display:inline-block}.ngx-tags .tag-container .tag-readonly{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;opacity:.7}.ngx-tags .tag-container .close{position:relative;display:inline-block;width:10px;height:10px;opacity:.8}.ngx-tags .tag-container .close:hover{opacity:1}.ngx-tags .tag-container .close:after,.ngx-tags .tag-container .close:before{position:absolute;left:3px;content:' ';height:11px;width:2px;background-color:#333}.ngx-tags .tag-container .close:before{transform:rotate(45deg)}.ngx-tags .tag-container .close:after{transform:rotate(-45deg)}.item:hover,.keynav-active{background:#e1e4e8}.dropdown{margin:0;padding:0;border:1px solid #e1e4e8;box-shadow:0 2px 4px -1px rgba(0,0,0,.2),0 4px 5px 0 rgba(0,0,0,.14),0 1px 10px 0 rgba(0,0,0,.12);border-radius:2px;max-height:200px;overflow-y:auto;position:absolute;background:#fff;display:block;width:100%;z-index:1}.item{padding:4px 2px;display:block}"]
}] }
];
/** @nocollapse */
NgTagComponent.ctorParameters = function () { return []; };
NgTagComponent.propDecorators = {
tagTemplate: [{ type: Input }],
dropdownItemTemplate: [{ type: Input }],
options: [{ type: Input }],
maxTags: [{ type: Input }],
tagLabel: [{ type: Input }],
tagValue: [{ type: Input }],
removeLastOnBackspace: [{ type: Input }],
canDeleteTags: [{ type: Input }],
canAddTags: [{ type: Input }],
clearOnBlur: [{ type: Input }],
allowDupes: [{ type: Input }],
onlyFromDropdown: [{ type: Input }],
tagEditable: [{ type: Input }],
change: [{ type: Output }]
};
return NgTagComponent;
}(NgxTagsValueAccessor));
export { NgTagComponent };
if (false) {
/** @type {?} */
NgTagComponent.prototype.isMenuOpen;
/** @type {?} */
NgTagComponent.prototype._options;
/** @type {?} */
NgTagComponent.prototype.inputTag;
/** @type {?} */
NgTagComponent.prototype.placeholder;
/** @type {?} */
NgTagComponent.prototype.actionTypes;
/** @type {?} */
NgTagComponent.prototype.tagTemplate;
/** @type {?} */
NgTagComponent.prototype.dropdownItemTemplate;
/** @type {?} */
NgTagComponent.prototype.options;
/** @type {?} */
NgTagComponent.prototype.maxTags;
/** @type {?} */
NgTagComponent.prototype.tagLabel;
/** @type {?} */
NgTagComponent.prototype.tagValue;
/** @type {?} */
NgTagComponent.prototype.removeLastOnBackspace;
/** @type {?} */
NgTagComponent.prototype.canDeleteTags;
/** @type {?} */
NgTagComponent.prototype.canAddTags;
/** @type {?} */
NgTagComponent.prototype.clearOnBlur;
/** @type {?} */
NgTagComponent.prototype.allowDupes;
/** @type {?} */
NgTagComponent.prototype.onlyFromDropdown;
/** @type {?} */
NgTagComponent.prototype.tagEditable;
/** @type {?} */
NgTagComponent.prototype.change;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngxTags.component.js","sourceRoot":"ng://ngx-tags/","sources":["lib/ngxTags.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewEncapsulation, TemplateRef, Input, EventEmitter, Output, forwardRef } from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { NgxTagsValueAccessor } from './ngxTagsValueAccessor';\nimport { Observable } from 'rxjs';\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\n\n/* tslint:disable:component-selector */\n@Component({\n  selector: 'ngx-tags',\n  templateUrl: './ngxTags.component.html',\n  styleUrls: ['./ngxTags.component.scss'],\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => NgTagComponent),\n    multi: true\n  }],\n  encapsulation: ViewEncapsulation.None\n\n})\nexport class NgTagComponent extends NgxTagsValueAccessor {\n  public isMenuOpen = false;\n  public _options: Observable<{}> | Array<any>;\n  public inputTag = '';\n  public placeholder = 'add a tag';\n  public actionTypes = {\n    'add': 'add',\n    'delete': 'delete',\n    'update': 'update',\n  };\n\n  public get tags() {\n    return this._value;\n  }\n\n  @Input() tagTemplate: TemplateRef<any>;\n  @Input() dropdownItemTemplate: TemplateRef<any>;\n  @Input() options: any;\n  @Input() maxTags: number;\n  @Input() tagLabel = 'tagLabel';\n  @Input() tagValue = 'tagValue';\n  @Input() removeLastOnBackspace: boolean;\n  @Input() canDeleteTags: boolean;\n  @Input() canAddTags: boolean;\n  @Input() clearOnBlur = true;\n  @Input() allowDupes = false;\n  @Input() onlyFromDropdown = false;\n  @Input() tagEditable = false;\n\n  @Output() public change = new EventEmitter<any>();\n\n  constructor() {\n    super();\n  }\n\n\n  whenClickedOut() {\n    this.isMenuOpen = false;\n  }\n\n\n  enter(e) {\n    if (this.onlyFromDropdown) {\n    e.stopProgation();\n      return false;\n    }\n    if (this.inputTag.trim()) {\n      this.addToModal(this.inputTag);\n      this.clearInput();\n    }\n  }\n  save($event) {\n    this._value[$event.index][this.tagLabel] = $event.item.trim();\n    this.emitChange(this.actionTypes.update, this._value[$event.index]);\n  }\n\n  blur() {\n    if (this.clearOnBlur) { this.clearInput(); }\n  }\n\n  clearInput() {\n    this.inputTag = '';\n  }\n\n  del(indx: number) {\n    if (this.canDeleteTags) {\n      this._value.splice(indx, 1);\n      this.emitChange(this.actionTypes.delete, this._value);\n    }\n  }\n\n  backspace() {\n    if (!this.removeLastOnBackspace && !this.inputTag.trim()) {\n      this._value.pop();\n    }\n  }\n\n  input() {\n    const _inputTag = this.inputTag.trim();\n    if (_inputTag) {\n      this._options = this.filterByInput(this.options);\n      this.isMenuOpen = true;\n    }\n  }\n\n  private filterByInput(items) {\n    return items.filter((item) => {\n      const val = (typeof item !== 'string' && this.tagLabel) ? item[this.tagLabel] : item;\n      if (val.toLowerCase().includes(this.inputTag.trim().toLowerCase())) {\n        return true;\n      }\n      return false;\n    });\n  }\n\n  select(item) {\n    this.addToModal(item.value);\n    this.clearInput();\n    this.whenClickedOut();\n  }\n\n  private addToModal(item) {\n    if (this.hasReachedMaxTags()) {\n      return;\n    }\n    const itemToAdd = this.createTag(item);\n    if (!this.allowDupes) {\n      if (this.isDuplicate(itemToAdd)) {\n        this._value.push(itemToAdd);\n        this.emitChange(this.actionTypes.add, itemToAdd);\n      }\n    } else {\n      this._value.push(itemToAdd);\n      this.emitChange(this.actionTypes.add, itemToAdd);\n    }\n  }\n\n  private createTag(tag) {\n    if (typeof tag !== 'string') {\n      return tag;\n    } else {\n      return {\n        [this.tagValue]: tag,\n        [this.tagLabel]: tag\n      };\n    }\n  }\n\n  hasReachedMaxTags() {\n    return this.maxTags ? (this.maxTags === this._value.length) : false;\n  }\n\n  isDuplicate(item) {\n    return this._value.indexOf(item) === -1 ? true : false;\n  }\n  private emitChange(type: string, value: any) {\n    this.change.emit({ type: type, value: value });\n  }\n}\n"]}