@libs-ui/components-list 0.2.64 → 0.2.65

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.
Files changed (28) hide show
  1. package/defines/list.define.d.ts +2 -1
  2. package/esm2022/defines/list.define.mjs +14 -13
  3. package/esm2022/interfaces/config-item.interface.mjs +1 -1
  4. package/esm2022/list.component.mjs +40 -18
  5. package/esm2022/templates/checkbox/checkbox.component.mjs +10 -9
  6. package/esm2022/templates/group/group.component.mjs +773 -0
  7. package/esm2022/templates/group/item/item.component.mjs +77 -0
  8. package/esm2022/templates/group/pipes/calculator-left-line-vertical-item.pipe.mjs +38 -0
  9. package/esm2022/templates/group/pipes/calculator-margin-left-item.pipe.mjs +40 -0
  10. package/esm2022/templates/group/pipes/calculator-padding-left-item.pipe.mjs +26 -0
  11. package/esm2022/templates/radio/radio.component.mjs +5 -5
  12. package/esm2022/templates/rows/rows.component.mjs +4 -4
  13. package/esm2022/templates/tag/tag.component.mjs +3 -3
  14. package/esm2022/templates/templates.component.abstract.mjs +21 -16
  15. package/esm2022/templates/text/text.component.mjs +4 -4
  16. package/fesm2022/libs-ui-components-list.mjs +1013 -69
  17. package/fesm2022/libs-ui-components-list.mjs.map +1 -1
  18. package/interfaces/config-item.interface.d.ts +24 -29
  19. package/list.component.d.ts +2 -2
  20. package/package.json +1 -1
  21. package/templates/checkbox/checkbox.component.d.ts +1 -1
  22. package/templates/group/group.component.d.ts +50 -0
  23. package/templates/group/item/item.component.d.ts +27 -0
  24. package/templates/group/pipes/calculator-left-line-vertical-item.pipe.d.ts +7 -0
  25. package/templates/group/pipes/calculator-margin-left-item.pipe.d.ts +7 -0
  26. package/templates/group/pipes/calculator-padding-left-item.pipe.d.ts +7 -0
  27. package/templates/rows/rows.component.d.ts +2 -2
  28. package/templates/templates.component.abstract.d.ts +1 -1
@@ -1,9 +1,10 @@
1
1
  import { TYPE_TEMPLATE } from "../interfaces/templates-type.type";
2
2
  import { LibsUiComponentsListCheckboxComponent } from "../templates/checkbox/checkbox.component";
3
+ import { LibsUiComponentsListGroupComponent } from "../templates/group/group.component";
3
4
  import { LibsUiComponentsListRadioComponent } from "../templates/radio/radio.component";
4
5
  import { LibsUiComponentsListTagComponent } from "../templates/tag/tag.component";
5
6
  import { LibsUiComponentsListTextComponent } from "../templates/text/text.component";
6
7
  import { IListConfigItem } from './../interfaces/config-item.interface';
7
- export declare const getComponentByType: (typeTemplate: TYPE_TEMPLATE) => typeof LibsUiComponentsListCheckboxComponent | typeof LibsUiComponentsListRadioComponent | typeof LibsUiComponentsListTagComponent | typeof LibsUiComponentsListTextComponent;
8
+ export declare const getComponentByType: (typeTemplate: TYPE_TEMPLATE) => typeof LibsUiComponentsListCheckboxComponent | typeof LibsUiComponentsListGroupComponent | typeof LibsUiComponentsListRadioComponent | typeof LibsUiComponentsListTextComponent | typeof LibsUiComponentsListTagComponent;
8
9
  export declare const getFieldKeyByType: (config: IListConfigItem | undefined, fieldKeyDefault: string) => string;
9
10
  export declare const initConfig: (config: IListConfigItem) => void;
@@ -1,4 +1,5 @@
1
1
  import { LibsUiComponentsListCheckboxComponent } from "../templates/checkbox/checkbox.component";
2
+ import { LibsUiComponentsListGroupComponent } from "../templates/group/group.component";
2
3
  import { LibsUiComponentsListRadioComponent } from "../templates/radio/radio.component";
3
4
  import { LibsUiComponentsListTagComponent } from "../templates/tag/tag.component";
4
5
  import { LibsUiComponentsListTextComponent } from "../templates/text/text.component";
@@ -7,7 +8,7 @@ export const getComponentByType = (typeTemplate) => {
7
8
  case 'checkbox':
8
9
  return LibsUiComponentsListCheckboxComponent;
9
10
  case 'group':
10
- return LibsUiComponentsListTextComponent;
11
+ return LibsUiComponentsListGroupComponent;
11
12
  case 'radio':
12
13
  return LibsUiComponentsListRadioComponent;
13
14
  case 'text':
@@ -22,15 +23,15 @@ export const getFieldKeyByType = (config, fieldKeyDefault) => {
22
23
  }
23
24
  switch (config.type) {
24
25
  case 'checkbox':
25
- return config.configTemplateCheckbox?.fieldKey || fieldKeyDefault;
26
+ return config.configTemplateCheckbox?.()?.fieldKey || fieldKeyDefault;
26
27
  case 'group':
27
- return config.configTemplateGroup?.fieldKey || fieldKeyDefault;
28
+ return config.configTemplateGroup?.()?.fieldKey || fieldKeyDefault;
28
29
  case 'radio':
29
- return config.configTemplateRadio?.fieldKey || fieldKeyDefault;
30
+ return config.configTemplateRadio?.()?.fieldKey || fieldKeyDefault;
30
31
  case 'text':
31
- return config.configTemplateText?.fieldKey || fieldKeyDefault;
32
+ return config.configTemplateText?.()?.fieldKey || fieldKeyDefault;
32
33
  case 'tag':
33
- return config.configTemplateTag?.fieldKey || fieldKeyDefault;
34
+ return config.configTemplateTag?.()?.fieldKey || fieldKeyDefault;
34
35
  }
35
36
  };
36
37
  export const initConfig = (config) => {
@@ -48,22 +49,22 @@ export const initConfig = (config) => {
48
49
  };
49
50
  switch (config.type) {
50
51
  case 'checkbox':
51
- if (!config.configTemplateCheckbox) {
52
- config.configTemplateCheckbox = defaultConfig;
52
+ if (!config.configTemplateCheckbox?.()) {
53
+ config.configTemplateCheckbox?.set(defaultConfig);
53
54
  }
54
55
  break;
55
56
  case 'group':
56
57
  break;
57
58
  case 'radio':
58
- if (!config.configTemplateRadio) {
59
- config.configTemplateRadio = defaultConfig;
59
+ if (!config.configTemplateRadio?.()) {
60
+ config.configTemplateRadio?.set(defaultConfig);
60
61
  }
61
62
  break;
62
63
  case 'text':
63
- if (!config.configTemplateText) {
64
- config.configTemplateText = defaultConfig;
64
+ if (!config.configTemplateText?.()) {
65
+ config.configTemplateText?.set(defaultConfig);
65
66
  }
66
67
  break;
67
68
  }
68
69
  };
69
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC5kZWZpbmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvbGlzdC9zcmMvZGVmaW5lcy9saXN0LmRlZmluZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUUscUNBQXFDLEVBQUUsTUFBTSwwQ0FBMEMsQ0FBQztBQUNqRyxPQUFPLEVBQUUsa0NBQWtDLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUN4RixPQUFPLEVBQUUsZ0NBQWdDLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNsRixPQUFPLEVBQUUsaUNBQWlDLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUdyRixNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxDQUFDLFlBQTJCLEVBQUUsRUFBRTtJQUNoRSxRQUFRLFlBQVksRUFBRSxDQUFDO1FBQ3JCLEtBQUssVUFBVTtZQUNiLE9BQU8scUNBQXFDLENBQUM7UUFFL0MsS0FBSyxPQUFPO1lBQ1YsT0FBTyxpQ0FBaUMsQ0FBQztRQUUzQyxLQUFLLE9BQU87WUFDVixPQUFPLGtDQUFrQyxDQUFDO1FBRTVDLEtBQUssTUFBTTtZQUNULE9BQU8saUNBQWlDLENBQUM7UUFFM0MsS0FBSyxLQUFLO1lBQ1IsT0FBTyxnQ0FBZ0MsQ0FBQztJQUM1QyxDQUFDO0FBRUgsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsQ0FBQyxNQUFtQyxFQUFFLGVBQXVCLEVBQVUsRUFBRTtJQUN4RyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDWixPQUFPLGVBQWUsQ0FBQztJQUN6QixDQUFDO0lBQ0QsUUFBUSxNQUFNLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDcEIsS0FBSyxVQUFVO1lBQ2IsT0FBTyxNQUFNLENBQUMsc0JBQXNCLEVBQUUsUUFBUSxJQUFJLGVBQWUsQ0FBQztRQUVwRSxLQUFLLE9BQU87WUFDVixPQUFPLE1BQU0sQ0FBQyxtQkFBbUIsRUFBRSxRQUFRLElBQUksZUFBZSxDQUFDO1FBRWpFLEtBQUssT0FBTztZQUNWLE9BQU8sTUFBTSxDQUFDLG1CQUFtQixFQUFFLFFBQVEsSUFBSSxlQUFlLENBQUM7UUFFakUsS0FBSyxNQUFNO1lBQ1QsT0FBTyxNQUFNLENBQUMsa0JBQWtCLEVBQUUsUUFBUSxJQUFJLGVBQWUsQ0FBQztRQUVoRSxLQUFLLEtBQUs7WUFDUixPQUFPLE1BQU0sQ0FBQyxpQkFBaUIsRUFBRSxRQUFRLElBQUksZUFBZSxDQUFDO0lBQ2pFLENBQUM7QUFFSCxDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUcsQ0FBQyxNQUF1QixFQUFRLEVBQUU7SUFDMUQsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ1osT0FBTztJQUNULENBQUM7SUFFRCxNQUFNLGFBQWEsR0FBRztRQUNwQixRQUFRLEVBQUUsSUFBSTtRQUNkLFFBQVEsRUFBRSxDQUFDLElBQVMsRUFBVSxFQUFFO1lBQzlCLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztnQkFDVixPQUFPLEdBQUcsQ0FBQztZQUNiLENBQUM7WUFFRCxPQUFPLElBQUksQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDLElBQUksSUFBSSxHQUFHLENBQUM7UUFDeEMsQ0FBQztLQUNGLENBQUM7SUFFRixRQUFRLE1BQU0sQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUVwQixLQUFLLFVBQVU7WUFDYixJQUFJLENBQUMsTUFBTSxDQUFDLHNCQUFzQixFQUFFLENBQUM7Z0JBQ25DLE1BQU0sQ0FBQyxzQkFBc0IsR0FBRyxhQUFhLENBQUM7WUFDaEQsQ0FBQztZQUNELE1BQU07UUFFUixLQUFLLE9BQU87WUFDVixNQUFNO1FBRVIsS0FBSyxPQUFPO1lBQ1YsSUFBSSxDQUFDLE1BQU0sQ0FBQyxtQkFBbUIsRUFBRSxDQUFDO2dCQUNoQyxNQUFNLENBQUMsbUJBQW1CLEdBQUcsYUFBYSxDQUFDO1lBQzdDLENBQUM7WUFDRCxNQUFNO1FBRVIsS0FBSyxNQUFNO1lBQ1QsSUFBSSxDQUFDLE1BQU0sQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO2dCQUMvQixNQUFNLENBQUMsa0JBQWtCLEdBQUcsYUFBYSxDQUFDO1lBQzVDLENBQUM7WUFDRCxNQUFNO0lBQ1YsQ0FBQztBQUNILENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnkgKi9cbmltcG9ydCB7IFRZUEVfVEVNUExBVEUgfSBmcm9tIFwiLi4vaW50ZXJmYWNlcy90ZW1wbGF0ZXMtdHlwZS50eXBlXCI7XG5pbXBvcnQgeyBMaWJzVWlDb21wb25lbnRzTGlzdENoZWNrYm94Q29tcG9uZW50IH0gZnJvbSBcIi4uL3RlbXBsYXRlcy9jaGVja2JveC9jaGVja2JveC5jb21wb25lbnRcIjtcbmltcG9ydCB7IExpYnNVaUNvbXBvbmVudHNMaXN0UmFkaW9Db21wb25lbnQgfSBmcm9tIFwiLi4vdGVtcGxhdGVzL3JhZGlvL3JhZGlvLmNvbXBvbmVudFwiO1xuaW1wb3J0IHsgTGlic1VpQ29tcG9uZW50c0xpc3RUYWdDb21wb25lbnQgfSBmcm9tIFwiLi4vdGVtcGxhdGVzL3RhZy90YWcuY29tcG9uZW50XCI7XG5pbXBvcnQgeyBMaWJzVWlDb21wb25lbnRzTGlzdFRleHRDb21wb25lbnQgfSBmcm9tIFwiLi4vdGVtcGxhdGVzL3RleHQvdGV4dC5jb21wb25lbnRcIjtcbmltcG9ydCB7IElMaXN0Q29uZmlnSXRlbSB9IGZyb20gJy4vLi4vaW50ZXJmYWNlcy9jb25maWctaXRlbS5pbnRlcmZhY2UnO1xuXG5leHBvcnQgY29uc3QgZ2V0Q29tcG9uZW50QnlUeXBlID0gKHR5cGVUZW1wbGF0ZTogVFlQRV9URU1QTEFURSkgPT4ge1xuICBzd2l0Y2ggKHR5cGVUZW1wbGF0ZSkge1xuICAgIGNhc2UgJ2NoZWNrYm94JzpcbiAgICAgIHJldHVybiBMaWJzVWlDb21wb25lbnRzTGlzdENoZWNrYm94Q29tcG9uZW50O1xuXG4gICAgY2FzZSAnZ3JvdXAnOlxuICAgICAgcmV0dXJuIExpYnNVaUNvbXBvbmVudHNMaXN0VGV4dENvbXBvbmVudDtcblxuICAgIGNhc2UgJ3JhZGlvJzpcbiAgICAgIHJldHVybiBMaWJzVWlDb21wb25lbnRzTGlzdFJhZGlvQ29tcG9uZW50O1xuXG4gICAgY2FzZSAndGV4dCc6XG4gICAgICByZXR1cm4gTGlic1VpQ29tcG9uZW50c0xpc3RUZXh0Q29tcG9uZW50O1xuXG4gICAgY2FzZSAndGFnJzpcbiAgICAgIHJldHVybiBMaWJzVWlDb21wb25lbnRzTGlzdFRhZ0NvbXBvbmVudDtcbiAgfVxuXG59O1xuXG5leHBvcnQgY29uc3QgZ2V0RmllbGRLZXlCeVR5cGUgPSAoY29uZmlnOiBJTGlzdENvbmZpZ0l0ZW0gfCB1bmRlZmluZWQsIGZpZWxkS2V5RGVmYXVsdDogc3RyaW5nKTogc3RyaW5nID0+IHtcbiAgaWYgKCFjb25maWcpIHtcbiAgICByZXR1cm4gZmllbGRLZXlEZWZhdWx0O1xuICB9XG4gIHN3aXRjaCAoY29uZmlnLnR5cGUpIHtcbiAgICBjYXNlICdjaGVja2JveCc6XG4gICAgICByZXR1cm4gY29uZmlnLmNvbmZpZ1RlbXBsYXRlQ2hlY2tib3g/LmZpZWxkS2V5IHx8IGZpZWxkS2V5RGVmYXVsdDtcblxuICAgIGNhc2UgJ2dyb3VwJzpcbiAgICAgIHJldHVybiBjb25maWcuY29uZmlnVGVtcGxhdGVHcm91cD8uZmllbGRLZXkgfHwgZmllbGRLZXlEZWZhdWx0O1xuXG4gICAgY2FzZSAncmFkaW8nOlxuICAgICAgcmV0dXJuIGNvbmZpZy5jb25maWdUZW1wbGF0ZVJhZGlvPy5maWVsZEtleSB8fCBmaWVsZEtleURlZmF1bHQ7XG5cbiAgICBjYXNlICd0ZXh0JzpcbiAgICAgIHJldHVybiBjb25maWcuY29uZmlnVGVtcGxhdGVUZXh0Py5maWVsZEtleSB8fCBmaWVsZEtleURlZmF1bHQ7XG5cbiAgICBjYXNlICd0YWcnOlxuICAgICAgcmV0dXJuIGNvbmZpZy5jb25maWdUZW1wbGF0ZVRhZz8uZmllbGRLZXkgfHwgZmllbGRLZXlEZWZhdWx0O1xuICB9XG5cbn07XG5cbmV4cG9ydCBjb25zdCBpbml0Q29uZmlnID0gKGNvbmZpZzogSUxpc3RDb25maWdJdGVtKTogdm9pZCA9PiB7XG4gIGlmICghY29uZmlnKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgY29uc3QgZGVmYXVsdENvbmZpZyA9IHtcbiAgICBmaWVsZEtleTogJ2lkJyxcbiAgICBnZXRWYWx1ZTogKGl0ZW06IGFueSk6IHN0cmluZyA9PiB7XG4gICAgICBpZiAoIWl0ZW0pIHtcbiAgICAgICAgcmV0dXJuICcgJztcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIGl0ZW0ubGFiZWwgfHwgaXRlbS5uYW1lIHx8ICcgJztcbiAgICB9XG4gIH07XG5cbiAgc3dpdGNoIChjb25maWcudHlwZSkge1xuXG4gICAgY2FzZSAnY2hlY2tib3gnOlxuICAgICAgaWYgKCFjb25maWcuY29uZmlnVGVtcGxhdGVDaGVja2JveCkge1xuICAgICAgICBjb25maWcuY29uZmlnVGVtcGxhdGVDaGVja2JveCA9IGRlZmF1bHRDb25maWc7XG4gICAgICB9XG4gICAgICBicmVhaztcblxuICAgIGNhc2UgJ2dyb3VwJzpcbiAgICAgIGJyZWFrO1xuXG4gICAgY2FzZSAncmFkaW8nOlxuICAgICAgaWYgKCFjb25maWcuY29uZmlnVGVtcGxhdGVSYWRpbykge1xuICAgICAgICBjb25maWcuY29uZmlnVGVtcGxhdGVSYWRpbyA9IGRlZmF1bHRDb25maWc7XG4gICAgICB9XG4gICAgICBicmVhaztcblxuICAgIGNhc2UgJ3RleHQnOlxuICAgICAgaWYgKCFjb25maWcuY29uZmlnVGVtcGxhdGVUZXh0KSB7XG4gICAgICAgIGNvbmZpZy5jb25maWdUZW1wbGF0ZVRleHQgPSBkZWZhdWx0Q29uZmlnO1xuICAgICAgfVxuICAgICAgYnJlYWs7XG4gIH1cbn07Il19
70
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC5kZWZpbmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvbGlzdC9zcmMvZGVmaW5lcy9saXN0LmRlZmluZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUUscUNBQXFDLEVBQUUsTUFBTSwwQ0FBMEMsQ0FBQztBQUNqRyxPQUFPLEVBQUUsa0NBQWtDLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUN4RixPQUFPLEVBQUUsa0NBQWtDLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUN4RixPQUFPLEVBQUUsZ0NBQWdDLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNsRixPQUFPLEVBQUUsaUNBQWlDLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUdyRixNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxDQUFDLFlBQTJCLEVBQUUsRUFBRTtJQUNoRSxRQUFRLFlBQVksRUFBRSxDQUFDO1FBQ3JCLEtBQUssVUFBVTtZQUNiLE9BQU8scUNBQXFDLENBQUM7UUFFL0MsS0FBSyxPQUFPO1lBQ1YsT0FBTyxrQ0FBa0MsQ0FBQztRQUU1QyxLQUFLLE9BQU87WUFDVixPQUFPLGtDQUFrQyxDQUFDO1FBRTVDLEtBQUssTUFBTTtZQUNULE9BQU8saUNBQWlDLENBQUM7UUFFM0MsS0FBSyxLQUFLO1lBQ1IsT0FBTyxnQ0FBZ0MsQ0FBQztJQUM1QyxDQUFDO0FBRUgsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsQ0FBQyxNQUFtQyxFQUFFLGVBQXVCLEVBQVUsRUFBRTtJQUN4RyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDWixPQUFPLGVBQWUsQ0FBQztJQUN6QixDQUFDO0lBQ0QsUUFBUSxNQUFNLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDcEIsS0FBSyxVQUFVO1lBQ2IsT0FBTyxNQUFNLENBQUMsc0JBQXNCLEVBQUUsRUFBRSxFQUFFLFFBQVEsSUFBSSxlQUFlLENBQUM7UUFFeEUsS0FBSyxPQUFPO1lBQ1YsT0FBTyxNQUFNLENBQUMsbUJBQW1CLEVBQUUsRUFBRSxFQUFFLFFBQVEsSUFBSSxlQUFlLENBQUM7UUFFckUsS0FBSyxPQUFPO1lBQ1YsT0FBTyxNQUFNLENBQUMsbUJBQW1CLEVBQUUsRUFBRSxFQUFFLFFBQVEsSUFBSSxlQUFlLENBQUM7UUFFckUsS0FBSyxNQUFNO1lBQ1QsT0FBTyxNQUFNLENBQUMsa0JBQWtCLEVBQUUsRUFBRSxFQUFFLFFBQVEsSUFBSSxlQUFlLENBQUM7UUFFcEUsS0FBSyxLQUFLO1lBQ1IsT0FBTyxNQUFNLENBQUMsaUJBQWlCLEVBQUUsRUFBRSxFQUFFLFFBQVEsSUFBSSxlQUFlLENBQUM7SUFDckUsQ0FBQztBQUVILENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLFVBQVUsR0FBRyxDQUFDLE1BQXVCLEVBQVEsRUFBRTtJQUMxRCxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDWixPQUFPO0lBQ1QsQ0FBQztJQUVELE1BQU0sYUFBYSxHQUFHO1FBQ3BCLFFBQVEsRUFBRSxJQUFJO1FBQ2QsUUFBUSxFQUFFLENBQUMsSUFBUyxFQUFVLEVBQUU7WUFDOUIsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO2dCQUNWLE9BQU8sR0FBRyxDQUFDO1lBQ2IsQ0FBQztZQUVELE9BQU8sSUFBSSxDQUFDLEtBQUssSUFBSSxJQUFJLENBQUMsSUFBSSxJQUFJLEdBQUcsQ0FBQztRQUN4QyxDQUFDO0tBQ0YsQ0FBQztJQUVGLFFBQVEsTUFBTSxDQUFDLElBQUksRUFBRSxDQUFDO1FBRXBCLEtBQUssVUFBVTtZQUNiLElBQUksQ0FBQyxNQUFNLENBQUMsc0JBQXNCLEVBQUUsRUFBRSxFQUFFLENBQUM7Z0JBQ3ZDLE1BQU0sQ0FBQyxzQkFBc0IsRUFBRSxHQUFHLENBQUMsYUFBYSxDQUFDLENBQUM7WUFDcEQsQ0FBQztZQUNELE1BQU07UUFFUixLQUFLLE9BQU87WUFDVixNQUFNO1FBRVIsS0FBSyxPQUFPO1lBQ1YsSUFBSSxDQUFDLE1BQU0sQ0FBQyxtQkFBbUIsRUFBRSxFQUFFLEVBQUUsQ0FBQztnQkFDcEMsTUFBTSxDQUFDLG1CQUFtQixFQUFFLEdBQUcsQ0FBQyxhQUFhLENBQUMsQ0FBQztZQUNqRCxDQUFDO1lBQ0QsTUFBTTtRQUVSLEtBQUssTUFBTTtZQUNULElBQUksQ0FBQyxNQUFNLENBQUMsa0JBQWtCLEVBQUUsRUFBRSxFQUFFLENBQUM7Z0JBQ25DLE1BQU0sQ0FBQyxrQkFBa0IsRUFBRSxHQUFHLENBQUMsYUFBYSxDQUFDLENBQUM7WUFDaEQsQ0FBQztZQUNELE1BQU07SUFDVixDQUFDO0FBQ0gsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueSAqL1xuaW1wb3J0IHsgVFlQRV9URU1QTEFURSB9IGZyb20gXCIuLi9pbnRlcmZhY2VzL3RlbXBsYXRlcy10eXBlLnR5cGVcIjtcbmltcG9ydCB7IExpYnNVaUNvbXBvbmVudHNMaXN0Q2hlY2tib3hDb21wb25lbnQgfSBmcm9tIFwiLi4vdGVtcGxhdGVzL2NoZWNrYm94L2NoZWNrYm94LmNvbXBvbmVudFwiO1xuaW1wb3J0IHsgTGlic1VpQ29tcG9uZW50c0xpc3RHcm91cENvbXBvbmVudCB9IGZyb20gXCIuLi90ZW1wbGF0ZXMvZ3JvdXAvZ3JvdXAuY29tcG9uZW50XCI7XG5pbXBvcnQgeyBMaWJzVWlDb21wb25lbnRzTGlzdFJhZGlvQ29tcG9uZW50IH0gZnJvbSBcIi4uL3RlbXBsYXRlcy9yYWRpby9yYWRpby5jb21wb25lbnRcIjtcbmltcG9ydCB7IExpYnNVaUNvbXBvbmVudHNMaXN0VGFnQ29tcG9uZW50IH0gZnJvbSBcIi4uL3RlbXBsYXRlcy90YWcvdGFnLmNvbXBvbmVudFwiO1xuaW1wb3J0IHsgTGlic1VpQ29tcG9uZW50c0xpc3RUZXh0Q29tcG9uZW50IH0gZnJvbSBcIi4uL3RlbXBsYXRlcy90ZXh0L3RleHQuY29tcG9uZW50XCI7XG5pbXBvcnQgeyBJTGlzdENvbmZpZ0l0ZW0gfSBmcm9tICcuLy4uL2ludGVyZmFjZXMvY29uZmlnLWl0ZW0uaW50ZXJmYWNlJztcblxuZXhwb3J0IGNvbnN0IGdldENvbXBvbmVudEJ5VHlwZSA9ICh0eXBlVGVtcGxhdGU6IFRZUEVfVEVNUExBVEUpID0+IHtcbiAgc3dpdGNoICh0eXBlVGVtcGxhdGUpIHtcbiAgICBjYXNlICdjaGVja2JveCc6XG4gICAgICByZXR1cm4gTGlic1VpQ29tcG9uZW50c0xpc3RDaGVja2JveENvbXBvbmVudDtcblxuICAgIGNhc2UgJ2dyb3VwJzpcbiAgICAgIHJldHVybiBMaWJzVWlDb21wb25lbnRzTGlzdEdyb3VwQ29tcG9uZW50O1xuXG4gICAgY2FzZSAncmFkaW8nOlxuICAgICAgcmV0dXJuIExpYnNVaUNvbXBvbmVudHNMaXN0UmFkaW9Db21wb25lbnQ7XG5cbiAgICBjYXNlICd0ZXh0JzpcbiAgICAgIHJldHVybiBMaWJzVWlDb21wb25lbnRzTGlzdFRleHRDb21wb25lbnQ7XG5cbiAgICBjYXNlICd0YWcnOlxuICAgICAgcmV0dXJuIExpYnNVaUNvbXBvbmVudHNMaXN0VGFnQ29tcG9uZW50O1xuICB9XG5cbn07XG5cbmV4cG9ydCBjb25zdCBnZXRGaWVsZEtleUJ5VHlwZSA9IChjb25maWc6IElMaXN0Q29uZmlnSXRlbSB8IHVuZGVmaW5lZCwgZmllbGRLZXlEZWZhdWx0OiBzdHJpbmcpOiBzdHJpbmcgPT4ge1xuICBpZiAoIWNvbmZpZykge1xuICAgIHJldHVybiBmaWVsZEtleURlZmF1bHQ7XG4gIH1cbiAgc3dpdGNoIChjb25maWcudHlwZSkge1xuICAgIGNhc2UgJ2NoZWNrYm94JzpcbiAgICAgIHJldHVybiBjb25maWcuY29uZmlnVGVtcGxhdGVDaGVja2JveD8uKCk/LmZpZWxkS2V5IHx8IGZpZWxkS2V5RGVmYXVsdDtcblxuICAgIGNhc2UgJ2dyb3VwJzpcbiAgICAgIHJldHVybiBjb25maWcuY29uZmlnVGVtcGxhdGVHcm91cD8uKCk/LmZpZWxkS2V5IHx8IGZpZWxkS2V5RGVmYXVsdDtcblxuICAgIGNhc2UgJ3JhZGlvJzpcbiAgICAgIHJldHVybiBjb25maWcuY29uZmlnVGVtcGxhdGVSYWRpbz8uKCk/LmZpZWxkS2V5IHx8IGZpZWxkS2V5RGVmYXVsdDtcblxuICAgIGNhc2UgJ3RleHQnOlxuICAgICAgcmV0dXJuIGNvbmZpZy5jb25maWdUZW1wbGF0ZVRleHQ/LigpPy5maWVsZEtleSB8fCBmaWVsZEtleURlZmF1bHQ7XG5cbiAgICBjYXNlICd0YWcnOlxuICAgICAgcmV0dXJuIGNvbmZpZy5jb25maWdUZW1wbGF0ZVRhZz8uKCk/LmZpZWxkS2V5IHx8IGZpZWxkS2V5RGVmYXVsdDtcbiAgfVxuXG59O1xuXG5leHBvcnQgY29uc3QgaW5pdENvbmZpZyA9IChjb25maWc6IElMaXN0Q29uZmlnSXRlbSk6IHZvaWQgPT4ge1xuICBpZiAoIWNvbmZpZykge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IGRlZmF1bHRDb25maWcgPSB7XG4gICAgZmllbGRLZXk6ICdpZCcsXG4gICAgZ2V0VmFsdWU6IChpdGVtOiBhbnkpOiBzdHJpbmcgPT4ge1xuICAgICAgaWYgKCFpdGVtKSB7XG4gICAgICAgIHJldHVybiAnICc7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBpdGVtLmxhYmVsIHx8IGl0ZW0ubmFtZSB8fCAnICc7XG4gICAgfVxuICB9O1xuXG4gIHN3aXRjaCAoY29uZmlnLnR5cGUpIHtcblxuICAgIGNhc2UgJ2NoZWNrYm94JzpcbiAgICAgIGlmICghY29uZmlnLmNvbmZpZ1RlbXBsYXRlQ2hlY2tib3g/LigpKSB7XG4gICAgICAgIGNvbmZpZy5jb25maWdUZW1wbGF0ZUNoZWNrYm94Py5zZXQoZGVmYXVsdENvbmZpZyk7XG4gICAgICB9XG4gICAgICBicmVhaztcblxuICAgIGNhc2UgJ2dyb3VwJzpcbiAgICAgIGJyZWFrO1xuXG4gICAgY2FzZSAncmFkaW8nOlxuICAgICAgaWYgKCFjb25maWcuY29uZmlnVGVtcGxhdGVSYWRpbz8uKCkpIHtcbiAgICAgICAgY29uZmlnLmNvbmZpZ1RlbXBsYXRlUmFkaW8/LnNldChkZWZhdWx0Q29uZmlnKTtcbiAgICAgIH1cbiAgICAgIGJyZWFrO1xuXG4gICAgY2FzZSAndGV4dCc6XG4gICAgICBpZiAoIWNvbmZpZy5jb25maWdUZW1wbGF0ZVRleHQ/LigpKSB7XG4gICAgICAgIGNvbmZpZy5jb25maWdUZW1wbGF0ZVRleHQ/LnNldChkZWZhdWx0Q29uZmlnKTtcbiAgICAgIH1cbiAgICAgIGJyZWFrO1xuICB9XG59OyJdfQ==
@@ -1,3 +1,3 @@
1
1
  ;
2
2
  export {};
3
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"config-item.interface.js","sourceRoot":"","sources":["../../../../../../libs-ui/components/list/src/interfaces/config-item.interface.ts"],"names":[],"mappings":"AAmJC,CAAC","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { IAvatarConfig } from \"@libs-ui/components-avatar\";\nimport { IBadge } from \"@libs-ui/components-badge\";\nimport { IButton } from \"@libs-ui/components-buttons-button\";\nimport { ISort } from \"@libs-ui/components-buttons-sort\";\nimport { ICheckboxItem } from \"@libs-ui/components-checkbox-group\";\nimport { ILabel } from \"@libs-ui/components-label\";\nimport { IPopover, IPopoverOverlay, TYPE_POPOVER_EVENT } from \"@libs-ui/components-popover\";\nimport { IHttpRequestConfig } from \"@libs-ui/services-http-request\";\nimport { TYPE_TEMPLATE } from \"./templates-type.type\";\nimport { Observable } from \"rxjs\";\nimport { WritableSignal } from \"@angular/core\";\n\nexport interface IListConfigItem {\n  type: TYPE_TEMPLATE;\n  httpRequestData?: IHttpRequestConfig;\n  configTemplateText?: IListConfigItemText;\n  configTemplateRadio?: IListConfigItemRadio;\n  configTemplateCheckbox?: IListConfigItemCheckbox;\n  configTemplateGroup?: IListConfigItemGroup;\n  configTemplateTag?: IListConfigItemTag;\n  configDescriptionGroup?: IConfigDescriptionGroup;\n  textNoData?: string;\n  textNoDataClassInclude?: string;\n  textSearchNoData?: string;\n  autoSelectFirstItem?: boolean; // nếu như có dữ liệu mà chưa có keySelected thì sẽ tự động chọn phần từ đầu tiên;\n  backgroundListCustom?: string;\n  paddingLeftItem?: boolean;\n  sort?: (items: Array<any>) => void;\n  hasIconNoData?: boolean;\n  ignoreShowDataWhenNotSearch?: boolean | undefined;\n  ignoreFixHeightShowDataWhenNotSearch?: boolean | undefined;\n  highlightTextSearchInResult?: boolean | undefined;\n}\n\nexport interface IListConfigItemText {\n  fieldKey: string;\n  getValue?: (item: any) => string;\n  fieldGetImage?: string;\n  classIncludeImage?: string;\n  getImage?: (data: IDataFunctionCallInConfig) => Observable<string>;\n  getImageError?: (data: IDataFunctionCallInConfig) => Observable<string>;\n  imgTypeIcon?: boolean;\n  ignoreIconSelected?: boolean;\n  classIncludeIconSelected?: string;\n  ignoreShowFieldLabel?: boolean;\n  getHrefButton?: (item: any) => string;\n  getClassItem?: (item: any) => string;\n  getClassIncludePopover?: (item: any) => string;\n  getConfigButtonLeft?: (item: any) => IButton;\n  getClassIconLeft?: (item: any) => string;\n  getConfigHoverDanger?: (item: any) => boolean;\n  getPopover?: (item: any) => IPopover | undefined;\n  rows?: Array<IListConfigItemTextRow>;\n  classRowsWrapper?: string;\n  classRows?: string;\n  configLabelPopover?: IPopoverOverlay;\n  autoScrollToItemSelected?: boolean;\n  itemSort?: ISort; // biến lưu trữ item sort\n  actionSort?: (itemSort: ISort) => void; // set hàm này nếu muốn bật sort trên list\n  notUseVirtualScroll?: boolean; // sử dụng cho trường hợp config badge trong table\n  getAvatarConfig?: (item: any) => IAvatarConfig;\n  getConfigAlignStart?: (item: any) => boolean;\n  stylePaddingRightItemOther?: boolean;\n}\n\nexport interface IListConfigItemTag extends IListConfigItemText {\n  fieldKey: string;\n  ignoreItemFlexWrap?: boolean;\n  classIncludeContainer?: string;\n}\n\nexport interface IListConfigItemRadio {\n  fieldKey: string;\n  fieldGetImage?: string;\n  classIncludeImage?: string;\n  hasAvatarPagesSocial?: boolean;\n  hasAvatarGroupSocial?: boolean;\n  getValue?: (item: any) => string;\n  getPopover?: (item: any) => IPopover | undefined;\n  rows?: Array<IListConfigItemTextRow>;\n  classRows?: string;\n  autoScrollToItemSelected?: boolean;\n  zIndexPopover?: number;\n  getAvatarConfig?: (item: any) => IAvatarConfig;\n  getClassItem?: (item: any) => string;\n  classItemInclude?: string;\n  getImage?: (data: IDataFunctionCallInConfig) => Observable<string>;\n  getImageError?: (data: IDataFunctionCallInConfig) => Observable<string>;\n}\n\nexport interface IListConfigItemCheckbox {\n  autoSelectAllItem?: boolean; // dropdown nếu như có dữ liệu mà chưa có multiKeySelected thì sẽ tự động chọn phần từ đầu tiên;\n  classListInclude?: string;\n  httpRequestAllIdSelectOrUnSelect?: IHttpRequestConfig;\n  configButtonSelectAndUndSelectItem?: {\n    classInclude?: string;\n    buttonCheckAll?: IButton;\n    buttonUncheckAll?: IButton;\n  };\n  configCheckboxCheckAll?: ICheckboxItem;\n  classIncludeHasConfigCheckBoxAll?: string;\n  fieldKey: string;\n  getValue?: (item: any) => string;\n  getPopover?: (item: any) => IPopover;\n  getClassItem?: (item: any) => string;\n  getImage?: (data: IDataFunctionCallInConfig) => Observable<string>;\n  getImageError?: (data: IDataFunctionCallInConfig) => Observable<string>;\n  fieldGetImage?: string;\n  hasAvatarPagesSocial?: boolean;\n  hasAvatarGroupSocial?: boolean;\n  classIncludeImage?: string;\n  rows?: Array<IListConfigItemTextRow>;\n  classRowsWrapper?: string;\n  classRows?: string;\n  ignoreClickItemUnChecked?: boolean;\n  classLabelInclude?: string;\n  fieldGetLinkImageError?: string;\n  zIndexPopover?: number;\n  classItemInclude?: string;\n  getAvatarConfig?: (item: any) => IAvatarConfig;\n  classCheckboxItemInclude?: string;\n  ignoreItemWidth100?: boolean;\n  classIncludeLastViewItem?: string;\n  classInclude?: string;\n}\n\ninterface IListConfigItemTextRow {\n  classRow?: string;\n  classItemSelected?: string;\n  getValue?: (data: IDataFunctionCallInConfig) => Observable<string>;\n  classGetValue?: string;\n  classCols?: string;\n  getRowStylesDynamicCols?: (item: any) => string;\n  cols?: Array<IListConfigItemTextCol>;\n  action?: (item: any) => void;\n  getImage?: (item: IDataFunctionCallInConfig) => Observable<string>;\n  getClassImage?: (item: IDataFunctionCallInConfig) => Observable<string>;\n  getImageError?: (item: IDataFunctionCallInConfig) => Observable<string>;\n  getPopoverConfig?: (item: any) => Observable<IPopoverOverlay>;\n  getAvatarConfig?: (item: any) => IAvatarConfig;\n}\n\nexport interface IDataFunctionCallInConfig {\n  value?: any;\n  item?: any;\n  otherData?: any;\n};\n\nexport interface IListConfigItemTextRowSignal extends Omit<IListConfigItemTextRow, 'cols'> {\n  cols?: WritableSignal<Array<WritableSignal<IListConfigItemTextCol>>>;\n}\nexport interface IListConfigItemTextCol {\n  getClassCol?: (item: any, index: number) => string | undefined;\n  getValue?: (data: IDataFunctionCallInConfig) => Observable<string>;\n  getPopover?: (item: any, index: number) => IPopover | undefined;\n  action?: (item: any) => void;\n  getImage?: (item: any) => Observable<string>;\n  getClassImage?: (item: any) => Observable<string>;\n  getImageError?: (item: any) => Observable<string>;\n  getConfigBadge?: (item: any, index: number) => IBadge | undefined;\n  getStylesDynamicCol?: (data: IDataFunctionCallInConfig) => Observable<string>;\n  getButton?: (item: any, index: number) => IButton | undefined;\n  getLabelSwitch?: (item: any, index: number) => ILabel | undefined;\n  getAvatarConfig?: (item: any) => IAvatarConfig;\n}\n\nexport interface IListConfigItemGroup {\n  flatItemsSupportAutoSelect?: (data: Array<any>) => Array<any>; // sử dụng khi muốn mặc định selected tất cả các key trong group\n  fieldKey?: string;\n  isViewRadio?: boolean;\n  timeIntervalCalculatorHeight?: number; // trường hợp trong page nhiều list tham số này sẽ thay đổi tùy từng trường hợp\n  configButtonSelectAndUndSelectItem?: {\n    classInclude?: string;\n    buttonCheckAll?: IButton;\n    buttonUncheckAll?: IButton;\n  };\n  configCheckboxCheckAll?: ICheckboxItem;\n  classIncludeHasConfigCheckBoxAll?: string;\n  getLabelSearch?: (item: any) => string; // Dùng để  customs khi search không chỉ field label: ví dụ: search cả code và name nhưng chỉ hiển thị name\n  getLabelGroup: (group: any) => string;\n  getExpandGroup?: (group: any) => boolean;\n  getPopoverGroup?: (group: any) => string;\n  getMaxLevelGroup: (group: any) => number;\n  getDescriptionGroupWhenNoData?: (group: any) => string | undefined;\n  getButtonGroup?: (group: any) => IButton;\n  getIconEmptyDataInGroup?: (group: any) => boolean; // hiển thị image empty trong từng group\n  ignoreCheckboxGroup?: boolean;\n  classIncludeNodata?: string;\n  classIncludeGroup?: string;\n  ignoreRadioGroup?: boolean;\n  ignoreTextUppercaseLabelGroup?: boolean;\n  ignoreGroupLine?: boolean;\n  marginTopHasLine?: number;\n  ignoreClickLabelGroup?: boolean;\n\n  fieldGetItems: string;\n  fieldGetAvatarItem?: string;\n  hasAvatarPagesSocial?: boolean;\n  hasAvatarGroupSocial?: boolean;\n  imgTypeIcon?: boolean;\n  classImageInclude?: string;\n  isViewTree?: boolean;\n  isViewTreeJson?: boolean;\n  getLabelItem: (item: any) => string;\n  getPopoverItem?: (item: any) => IPopover | undefined;\n  actionPopoverByItem?: (item: any, event: TYPE_POPOVER_EVENT) => void;\n  getExpandItem?: (group: any) => boolean;\n  getBonusPaddingLeftItem?: (item: any, parentItem?: any) => number;\n  getClassIncludeItemNoData?: (item: any, parentItem?: any) => string;\n  ignoreCheckboxItem?: boolean;\n  ignoreRadioItem?: boolean;\n  notChangeStateItemCheckOther?: boolean; // sử dụng cho trường hợp danh mục sản phẩm khi bỏ chọn 1 node thì các node cha và con không ảnh hưởng\n  searchAllLevel?: boolean; // nếu bật search all level thì khi tìm tất cả các group không phù hợp với key search sẽ bị ẩn, ko phân biệt cấp bậc\n  emitAllItemChecked?: boolean; // tham khảo trường hợp danh mục sản phẩm\n  singleSelectItem?: boolean; // sử dụng khi chỉ muốn chọn node ở level cuối cùng\n  singleSelectItemByTree?: boolean; //tham khảo trường hợp dòng sản phẩm của bank\n  hasIconCheckSingleSelectItem?: boolean;\n  colorBlueWhenItemSelected?: boolean;\n  hasBackgroundColorWhenItemSelected?: boolean;\n  iconExpand: '' | 'left' | 'right';\n  ignoreIconExpandMarginRight?: boolean;\n  onlySelectFirstItem?: boolean;\n  ignoreChooseParentThenAutoChooseChildren?: boolean; // tham khảo trường hợp dòng sản phẩm của bank\n  chooseChildThenAutoChooseParent?: boolean; // tham khảo trường hợp dòng sản phẩm của bank\n  ignoreUnselectChildrenRemoveSelectParent?: boolean; // tham khảo trường hợp dòng sản phẩm của bank\n  ignoreEmitAllItemCheckedWhenChooseChildThenAutoChooseParent?: boolean; // tham khảo trường hợp dòng sản phẩm của bank\n  disableItemNotLastLevel?: boolean; // tham khảo trường hợp dòng sản phẩm của bank\n  classLabelItem?: string\n  allowDisableLabel?: boolean;\n  zIndexLabel?: number;\n  expandFirstItem?: boolean;\n  widthLabelSub24WhenNotTreeView?: boolean; // width label item trừ 24px khi không phải dạng treeview,\n  classIncludeItem?: string;\n  getClassIncludeItemContent?: (item: any) => string; // truyền class cho item\n  getLinkImageError?: (item: any) => string;\n  getAvatarConfig?: (item: any) => IAvatarConfig;\n  classIncludeLastItem?: string;\n  getIconImageClass?: (item: any) => string;\n  autoCountWhenGroupEmptyItemLevel1?: boolean; // Trường hợp chỉ có 1 group item và sub_item empty, set = true tăng chiều cao popup để nhìn thấy empty text (Tham khảo dropdown chọn loại sản phẩm bank khi gắn dòng/ loại sản phẩm)\n  ignoreChangeChildrenDisableWhenChangeParent?: boolean\n}\n\nexport interface IConfigDescriptionGroup {\n  classInclude?: string;\n  tooltipDescription?: IPopoverOverlay;\n  textDescription: string;\n  classTextDescriptionInclude?: string;\n}\n"]}
3
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"config-item.interface.js","sourceRoot":"","sources":["../../../../../../libs-ui/components/list/src/interfaces/config-item.interface.ts"],"names":[],"mappings":"AAmJC,CAAC","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { IAvatarConfig } from \"@libs-ui/components-avatar\";\nimport { IBadge } from \"@libs-ui/components-badge\";\nimport { IButton } from \"@libs-ui/components-buttons-button\";\nimport { ISort } from \"@libs-ui/components-buttons-sort\";\nimport { ICheckboxItem } from \"@libs-ui/components-checkbox-group\";\nimport { ILabel } from \"@libs-ui/components-label\";\nimport { IPopover, IPopoverOverlay, TYPE_POPOVER_EVENT } from \"@libs-ui/components-popover\";\nimport { IHttpRequestConfig } from \"@libs-ui/services-http-request\";\nimport { TYPE_TEMPLATE } from \"./templates-type.type\";\nimport { Observable } from \"rxjs\";\nimport { WritableSignal } from \"@angular/core\";\n\nexport interface IListConfigItem {\n  type: TYPE_TEMPLATE;\n  httpRequestData?: WritableSignal<IHttpRequestConfig>;\n  configTemplateText?: WritableSignal<IListConfigItemText>;\n  configTemplateRadio?: WritableSignal<IListConfigItemRadio>;\n  configTemplateCheckbox?: WritableSignal<IListConfigItemCheckbox>;\n  configTemplateGroup?: WritableSignal<IListConfigItemGroup>;\n  configTemplateTag?: WritableSignal<IListConfigItemTag>;\n  configDescriptionGroup?: WritableSignal<IConfigDescriptionGroup>;\n  textNoData?: string;\n  textNoDataClassInclude?: string;\n  textSearchNoData?: string;\n  autoSelectFirstItem?: boolean; // nếu như có dữ liệu mà chưa có keySelected thì sẽ tự động chọn phần từ đầu tiên;\n  backgroundListCustom?: string;\n  paddingLeftItem?: boolean;\n  sort?: (items: Array<any>) => void;\n  hasIconNoData?: boolean;\n  ignoreShowDataWhenNotSearch?: boolean | undefined;\n  ignoreFixHeightShowDataWhenNotSearch?: boolean | undefined;\n  highlightTextSearchInResult?: boolean | undefined;\n}\n\nexport interface IListConfigItemText {\n  fieldKey: string;\n  getValue?: (item: any) => string;\n  fieldGetImage?: string;\n  classIncludeImage?: string;\n  getImage?: (data: IDataFunctionCallInConfig) => Observable<string>;\n  getImageError?: (data: IDataFunctionCallInConfig) => Observable<string>;\n  imgTypeIcon?: boolean;\n  ignoreIconSelected?: boolean;\n  classIncludeIconSelected?: string;\n  ignoreShowFieldLabel?: boolean;\n  getHrefButton?: (item: any) => string;\n  getClassItem?: (item: any) => string;\n  getClassIncludePopover?: (item: any) => string;\n  getConfigButtonLeft?: (item: any) => IButton;\n  getClassIconLeft?: (item: any) => string;\n  getConfigHoverDanger?: (item: any) => boolean;\n  getPopover?: (item: any) => IPopover | undefined;\n  rows?: WritableSignal<Array<WritableSignal<IListConfigItemTextRow>>>;\n  classRowsWrapper?: string;\n  classRows?: string;\n  configLabelPopover?: WritableSignal<IPopoverOverlay>;\n  autoScrollToItemSelected?: boolean;\n  itemSort?: ISort; // biến lưu trữ item sort\n  actionSort?: (itemSort: ISort) => void; // set hàm này nếu muốn bật sort trên list\n  notUseVirtualScroll?: boolean; // sử dụng cho trường hợp config badge trong table\n  getAvatarConfig?: (item: any) => IAvatarConfig;\n  getConfigAlignStart?: (item: any) => boolean;\n  stylePaddingRightItemOther?: boolean;\n}\n\nexport interface IListConfigItemTag extends IListConfigItemText {\n  fieldKey: string;\n  ignoreItemFlexWrap?: boolean;\n  classIncludeContainer?: string;\n}\n\nexport interface IListConfigItemRadio {\n  fieldKey: string;\n  fieldGetImage?: string;\n  classIncludeImage?: string;\n  hasAvatarPagesSocial?: boolean;\n  hasAvatarGroupSocial?: boolean;\n  getValue?: (item: any) => string;\n  getPopover?: (item: any) => IPopover | undefined;\n  rows?: WritableSignal<Array<WritableSignal<IListConfigItemTextRow>>>;\n  classRows?: string;\n  autoScrollToItemSelected?: boolean;\n  zIndexPopover?: number;\n  getAvatarConfig?: (item: any) => IAvatarConfig;\n  getClassItem?: (item: any) => string;\n  classItemInclude?: string;\n  getImage?: (data: IDataFunctionCallInConfig) => Observable<string>;\n  getImageError?: (data: IDataFunctionCallInConfig) => Observable<string>;\n}\n\nexport interface IListConfigItemCheckbox {\n  autoSelectAllItem?: boolean; // dropdown nếu như có dữ liệu mà chưa có multiKeySelected thì sẽ tự động chọn phần từ đầu tiên;\n  classListInclude?: string;\n  httpRequestAllIdSelectOrUnSelect?: WritableSignal<IHttpRequestConfig>;\n  configButtonSelectAndUndSelectItem?: WritableSignal<{\n    classInclude?: string;\n    buttonCheckAll?: IButton;\n    buttonUncheckAll?: IButton;\n  }>;\n  configCheckboxCheckAll?: WritableSignal<ICheckboxItem>;\n  classIncludeHasConfigCheckBoxAll?: string;\n  fieldKey: string;\n  getValue?: (item: any) => string;\n  getPopover?: (item: any) => IPopover;\n  getClassItem?: (item: any) => string;\n  getImage?: (data: IDataFunctionCallInConfig) => Observable<string>;\n  getImageError?: (data: IDataFunctionCallInConfig) => Observable<string>;\n  fieldGetImage?: string;\n  hasAvatarPagesSocial?: boolean;\n  hasAvatarGroupSocial?: boolean;\n  classIncludeImage?: string;\n  rows?: WritableSignal<Array<WritableSignal<IListConfigItemTextRow>>>;\n  classRowsWrapper?: string;\n  classRows?: string;\n  ignoreClickItemUnChecked?: boolean;\n  classLabelInclude?: string;\n  fieldGetLinkImageError?: string;\n  zIndexPopover?: number;\n  classItemInclude?: string;\n  getAvatarConfig?: (item: any) => IAvatarConfig;\n  classCheckboxItemInclude?: string;\n  ignoreItemWidth100?: boolean;\n  classIncludeLastViewItem?: string;\n  classInclude?: string;\n}\n\nexport interface IListConfigItemTextRow {\n  classRow?: string;\n  classItemSelected?: string;\n  getValue?: (data: IDataFunctionCallInConfig) => Observable<string>;\n  classGetValue?: string;\n  classCols?: string;\n  cols?: WritableSignal<Array<WritableSignal<IListConfigItemTextCol>>>;\n  getRowStylesDynamicCols?: (item: any) => string;\n  action?: (item: any) => void;\n  getImage?: (item: IDataFunctionCallInConfig) => Observable<string>;\n  getClassImage?: (item: IDataFunctionCallInConfig) => Observable<string>;\n  getImageError?: (item: IDataFunctionCallInConfig) => Observable<string>;\n  getPopoverConfig?: (item: any) => Observable<IPopoverOverlay>;\n  getAvatarConfig?: (item: any) => IAvatarConfig;\n}\n\nexport interface IDataFunctionCallInConfig {\n  value?: any;\n  item?: any;\n  otherData?: any;\n};\n\nexport interface IListConfigItemTextCol {\n  getClassCol?: (item: any, index: number) => string | undefined;\n  getValue?: (data: IDataFunctionCallInConfig) => Observable<string>;\n  getPopover?: (item: any, index: number) => IPopover | undefined;\n  action?: (item: any) => void;\n  getImage?: (item: any) => Observable<string>;\n  getClassImage?: (item: any) => Observable<string>;\n  getImageError?: (item: any) => Observable<string>;\n  getConfigBadge?: (item: any, index: number) => IBadge | undefined;\n  getStylesDynamicCol?: (data: IDataFunctionCallInConfig) => Observable<string>;\n  getButton?: (item: any, index: number) => IButton | undefined;\n  getLabelSwitch?: (item: any, index: number) => ILabel | undefined;\n  getAvatarConfig?: (item: any) => IAvatarConfig;\n}\n\nexport interface IListConfigItemGroup {\n  flatItemsSupportAutoSelect?: (data: Array<any>) => Array<any>; // sử dụng khi muốn mặc định selected tất cả các key trong group\n  fieldKey?: string;\n  isViewRadio?: boolean;\n  timeIntervalCalculatorHeight?: number; // trường hợp trong page nhiều list tham số này sẽ thay đổi tùy từng trường hợp\n  configButtonSelectAndUndSelectItem?: WritableSignal<{\n    classInclude?: string;\n    buttonCheckAll?: IButton;\n    buttonUncheckAll?: IButton;\n  }>;\n  configCheckboxCheckAll?: WritableSignal<ICheckboxItem>;\n  classIncludeHasConfigCheckBoxAll?: string;\n  getLabelSearch?: (item: any) => string; // Dùng để  customs khi search không chỉ field label: ví dụ: search cả code và name nhưng chỉ hiển thị name\n  getLabelGroup: (group: any) => string;\n  getExpandGroup?: (group: any) => boolean;\n  getPopoverGroup?: (group: any) => string;\n  getMaxLevelGroup: (group: any) => number;\n  getDescriptionGroupWhenNoData?: (group: any) => string | undefined;\n  getButtonGroup?: (group: any) => IButton;\n  getIconEmptyDataInGroup?: (group: any) => boolean; // hiển thị image empty trong từng group\n  ignoreCheckboxGroup?: boolean;\n  classIncludeNodata?: string;\n  classIncludeGroup?: string;\n  ignoreRadioGroup?: boolean;\n  ignoreTextUppercaseLabelGroup?: boolean;\n  ignoreGroupLine?: boolean;\n  marginTopHasLine?: number;\n  ignoreClickLabelGroup?: boolean;\n\n  fieldGetItems: string;\n  fieldGetAvatarItem?: string;\n  imgTypeIcon?: boolean;\n  classImageInclude?: string;\n  isViewTree?: boolean;\n  isViewTreeJson?: boolean;\n  getLabelItem: (item: any) => string;\n  getPopoverItem?: (item: any) => IPopover | undefined;\n  actionPopoverByItem?: (item: any, event: TYPE_POPOVER_EVENT) => void;\n  getExpandItem?: (group: any) => boolean;\n  getBonusPaddingLeftItem?: (item: any, parentItem?: any) => number;\n  getClassIncludeItemNoData?: (item: any, parentItem?: any) => string;\n  ignoreCheckboxItem?: boolean;\n  ignoreRadioItem?: boolean;\n  notChangeStateItemCheckOther?: boolean; // sử dụng cho trường hợp danh mục sản phẩm khi bỏ chọn 1 node thì các node cha và con không ảnh hưởng\n  searchAllLevel?: boolean; // nếu bật search all level thì khi tìm tất cả các group không phù hợp với key search sẽ bị ẩn, ko phân biệt cấp bậc\n  emitAllItemChecked?: boolean; // tham khảo trường hợp danh mục sản phẩm\n  singleSelectItem?: boolean; // sử dụng khi chỉ muốn chọn node ở level cuối cùng\n  singleSelectItemByTree?: boolean; //tham khảo trường hợp dòng sản phẩm của bank\n  hasIconCheckSingleSelectItem?: boolean;\n  colorBlueWhenItemSelected?: boolean;\n  hasBackgroundColorWhenItemSelected?: boolean;\n  iconExpand: '' | 'left' | 'right';\n  ignoreIconExpandMarginRight?: boolean;\n  onlySelectFirstItem?: boolean;\n  ignoreChooseParentThenAutoChooseChildren?: boolean; // tham khảo trường hợp dòng sản phẩm của bank\n  chooseChildThenAutoChooseParent?: boolean; // tham khảo trường hợp dòng sản phẩm của bank\n  ignoreUnselectChildrenRemoveSelectParent?: boolean; // tham khảo trường hợp dòng sản phẩm của bank\n  ignoreEmitAllItemCheckedWhenChooseChildThenAutoChooseParent?: boolean; // tham khảo trường hợp dòng sản phẩm của bank\n  disableItemNotLastLevel?: boolean; // tham khảo trường hợp dòng sản phẩm của bank\n  classLabelItem?: string\n  allowDisableLabel?: boolean;\n  zIndexLabel?: number;\n  expandFirstItem?: boolean;\n  widthLabelSub24WhenNotTreeView?: boolean; // width label item trừ 24px khi không phải dạng treeview,\n  classIncludeItem?: string;\n  getClassIncludeItemContent?: (item: any) => string; // truyền class cho item\n  getLinkImageError?: (item: any) => Observable<string>;\n  getImage?: (item: any) => Observable<string>;\n  getAvatarConfig?: (item: any) => IAvatarConfig;\n  getIconImageClass?: (item: any) => string;\n  classIncludeLastItem?: string;\n  autoCountWhenGroupEmptyItemLevel1?: boolean; // Trường hợp chỉ có 1 group item và sub_item empty, set = true tăng chiều cao popup để nhìn thấy empty text (Tham khảo dropdown chọn loại sản phẩm bank khi gắn dòng/ loại sản phẩm)\n  ignoreChangeChildrenDisableWhenChangeParent?: boolean\n}\n\nexport interface IConfigDescriptionGroup {\n  classInclude?: string;\n  tooltipDescription?: WritableSignal<IPopoverOverlay>;\n  textDescription: string;\n  classTextDescriptionInclude?: string;\n}\n"]}