@softheon/armature 17.29.0 → 17.30.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.
@@ -0,0 +1,3 @@
1
+ {
2
+ "module": "../fesm2022/softheon-armature-ag-grid-components.mjs"
3
+ }
@@ -1,96 +1,129 @@
1
- @use "@angular/material" as mat;
2
1
  @use "../arm-theme" as theme;
2
+ @use "../variables" as vars;
3
3
 
4
- mat-radio-button.sof-radio-button.mat-mdc-radio-checked {
5
- &.mat-primary,
6
- &[color="primary"] {
7
- --mdc-radio-selected-focus-icon-color: #{mat.get-color-from-palette(theme.$arm-primary, 500)};
8
- --mdc-radio-selected-hover-icon-color: #{mat.get-color-from-palette(theme.$arm-primary, 500)};
9
- --mdc-radio-selected-icon-color: #{mat.get-color-from-palette(theme.$arm-primary, 500)};
10
- --mdc-radio-selected-pressed-icon-color: #{mat.get-color-from-palette(theme.$arm-primary, 500)};
11
- --mat-mdc-radio-checked-ripple-color: #{mat.get-color-from-palette(theme.$arm-primary, 500)};
12
- }
4
+ .sof-radio-button {
5
+ display: flex !important;
6
+ width: fit-content !important;
13
7
 
14
- &.mat-accent,
15
- &[color="accent"] {
16
- --mdc-radio-selected-focus-icon-color: #{mat.get-color-from-palette(theme.$arm-accent, 500)};
17
- --mdc-radio-selected-hover-icon-color: #{mat.get-color-from-palette(theme.$arm-accent, 500)};
18
- --mdc-radio-selected-icon-color: #{mat.get-color-from-palette(theme.$arm-accent, 500)};
19
- --mdc-radio-selected-pressed-icon-color: #{mat.get-color-from-palette(theme.$arm-accent, 500)};
20
- --mat-mdc-radio-checked-ripple-color: #{mat.get-color-from-palette(theme.$arm-accent, 500)};
8
+ * {
9
+ box-sizing: border-box !important;
21
10
  }
22
11
 
23
- &.mat-warn,
24
- &[color="warn"] {
25
- --mdc-radio-selected-focus-icon-color: #{mat.get-color-from-palette(theme.$arm-warn, 500)};
26
- --mdc-radio-selected-hover-icon-color: #{mat.get-color-from-palette(theme.$arm-warn, 500)};
27
- --mdc-radio-selected-icon-color: #{mat.get-color-from-palette(theme.$arm-warn, 500)};
28
- --mdc-radio-selected-pressed-icon-color: #{mat.get-color-from-palette(theme.$arm-warn, 500)};
29
- --mat-mdc-radio-checked-ripple-color: #{mat.get-color-from-palette(theme.$arm-warn, 500)};
30
- }
12
+ $sof-radio-size: 20px;
13
+
14
+ --mdc-radio-disabled-selected-icon-color: #{map-get(theme.$arm-neutral, 300)} !important;
15
+ --mdc-radio-disabled-unselected-icon-color: #{map-get(theme.$arm-neutral, 300)} !important;
16
+ --mdc-radio-disabled-selected-icon-opacity: 1 !important;
17
+ --mdc-radio-disabled-unselected-icon-opacity: 1 !important;
18
+
19
+ --mdc-radio-unselected-icon-color: #{map-get(theme.$arm-neutral, 500)} !important;
20
+ --mdc-radio-unselected-hover-icon-color: #{map-get(theme.$arm-neutral, 700)} !important;
21
+ --mdc-radio-unselected-pressed-icon-color: #{map-get(theme.$arm-neutral, 800)} !important;
31
22
 
32
- &.mat-success,
33
- &[color="success"] {
34
- --mdc-radio-selected-focus-icon-color: #{mat.get-color-from-palette(theme.$arm-success, 500)};
35
- --mdc-radio-selected-hover-icon-color: #{mat.get-color-from-palette(theme.$arm-success, 500)};
36
- --mdc-radio-selected-icon-color: #{mat.get-color-from-palette(theme.$arm-success, 500)};
37
- --mdc-radio-selected-pressed-icon-color: #{mat.get-color-from-palette(theme.$arm-success, 500)};
38
- --mat-mdc-radio-checked-ripple-color: #{mat.get-color-from-palette(theme.$arm-success, 500)};
23
+ --mdc-radio-selected-icon-color: #{map-get(theme.$arm-primary, 500)} !important;
24
+ --mdc-radio-selected-hover-icon-color: #{map-get(theme.$arm-primary, 700)} !important;
25
+ --mdc-radio-selected-focus-icon-color: #{map-get(theme.$arm-primary, 800)} !important;
26
+ --mdc-radio-selected-pressed-icon-color: #{map-get(theme.$arm-primary, 800)} !important;
27
+
28
+ --mat-radio-ripple-color: transparent !important;
29
+ --mat-radio-checked-ripple-color: transparent !important;
30
+
31
+ &:hover {
32
+ .mdc-radio:not(.mdc-radio--disabled) {
33
+ .mat-mdc-radio-touch-target {
34
+ background: map-get(theme.$arm-primary, A100) !important;
35
+ }
36
+ }
39
37
  }
40
38
 
41
- &.mat-info,
42
- &[color="info"] {
43
- --mdc-radio-selected-focus-icon-color: #{mat.get-color-from-palette(theme.$arm-info, 500)};
44
- --mdc-radio-selected-hover-icon-color: #{mat.get-color-from-palette(theme.$arm-info, 500)};
45
- --mdc-radio-selected-icon-color: #{mat.get-color-from-palette(theme.$arm-info, 500)};
46
- --mdc-radio-selected-pressed-icon-color: #{mat.get-color-from-palette(theme.$arm-info, 500)};
47
- --mat-mdc-radio-checked-ripple-color: #{mat.get-color-from-palette(theme.$arm-info, 500)};
39
+ &:hover:not(.mat-mdc-radio-checked) {
40
+ .mdc-radio__background {
41
+ .mdc-radio__outer-circle {
42
+ border-color: map-get(theme.$arm-neutral, 700) !important;
43
+ }
44
+ }
48
45
  }
49
46
 
50
- &.mat-error,
51
- &[color="error"] {
52
- --mdc-radio-selected-focus-icon-color: #{mat.get-color-from-palette(theme.$arm-error, 500)};
53
- --mdc-radio-selected-hover-icon-color: #{mat.get-color-from-palette(theme.$arm-error, 500)};
54
- --mdc-radio-selected-icon-color: #{mat.get-color-from-palette(theme.$arm-error, 500)};
55
- --mdc-radio-selected-pressed-icon-color: #{mat.get-color-from-palette(theme.$arm-error, 500)};
56
- --mat-mdc-radio-checked-ripple-color: #{mat.get-color-from-palette(theme.$arm-error, 500)};
47
+ &:active {
48
+ .mdc-radio:not(.mdc-radio--disabled) {
49
+ .mat-mdc-radio-touch-target {
50
+ background: map-get(theme.$arm-primary, A200) !important;
51
+ }
52
+ }
57
53
  }
58
54
 
59
- &.mat-neutral,
60
55
  &[color="neutral"] {
61
- --mdc-radio-selected-focus-icon-color: #{mat.get-color-from-palette(theme.$arm-neutral, 500)};
62
- --mdc-radio-selected-hover-icon-color: #{mat.get-color-from-palette(theme.$arm-neutral, 500)};
63
- --mdc-radio-selected-icon-color: #{mat.get-color-from-palette(theme.$arm-neutral, 500)};
64
- --mdc-radio-selected-pressed-icon-color: #{mat.get-color-from-palette(theme.$arm-neutral, 500)};
65
- --mat-mdc-radio-checked-ripple-color: #{mat.get-color-from-palette(theme.$arm-neutral, 500)};
66
- }
67
- }
56
+ --mdc-radio-selected-icon-color: #{map-get(theme.$arm-neutral, 500)} !important;
57
+ --mdc-radio-selected-hover-icon-color: #{map-get(theme.$arm-neutral, 700)} !important;
58
+ --mdc-radio-selected-focus-icon-color: #{map-get(theme.$arm-neutral, 800)} !important;
59
+ --mdc-radio-selected-pressed-icon-color: #{map-get(theme.$arm-neutral, 800)} !important;
68
60
 
69
- mat-radio-button.sof-radio-button {
70
- .mdc-radio__background {
71
- border-width: 3px !important;
61
+ &:hover {
62
+ .mdc-radio:not(.mdc-radio--disabled) {
63
+ .mat-mdc-radio-touch-target {
64
+ background: map-get(theme.$arm-neutral, A100) !important;
65
+ }
66
+ }
67
+ }
68
+
69
+ &:active {
70
+ .mdc-radio:not(.mdc-radio--disabled) {
71
+ .mat-mdc-radio-touch-target {
72
+ background: map-get(theme.$arm-neutral, A200) !important;
73
+ }
74
+ }
75
+ }
72
76
  }
73
77
 
74
- .mdc-radio__background,
75
78
  .mdc-radio {
76
- width: 20px !important;
77
- height: 20px !important;
78
- }
79
+ --mdc-radio-state-layer-size: #{$sof-radio-size};
80
+ margin: 0 !important;
81
+ padding: 0 !important;
82
+ width: calc($sof-radio-size) !important;
83
+ height: calc($sof-radio-size) !important;
84
+ flex: none !important;
79
85
 
80
- .mdc-radio__native-control {
81
- width: 24px !important;
82
- height: 24px !important;
83
- transform: translate(0.7em, 9.5px);
84
- }
86
+ .mat-mdc-radio-touch-target {
87
+ width: calc($sof-radio-size + 4px) !important;
88
+ height: calc($sof-radio-size + 4px) !important;
89
+ border-radius: 50% !important;
90
+ background: transparent !important;
91
+ }
92
+
93
+ .mdc-radio__native-control {
94
+ width: $sof-radio-size !important;
95
+ height: $sof-radio-size !important;
96
+ }
85
97
 
86
- .mat-mdc-radio-touch-target {
87
- transform: translate(-48%, -50%) !important;
98
+ .mdc-radio__native-control:focus ~ .mdc-radio__background {
99
+ outline: 3px solid !important;
100
+ outline-offset: 2px !important;
101
+ outline-color: map-get(theme.$arm-primary, 300) !important;
102
+ }
103
+
104
+ .mdc-radio__background {
105
+ border-radius: 50% !important;
106
+ width: $sof-radio-size !important;
107
+ height: $sof-radio-size !important;
108
+ }
109
+
110
+ .mat-radio-ripple,
111
+ .mdc-radio:hover .mdc-radio__native-control:not([disabled])~.mdc-radio-ripple {
112
+ display: none !important;
113
+ }
88
114
  }
89
115
 
90
- .mat-radio-ripple,
91
- .mdc-radio:hover .mdc-radio__native-control:not([disabled])~.mdc-radio-ripple {
92
- width: 40px;
93
- height: 40px;
94
- transform: translate(1px, 1px) !important;
116
+ label {
117
+ padding: 0 0 0 8px !important;
118
+ font-family: "Poppins", sans-serif !important;
119
+ letter-spacing: 0px !important;
120
+ font-size: 16px !important;
121
+ line-height: $sof-radio-size !important;
122
+ cursor: pointer !important;
95
123
  }
96
124
  }
125
+
126
+ .mat-mdc-radio-button .mdc-radio--disabled+label {
127
+ color: vars.$text-low-emphasis !important;
128
+ cursor: default !important;
129
+ }
@@ -10,4 +10,4 @@
10
10
  * Do not edit the class manually.
11
11
  */
12
12
  export {};
13
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhlbWVQYWxldHRlQ29sb3JzTW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hcm1hdHVyZS9zcmMvbGliL2NvcmUvY2xpZW50LWdlbmVyYXRlZC9tb2RlbC90aGVtZVBhbGV0dGVDb2xvcnNNb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7OztHQVVHIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXHJcbiAqIERpc3RyaWJ1dGVkIENhY2hlIEFQSVxyXG4gKiBObyBkZXNjcmlwdGlvbiBwcm92aWRlZCAoZ2VuZXJhdGVkIGJ5IFN3YWdnZXIgQ29kZWdlbiBodHRwczovL2dpdGh1Yi5jb20vc3dhZ2dlci1hcGkvc3dhZ2dlci1jb2RlZ2VuKVxyXG4gKlxyXG4gKiBPcGVuQVBJIHNwZWMgdmVyc2lvbjogMVxyXG4gKiBcclxuICpcclxuICogTk9URTogVGhpcyBjbGFzcyBpcyBhdXRvIGdlbmVyYXRlZCBieSB0aGUgc3dhZ2dlciBjb2RlIGdlbmVyYXRvciBwcm9ncmFtLlxyXG4gKiBodHRwczovL2dpdGh1Yi5jb20vc3dhZ2dlci1hcGkvc3dhZ2dlci1jb2RlZ2VuLmdpdFxyXG4gKiBEbyBub3QgZWRpdCB0aGUgY2xhc3MgbWFudWFsbHkuXHJcbiAqL1xyXG5cclxuLyoqXHJcbiAqIFRoZSB0aGVtZSBwYWxldHRlXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIFRoZW1lUGFsZXR0ZUNvbG9yc01vZGVsIHsgXHJcbiAgICAvKipcclxuICAgICAqIFRoZSA1MCBwYWxldHRlIGNvbG9yXHJcbiAgICAgKi9cclxuICAgIGZpZnR5OiBzdHJpbmc7XHJcbiAgICAvKipcclxuICAgICAqIFRoZSAxMDAgcGFsZXR0ZSBjb2xvclxyXG4gICAgICovXHJcbiAgICBvbmVIdW5kcmVkOiBzdHJpbmc7XHJcbiAgICAvKipcclxuICAgICAqIFRoZSAyMDAgcGFsZXR0ZSBjb2xvclxyXG4gICAgICovXHJcbiAgICB0d29IdW5kcmVkOiBzdHJpbmc7XHJcbiAgICAvKipcclxuICAgICAqIFRoZSAzMDAgcGFsZXR0ZSBjb2xvclxyXG4gICAgICovXHJcbiAgICB0aHJlZUh1bmRyZWQ6IHN0cmluZztcclxuICAgIC8qKlxyXG4gICAgICogVGhlIDQwMCBwYWxldHRlIGNvbG9yXHJcbiAgICAgKi9cclxuICAgIGZvdXJIdW5kcmVkOiBzdHJpbmc7XHJcbiAgICAvKipcclxuICAgICAqIFRoZSA1MDAgcGFsZXR0ZSBjb2xvclxyXG4gICAgICovXHJcbiAgICBmaXZlSHVuZHJlZDogc3RyaW5nO1xyXG4gICAgLyoqXHJcbiAgICAgKiBUaGUgNjAwIHBhbGV0dGUgY29sb3JcclxuICAgICAqL1xyXG4gICAgc2l4SHVuZHJlZDogc3RyaW5nO1xyXG4gICAgLyoqXHJcbiAgICAgKiBUaGUgNzAwIHBhbGV0dGUgY29sb3JcclxuICAgICAqL1xyXG4gICAgc2V2ZW5IdW5kcmVkOiBzdHJpbmc7XHJcbiAgICAvKipcclxuICAgICAqIFRoZSA4MDAgcGFsZXR0ZSBjb2xvclxyXG4gICAgICovXHJcbiAgICBlaWdodEh1bmRyZWQ6IHN0cmluZztcclxuICAgIC8qKlxyXG4gICAgICogVGhlIDkwMCBwYWxldHRlIGNvbG9yXHJcbiAgICAgKi9cclxuICAgIG5pbmVIdW5kcmVkOiBzdHJpbmc7XHJcbiAgICAvKipcclxuICAgICAqIFRoZSBBMTAwIHBhbGV0dGUgY29sb3JcclxuICAgICAqL1xyXG4gICAgYTEwMDogc3RyaW5nO1xyXG4gICAgLyoqXHJcbiAgICAgKiBUaGUgQTIwMCBwYWxldHRlIGNvbG9yXHJcbiAgICAgKi9cclxuICAgIGEyMDA6IHN0cmluZztcclxuICAgIC8qKlxyXG4gICAgICogVGhlIEEzMDAgcGFsZXR0ZSBjb2xvclxyXG4gICAgICovXHJcbiAgICBhMzAwOiBzdHJpbmc7XHJcbiAgICAvKipcclxuICAgICAqIFRoZSBBNDAwIHBhbGV0dGUgY29sb3JcclxuICAgICAqL1xyXG4gICAgYTQwMDogc3RyaW5nO1xyXG4gICAgLyoqXHJcbiAgICAgKiBUaGUgQTUwMCBwYWxldHRlIGNvbG9yXHJcbiAgICAgKi9cclxuICAgIGE1MDA6IHN0cmluZztcclxufSJdfQ==
13
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhlbWVQYWxldHRlQ29sb3JzTW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hcm1hdHVyZS9zcmMvbGliL2NvcmUvY2xpZW50LWdlbmVyYXRlZC9tb2RlbC90aGVtZVBhbGV0dGVDb2xvcnNNb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7OztHQVVHIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXHJcbiAqIERpc3RyaWJ1dGVkIENhY2hlIEFQSVxyXG4gKiBObyBkZXNjcmlwdGlvbiBwcm92aWRlZCAoZ2VuZXJhdGVkIGJ5IFN3YWdnZXIgQ29kZWdlbiBodHRwczovL2dpdGh1Yi5jb20vc3dhZ2dlci1hcGkvc3dhZ2dlci1jb2RlZ2VuKVxyXG4gKlxyXG4gKiBPcGVuQVBJIHNwZWMgdmVyc2lvbjogMVxyXG4gKiBcclxuICpcclxuICogTk9URTogVGhpcyBjbGFzcyBpcyBhdXRvIGdlbmVyYXRlZCBieSB0aGUgc3dhZ2dlciBjb2RlIGdlbmVyYXRvciBwcm9ncmFtLlxyXG4gKiBodHRwczovL2dpdGh1Yi5jb20vc3dhZ2dlci1hcGkvc3dhZ2dlci1jb2RlZ2VuLmdpdFxyXG4gKiBEbyBub3QgZWRpdCB0aGUgY2xhc3MgbWFudWFsbHkuXHJcbiAqL1xyXG5cclxuLyoqXHJcbiAqIFRoZSB0aGVtZSBwYWxldHRlXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIFRoZW1lUGFsZXR0ZUNvbG9yc01vZGVsIHsgXHJcbiAgICAvKipcclxuICAgICAqIFRoZSA1MCBwYWxldHRlIGNvbG9yXHJcbiAgICAgKi9cclxuICAgIGZpZnR5Pzogc3RyaW5nO1xyXG4gICAgLyoqXHJcbiAgICAgKiBUaGUgMTAwIHBhbGV0dGUgY29sb3JcclxuICAgICAqL1xyXG4gICAgb25lSHVuZHJlZD86IHN0cmluZztcclxuICAgIC8qKlxyXG4gICAgICogVGhlIDIwMCBwYWxldHRlIGNvbG9yXHJcbiAgICAgKi9cclxuICAgIHR3b0h1bmRyZWQ/OiBzdHJpbmc7XHJcbiAgICAvKipcclxuICAgICAqIFRoZSAzMDAgcGFsZXR0ZSBjb2xvclxyXG4gICAgICovXHJcbiAgICB0aHJlZUh1bmRyZWQ/OiBzdHJpbmc7XHJcbiAgICAvKipcclxuICAgICAqIFRoZSA0MDAgcGFsZXR0ZSBjb2xvclxyXG4gICAgICovXHJcbiAgICBmb3VySHVuZHJlZD86IHN0cmluZztcclxuICAgIC8qKlxyXG4gICAgICogVGhlIDUwMCBwYWxldHRlIGNvbG9yXHJcbiAgICAgKi9cclxuICAgIGZpdmVIdW5kcmVkPzogc3RyaW5nO1xyXG4gICAgLyoqXHJcbiAgICAgKiBUaGUgNjAwIHBhbGV0dGUgY29sb3JcclxuICAgICAqL1xyXG4gICAgc2l4SHVuZHJlZD86IHN0cmluZztcclxuICAgIC8qKlxyXG4gICAgICogVGhlIDcwMCBwYWxldHRlIGNvbG9yXHJcbiAgICAgKi9cclxuICAgIHNldmVuSHVuZHJlZD86IHN0cmluZztcclxuICAgIC8qKlxyXG4gICAgICogVGhlIDgwMCBwYWxldHRlIGNvbG9yXHJcbiAgICAgKi9cclxuICAgIGVpZ2h0SHVuZHJlZD86IHN0cmluZztcclxuICAgIC8qKlxyXG4gICAgICogVGhlIDkwMCBwYWxldHRlIGNvbG9yXHJcbiAgICAgKi9cclxuICAgIG5pbmVIdW5kcmVkPzogc3RyaW5nO1xyXG4gICAgLyoqXHJcbiAgICAgKiBUaGUgQTUwIHBhbGV0dGUgY29sb3JcclxuICAgICAqL1xyXG4gICAgYTUwPzogc3RyaW5nO1xyXG4gICAgLyoqXHJcbiAgICAgKiBUaGUgQTEwMCBwYWxldHRlIGNvbG9yXHJcbiAgICAgKi9cclxuICAgIGExMDA/OiBzdHJpbmc7XHJcbiAgICAvKipcclxuICAgICAqIFRoZSBBMjAwIHBhbGV0dGUgY29sb3JcclxuICAgICAqL1xyXG4gICAgYTIwMD86IHN0cmluZztcclxuICAgIC8qKlxyXG4gICAgICogVGhlIEEzMDAgcGFsZXR0ZSBjb2xvclxyXG4gICAgICovXHJcbiAgICBhMzAwPzogc3RyaW5nO1xyXG4gICAgLyoqXHJcbiAgICAgKiBUaGUgQTQwMCBwYWxldHRlIGNvbG9yXHJcbiAgICAgKi9cclxuICAgIGE0MDA/OiBzdHJpbmc7XHJcbiAgICAvKipcclxuICAgICAqIFRoZSBBNTAwIHBhbGV0dGUgY29sb3JcclxuICAgICAqL1xyXG4gICAgYTUwMD86IHN0cmluZztcclxuICAgIC8qKlxyXG4gICAgICogVGhlIEE2MDAgcGFsZXR0ZSBjb2xvclxyXG4gICAgICovXHJcbiAgICBhNjAwPzogc3RyaW5nO1xyXG4gICAgLyoqXHJcbiAgICAgKiBUaGUgQTcwMCBwYWxldHRlIGNvbG9yXHJcbiAgICAgKi9cclxuICAgIGE3MDA/OiBzdHJpbmc7XHJcbiAgICAvKipcclxuICAgICAqIFRoZSBBODAwIHBhbGV0dGUgY29sb3JcclxuICAgICAqL1xyXG4gICAgYTgwMD86IHN0cmluZztcclxuICAgIC8qKlxyXG4gICAgICogVGhlIEE5MDAgcGFsZXR0ZSBjb2xvclxyXG4gICAgICovXHJcbiAgICBhOTAwPzogc3RyaW5nO1xyXG59Il19
@@ -64,11 +64,16 @@ export class ThemeService {
64
64
  this.updateColor(paletteName, '700', palette.sevenHundred);
65
65
  this.updateColor(paletteName, '800', palette.eightHundred);
66
66
  this.updateColor(paletteName, '900', palette.nineHundred);
67
+ this.updateColor(paletteName, 'A50', palette.a50);
67
68
  this.updateColor(paletteName, 'A100', palette.a100);
68
69
  this.updateColor(paletteName, 'A200', palette.a200);
69
70
  this.updateColor(paletteName, 'A300', palette.a300);
70
71
  this.updateColor(paletteName, 'A400', palette.a400);
71
72
  this.updateColor(paletteName, 'A500', palette.a500);
73
+ this.updateColor(paletteName, 'A600', palette.a600);
74
+ this.updateColor(paletteName, 'A700', palette.a700);
75
+ this.updateColor(paletteName, 'A800', palette.a800);
76
+ this.updateColor(paletteName, 'A900', palette.a900);
72
77
  }
73
78
  else if (paletteType == CONTRAST_PALETTE) {
74
79
  this.updateContrast(paletteName, '50', palette.fifty);
@@ -81,11 +86,16 @@ export class ThemeService {
81
86
  this.updateContrast(paletteName, '700', palette.sevenHundred);
82
87
  this.updateContrast(paletteName, '800', palette.eightHundred);
83
88
  this.updateContrast(paletteName, '900', palette.nineHundred);
89
+ this.updateContrast(paletteName, 'A50', palette.a50);
84
90
  this.updateContrast(paletteName, 'A100', palette.a100);
85
91
  this.updateContrast(paletteName, 'A200', palette.a200);
86
92
  this.updateContrast(paletteName, 'A300', palette.a300);
87
93
  this.updateContrast(paletteName, 'A400', palette.a400);
88
94
  this.updateContrast(paletteName, 'A500', palette.a500);
95
+ this.updateContrast(paletteName, 'A600', palette.a600);
96
+ this.updateContrast(paletteName, 'A700', palette.a700);
97
+ this.updateContrast(paletteName, 'A800', palette.a800);
98
+ this.updateContrast(paletteName, 'A900', palette.a900);
89
99
  }
90
100
  }
91
101
  /**
@@ -174,4 +184,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
174
184
  providedIn: 'root'
175
185
  }]
176
186
  }] });
177
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"theme.service.js","sourceRoot":"","sources":["../../../../../../../projects/armature/src/lib/theming/services/theme.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { inject, Injectable } from '@angular/core';\r\nimport { DOCUMENT } from '@angular/common';\r\nimport { ThemePaletteColorsModel, ThemePaletteModel } from '../../core/client-generated/model/models';\r\n\r\n/** The color palette constant */\r\nconst COLOR_PALETTE = 'color';\r\n\r\n/** The contrast palette constant */\r\nconst CONTRAST_PALETTE = 'contrast';\r\n\r\n/** The Theme Service */\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class ThemeService {\r\n\r\n  private readonly document: Document = inject(DOCUMENT);\r\n\r\n  /**\r\n   * Initializes the palette\r\n   * @param themeConfig The theme configurations\r\n   */\r\n  public initPalette(themeConfig: ThemePaletteModel): void {\r\n    if (themeConfig) {\r\n      // Setting up primary color & contrast palettes\r\n      const primaryColor = themeConfig.primaryColor;\r\n      const primaryContrast = themeConfig.primaryContrast;\r\n      if (primaryColor && JSON.stringify(primaryColor) !== '{}') {\r\n        this.updatePalette('primary', COLOR_PALETTE, primaryColor);\r\n      }\r\n      if (primaryContrast && JSON.stringify(primaryContrast) !== '{}') {\r\n        this.updatePalette('primary', CONTRAST_PALETTE, primaryContrast);\r\n      }\r\n      // Setting up accent color & contrast palettes\r\n      const accentColor = themeConfig.accentColor;\r\n      const accentContrast = themeConfig.accentContrast;\r\n      if (accentColor && JSON.stringify(accentColor) !== '{}') {\r\n        this.updatePalette('accent', COLOR_PALETTE, accentColor);\r\n      }\r\n      if (accentContrast && JSON.stringify(accentContrast) !== '{}') {\r\n        this.updatePalette('accent', CONTRAST_PALETTE, accentContrast);\r\n      }\r\n      // Setting up warning color & contrast palettes\r\n      const warningColor = themeConfig.warningColor;\r\n      const warningContrast = themeConfig.warningContrast;\r\n      if (warningColor && JSON.stringify(warningColor) !== '{}') {\r\n        this.updatePalette('warn', COLOR_PALETTE, warningColor);\r\n      }\r\n      if (warningContrast && JSON.stringify(warningContrast) !== '{}') {\r\n        this.updatePalette('warn', CONTRAST_PALETTE, warningContrast);\r\n      }\r\n      this.initExtendedPalettes(themeConfig);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Updates the theme\r\n   * @param paletteName Palette name\r\n   * @param paletteType Palette type\r\n   * @param palette Palette values\r\n   */\r\n  public updatePalette(paletteName: string, paletteType: string, palette: ThemePaletteColorsModel): void {\r\n    if (paletteType == COLOR_PALETTE) {\r\n      this.updateColor(paletteName, '50', palette.fifty);\r\n      this.updateColor(paletteName, '100', palette.oneHundred);\r\n      this.updateColor(paletteName, '200', palette.twoHundred);\r\n      this.updateColor(paletteName, '300', palette.threeHundred);\r\n      this.updateColor(paletteName, '400', palette.fourHundred);\r\n      this.updateColor(paletteName, '500', palette.fiveHundred);\r\n      this.updateColor(paletteName, '600', palette.sixHundred);\r\n      this.updateColor(paletteName, '700', palette.sevenHundred);\r\n      this.updateColor(paletteName, '800', palette.eightHundred);\r\n      this.updateColor(paletteName, '900', palette.nineHundred);\r\n      this.updateColor(paletteName, 'A100', palette.a100);\r\n      this.updateColor(paletteName, 'A200', palette.a200);\r\n      this.updateColor(paletteName, 'A300', palette.a300);\r\n      this.updateColor(paletteName, 'A400', palette.a400);\r\n      this.updateColor(paletteName, 'A500', palette.a500);\r\n    }\r\n    else if (paletteType == CONTRAST_PALETTE) {\r\n      this.updateContrast(paletteName, '50', palette.fifty);\r\n      this.updateContrast(paletteName, '100', palette.oneHundred);\r\n      this.updateContrast(paletteName, '200', palette.twoHundred);\r\n      this.updateContrast(paletteName, '300', palette.threeHundred);\r\n      this.updateContrast(paletteName, '400', palette.fourHundred);\r\n      this.updateContrast(paletteName, '500', palette.fiveHundred);\r\n      this.updateContrast(paletteName, '600', palette.sixHundred);\r\n      this.updateContrast(paletteName, '700', palette.sevenHundred);\r\n      this.updateContrast(paletteName, '800', palette.eightHundred);\r\n      this.updateContrast(paletteName, '900', palette.nineHundred);\r\n      this.updateContrast(paletteName, 'A100', palette.a100);\r\n      this.updateContrast(paletteName, 'A200', palette.a200);\r\n      this.updateContrast(paletteName, 'A300', palette.a300);\r\n      this.updateContrast(paletteName, 'A400', palette.a400);\r\n      this.updateContrast(paletteName, 'A500', palette.a500);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Updates the color CSS variable for the given theme\r\n   * @param palette Palette to update\r\n   * @param part Part number\r\n   * @param value Value to replace with\r\n   */\r\n  public updateColor(palette: string, part: string, value: string): void {\r\n    if (!value) {\r\n      return;\r\n    }\r\n    const cssVar = `--${palette}-color-${part}-parts`;\r\n    if (value.includes('#')) {\r\n      const rgb = this.hexToRgb(value);\r\n      this.document.documentElement.style.setProperty(`${cssVar}-rgb`, `${rgb.r}, ${rgb.g}, ${rgb.b}`);\r\n    }\r\n    this.document.documentElement.style.setProperty(cssVar, value);\r\n  }\r\n\r\n  /**\r\n   * Updates the color contrast CSS variable for the given theme\r\n   * @param palette Palette to update\r\n   * @param part Part number\r\n   * @param value Value to replace with\r\n   */\r\n  public updateContrast(palette: string, part: string, value: string): void {\r\n    if (!value) {\r\n      return;\r\n    }\r\n    if (value === '#000000' || value === '#000') value = '#000000de'; // updates to black with 87% opacity per design best practices ...\r\n    this.document.documentElement.style.setProperty(`--${palette}-color-contrast-${part}-parts`, value);\r\n  }\r\n\r\n  /**\r\n   * initializes the extended palettes\r\n   * @param themeConfig The theme config\r\n   */\r\n  private initExtendedPalettes(themeConfig: ThemePaletteModel): void {\r\n    // Setting up error color & contrast palettes\r\n    const errorColor = themeConfig.errorColor;\r\n    const errorContrast = themeConfig.errorContrast;\r\n    if (errorColor && JSON.stringify(errorColor) !== '{}') {\r\n      this.updatePalette('error', COLOR_PALETTE, errorColor);\r\n    }\r\n    if (errorContrast && JSON.stringify(errorContrast) !== '{}') {\r\n      this.updatePalette('error', CONTRAST_PALETTE, errorContrast);\r\n    }\r\n    // Setting up info color & contrast palettes\r\n    const infoColor = themeConfig.infoColor;\r\n    const infoContrast = themeConfig.infoContrast;\r\n    if (infoColor && JSON.stringify(infoColor) !== '{}') {\r\n      this.updatePalette('info', COLOR_PALETTE, infoColor);\r\n    }\r\n    if (infoContrast && JSON.stringify(infoContrast) !== '{}') {\r\n      this.updatePalette('info', CONTRAST_PALETTE, infoContrast);\r\n    }\r\n    // Setting up success color & contrast palettes\r\n    const successColor = themeConfig.successColor;\r\n    const successContrast = themeConfig.successContrast;\r\n    if (successColor && JSON.stringify(successColor) !== '{}') {\r\n      this.updatePalette('success', COLOR_PALETTE, successColor);\r\n    }\r\n    if (successContrast && JSON.stringify(successContrast) !== '{}') {\r\n      this.updatePalette('success', CONTRAST_PALETTE, successContrast);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Converts the hex code to RGB\r\n   * https://stackoverflow.com/questions/5623838/rgb-to-hex-and-hex-to-rgb\r\n   * @param hex The hex code\r\n   */\r\n  private hexToRgb(hex: string): {r: number, g: number, b: number} {\r\n    const result = /^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(hex);\r\n\r\n    return result ? {\r\n      r: parseInt(result[1], 16),\r\n      g: parseInt(result[2], 16),\r\n      b: parseInt(result[3], 16)\r\n    } : undefined;\r\n  }\r\n}\r\n\r\n"]}
187
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"theme.service.js","sourceRoot":"","sources":["../../../../../../../projects/armature/src/lib/theming/services/theme.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { inject, Injectable } from '@angular/core';\r\nimport { DOCUMENT } from '@angular/common';\r\nimport { ThemePaletteColorsModel, ThemePaletteModel } from '../../core/client-generated/model/models';\r\n\r\n/** The color palette constant */\r\nconst COLOR_PALETTE = 'color';\r\n\r\n/** The contrast palette constant */\r\nconst CONTRAST_PALETTE = 'contrast';\r\n\r\n/** The Theme Service */\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class ThemeService {\r\n\r\n  private readonly document: Document = inject(DOCUMENT);\r\n\r\n  /**\r\n   * Initializes the palette\r\n   * @param themeConfig The theme configurations\r\n   */\r\n  public initPalette(themeConfig: ThemePaletteModel): void {\r\n    if (themeConfig) {\r\n      // Setting up primary color & contrast palettes\r\n      const primaryColor = themeConfig.primaryColor;\r\n      const primaryContrast = themeConfig.primaryContrast;\r\n      if (primaryColor && JSON.stringify(primaryColor) !== '{}') {\r\n        this.updatePalette('primary', COLOR_PALETTE, primaryColor);\r\n      }\r\n      if (primaryContrast && JSON.stringify(primaryContrast) !== '{}') {\r\n        this.updatePalette('primary', CONTRAST_PALETTE, primaryContrast);\r\n      }\r\n      // Setting up accent color & contrast palettes\r\n      const accentColor = themeConfig.accentColor;\r\n      const accentContrast = themeConfig.accentContrast;\r\n      if (accentColor && JSON.stringify(accentColor) !== '{}') {\r\n        this.updatePalette('accent', COLOR_PALETTE, accentColor);\r\n      }\r\n      if (accentContrast && JSON.stringify(accentContrast) !== '{}') {\r\n        this.updatePalette('accent', CONTRAST_PALETTE, accentContrast);\r\n      }\r\n      // Setting up warning color & contrast palettes\r\n      const warningColor = themeConfig.warningColor;\r\n      const warningContrast = themeConfig.warningContrast;\r\n      if (warningColor && JSON.stringify(warningColor) !== '{}') {\r\n        this.updatePalette('warn', COLOR_PALETTE, warningColor);\r\n      }\r\n      if (warningContrast && JSON.stringify(warningContrast) !== '{}') {\r\n        this.updatePalette('warn', CONTRAST_PALETTE, warningContrast);\r\n      }\r\n      this.initExtendedPalettes(themeConfig);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Updates the theme\r\n   * @param paletteName Palette name\r\n   * @param paletteType Palette type\r\n   * @param palette Palette values\r\n   */\r\n  public updatePalette(paletteName: string, paletteType: string, palette: ThemePaletteColorsModel): void {\r\n    if (paletteType == COLOR_PALETTE) {\r\n      this.updateColor(paletteName, '50', palette.fifty);\r\n      this.updateColor(paletteName, '100', palette.oneHundred);\r\n      this.updateColor(paletteName, '200', palette.twoHundred);\r\n      this.updateColor(paletteName, '300', palette.threeHundred);\r\n      this.updateColor(paletteName, '400', palette.fourHundred);\r\n      this.updateColor(paletteName, '500', palette.fiveHundred);\r\n      this.updateColor(paletteName, '600', palette.sixHundred);\r\n      this.updateColor(paletteName, '700', palette.sevenHundred);\r\n      this.updateColor(paletteName, '800', palette.eightHundred);\r\n      this.updateColor(paletteName, '900', palette.nineHundred);\r\n      this.updateColor(paletteName, 'A50', palette.a50);\r\n      this.updateColor(paletteName, 'A100', palette.a100);\r\n      this.updateColor(paletteName, 'A200', palette.a200);\r\n      this.updateColor(paletteName, 'A300', palette.a300);\r\n      this.updateColor(paletteName, 'A400', palette.a400);\r\n      this.updateColor(paletteName, 'A500', palette.a500);\r\n      this.updateColor(paletteName, 'A600', palette.a600);\r\n      this.updateColor(paletteName, 'A700', palette.a700);\r\n      this.updateColor(paletteName, 'A800', palette.a800);\r\n      this.updateColor(paletteName, 'A900', palette.a900);\r\n    }\r\n    else if (paletteType == CONTRAST_PALETTE) {\r\n      this.updateContrast(paletteName, '50', palette.fifty);\r\n      this.updateContrast(paletteName, '100', palette.oneHundred);\r\n      this.updateContrast(paletteName, '200', palette.twoHundred);\r\n      this.updateContrast(paletteName, '300', palette.threeHundred);\r\n      this.updateContrast(paletteName, '400', palette.fourHundred);\r\n      this.updateContrast(paletteName, '500', palette.fiveHundred);\r\n      this.updateContrast(paletteName, '600', palette.sixHundred);\r\n      this.updateContrast(paletteName, '700', palette.sevenHundred);\r\n      this.updateContrast(paletteName, '800', palette.eightHundred);\r\n      this.updateContrast(paletteName, '900', palette.nineHundred);\r\n      this.updateContrast(paletteName, 'A50', palette.a50);\r\n      this.updateContrast(paletteName, 'A100', palette.a100);\r\n      this.updateContrast(paletteName, 'A200', palette.a200);\r\n      this.updateContrast(paletteName, 'A300', palette.a300);\r\n      this.updateContrast(paletteName, 'A400', palette.a400);\r\n      this.updateContrast(paletteName, 'A500', palette.a500);\r\n      this.updateContrast(paletteName, 'A600', palette.a600);\r\n      this.updateContrast(paletteName, 'A700', palette.a700);\r\n      this.updateContrast(paletteName, 'A800', palette.a800);\r\n      this.updateContrast(paletteName, 'A900', palette.a900);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Updates the color CSS variable for the given theme\r\n   * @param palette Palette to update\r\n   * @param part Part number\r\n   * @param value Value to replace with\r\n   */\r\n  public updateColor(palette: string, part: string, value: string): void {\r\n    if (!value) {\r\n      return;\r\n    }\r\n    const cssVar = `--${palette}-color-${part}-parts`;\r\n    if (value.includes('#')) {\r\n      const rgb = this.hexToRgb(value);\r\n      this.document.documentElement.style.setProperty(`${cssVar}-rgb`, `${rgb.r}, ${rgb.g}, ${rgb.b}`);\r\n    }\r\n    this.document.documentElement.style.setProperty(cssVar, value);\r\n  }\r\n\r\n  /**\r\n   * Updates the color contrast CSS variable for the given theme\r\n   * @param palette Palette to update\r\n   * @param part Part number\r\n   * @param value Value to replace with\r\n   */\r\n  public updateContrast(palette: string, part: string, value: string): void {\r\n    if (!value) {\r\n      return;\r\n    }\r\n    if (value === '#000000' || value === '#000') value = '#000000de'; // updates to black with 87% opacity per design best practices ...\r\n    this.document.documentElement.style.setProperty(`--${palette}-color-contrast-${part}-parts`, value);\r\n  }\r\n\r\n  /**\r\n   * initializes the extended palettes\r\n   * @param themeConfig The theme config\r\n   */\r\n  private initExtendedPalettes(themeConfig: ThemePaletteModel): void {\r\n    // Setting up error color & contrast palettes\r\n    const errorColor = themeConfig.errorColor;\r\n    const errorContrast = themeConfig.errorContrast;\r\n    if (errorColor && JSON.stringify(errorColor) !== '{}') {\r\n      this.updatePalette('error', COLOR_PALETTE, errorColor);\r\n    }\r\n    if (errorContrast && JSON.stringify(errorContrast) !== '{}') {\r\n      this.updatePalette('error', CONTRAST_PALETTE, errorContrast);\r\n    }\r\n    // Setting up info color & contrast palettes\r\n    const infoColor = themeConfig.infoColor;\r\n    const infoContrast = themeConfig.infoContrast;\r\n    if (infoColor && JSON.stringify(infoColor) !== '{}') {\r\n      this.updatePalette('info', COLOR_PALETTE, infoColor);\r\n    }\r\n    if (infoContrast && JSON.stringify(infoContrast) !== '{}') {\r\n      this.updatePalette('info', CONTRAST_PALETTE, infoContrast);\r\n    }\r\n    // Setting up success color & contrast palettes\r\n    const successColor = themeConfig.successColor;\r\n    const successContrast = themeConfig.successContrast;\r\n    if (successColor && JSON.stringify(successColor) !== '{}') {\r\n      this.updatePalette('success', COLOR_PALETTE, successColor);\r\n    }\r\n    if (successContrast && JSON.stringify(successContrast) !== '{}') {\r\n      this.updatePalette('success', CONTRAST_PALETTE, successContrast);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Converts the hex code to RGB\r\n   * https://stackoverflow.com/questions/5623838/rgb-to-hex-and-hex-to-rgb\r\n   * @param hex The hex code\r\n   */\r\n  private hexToRgb(hex: string): {r: number, g: number, b: number} {\r\n    const result = /^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(hex);\r\n    return result ? {\r\n      r: parseInt(result[1], 16),\r\n      g: parseInt(result[2], 16),\r\n      b: parseInt(result[3], 16)\r\n    } : undefined;\r\n  }\r\n}\r\n"]}
@@ -2485,11 +2485,16 @@ class ThemeService {
2485
2485
  this.updateColor(paletteName, '700', palette.sevenHundred);
2486
2486
  this.updateColor(paletteName, '800', palette.eightHundred);
2487
2487
  this.updateColor(paletteName, '900', palette.nineHundred);
2488
+ this.updateColor(paletteName, 'A50', palette.a50);
2488
2489
  this.updateColor(paletteName, 'A100', palette.a100);
2489
2490
  this.updateColor(paletteName, 'A200', palette.a200);
2490
2491
  this.updateColor(paletteName, 'A300', palette.a300);
2491
2492
  this.updateColor(paletteName, 'A400', palette.a400);
2492
2493
  this.updateColor(paletteName, 'A500', palette.a500);
2494
+ this.updateColor(paletteName, 'A600', palette.a600);
2495
+ this.updateColor(paletteName, 'A700', palette.a700);
2496
+ this.updateColor(paletteName, 'A800', palette.a800);
2497
+ this.updateColor(paletteName, 'A900', palette.a900);
2493
2498
  }
2494
2499
  else if (paletteType == CONTRAST_PALETTE) {
2495
2500
  this.updateContrast(paletteName, '50', palette.fifty);
@@ -2502,11 +2507,16 @@ class ThemeService {
2502
2507
  this.updateContrast(paletteName, '700', palette.sevenHundred);
2503
2508
  this.updateContrast(paletteName, '800', palette.eightHundred);
2504
2509
  this.updateContrast(paletteName, '900', palette.nineHundred);
2510
+ this.updateContrast(paletteName, 'A50', palette.a50);
2505
2511
  this.updateContrast(paletteName, 'A100', palette.a100);
2506
2512
  this.updateContrast(paletteName, 'A200', palette.a200);
2507
2513
  this.updateContrast(paletteName, 'A300', palette.a300);
2508
2514
  this.updateContrast(paletteName, 'A400', palette.a400);
2509
2515
  this.updateContrast(paletteName, 'A500', palette.a500);
2516
+ this.updateContrast(paletteName, 'A600', palette.a600);
2517
+ this.updateContrast(paletteName, 'A700', palette.a700);
2518
+ this.updateContrast(paletteName, 'A800', palette.a800);
2519
+ this.updateContrast(paletteName, 'A900', palette.a900);
2510
2520
  }
2511
2521
  }
2512
2522
  /**