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.
Files changed (208) hide show
  1. package/commons-shared-web-ui-1.0.0.tgz +0 -0
  2. package/documentation/alert.md +123 -0
  3. package/documentation/button-dropdown.md +126 -0
  4. package/documentation/button.md +184 -0
  5. package/documentation/cards-usage-guidelines.md +131 -0
  6. package/documentation/configurable-form.md +605 -0
  7. package/documentation/confirmation-modal.md +250 -0
  8. package/documentation/filter-sidebar.md +178 -0
  9. package/documentation/filter-table-selector.md +228 -0
  10. package/documentation/form-builder.md +597 -0
  11. package/documentation/form-components.md +384 -0
  12. package/documentation/nav.md +427 -0
  13. package/documentation/pagination.md +181 -0
  14. package/documentation/side-nav-documentation.md +169 -0
  15. package/documentation/smart-form.md +2177 -0
  16. package/documentation/smart-table.md +1198 -0
  17. package/documentation/snackbar.md +118 -0
  18. package/documentation/style-externalization.md +88 -0
  19. package/documentation/summary-card.md +279 -0
  20. package/ng-package.json +28 -0
  21. package/package.json +54 -0
  22. package/src/lib/modules/alert/alert.models.ts +6 -0
  23. package/src/lib/modules/alert/alert.module.ts +16 -0
  24. package/src/lib/modules/alert/alert.theme.scss +85 -0
  25. package/src/lib/modules/alert/components/alert/alert.component.html +27 -0
  26. package/src/lib/modules/alert/components/alert/alert.component.scss +92 -0
  27. package/src/lib/modules/alert/components/alert/alert.component.ts +81 -0
  28. package/src/lib/modules/button/button.models.ts +13 -0
  29. package/src/lib/modules/button/button.module.ts +16 -0
  30. package/src/lib/modules/button/button.theme.scss +121 -0
  31. package/src/lib/modules/button/components/button/button.component.html +22 -0
  32. package/src/lib/modules/button/components/button/button.component.scss +88 -0
  33. package/src/lib/modules/button/components/button/button.component.ts +67 -0
  34. package/src/lib/modules/button-dropdown/button-dropdown.models.ts +26 -0
  35. package/src/lib/modules/button-dropdown/button-dropdown.module.ts +22 -0
  36. package/src/lib/modules/button-dropdown/button-dropdown.theme.scss +87 -0
  37. package/src/lib/modules/button-dropdown/components/button-dropdown/button-dropdown.component.html +41 -0
  38. package/src/lib/modules/button-dropdown/components/button-dropdown/button-dropdown.component.scss +135 -0
  39. package/src/lib/modules/button-dropdown/components/button-dropdown/button-dropdown.component.ts +160 -0
  40. package/src/lib/modules/configurable-form/component/configurable-form.component.html +294 -0
  41. package/src/lib/modules/configurable-form/component/configurable-form.component.scss +503 -0
  42. package/src/lib/modules/configurable-form/component/configurable-form.component.ts +628 -0
  43. package/src/lib/modules/configurable-form/configurable-form.examples.ts +154 -0
  44. package/src/lib/modules/configurable-form/configurable-form.model.ts +131 -0
  45. package/src/lib/modules/configurable-form/configurable-form.module.ts +19 -0
  46. package/src/lib/modules/configurable-form/configurable-form.theme.scss +78 -0
  47. package/src/lib/modules/confirmation-modal/components/confirmation-modal/confirmation-modal.component.html +77 -0
  48. package/src/lib/modules/confirmation-modal/components/confirmation-modal/confirmation-modal.component.scss +395 -0
  49. package/src/lib/modules/confirmation-modal/components/confirmation-modal/confirmation-modal.component.ts +266 -0
  50. package/src/lib/modules/confirmation-modal/confirmation-modal.models.ts +71 -0
  51. package/src/lib/modules/confirmation-modal/confirmation-modal.module.ts +20 -0
  52. package/src/lib/modules/confirmation-modal/confirmation-modal.theme.scss +87 -0
  53. package/src/lib/modules/filter/components/filter/filter.component.html +131 -0
  54. package/src/lib/modules/filter/components/filter/filter.component.scss +245 -0
  55. package/src/lib/modules/filter/components/filter/filter.component.ts +216 -0
  56. package/src/lib/modules/filter/filter.models.ts +88 -0
  57. package/src/lib/modules/filter/filter.module.ts +24 -0
  58. package/src/lib/modules/filter/filter.theme.scss +92 -0
  59. package/src/lib/modules/filter-sidebar/components/filter-sidebar/filter-sidebar.component.html +112 -0
  60. package/src/lib/modules/filter-sidebar/components/filter-sidebar/filter-sidebar.component.scss +186 -0
  61. package/src/lib/modules/filter-sidebar/components/filter-sidebar/filter-sidebar.component.ts +163 -0
  62. package/src/lib/modules/filter-sidebar/filter-sidebar.models.ts +95 -0
  63. package/src/lib/modules/filter-sidebar/filter-sidebar.module.ts +24 -0
  64. package/src/lib/modules/filter-sidebar/filter-sidebar.theme.scss +38 -0
  65. package/src/lib/modules/filter-table-selector/components/filter-table-selector/filter-table-selector.component.html +73 -0
  66. package/src/lib/modules/filter-table-selector/components/filter-table-selector/filter-table-selector.component.scss +321 -0
  67. package/src/lib/modules/filter-table-selector/components/filter-table-selector/filter-table-selector.component.ts +361 -0
  68. package/src/lib/modules/filter-table-selector/filter-table-selector.models.ts +91 -0
  69. package/src/lib/modules/filter-table-selector/filter-table-selector.module.ts +22 -0
  70. package/src/lib/modules/filter-table-selector/filter-table-selector.theme.scss +36 -0
  71. package/src/lib/modules/form-builder/components/field-configurator/configurator-config-panel/configurator-config-panel.component.html +63 -0
  72. package/src/lib/modules/form-builder/components/field-configurator/configurator-config-panel/configurator-config-panel.component.scss +496 -0
  73. package/src/lib/modules/form-builder/components/field-configurator/configurator-config-panel/configurator-config-panel.component.ts +445 -0
  74. package/src/lib/modules/form-builder/components/field-configurator/configurator-tree/configurator-tree.component.html +75 -0
  75. package/src/lib/modules/form-builder/components/field-configurator/configurator-tree/configurator-tree.component.scss +210 -0
  76. package/src/lib/modules/form-builder/components/field-configurator/configurator-tree/configurator-tree.component.ts +55 -0
  77. package/src/lib/modules/form-builder/components/field-configurator/field-configurator.component.html +25 -0
  78. package/src/lib/modules/form-builder/components/field-configurator/field-configurator.component.scss +82 -0
  79. package/src/lib/modules/form-builder/components/field-configurator/field-configurator.component.ts +95 -0
  80. package/src/lib/modules/form-builder/components/field-selection/field-selection.component.html +20 -0
  81. package/src/lib/modules/form-builder/components/field-selection/field-selection.component.scss +37 -0
  82. package/src/lib/modules/form-builder/components/field-selection/field-selection.component.ts +94 -0
  83. package/src/lib/modules/form-builder/components/field-selection/group-node/group-node.component.html +46 -0
  84. package/src/lib/modules/form-builder/components/field-selection/group-node/group-node.component.scss +102 -0
  85. package/src/lib/modules/form-builder/components/field-selection/group-node/group-node.component.ts +50 -0
  86. package/src/lib/modules/form-builder/components/field-selection/selection-field-node/selection-field-node.component.html +35 -0
  87. package/src/lib/modules/form-builder/components/field-selection/selection-field-node/selection-field-node.component.scss +67 -0
  88. package/src/lib/modules/form-builder/components/field-selection/selection-field-node/selection-field-node.component.ts +34 -0
  89. package/src/lib/modules/form-builder/components/field-selection/selection-section-node/selection-section-node.component.html +68 -0
  90. package/src/lib/modules/form-builder/components/field-selection/selection-section-node/selection-section-node.component.scss +113 -0
  91. package/src/lib/modules/form-builder/components/field-selection/selection-section-node/selection-section-node.component.ts +74 -0
  92. package/src/lib/modules/form-builder/configs/field-type-schema.map.ts +533 -0
  93. package/src/lib/modules/form-builder/form-builder.module.ts +36 -0
  94. package/src/lib/modules/form-builder/form-builder.theme.scss +212 -0
  95. package/src/lib/modules/form-builder/index.ts +9 -0
  96. package/src/lib/modules/form-builder/models/builder.models.ts +7 -0
  97. package/src/lib/modules/form-builder/models/field-configurator.models.ts +38 -0
  98. package/src/lib/modules/form-builder/models/field-selection.models.ts +51 -0
  99. package/src/lib/modules/form-builder/services/field-configurator.service.ts +258 -0
  100. package/src/lib/modules/form-builder/services/field-selection.service.ts +300 -0
  101. package/src/lib/modules/form-builder/services/form-schema-tree.service.ts +652 -0
  102. package/src/lib/modules/form-builder/tokens/builder.tokens.ts +10 -0
  103. package/src/lib/modules/form-builder/utils/constants.ts +43 -0
  104. package/src/lib/modules/form-components/components/checkbox/_theme.scss +63 -0
  105. package/src/lib/modules/form-components/components/checkbox/checkbox.component.html +29 -0
  106. package/src/lib/modules/form-components/components/checkbox/checkbox.component.scss +111 -0
  107. package/src/lib/modules/form-components/components/checkbox/checkbox.component.ts +207 -0
  108. package/src/lib/modules/form-components/components/checkbox/checkbox.models.ts +35 -0
  109. package/src/lib/modules/form-components/components/datepicker/_theme.scss +82 -0
  110. package/src/lib/modules/form-components/components/datepicker/datepicker.component.html +42 -0
  111. package/src/lib/modules/form-components/components/datepicker/datepicker.component.scss +115 -0
  112. package/src/lib/modules/form-components/components/datepicker/datepicker.component.ts +267 -0
  113. package/src/lib/modules/form-components/components/datepicker/datepicker.models.ts +45 -0
  114. package/src/lib/modules/form-components/components/dropdown/_theme.scss +91 -0
  115. package/src/lib/modules/form-components/components/dropdown/dropdown.component.html +74 -0
  116. package/src/lib/modules/form-components/components/dropdown/dropdown.component.scss +252 -0
  117. package/src/lib/modules/form-components/components/dropdown/dropdown.component.ts +377 -0
  118. package/src/lib/modules/form-components/components/dropdown/dropdown.models.ts +53 -0
  119. package/src/lib/modules/form-components/components/input/_theme.scss +77 -0
  120. package/src/lib/modules/form-components/components/input/input.component.html +51 -0
  121. package/src/lib/modules/form-components/components/input/input.component.scss +128 -0
  122. package/src/lib/modules/form-components/components/input/input.component.ts +250 -0
  123. package/src/lib/modules/form-components/components/input/input.models.ts +55 -0
  124. package/src/lib/modules/form-components/components/radio/_theme.scss +61 -0
  125. package/src/lib/modules/form-components/components/radio/radio.component.html +22 -0
  126. package/src/lib/modules/form-components/components/radio/radio.component.scss +107 -0
  127. package/src/lib/modules/form-components/components/radio/radio.component.ts +181 -0
  128. package/src/lib/modules/form-components/components/radio/radio.models.ts +39 -0
  129. package/src/lib/modules/form-components/components/search/_theme.scss +73 -0
  130. package/src/lib/modules/form-components/components/search/search.component.html +15 -0
  131. package/src/lib/modules/form-components/components/search/search.component.scss +87 -0
  132. package/src/lib/modules/form-components/components/search/search.component.ts +213 -0
  133. package/src/lib/modules/form-components/components/search/search.models.ts +40 -0
  134. package/src/lib/modules/form-components/components/toggle/_theme.scss +45 -0
  135. package/src/lib/modules/form-components/components/toggle/toggle.component.html +15 -0
  136. package/src/lib/modules/form-components/components/toggle/toggle.component.scss +81 -0
  137. package/src/lib/modules/form-components/components/toggle/toggle.component.ts +166 -0
  138. package/src/lib/modules/form-components/components/toggle/toggle.models.ts +27 -0
  139. package/src/lib/modules/form-components/directives/click-outside.directive.ts +22 -0
  140. package/src/lib/modules/form-components/form-components.module.ts +41 -0
  141. package/src/lib/modules/form-components/form-components.theme.scss +25 -0
  142. package/src/lib/modules/material/material.module.ts +94 -0
  143. package/src/lib/modules/nav/components/nav/nav.component.html +34 -0
  144. package/src/lib/modules/nav/components/nav/nav.component.scss +171 -0
  145. package/src/lib/modules/nav/components/nav/nav.component.ts +82 -0
  146. package/src/lib/modules/nav/nav.models.ts +31 -0
  147. package/src/lib/modules/nav/nav.module.ts +17 -0
  148. package/src/lib/modules/nav/nav.theme.scss +86 -0
  149. package/src/lib/modules/pagination/components/pagination/pagination.component.html +52 -0
  150. package/src/lib/modules/pagination/components/pagination/pagination.component.scss +155 -0
  151. package/src/lib/modules/pagination/components/pagination/pagination.component.ts +109 -0
  152. package/src/lib/modules/pagination/pagination.module.ts +17 -0
  153. package/src/lib/modules/pagination/pagination.theme.scss +66 -0
  154. package/src/lib/modules/side-nav/components/side-nav/side-nav.component.html +56 -0
  155. package/src/lib/modules/side-nav/components/side-nav/side-nav.component.scss +342 -0
  156. package/src/lib/modules/side-nav/components/side-nav/side-nav.component.ts +135 -0
  157. package/src/lib/modules/side-nav/side-nav.models.ts +38 -0
  158. package/src/lib/modules/side-nav/side-nav.module.ts +16 -0
  159. package/src/lib/modules/side-nav/side-nav.theme.scss +111 -0
  160. package/src/lib/modules/smart-form/components/form-field/form-field.component.html +1109 -0
  161. package/src/lib/modules/smart-form/components/form-field/form-field.component.scss +1860 -0
  162. package/src/lib/modules/smart-form/components/form-field/form-field.component.ts +2232 -0
  163. package/src/lib/modules/smart-form/components/form-section/form-section.component.html +64 -0
  164. package/src/lib/modules/smart-form/components/form-section/form-section.component.scss +209 -0
  165. package/src/lib/modules/smart-form/components/form-section/form-section.component.ts +119 -0
  166. package/src/lib/modules/smart-form/components/smart-form/smart-form.component.html +253 -0
  167. package/src/lib/modules/smart-form/components/smart-form/smart-form.component.scss +689 -0
  168. package/src/lib/modules/smart-form/components/smart-form/smart-form.component.ts +1087 -0
  169. package/src/lib/modules/smart-form/index.ts +10 -0
  170. package/src/lib/modules/smart-form/models/form-schema.model.ts +700 -0
  171. package/src/lib/modules/smart-form/models/hierarchy-config.model.ts +21 -0
  172. package/src/lib/modules/smart-form/services/expression.service.ts +75 -0
  173. package/src/lib/modules/smart-form/services/smart-form-controller.service.ts +65 -0
  174. package/src/lib/modules/smart-form/smart-form.examples.ts +1324 -0
  175. package/src/lib/modules/smart-form/smart-form.module.ts +36 -0
  176. package/src/lib/modules/smart-form/smart-form.theme.scss +890 -0
  177. package/src/lib/modules/smart-form/utils/translation.utils.ts +82 -0
  178. package/src/lib/modules/smart-form/utils/trusted-url.pipe.ts +25 -0
  179. package/src/lib/modules/smart-form/utils/validation.utils.ts +98 -0
  180. package/src/lib/modules/smart-table/components/smart-table/smart-table.component.html +283 -0
  181. package/src/lib/modules/smart-table/components/smart-table/smart-table.component.scss +685 -0
  182. package/src/lib/modules/smart-table/components/smart-table/smart-table.component.ts +1118 -0
  183. package/src/lib/modules/smart-table/models/table-config.model.ts +202 -0
  184. package/src/lib/modules/smart-table/smart-table.module.ts +30 -0
  185. package/src/lib/modules/smart-table/smart-table.theme.scss +335 -0
  186. package/src/lib/modules/smart-table/utils/safe-html.pipe.ts +22 -0
  187. package/src/lib/modules/smart-table/utils/smart-table.utils.ts +18 -0
  188. package/src/lib/modules/snackbar/components/snackbar.component.html +41 -0
  189. package/src/lib/modules/snackbar/components/snackbar.component.scss +99 -0
  190. package/src/lib/modules/snackbar/components/snackbar.component.ts +18 -0
  191. package/src/lib/modules/snackbar/models/snackbar.models.ts +10 -0
  192. package/src/lib/modules/snackbar/services/snackbar.service.ts +40 -0
  193. package/src/lib/modules/snackbar/snackbar.module.ts +11 -0
  194. package/src/lib/modules/snackbar/snackbar.theme.scss +93 -0
  195. package/src/lib/modules/summary-card/components/summary-card/summary-card.component.html +47 -0
  196. package/src/lib/modules/summary-card/components/summary-card/summary-card.component.scss +199 -0
  197. package/src/lib/modules/summary-card/components/summary-card/summary-card.component.ts +126 -0
  198. package/src/lib/modules/summary-card/summary-card.module.ts +18 -0
  199. package/src/lib/modules/summary-card/summary-card.theme.scss +176 -0
  200. package/src/lib/shared-ui.module.ts +44 -0
  201. package/src/lib/styles/global.scss +152 -0
  202. package/src/lib/styles/utilities.scss +250 -0
  203. package/src/lib/utils/constants.ts +11 -0
  204. package/src/lib/utils/storage.utils.ts +37 -0
  205. package/src/lib/utils/string.utils.ts +23 -0
  206. package/src/lib/utils/translation.utils.ts +87 -0
  207. package/src/public-api.ts +104 -0
  208. package/tsconfig.lib.json +15 -0
@@ -0,0 +1,107 @@
1
+ /* Radio Component - Alternative Approach with Native Fallback */
2
+
3
+ .cc-radio-wrapper {
4
+ display: block;
5
+ width: 100%;
6
+ font-family: var(--cc-radio-font-family, inherit);
7
+ }
8
+
9
+ .cc-radio-group-label {
10
+ display: block;
11
+ font-size: var(--cc-radio-group-label-font-size, 14px);
12
+ font-weight: var(--cc-radio-group-label-font-weight, 500);
13
+ color: var(--cc-radio-group-label-color, #202124);
14
+ margin-bottom: 8px;
15
+ }
16
+
17
+ .cc-radio-group {
18
+ display: flex;
19
+ gap: var(--cc-radio-group-gap, 12px);
20
+ }
21
+
22
+ .cc-radio-group.vertical {
23
+ flex-direction: column;
24
+ }
25
+
26
+ .cc-radio-group.horizontal {
27
+ flex-direction: row;
28
+ flex-wrap: wrap;
29
+ }
30
+
31
+ .cc-radio-label {
32
+ display: flex;
33
+ align-items: center;
34
+ cursor: pointer;
35
+ font-size: var(--cc-radio-font-size, 14px);
36
+ color: var(--cc-radio-label-color, #202124);
37
+ user-select: none;
38
+ padding: 4px 0;
39
+ }
40
+
41
+ /* APPROACH 1: Custom Circle (Primary) */
42
+ .cc-native-radio {
43
+ /* Completely hide but keep accessible */
44
+ position: absolute;
45
+ left: -9999px;
46
+ }
47
+
48
+ .cc-radio-circle {
49
+ width: var(--cc-radio-size, 20px);
50
+ height: var(--cc-radio-size, 20px);
51
+ border: 2px solid var(--cc-radio-unchecked-color, #5F6368);
52
+ border-radius: var(--cc-radio-border-radius, 50%);
53
+ margin-right: 8px;
54
+ flex-shrink: 0;
55
+ position: relative;
56
+ background: white;
57
+ box-sizing: border-box;
58
+ }
59
+
60
+ .cc-radio-circle::after {
61
+ content: '';
62
+ width: calc(var(--cc-radio-size, 20px) * 0.5);
63
+ height: calc(var(--cc-radio-size, 20px) * 0.5);
64
+ background: var(--cc-radio-checked-color, #1A73E8);
65
+ border-radius: var(--cc-radio-border-radius, 50%);
66
+ position: absolute;
67
+ top: 50%;
68
+ left: 50%;
69
+ transform: translate(-50%, -50%) scale(0);
70
+ transition: transform 0.2s;
71
+ }
72
+
73
+ .cc-native-radio:checked+.cc-radio-circle {
74
+ border-color: var(--cc-radio-checked-color, #1A73E8);
75
+ }
76
+
77
+ .cc-native-radio:checked+.cc-radio-circle::after {
78
+ transform: translate(-50%, -50%) scale(1);
79
+ }
80
+
81
+ /* APPROACH 2: Visible Native Radio (Fallback - uncomment if custom doesn't work) */
82
+ /*
83
+ .cc-native-radio {
84
+ width: 20px;
85
+ height: 20px;
86
+ margin-right: 8px;
87
+ cursor: pointer;
88
+ flex-shrink: 0;
89
+ appearance: auto;
90
+ -webkit-appearance: radio;
91
+ -moz-appearance: radio;
92
+ }
93
+
94
+ .cc-radio-circle {
95
+ display: none;
96
+ }
97
+ */
98
+
99
+ .cc-text {
100
+ line-height: 1.5;
101
+ }
102
+
103
+ /* Disabled states */
104
+ .cc-radio-label.disabled {
105
+ opacity: 0.5;
106
+ cursor: not-allowed;
107
+ }
@@ -0,0 +1,181 @@
1
+ import { Component, Input, Output, EventEmitter, forwardRef, OnInit } from '@angular/core';
2
+ import { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import { RadioConfig, RadioOption, RadioLabels } from './radio.models';
4
+
5
+ @Component({
6
+ selector: 'lib-radio',
7
+ templateUrl: './radio.component.html',
8
+ styleUrls: ['./radio.component.scss'],
9
+ standalone: false,
10
+ providers: [
11
+ {
12
+ provide: NG_VALUE_ACCESSOR,
13
+ useExisting: forwardRef(() => RadioComponent),
14
+ multi: true
15
+ }
16
+ ]
17
+ })
18
+ export class RadioComponent implements ControlValueAccessor, OnInit {
19
+ @Input() config?: RadioConfig;
20
+ @Input() label: string = '';
21
+ @Input() options: RadioOption[] = [];
22
+ @Input() disabled: boolean = false;
23
+ @Input() required: boolean = false;
24
+ @Input() labelPosition: 'before' | 'after' = 'after';
25
+ @Input() color: 'primary' | 'warning' | 'danger' | 'success' | 'accent' | 'warn' | string = 'primary';
26
+ @Input() layout: 'vertical' | 'horizontal' = 'vertical';
27
+
28
+ // i18n Labels
29
+ @Input() labels: RadioLabels = {};
30
+
31
+ // Customization — Layout
32
+ @Input() gap?: string;
33
+
34
+ // Customization — Colors
35
+ @Input() labelColor?: string;
36
+ @Input() checkedColor?: string;
37
+ @Input() uncheckedColor?: string;
38
+
39
+ // Customization — Typography
40
+ @Input() fontSize?: string;
41
+ @Input() fontWeight?: string;
42
+ @Input() fontFamily?: string;
43
+
44
+ // Customization — Group label
45
+ @Input() groupLabelColor?: string;
46
+ @Input() groupLabelFontSize?: string;
47
+ @Input() groupLabelFontWeight?: string;
48
+
49
+ // Customization — States
50
+ @Input() disabledColor?: string;
51
+ @Input() errorColor?: string;
52
+
53
+ // Customization — Size
54
+ @Input() size?: string;
55
+ @Input() borderRadius?: string;
56
+
57
+ // Customization — Synonyms for Playground
58
+ @Input() labelFontSize?: string;
59
+ @Input() labelFontWeight?: string;
60
+
61
+ @Output() selectionChange = new EventEmitter<any>();
62
+
63
+ value: any;
64
+ uuid = `radio-group-${Math.random().toString(36).substr(2, 9)}`;
65
+
66
+ private onChange: (value: any) => void = () => { };
67
+ private onTouched: () => void = () => { };
68
+
69
+ ngOnInit(): void {
70
+ this.updateFromConfig();
71
+ // i18n labels override
72
+ if (this.labels) {
73
+ this.label = this.labels.label || this.label;
74
+ }
75
+ }
76
+
77
+ ngOnChanges(changes: any): void {
78
+ if (changes.config) {
79
+ this.updateFromConfig();
80
+ }
81
+ }
82
+
83
+ private updateFromConfig(): void {
84
+ if (this.config) {
85
+ this.label = this.config.label ?? this.label;
86
+ this.options = this.config.options || this.options;
87
+ this.disabled = this.config.disabled ?? this.disabled;
88
+ this.required = this.config.required ?? this.required;
89
+ this.labelPosition = this.config.labelPosition ?? this.labelPosition;
90
+ this.color = this.config.color ?? this.color;
91
+ this.layout = this.config.layout ?? this.layout;
92
+ this.value = this.config.value;
93
+
94
+ // Style mappings
95
+ this.gap = this.config.gap ?? this.gap;
96
+ this.labelColor = this.config.labelColor ?? this.labelColor;
97
+ this.checkedColor = this.config.checkedColor ?? this.checkedColor;
98
+ this.uncheckedColor = this.config.uncheckedColor ?? this.uncheckedColor;
99
+ this.fontSize = this.config.fontSize ?? this.fontSize;
100
+ this.fontWeight = this.config.fontWeight ?? this.fontWeight;
101
+ this.fontFamily = this.config.fontFamily ?? this.fontFamily;
102
+ this.groupLabelColor = this.config.groupLabelColor ?? this.groupLabelColor;
103
+ this.groupLabelFontSize = this.config.groupLabelFontSize ?? this.groupLabelFontSize;
104
+ this.groupLabelFontWeight = this.config.groupLabelFontWeight ?? this.groupLabelFontWeight;
105
+ this.disabledColor = this.config.disabledColor ?? this.disabledColor;
106
+ this.errorColor = this.config.errorColor ?? this.errorColor;
107
+ this.size = this.config.size ?? this.size;
108
+ this.borderRadius = this.config.borderRadius ?? this.borderRadius;
109
+ this.labelFontSize = this.config.labelFontSize ?? this.labelFontSize;
110
+ this.labelFontWeight = this.config.labelFontWeight ?? this.labelFontWeight;
111
+ }
112
+ }
113
+
114
+
115
+ get requiredMarker(): string {
116
+ return this.labels?.requiredMarker || '*';
117
+ }
118
+
119
+ get visibleOptions(): RadioOption[] {
120
+ return this.options.filter(o => o.label != null && o.label !== '');
121
+ }
122
+
123
+ writeValue(value: any): void {
124
+ this.value = value;
125
+ }
126
+
127
+ registerOnChange(fn: any): void {
128
+ this.onChange = fn;
129
+ }
130
+
131
+ registerOnTouched(fn: any): void {
132
+ this.onTouched = fn;
133
+ }
134
+
135
+ setDisabledState(isDisabled: boolean): void {
136
+ this.disabled = isDisabled;
137
+ }
138
+
139
+ onRadioChange(option: RadioOption): void {
140
+ this.value = option.value;
141
+ this.onChange(this.value);
142
+ this.onTouched();
143
+ this.selectionChange.emit(this.value);
144
+ }
145
+
146
+ private getStyleValue(value: string | undefined): string | undefined {
147
+ return value ? `${value}` : undefined;
148
+ }
149
+
150
+ private getThemeColor(colorStr: string | undefined): string | undefined {
151
+ if (!colorStr) return undefined;
152
+ const themeColors: { [key: string]: string } = {
153
+ 'primary': 'var(--cc-radio-primary-bg, var(--cc-btn-primary-bg, #1A73E8))',
154
+ 'warning': 'var(--cc-radio-warning-bg, var(--cc-btn-warning-bg, #F9C80E))',
155
+ 'danger': 'var(--cc-radio-danger-bg, var(--cc-btn-danger-bg, #dc3545))',
156
+ 'success': 'var(--cc-radio-success-bg, var(--cc-btn-success-bg, #28a745))',
157
+ 'warn': 'var(--cc-radio-danger-bg, var(--cc-btn-danger-bg, #dc3545))',
158
+ 'accent': 'var(--cc-radio-accent-bg, #ff4081)'
159
+ };
160
+ return themeColors[colorStr] || colorStr;
161
+ }
162
+
163
+ get wrapperStyles(): { [key: string]: string | undefined } {
164
+ return {
165
+ '--cc-radio-font-family': this.getStyleValue(this.fontFamily),
166
+ '--cc-radio-font-size': this.getStyleValue(this.fontSize || this.labelFontSize),
167
+ '--cc-radio-font-weight': this.getStyleValue(this.fontWeight || this.labelFontWeight),
168
+ '--cc-radio-label-color': this.getStyleValue(this.labelColor),
169
+ '--cc-radio-size': this.getStyleValue(this.size),
170
+ '--cc-radio-border-radius': this.getStyleValue(this.borderRadius),
171
+ '--cc-radio-checked-color': this.getStyleValue(this.getThemeColor(this.checkedColor || this.color)),
172
+ '--cc-radio-unchecked-color': this.getStyleValue(this.uncheckedColor),
173
+ '--cc-radio-disabled-color': this.getStyleValue(this.disabledColor),
174
+ '--cc-radio-error-color': this.getStyleValue(this.errorColor),
175
+ '--cc-radio-group-gap': this.getStyleValue(this.gap),
176
+ '--cc-radio-group-label-color': this.getStyleValue(this.groupLabelColor),
177
+ '--cc-radio-group-label-font-size': this.getStyleValue(this.groupLabelFontSize),
178
+ '--cc-radio-group-label-font-weight': this.getStyleValue(this.groupLabelFontWeight)
179
+ };
180
+ }
181
+ }
@@ -0,0 +1,39 @@
1
+ export interface RadioOption {
2
+ value: any;
3
+ label: string;
4
+ disabled?: boolean;
5
+ }
6
+
7
+ export interface RadioLabels {
8
+ label?: string;
9
+ requiredMarker?: string;
10
+ }
11
+
12
+ export interface RadioConfig {
13
+ label?: string;
14
+ options: RadioOption[];
15
+ value?: any;
16
+ disabled?: boolean;
17
+ required?: boolean;
18
+ labelPosition?: 'before' | 'after';
19
+ color?: 'primary' | 'warning' | 'danger' | 'success' | 'accent' | 'warn' | string;
20
+ layout?: 'vertical' | 'horizontal';
21
+
22
+ // Customization
23
+ gap?: string;
24
+ labelColor?: string;
25
+ checkedColor?: string;
26
+ uncheckedColor?: string;
27
+ fontSize?: string;
28
+ fontWeight?: string;
29
+ fontFamily?: string;
30
+ groupLabelColor?: string;
31
+ groupLabelFontSize?: string;
32
+ groupLabelFontWeight?: string;
33
+ disabledColor?: string;
34
+ errorColor?: string;
35
+ size?: string;
36
+ borderRadius?: string;
37
+ labelFontSize?: string;
38
+ labelFontWeight?: string;
39
+ }
@@ -0,0 +1,73 @@
1
+ @use 'sass:map';
2
+
3
+ $default-search-config: (
4
+ // Layout
5
+ height: 2.5rem,
6
+ padding: 0.375rem 1rem,
7
+ label-gap: 0.5rem,
8
+
9
+ // Borders
10
+ border-radius: 0.4375rem,
11
+ border-color: #BDC1C6,
12
+ border-width: 1px,
13
+
14
+ // Colors
15
+ bg: #FEFEFE,
16
+ color: #202124,
17
+ placeholder-color: #80868B,
18
+
19
+ // Typography
20
+ font-size: 0.875rem,
21
+ font-weight: 400,
22
+ font-family: inherit,
23
+
24
+ // Label
25
+ label-font-size: 0.875rem,
26
+ label-font-weight: 500,
27
+ label-color: #202124,
28
+
29
+ // States
30
+ focus-border-color: #1A73E8,
31
+ disabled-bg: #F1F3F4,
32
+ disabled-color: #80868B,
33
+
34
+ // Icon
35
+ icon-color: #5F6368
36
+ );
37
+
38
+ @mixin search-theme($user-config: ()) {
39
+ $config: map.merge($default-search-config, $user-config);
40
+
41
+ // Layout
42
+ --cc-search-height: #{map.get($config, height)};
43
+ --cc-search-padding: #{map.get($config, padding)};
44
+ --cc-search-label-gap: #{map.get($config, label-gap)};
45
+
46
+ // Borders
47
+ --cc-search-border-radius: #{map.get($config, border-radius)};
48
+ --cc-search-border-color: #{map.get($config, border-color)};
49
+ --cc-search-border-width: #{map.get($config, border-width)};
50
+
51
+ // Colors
52
+ --cc-search-bg: #{map.get($config, bg)};
53
+ --cc-search-color: #{map.get($config, color)};
54
+ --cc-search-placeholder-color: #{map.get($config, placeholder-color)};
55
+
56
+ // Typography
57
+ --cc-search-font-size: #{map.get($config, font-size)};
58
+ --cc-search-font-weight: #{map.get($config, font-weight)};
59
+ --cc-search-font-family: #{map.get($config, font-family)};
60
+
61
+ // Label
62
+ --cc-search-label-font-size: #{map.get($config, label-font-size)};
63
+ --cc-search-label-font-weight: #{map.get($config, label-font-weight)};
64
+ --cc-search-label-color: #{map.get($config, label-color)};
65
+
66
+ // States
67
+ --cc-search-focus-border-color: #{map.get($config, focus-border-color)};
68
+ --cc-search-disabled-bg: #{map.get($config, disabled-bg)};
69
+ --cc-search-disabled-color: #{map.get($config, disabled-color)};
70
+
71
+ // Icon
72
+ --cc-search-icon-color: #{map.get($config, icon-color)};
73
+ }
@@ -0,0 +1,15 @@
1
+ <div class="cc-search-wrapper" [ngStyle]="wrapperStyles">
2
+ <label *ngIf="label" class="cc-search-label" [ngStyle]="labelStyles">{{ label }}</label>
3
+
4
+ <div class="cc-search-field" [class.focused]="focused" [class.disabled]="disabled" [ngStyle]="fieldStyles">
5
+ <span class="cc-search-icon material-icons">search</span>
6
+
7
+ <input type="text" class="cc-search-input" [value]="value" [placeholder]="placeholder" [disabled]="disabled"
8
+ (input)="onInputChange($event)" (blur)="onBlur()" (focus)="onFocus()" />
9
+
10
+ <button *ngIf="clearable && value && !disabled" type="button" class="cc-clear-btn" (click)="onClear()"
11
+ [attr.aria-label]="clearAriaLabel">
12
+ <span class="material-icons">close</span>
13
+ </button>
14
+ </div>
15
+ </div>
@@ -0,0 +1,87 @@
1
+ .cc-search-wrapper {
2
+ display: flex;
3
+ flex-direction: column;
4
+ gap: var(--cc-search-label-gap, 0.5rem);
5
+ width: 100%;
6
+ font-family: var(--cc-search-font-family, inherit);
7
+ }
8
+
9
+ .cc-search-label {
10
+ font-size: var(--cc-search-label-font-size, 0.875rem);
11
+ font-weight: var(--cc-search-label-font-weight, 500);
12
+ color: var(--cc-search-label-color, #202124);
13
+ margin: 0;
14
+ line-height: 1.4;
15
+ }
16
+
17
+ .cc-search-field {
18
+ display: flex;
19
+ align-items: center;
20
+ width: 100%;
21
+ box-sizing: border-box;
22
+ background-color: var(--cc-search-bg, #FEFEFE);
23
+ border: var(--cc-search-border-width, 1px) solid var(--cc-search-border-color, #BDC1C6);
24
+ border-radius: var(--cc-search-border-radius, 0.4375rem);
25
+ padding: var(--cc-search-padding, 0.5rem 0.75rem);
26
+ min-height: var(--cc-search-height, 2.5rem);
27
+ transition: border-color 0.2s, box-shadow 0.2s;
28
+
29
+ &.focused {
30
+ border-color: var(--cc-search-focus-border-color, #1A73E8);
31
+ }
32
+
33
+ &.disabled {
34
+ background-color: var(--cc-search-disabled-bg, #F1F3F4);
35
+ cursor: not-allowed;
36
+
37
+ .cc-search-input {
38
+ cursor: not-allowed;
39
+ color: var(--cc-search-disabled-color, #80868B);
40
+ }
41
+
42
+ .cc-search-icon,
43
+ .cc-clear-btn {
44
+ color: var(--cc-search-disabled-color, #80868B);
45
+ }
46
+ }
47
+ }
48
+
49
+ .cc-search-icon {
50
+ margin-right: 0.5rem;
51
+ color: var(--cc-search-icon-color, #5F6368);
52
+ display: flex;
53
+ align-items: center;
54
+ }
55
+
56
+ .cc-search-input {
57
+ flex: 1;
58
+ border: none;
59
+ background: none;
60
+ outline: none;
61
+ font-family: inherit;
62
+ font-size: var(--cc-search-font-size, 0.875rem);
63
+ font-weight: var(--cc-search-font-weight, 400);
64
+ color: var(--cc-search-color, #202124);
65
+ padding: 0;
66
+ margin: 0;
67
+ width: 100%;
68
+
69
+ &::placeholder {
70
+ color: var(--cc-search-placeholder-color, #80868B);
71
+ }
72
+ }
73
+
74
+ .cc-clear-btn {
75
+ background: none;
76
+ border: none;
77
+ cursor: pointer;
78
+ padding: 0;
79
+ margin-left: 0.5rem;
80
+ display: flex;
81
+ align-items: center;
82
+ color: var(--cc-search-icon-color, #5F6368);
83
+
84
+ &:focus {
85
+ outline: none;
86
+ }
87
+ }