platformcommons-web-lib 1.0.0
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/commons-shared-web-ui-1.0.0.tgz +0 -0
- package/documentation/alert.md +123 -0
- package/documentation/button-dropdown.md +126 -0
- package/documentation/button.md +184 -0
- package/documentation/cards-usage-guidelines.md +131 -0
- package/documentation/configurable-form.md +605 -0
- package/documentation/confirmation-modal.md +250 -0
- package/documentation/filter-sidebar.md +178 -0
- package/documentation/filter-table-selector.md +228 -0
- package/documentation/form-builder.md +597 -0
- package/documentation/form-components.md +384 -0
- package/documentation/nav.md +427 -0
- package/documentation/pagination.md +181 -0
- package/documentation/side-nav-documentation.md +169 -0
- package/documentation/smart-form.md +2177 -0
- package/documentation/smart-table.md +1198 -0
- package/documentation/snackbar.md +118 -0
- package/documentation/style-externalization.md +88 -0
- package/documentation/summary-card.md +279 -0
- package/ng-package.json +28 -0
- package/package.json +54 -0
- package/src/lib/modules/alert/alert.models.ts +6 -0
- package/src/lib/modules/alert/alert.module.ts +16 -0
- package/src/lib/modules/alert/alert.theme.scss +85 -0
- package/src/lib/modules/alert/components/alert/alert.component.html +27 -0
- package/src/lib/modules/alert/components/alert/alert.component.scss +92 -0
- package/src/lib/modules/alert/components/alert/alert.component.ts +81 -0
- package/src/lib/modules/button/button.models.ts +13 -0
- package/src/lib/modules/button/button.module.ts +16 -0
- package/src/lib/modules/button/button.theme.scss +121 -0
- package/src/lib/modules/button/components/button/button.component.html +22 -0
- package/src/lib/modules/button/components/button/button.component.scss +88 -0
- package/src/lib/modules/button/components/button/button.component.ts +67 -0
- package/src/lib/modules/button-dropdown/button-dropdown.models.ts +26 -0
- package/src/lib/modules/button-dropdown/button-dropdown.module.ts +22 -0
- package/src/lib/modules/button-dropdown/button-dropdown.theme.scss +87 -0
- package/src/lib/modules/button-dropdown/components/button-dropdown/button-dropdown.component.html +41 -0
- package/src/lib/modules/button-dropdown/components/button-dropdown/button-dropdown.component.scss +135 -0
- package/src/lib/modules/button-dropdown/components/button-dropdown/button-dropdown.component.ts +160 -0
- package/src/lib/modules/configurable-form/component/configurable-form.component.html +294 -0
- package/src/lib/modules/configurable-form/component/configurable-form.component.scss +503 -0
- package/src/lib/modules/configurable-form/component/configurable-form.component.ts +628 -0
- package/src/lib/modules/configurable-form/configurable-form.examples.ts +154 -0
- package/src/lib/modules/configurable-form/configurable-form.model.ts +131 -0
- package/src/lib/modules/configurable-form/configurable-form.module.ts +19 -0
- package/src/lib/modules/configurable-form/configurable-form.theme.scss +78 -0
- package/src/lib/modules/confirmation-modal/components/confirmation-modal/confirmation-modal.component.html +77 -0
- package/src/lib/modules/confirmation-modal/components/confirmation-modal/confirmation-modal.component.scss +395 -0
- package/src/lib/modules/confirmation-modal/components/confirmation-modal/confirmation-modal.component.ts +266 -0
- package/src/lib/modules/confirmation-modal/confirmation-modal.models.ts +71 -0
- package/src/lib/modules/confirmation-modal/confirmation-modal.module.ts +20 -0
- package/src/lib/modules/confirmation-modal/confirmation-modal.theme.scss +87 -0
- package/src/lib/modules/filter/components/filter/filter.component.html +131 -0
- package/src/lib/modules/filter/components/filter/filter.component.scss +245 -0
- package/src/lib/modules/filter/components/filter/filter.component.ts +216 -0
- package/src/lib/modules/filter/filter.models.ts +88 -0
- package/src/lib/modules/filter/filter.module.ts +24 -0
- package/src/lib/modules/filter/filter.theme.scss +92 -0
- package/src/lib/modules/filter-sidebar/components/filter-sidebar/filter-sidebar.component.html +112 -0
- package/src/lib/modules/filter-sidebar/components/filter-sidebar/filter-sidebar.component.scss +186 -0
- package/src/lib/modules/filter-sidebar/components/filter-sidebar/filter-sidebar.component.ts +163 -0
- package/src/lib/modules/filter-sidebar/filter-sidebar.models.ts +95 -0
- package/src/lib/modules/filter-sidebar/filter-sidebar.module.ts +24 -0
- package/src/lib/modules/filter-sidebar/filter-sidebar.theme.scss +38 -0
- package/src/lib/modules/filter-table-selector/components/filter-table-selector/filter-table-selector.component.html +73 -0
- package/src/lib/modules/filter-table-selector/components/filter-table-selector/filter-table-selector.component.scss +321 -0
- package/src/lib/modules/filter-table-selector/components/filter-table-selector/filter-table-selector.component.ts +361 -0
- package/src/lib/modules/filter-table-selector/filter-table-selector.models.ts +91 -0
- package/src/lib/modules/filter-table-selector/filter-table-selector.module.ts +22 -0
- package/src/lib/modules/filter-table-selector/filter-table-selector.theme.scss +36 -0
- package/src/lib/modules/form-builder/components/field-configurator/configurator-config-panel/configurator-config-panel.component.html +63 -0
- package/src/lib/modules/form-builder/components/field-configurator/configurator-config-panel/configurator-config-panel.component.scss +496 -0
- package/src/lib/modules/form-builder/components/field-configurator/configurator-config-panel/configurator-config-panel.component.ts +445 -0
- package/src/lib/modules/form-builder/components/field-configurator/configurator-tree/configurator-tree.component.html +75 -0
- package/src/lib/modules/form-builder/components/field-configurator/configurator-tree/configurator-tree.component.scss +210 -0
- package/src/lib/modules/form-builder/components/field-configurator/configurator-tree/configurator-tree.component.ts +55 -0
- package/src/lib/modules/form-builder/components/field-configurator/field-configurator.component.html +25 -0
- package/src/lib/modules/form-builder/components/field-configurator/field-configurator.component.scss +82 -0
- package/src/lib/modules/form-builder/components/field-configurator/field-configurator.component.ts +95 -0
- package/src/lib/modules/form-builder/components/field-selection/field-selection.component.html +20 -0
- package/src/lib/modules/form-builder/components/field-selection/field-selection.component.scss +37 -0
- package/src/lib/modules/form-builder/components/field-selection/field-selection.component.ts +94 -0
- package/src/lib/modules/form-builder/components/field-selection/group-node/group-node.component.html +46 -0
- package/src/lib/modules/form-builder/components/field-selection/group-node/group-node.component.scss +102 -0
- package/src/lib/modules/form-builder/components/field-selection/group-node/group-node.component.ts +50 -0
- package/src/lib/modules/form-builder/components/field-selection/selection-field-node/selection-field-node.component.html +35 -0
- package/src/lib/modules/form-builder/components/field-selection/selection-field-node/selection-field-node.component.scss +67 -0
- package/src/lib/modules/form-builder/components/field-selection/selection-field-node/selection-field-node.component.ts +34 -0
- package/src/lib/modules/form-builder/components/field-selection/selection-section-node/selection-section-node.component.html +68 -0
- package/src/lib/modules/form-builder/components/field-selection/selection-section-node/selection-section-node.component.scss +113 -0
- package/src/lib/modules/form-builder/components/field-selection/selection-section-node/selection-section-node.component.ts +74 -0
- package/src/lib/modules/form-builder/configs/field-type-schema.map.ts +533 -0
- package/src/lib/modules/form-builder/form-builder.module.ts +36 -0
- package/src/lib/modules/form-builder/form-builder.theme.scss +212 -0
- package/src/lib/modules/form-builder/index.ts +9 -0
- package/src/lib/modules/form-builder/models/builder.models.ts +7 -0
- package/src/lib/modules/form-builder/models/field-configurator.models.ts +38 -0
- package/src/lib/modules/form-builder/models/field-selection.models.ts +51 -0
- package/src/lib/modules/form-builder/services/field-configurator.service.ts +258 -0
- package/src/lib/modules/form-builder/services/field-selection.service.ts +300 -0
- package/src/lib/modules/form-builder/services/form-schema-tree.service.ts +652 -0
- package/src/lib/modules/form-builder/tokens/builder.tokens.ts +10 -0
- package/src/lib/modules/form-builder/utils/constants.ts +43 -0
- package/src/lib/modules/form-components/components/checkbox/_theme.scss +63 -0
- package/src/lib/modules/form-components/components/checkbox/checkbox.component.html +29 -0
- package/src/lib/modules/form-components/components/checkbox/checkbox.component.scss +111 -0
- package/src/lib/modules/form-components/components/checkbox/checkbox.component.ts +207 -0
- package/src/lib/modules/form-components/components/checkbox/checkbox.models.ts +35 -0
- package/src/lib/modules/form-components/components/datepicker/_theme.scss +82 -0
- package/src/lib/modules/form-components/components/datepicker/datepicker.component.html +42 -0
- package/src/lib/modules/form-components/components/datepicker/datepicker.component.scss +115 -0
- package/src/lib/modules/form-components/components/datepicker/datepicker.component.ts +267 -0
- package/src/lib/modules/form-components/components/datepicker/datepicker.models.ts +45 -0
- package/src/lib/modules/form-components/components/dropdown/_theme.scss +91 -0
- package/src/lib/modules/form-components/components/dropdown/dropdown.component.html +74 -0
- package/src/lib/modules/form-components/components/dropdown/dropdown.component.scss +252 -0
- package/src/lib/modules/form-components/components/dropdown/dropdown.component.ts +377 -0
- package/src/lib/modules/form-components/components/dropdown/dropdown.models.ts +53 -0
- package/src/lib/modules/form-components/components/input/_theme.scss +77 -0
- package/src/lib/modules/form-components/components/input/input.component.html +51 -0
- package/src/lib/modules/form-components/components/input/input.component.scss +128 -0
- package/src/lib/modules/form-components/components/input/input.component.ts +250 -0
- package/src/lib/modules/form-components/components/input/input.models.ts +55 -0
- package/src/lib/modules/form-components/components/radio/_theme.scss +61 -0
- package/src/lib/modules/form-components/components/radio/radio.component.html +22 -0
- package/src/lib/modules/form-components/components/radio/radio.component.scss +107 -0
- package/src/lib/modules/form-components/components/radio/radio.component.ts +181 -0
- package/src/lib/modules/form-components/components/radio/radio.models.ts +39 -0
- package/src/lib/modules/form-components/components/search/_theme.scss +73 -0
- package/src/lib/modules/form-components/components/search/search.component.html +15 -0
- package/src/lib/modules/form-components/components/search/search.component.scss +87 -0
- package/src/lib/modules/form-components/components/search/search.component.ts +213 -0
- package/src/lib/modules/form-components/components/search/search.models.ts +40 -0
- package/src/lib/modules/form-components/components/toggle/_theme.scss +45 -0
- package/src/lib/modules/form-components/components/toggle/toggle.component.html +15 -0
- package/src/lib/modules/form-components/components/toggle/toggle.component.scss +81 -0
- package/src/lib/modules/form-components/components/toggle/toggle.component.ts +166 -0
- package/src/lib/modules/form-components/components/toggle/toggle.models.ts +27 -0
- package/src/lib/modules/form-components/directives/click-outside.directive.ts +22 -0
- package/src/lib/modules/form-components/form-components.module.ts +41 -0
- package/src/lib/modules/form-components/form-components.theme.scss +25 -0
- package/src/lib/modules/material/material.module.ts +94 -0
- package/src/lib/modules/nav/components/nav/nav.component.html +34 -0
- package/src/lib/modules/nav/components/nav/nav.component.scss +171 -0
- package/src/lib/modules/nav/components/nav/nav.component.ts +82 -0
- package/src/lib/modules/nav/nav.models.ts +31 -0
- package/src/lib/modules/nav/nav.module.ts +17 -0
- package/src/lib/modules/nav/nav.theme.scss +86 -0
- package/src/lib/modules/pagination/components/pagination/pagination.component.html +52 -0
- package/src/lib/modules/pagination/components/pagination/pagination.component.scss +155 -0
- package/src/lib/modules/pagination/components/pagination/pagination.component.ts +109 -0
- package/src/lib/modules/pagination/pagination.module.ts +17 -0
- package/src/lib/modules/pagination/pagination.theme.scss +66 -0
- package/src/lib/modules/side-nav/components/side-nav/side-nav.component.html +56 -0
- package/src/lib/modules/side-nav/components/side-nav/side-nav.component.scss +342 -0
- package/src/lib/modules/side-nav/components/side-nav/side-nav.component.ts +135 -0
- package/src/lib/modules/side-nav/side-nav.models.ts +38 -0
- package/src/lib/modules/side-nav/side-nav.module.ts +16 -0
- package/src/lib/modules/side-nav/side-nav.theme.scss +111 -0
- package/src/lib/modules/smart-form/components/form-field/form-field.component.html +1109 -0
- package/src/lib/modules/smart-form/components/form-field/form-field.component.scss +1860 -0
- package/src/lib/modules/smart-form/components/form-field/form-field.component.ts +2232 -0
- package/src/lib/modules/smart-form/components/form-section/form-section.component.html +64 -0
- package/src/lib/modules/smart-form/components/form-section/form-section.component.scss +209 -0
- package/src/lib/modules/smart-form/components/form-section/form-section.component.ts +119 -0
- package/src/lib/modules/smart-form/components/smart-form/smart-form.component.html +253 -0
- package/src/lib/modules/smart-form/components/smart-form/smart-form.component.scss +689 -0
- package/src/lib/modules/smart-form/components/smart-form/smart-form.component.ts +1087 -0
- package/src/lib/modules/smart-form/index.ts +10 -0
- package/src/lib/modules/smart-form/models/form-schema.model.ts +700 -0
- package/src/lib/modules/smart-form/models/hierarchy-config.model.ts +21 -0
- package/src/lib/modules/smart-form/services/expression.service.ts +75 -0
- package/src/lib/modules/smart-form/services/smart-form-controller.service.ts +65 -0
- package/src/lib/modules/smart-form/smart-form.examples.ts +1324 -0
- package/src/lib/modules/smart-form/smart-form.module.ts +36 -0
- package/src/lib/modules/smart-form/smart-form.theme.scss +890 -0
- package/src/lib/modules/smart-form/utils/translation.utils.ts +82 -0
- package/src/lib/modules/smart-form/utils/trusted-url.pipe.ts +25 -0
- package/src/lib/modules/smart-form/utils/validation.utils.ts +98 -0
- package/src/lib/modules/smart-table/components/smart-table/smart-table.component.html +283 -0
- package/src/lib/modules/smart-table/components/smart-table/smart-table.component.scss +685 -0
- package/src/lib/modules/smart-table/components/smart-table/smart-table.component.ts +1118 -0
- package/src/lib/modules/smart-table/models/table-config.model.ts +202 -0
- package/src/lib/modules/smart-table/smart-table.module.ts +30 -0
- package/src/lib/modules/smart-table/smart-table.theme.scss +335 -0
- package/src/lib/modules/smart-table/utils/safe-html.pipe.ts +22 -0
- package/src/lib/modules/smart-table/utils/smart-table.utils.ts +18 -0
- package/src/lib/modules/snackbar/components/snackbar.component.html +41 -0
- package/src/lib/modules/snackbar/components/snackbar.component.scss +99 -0
- package/src/lib/modules/snackbar/components/snackbar.component.ts +18 -0
- package/src/lib/modules/snackbar/models/snackbar.models.ts +10 -0
- package/src/lib/modules/snackbar/services/snackbar.service.ts +40 -0
- package/src/lib/modules/snackbar/snackbar.module.ts +11 -0
- package/src/lib/modules/snackbar/snackbar.theme.scss +93 -0
- package/src/lib/modules/summary-card/components/summary-card/summary-card.component.html +47 -0
- package/src/lib/modules/summary-card/components/summary-card/summary-card.component.scss +199 -0
- package/src/lib/modules/summary-card/components/summary-card/summary-card.component.ts +126 -0
- package/src/lib/modules/summary-card/summary-card.module.ts +18 -0
- package/src/lib/modules/summary-card/summary-card.theme.scss +176 -0
- package/src/lib/shared-ui.module.ts +44 -0
- package/src/lib/styles/global.scss +152 -0
- package/src/lib/styles/utilities.scss +250 -0
- package/src/lib/utils/constants.ts +11 -0
- package/src/lib/utils/storage.utils.ts +37 -0
- package/src/lib/utils/string.utils.ts +23 -0
- package/src/lib/utils/translation.utils.ts +87 -0
- package/src/public-api.ts +104 -0
- package/tsconfig.lib.json +15 -0
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
.cc-snackbar-container {
|
|
2
|
+
display: flex;
|
|
3
|
+
align-items: center;
|
|
4
|
+
gap: var(--cc-sb-gap, 12px);
|
|
5
|
+
padding: var(--cc-sb-padding, 12px 16px);
|
|
6
|
+
border-radius: var(--cc-sb-radius, 8px);
|
|
7
|
+
box-shadow: var(--cc-sb-shadow, 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06));
|
|
8
|
+
font-family: var(--cc-sb-font-family, 'Inter', sans-serif);
|
|
9
|
+
font-size: var(--cc-sb-font-size, 14px);
|
|
10
|
+
font-weight: var(--cc-sb-font-weight, 500);
|
|
11
|
+
background: var(--cc-sb-bg, #ffffff);
|
|
12
|
+
color: var(--cc-sb-color, #1f2937);
|
|
13
|
+
border: var(--cc-sb-border, 1px solid transparent);
|
|
14
|
+
min-width: var(--cc-sb-min-width, 300px);
|
|
15
|
+
|
|
16
|
+
&.snackbar-success {
|
|
17
|
+
background: var(--cc-sb-success-bg, #ecfdf5);
|
|
18
|
+
color: var(--cc-sb-success-color, #065f46);
|
|
19
|
+
border-color: var(--cc-sb-success-border, #a7f3d0);
|
|
20
|
+
.cc-snackbar-icon { color: var(--cc-sb-success-icon-color, #10b981); }
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
&.snackbar-error {
|
|
24
|
+
background: var(--cc-sb-error-bg, #fef2f2);
|
|
25
|
+
color: var(--cc-sb-error-color, #991b1b);
|
|
26
|
+
border-color: var(--cc-sb-error-border, #fecaca);
|
|
27
|
+
.cc-snackbar-icon { color: var(--cc-sb-error-icon-color, #ef4444); }
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
&.snackbar-warning {
|
|
31
|
+
background: var(--cc-sb-warning-bg, #fffbeb);
|
|
32
|
+
color: var(--cc-sb-warning-color, #92400e);
|
|
33
|
+
border-color: var(--cc-sb-warning-border, #fde68a);
|
|
34
|
+
.cc-snackbar-icon { color: var(--cc-sb-warning-icon-color, #f59e0b); }
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
&.snackbar-info {
|
|
38
|
+
background: var(--cc-sb-info-bg, #eff6ff);
|
|
39
|
+
color: var(--cc-sb-info-color, #1e40af);
|
|
40
|
+
border-color: var(--cc-sb-info-border, #bfdbfe);
|
|
41
|
+
.cc-snackbar-icon { color: var(--cc-sb-info-icon-color, #3b82f6); }
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
.cc-snackbar-icon {
|
|
45
|
+
display: flex;
|
|
46
|
+
align-items: center;
|
|
47
|
+
justify-content: center;
|
|
48
|
+
flex-shrink: 0;
|
|
49
|
+
|
|
50
|
+
svg {
|
|
51
|
+
width: var(--cc-sb-icon-size, 20px);
|
|
52
|
+
height: var(--cc-sb-icon-size, 20px);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
.cc-snackbar-message {
|
|
57
|
+
flex-grow: 1;
|
|
58
|
+
line-height: 1.4;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
.cc-snackbar-close {
|
|
62
|
+
background: transparent;
|
|
63
|
+
border: none;
|
|
64
|
+
padding: 0;
|
|
65
|
+
margin: 0;
|
|
66
|
+
cursor: pointer;
|
|
67
|
+
display: flex;
|
|
68
|
+
align-items: center;
|
|
69
|
+
justify-content: center;
|
|
70
|
+
color: currentcolor;
|
|
71
|
+
opacity: 0.7;
|
|
72
|
+
transition: opacity 0.2s;
|
|
73
|
+
|
|
74
|
+
&:hover {
|
|
75
|
+
opacity: 1;
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
svg {
|
|
79
|
+
width: var(--cc-sb-close-icon-size, 16px);
|
|
80
|
+
height: var(--cc-sb-close-icon-size, 16px);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
// Override Angular Material default snackbar surface
|
|
86
|
+
::ng-deep .cc-snackbar-panel {
|
|
87
|
+
.mdc-snackbar__surface {
|
|
88
|
+
background: transparent !important;
|
|
89
|
+
box-shadow: none !important;
|
|
90
|
+
padding: 0 !important;
|
|
91
|
+
border-radius: 0 !important;
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
&.mat-snack-bar-container {
|
|
95
|
+
background: transparent !important;
|
|
96
|
+
box-shadow: none !important;
|
|
97
|
+
padding: 0 !important;
|
|
98
|
+
}
|
|
99
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { Component, inject } from '@angular/core';
|
|
2
|
+
import { MAT_SNACK_BAR_DATA, MatSnackBarRef } from '@angular/material/snack-bar';
|
|
3
|
+
import { SnackbarConfig } from '../models/snackbar.models';
|
|
4
|
+
|
|
5
|
+
@Component({
|
|
6
|
+
selector: 'lib-snackbar',
|
|
7
|
+
templateUrl: './snackbar.component.html',
|
|
8
|
+
styleUrls: ['./snackbar.component.scss'],
|
|
9
|
+
standalone: false
|
|
10
|
+
})
|
|
11
|
+
export class SnackbarComponent {
|
|
12
|
+
public data: SnackbarConfig = inject(MAT_SNACK_BAR_DATA);
|
|
13
|
+
public snackBarRef: MatSnackBarRef<SnackbarComponent> = inject(MatSnackBarRef);
|
|
14
|
+
|
|
15
|
+
get variantClass(): string {
|
|
16
|
+
return `snackbar-${this.data.variant || 'info'}`;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export type SnackbarVariant = 'success' | 'error' | 'warning' | 'info';
|
|
2
|
+
|
|
3
|
+
export interface SnackbarConfig {
|
|
4
|
+
message: string;
|
|
5
|
+
variant?: SnackbarVariant;
|
|
6
|
+
duration?: number;
|
|
7
|
+
horizontalPosition?: 'start' | 'center' | 'end' | 'left' | 'right';
|
|
8
|
+
verticalPosition?: 'top' | 'bottom';
|
|
9
|
+
showCloseButton?: boolean;
|
|
10
|
+
}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { MatSnackBar, MatSnackBarConfig } from '@angular/material/snack-bar';
|
|
3
|
+
import { SnackbarConfig } from '../models/snackbar.models';
|
|
4
|
+
import { SnackbarComponent } from '../components/snackbar.component';
|
|
5
|
+
|
|
6
|
+
@Injectable({
|
|
7
|
+
providedIn: 'root'
|
|
8
|
+
})
|
|
9
|
+
export class SnackbarService {
|
|
10
|
+
|
|
11
|
+
constructor(private snackBar: MatSnackBar) {}
|
|
12
|
+
|
|
13
|
+
show(config: SnackbarConfig): void {
|
|
14
|
+
const matConfig: MatSnackBarConfig = {
|
|
15
|
+
duration: config.duration ?? 5000,
|
|
16
|
+
horizontalPosition: config.horizontalPosition ?? 'right',
|
|
17
|
+
verticalPosition: config.verticalPosition ?? 'top',
|
|
18
|
+
panelClass: ['cc-snackbar-panel', `cc-snackbar-${config.variant || 'info'}`],
|
|
19
|
+
data: config // Pass the entire config down to the component
|
|
20
|
+
};
|
|
21
|
+
|
|
22
|
+
this.snackBar.openFromComponent(SnackbarComponent, matConfig);
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
success(message: string, duration?: number): void {
|
|
26
|
+
this.show({ message, variant: 'success', duration });
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
error(message: string, duration?: number): void {
|
|
30
|
+
this.show({ message, variant: 'error', duration });
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
warning(message: string, duration?: number): void {
|
|
34
|
+
this.show({ message, variant: 'warning', duration });
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
info(message: string, duration?: number): void {
|
|
38
|
+
this.show({ message, variant: 'info', duration });
|
|
39
|
+
}
|
|
40
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { MatSnackBarModule } from '@angular/material/snack-bar';
|
|
4
|
+
import { SnackbarComponent } from './components/snackbar.component';
|
|
5
|
+
|
|
6
|
+
@NgModule({
|
|
7
|
+
declarations: [SnackbarComponent],
|
|
8
|
+
imports: [CommonModule, MatSnackBarModule],
|
|
9
|
+
exports: [SnackbarComponent]
|
|
10
|
+
})
|
|
11
|
+
export class SnackbarModule {}
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
@use 'sass:map';
|
|
2
|
+
|
|
3
|
+
// Default configuration for the snackbar theme
|
|
4
|
+
$default-snackbar-config: (
|
|
5
|
+
// Shared Layout
|
|
6
|
+
font-family: ('Inter', sans-serif),
|
|
7
|
+
font-size: 14px,
|
|
8
|
+
font-weight: 500,
|
|
9
|
+
min-width: 300px,
|
|
10
|
+
padding: 12px 16px,
|
|
11
|
+
gap: 12px,
|
|
12
|
+
radius: 8px,
|
|
13
|
+
shadow: (0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06)),
|
|
14
|
+
icon-size: 20px,
|
|
15
|
+
close-icon-size: 16px,
|
|
16
|
+
|
|
17
|
+
// Base Colors
|
|
18
|
+
bg: #ffffff,
|
|
19
|
+
color: #1f2937,
|
|
20
|
+
border: 1px solid transparent,
|
|
21
|
+
|
|
22
|
+
// Success
|
|
23
|
+
success-bg: #ecfdf5,
|
|
24
|
+
success-color: #065f46,
|
|
25
|
+
success-border: #a7f3d0,
|
|
26
|
+
success-icon-color: #10b981,
|
|
27
|
+
|
|
28
|
+
// Error
|
|
29
|
+
error-bg: #fef2f2,
|
|
30
|
+
error-color: #991b1b,
|
|
31
|
+
error-border: #fecaca,
|
|
32
|
+
error-icon-color: #ef4444,
|
|
33
|
+
|
|
34
|
+
// Info
|
|
35
|
+
info-bg: #eff6ff,
|
|
36
|
+
info-color: #1e40af,
|
|
37
|
+
info-border: #bfdbfe,
|
|
38
|
+
info-icon-color: #3b82f6,
|
|
39
|
+
|
|
40
|
+
// Warning
|
|
41
|
+
warning-bg: #fffbeb,
|
|
42
|
+
warning-color: #92400e,
|
|
43
|
+
warning-border: #fde68a,
|
|
44
|
+
warning-icon-color: #f59e0b
|
|
45
|
+
);
|
|
46
|
+
|
|
47
|
+
// Mixin to generate CSS variables for the snackbar component
|
|
48
|
+
// E.g., @include cc-snackbar-theme()
|
|
49
|
+
@mixin snackbar-theme($user-config: ()) {
|
|
50
|
+
// Merge user config with defaults
|
|
51
|
+
$config: map.merge($default-snackbar-config, $user-config);
|
|
52
|
+
|
|
53
|
+
// Structural
|
|
54
|
+
--cc-sb-font-family: #{map.get($config, font-family)};
|
|
55
|
+
--cc-sb-font-size: #{map.get($config, font-size)};
|
|
56
|
+
--cc-sb-font-weight: #{map.get($config, font-weight)};
|
|
57
|
+
--cc-sb-min-width: #{map.get($config, min-width)};
|
|
58
|
+
--cc-sb-padding: #{map.get($config, padding)};
|
|
59
|
+
--cc-sb-gap: #{map.get($config, gap)};
|
|
60
|
+
--cc-sb-radius: #{map.get($config, radius)};
|
|
61
|
+
--cc-sb-shadow: #{map.get($config, shadow)};
|
|
62
|
+
--cc-sb-icon-size: #{map.get($config, icon-size)};
|
|
63
|
+
--cc-sb-close-icon-size: #{map.get($config, close-icon-size)};
|
|
64
|
+
|
|
65
|
+
// Base Defaults
|
|
66
|
+
--cc-sb-bg: #{map.get($config, bg)};
|
|
67
|
+
--cc-sb-color: #{map.get($config, color)};
|
|
68
|
+
--cc-sb-border: #{map.get($config, border)};
|
|
69
|
+
|
|
70
|
+
// Success
|
|
71
|
+
--cc-sb-success-bg: #{map.get($config, success-bg)};
|
|
72
|
+
--cc-sb-success-color: #{map.get($config, success-color)};
|
|
73
|
+
--cc-sb-success-border: #{map.get($config, success-border)};
|
|
74
|
+
--cc-sb-success-icon-color: #{map.get($config, success-icon-color)};
|
|
75
|
+
|
|
76
|
+
// Error
|
|
77
|
+
--cc-sb-error-bg: #{map.get($config, error-bg)};
|
|
78
|
+
--cc-sb-error-color: #{map.get($config, error-color)};
|
|
79
|
+
--cc-sb-error-border: #{map.get($config, error-border)};
|
|
80
|
+
--cc-sb-error-icon-color: #{map.get($config, error-icon-color)};
|
|
81
|
+
|
|
82
|
+
// Info
|
|
83
|
+
--cc-sb-info-bg: #{map.get($config, info-bg)};
|
|
84
|
+
--cc-sb-info-color: #{map.get($config, info-color)};
|
|
85
|
+
--cc-sb-info-border: #{map.get($config, info-border)};
|
|
86
|
+
--cc-sb-info-icon-color: #{map.get($config, info-icon-color)};
|
|
87
|
+
|
|
88
|
+
// Warning
|
|
89
|
+
--cc-sb-warning-bg: #{map.get($config, warning-bg)};
|
|
90
|
+
--cc-sb-warning-color: #{map.get($config, warning-color)};
|
|
91
|
+
--cc-sb-warning-border: #{map.get($config, warning-border)};
|
|
92
|
+
--cc-sb-warning-icon-color: #{map.get($config, warning-icon-color)};
|
|
93
|
+
}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
<div class="cc-summary-card" (click)="onCardClick()">
|
|
2
|
+
<!-- Icon Section (Left Side) -->
|
|
3
|
+
<div class="icon-section" *ngIf="config.icon || config.iconImage" [ngClass]="config.iconClass"
|
|
4
|
+
[ngStyle]="iconStyles">
|
|
5
|
+
<mat-icon *ngIf="config.icon">{{ config.icon }}</mat-icon>
|
|
6
|
+
<img *ngIf="!config.icon && config.iconImage" [src]="config.iconImage" [alt]="labels.iconAlt">
|
|
7
|
+
</div>
|
|
8
|
+
|
|
9
|
+
<!-- Right Section (Header + Value/Meta) -->
|
|
10
|
+
<div class="right-section">
|
|
11
|
+
<!-- Header (Full Width on Right) -->
|
|
12
|
+
<div class="header" [ngClass]="config.headerClass" [ngStyle]="headerStyles">
|
|
13
|
+
{{ config.header }}
|
|
14
|
+
</div>
|
|
15
|
+
|
|
16
|
+
<!-- Value and Meta Row -->
|
|
17
|
+
<div class="value-meta-row">
|
|
18
|
+
<!-- Content Section -->
|
|
19
|
+
<div class="content-section">
|
|
20
|
+
<!-- Value Row (with optional inline description) -->
|
|
21
|
+
<div class="value-row" [class.inline-layout]="isDescriptionInline">
|
|
22
|
+
<div class="value-container">
|
|
23
|
+
<div class="value" [ngClass]="config.valueClass" [ngStyle]="valueStyles">
|
|
24
|
+
{{ config.value }}
|
|
25
|
+
<span *ngIf="config.valueSubtext" class="value-subtext">{{ config.valueSubtext }}</span>
|
|
26
|
+
</div>
|
|
27
|
+
</div>
|
|
28
|
+
|
|
29
|
+
<!-- Description (inline or bottom based on config) -->
|
|
30
|
+
<div class="description" *ngIf="config.description" [ngClass]="config.descriptionClass"
|
|
31
|
+
[ngStyle]="descriptionStyles">
|
|
32
|
+
{{ config.description }}
|
|
33
|
+
</div>
|
|
34
|
+
</div>
|
|
35
|
+
</div>
|
|
36
|
+
|
|
37
|
+
<!-- Meta/Status Section (Aligned with Value) -->
|
|
38
|
+
<div class="meta-section" *ngIf="config.metaData && config.metaData.length > 0">
|
|
39
|
+
<div *ngFor="let meta of config.metaData" class="meta-item"
|
|
40
|
+
[ngClass]="[meta.type === 'pill' ? 'meta-pill' : 'meta-text', meta.cssClass || '']"
|
|
41
|
+
[ngStyle]="getMetaStyles(meta)">
|
|
42
|
+
{{ meta.text }}
|
|
43
|
+
</div>
|
|
44
|
+
</div>
|
|
45
|
+
</div>
|
|
46
|
+
</div>
|
|
47
|
+
</div>
|
|
@@ -0,0 +1,199 @@
|
|
|
1
|
+
:host {
|
|
2
|
+
display: block;
|
|
3
|
+
width: 100%;
|
|
4
|
+
}
|
|
5
|
+
|
|
6
|
+
.cc-summary-card {
|
|
7
|
+
display: flex;
|
|
8
|
+
flex-direction: row;
|
|
9
|
+
align-items: stretch;
|
|
10
|
+
box-sizing: border-box;
|
|
11
|
+
font-family: var(--cc-sc-font-family, 'Inter', sans-serif);
|
|
12
|
+
background-color: var(--cc-sc-bg-color, #ffffff);
|
|
13
|
+
border-radius: var(--cc-sc-border-radius, 8px);
|
|
14
|
+
border: var(--cc-sc-border, 1px solid #e0e0e0);
|
|
15
|
+
padding: var(--cc-sc-padding, 16px);
|
|
16
|
+
box-shadow: var(--cc-sc-shadow, 0 2px 4px rgba(0, 0, 0, 0.05));
|
|
17
|
+
transition: all var(--cc-sc-transition-duration, 0.2s) ease;
|
|
18
|
+
height: 100%;
|
|
19
|
+
width: 100%;
|
|
20
|
+
overflow: hidden;
|
|
21
|
+
gap: var(--cc-sc-icon-margin, 1rem);
|
|
22
|
+
|
|
23
|
+
&.clickable {
|
|
24
|
+
cursor: pointer;
|
|
25
|
+
|
|
26
|
+
&:hover {
|
|
27
|
+
transform: var(--cc-sc-hover-transform);
|
|
28
|
+
box-shadow: var(--cc-sc-hover-shadow);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
&.disabled {
|
|
33
|
+
opacity: var(--cc-sc-disabled-opacity);
|
|
34
|
+
cursor: not-allowed;
|
|
35
|
+
pointer-events: none;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
// Icon Section (Left Side)
|
|
39
|
+
.icon-section {
|
|
40
|
+
width: var(--cc-sc-icon-box-size);
|
|
41
|
+
height: var(--cc-sc-icon-box-size);
|
|
42
|
+
min-width: var(--cc-sc-icon-box-size);
|
|
43
|
+
display: flex;
|
|
44
|
+
align-items: center;
|
|
45
|
+
justify-content: center;
|
|
46
|
+
border-radius: var(--cc-sc-icon-radius);
|
|
47
|
+
background-color: var(--cc-sc-icon-bg);
|
|
48
|
+
color: var(--cc-sc-icon-color);
|
|
49
|
+
flex-shrink: 0;
|
|
50
|
+
align-self: center;
|
|
51
|
+
|
|
52
|
+
mat-icon {
|
|
53
|
+
width: var(--cc-sc-icon-size);
|
|
54
|
+
height: var(--cc-sc-icon-size);
|
|
55
|
+
font-size: var(--cc-sc-icon-size);
|
|
56
|
+
line-height: var(--cc-sc-icon-size);
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
img {
|
|
60
|
+
width: var(--cc-sc-icon-size);
|
|
61
|
+
height: var(--cc-sc-icon-size);
|
|
62
|
+
object-fit: contain;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
// Right Section (Header + Value/Meta)
|
|
67
|
+
.right-section {
|
|
68
|
+
display: flex;
|
|
69
|
+
flex-direction: column;
|
|
70
|
+
flex: 1;
|
|
71
|
+
min-width: 0;
|
|
72
|
+
gap: var(--cc-sc-content-gap, 0.5rem);
|
|
73
|
+
|
|
74
|
+
.header {
|
|
75
|
+
font-size: var(--cc-sc-header-size);
|
|
76
|
+
font-weight: var(--cc-sc-header-weight);
|
|
77
|
+
text-transform: var(--cc-sc-header-transform);
|
|
78
|
+
color: var(--cc-sc-header-color);
|
|
79
|
+
letter-spacing: var(--cc-sc-header-letter-spacing);
|
|
80
|
+
line-height: var(--cc-sc-header-line-height);
|
|
81
|
+
white-space: nowrap;
|
|
82
|
+
overflow: hidden;
|
|
83
|
+
text-overflow: ellipsis;
|
|
84
|
+
width: 100%;
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
// Value and Meta Row
|
|
88
|
+
.value-meta-row {
|
|
89
|
+
display: flex;
|
|
90
|
+
flex-direction: row;
|
|
91
|
+
align-items: flex-start;
|
|
92
|
+
justify-content: space-between;
|
|
93
|
+
gap: 1rem;
|
|
94
|
+
flex: 1;
|
|
95
|
+
|
|
96
|
+
// Content Section
|
|
97
|
+
.content-section {
|
|
98
|
+
display: flex;
|
|
99
|
+
flex-direction: column;
|
|
100
|
+
justify-content: flex-start;
|
|
101
|
+
flex: 1;
|
|
102
|
+
min-width: 0;
|
|
103
|
+
|
|
104
|
+
.value-row {
|
|
105
|
+
display: flex;
|
|
106
|
+
flex-direction: column;
|
|
107
|
+
gap: var(--cc-sc-value-desc-gap);
|
|
108
|
+
|
|
109
|
+
&.inline-layout {
|
|
110
|
+
flex-direction: row;
|
|
111
|
+
align-items: baseline;
|
|
112
|
+
flex-wrap: wrap;
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
.value {
|
|
116
|
+
font-size: var(--cc-sc-value-size);
|
|
117
|
+
font-weight: var(--cc-sc-value-weight);
|
|
118
|
+
color: var(--cc-sc-value-color);
|
|
119
|
+
line-height: var(--cc-sc-value-line-height);
|
|
120
|
+
white-space: nowrap;
|
|
121
|
+
|
|
122
|
+
.value-subtext {
|
|
123
|
+
font-size: var(--cc-sc-desc-size);
|
|
124
|
+
font-weight: var(--cc-sc-desc-weight);
|
|
125
|
+
color: var(--cc-sc-desc-color);
|
|
126
|
+
margin-left: 4px;
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
.description {
|
|
131
|
+
font-size: var(--cc-sc-desc-size);
|
|
132
|
+
font-weight: var(--cc-sc-desc-weight);
|
|
133
|
+
color: var(--cc-sc-desc-color);
|
|
134
|
+
line-height: var(--cc-sc-desc-line-height);
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
// Meta Section (Aligned with Value)
|
|
140
|
+
.meta-section {
|
|
141
|
+
display: flex;
|
|
142
|
+
flex-direction: column;
|
|
143
|
+
align-items: flex-end;
|
|
144
|
+
justify-content: flex-start;
|
|
145
|
+
flex-shrink: 0;
|
|
146
|
+
gap: 6px;
|
|
147
|
+
|
|
148
|
+
.meta-item {
|
|
149
|
+
font-size: 0.8125rem; // ~13px
|
|
150
|
+
line-height: 1.4;
|
|
151
|
+
white-space: nowrap;
|
|
152
|
+
text-align: right;
|
|
153
|
+
flex-shrink: 0;
|
|
154
|
+
|
|
155
|
+
&.meta-text {
|
|
156
|
+
color: var(--cc-sc-desc-color, #64748b);
|
|
157
|
+
font-weight: 500;
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
&.meta-pill {
|
|
161
|
+
display: inline-flex;
|
|
162
|
+
align-items: center;
|
|
163
|
+
justify-content: center;
|
|
164
|
+
padding: var(--cc-sc-meta-pill-padding, 4px 12px);
|
|
165
|
+
border-radius: var(--cc-sc-meta-pill-radius, 20px);
|
|
166
|
+
font-size: var(--cc-sc-meta-pill-font-size, 0.75rem);
|
|
167
|
+
font-weight: var(--cc-sc-meta-pill-font-weight, 600);
|
|
168
|
+
line-height: 1.2;
|
|
169
|
+
background-color: var(--cc-sc-meta-pill-bg, #f1f5f9);
|
|
170
|
+
color: var(--cc-sc-meta-pill-color, #475569);
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
// Responsive Design
|
|
178
|
+
@media (max-width: 600px) {
|
|
179
|
+
.icon-section {
|
|
180
|
+
margin-right: var(--cc-sc-icon-margin-mobile, 0.75rem);
|
|
181
|
+
}
|
|
182
|
+
|
|
183
|
+
.content-section {
|
|
184
|
+
.header {
|
|
185
|
+
font-size: var(--cc-sc-header-size-mobile, 0.7rem);
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
.value-row {
|
|
189
|
+
.value {
|
|
190
|
+
font-size: var(--cc-sc-value-size-mobile, 1.25rem);
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
.description {
|
|
194
|
+
font-size: var(--cc-sc-desc-size-mobile, 0.7rem);
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
}
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
import { Component, Input, Output, EventEmitter, HostBinding } from '@angular/core';
|
|
2
|
+
|
|
3
|
+
export interface SummaryCardConfig {
|
|
4
|
+
header: string;
|
|
5
|
+
value: string;
|
|
6
|
+
description?: string;
|
|
7
|
+
|
|
8
|
+
// Icon or Image (mutually exclusive)
|
|
9
|
+
icon?: string; // Material icon name
|
|
10
|
+
iconImage?: string; // URL for image icon
|
|
11
|
+
|
|
12
|
+
// Layout configurations
|
|
13
|
+
descriptionPosition?: 'bottom' | 'inline'; // 'bottom' (default) or 'inline' (right side of value)
|
|
14
|
+
|
|
15
|
+
// Extended Content
|
|
16
|
+
valueSubtext?: string; // Text displayed next to the value (e.g. "/ 15 Target")
|
|
17
|
+
metaData?: SummaryCardMeta[]; // Right-aligned meta information
|
|
18
|
+
|
|
19
|
+
// Color configurations
|
|
20
|
+
valueColor?: string; // Color for the value text
|
|
21
|
+
headerColor?: string; // Color for the header text
|
|
22
|
+
descriptionColor?: string; // Color for the description text
|
|
23
|
+
iconColor?: string; // Color for the icon
|
|
24
|
+
iconBackgroundColor?: string; // Background color for the icon container
|
|
25
|
+
|
|
26
|
+
// Additional styling
|
|
27
|
+
iconClass?: string; // Additional CSS classes for icon
|
|
28
|
+
valueClass?: string; // Additional CSS classes for value
|
|
29
|
+
headerClass?: string; // Additional CSS classes for header
|
|
30
|
+
descriptionClass?: string; // Additional CSS classes for description
|
|
31
|
+
|
|
32
|
+
// Interaction
|
|
33
|
+
isDisabled?: boolean; // Disable click interaction
|
|
34
|
+
isClickable?: boolean; // Whether card is clickable (default: true)
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
export interface SummaryCardMeta {
|
|
38
|
+
text: string;
|
|
39
|
+
type?: 'text' | 'pill'; // 'text' (default) or 'pill' (badge style)
|
|
40
|
+
color?: string; // Text color
|
|
41
|
+
backgroundColor?: string; // Background color for pill
|
|
42
|
+
cssClass?: string; // Custom CSS class
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
export interface SummaryCardLabels {
|
|
46
|
+
iconAlt: string;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
@Component({
|
|
50
|
+
selector: 'lib-summary-card',
|
|
51
|
+
templateUrl: './summary-card.component.html',
|
|
52
|
+
styleUrls: ['./summary-card.component.scss'],
|
|
53
|
+
standalone: false
|
|
54
|
+
})
|
|
55
|
+
export class SummaryCardComponent {
|
|
56
|
+
@Input() config!: SummaryCardConfig;
|
|
57
|
+
@Input() theme?: 'theme-1' | 'theme-2';
|
|
58
|
+
@Input() labels: any;
|
|
59
|
+
@Output() cardClick = new EventEmitter<void>();
|
|
60
|
+
|
|
61
|
+
constructor() { }
|
|
62
|
+
|
|
63
|
+
onCardClick(): void {
|
|
64
|
+
if (this.config?.isDisabled || this.config?.isClickable === false) {
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
67
|
+
this.cardClick.emit();
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
get cardClasses(): { [key: string]: boolean } {
|
|
71
|
+
return {
|
|
72
|
+
'disabled': !!this.config?.isDisabled,
|
|
73
|
+
'clickable': this.config?.isClickable !== false && !this.config?.isDisabled
|
|
74
|
+
};
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
get iconStyles(): { [key: string]: string } {
|
|
78
|
+
const styles: { [key: string]: string } = {};
|
|
79
|
+
if (this.config.iconBackgroundColor) {
|
|
80
|
+
styles['backgroundColor'] = this.config.iconBackgroundColor;
|
|
81
|
+
}
|
|
82
|
+
if (this.config.iconColor) {
|
|
83
|
+
styles['color'] = this.config.iconColor;
|
|
84
|
+
}
|
|
85
|
+
return styles;
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
get headerStyles(): { [key: string]: string } {
|
|
89
|
+
const styles: { [key: string]: string } = {};
|
|
90
|
+
if (this.config.headerColor) {
|
|
91
|
+
styles['color'] = this.config.headerColor;
|
|
92
|
+
}
|
|
93
|
+
return styles;
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
get valueStyles(): { [key: string]: string } {
|
|
97
|
+
const styles: { [key: string]: string } = {};
|
|
98
|
+
if (this.config.valueColor) {
|
|
99
|
+
styles['color'] = this.config.valueColor;
|
|
100
|
+
}
|
|
101
|
+
return styles;
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
get descriptionStyles(): { [key: string]: string } {
|
|
105
|
+
const styles: { [key: string]: string } = {};
|
|
106
|
+
if (this.config.descriptionColor) {
|
|
107
|
+
styles['color'] = this.config.descriptionColor;
|
|
108
|
+
}
|
|
109
|
+
return styles;
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
get isDescriptionInline(): boolean {
|
|
113
|
+
return this.config.descriptionPosition === 'inline';
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
getMetaStyles(meta: SummaryCardMeta): { [key: string]: string } {
|
|
117
|
+
const styles: { [key: string]: string } = {};
|
|
118
|
+
if (meta.color) {
|
|
119
|
+
styles['color'] = meta.color;
|
|
120
|
+
}
|
|
121
|
+
if (meta.backgroundColor && meta.type === 'pill') {
|
|
122
|
+
styles['backgroundColor'] = meta.backgroundColor;
|
|
123
|
+
}
|
|
124
|
+
return styles;
|
|
125
|
+
}
|
|
126
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
4
|
+
import { SummaryCardComponent } from './components/summary-card/summary-card.component';
|
|
5
|
+
|
|
6
|
+
@NgModule({
|
|
7
|
+
declarations: [
|
|
8
|
+
SummaryCardComponent
|
|
9
|
+
],
|
|
10
|
+
imports: [
|
|
11
|
+
CommonModule,
|
|
12
|
+
MatIconModule
|
|
13
|
+
],
|
|
14
|
+
exports: [
|
|
15
|
+
SummaryCardComponent
|
|
16
|
+
]
|
|
17
|
+
})
|
|
18
|
+
export class SummaryCardModule { }
|