@sd-angular/core 1.0.68 → 1.0.71

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 (26) hide show
  1. package/bundles/sd-angular-core-grid-material.umd.js +53 -17
  2. package/bundles/sd-angular-core-grid-material.umd.js.map +1 -1
  3. package/bundles/sd-angular-core-grid-material.umd.min.js +1 -1
  4. package/bundles/sd-angular-core-grid-material.umd.min.js.map +1 -1
  5. package/bundles/sd-angular-core-popover.umd.js +17 -1
  6. package/bundles/sd-angular-core-popover.umd.js.map +1 -1
  7. package/bundles/sd-angular-core-popover.umd.min.js +2 -2
  8. package/bundles/sd-angular-core-popover.umd.min.js.map +1 -1
  9. package/esm2015/grid-material/src/lib/grid-material.component.js +16 -8
  10. package/esm2015/grid-material/src/lib/models/grid-action.model.js +1 -1
  11. package/esm2015/grid-material/src/lib/models/grid.model.js +1 -1
  12. package/esm2015/grid-material/src/lib/pipes/selection-visible-select-all.pipe.js +4 -1
  13. package/esm2015/grid-material/src/lib/pipes/selection-visible.pipe.js +31 -6
  14. package/esm2015/popover/src/lib/popover/popover.component.js +19 -3
  15. package/fesm2015/sd-angular-core-grid-material.js +48 -12
  16. package/fesm2015/sd-angular-core-grid-material.js.map +1 -1
  17. package/fesm2015/sd-angular-core-popover.js +17 -1
  18. package/fesm2015/sd-angular-core-popover.js.map +1 -1
  19. package/grid-material/sd-angular-core-grid-material.metadata.json +1 -1
  20. package/grid-material/src/lib/grid-material.component.d.ts +1 -1
  21. package/grid-material/src/lib/models/grid-action.model.d.ts +2 -0
  22. package/grid-material/src/lib/models/grid.model.d.ts +4 -3
  23. package/package.json +1 -1
  24. package/popover/sd-angular-core-popover.metadata.json +1 -1
  25. package/popover/src/lib/popover/popover.component.d.ts +4 -2
  26. package/{sd-angular-core-1.0.68.tgz → sd-angular-core-1.0.71.tgz} +0 -0
@@ -3,7 +3,9 @@ import hash from 'object-hash';
3
3
  export class SdSelectionVisiblePipe {
4
4
  constructor() {
5
5
  this.transform = (rowData, selection) => {
6
+ var _a, _b;
6
7
  const { actions } = selection;
8
+ const groupedActions = [];
7
9
  rowData.actions = rowData.actions || [];
8
10
  if (!(actions === null || actions === void 0 ? void 0 : actions.length)) {
9
11
  rowData.selectable = true;
@@ -12,39 +14,62 @@ export class SdSelectionVisiblePipe {
12
14
  for (const action of actions) {
13
15
  if ('children' in action) {
14
16
  let flag = false;
17
+ let hasGroup = false;
15
18
  for (const childAction of action.children) {
16
- const { hidden } = childAction;
19
+ const { hidden, isGrouped } = childAction;
17
20
  const key = hash(childAction);
21
+ if (isGrouped) {
22
+ hasGroup = true;
23
+ }
18
24
  if (typeof (hidden) === 'function') {
19
25
  if (!hidden(rowData)) {
20
- rowData.actions.push(key);
21
26
  flag = true;
27
+ rowData.actions.push(key);
28
+ if (isGrouped) {
29
+ groupedActions.push(key);
30
+ }
22
31
  }
23
32
  }
24
33
  else if (!hidden) {
25
- rowData.actions.push(key);
26
34
  flag = true;
35
+ rowData.actions.push(key);
36
+ if (isGrouped) {
37
+ groupedActions.push(key);
38
+ }
27
39
  }
28
40
  }
29
41
  if (flag) {
30
42
  rowData.actions.push(hash(action));
43
+ if (hasGroup) {
44
+ groupedActions.push(hash(action));
45
+ }
31
46
  }
32
47
  }
33
48
  else {
34
- const { hidden } = action;
49
+ const { hidden, isGrouped } = action;
35
50
  const key = hash(action);
36
51
  if (typeof (hidden) === 'function') {
37
52
  if (!hidden(rowData)) {
38
53
  rowData.actions.push(key);
54
+ if (isGrouped) {
55
+ groupedActions.push(key);
56
+ }
39
57
  }
40
58
  }
41
59
  else if (!hidden) {
42
60
  rowData.actions.push(key);
61
+ if (isGrouped) {
62
+ groupedActions.push(key);
63
+ }
43
64
  }
44
65
  }
45
66
  }
46
67
  rowData.selectable = !!rowData.actions.length;
47
- return rowData.selectable;
68
+ if (!rowData.selectable || !groupedActions.length || ((_b = (_a = rowData === null || rowData === void 0 ? void 0 : rowData.sdGroup) === null || _a === void 0 ? void 0 : _a.items) === null || _b === void 0 ? void 0 : _b.length)) {
69
+ return rowData.selectable;
70
+ }
71
+ // Đối với trường hợp grouped, tuy selectable là true nhưng vẫn ẩn đi checkbox nếu các action đều thuộc groupedActions và rowData ko phải là dòng group
72
+ return rowData.actions.some(action => !groupedActions.includes(action));
48
73
  };
49
74
  }
50
75
  }
@@ -53,4 +78,4 @@ SdSelectionVisiblePipe.decorators = [
53
78
  name: 'selectionVisible'
54
79
  },] }
55
80
  ];
56
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0aW9uLXZpc2libGUucGlwZS5qcyIsInNvdXJjZVJvb3QiOiJDOi9Vc2Vycy9uZ2hpYXR0MTVfb25lbW91bnQvRG9jdW1lbnRzL2xpYi1jb3JlLXVpL3Byb2plY3RzL3NkLWNvcmUvZ3JpZC1tYXRlcmlhbC8iLCJzb3VyY2VzIjpbInNyYy9saWIvcGlwZXMvc2VsZWN0aW9uLXZpc2libGUucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQUNwRCxPQUFPLElBQUksTUFBTSxhQUFhLENBQUM7QUFPL0IsTUFBTSxPQUFPLHNCQUFzQjtJQUhuQztRQUlFLGNBQVMsR0FBRyxDQUFDLE9BQWUsRUFBRSxTQUFrQyxFQUFXLEVBQUU7WUFDM0UsTUFBTSxFQUFFLE9BQU8sRUFBRSxHQUFHLFNBQVMsQ0FBQztZQUM5QixPQUFPLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQyxPQUFPLElBQUksRUFBRSxDQUFDO1lBQ3hDLElBQUksRUFBQyxPQUFPLGFBQVAsT0FBTyx1QkFBUCxPQUFPLENBQUUsTUFBTSxDQUFBLEVBQUU7Z0JBQ3BCLE9BQU8sQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDO2dCQUMxQixPQUFPLE9BQU8sQ0FBQyxVQUFVLENBQUM7YUFDM0I7WUFDRCxLQUFLLE1BQU0sTUFBTSxJQUFJLE9BQU8sRUFBRTtnQkFDNUIsSUFBSSxVQUFVLElBQUksTUFBTSxFQUFFO29CQUN4QixJQUFJLElBQUksR0FBRyxLQUFLLENBQUM7b0JBQ2pCLEtBQUssTUFBTSxXQUFXLElBQUksTUFBTSxDQUFDLFFBQVEsRUFBRTt3QkFDekMsTUFBTSxFQUFFLE1BQU0sRUFBRSxHQUFHLFdBQVcsQ0FBQzt3QkFDL0IsTUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO3dCQUM5QixJQUFJLE9BQU8sQ0FBQyxNQUFNLENBQUMsS0FBSyxVQUFVLEVBQUU7NEJBQ2xDLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLEVBQUU7Z0NBQ3BCLE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO2dDQUMxQixJQUFJLEdBQUcsSUFBSSxDQUFDOzZCQUNiO3lCQUNGOzZCQUFNLElBQUksQ0FBQyxNQUFNLEVBQUU7NEJBQ2xCLE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDOzRCQUMxQixJQUFJLEdBQUcsSUFBSSxDQUFDO3lCQUNiO3FCQUNGO29CQUNELElBQUcsSUFBSSxFQUFFO3dCQUNQLE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO3FCQUNwQztpQkFDRjtxQkFBTTtvQkFDTCxNQUFNLEVBQUUsTUFBTSxFQUFFLEdBQUcsTUFBTSxDQUFDO29CQUMxQixNQUFNLEdBQUcsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7b0JBQ3pCLElBQUksT0FBTyxDQUFDLE1BQU0sQ0FBQyxLQUFLLFVBQVUsRUFBRTt3QkFDbEMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsRUFBRTs0QkFDcEIsT0FBTyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7eUJBQzNCO3FCQUNGO3lCQUFNLElBQUksQ0FBQyxNQUFNLEVBQUU7d0JBQ2xCLE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO3FCQUMzQjtpQkFDRjthQUNGO1lBQ0QsT0FBTyxDQUFDLFVBQVUsR0FBRyxDQUFDLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUM7WUFDOUMsT0FBTyxPQUFPLENBQUMsVUFBVSxDQUFDO1FBQzVCLENBQUMsQ0FBQTtJQUNILENBQUM7OztZQTdDQSxJQUFJLFNBQUM7Z0JBQ0osSUFBSSxFQUFFLGtCQUFrQjthQUN6QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IGhhc2ggZnJvbSAnb2JqZWN0LWhhc2gnO1xyXG5pbXBvcnQgeyBTZEdyaWRNYXRlcmlhbFNlbGVjdGlvbiB9IGZyb20gJy4uL21vZGVscy9ncmlkLXNlbGVjdGlvbi5tb2RlbCc7XHJcbmltcG9ydCB7IFNkSXRlbSB9IGZyb20gJy4uL21vZGVscy9ncmlkLm1vZGVsJztcclxuXHJcbkBQaXBlKHtcclxuICBuYW1lOiAnc2VsZWN0aW9uVmlzaWJsZSdcclxufSlcclxuZXhwb3J0IGNsYXNzIFNkU2VsZWN0aW9uVmlzaWJsZVBpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcclxuICB0cmFuc2Zvcm0gPSAocm93RGF0YTogU2RJdGVtLCBzZWxlY3Rpb246IFNkR3JpZE1hdGVyaWFsU2VsZWN0aW9uKTogYm9vbGVhbiA9PiB7XHJcbiAgICBjb25zdCB7IGFjdGlvbnMgfSA9IHNlbGVjdGlvbjtcclxuICAgIHJvd0RhdGEuYWN0aW9ucyA9IHJvd0RhdGEuYWN0aW9ucyB8fCBbXTtcclxuICAgIGlmICghYWN0aW9ucz8ubGVuZ3RoKSB7XHJcbiAgICAgIHJvd0RhdGEuc2VsZWN0YWJsZSA9IHRydWU7XHJcbiAgICAgIHJldHVybiByb3dEYXRhLnNlbGVjdGFibGU7XHJcbiAgICB9XHJcbiAgICBmb3IgKGNvbnN0IGFjdGlvbiBvZiBhY3Rpb25zKSB7XHJcbiAgICAgIGlmICgnY2hpbGRyZW4nIGluIGFjdGlvbikge1xyXG4gICAgICAgIGxldCBmbGFnID0gZmFsc2U7XHJcbiAgICAgICAgZm9yIChjb25zdCBjaGlsZEFjdGlvbiBvZiBhY3Rpb24uY2hpbGRyZW4pIHtcclxuICAgICAgICAgIGNvbnN0IHsgaGlkZGVuIH0gPSBjaGlsZEFjdGlvbjtcclxuICAgICAgICAgIGNvbnN0IGtleSA9IGhhc2goY2hpbGRBY3Rpb24pO1xyXG4gICAgICAgICAgaWYgKHR5cGVvZiAoaGlkZGVuKSA9PT0gJ2Z1bmN0aW9uJykge1xyXG4gICAgICAgICAgICBpZiAoIWhpZGRlbihyb3dEYXRhKSkge1xyXG4gICAgICAgICAgICAgIHJvd0RhdGEuYWN0aW9ucy5wdXNoKGtleSk7XHJcbiAgICAgICAgICAgICAgZmxhZyA9IHRydWU7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICAgIH0gZWxzZSBpZiAoIWhpZGRlbikge1xyXG4gICAgICAgICAgICByb3dEYXRhLmFjdGlvbnMucHVzaChrZXkpO1xyXG4gICAgICAgICAgICBmbGFnID0gdHJ1ZTtcclxuICAgICAgICAgIH1cclxuICAgICAgICB9XHJcbiAgICAgICAgaWYoZmxhZykge1xyXG4gICAgICAgICAgcm93RGF0YS5hY3Rpb25zLnB1c2goaGFzaChhY3Rpb24pKTtcclxuICAgICAgICB9XHJcbiAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgY29uc3QgeyBoaWRkZW4gfSA9IGFjdGlvbjtcclxuICAgICAgICBjb25zdCBrZXkgPSBoYXNoKGFjdGlvbik7XHJcbiAgICAgICAgaWYgKHR5cGVvZiAoaGlkZGVuKSA9PT0gJ2Z1bmN0aW9uJykge1xyXG4gICAgICAgICAgaWYgKCFoaWRkZW4ocm93RGF0YSkpIHtcclxuICAgICAgICAgICAgcm93RGF0YS5hY3Rpb25zLnB1c2goa2V5KTtcclxuICAgICAgICAgIH1cclxuICAgICAgICB9IGVsc2UgaWYgKCFoaWRkZW4pIHtcclxuICAgICAgICAgIHJvd0RhdGEuYWN0aW9ucy5wdXNoKGtleSk7XHJcbiAgICAgICAgfVxyXG4gICAgICB9XHJcbiAgICB9XHJcbiAgICByb3dEYXRhLnNlbGVjdGFibGUgPSAhIXJvd0RhdGEuYWN0aW9ucy5sZW5ndGg7XHJcbiAgICByZXR1cm4gcm93RGF0YS5zZWxlY3RhYmxlO1xyXG4gIH1cclxufVxyXG4iXX0=
81
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0aW9uLXZpc2libGUucGlwZS5qcyIsInNvdXJjZVJvb3QiOiJDOi9Vc2Vycy9uZ2hpYXR0MTVfb25lbW91bnQvRG9jdW1lbnRzL2xpYi1jb3JlLXVpL3Byb2plY3RzL3NkLWNvcmUvZ3JpZC1tYXRlcmlhbC8iLCJzb3VyY2VzIjpbInNyYy9saWIvcGlwZXMvc2VsZWN0aW9uLXZpc2libGUucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQUNwRCxPQUFPLElBQUksTUFBTSxhQUFhLENBQUM7QUFPL0IsTUFBTSxPQUFPLHNCQUFzQjtJQUhuQztRQUlFLGNBQVMsR0FBRyxDQUFDLE9BQWUsRUFBRSxTQUFrQyxFQUFXLEVBQUU7O1lBQzNFLE1BQU0sRUFBRSxPQUFPLEVBQUUsR0FBRyxTQUFTLENBQUM7WUFDOUIsTUFBTSxjQUFjLEdBQWEsRUFBRSxDQUFDO1lBQ3BDLE9BQU8sQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDLE9BQU8sSUFBSSxFQUFFLENBQUM7WUFDeEMsSUFBSSxFQUFDLE9BQU8sYUFBUCxPQUFPLHVCQUFQLE9BQU8sQ0FBRSxNQUFNLENBQUEsRUFBRTtnQkFDcEIsT0FBTyxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUM7Z0JBQzFCLE9BQU8sT0FBTyxDQUFDLFVBQVUsQ0FBQzthQUMzQjtZQUNELEtBQUssTUFBTSxNQUFNLElBQUksT0FBTyxFQUFFO2dCQUM1QixJQUFJLFVBQVUsSUFBSSxNQUFNLEVBQUU7b0JBQ3hCLElBQUksSUFBSSxHQUFHLEtBQUssQ0FBQztvQkFDakIsSUFBSSxRQUFRLEdBQUcsS0FBSyxDQUFDO29CQUNyQixLQUFLLE1BQU0sV0FBVyxJQUFJLE1BQU0sQ0FBQyxRQUFRLEVBQUU7d0JBQ3pDLE1BQU0sRUFBRSxNQUFNLEVBQUUsU0FBUyxFQUFFLEdBQUcsV0FBVyxDQUFDO3dCQUMxQyxNQUFNLEdBQUcsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7d0JBQzlCLElBQUcsU0FBUyxFQUFFOzRCQUNaLFFBQVEsR0FBRyxJQUFJLENBQUM7eUJBQ2pCO3dCQUNELElBQUksT0FBTyxDQUFDLE1BQU0sQ0FBQyxLQUFLLFVBQVUsRUFBRTs0QkFDbEMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsRUFBRTtnQ0FDcEIsSUFBSSxHQUFHLElBQUksQ0FBQztnQ0FDWixPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztnQ0FDMUIsSUFBSSxTQUFTLEVBQUU7b0NBQ2IsY0FBYyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztpQ0FDMUI7NkJBQ0Y7eUJBQ0Y7NkJBQU0sSUFBSSxDQUFDLE1BQU0sRUFBRTs0QkFDbEIsSUFBSSxHQUFHLElBQUksQ0FBQzs0QkFDWixPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQzs0QkFDMUIsSUFBSSxTQUFTLEVBQUU7Z0NBQ2IsY0FBYyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQzs2QkFDMUI7eUJBQ0Y7cUJBQ0Y7b0JBQ0QsSUFBSSxJQUFJLEVBQUU7d0JBQ1IsT0FBTyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUM7d0JBQ25DLElBQUcsUUFBUSxFQUFFOzRCQUNYLGNBQWMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUM7eUJBQ25DO3FCQUNGO2lCQUNGO3FCQUFNO29CQUNMLE1BQU0sRUFBRSxNQUFNLEVBQUUsU0FBUyxFQUFFLEdBQUcsTUFBTSxDQUFDO29CQUNyQyxNQUFNLEdBQUcsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7b0JBQ3pCLElBQUksT0FBTyxDQUFDLE1BQU0sQ0FBQyxLQUFLLFVBQVUsRUFBRTt3QkFDbEMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsRUFBRTs0QkFDcEIsT0FBTyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7NEJBQzFCLElBQUksU0FBUyxFQUFFO2dDQUNiLGNBQWMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7NkJBQzFCO3lCQUNGO3FCQUNGO3lCQUFNLElBQUksQ0FBQyxNQUFNLEVBQUU7d0JBQ2xCLE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO3dCQUMxQixJQUFJLFNBQVMsRUFBRTs0QkFDYixjQUFjLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO3lCQUMxQjtxQkFDRjtpQkFDRjthQUNGO1lBQ0QsT0FBTyxDQUFDLFVBQVUsR0FBRyxDQUFDLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUM7WUFDOUMsSUFBRyxDQUFDLE9BQU8sQ0FBQyxVQUFVLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxpQkFBSSxPQUFPLGFBQVAsT0FBTyx1QkFBUCxPQUFPLENBQUUsT0FBTywwQ0FBRSxLQUFLLDBDQUFFLE1BQU0sQ0FBQSxFQUFFO2dCQUNuRixPQUFPLE9BQU8sQ0FBQyxVQUFVLENBQUM7YUFDM0I7WUFDRCx1SkFBdUo7WUFDdkosT0FBTyxPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUEsRUFBRSxDQUFDLENBQUMsY0FBYyxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO1FBQ3pFLENBQUMsQ0FBQTtJQUNILENBQUM7OztZQXJFQSxJQUFJLFNBQUM7Z0JBQ0osSUFBSSxFQUFFLGtCQUFrQjthQUN6QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IGhhc2ggZnJvbSAnb2JqZWN0LWhhc2gnO1xyXG5pbXBvcnQgeyBTZEdyaWRNYXRlcmlhbFNlbGVjdGlvbiB9IGZyb20gJy4uL21vZGVscy9ncmlkLXNlbGVjdGlvbi5tb2RlbCc7XHJcbmltcG9ydCB7IFNkSXRlbSB9IGZyb20gJy4uL21vZGVscy9ncmlkLm1vZGVsJztcclxuXHJcbkBQaXBlKHtcclxuICBuYW1lOiAnc2VsZWN0aW9uVmlzaWJsZSdcclxufSlcclxuZXhwb3J0IGNsYXNzIFNkU2VsZWN0aW9uVmlzaWJsZVBpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcclxuICB0cmFuc2Zvcm0gPSAocm93RGF0YTogU2RJdGVtLCBzZWxlY3Rpb246IFNkR3JpZE1hdGVyaWFsU2VsZWN0aW9uKTogYm9vbGVhbiA9PiB7XHJcbiAgICBjb25zdCB7IGFjdGlvbnMgfSA9IHNlbGVjdGlvbjtcclxuICAgIGNvbnN0IGdyb3VwZWRBY3Rpb25zOiBzdHJpbmdbXSA9IFtdO1xyXG4gICAgcm93RGF0YS5hY3Rpb25zID0gcm93RGF0YS5hY3Rpb25zIHx8IFtdO1xyXG4gICAgaWYgKCFhY3Rpb25zPy5sZW5ndGgpIHtcclxuICAgICAgcm93RGF0YS5zZWxlY3RhYmxlID0gdHJ1ZTtcclxuICAgICAgcmV0dXJuIHJvd0RhdGEuc2VsZWN0YWJsZTtcclxuICAgIH1cclxuICAgIGZvciAoY29uc3QgYWN0aW9uIG9mIGFjdGlvbnMpIHtcclxuICAgICAgaWYgKCdjaGlsZHJlbicgaW4gYWN0aW9uKSB7XHJcbiAgICAgICAgbGV0IGZsYWcgPSBmYWxzZTtcclxuICAgICAgICBsZXQgaGFzR3JvdXAgPSBmYWxzZTtcclxuICAgICAgICBmb3IgKGNvbnN0IGNoaWxkQWN0aW9uIG9mIGFjdGlvbi5jaGlsZHJlbikge1xyXG4gICAgICAgICAgY29uc3QgeyBoaWRkZW4sIGlzR3JvdXBlZCB9ID0gY2hpbGRBY3Rpb247XHJcbiAgICAgICAgICBjb25zdCBrZXkgPSBoYXNoKGNoaWxkQWN0aW9uKTtcclxuICAgICAgICAgIGlmKGlzR3JvdXBlZCkge1xyXG4gICAgICAgICAgICBoYXNHcm91cCA9IHRydWU7XHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgICBpZiAodHlwZW9mIChoaWRkZW4pID09PSAnZnVuY3Rpb24nKSB7XHJcbiAgICAgICAgICAgIGlmICghaGlkZGVuKHJvd0RhdGEpKSB7XHJcbiAgICAgICAgICAgICAgZmxhZyA9IHRydWU7XHJcbiAgICAgICAgICAgICAgcm93RGF0YS5hY3Rpb25zLnB1c2goa2V5KTtcclxuICAgICAgICAgICAgICBpZiAoaXNHcm91cGVkKSB7XHJcbiAgICAgICAgICAgICAgICBncm91cGVkQWN0aW9ucy5wdXNoKGtleSk7XHJcbiAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICB9IGVsc2UgaWYgKCFoaWRkZW4pIHtcclxuICAgICAgICAgICAgZmxhZyA9IHRydWU7XHJcbiAgICAgICAgICAgIHJvd0RhdGEuYWN0aW9ucy5wdXNoKGtleSk7XHJcbiAgICAgICAgICAgIGlmIChpc0dyb3VwZWQpIHtcclxuICAgICAgICAgICAgICBncm91cGVkQWN0aW9ucy5wdXNoKGtleSk7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICAgIH1cclxuICAgICAgICB9XHJcbiAgICAgICAgaWYgKGZsYWcpIHtcclxuICAgICAgICAgIHJvd0RhdGEuYWN0aW9ucy5wdXNoKGhhc2goYWN0aW9uKSk7XHJcbiAgICAgICAgICBpZihoYXNHcm91cCkge1xyXG4gICAgICAgICAgICBncm91cGVkQWN0aW9ucy5wdXNoKGhhc2goYWN0aW9uKSk7XHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG4gICAgICB9IGVsc2Uge1xyXG4gICAgICAgIGNvbnN0IHsgaGlkZGVuLCBpc0dyb3VwZWQgfSA9IGFjdGlvbjtcclxuICAgICAgICBjb25zdCBrZXkgPSBoYXNoKGFjdGlvbik7XHJcbiAgICAgICAgaWYgKHR5cGVvZiAoaGlkZGVuKSA9PT0gJ2Z1bmN0aW9uJykge1xyXG4gICAgICAgICAgaWYgKCFoaWRkZW4ocm93RGF0YSkpIHtcclxuICAgICAgICAgICAgcm93RGF0YS5hY3Rpb25zLnB1c2goa2V5KTtcclxuICAgICAgICAgICAgaWYgKGlzR3JvdXBlZCkge1xyXG4gICAgICAgICAgICAgIGdyb3VwZWRBY3Rpb25zLnB1c2goa2V5KTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgICAgfVxyXG4gICAgICAgIH0gZWxzZSBpZiAoIWhpZGRlbikge1xyXG4gICAgICAgICAgcm93RGF0YS5hY3Rpb25zLnB1c2goa2V5KTtcclxuICAgICAgICAgIGlmIChpc0dyb3VwZWQpIHtcclxuICAgICAgICAgICAgZ3JvdXBlZEFjdGlvbnMucHVzaChrZXkpO1xyXG4gICAgICAgICAgfVxyXG4gICAgICAgIH1cclxuICAgICAgfVxyXG4gICAgfVxyXG4gICAgcm93RGF0YS5zZWxlY3RhYmxlID0gISFyb3dEYXRhLmFjdGlvbnMubGVuZ3RoO1xyXG4gICAgaWYoIXJvd0RhdGEuc2VsZWN0YWJsZSB8fCAhZ3JvdXBlZEFjdGlvbnMubGVuZ3RoIHx8IHJvd0RhdGE/LnNkR3JvdXA/Lml0ZW1zPy5sZW5ndGgpIHtcclxuICAgICAgcmV0dXJuIHJvd0RhdGEuc2VsZWN0YWJsZTtcclxuICAgIH1cclxuICAgIC8vIMSQ4buRaSB24bubaSB0csaw4budbmcgaOG7o3AgZ3JvdXBlZCwgdHV5IHNlbGVjdGFibGUgbMOgIHRydWUgbmjGsG5nIHbhuqtuIOG6qW4gxJFpIGNoZWNrYm94IG7hur91IGPDoWMgYWN0aW9uIMSR4buBdSB0aHXhu5ljIGdyb3VwZWRBY3Rpb25zIHbDoCByb3dEYXRhIGtvIHBo4bqjaSBsw6AgZMOybmcgZ3JvdXBcclxuICAgIHJldHVybiByb3dEYXRhLmFjdGlvbnMuc29tZShhY3Rpb249PiAhZ3JvdXBlZEFjdGlvbnMuaW5jbHVkZXMoYWN0aW9uKSk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
@@ -1,6 +1,6 @@
1
1
  var _xPosition;
2
2
  import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
3
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, HostListener, Input, Output, TemplateRef, ViewChild, ViewEncapsulation, } from "@angular/core";
3
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, HostListener, Input, Output, TemplateRef, ViewChild, ViewEncapsulation } from "@angular/core";
4
4
  import * as uuid from "uuid";
5
5
  import { DeviceDetectorService } from "ngx-device-detector";
6
6
  import { BehaviorSubject } from "rxjs";
@@ -16,6 +16,7 @@ export class PopoverComponent {
16
16
  this.panelClass = "";
17
17
  this.width = "sm";
18
18
  this.height = "auto";
19
+ this.type = "normal";
19
20
  _xPosition.set(this, void 0);
20
21
  this.closed = new EventEmitter();
21
22
  this.close = () => {
@@ -72,6 +73,20 @@ export class PopoverComponent {
72
73
  }
73
74
  }
74
75
  }
76
+ ngOnChanges(changes) {
77
+ var _a;
78
+ if (changes.type) {
79
+ const type = changes.type.currentValue;
80
+ const preType = changes.type.previousValue;
81
+ const classes = (_a = this.classList) !== null && _a !== void 0 ? _a : {};
82
+ if (preType) {
83
+ classes[`sd-popover--${preType}`] = false;
84
+ }
85
+ if (type) {
86
+ classes[`sd-popover--${type}`] = true;
87
+ }
88
+ }
89
+ }
75
90
  ngOnInit() {
76
91
  this.setPositionClasses();
77
92
  this.width = this.width || "80vw";
@@ -102,7 +117,7 @@ PopoverComponent.decorators = [
102
117
  encapsulation: ViewEncapsulation.None,
103
118
  exportAs: "sdPopover",
104
119
  changeDetection: ChangeDetectionStrategy.OnPush,
105
- styles: [".sd-popover-panel{background-color:#fff;position:relative}.sd-popover-panel .sd-popover-arrow{clear:both;height:0;left:50%;position:absolute;width:0}.sd-popover-panel.sd-popover-above .sd-popover-arrow{border-left:12px solid transparent;border-right:12px solid transparent;border-top:12px solid #fff;top:100%;transform:translateX(-6px) translateY(-1px)}.sd-popover-panel.sd-popover-above:after{content:\" \";display:block;height:16px;position:absolute;width:100%}.sd-popover-panel.sd-popover-below .sd-popover-arrow{border-bottom:12px solid #fff;border-left:12px solid transparent;border-right:12px solid transparent;bottom:100%;transform:translateX(-6px) translateY(1px)}.sd-popover-panel.sd-popover-below:before{content:\" \";display:block;height:16px;position:absolute;width:100%}.sd-popover-content{padding:16px}"]
120
+ styles: [".text-black400{color:#757575}.sd-popover-panel{position:relative}.sd-popover-panel .sd-popover-arrow{clear:both;height:0;left:50%;position:absolute;width:0}.sd-popover-panel.sd-popover-above .sd-popover-arrow{border-color:#fff transparent transparent;border-style:solid;border-width:12px 12px 0;top:100%;transform:translateX(-6px) translateY(-1px)}.sd-popover-panel.sd-popover-above:after{content:\" \";display:block;height:16px;position:absolute;width:100%}.sd-popover-panel.sd-popover-below .sd-popover-arrow{border-color:transparent transparent #fff;border-style:solid;border-width:0 12px 12px;bottom:100%;transform:translateX(-6px) translateY(1px)}.sd-popover-panel.sd-popover-below:before{content:\" \";display:block;height:16px;position:absolute;width:100%}.sd-popover--normal{background:#fff;color:#000}.sd-popover--normal.sd-popover-above .sd-popover-arrow{border-color:#fff transparent transparent;border-style:solid;border-width:12px 12px 0;top:100%}.sd-popover--normal.sd-popover-below .sd-popover-arrow{border-color:transparent transparent #fff;border-style:solid;border-width:0 12px 12px;bottom:100%}.sd-popover--primary{background:#e7e9ff;color:#2962ff}.sd-popover--primary.sd-popover-above .sd-popover-arrow{border-color:#e7e9ff transparent transparent;border-style:solid;border-width:12px 12px 0;top:100%}.sd-popover--primary.sd-popover-below .sd-popover-arrow{border-color:transparent transparent #e7e9ff;border-style:solid;border-width:0 12px 12px;bottom:100%}.sd-popover--info{background:#e7e9ff;color:#2962ff}.sd-popover--info.sd-popover-above .sd-popover-arrow{border-color:#e7e9ff transparent transparent;border-style:solid;border-width:12px 12px 0;top:100%}.sd-popover--info.sd-popover-below .sd-popover-arrow{border-color:transparent transparent #e7e9ff;border-style:solid;border-width:0 12px 12px;bottom:100%}.sd-popover--success{background:#dbefdc;color:#4caf50}.sd-popover--success.sd-popover-above .sd-popover-arrow{border-color:#dbefdc transparent transparent;border-style:solid;border-width:12px 12px 0;top:100%}.sd-popover--success.sd-popover-below .sd-popover-arrow{border-color:transparent transparent #dbefdc;border-style:solid;border-width:0 12px 12px;bottom:100%}.sd-popover--warning{background:#ffeacc;color:#ff9600}.sd-popover--warning.sd-popover-above .sd-popover-arrow{border-color:#ffeacc transparent transparent;border-style:solid;border-width:12px 12px 0;top:100%}.sd-popover--warning.sd-popover-below .sd-popover-arrow{border-color:transparent transparent #ffeacc;border-style:solid;border-width:0 12px 12px;bottom:100%}.sd-popover--danger{background:#fed5d0;color:#f82c13}.sd-popover--danger.sd-popover-above .sd-popover-arrow{border-color:#fed5d0 transparent transparent;border-style:solid;border-width:12px 12px 0;top:100%}.sd-popover--danger.sd-popover-below .sd-popover-arrow{border-color:transparent transparent #fed5d0;border-style:solid;border-width:0 12px 12px;bottom:100%}.sd-popover-content{padding:16px}"]
106
121
  },] }
107
122
  ];
108
123
  PopoverComponent.ctorParameters = () => [
@@ -115,8 +130,9 @@ PopoverComponent.propDecorators = {
115
130
  panelClass: [{ type: Input }],
116
131
  width: [{ type: Input }],
117
132
  height: [{ type: Input }],
133
+ type: [{ type: Input }],
118
134
  position: [{ type: Input }],
119
135
  closed: [{ type: Output }],
120
136
  _hostClick: [{ type: HostListener, args: ['document:click', ['$event.target'],] }]
121
137
  };
122
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.component.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/popover/","sources":["src/lib/popover/popover.component.ts"],"names":[],"mappings":";;AAAA,OAAO,EACL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EAET,YAAY,EACZ,YAAY,EACZ,KAAK,EAGL,MAAM,EACN,WAAW,EACX,SAAS,EACT,iBAAiB,GAClB,MAAM,eAAe,CAAC;AAEvB,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAC7B,OAAO,EAAE,qBAAqB,EAAE,MAAM,qBAAqB,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,MAAM,CAAC;AAevC,MAAM,OAAO,gBAAgB;IAmC3B,YACU,KAAwB,EACxB,aAAoC;QADpC,UAAK,GAAL,KAAK,CAAmB;QACxB,kBAAa,GAAb,aAAa,CAAuB;QApC9C,cAAS,GAA4B,EAAE,CAAC;QACxC,YAAO,GAAG,oBAAoB,IAAI,CAAC,EAAE,EAAE,EAAE,CAAC;QAC1C,qBAAgB,GAAG,KAAK,CAAC;QACzB,gBAAW,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAClD,YAAO,GAA4B,IAAI,CAAC;QAK/B,eAAU,GAAW,EAAE,CAAC;QACxB,UAAK,GAAgC,IAAI,CAAC;QAC1C,WAAM,GAAW,MAAM,CAAC;QASjC,6BAAqB;QAEF,WAAM,GAAG,IAAI,YAAY,EAAQ,CAAC;QA0CrD,UAAK,GAAG,GAAG,EAAE;YACX,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC7B,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;QACrB,CAAC,CAAC;QAEF,uBAAkB,GAAG,CAAC,MAAgB,IAAI,CAAC,QAAQ,EAAE,EAAE;;YACrD,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC;YAC/B,OAAO,CAAC,kBAAkB,CAAC,GAAG,GAAG,KAAK,OAAO,CAAC;YAC9C,OAAO,CAAC,kBAAkB,CAAC,GAAG,GAAG,KAAK,OAAO,CAAC;YAE9C,MAAA,IAAI,CAAC,KAAK,0CAAE,YAAY,GAAG;QAC7B,CAAC,CAAC;QAEF,uBAAkB,GAAG,CAAC,MAAc,EAAE,EAAE;YACtC,MAAM,YAAY,GAAgB,QAAQ,CAAC,aAAa,CAAC,IAAI,IAAI,CAAC,OAAO,oBAAoB,CAAC,CAAC;YAC/F,IAAI,YAAY,IAAI,MAAM,EAAE;gBAC1B,IAAI;oBACF,MAAM,KAAK,GAAG,MAAM,CAAC,gBAAgB,CAAC,YAAY,CAAC,CAAC;oBACpD,MAAM,MAAM,GAAG,IAAI,eAAe,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;oBACpD,MAAM,UAAU,GAAG,MAAM,CAAC,GAAG,GAAG,MAAM,CAAC;oBACvC,MAAM,UAAU,GAAG,MAAM,CAAC,GAAG,CAAC;oBAC9B,YAAY,CAAC,KAAK,CAAC,SAAS,GAAG,cAAc,UAAU,kBAAkB,UAAU,KAAK,CAAC;iBAC1F;gBAAC,OAAO,KAAK,EAAE,GAAE;aACnB;QACH,CAAC,CAAC;QAEF,kBAAa,GAAG,CAAC,OAAgB,EAAE,EAAE;YACnC,IAAI,CAAC,OAAO,EAAE;gBACZ,gEAAgE;gBAChE,mEAAmE;gBACnE,MAAM,aAAa,GAAG,QAAQ,CAAC,aAAa,CAAC;gBAC7C,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC;gBAC9C,IAAI,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,QAAQ,CAAC,aAAa,GAAG;oBACzC,OAAO;iBACR;aACF;YACD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACjC,CAAC,CAAC;QA/DA,IAAI,CAAC,gBAAgB,GAAG,CAAC,aAAa,CAAC,SAAS,EAAE,CAAC;IACrD,CAAC;IA3BD,IACI,QAAQ;QACV,gDAAuB;IACzB,CAAC;IACD,IAAI,QAAQ,CAAC,KAAe;QAC1B,uBAAA,IAAI,cAAc,KAAK,EAAC;QACxB,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAMD,UAAU,CAAC,aAAa;;QACtB,UAAI,IAAI,CAAC,KAAK,0CAAE,aAAa,EAAE;YAC7B,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;YAClE,IAAI,CAAC,QAAQ,EAAE;gBACb,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;aAC3B;SACF;IACH,CAAC;IASD,QAAQ;QACN,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,IAAI,MAAM,CAAC;QAClC,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE;YAC1B,QAAQ,IAAI,CAAC,KAAK,EAAE;gBAClB,KAAK,IAAI;oBACP,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC;oBACpB,MAAM;gBACR,KAAK,IAAI;oBACP,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC;oBACpB,MAAM;gBACR,KAAK,IAAI;oBACP,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC;oBACpB,MAAM;aACT;SACF;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;QACvB,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAC;IAC9B,CAAC;;;;YAvEF,SAAS,SAAC;gBACT,QAAQ,EAAE,YAAY;gBACtB,ueAAuC;gBAEvC,aAAa,EAAE,iBAAiB,CAAC,IAAI;gBACrC,QAAQ,EAAE,WAAW;gBACrB,eAAe,EAAE,uBAAuB,CAAC,MAAM;;aAChD;;;YA9BC,iBAAiB;YAeV,qBAAqB;;;0BAuB3B,SAAS,SAAC,WAAW;oBACrB,SAAS,SAAC,OAAO;yBAEjB,KAAK;oBACL,KAAK;qBACL,KAAK;uBACL,KAAK;qBAUL,MAAM;yBAEN,YAAY,SAAC,gBAAgB,EAAE,CAAC,eAAe,CAAC","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  TemplateRef,\r\n  ViewChild,\r\n  ViewEncapsulation,\r\n} from \"@angular/core\";\r\nimport { Position } from \"../popover.model\";\r\nimport * as uuid from \"uuid\";\r\nimport { DeviceDetectorService } from \"ngx-device-detector\";\r\nimport { BehaviorSubject } from \"rxjs\";\r\nimport { PopoverTriggerDirective } from \"../directives/popover-trigger.directive\";\r\n\r\nexport interface SdPopover {\r\n  close: () => void;\r\n}\r\n\r\n@Component({\r\n  selector: \"sd-popover\",\r\n  templateUrl: \"./popover.component.html\",\r\n  styleUrls: [\"./popover.component.scss\"],\r\n  encapsulation: ViewEncapsulation.None,\r\n  exportAs: \"sdPopover\",\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class PopoverComponent implements SdPopover, OnInit, OnDestroy {\r\n  classList: Record<string, boolean> = {};\r\n  panelId = `sd-popover-panel-${uuid.v4()}`;\r\n  isMobileOrTablet = false;\r\n  mouseState$ = new BehaviorSubject<boolean>(false);\r\n  trigger: PopoverTriggerDirective = null;\r\n\r\n  @ViewChild(TemplateRef) templateRef: TemplateRef<any>;\r\n  @ViewChild(\"panel\") panel: ElementRef<HTMLDivElement>;\r\n\r\n  @Input() panelClass: string = \"\";\r\n  @Input() width: \"lg\" | \"md\" | \"sm\" | string = \"sm\";\r\n  @Input() height: string = \"auto\";\r\n  @Input()\r\n  get position(): Position {\r\n    return this.#xPosition;\r\n  }\r\n  set position(value: Position) {\r\n    this.#xPosition = value;\r\n    this.setPositionClasses();\r\n  }\r\n  #xPosition: Position;\r\n\r\n  @Output() readonly closed = new EventEmitter<void>();\r\n\r\n  @HostListener('document:click', ['$event.target'])\r\n  _hostClick(targetElement) {\r\n    if (this.panel?.nativeElement) {\r\n      const isInside = this.panel.nativeElement.contains(targetElement);\r\n      if (!isInside) {\r\n        this.setMouseState(false);\r\n      }\r\n    }\r\n  }\r\n\r\n  constructor(\r\n    private cdRef: ChangeDetectorRef,\r\n    private deviceService: DeviceDetectorService\r\n  ) {\r\n    this.isMobileOrTablet = !deviceService.isDesktop();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.setPositionClasses();\r\n    this.width = this.width || \"80vw\";\r\n    if (!this.isMobileOrTablet) {\r\n      switch (this.width) {\r\n        case \"lg\":\r\n          this.width = \"80vw\";\r\n          break;\r\n        case \"md\":\r\n          this.width = \"60vw\";\r\n          break;\r\n        case \"sm\":\r\n          this.width = \"40vw\";\r\n          break;\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.closed.complete();\r\n    this.mouseState$.complete();\r\n  }\r\n\r\n  close = () => {\r\n    this.mouseState$.next(false);\r\n    this.closed.emit();\r\n  };\r\n\r\n  setPositionClasses = (pos: Position = this.position) => {\r\n    const classes = this.classList;\r\n    classes[\"sd-popover-above\"] = pos === \"above\";\r\n    classes[\"sd-popover-below\"] = pos === \"below\";\r\n\r\n    this.cdRef?.markForCheck();\r\n  };\r\n\r\n  addArrowTranslateX = (offset: number) => {\r\n    const arrowElement: HTMLElement = document.querySelector(`#${this.panelId} .sd-popover-arrow`);\r\n    if (arrowElement && offset) {\r\n      try {\r\n        const style = window.getComputedStyle(arrowElement);\r\n        const matrix = new WebKitCSSMatrix(style.transform);\r\n        const translateX = matrix.m41 + offset;\r\n        const translateY = matrix.m42;\r\n        arrowElement.style.transform = `translateX(${translateX}px) translateY(${translateY}px)`;\r\n      } catch (error) {}\r\n    }\r\n  };\r\n\r\n  setMouseState = (visible: boolean) => {\r\n    if (!visible) {\r\n      // chỉ được tắt khi đang không focus element nào bên trong panel\r\n      // tránh lỗi có control mở overlay khiến cho mất mouseenter ở panel\r\n      const activeElement = document.activeElement;\r\n      const panelElement = this.panel.nativeElement;\r\n      if (panelElement?.contains(activeElement)) {\r\n        return;\r\n      }\r\n    }\r\n    this.mouseState$.next(visible);\r\n  };\r\n}\r\n"]}
138
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.component.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/popover/","sources":["src/lib/popover/popover.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  TemplateRef,\r\n  ViewChild,\r\n  ViewEncapsulation,\r\n  OnChanges,\r\n  SimpleChanges\r\n} from \"@angular/core\";\r\nimport { Position } from \"../popover.model\";\r\nimport * as uuid from \"uuid\";\r\nimport { DeviceDetectorService } from \"ngx-device-detector\";\r\nimport { BehaviorSubject } from \"rxjs\";\r\nimport { PopoverTriggerDirective } from \"../directives/popover-trigger.directive\";\r\n\r\nexport interface SdPopover {\r\n  close: () => void;\r\n}\r\n\r\n@Component({\r\n  selector: \"sd-popover\",\r\n  templateUrl: \"./popover.component.html\",\r\n  styleUrls: [\"./popover.component.scss\"],\r\n  encapsulation: ViewEncapsulation.None,\r\n  exportAs: \"sdPopover\",\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class PopoverComponent implements SdPopover, OnChanges, OnInit, OnDestroy {\r\n  classList: Record<string, boolean> = {};\r\n  panelId = `sd-popover-panel-${uuid.v4()}`;\r\n  isMobileOrTablet = false;\r\n  mouseState$ = new BehaviorSubject<boolean>(false);\r\n  trigger: PopoverTriggerDirective = null;\r\n\r\n  @ViewChild(TemplateRef) templateRef: TemplateRef<any>;\r\n  @ViewChild(\"panel\") panel: ElementRef<HTMLDivElement>;\r\n\r\n  @Input() panelClass: string = \"\";\r\n  @Input() width: \"lg\" | \"md\" | \"sm\" | string = \"sm\";\r\n  @Input() height: string = \"auto\";\r\n  @Input() type: 'normal' | 'primary' | 'info' | 'success' | 'warning' | 'danger' = \"normal\";\r\n  @Input()\r\n  get position(): Position {\r\n    return this.#xPosition;\r\n  }\r\n  set position(value: Position) {\r\n    this.#xPosition = value;\r\n    this.setPositionClasses();\r\n  }\r\n  #xPosition: Position;\r\n\r\n  @Output() readonly closed = new EventEmitter<void>();\r\n\r\n  @HostListener('document:click', ['$event.target'])\r\n  _hostClick(targetElement) {\r\n    if (this.panel?.nativeElement) {\r\n      const isInside = this.panel.nativeElement.contains(targetElement);\r\n      if (!isInside) {\r\n        this.setMouseState(false);\r\n      }\r\n    }\r\n  }\r\n\r\n  constructor(\r\n    private cdRef: ChangeDetectorRef,\r\n    private deviceService: DeviceDetectorService\r\n  ) {\r\n    this.isMobileOrTablet = !deviceService.isDesktop();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if(changes.type) {\r\n      const type = changes.type.currentValue;\r\n      const preType = changes.type.previousValue;\r\n      const classes = this.classList ?? {};\r\n      if (preType) {\r\n        classes[`sd-popover--${preType}`] = false;\r\n      }\r\n      if (type) {\r\n        classes[`sd-popover--${type}`] = true;\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.setPositionClasses();\r\n    this.width = this.width || \"80vw\";\r\n    if (!this.isMobileOrTablet) {\r\n      switch (this.width) {\r\n        case \"lg\":\r\n          this.width = \"80vw\";\r\n          break;\r\n        case \"md\":\r\n          this.width = \"60vw\";\r\n          break;\r\n        case \"sm\":\r\n          this.width = \"40vw\";\r\n          break;\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.closed.complete();\r\n    this.mouseState$.complete();\r\n  }\r\n\r\n  close = () => {\r\n    this.mouseState$.next(false);\r\n    this.closed.emit();\r\n  };\r\n\r\n  setPositionClasses = (pos: Position = this.position) => {\r\n    const classes = this.classList;\r\n    classes[\"sd-popover-above\"] = pos === \"above\";\r\n    classes[\"sd-popover-below\"] = pos === \"below\";\r\n\r\n    this.cdRef?.markForCheck();\r\n  };\r\n\r\n  addArrowTranslateX = (offset: number) => {\r\n    const arrowElement: HTMLElement = document.querySelector(`#${this.panelId} .sd-popover-arrow`);\r\n    if (arrowElement && offset) {\r\n      try {\r\n        const style = window.getComputedStyle(arrowElement);\r\n        const matrix = new WebKitCSSMatrix(style.transform);\r\n        const translateX = matrix.m41 + offset;\r\n        const translateY = matrix.m42;\r\n        arrowElement.style.transform = `translateX(${translateX}px) translateY(${translateY}px)`;\r\n      } catch (error) {}\r\n    }\r\n  };\r\n\r\n  setMouseState = (visible: boolean) => {\r\n    if (!visible) {\r\n      // chỉ được tắt khi đang không focus element nào bên trong panel\r\n      // tránh lỗi có control mở overlay khiến cho mất mouseenter ở panel\r\n      const activeElement = document.activeElement;\r\n      const panelElement = this.panel.nativeElement;\r\n      if (panelElement?.contains(activeElement)) {\r\n        return;\r\n      }\r\n    }\r\n    this.mouseState$.next(visible);\r\n  };\r\n}\r\n"]}
@@ -1688,15 +1688,23 @@ class SdGridMaterial {
1688
1688
  }
1689
1689
  });
1690
1690
  this.onSelect = (rowData) => {
1691
- var _a, _b, _c;
1692
- if ((_a = this.gridOption.selection) === null || _a === void 0 ? void 0 : _a.single) {
1693
- this.items.filter(e => e !== rowData).forEach(e => e.isSelected = false);
1691
+ var _a, _b, _c, _d, _e, _f, _g, _h;
1692
+ if ((_b = (_a = rowData === null || rowData === void 0 ? void 0 : rowData.sdGroup) === null || _a === void 0 ? void 0 : _a.items) === null || _b === void 0 ? void 0 : _b.length) {
1693
+ (_c = rowData === null || rowData === void 0 ? void 0 : rowData.sdGroup) === null || _c === void 0 ? void 0 : _c.items.forEach(e => e.isSelected = rowData.isSelected);
1694
+ (_e = (_d = this.gridOption.selection) === null || _d === void 0 ? void 0 : _d.onSelect) === null || _e === void 0 ? void 0 : _e.call(_d, rowData, this.items.filter(e => e.isSelected));
1695
+ this.isSelectAll = this.items.every(e => e.isSelected);
1696
+ __classPrivateFieldGet(this, _updateSelectedItems).call(this);
1697
+ }
1698
+ else {
1699
+ if ((_f = this.gridOption.selection) === null || _f === void 0 ? void 0 : _f.single) {
1700
+ this.items.filter(e => e !== rowData).forEach(e => e.isSelected = false);
1701
+ __classPrivateFieldGet(this, _updateSelectedItems).call(this);
1702
+ return;
1703
+ }
1704
+ (_h = (_g = this.gridOption.selection) === null || _g === void 0 ? void 0 : _g.onSelect) === null || _h === void 0 ? void 0 : _h.call(_g, rowData, this.items.filter(e => e.isSelected));
1705
+ this.isSelectAll = this.items.every(e => e.isSelected);
1694
1706
  __classPrivateFieldGet(this, _updateSelectedItems).call(this);
1695
- return;
1696
1707
  }
1697
- (_c = (_b = this.gridOption.selection) === null || _b === void 0 ? void 0 : _b.onSelect) === null || _c === void 0 ? void 0 : _c.call(_b, rowData, this.items.filter(e => e.isSelected));
1698
- this.isSelectAll = this.items.every(e => e.isSelected);
1699
- __classPrivateFieldGet(this, _updateSelectedItems).call(this);
1700
1708
  };
1701
1709
  this.onSelectAll = () => {
1702
1710
  var _a, _b, _c;
@@ -2657,6 +2665,9 @@ class SdSelectionVisibleSelectAllPipe {
2657
2665
  if (!items.length) {
2658
2666
  return false;
2659
2667
  }
2668
+ if (actions.some(e => ('children' in e && e.children.some(e1 => e1.isGrouped)) || e.isGrouped)) {
2669
+ return false;
2670
+ }
2660
2671
  yield new Promise(resolve => setTimeout(resolve, 500));
2661
2672
  const first = items[0];
2662
2673
  for (const action of first.actions) {
@@ -3076,7 +3087,9 @@ SdColumnInlineFilter.propDecorators = {
3076
3087
  class SdSelectionVisiblePipe {
3077
3088
  constructor() {
3078
3089
  this.transform = (rowData, selection) => {
3090
+ var _a, _b;
3079
3091
  const { actions } = selection;
3092
+ const groupedActions = [];
3080
3093
  rowData.actions = rowData.actions || [];
3081
3094
  if (!(actions === null || actions === void 0 ? void 0 : actions.length)) {
3082
3095
  rowData.selectable = true;
@@ -3085,39 +3098,62 @@ class SdSelectionVisiblePipe {
3085
3098
  for (const action of actions) {
3086
3099
  if ('children' in action) {
3087
3100
  let flag = false;
3101
+ let hasGroup = false;
3088
3102
  for (const childAction of action.children) {
3089
- const { hidden } = childAction;
3103
+ const { hidden, isGrouped } = childAction;
3090
3104
  const key = hash__default(childAction);
3105
+ if (isGrouped) {
3106
+ hasGroup = true;
3107
+ }
3091
3108
  if (typeof (hidden) === 'function') {
3092
3109
  if (!hidden(rowData)) {
3093
- rowData.actions.push(key);
3094
3110
  flag = true;
3111
+ rowData.actions.push(key);
3112
+ if (isGrouped) {
3113
+ groupedActions.push(key);
3114
+ }
3095
3115
  }
3096
3116
  }
3097
3117
  else if (!hidden) {
3098
- rowData.actions.push(key);
3099
3118
  flag = true;
3119
+ rowData.actions.push(key);
3120
+ if (isGrouped) {
3121
+ groupedActions.push(key);
3122
+ }
3100
3123
  }
3101
3124
  }
3102
3125
  if (flag) {
3103
3126
  rowData.actions.push(hash__default(action));
3127
+ if (hasGroup) {
3128
+ groupedActions.push(hash__default(action));
3129
+ }
3104
3130
  }
3105
3131
  }
3106
3132
  else {
3107
- const { hidden } = action;
3133
+ const { hidden, isGrouped } = action;
3108
3134
  const key = hash__default(action);
3109
3135
  if (typeof (hidden) === 'function') {
3110
3136
  if (!hidden(rowData)) {
3111
3137
  rowData.actions.push(key);
3138
+ if (isGrouped) {
3139
+ groupedActions.push(key);
3140
+ }
3112
3141
  }
3113
3142
  }
3114
3143
  else if (!hidden) {
3115
3144
  rowData.actions.push(key);
3145
+ if (isGrouped) {
3146
+ groupedActions.push(key);
3147
+ }
3116
3148
  }
3117
3149
  }
3118
3150
  }
3119
3151
  rowData.selectable = !!rowData.actions.length;
3120
- return rowData.selectable;
3152
+ if (!rowData.selectable || !groupedActions.length || ((_b = (_a = rowData === null || rowData === void 0 ? void 0 : rowData.sdGroup) === null || _a === void 0 ? void 0 : _a.items) === null || _b === void 0 ? void 0 : _b.length)) {
3153
+ return rowData.selectable;
3154
+ }
3155
+ // Đối với trường hợp grouped, tuy selectable là true nhưng vẫn ẩn đi checkbox nếu các action đều thuộc groupedActions và rowData ko phải là dòng group
3156
+ return rowData.actions.some(action => !groupedActions.includes(action));
3121
3157
  };
3122
3158
  }
3123
3159
  }