lct-components
Version:
LCT basic components
195 lines • 47.2 kB
JavaScript
import { Component, EventEmitter, Input, Output, } from '@angular/core';
import * as i0 from "@angular/core";
import * as i1 from "@angular/platform-browser";
import * as i2 from "../input-text/input-text.component";
import * as i3 from "@angular/common";
import * as i4 from "@angular/forms";
import * as i5 from "../pipes/label.title.pipe";
import * as i6 from "../pipes/label.pipe";
export class SelectMultipleNestedComponent {
constructor(sanitizer) {
this.sanitizer = sanitizer;
this.list = [];
this.listFiltered = [];
this.title = 'Insert title';
this.disabled = 'false';
this.showIcon = true;
this.placeholder = 'Insert placeholder';
this.placeholderFilter = 'Buscar';
this.quantityToFilter = 6;
this.heightOptions = '200px';
this.id = ''; // ID en Button Opcional
this.shareCheckedList = new EventEmitter();
this.shareIndividualCheckedList = new EventEmitter();
this.setAutofocusEvent = new EventEmitter();
this.disabledValue = false;
this.filter = '';
this.currentSelected = null;
this.showDropDown = false;
this.searchValue = '';
this.iconFinder = this.sanitizer.bypassSecurityTrustResourceUrl(`data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjAiIGhlaWdodD0iMjEiIHZpZXdCb3g9IjAgMCAyMCAyMSIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTEyLjE1MDMgMTIuNDE2M0MxMi4yOTUgMTIuMjcxNyAxMi41MTk1IDEyLjI1NTYgMTIuNjgxOSAxMi4zNjgxTDEyLjczOTYgMTIuNDE2M0wxNi40MDYxIDE2LjA4MjhDMTYuNTY4OCAxNi4yNDU1IDE2LjU2ODggMTYuNTA5MyAxNi40MDYxIDE2LjY3MkMxNi4yNjE0IDE2LjgxNjcgMTYuMDM2OSAxNi44MzI4IDE1Ljg3NDUgMTYuNzIwM0wxNS44MTY4IDE2LjY3MkwxMi4xNTAzIDEzLjAwNTZDMTEuOTg3NiAxMi44NDI4IDExLjk4NzYgMTIuNTc5IDEyLjE1MDMgMTIuNDE2M1oiIGZpbGw9IiMyNjQ5QjYiLz4KPHBhdGggZmlsbC1ydWxlPSJldmVub2RkIiBjbGlwLXJ1bGU9ImV2ZW5vZGQiIGQ9Ik0xMi4zOTcxIDUuNTkxOTFDMTAuNDQ0NSAzLjYzOTI5IDcuMjc4NjggMy42MzkyOSA1LjMyNjA2IDUuNTkxOTFDMy4zNzM0NCA3LjU0NDUzIDMuMzczNDQgMTAuNzEwNCA1LjMyNjA2IDEyLjY2M0M3LjI3ODY4IDE0LjYxNTYgMTAuNDQ0NSAxNC42MTU2IDEyLjM5NzEgMTIuNjYzQzE0LjM0OTggMTAuNzEwNCAxNC4zNDk4IDcuNTQ0NTMgMTIuMzk3MSA1LjU5MTkxWk01LjkxNTMyIDEyLjA3MzdDNC4yODgxMyAxMC40NDY1IDQuMjg4MTMgNy44MDgzNSA1LjkxNTMyIDYuMTgxMTZDNy41NDI1IDQuNTUzOTggMTAuMTgwNyA0LjU1Mzk4IDExLjgwNzkgNi4xODExNkMxMy40MzUxIDcuODA4MzUgMTMuNDM1MSAxMC40NDY1IDExLjgwNzkgMTIuMDczN0MxMC4xODA3IDEzLjcwMDkgNy41NDI1IDEzLjcwMDkgNS45MTUzMiAxMi4wNzM3WiIgZmlsbD0iIzI2NDlCNiIvPgo8L3N2Zz4K`);
}
// Propiedad calculada para generar el id dinámico
get selectId() {
return this.id ? `select-${this.id}` : null;
}
ngOnInit() {
this.listFiltered = [...this.list];
// console.log(this.listFiltered);
this.disabledValue =
this.disabled === true || this.disabled == 'true' || this.disabled === '';
}
ngOnChanges(changes) {
if (changes['disabled'] && !changes['disabled'].firstChange) {
if (changes['disabled'].currentValue === true ||
changes['disabled'].currentValue == 'true' ||
changes['disabled'].currentValue === '') {
this.disabledValue = true;
}
else {
this.disabledValue = false;
}
}
if (changes['list']) {
if (Array.isArray(changes['list'].currentValue)) {
this.list = changes['list'].currentValue;
this.applyFilter();
}
}
}
getListChecked() {
return this.listFiltered.reduce((accumulator, category) => {
const checkedOptions = category.listOptions.filter((option) => option.checked);
return accumulator.concat(checkedOptions);
}, []);
}
getTotalCategoryCount() {
let totalCount = 0;
for (const _category in this.list) {
totalCount += 1;
}
return totalCount;
}
getCategories() {
return Object.keys(this.list);
}
toggleCategory(category) {
category.open = !category.open;
}
shareChecked() {
this.shareCheckedList.emit(this.getListChecked());
}
shareIndividualStatus() {
if (this.currentSelected) {
this.shareIndividualCheckedList.emit(this.currentSelected);
}
}
toggleAllOptions(category) {
//category.checkedAll = !category.checkedAll;
category.listOptions.forEach((option) => {
if (!option.disabled) {
option.checked = category.checkedAll || false;
}
});
this.shareChecked();
}
toggleOption(category, option) {
if (category) {
category.checkedAll = category.listOptions
.filter((option) => !option.disabled)
.every((option) => option.checked);
this.currentSelected = option;
this.shareIndividualStatus();
this.shareChecked();
}
}
discardOption(category, option) {
this.showDropDown = !this.showDropDown;
if (category) {
option.checked = false;
category.checkedAll = category.listOptions.every((option) => option.checked);
this.currentSelected = option;
this.shareIndividualStatus();
this.shareChecked();
}
}
// Método para filtrar los datos basados en el nombre de las opciones
filterData(value) {
if (!value) {
return this.list; // Retorna la lista completa si no hay valor de búsqueda
}
// Filtra cada categoría y sus opciones
const normalizar = (str) => str
.normalize('NFD') // Descompone los caracteres con tilde
.replace(/[\u0300-\u036f]/g, '') // Elimina los signos diacríticos
.toLowerCase();
return this.list
.map((category) => {
const filteredOptions = category.listOptions.filter((opt) => normalizar(opt.name).includes(normalizar(value)));
return Object.assign(Object.assign({}, category), { listOptions: filteredOptions });
})
.filter((category) => category.listOptions.length > 0);
}
applyFilter() {
this.listFiltered = this.filterData(this.searchValue); // Actualiza la lista filtrada
}
findOptionCategory(option) {
for (let category of this.list) {
if (category.listOptions.includes(option)) {
return category;
}
}
return null; // Retornar null si no se encuentra la categoría
}
clickFilterComponent() {
var _a;
this.showDropDown = !this.showDropDown;
//Desactivar autofocus externo cuando se muestra el buscador
if (this.list.length >= this.quantityToFilter) {
(_a = this.setAutofocusEvent) === null || _a === void 0 ? void 0 : _a.emit(this.showDropDown);
}
}
leaveComponent() {
var _a;
this.showDropDown = false;
//Desactivar autofocus externo cuando se muestra el buscador
if (this.list.length >= this.quantityToFilter) {
(_a = this.setAutofocusEvent) === null || _a === void 0 ? void 0 : _a.emit(this.showDropDown);
}
}
}
SelectMultipleNestedComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0, type: SelectMultipleNestedComponent, deps: [{ token: i1.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component });
SelectMultipleNestedComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.5", type: SelectMultipleNestedComponent, selector: "lct-select-multiple-nested", inputs: { list: "list", title: "title", disabled: "disabled", showIcon: "showIcon", placeholder: "placeholder", placeholderFilter: "placeholderFilter", quantityToFilter: "quantityToFilter", heightOptions: "heightOptions", id: "id" }, outputs: { shareCheckedList: "shareCheckedList", shareIndividualCheckedList: "shareIndividualCheckedList", setAutofocusEvent: "setAutofocusEvent" }, usesOnChanges: true, ngImport: i0, template: "<div>\n <div class=\"title\">{{title}}</div>\n <div class=\"containerSelectMultiple\" (mouseleave)=\"leaveComponent()\">\n <button [attr.id]=\"selectId\" class=\"drop-toggle\" [disabled]=\"disabledValue\" (click)=\"clickFilterComponent()\">\n <span *ngIf=\"getListChecked().length<=0\">{{placeholder}}</span>\n <span *ngIf=\"getListChecked().length>0\">\n <div class=\"selected\">\n <span [ngClass]=\"{'text-disabled':getListChecked()[0].disabled || false}\">{{getListChecked()[0].name | labelTitlePipe}}</span>\n <div class=\"icon\" (click)=\"discardOption(findOptionCategory(getListChecked()[0]), getListChecked()[0])\" [ngClass]=\"{'icon-disabled':getListChecked()[0].disabled || false}\">\n <svg [ngClass]=\"{'text-disabled':getListChecked()[0].disabled || false}\"\n width=\"20\"\n height=\"20\"\n viewBox=\"0 4 24 24\"\n fill=\"none\"\n style=\"color: #2649B6\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M6.2253 4.81108C5.83477 4.42056 5.20161 4.42056 4.81108 4.81108C4.42056 5.20161 4.42056 5.83477 4.81108 6.2253L10.5858 12L4.81114 17.7747C4.42062 18.1652 4.42062 18.7984 4.81114 19.1889C5.20167 19.5794 5.83483 19.5794 6.22535 19.1889L12 13.4142L17.7747 19.1889C18.1652 19.5794 18.7984 19.5794 19.1889 19.1889C19.5794 18.7984 19.5794 18.1652 19.1889 17.7747L13.4142 12L19.189 6.2253C19.5795 5.83477 19.5795 5.20161 19.189 4.81108C18.7985 4.42056 18.1653 4.42056 17.7748 4.81108L12 10.5858L6.2253 4.81108Z\"\n fill=\"currentColor\"\n />\n </svg>\n </div>\n </div>\n <span class=\"moreSelected\" *ngIf=\"getListChecked().length > 1 \">(+ {{getListChecked().length - 1}} m\u00E1s)</span>\n <!--{{getListChecked().join(', ')}}-->\n </span>\n <img *ngIf=\"showIcon\"\n class=\"select-box__icon\"\n [ngStyle]=\"{'transform': showDropDown ? 'translateY(-50%) rotate(180deg)' : 'translateY(-50%) rotate(0deg)' }\"\n src=\"data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4NCjwhLS0gU3ZnIFZlY3RvciBJY29ucyA6IGh0dHA6Ly93d3cub25saW5ld2ViZm9udHMuY29tL2ljb24gLS0+DQo8IURPQ1RZUEUgc3ZnIFBVQkxJQyAiLS8vVzNDLy9EVEQgU1ZHIDEuMS8vRU4iICJodHRwOi8vd3d3LnczLm9yZy9HcmFwaGljcy9TVkcvMS4xL0RURC9zdmcxMS5kdGQiPg0KPHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4IiB2aWV3Qm94PSIwIDAgMTAwMCAxMDAwIiBlbmFibGUtYmFja2dyb3VuZD0ibmV3IDAgMCAxMDAwIDEwMDAiIHhtbDpzcGFjZT0icHJlc2VydmUiPg0KPG1ldGFkYXRhPiBTdmcgVmVjdG9yIEljb25zIDogaHR0cDovL3d3dy5vbmxpbmV3ZWJmb250cy5jb20vaWNvbiA8L21ldGFkYXRhPg0KPGc+PHBhdGggZD0iTTUwMCw3NzUuNEwxMCwyODcuMmw2NC40LTYyLjZMNTAwLDY1MC4ybDQyNS42LTQyNS42bDY0LjQsNjIuNkw1MDAsNzc1LjR6Ii8+PC9nPg0KPC9zdmc+\" alt=\"Arrow Icon\"\n aria-hidden=\"true\"/>\n </button>\n <div class=\"drop-show\" *ngIf=\"showDropDown && list.length>0\">\n <div *ngIf=\"getTotalCategoryCount()>=quantityToFilter\" class=\"main\">\n <lct-input-text [placeholder]=\"placeholderFilter\" title=\"\"\n [(ngModel)]=\"searchValue\"\n (ngModelChange)=\"applyFilter()\"\n [icon]=\"iconFinder\"\n [showIcon]=\"true\"\n ></lct-input-text>\n </div>\n <div [ngStyle]=\"{'height': getTotalCategoryCount()>=quantityToFilter ? heightOptions : 'auto','overflow-y':getTotalCategoryCount()>=quantityToFilter ? 'auto':''}\">\n <div *ngFor=\"let category of listFiltered\">\n <div style=\"display: inline-flex;\">\n <svg [ngStyle]=\"{'transform': category.open ? 'translateY(25%) rotate(180deg)' : 'translateY(25%) rotate(0deg)' }\"\n (click)=\"toggleCategory(category)\" class=\"select-box__category\"\n width=\"17\" height=\"18\" viewBox=\"0 0 17 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M13.459 7.58398L8.50065 11.834L3.54232 7.58398\" stroke=\"#2649B6\" stroke-width=\"1.3\" stroke-linecap=\"round\"/>\n </svg>\n <!-- <img *ngIf=\"showIcon\"\n class=\"select-box__category\"\n [ngStyle]=\"{'transform': category.open ? 'translateY(32%) rotate(180deg)' : 'translateY(32%) rotate(0deg)' }\"\n src=\"data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4NCjwhLS0gU3ZnIFZlY3RvciBJY29ucyA6IGh0dHA6Ly93d3cub25saW5ld2ViZm9udHMuY29tL2ljb24gLS0+DQo8IURPQ1RZUEUgc3ZnIFBVQkxJQyAiLS8vVzNDLy9EVEQgU1ZHIDEuMS8vRU4iICJodHRwOi8vd3d3LnczLm9yZy9HcmFwaGljcy9TVkcvMS4xL0RURC9zdmcxMS5kdGQiPg0KPHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4IiB2aWV3Qm94PSIwIDAgMTAwMCAxMDAwIiBlbmFibGUtYmFja2dyb3VuZD0ibmV3IDAgMCAxMDAwIDEwMDAiIHhtbDpzcGFjZT0icHJlc2VydmUiPg0KPG1ldGFkYXRhPiBTdmcgVmVjdG9yIEljb25zIDogaHR0cDovL3d3dy5vbmxpbmV3ZWJmb250cy5jb20vaWNvbiA8L21ldGFkYXRhPg0KPGc+PHBhdGggZD0iTTUwMCw3NzUuNEwxMCwyODcuMmw2NC40LTYyLjZMNTAwLDY1MC4ybDQyNS42LTQyNS42bDY0LjQsNjIuNkw1MDAsNzc1LjR6Ii8+PC9nPg0KPC9zdmc+\" alt=\"Arrow Icon\"\n aria-hidden=\"true\" height=\"17px\" width=\"17px\" (click)=\"toggleCategory(category)\"/> -->\n <label class=\"main\">\n <span class=\"text-capitalize\" style=\"margin-left: 21px;\">{{ category.name.toLowerCase() | labelPipe }} </span>\n <span *ngIf=\"category.quantity\">({{category.quantity}})</span>\n <input type=\"checkbox\" [(ngModel)]=\"category.checkedAll\"\n (change)=\"toggleAllOptions(category)\" [disabled]=\"category.disabled || false || searchValue.length > 0\">\n <span class=\"mark\" [ngClass]=\"{'mark-disabled': category.disabled || false || searchValue.length > 0}\"></span>\n </label>\n </div>\n\n <ul *ngIf=\"category.open\">\n <label class=\"main\" *ngFor=\"let option of category.listOptions\">\n <span class=\"text-capitalize\" style=\"margin-left: 21px;\" [ngClass]=\"{ 'text-disabled': option.disabled }\">{{ option.name.toLowerCase() | labelPipe }} </span>\n <span *ngIf=\"option.quantity\">({{option.quantity}})</span>\n <input type=\"checkbox\" [(ngModel)]=\"option.checked\"\n (change)=\"toggleOption(category, option)\" [disabled]=\"option.disabled || false\"/>\n <span class=\"mark\" [ngClass]=\"{'mark-disabled': option.disabled || false}\"></span>\n </label>\n </ul>\n\n </div>\n\n </div>\n </div>\n <div class=\"drop-empty\" *ngIf=\"showDropDown && list.length===0\">\n Sin informaci\u00F3n\n </div>\n </div>\n</div>\n", styles: ["*{font-family:\"Barlow\",\"Open Sans\",\"Helvetica Neue\",\"Segoe UI\",\"Calibri\",\"Arial\",sans-serif}.title{color:#3c4149;font-size:12px;letter-spacing:0;line-height:15px;margin-left:2px;margin-bottom:5px}.containerSelectMultiple{width:100%;position:relative}.drop-toggle{background-color:#e0e5ee;cursor:pointer;box-sizing:border-box;height:41px;width:100%;border:0;border-radius:5px;text-align:left;font-size:14px;padding-left:12px;color:#3c4149;overflow:hidden}.select-box__icon{position:absolute;right:15px;width:20px;top:50%;transform:translateY(-50%) rotate(0);opacity:.3;transition:.2s ease}.select-box__category{width:17px;transform:translateY(25%) rotate(0);color:#2649b6;transition:.2s ease;margin-left:10px;cursor:pointer}button:disabled{background-color:#f5f7fa;cursor:not-allowed;color:#c8ccd4}.drop-toggle i{float:right}.drop-show{box-sizing:border-box;width:100%;border:1px solid #E0E5EE;border-radius:5px;background-color:#fff;position:absolute;z-index:2;box-shadow:0 6px 10px #00000026;margin-left:1px}.drop-empty{width:100%;border:1px solid #E0E5EE;border-radius:5px;background-color:#fff;position:absolute;z-index:2;box-shadow:0 6px 10px #00000026;padding:12px;cursor:no-drop}.mark-disabled{background-color:#c8ccd4!important}.text-disabled{color:#c8ccd4!important}.icon-disabled{pointer-events:none}.selected{display:inline-block;position:relative;margin-right:5px;box-sizing:border-box;height:26px;border:1px solid #C2C2C2;border-radius:3px;background-color:#f5f7fa;font-size:13px;letter-spacing:0;line-height:16px;padding:5px}.selected span{vertical-align:top}.selected .icon{display:inline;margin-left:2px}.moreSelected{position:absolute;margin-top:8px;color:#3c4149;font-size:12px;letter-spacing:0;line-height:15px}ul .main{display:block;position:relative;margin-left:17px;margin-right:17px;margin-bottom:5px;cursor:pointer;color:#3c4149;font-size:13px;letter-spacing:0;line-height:27px}.main{display:block;position:relative;margin-left:10px;margin-right:17px;margin-bottom:5px;cursor:pointer;color:#3c4149;font-size:13px;letter-spacing:0;line-height:27px}.text{margin-left:27px}input[type=checkbox]{visibility:hidden}.mark{position:absolute;top:5px;left:0;box-sizing:border-box;height:17px;width:17px;border:1px solid #D6D6D6;border-radius:2px;background-color:#f4f4f4}.main:hover input~.mark{background-color:#c2c2c2}.main input:active~.mark{background-color:#546c84}.main input:checked~.mark{background-color:#2649b6}.mark:after{content:\"\";position:absolute;display:none}.main input:checked~.mark:after{display:block}.main .mark:after{left:5px;bottom:5px;width:3px;height:6px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}\n"], components: [{ type: i2.InputTextComponent, selector: "lct-input-text", inputs: ["disabled", "icon", "iconPosition", "pdaAutoEnter", "placeholder", "showIcon", "title", "type", "error", "id", "transparent"], outputs: ["enterEmitted", "iconClick", "inputClick"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i4.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }], pipes: { "labelTitlePipe": i5.LabelTitlePipe, "labelPipe": i6.LabelPipe } });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0, type: SelectMultipleNestedComponent, decorators: [{
type: Component,
args: [{
selector: 'lct-select-multiple-nested',
templateUrl: './select-multiple-nested.component.html',
styleUrls: ['./select-multiple-nested.component.css'],
}]
}], ctorParameters: function () { return [{ type: i1.DomSanitizer }]; }, propDecorators: { list: [{
type: Input
}], title: [{
type: Input
}], disabled: [{
type: Input
}], showIcon: [{
type: Input
}], placeholder: [{
type: Input
}], placeholderFilter: [{
type: Input
}], quantityToFilter: [{
type: Input
}], heightOptions: [{
type: Input
}], id: [{
type: Input
}], shareCheckedList: [{
type: Output
}], shareIndividualCheckedList: [{
type: Output
}], setAutofocusEvent: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-multiple-nested.component.js","sourceRoot":"","sources":["../../../../../projects/lct-components/src/lib/select-multiple-nested/select-multiple-nested.component.ts","../../../../../projects/lct-components/src/lib/select-multiple-nested/select-multiple-nested.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges,\n} from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\n\nexport interface ILCTSelectMultiple {\n  name: string;\n  checked: boolean;\n  value?: string | number;\n  disabled?: boolean | string;\n  secondaryValue?: string | number;\n  quantity?: number;\n}\n\nexport interface IListSelectMultipleNested {\n  name: string;\n  checkedAll?: boolean;\n  listOptions: ILCTSelectMultiple[];\n  disabled?: boolean | string;\n  open?: boolean;\n  quantity?: number;\n}\n\n@Component({\n  selector: 'lct-select-multiple-nested',\n  templateUrl: './select-multiple-nested.component.html',\n  styleUrls: ['./select-multiple-nested.component.css'],\n})\nexport class SelectMultipleNestedComponent implements OnInit, OnChanges {\n  @Input() list: IListSelectMultipleNested[] = [];\n  listFiltered: IListSelectMultipleNested[] = [];\n  @Input() title = 'Insert title';\n  @Input() disabled: 'true' | 'false' | 'disabled' | boolean | '' = 'false';\n  @Input() showIcon = true;\n  @Input() placeholder = 'Insert placeholder';\n  @Input() placeholderFilter = 'Buscar';\n  @Input() quantityToFilter: number = 6;\n  @Input() heightOptions: string = '200px';\n  @Input() id?: string = ''; // ID en Button Opcional\n\n  @Output() shareCheckedList = new EventEmitter();\n  @Output() shareIndividualCheckedList = new EventEmitter();\n  @Output() setAutofocusEvent = new EventEmitter<boolean>();\n  disabledValue = false;\n\n  iconFinder;\n  filter: string = '';\n\n  currentSelected: ILCTSelectMultiple | null = null;\n  showDropDown = false;\n  searchValue: string = '';\n\n  // Propiedad calculada para generar el id dinámico\n  get selectId(): string | null {\n    return this.id ? `select-${this.id}` : null;\n  }\n  constructor(private sanitizer: DomSanitizer) {\n    this.iconFinder = this.sanitizer.bypassSecurityTrustResourceUrl(\n      `data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjAiIGhlaWdodD0iMjEiIHZpZXdCb3g9IjAgMCAyMCAyMSIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTEyLjE1MDMgMTIuNDE2M0MxMi4yOTUgMTIuMjcxNyAxMi41MTk1IDEyLjI1NTYgMTIuNjgxOSAxMi4zNjgxTDEyLjczOTYgMTIuNDE2M0wxNi40MDYxIDE2LjA4MjhDMTYuNTY4OCAxNi4yNDU1IDE2LjU2ODggMTYuNTA5MyAxNi40MDYxIDE2LjY3MkMxNi4yNjE0IDE2LjgxNjcgMTYuMDM2OSAxNi44MzI4IDE1Ljg3NDUgMTYuNzIwM0wxNS44MTY4IDE2LjY3MkwxMi4xNTAzIDEzLjAwNTZDMTEuOTg3NiAxMi44NDI4IDExLjk4NzYgMTIuNTc5IDEyLjE1MDMgMTIuNDE2M1oiIGZpbGw9IiMyNjQ5QjYiLz4KPHBhdGggZmlsbC1ydWxlPSJldmVub2RkIiBjbGlwLXJ1bGU9ImV2ZW5vZGQiIGQ9Ik0xMi4zOTcxIDUuNTkxOTFDMTAuNDQ0NSAzLjYzOTI5IDcuMjc4NjggMy42MzkyOSA1LjMyNjA2IDUuNTkxOTFDMy4zNzM0NCA3LjU0NDUzIDMuMzczNDQgMTAuNzEwNCA1LjMyNjA2IDEyLjY2M0M3LjI3ODY4IDE0LjYxNTYgMTAuNDQ0NSAxNC42MTU2IDEyLjM5NzEgMTIuNjYzQzE0LjM0OTggMTAuNzEwNCAxNC4zNDk4IDcuNTQ0NTMgMTIuMzk3MSA1LjU5MTkxWk01LjkxNTMyIDEyLjA3MzdDNC4yODgxMyAxMC40NDY1IDQuMjg4MTMgNy44MDgzNSA1LjkxNTMyIDYuMTgxMTZDNy41NDI1IDQuNTUzOTggMTAuMTgwNyA0LjU1Mzk4IDExLjgwNzkgNi4xODExNkMxMy40MzUxIDcuODA4MzUgMTMuNDM1MSAxMC40NDY1IDExLjgwNzkgMTIuMDczN0MxMC4xODA3IDEzLjcwMDkgNy41NDI1IDEzLjcwMDkgNS45MTUzMiAxMi4wNzM3WiIgZmlsbD0iIzI2NDlCNiIvPgo8L3N2Zz4K`\n    );\n  }\n\n  ngOnInit() {\n    this.listFiltered = [...this.list];\n    // console.log(this.listFiltered);\n    this.disabledValue =\n      this.disabled === true || this.disabled == 'true' || this.disabled === '';\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['disabled'] && !changes['disabled'].firstChange) {\n      if (\n        changes['disabled'].currentValue === true ||\n        changes['disabled'].currentValue == 'true' ||\n        changes['disabled'].currentValue === ''\n      ) {\n        this.disabledValue = true;\n      } else {\n        this.disabledValue = false;\n      }\n    }\n    if (changes['list']) {\n      if (Array.isArray(changes['list'].currentValue)) {\n        this.list = changes['list'].currentValue;\n        this.applyFilter();\n      }\n    }\n  }\n\n  getListChecked(): ILCTSelectMultiple[] {\n    return this.listFiltered.reduce(\n      (accumulator: ILCTSelectMultiple[], category) => {\n        const checkedOptions = category.listOptions.filter(\n          (option) => option.checked\n        );\n        return accumulator.concat(checkedOptions);\n      },\n      []\n    );\n  }\n\n  getTotalCategoryCount(): number {\n    let totalCount = 0;\n\n    for (const _category in this.list) {\n      totalCount += 1;\n    }\n\n    return totalCount;\n  }\n\n  getCategories(): string[] {\n    return Object.keys(this.list);\n  }\n\n  toggleCategory(category: IListSelectMultipleNested): void {\n    category.open = !category.open;\n  }\n\n  shareChecked(): void {\n    this.shareCheckedList.emit(this.getListChecked());\n  }\n\n  shareIndividualStatus(): void {\n    if (this.currentSelected) {\n      this.shareIndividualCheckedList.emit(this.currentSelected);\n    }\n  }\n\n  toggleAllOptions(category: IListSelectMultipleNested): void {\n    //category.checkedAll = !category.checkedAll;\n    category.listOptions.forEach((option) => {\n      if (!option.disabled) {\n        option.checked = category.checkedAll || false;\n      }\n    });\n    this.shareChecked();\n  }\n\n  toggleOption(\n    category: IListSelectMultipleNested | null,\n    option: ILCTSelectMultiple\n  ): void {\n    if (category) {\n      category.checkedAll = category.listOptions\n        .filter((option) => !option.disabled)\n        .every((option) => option.checked);\n      this.currentSelected = option;\n      this.shareIndividualStatus();\n      this.shareChecked();\n    }\n  }\n\n  discardOption(\n    category: IListSelectMultipleNested | null,\n    option: ILCTSelectMultiple\n  ): void {\n    this.showDropDown = !this.showDropDown;\n    if (category) {\n      option.checked = false;\n      category.checkedAll = category.listOptions.every(\n        (option) => option.checked\n      );\n      this.currentSelected = option;\n      this.shareIndividualStatus();\n      this.shareChecked();\n    }\n  }\n\n  // Método para filtrar los datos basados en el nombre de las opciones\n  filterData(value: string): IListSelectMultipleNested[] {\n    if (!value) {\n      return this.list; // Retorna la lista completa si no hay valor de búsqueda\n    }\n\n    // Filtra cada categoría y sus opciones\n    const normalizar = (str: string) =>\n      str\n        .normalize('NFD') // Descompone los caracteres con tilde\n        .replace(/[\\u0300-\\u036f]/g, '') // Elimina los signos diacríticos\n        .toLowerCase();\n\n    return this.list\n      .map((category) => {\n        const filteredOptions = category.listOptions.filter((opt) =>\n          normalizar(opt.name).includes(normalizar(value))\n        );\n\n        return {\n          ...category,\n          listOptions: filteredOptions,\n        };\n      })\n      .filter((category) => category.listOptions.length > 0);\n  }\n\n  applyFilter(): void {\n    this.listFiltered = this.filterData(this.searchValue); // Actualiza la lista filtrada\n  }\n\n  findOptionCategory(\n    option: ILCTSelectMultiple\n  ): IListSelectMultipleNested | null {\n    for (let category of this.list) {\n      if (category.listOptions.includes(option)) {\n        return category;\n      }\n    }\n    return null; // Retornar null si no se encuentra la categoría\n  }\n\n  clickFilterComponent() {\n    this.showDropDown = !this.showDropDown;\n    //Desactivar autofocus externo cuando se muestra el buscador\n    if (this.list.length >= this.quantityToFilter) {\n      this.setAutofocusEvent?.emit(this.showDropDown);\n    }\n  }\n  leaveComponent() {\n    this.showDropDown = false;\n    //Desactivar autofocus externo cuando se muestra el buscador\n    if (this.list.length >= this.quantityToFilter) {\n      this.setAutofocusEvent?.emit(this.showDropDown);\n    }\n  }\n}\n","<div>\n  <div class=\"title\">{{title}}</div>\n  <div class=\"containerSelectMultiple\" (mouseleave)=\"leaveComponent()\">\n    <button [attr.id]=\"selectId\" class=\"drop-toggle\" [disabled]=\"disabledValue\" (click)=\"clickFilterComponent()\">\n      <span *ngIf=\"getListChecked().length<=0\">{{placeholder}}</span>\n      <span *ngIf=\"getListChecked().length>0\">\n        <div class=\"selected\">\n          <span [ngClass]=\"{'text-disabled':getListChecked()[0].disabled || false}\">{{getListChecked()[0].name | labelTitlePipe}}</span>\n          <div class=\"icon\" (click)=\"discardOption(findOptionCategory(getListChecked()[0]), getListChecked()[0])\" [ngClass]=\"{'icon-disabled':getListChecked()[0].disabled || false}\">\n            <svg [ngClass]=\"{'text-disabled':getListChecked()[0].disabled || false}\"\n              width=\"20\"\n              height=\"20\"\n              viewBox=\"0 4 24 24\"\n              fill=\"none\"\n              style=\"color: #2649B6\"\n              xmlns=\"http://www.w3.org/2000/svg\"\n            >\n              <path\n                d=\"M6.2253 4.81108C5.83477 4.42056 5.20161 4.42056 4.81108 4.81108C4.42056 5.20161 4.42056 5.83477 4.81108 6.2253L10.5858 12L4.81114 17.7747C4.42062 18.1652 4.42062 18.7984 4.81114 19.1889C5.20167 19.5794 5.83483 19.5794 6.22535 19.1889L12 13.4142L17.7747 19.1889C18.1652 19.5794 18.7984 19.5794 19.1889 19.1889C19.5794 18.7984 19.5794 18.1652 19.1889 17.7747L13.4142 12L19.189 6.2253C19.5795 5.83477 19.5795 5.20161 19.189 4.81108C18.7985 4.42056 18.1653 4.42056 17.7748 4.81108L12 10.5858L6.2253 4.81108Z\"\n                fill=\"currentColor\"\n              />\n            </svg>\n          </div>\n        </div>\n        <span class=\"moreSelected\" *ngIf=\"getListChecked().length > 1 \">(+ {{getListChecked().length - 1}} más)</span>\n        <!--{{getListChecked().join(', ')}}-->\n      </span>\n      <img *ngIf=\"showIcon\"\n           class=\"select-box__icon\"\n           [ngStyle]=\"{'transform': showDropDown ? 'translateY(-50%) rotate(180deg)' : 'translateY(-50%) rotate(0deg)' }\"\n           src=\"data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4NCjwhLS0gU3ZnIFZlY3RvciBJY29ucyA6IGh0dHA6Ly93d3cub25saW5ld2ViZm9udHMuY29tL2ljb24gLS0+DQo8IURPQ1RZUEUgc3ZnIFBVQkxJQyAiLS8vVzNDLy9EVEQgU1ZHIDEuMS8vRU4iICJodHRwOi8vd3d3LnczLm9yZy9HcmFwaGljcy9TVkcvMS4xL0RURC9zdmcxMS5kdGQiPg0KPHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4IiB2aWV3Qm94PSIwIDAgMTAwMCAxMDAwIiBlbmFibGUtYmFja2dyb3VuZD0ibmV3IDAgMCAxMDAwIDEwMDAiIHhtbDpzcGFjZT0icHJlc2VydmUiPg0KPG1ldGFkYXRhPiBTdmcgVmVjdG9yIEljb25zIDogaHR0cDovL3d3dy5vbmxpbmV3ZWJmb250cy5jb20vaWNvbiA8L21ldGFkYXRhPg0KPGc+PHBhdGggZD0iTTUwMCw3NzUuNEwxMCwyODcuMmw2NC40LTYyLjZMNTAwLDY1MC4ybDQyNS42LTQyNS42bDY0LjQsNjIuNkw1MDAsNzc1LjR6Ii8+PC9nPg0KPC9zdmc+\" alt=\"Arrow Icon\"\n           aria-hidden=\"true\"/>\n    </button>\n    <div class=\"drop-show\" *ngIf=\"showDropDown && list.length>0\">\n      <div *ngIf=\"getTotalCategoryCount()>=quantityToFilter\" class=\"main\">\n        <lct-input-text [placeholder]=\"placeholderFilter\" title=\"\"\n                        [(ngModel)]=\"searchValue\"\n                        (ngModelChange)=\"applyFilter()\"\n                        [icon]=\"iconFinder\"\n                        [showIcon]=\"true\"\n        ></lct-input-text>\n      </div>\n      <div [ngStyle]=\"{'height': getTotalCategoryCount()>=quantityToFilter ? heightOptions : 'auto','overflow-y':getTotalCategoryCount()>=quantityToFilter ? 'auto':''}\">\n        <div *ngFor=\"let category of listFiltered\">\n          <div style=\"display: inline-flex;\">\n            <svg [ngStyle]=\"{'transform': category.open ? 'translateY(25%) rotate(180deg)' : 'translateY(25%) rotate(0deg)' }\"\n                (click)=\"toggleCategory(category)\" class=\"select-box__category\"\n              width=\"17\" height=\"18\" viewBox=\"0 0 17 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n              <path d=\"M13.459 7.58398L8.50065 11.834L3.54232 7.58398\" stroke=\"#2649B6\" stroke-width=\"1.3\" stroke-linecap=\"round\"/>\n            </svg>\n            <!-- <img *ngIf=\"showIcon\"\n             class=\"select-box__category\"\n             [ngStyle]=\"{'transform': category.open ? 'translateY(32%) rotate(180deg)' : 'translateY(32%) rotate(0deg)' }\"\n             src=\"data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4NCjwhLS0gU3ZnIFZlY3RvciBJY29ucyA6IGh0dHA6Ly93d3cub25saW5ld2ViZm9udHMuY29tL2ljb24gLS0+DQo8IURPQ1RZUEUgc3ZnIFBVQkxJQyAiLS8vVzNDLy9EVEQgU1ZHIDEuMS8vRU4iICJodHRwOi8vd3d3LnczLm9yZy9HcmFwaGljcy9TVkcvMS4xL0RURC9zdmcxMS5kdGQiPg0KPHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4IiB2aWV3Qm94PSIwIDAgMTAwMCAxMDAwIiBlbmFibGUtYmFja2dyb3VuZD0ibmV3IDAgMCAxMDAwIDEwMDAiIHhtbDpzcGFjZT0icHJlc2VydmUiPg0KPG1ldGFkYXRhPiBTdmcgVmVjdG9yIEljb25zIDogaHR0cDovL3d3dy5vbmxpbmV3ZWJmb250cy5jb20vaWNvbiA8L21ldGFkYXRhPg0KPGc+PHBhdGggZD0iTTUwMCw3NzUuNEwxMCwyODcuMmw2NC40LTYyLjZMNTAwLDY1MC4ybDQyNS42LTQyNS42bDY0LjQsNjIuNkw1MDAsNzc1LjR6Ii8+PC9nPg0KPC9zdmc+\" alt=\"Arrow Icon\"\n             aria-hidden=\"true\" height=\"17px\" width=\"17px\" (click)=\"toggleCategory(category)\"/> -->\n            <label class=\"main\">\n              <span class=\"text-capitalize\" style=\"margin-left: 21px;\">{{ category.name.toLowerCase() | labelPipe }} </span>\n              <span *ngIf=\"category.quantity\">({{category.quantity}})</span>\n              <input type=\"checkbox\" [(ngModel)]=\"category.checkedAll\"\n                     (change)=\"toggleAllOptions(category)\" [disabled]=\"category.disabled || false || searchValue.length > 0\">\n              <span class=\"mark\" [ngClass]=\"{'mark-disabled': category.disabled || false || searchValue.length > 0}\"></span>\n            </label>\n          </div>\n\n          <ul *ngIf=\"category.open\">\n            <label class=\"main\" *ngFor=\"let option of category.listOptions\">\n              <span class=\"text-capitalize\" style=\"margin-left: 21px;\" [ngClass]=\"{ 'text-disabled': option.disabled }\">{{ option.name.toLowerCase() | labelPipe }} </span>\n              <span *ngIf=\"option.quantity\">({{option.quantity}})</span>\n              <input type=\"checkbox\" [(ngModel)]=\"option.checked\"\n                (change)=\"toggleOption(category, option)\" [disabled]=\"option.disabled || false\"/>\n              <span class=\"mark\" [ngClass]=\"{'mark-disabled': option.disabled || false}\"></span>\n            </label>\n          </ul>\n\n        </div>\n\n      </div>\n    </div>\n    <div class=\"drop-empty\" *ngIf=\"showDropDown && list.length===0\">\n      Sin información\n    </div>\n  </div>\n</div>\n"]}