@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.
- package/bundles/sd-angular-core-grid-material.umd.js +53 -17
- package/bundles/sd-angular-core-grid-material.umd.js.map +1 -1
- package/bundles/sd-angular-core-grid-material.umd.min.js +1 -1
- package/bundles/sd-angular-core-grid-material.umd.min.js.map +1 -1
- package/bundles/sd-angular-core-popover.umd.js +17 -1
- package/bundles/sd-angular-core-popover.umd.js.map +1 -1
- package/bundles/sd-angular-core-popover.umd.min.js +2 -2
- package/bundles/sd-angular-core-popover.umd.min.js.map +1 -1
- package/esm2015/grid-material/src/lib/grid-material.component.js +16 -8
- package/esm2015/grid-material/src/lib/models/grid-action.model.js +1 -1
- package/esm2015/grid-material/src/lib/models/grid.model.js +1 -1
- package/esm2015/grid-material/src/lib/pipes/selection-visible-select-all.pipe.js +4 -1
- package/esm2015/grid-material/src/lib/pipes/selection-visible.pipe.js +31 -6
- package/esm2015/popover/src/lib/popover/popover.component.js +19 -3
- package/fesm2015/sd-angular-core-grid-material.js +48 -12
- package/fesm2015/sd-angular-core-grid-material.js.map +1 -1
- package/fesm2015/sd-angular-core-popover.js +17 -1
- package/fesm2015/sd-angular-core-popover.js.map +1 -1
- package/grid-material/sd-angular-core-grid-material.metadata.json +1 -1
- package/grid-material/src/lib/grid-material.component.d.ts +1 -1
- package/grid-material/src/lib/models/grid-action.model.d.ts +2 -0
- package/grid-material/src/lib/models/grid.model.d.ts +4 -3
- package/package.json +1 -1
- package/popover/sd-angular-core-popover.metadata.json +1 -1
- package/popover/src/lib/popover/popover.component.d.ts +4 -2
- 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
|
-
|
|
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,
|
|
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
|
|
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{
|
|
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":"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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} 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 =
|
|
1693
|
-
|
|
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
|
-
|
|
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
|
}
|