@c80/ui 1.0.34 → 1.0.37
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/icon/icon.component.mjs +65 -205
- package/esm2022/lib/icon/icon.constants.mjs +38 -0
- package/esm2022/lib/icon/icon.types.mjs +2 -0
- package/esm2022/lib/icon/index.mjs +3 -1
- package/esm2022/lib/stat-card/stat-card.component.mjs +1 -1
- package/esm2022/lib/table/table-column-visibility.service.mjs +1 -1
- package/esm2022/lib/table/table-crud-state.service.mjs +97 -76
- package/esm2022/lib/table/table-data-converter.service.mjs +9 -13
- package/esm2022/lib/table/table-data-utils.service.mjs +4 -4
- package/esm2022/lib/table/table-selection.service.mjs +53 -66
- package/esm2022/lib/table/table.component.mjs +24 -7
- package/lib/icon/icon.component.d.ts +38 -44
- package/lib/icon/icon.constants.d.ts +9 -0
- package/lib/icon/icon.types.d.ts +4 -0
- package/lib/icon/index.d.ts +2 -0
- package/lib/stat-card/stat-card.component.d.ts +2 -2
- package/lib/table/table-crud-state.service.d.ts +25 -0
- package/lib/table/table-data-utils.service.d.ts +1 -1
- package/lib/table/table-selection.service.d.ts +14 -8
- package/lib/table/table.component.d.ts +10 -1
- package/package.json +1 -1
|
@@ -18,116 +18,103 @@ export class TableSelectionService {
|
|
|
18
18
|
const selectedItems = signal(new Set());
|
|
19
19
|
const selectAllChecked = signal(false);
|
|
20
20
|
const selectAllIndeterminate = signal(false);
|
|
21
|
-
|
|
22
|
-
selectedItems.
|
|
23
|
-
|
|
21
|
+
return {
|
|
22
|
+
selectedItems: selectedItems.asReadonly(),
|
|
23
|
+
selectAllChecked: selectAllChecked.asReadonly(),
|
|
24
|
+
selectAllIndeterminate: selectAllIndeterminate.asReadonly(),
|
|
25
|
+
clearSelection: this.createClearSelectionFn(selectedItems, selectAllChecked, selectAllIndeterminate),
|
|
26
|
+
toggleSelectAll: this.createToggleSelectAllFn(selectedItems, selectAllChecked, selectAllIndeterminate),
|
|
27
|
+
toggleItemSelection: this.createToggleItemSelectionFn(selectedItems),
|
|
28
|
+
isItemSelected: this.createIsItemSelectedFn(selectedItems),
|
|
29
|
+
preserveSelection: this.createPreserveSelectionFn(selectedItems, selectAllChecked, selectAllIndeterminate),
|
|
30
|
+
getSelectedItems: this.createGetSelectedItemsFn(selectedItems),
|
|
24
31
|
};
|
|
25
|
-
|
|
26
|
-
|
|
32
|
+
}
|
|
33
|
+
createClearSelectionFn(selectedItems, selectAllChecked, selectAllIndeterminate) {
|
|
34
|
+
return () => {
|
|
35
|
+
selectedItems.set(new Set());
|
|
27
36
|
selectAllChecked.set(false);
|
|
28
37
|
selectAllIndeterminate.set(false);
|
|
29
38
|
};
|
|
30
|
-
|
|
39
|
+
}
|
|
40
|
+
createToggleSelectAllFn(selectedItems, selectAllChecked, selectAllIndeterminate) {
|
|
41
|
+
return (allItems) => {
|
|
31
42
|
const currentSelection = selectedItems();
|
|
32
43
|
if (currentSelection.size === allItems.length) {
|
|
33
|
-
|
|
34
|
-
|
|
44
|
+
selectedItems.set(new Set());
|
|
45
|
+
selectAllChecked.set(false);
|
|
46
|
+
selectAllIndeterminate.set(false);
|
|
35
47
|
}
|
|
36
48
|
else {
|
|
37
|
-
// Marcar todos los elementos
|
|
38
49
|
const allIds = new Set(allItems.map(item => item['id']));
|
|
39
50
|
selectedItems.set(allIds);
|
|
40
|
-
|
|
51
|
+
this.updateSelectAllState(allItems, allIds.size, selectAllChecked, selectAllIndeterminate);
|
|
41
52
|
}
|
|
42
53
|
};
|
|
43
|
-
|
|
54
|
+
}
|
|
55
|
+
createToggleItemSelectionFn(selectedItems) {
|
|
56
|
+
return (item, multiple) => {
|
|
44
57
|
const id = item['id'];
|
|
45
58
|
const currentSelection = new Set(selectedItems());
|
|
46
59
|
if (!multiple) {
|
|
47
|
-
// Selección simple: solo permitir un elemento seleccionado
|
|
48
60
|
if (currentSelection.has(id)) {
|
|
49
|
-
// Deseleccionar el elemento actual
|
|
50
61
|
currentSelection.clear();
|
|
51
62
|
}
|
|
52
63
|
else {
|
|
53
|
-
// Seleccionar solo este elemento
|
|
54
64
|
currentSelection.clear();
|
|
55
65
|
currentSelection.add(id);
|
|
56
66
|
}
|
|
57
67
|
}
|
|
58
68
|
else if (currentSelection.has(id)) {
|
|
59
|
-
// Selección múltiple: deseleccionar elemento existente
|
|
60
69
|
currentSelection.delete(id);
|
|
61
70
|
}
|
|
62
71
|
else {
|
|
63
|
-
// Selección múltiple: agregar nuevo elemento
|
|
64
72
|
currentSelection.add(id);
|
|
65
73
|
}
|
|
66
74
|
selectedItems.set(currentSelection);
|
|
67
75
|
};
|
|
68
|
-
|
|
76
|
+
}
|
|
77
|
+
createIsItemSelectedFn(selectedItems) {
|
|
78
|
+
return (item) => {
|
|
69
79
|
const id = item['id'];
|
|
70
80
|
return selectedItems().has(id);
|
|
71
81
|
};
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
if (selectedCount === 0) {
|
|
76
|
-
selectAllChecked.set(false);
|
|
77
|
-
selectAllIndeterminate.set(false);
|
|
78
|
-
}
|
|
79
|
-
else if (selectedCount === totalCount) {
|
|
80
|
-
selectAllChecked.set(true);
|
|
81
|
-
selectAllIndeterminate.set(false);
|
|
82
|
-
}
|
|
83
|
-
else {
|
|
84
|
-
selectAllChecked.set(false);
|
|
85
|
-
selectAllIndeterminate.set(true);
|
|
86
|
-
}
|
|
87
|
-
};
|
|
88
|
-
const preserveSelection = (newData) => {
|
|
82
|
+
}
|
|
83
|
+
createPreserveSelectionFn(selectedItems, selectAllChecked, selectAllIndeterminate) {
|
|
84
|
+
return (newData) => {
|
|
89
85
|
const currentSelection = selectedItems();
|
|
90
86
|
if (currentSelection.size === 0 || newData.length === 0) {
|
|
91
|
-
|
|
92
|
-
|
|
87
|
+
selectedItems.set(new Set());
|
|
88
|
+
selectAllChecked.set(false);
|
|
89
|
+
selectAllIndeterminate.set(false);
|
|
93
90
|
return;
|
|
94
91
|
}
|
|
95
|
-
// Obtener los IDs disponibles en los nuevos datos
|
|
96
92
|
const availableIds = new Set(newData.map(item => item['id']));
|
|
97
|
-
// Filtrar la selección actual para mantener solo los IDs que aún existen
|
|
98
93
|
const preservedSelection = new Set(Array.from(currentSelection).filter(id => availableIds.has(id)));
|
|
99
|
-
// Actualizar la selección con los IDs preservados
|
|
100
94
|
selectedItems.set(preservedSelection);
|
|
101
|
-
|
|
95
|
+
this.updateSelectAllState(newData, preservedSelection.size, selectAllChecked, selectAllIndeterminate);
|
|
102
96
|
};
|
|
103
|
-
|
|
97
|
+
}
|
|
98
|
+
createGetSelectedItemsFn(selectedItems) {
|
|
99
|
+
return (allData) => {
|
|
104
100
|
const selectedIds = selectedItems();
|
|
105
101
|
return allData.filter(item => selectedIds.has(item['id']));
|
|
106
102
|
};
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
const
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
// Métodos
|
|
123
|
-
clearSelection,
|
|
124
|
-
toggleSelectAll,
|
|
125
|
-
toggleItemSelection,
|
|
126
|
-
isItemSelected,
|
|
127
|
-
preserveSelection,
|
|
128
|
-
getSelectedItems,
|
|
129
|
-
updateSelectAllState: updateSelectAllStateWrapper,
|
|
130
|
-
};
|
|
103
|
+
}
|
|
104
|
+
updateSelectAllState(allItems, selectedCount, selectAllChecked, selectAllIndeterminate) {
|
|
105
|
+
const totalCount = allItems.length;
|
|
106
|
+
if (selectedCount === 0) {
|
|
107
|
+
selectAllChecked.set(false);
|
|
108
|
+
selectAllIndeterminate.set(false);
|
|
109
|
+
}
|
|
110
|
+
else if (selectedCount === totalCount) {
|
|
111
|
+
selectAllChecked.set(true);
|
|
112
|
+
selectAllIndeterminate.set(false);
|
|
113
|
+
}
|
|
114
|
+
else {
|
|
115
|
+
selectAllChecked.set(false);
|
|
116
|
+
selectAllIndeterminate.set(true);
|
|
117
|
+
}
|
|
131
118
|
}
|
|
132
119
|
/**
|
|
133
120
|
* Emite los elementos seleccionados a través del EventEmitter proporcionado
|
|
@@ -148,4 +135,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
148
135
|
providedIn: 'root'
|
|
149
136
|
}]
|
|
150
137
|
}] });
|
|
151
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-selection.service.js","sourceRoot":"","sources":["../../../../../libs/ui/src/lib/table/table-selection.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, signal, EventEmitter } from '@angular/core';\nimport { ID } from './table.types';\n\n/**\n * Servicio para gestionar la selección de elementos en tablas C80\n *\n * Maneja:\n * - Selección simple y múltiple\n * - Estado de selección completa\n * - Preservación de selección tras actualizaciones de datos\n * - Emisión de eventos de selección\n */\n@Injectable({\n    providedIn: 'root'\n})\nexport class TableSelectionService {\n\n    /**\n     * Inicializa el estado de selección para una nueva tabla\n     * @returns Objeto con signals y métodos de selección\n     */\n    createSelectionState<T extends Record<string, unknown>>() {\n        const selectedItems = signal<Set<ID>>(new Set());\n        const selectAllChecked = signal(false);\n        const selectAllIndeterminate = signal(false);\n\n        const clearSelection = (): void => {\n            selectedItems.set(new Set());\n            updateSelectAllState();\n        };\n\n        const updateSelectAllState = (): void => {\n            // Esta función será actualizada cuando se tengan los datos disponibles\n            selectAllChecked.set(false);\n            selectAllIndeterminate.set(false);\n        };\n\n        const toggleSelectAll = (allItems: T[]): void => {\n            const currentSelection = selectedItems();\n\n            if (currentSelection.size === allItems.length) {\n                // Desmarcar todos los elementos\n                clearSelection();\n            } else {\n                // Marcar todos los elementos\n                const allIds = new Set(allItems.map(item => item['id'] as ID));\n                selectedItems.set(allIds);\n                updateSelectAllStateWithData(allItems);\n            }\n        };\n\n        const toggleItemSelection = (item: T, multiple: boolean): void => {\n            const id = item['id'] as ID;\n            const currentSelection = new Set(selectedItems());\n\n            if (!multiple) {\n                // Selección simple: solo permitir un elemento seleccionado\n                if (currentSelection.has(id)) {\n                    // Deseleccionar el elemento actual\n                    currentSelection.clear();\n                } else {\n                    // Seleccionar solo este elemento\n                    currentSelection.clear();\n                    currentSelection.add(id);\n                }\n            } else if (currentSelection.has(id)) {\n                // Selección múltiple: deseleccionar elemento existente\n                currentSelection.delete(id);\n            } else {\n                // Selección múltiple: agregar nuevo elemento\n                currentSelection.add(id);\n            }\n\n            selectedItems.set(currentSelection);\n        };\n\n        const isItemSelected = (item: T): boolean => {\n            const id = item['id'] as ID;\n            return selectedItems().has(id);\n        };\n\n        const updateSelectAllStateWithData = (allItems: T[]): void => {\n            const selectedCount = selectedItems().size;\n            const totalCount = allItems.length;\n\n            if (selectedCount === 0) {\n                selectAllChecked.set(false);\n                selectAllIndeterminate.set(false);\n            } else if (selectedCount === totalCount) {\n                selectAllChecked.set(true);\n                selectAllIndeterminate.set(false);\n            } else {\n                selectAllChecked.set(false);\n                selectAllIndeterminate.set(true);\n            }\n        };\n\n        const preserveSelection = (newData: T[]): void => {\n            const currentSelection = selectedItems();\n\n            if (currentSelection.size === 0 || newData.length === 0) {\n                // Si no hay selección o no hay datos, limpiar la selección\n                clearSelection();\n                return;\n            }\n\n            // Obtener los IDs disponibles en los nuevos datos\n            const availableIds = new Set(newData.map(item => item['id'] as ID));\n\n            // Filtrar la selección actual para mantener solo los IDs que aún existen\n            const preservedSelection = new Set(\n                Array.from(currentSelection).filter(id => availableIds.has(id))\n            );\n\n            // Actualizar la selección con los IDs preservados\n            selectedItems.set(preservedSelection);\n            updateSelectAllStateWithData(newData);\n        };\n\n        const getSelectedItems = (allData: T[]): T[] => {\n            const selectedIds = selectedItems();\n            return allData.filter(item => selectedIds.has(item['id'] as ID));\n        };\n\n        // Redefinir updateSelectAllState con acceso a los datos\n        const originalUpdateSelectAllState = updateSelectAllState;\n        const updateSelectAllStateWrapper = (allItems?: T[]): void => {\n            if (allItems) {\n                updateSelectAllStateWithData(allItems);\n            } else {\n                originalUpdateSelectAllState();\n            }\n        };\n\n        return {\n            // Signals\n            selectedItems: selectedItems.asReadonly(),\n            selectAllChecked: selectAllChecked.asReadonly(),\n            selectAllIndeterminate: selectAllIndeterminate.asReadonly(),\n\n            // Métodos\n            clearSelection,\n            toggleSelectAll,\n            toggleItemSelection,\n            isItemSelected,\n            preserveSelection,\n            getSelectedItems,\n            updateSelectAllState: updateSelectAllStateWrapper,\n        };\n    }\n\n    /**\n     * Emite los elementos seleccionados a través del EventEmitter proporcionado\n     * @param selectionState - Estado de selección\n     * @param allData - Todos los datos de la tabla\n     * @param selectableEmitter - EventEmitter para emitir la selección\n     */\n    emitSelection<T extends Record<string, unknown>>(\n        selectionState: ReturnType<typeof this.createSelectionState<T>>,\n        allData: T[],\n        selectableEmitter: EventEmitter<T[]>\n    ): void {\n        const selectedItems = selectionState.getSelectedItems(allData);\n        selectableEmitter.emit(selectedItems);\n    }\n}\n"]}
|
|
138
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-selection.service.js","sourceRoot":"","sources":["../../../../../libs/ui/src/lib/table/table-selection.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, signal, EventEmitter } from '@angular/core';\nimport { ID } from './table.types';\n\n/**\n * Servicio para gestionar la selección de elementos en tablas C80\n *\n * Maneja:\n * - Selección simple y múltiple\n * - Estado de selección completa\n * - Preservación de selección tras actualizaciones de datos\n * - Emisión de eventos de selección\n */\n@Injectable({\n    providedIn: 'root'\n})\nexport class TableSelectionService {\n\n    /**\n     * Inicializa el estado de selección para una nueva tabla\n     * @returns Objeto con signals y métodos de selección\n     */\n    createSelectionState<_T extends Record<string, unknown>>() {\n        const selectedItems = signal<Set<ID>>(new Set());\n        const selectAllChecked = signal(false);\n        const selectAllIndeterminate = signal(false);\n\n        return {\n            selectedItems: selectedItems.asReadonly(),\n            selectAllChecked: selectAllChecked.asReadonly(),\n            selectAllIndeterminate: selectAllIndeterminate.asReadonly(),\n            clearSelection: this.createClearSelectionFn(selectedItems, selectAllChecked, selectAllIndeterminate),\n            toggleSelectAll: this.createToggleSelectAllFn(selectedItems, selectAllChecked, selectAllIndeterminate),\n            toggleItemSelection: this.createToggleItemSelectionFn(selectedItems),\n            isItemSelected: this.createIsItemSelectedFn(selectedItems),\n            preserveSelection: this.createPreserveSelectionFn(selectedItems, selectAllChecked, selectAllIndeterminate),\n            getSelectedItems: this.createGetSelectedItemsFn(selectedItems),\n        };\n    }\n\n    private createClearSelectionFn(\n        selectedItems: ReturnType<typeof signal<Set<ID>>>,\n        selectAllChecked: ReturnType<typeof signal<boolean>>,\n        selectAllIndeterminate: ReturnType<typeof signal<boolean>>\n    ) {\n        return (): void => {\n            selectedItems.set(new Set());\n            selectAllChecked.set(false);\n            selectAllIndeterminate.set(false);\n        };\n    }\n\n    private createToggleSelectAllFn<T extends Record<string, unknown>>(\n        selectedItems: ReturnType<typeof signal<Set<ID>>>,\n        selectAllChecked: ReturnType<typeof signal<boolean>>,\n        selectAllIndeterminate: ReturnType<typeof signal<boolean>>\n    ) {\n        return (allItems: T[]): void => {\n            const currentSelection = selectedItems();\n\n            if (currentSelection.size === allItems.length) {\n                selectedItems.set(new Set());\n                selectAllChecked.set(false);\n                selectAllIndeterminate.set(false);\n            } else {\n                const allIds = new Set(allItems.map(item => item['id'] as ID));\n                selectedItems.set(allIds);\n                this.updateSelectAllState(allItems, allIds.size, selectAllChecked, selectAllIndeterminate);\n            }\n        };\n    }\n\n    private createToggleItemSelectionFn<T extends Record<string, unknown>>(\n        selectedItems: ReturnType<typeof signal<Set<ID>>>\n    ) {\n        return (item: T, multiple: boolean): void => {\n            const id = item['id'] as ID;\n            const currentSelection = new Set(selectedItems());\n\n            if (!multiple) {\n                if (currentSelection.has(id)) {\n                    currentSelection.clear();\n                } else {\n                    currentSelection.clear();\n                    currentSelection.add(id);\n                }\n            } else if (currentSelection.has(id)) {\n                currentSelection.delete(id);\n            } else {\n                currentSelection.add(id);\n            }\n\n            selectedItems.set(currentSelection);\n        };\n    }\n\n    private createIsItemSelectedFn<T extends Record<string, unknown>>(\n        selectedItems: ReturnType<typeof signal<Set<ID>>>\n    ) {\n        return (item: T): boolean => {\n            const id = item['id'] as ID;\n            return selectedItems().has(id);\n        };\n    }\n\n    private createPreserveSelectionFn<T extends Record<string, unknown>>(\n        selectedItems: ReturnType<typeof signal<Set<ID>>>,\n        selectAllChecked: ReturnType<typeof signal<boolean>>,\n        selectAllIndeterminate: ReturnType<typeof signal<boolean>>\n    ) {\n        return (newData: T[]): void => {\n            const currentSelection = selectedItems();\n\n            if (currentSelection.size === 0 || newData.length === 0) {\n                selectedItems.set(new Set());\n                selectAllChecked.set(false);\n                selectAllIndeterminate.set(false);\n                return;\n            }\n\n            const availableIds = new Set(newData.map(item => item['id'] as ID));\n            const preservedSelection = new Set(\n                Array.from(currentSelection).filter(id => availableIds.has(id))\n            );\n\n            selectedItems.set(preservedSelection);\n            this.updateSelectAllState(newData, preservedSelection.size, selectAllChecked, selectAllIndeterminate);\n        };\n    }\n\n    private createGetSelectedItemsFn<T extends Record<string, unknown>>(\n        selectedItems: ReturnType<typeof signal<Set<ID>>>\n    ) {\n        return (allData: T[]): T[] => {\n            const selectedIds = selectedItems();\n            return allData.filter(item => selectedIds.has(item['id'] as ID));\n        };\n    }\n\n    private updateSelectAllState<T extends Record<string, unknown>>(\n        allItems: T[],\n        selectedCount: number,\n        selectAllChecked: ReturnType<typeof signal<boolean>>,\n        selectAllIndeterminate: ReturnType<typeof signal<boolean>>\n    ): void {\n        const totalCount = allItems.length;\n\n        if (selectedCount === 0) {\n            selectAllChecked.set(false);\n            selectAllIndeterminate.set(false);\n        } else if (selectedCount === totalCount) {\n            selectAllChecked.set(true);\n            selectAllIndeterminate.set(false);\n        } else {\n            selectAllChecked.set(false);\n            selectAllIndeterminate.set(true);\n        }\n    }\n\n    /**\n     * Emite los elementos seleccionados a través del EventEmitter proporcionado\n     * @param selectionState - Estado de selección\n     * @param allData - Todos los datos de la tabla\n     * @param selectableEmitter - EventEmitter para emitir la selección\n     */\n    emitSelection<T extends Record<string, unknown>>(\n        selectionState: ReturnType<typeof this.createSelectionState>,\n        allData: T[],\n        selectableEmitter: EventEmitter<T[]>\n    ): void {\n        const selectedItems = selectionState.getSelectedItems(allData) as T[];\n        selectableEmitter.emit(selectedItems);\n    }\n}\n"]}
|