cmat 0.0.3 → 0.0.4

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 (266) hide show
  1. package/components/breadcrumb/breadcrumb.component.d.ts +18 -20
  2. package/components/card/card.component.d.ts +0 -5
  3. package/components/cascade/cascade-list/cascade-list.component.d.ts +12 -9
  4. package/components/cascade/cascade-menu/cascade-menu.component.d.ts +0 -1
  5. package/components/chip-input/chip-input.component.d.ts +34 -0
  6. package/components/chip-input/index.d.ts +5 -0
  7. package/components/chip-input/public-api.d.ts +1 -0
  8. package/components/date-range/date-range.component.d.ts +3 -2
  9. package/components/json-editor/index.d.ts +5 -0
  10. package/components/json-editor/json-editor.component.d.ts +25 -0
  11. package/components/json-editor/public-api.d.ts +1 -0
  12. package/components/navigation/vertical/components/aside/aside.component.d.ts +2 -5
  13. package/components/navigation/vertical/components/basic/basic.component.d.ts +2 -5
  14. package/components/navigation/vertical/components/collapsable/collapsable.component.d.ts +2 -5
  15. package/components/navigation/vertical/components/divider/divider.component.d.ts +2 -5
  16. package/components/navigation/vertical/components/group/group.component.d.ts +2 -5
  17. package/components/navigation/vertical/components/spacer/spacer.component.d.ts +2 -5
  18. package/components/navigation/vertical/vertical.component.d.ts +1 -4
  19. package/components/progress-bar/progress-bar.component.d.ts +3 -2
  20. package/components/rating/rating.component.d.ts +3 -2
  21. package/components/select-search/select-search.component.d.ts +1 -2
  22. package/components/select-tree/select-tree.component.d.ts +5 -12
  23. package/components/timeline/timeline-item/timeline-item.component.d.ts +1 -1
  24. package/components/transfer-picker/interface.d.ts +1 -1
  25. package/components/transfer-picker/transfer-picker-source/transfer-picker-source.component.d.ts +4 -4
  26. package/components/transfer-picker/transfer-picker.service.d.ts +2 -1
  27. package/directives/autofocus/autofocus.directive.d.ts +1 -3
  28. package/directives/debounce/debounce-keyup.directive.d.ts +1 -1
  29. package/directives/digit-only/digit-only.directive.d.ts +2 -0
  30. package/esm2022/animations/dropdown.mjs +26 -0
  31. package/esm2022/animations/public-api.mjs +2 -2
  32. package/esm2022/components/adapter/dayjs-date-adapter.mjs +3 -3
  33. package/esm2022/components/adapter/dayjs-datetime-adapter.mjs +3 -3
  34. package/esm2022/components/adapter/native-datetime-adapter.mjs +3 -3
  35. package/esm2022/components/breadcrumb/breadcrumb-item.directive.mjs +3 -3
  36. package/esm2022/components/breadcrumb/breadcrumb.component.mjs +16 -17
  37. package/esm2022/components/breadcrumb/breadcrumb.service.mjs +4 -4
  38. package/esm2022/components/card/card.component.mjs +5 -14
  39. package/esm2022/components/cascade/cascade-bottom-sheet/cascade-bottom-sheet.component.mjs +5 -6
  40. package/esm2022/components/cascade/cascade-list/cascade-list.component.mjs +65 -39
  41. package/esm2022/components/cascade/cascade-menu/cascade-menu.component.mjs +5 -9
  42. package/esm2022/components/chip-input/chip-input.component.mjs +144 -0
  43. package/esm2022/components/chip-input/cmat-components-chip-input.mjs +5 -0
  44. package/esm2022/components/chip-input/public-api.mjs +2 -0
  45. package/esm2022/components/date-range/date-range.component.mjs +13 -9
  46. package/esm2022/components/drawer/drawer.component.mjs +4 -4
  47. package/esm2022/components/drawer/drawer.service.mjs +3 -3
  48. package/esm2022/components/fullscreen/fullscreen.component.mjs +3 -3
  49. package/esm2022/components/highlight/highlight.component.mjs +3 -3
  50. package/esm2022/components/highlight/highlight.service.mjs +3 -3
  51. package/esm2022/components/json-editor/cmat-components-json-editor.mjs +5 -0
  52. package/esm2022/components/json-editor/json-editor.component.mjs +176 -0
  53. package/esm2022/components/json-editor/public-api.mjs +2 -0
  54. package/esm2022/components/masonry/masonry.component.mjs +3 -3
  55. package/esm2022/components/material-color-picker/material-color-picker.component.mjs +6 -6
  56. package/esm2022/components/material-datetimepicker/calendar-body.mjs +5 -6
  57. package/esm2022/components/material-datetimepicker/calendar.mjs +7 -8
  58. package/esm2022/components/material-datetimepicker/clock.mjs +6 -6
  59. package/esm2022/components/material-datetimepicker/datetimepicker-input.mjs +3 -3
  60. package/esm2022/components/material-datetimepicker/datetimepicker-intl.mjs +3 -3
  61. package/esm2022/components/material-datetimepicker/datetimepicker-toggle.mjs +8 -9
  62. package/esm2022/components/material-datetimepicker/datetimepicker.mjs +7 -7
  63. package/esm2022/components/material-datetimepicker/month-view.mjs +5 -6
  64. package/esm2022/components/material-datetimepicker/multi-year-view.mjs +3 -3
  65. package/esm2022/components/material-datetimepicker/time.mjs +8 -9
  66. package/esm2022/components/material-datetimepicker/year-view.mjs +3 -3
  67. package/esm2022/components/navigation/horizontal/components/basic/basic.component.mjs +6 -6
  68. package/esm2022/components/navigation/horizontal/components/branch/branch.component.mjs +7 -8
  69. package/esm2022/components/navigation/horizontal/components/divider/divider.component.mjs +3 -3
  70. package/esm2022/components/navigation/horizontal/components/spacer/spacer.component.mjs +3 -3
  71. package/esm2022/components/navigation/horizontal/horizontal.component.mjs +5 -6
  72. package/esm2022/components/navigation/navigation.service.mjs +3 -3
  73. package/esm2022/components/navigation/vertical/components/aside/aside.component.mjs +8 -17
  74. package/esm2022/components/navigation/vertical/components/basic/basic.component.mjs +7 -15
  75. package/esm2022/components/navigation/vertical/components/collapsable/collapsable.component.mjs +8 -19
  76. package/esm2022/components/navigation/vertical/components/divider/divider.component.mjs +6 -15
  77. package/esm2022/components/navigation/vertical/components/group/group.component.mjs +9 -19
  78. package/esm2022/components/navigation/vertical/components/spacer/spacer.component.mjs +6 -15
  79. package/esm2022/components/navigation/vertical/vertical.component.mjs +7 -18
  80. package/esm2022/components/pagination/pagination.component.mjs +6 -7
  81. package/esm2022/components/pagination/pagination.directive.mjs +3 -3
  82. package/esm2022/components/pagination/pagination.pipe.mjs +5 -5
  83. package/esm2022/components/pagination/pagination.service.mjs +3 -3
  84. package/esm2022/components/password-strength/mat-pass-toggle-visibility/mat-pass-toggle-visibility.component.mjs +3 -3
  85. package/esm2022/components/password-strength/mat-password-strength/mat-password-strength.component.mjs +6 -6
  86. package/esm2022/components/password-strength/mat-password-strength-info/mat-password-strength-info.component.mjs +8 -9
  87. package/esm2022/components/popover/popover.component.mjs +5 -5
  88. package/esm2022/components/progress-bar/progress-bar.component.mjs +11 -8
  89. package/esm2022/components/rating/rating.component.mjs +14 -6
  90. package/esm2022/components/select-search/select-no-entries-found.directive.mjs +3 -3
  91. package/esm2022/components/select-search/select-search-clear.directive.mjs +3 -3
  92. package/esm2022/components/select-search/select-search.component.mjs +8 -11
  93. package/esm2022/components/select-tree/select-tree.component.mjs +13 -29
  94. package/esm2022/components/timeline/timeline-item/timeline-item.component.mjs +18 -16
  95. package/esm2022/components/timeline/timeline.component.mjs +3 -3
  96. package/esm2022/components/toast/toast-modal.component.mjs +7 -7
  97. package/esm2022/components/toast/toast.component.mjs +6 -6
  98. package/esm2022/components/toast/toast.service.mjs +3 -3
  99. package/esm2022/components/transfer-picker/filter/filter.component.mjs +17 -8
  100. package/esm2022/components/transfer-picker/interface.mjs +1 -1
  101. package/esm2022/components/transfer-picker/search/search.component.mjs +9 -5
  102. package/esm2022/components/transfer-picker/transfer-picker-source/transfer-picker-source.component.mjs +44 -21
  103. package/esm2022/components/transfer-picker/transfer-picker-target/transfer-picker-target.component.mjs +7 -6
  104. package/esm2022/components/transfer-picker/transfer-picker.component.mjs +9 -7
  105. package/esm2022/components/transfer-picker/transfer-picker.service.mjs +10 -7
  106. package/esm2022/directives/animate-on-scroll/animate-on-scroll.directive.mjs +3 -3
  107. package/esm2022/directives/animate-on-scroll/scroll.service.mjs +3 -3
  108. package/esm2022/directives/autofocus/autofocus.directive.mjs +7 -7
  109. package/esm2022/directives/debounce/abstract-debounce.directive.mjs +3 -3
  110. package/esm2022/directives/debounce/debounce-click.directive.mjs +3 -3
  111. package/esm2022/directives/debounce/debounce-keyup.directive.mjs +5 -5
  112. package/esm2022/directives/digit-only/digit-only.directive.mjs +20 -4
  113. package/esm2022/directives/digit-only/mask.directive.mjs +3 -3
  114. package/esm2022/directives/digit-only/public-api.mjs +1 -1
  115. package/esm2022/directives/equal-validator/equal-validator.directive.mjs +3 -3
  116. package/esm2022/lib/mock-api/mock-api.interceptor.mjs +3 -3
  117. package/esm2022/lib/mock-api/mock-api.service.mjs +3 -3
  118. package/esm2022/pipes/bytes/bytes.pipe.mjs +3 -3
  119. package/esm2022/pipes/date-format/date-format.pipe.mjs +3 -3
  120. package/esm2022/pipes/find-by-key/find-by-key.pipe.mjs +3 -3
  121. package/esm2022/pipes/group-by/group-by.pipe.mjs +3 -3
  122. package/esm2022/pipes/keys/keys.pipe.mjs +3 -3
  123. package/esm2022/pipes/secure/secure-pipe.mjs +5 -5
  124. package/esm2022/pipes/uppercase/uppercase.pipe.mjs +3 -3
  125. package/esm2022/services/alert/alert.service.mjs +16 -16
  126. package/esm2022/services/config/config.constants.mjs +1 -1
  127. package/esm2022/services/config/config.service.mjs +3 -3
  128. package/esm2022/services/config/urlStateConfig.service.mjs +4 -4
  129. package/esm2022/services/confirmation/confirmation.service.mjs +3 -3
  130. package/esm2022/services/confirmation/dialog/dialog.component.mjs +6 -6
  131. package/esm2022/services/data/data.service.mjs +4 -4
  132. package/esm2022/services/loading/loading.interceptor.mjs +3 -3
  133. package/esm2022/services/loading/loading.service.mjs +3 -3
  134. package/esm2022/services/local-storage/local-storage.service.mjs +3 -3
  135. package/esm2022/services/media-watcher/media-watcher.service.mjs +3 -3
  136. package/esm2022/services/platform/platform.service.mjs +3 -3
  137. package/esm2022/services/splash-screen/splash-screen.service.mjs +3 -3
  138. package/esm2022/services/title/title.service.mjs +3 -3
  139. package/esm2022/services/translation/translation.service.mjs +3 -3
  140. package/esm2022/services/utils/utils.service.mjs +3 -3
  141. package/fesm2022/cmat-animations.mjs.map +1 -1
  142. package/fesm2022/cmat-components-adapter.mjs +9 -9
  143. package/fesm2022/cmat-components-breadcrumb.mjs +21 -22
  144. package/fesm2022/cmat-components-breadcrumb.mjs.map +1 -1
  145. package/fesm2022/cmat-components-card.mjs +4 -13
  146. package/fesm2022/cmat-components-card.mjs.map +1 -1
  147. package/fesm2022/cmat-components-cascade.mjs +72 -49
  148. package/fesm2022/cmat-components-cascade.mjs.map +1 -1
  149. package/fesm2022/cmat-components-chip-input.mjs +151 -0
  150. package/fesm2022/cmat-components-chip-input.mjs.map +1 -0
  151. package/fesm2022/cmat-components-date-range.mjs +12 -8
  152. package/fesm2022/cmat-components-date-range.mjs.map +1 -1
  153. package/fesm2022/cmat-components-drawer.mjs +7 -7
  154. package/fesm2022/cmat-components-drawer.mjs.map +1 -1
  155. package/fesm2022/cmat-components-fullscreen.mjs +3 -3
  156. package/fesm2022/cmat-components-highlight.mjs +6 -6
  157. package/fesm2022/cmat-components-json-editor.mjs +183 -0
  158. package/fesm2022/cmat-components-json-editor.mjs.map +1 -0
  159. package/fesm2022/cmat-components-masonry.mjs +3 -3
  160. package/fesm2022/cmat-components-material-color-picker.mjs +5 -5
  161. package/fesm2022/cmat-components-material-color-picker.mjs.map +1 -1
  162. package/fesm2022/cmat-components-material-datetimepicker.mjs +51 -52
  163. package/fesm2022/cmat-components-material-datetimepicker.mjs.map +1 -1
  164. package/fesm2022/cmat-components-navigation.mjs +58 -125
  165. package/fesm2022/cmat-components-navigation.mjs.map +1 -1
  166. package/fesm2022/cmat-components-pagination.mjs +15 -16
  167. package/fesm2022/cmat-components-pagination.mjs.map +1 -1
  168. package/fesm2022/cmat-components-password-strength.mjs +14 -15
  169. package/fesm2022/cmat-components-password-strength.mjs.map +1 -1
  170. package/fesm2022/cmat-components-popover.mjs +4 -4
  171. package/fesm2022/cmat-components-popover.mjs.map +1 -1
  172. package/fesm2022/cmat-components-progress-bar.mjs +10 -7
  173. package/fesm2022/cmat-components-progress-bar.mjs.map +1 -1
  174. package/fesm2022/cmat-components-rating.mjs +13 -5
  175. package/fesm2022/cmat-components-rating.mjs.map +1 -1
  176. package/fesm2022/cmat-components-select-search.mjs +13 -16
  177. package/fesm2022/cmat-components-select-search.mjs.map +1 -1
  178. package/fesm2022/cmat-components-select-tree.mjs +12 -28
  179. package/fesm2022/cmat-components-select-tree.mjs.map +1 -1
  180. package/fesm2022/cmat-components-timeline.mjs +21 -19
  181. package/fesm2022/cmat-components-timeline.mjs.map +1 -1
  182. package/fesm2022/cmat-components-toast.mjs +13 -13
  183. package/fesm2022/cmat-components-toast.mjs.map +1 -1
  184. package/fesm2022/cmat-components-transfer-picker.mjs +81 -45
  185. package/fesm2022/cmat-components-transfer-picker.mjs.map +1 -1
  186. package/fesm2022/cmat-directives-animate-on-scroll.mjs +6 -6
  187. package/fesm2022/cmat-directives-autofocus.mjs +6 -6
  188. package/fesm2022/cmat-directives-autofocus.mjs.map +1 -1
  189. package/fesm2022/cmat-directives-debounce.mjs +10 -10
  190. package/fesm2022/cmat-directives-debounce.mjs.map +1 -1
  191. package/fesm2022/cmat-directives-digit-only.mjs +22 -6
  192. package/fesm2022/cmat-directives-digit-only.mjs.map +1 -1
  193. package/fesm2022/cmat-directives-equal-validator.mjs +3 -3
  194. package/fesm2022/cmat-lib-mock-api.mjs +6 -6
  195. package/fesm2022/cmat-pipes-bytes.mjs +3 -3
  196. package/fesm2022/cmat-pipes-date-format.mjs +3 -3
  197. package/fesm2022/cmat-pipes-find-by-key.mjs +3 -3
  198. package/fesm2022/cmat-pipes-group-by.mjs +3 -3
  199. package/fesm2022/cmat-pipes-keys.mjs +3 -3
  200. package/fesm2022/cmat-pipes-secure.mjs +4 -4
  201. package/fesm2022/cmat-pipes-secure.mjs.map +1 -1
  202. package/fesm2022/cmat-pipes-uppercase.mjs +3 -3
  203. package/fesm2022/cmat-services-alert.mjs +15 -15
  204. package/fesm2022/cmat-services-alert.mjs.map +1 -1
  205. package/fesm2022/cmat-services-config.mjs +6 -6
  206. package/fesm2022/cmat-services-config.mjs.map +1 -1
  207. package/fesm2022/cmat-services-confirmation.mjs +8 -8
  208. package/fesm2022/cmat-services-confirmation.mjs.map +1 -1
  209. package/fesm2022/cmat-services-data.mjs +3 -3
  210. package/fesm2022/cmat-services-data.mjs.map +1 -1
  211. package/fesm2022/cmat-services-loading.mjs +6 -6
  212. package/fesm2022/cmat-services-local-storage.mjs +3 -3
  213. package/fesm2022/cmat-services-media-watcher.mjs +3 -3
  214. package/fesm2022/cmat-services-platform.mjs +3 -3
  215. package/fesm2022/cmat-services-splash-screen.mjs +3 -3
  216. package/fesm2022/cmat-services-title.mjs +3 -3
  217. package/fesm2022/cmat-services-translation.mjs +3 -3
  218. package/fesm2022/cmat-services-utils.mjs +3 -3
  219. package/package.json +75 -65
  220. package/pipes/secure/secure-pipe.d.ts +1 -1
  221. package/services/alert/alert.service.d.ts +4 -4
  222. package/services/config/config.constants.d.ts +1 -1
  223. package/services/config/urlStateConfig.service.d.ts +3 -2
  224. package/styles/components/bundle.scss +559 -0
  225. package/styles/overrides/angular-material.scss +16 -16
  226. package/styles/styles.scss +6 -1
  227. package/styles/tailwind.scss +4 -2
  228. package/components/breadcrumb/breadcrumb.component.scss +0 -18
  229. package/components/card/card.component.scss +0 -63
  230. package/components/cascade/cascade-bottom-sheet/cascade-bottom-sheet.component.scss +0 -43
  231. package/components/cascade/cascade-list/cascade-list.component.scss +0 -22
  232. package/components/cascade/cascade-menu/cascade-menu.component.scss +0 -48
  233. package/components/date-range/date-range.component.scss +0 -232
  234. package/components/drawer/drawer.component.scss +0 -133
  235. package/components/highlight/highlight.component.scss +0 -3
  236. package/components/material-color-picker/material-color-picker.component.scss +0 -5
  237. package/components/material-datetimepicker/calendar-body.scss +0 -58
  238. package/components/material-datetimepicker/calendar.scss +0 -194
  239. package/components/material-datetimepicker/clock.scss +0 -90
  240. package/components/material-datetimepicker/datetimepicker-content.scss +0 -151
  241. package/components/material-datetimepicker/datetimepicker.scss +0 -145
  242. package/components/material-datetimepicker/time.scss +0 -82
  243. package/components/navigation/horizontal/horizontal.component.scss +0 -167
  244. package/components/navigation/vertical/styles/appearances/compact.scss +0 -103
  245. package/components/navigation/vertical/styles/appearances/default.scss +0 -550
  246. package/components/navigation/vertical/styles/appearances/dense.scss +0 -171
  247. package/components/navigation/vertical/styles/appearances/thin.scss +0 -91
  248. package/components/navigation/vertical/vertical.component.scss +0 -4
  249. package/components/password-strength/mat-password-strength-info/mat-password-strength-info.component.scss +0 -19
  250. package/components/popover/popover.component.scss +0 -174
  251. package/components/progress-bar/progress-bar.component.scss +0 -7
  252. package/components/rating/rating.component.scss +0 -33
  253. package/components/select-search/select-search.component.scss +0 -126
  254. package/components/select-tree/select-tree.component.scss +0 -54
  255. package/components/timeline/timeline-item/timeline-item.component.scss +0 -329
  256. package/components/timeline/timeline.component.scss +0 -42
  257. package/components/toast/toast-modal.component.scss +0 -119
  258. package/components/toast/toast.component.scss +0 -62
  259. package/components/transfer-picker/filter/filter.component.scss +0 -40
  260. package/components/transfer-picker/search/search.component.scss +0 -7
  261. package/components/transfer-picker/transfer-picker-source/transfer-picker-source.component.scss +0 -25
  262. package/components/transfer-picker/transfer-picker-target/transfer-picker-target.component.scss +0 -27
  263. package/components/transfer-picker/transfer-picker.component.scss +0 -8
  264. package/esm2022/animations/drop.mjs +0 -26
  265. package/styles/main.scss +0 -9
  266. /package/animations/{drop.d.ts → dropdown.d.ts} +0 -0
@@ -0,0 +1,176 @@
1
+ import { Component, Input, ViewChild, Output, EventEmitter, ChangeDetectionStrategy, ViewEncapsulation, } from '@angular/core';
2
+ import { JSONEditor, stringifyJSONPath, createAjvValidator, parseJSONPath, isKeySelection, isJSONContent, isMultiSelection, createMultiSelection, } from 'vanilla-jsoneditor';
3
+ import * as i0 from "@angular/core";
4
+ export class CmatJsonEditorComponent {
5
+ constructor(_changeDetectorRef) {
6
+ this._changeDetectorRef = _changeDetectorRef;
7
+ this.contentChanged = new EventEmitter();
8
+ this.pathChanged = new EventEmitter();
9
+ this.id = 'cmatjsoneditor' + Math.floor(Math.random() * 1000000);
10
+ this.content = {
11
+ text: undefined,
12
+ json: {}
13
+ };
14
+ }
15
+ ngOnInit() {
16
+ if (!this.jsonEditorContainer.nativeElement) {
17
+ console.error('Can\'t find the ElementRef reference for jsoneditor)');
18
+ }
19
+ this._editor = new JSONEditor({
20
+ target: this.jsonEditorContainer.nativeElement,
21
+ props: {
22
+ ...this.options,
23
+ content: this.content,
24
+ onChange: (updatedContent, previousContent, { contentErrors, patchResult }) => {
25
+ console.log('onChange', {
26
+ updatedContent,
27
+ previousContent,
28
+ contentErrors,
29
+ patchResult,
30
+ });
31
+ this.content = updatedContent;
32
+ this.contentChanged.emit(updatedContent);
33
+ },
34
+ onSelect: this._onSelect.bind(this),
35
+ onRenderMenu(items,
36
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
37
+ context) {
38
+ // remove buttons for table-mode, transform, sort
39
+ items.splice(items.findIndex(i => i['text'] === 'table'), 1);
40
+ items.splice(items.findIndex(i => i['className'] === 'jse-sort'), 1);
41
+ items.splice(items.findIndex(i => i['className'] === 'jse-transform'), 1);
42
+ items.forEach((item) => {
43
+ const button = item;
44
+ switch (button['title']) {
45
+ case 'Switch to text mode (current mode: text)':
46
+ button.text = '文本';
47
+ button.title = '切换到文本模式(当前模式:文本)';
48
+ break;
49
+ case 'Switch to tree mode (current mode: text)':
50
+ button.text = '树';
51
+ button.title = '切换到树模式(当前模式:文本)';
52
+ break;
53
+ case 'Switch to text mode (current mode: tree)':
54
+ button.text = '文本';
55
+ button.title = '切换到文本模式(当前模式:树)';
56
+ break;
57
+ case 'Switch to tree mode (current mode: tree)':
58
+ button.text = '树';
59
+ button.title = '切换到树模式(当前模式:树)';
60
+ break;
61
+ case 'Format JSON: add proper indentation and new lines (Ctrl+I)':
62
+ button.title = 'JSON格式化: 添加适当的缩进和新行 (Ctrl+I)';
63
+ break;
64
+ case 'Compact JSON: remove all white spacing and new lines (Ctrl+Shift+I)':
65
+ button.title = '压缩JSON: 删除所有白色间距和新行 (Ctrl+Shift+I)';
66
+ break;
67
+ case 'Search (Ctrl+F)':
68
+ button.title = '搜索 (Ctrl+F)';
69
+ break;
70
+ case 'Undo (Ctrl+Z)':
71
+ button.title = '撤回 (Ctrl+Z)';
72
+ break;
73
+ case 'Redo (Ctrl+Shift+Z)':
74
+ button.title = '重试 (Ctrl+Shift+Z)';
75
+ break;
76
+ case 'Expand all':
77
+ button.title = '全部展开';
78
+ break;
79
+ case 'Collapse all':
80
+ button.title = '全部折叠';
81
+ break;
82
+ case 'Open context menu (Click here, right click on the selection, or use the context menu button or Ctrl+Q)':
83
+ button.title = '打开内容菜单 (单击此处,右键单击所选内容,或使用内容菜单按钮或 Ctrl+Q)';
84
+ break;
85
+ }
86
+ });
87
+ return items;
88
+ },
89
+ },
90
+ });
91
+ }
92
+ ngOnChanges(changes) {
93
+ if (changes.data) {
94
+ this.content = {
95
+ text: undefined,
96
+ json: this.data
97
+ };
98
+ if (this._editor) {
99
+ this._editor.update(this.content);
100
+ }
101
+ this._changeDetectorRef.markForCheck();
102
+ }
103
+ if (changes.options) {
104
+ if (this._editor) {
105
+ this._editor?.updateProps(this.options);
106
+ }
107
+ }
108
+ }
109
+ ngOnDestroy() {
110
+ this._editor?.destroy();
111
+ }
112
+ setSchema(schema) {
113
+ const validator = createAjvValidator({ schema });
114
+ this._editor?.updateProps({ validator: validator });
115
+ }
116
+ setSelectionToPath(pathString) {
117
+ const path = parseJSONPath(pathString);
118
+ const selection = createMultiSelection(path, path);
119
+ try {
120
+ this._editor?.select(selection);
121
+ }
122
+ catch (error) {
123
+ console.warn('Set selection to path not possible:', pathString, error);
124
+ }
125
+ this.pathChanged.emit(pathString);
126
+ }
127
+ get() {
128
+ if (this._editor) {
129
+ const content = this._editor.get();
130
+ if (isJSONContent(content)) {
131
+ const j = this._editor.get().json;
132
+ return j;
133
+ }
134
+ else {
135
+ const t = this._editor.get().text;
136
+ const j = JSON.parse(t);
137
+ return j;
138
+ }
139
+ }
140
+ return undefined;
141
+ }
142
+ set(json) {
143
+ const value = {
144
+ json: json,
145
+ };
146
+ this._editor?.set(value);
147
+ }
148
+ _onSelect(selection) {
149
+ if (isKeySelection(selection)) {
150
+ const st = stringifyJSONPath(selection.path);
151
+ this.pathChanged.emit(st);
152
+ }
153
+ else if (isMultiSelection(selection)) {
154
+ const st = stringifyJSONPath(selection.anchorPath);
155
+ this.pathChanged.emit(st);
156
+ }
157
+ }
158
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CmatJsonEditorComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
159
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.4", type: CmatJsonEditorComponent, isStandalone: true, selector: "cmat-json-editor", inputs: { options: "options", data: "data" }, outputs: { contentChanged: "contentChanged", pathChanged: "pathChanged" }, viewQueries: [{ propertyName: "jsonEditorContainer", first: true, predicate: ["jsonEditorContainer"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: '<div class="cmat-jsoneditor" [id]="id" #jsonEditorContainer></div>', isInline: true, styles: [".cmat-jsoneditor .jse-main.svelte-sxaskb{min-height:24rem}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
160
+ }
161
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CmatJsonEditorComponent, decorators: [{
162
+ type: Component,
163
+ args: [{ selector: 'cmat-json-editor', template: '<div class="cmat-jsoneditor" [id]="id" #jsonEditorContainer></div>', preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, standalone: true, imports: [], styles: [".cmat-jsoneditor .jse-main.svelte-sxaskb{min-height:24rem}\n"] }]
164
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { jsonEditorContainer: [{
165
+ type: ViewChild,
166
+ args: ['jsonEditorContainer', { static: true }]
167
+ }], options: [{
168
+ type: Input
169
+ }], data: [{
170
+ type: Input
171
+ }], contentChanged: [{
172
+ type: Output
173
+ }], pathChanged: [{
174
+ type: Output
175
+ }] } });
176
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"json-editor.component.js","sourceRoot":"","sources":["../../../../../projects/cmat/components/json-editor/json-editor.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    Component,\r\n    ElementRef,\r\n    Input,\r\n    OnInit,\r\n    OnDestroy,\r\n    ViewChild,\r\n    Output,\r\n    EventEmitter,\r\n    ChangeDetectionStrategy,\r\n    ViewEncapsulation,\r\n    OnChanges,\r\n    SimpleChanges,\r\n    ChangeDetectorRef,\r\n} from '@angular/core';\r\nimport {\r\n    JSONEditor,\r\n    stringifyJSONPath,\r\n    Content,\r\n    MenuItem,\r\n    createAjvValidator,\r\n    parseJSONPath,\r\n    JSONEditorSelection,\r\n    isKeySelection,\r\n    isJSONContent,\r\n    JSONContent,\r\n    isMultiSelection,\r\n    createMultiSelection,\r\n    MenuButton,\r\n    TextContent,\r\n} from 'vanilla-jsoneditor';\r\n\r\n@Component({\r\n    selector: 'cmat-json-editor',\r\n    template: '<div class=\"cmat-jsoneditor\" [id]=\"id\" #jsonEditorContainer></div>',\r\n    preserveWhitespaces: false,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    styleUrls: ['./json-editor.component.scss'],\r\n    encapsulation: ViewEncapsulation.None,\r\n    standalone: true,\r\n    imports: []\r\n})\r\nexport class CmatJsonEditorComponent implements OnInit, OnChanges, OnDestroy {\r\n    @ViewChild('jsonEditorContainer', { static: true }) jsonEditorContainer!: ElementRef;\r\n    @Input() options: any;\r\n    @Input() data: any;\r\n\r\n    @Output() contentChanged: EventEmitter<any> = new EventEmitter<any>();\r\n    @Output() pathChanged: EventEmitter<string> = new EventEmitter<string>();\r\n\r\n    public id = 'cmatjsoneditor' + Math.floor(Math.random() * 1000000);\r\n    content: Content = {\r\n        text: undefined,\r\n        json: {}\r\n    };\r\n\r\n    private _editor: JSONEditor | undefined;\r\n\r\n    constructor(private _changeDetectorRef: ChangeDetectorRef) { }\r\n\r\n    ngOnInit(): void {\r\n        if (!this.jsonEditorContainer.nativeElement) {\r\n            console.error('Can\\'t find the ElementRef reference for jsoneditor)');\r\n        }\r\n        this._editor = new JSONEditor({\r\n            target: this.jsonEditorContainer.nativeElement,\r\n            props: {\r\n                ...this.options,\r\n                content: this.content,\r\n                onChange: (\r\n                    updatedContent,\r\n                    previousContent,\r\n                    { contentErrors, patchResult }\r\n                ): void => {\r\n                    console.log('onChange', {\r\n                        updatedContent,\r\n                        previousContent,\r\n                        contentErrors,\r\n                        patchResult,\r\n                    });\r\n                    this.content = updatedContent;\r\n                    this.contentChanged.emit(updatedContent);\r\n                },\r\n                onSelect: this._onSelect.bind(this),\r\n                onRenderMenu(\r\n                    items: MenuItem[],\r\n                    // eslint-disable-next-line @typescript-eslint/no-unused-vars\r\n                    context: { mode: 'tree' | 'text' | 'table'; modal: boolean }\r\n                ): MenuItem[] | undefined {\r\n                    // remove buttons for table-mode, transform, sort\r\n                    items.splice(\r\n                        items.findIndex(i => (i as MenuButton)['text'] === 'table'),\r\n                        1\r\n                    );\r\n                    items.splice(\r\n                        items.findIndex(i => (i as MenuButton)['className'] === 'jse-sort'),\r\n                        1\r\n                    );\r\n                    items.splice(\r\n                        items.findIndex(i => (i as MenuButton)['className'] === 'jse-transform'),\r\n                        1\r\n                    );\r\n\r\n                    items.forEach((item) => {\r\n                        const button = item as MenuButton;\r\n                        switch (button['title']) {\r\n                            case 'Switch to text mode (current mode: text)':\r\n                                button.text = '文本';\r\n                                button.title = '切换到文本模式(当前模式:文本)';\r\n                                break;\r\n                            case 'Switch to tree mode (current mode: text)':\r\n                                button.text = '树';\r\n                                button.title = '切换到树模式(当前模式:文本)';\r\n                                break;\r\n                            case 'Switch to text mode (current mode: tree)':\r\n                                button.text = '文本';\r\n                                button.title = '切换到文本模式(当前模式:树)';\r\n                                break;\r\n                            case 'Switch to tree mode (current mode: tree)':\r\n                                button.text = '树';\r\n                                button.title = '切换到树模式(当前模式:树)';\r\n                                break;\r\n                            case 'Format JSON: add proper indentation and new lines (Ctrl+I)':\r\n                                button.title = 'JSON格式化: 添加适当的缩进和新行 (Ctrl+I)';\r\n                                break;\r\n                            case 'Compact JSON: remove all white spacing and new lines (Ctrl+Shift+I)':\r\n                                button.title = '压缩JSON: 删除所有白色间距和新行 (Ctrl+Shift+I)';\r\n                                break;\r\n                            case 'Search (Ctrl+F)':\r\n                                button.title = '搜索 (Ctrl+F)';\r\n                                break;\r\n                            case 'Undo (Ctrl+Z)':\r\n                                button.title = '撤回 (Ctrl+Z)';\r\n                                break;\r\n                            case 'Redo (Ctrl+Shift+Z)':\r\n                                button.title = '重试 (Ctrl+Shift+Z)';\r\n                                break;\r\n                            case 'Expand all':\r\n                                button.title = '全部展开';\r\n                                break;\r\n                            case 'Collapse all':\r\n                                button.title = '全部折叠';\r\n                                break;\r\n                            case 'Open context menu (Click here, right click on the selection, or use the context menu button or Ctrl+Q)':\r\n                                button.title = '打开内容菜单 (单击此处，右键单击所选内容，或使用内容菜单按钮或 Ctrl+Q)';\r\n                                break;\r\n                        }\r\n                    });\r\n                    return items;\r\n                },\r\n            },\r\n        });\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        if (changes.data) {\r\n            this.content = {\r\n                text: undefined,\r\n                json: <any>this.data\r\n            };\r\n\r\n            if (this._editor) {\r\n                this._editor.update(this.content);\r\n            }\r\n\r\n            this._changeDetectorRef.markForCheck();\r\n        }\r\n\r\n        if(changes.options){\r\n            if(this._editor){\r\n                this._editor?.updateProps(this.options);\r\n            }\r\n        }\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this._editor?.destroy();\r\n    }\r\n\r\n    setSchema(schema: any): void {\r\n        const validator = createAjvValidator({ schema });\r\n        this._editor?.updateProps({ validator: validator });\r\n    }\r\n\r\n    setSelectionToPath(pathString: string): void {\r\n        const path = parseJSONPath(pathString);\r\n        const selection = createMultiSelection(path, path);\r\n\r\n        try {\r\n            this._editor?.select(selection);\r\n        } catch (error) {\r\n            console.warn('Set selection to path not possible:', pathString, error);\r\n        }\r\n        this.pathChanged.emit(pathString);\r\n    }\r\n\r\n    get(): JSON | undefined {\r\n        if (this._editor) {\r\n            const content: Content = this._editor.get();\r\n            if (isJSONContent(content)) {\r\n                const j: any = (this._editor.get() as JSONContent).json;\r\n                return j;\r\n            } else {\r\n                const t: any = (this._editor.get() as TextContent).text;\r\n                const j: JSON = JSON.parse(t);\r\n                return j;\r\n            }\r\n        }\r\n        return undefined;\r\n    }\r\n\r\n    set(json: any): void {\r\n        const value: JSONContent = {\r\n            json: json,\r\n        };\r\n\r\n        this._editor?.set(value);\r\n    }\r\n\r\n    private _onSelect(selection: JSONEditorSelection | null): void {\r\n        if (isKeySelection(selection)) {\r\n            const st = stringifyJSONPath((selection as any).path);\r\n            this.pathChanged.emit(st);\r\n        } else if (isMultiSelection(selection)) {\r\n            const st = stringifyJSONPath((selection as any).anchorPath);\r\n            this.pathChanged.emit(st);\r\n        }\r\n    }\r\n}"]}
@@ -0,0 +1,2 @@
1
+ export * from './json-editor.component';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NtYXQvY29tcG9uZW50cy9qc29uLWVkaXRvci9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMseUJBQXlCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2pzb24tZWRpdG9yLmNvbXBvbmVudCc7XHJcbiJdfQ==
@@ -36,10 +36,10 @@ export class CmatMasonryComponent {
36
36
  this.distributedColumns[i % this.columns].items.push(this.items[i]);
37
37
  }
38
38
  }
39
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: CmatMasonryComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
40
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.0", type: CmatMasonryComponent, isStandalone: true, selector: "cmat-masonry", inputs: { columnsTemplate: "columnsTemplate", columns: "columns", items: "items" }, exportAs: ["cmatMasonry"], usesOnChanges: true, ngImport: i0, template: "<div class=\"flex p-2\">\r\n <ng-container *ngTemplateOutlet=\"columnsTemplate; context: { $implicit: distributedColumns }\"></ng-container>\r\n</div>", dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], animations: cmatAnimations, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
39
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CmatMasonryComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
40
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.4", type: CmatMasonryComponent, isStandalone: true, selector: "cmat-masonry", inputs: { columnsTemplate: "columnsTemplate", columns: "columns", items: "items" }, exportAs: ["cmatMasonry"], usesOnChanges: true, ngImport: i0, template: "<div class=\"flex p-2\">\r\n <ng-container *ngTemplateOutlet=\"columnsTemplate; context: { $implicit: distributedColumns }\"></ng-container>\r\n</div>", dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], animations: cmatAnimations, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
41
41
  }
42
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: CmatMasonryComponent, decorators: [{
42
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CmatMasonryComponent, decorators: [{
43
43
  type: Component,
44
44
  args: [{ selector: 'cmat-masonry', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, animations: cmatAnimations, exportAs: 'cmatMasonry', standalone: true, imports: [NgTemplateOutlet], template: "<div class=\"flex p-2\">\r\n <ng-container *ngTemplateOutlet=\"columnsTemplate; context: { $implicit: distributedColumns }\"></ng-container>\r\n</div>" }]
45
45
  }], propDecorators: { columnsTemplate: [{
@@ -7,7 +7,7 @@ import { MatTooltipModule } from '@angular/material/tooltip';
7
7
  import { MatButtonModule } from '@angular/material/button';
8
8
  import { MatIconModule } from '@angular/material/icon';
9
9
  import { MatSelectModule } from '@angular/material/select';
10
- import { NgClass, NgSwitch, NgSwitchCase, NgFor, NgIf } from '@angular/common';
10
+ import { NgClass } from '@angular/common';
11
11
  import * as i0 from "@angular/core";
12
12
  import * as i1 from "@angular/material/select";
13
13
  import * as i2 from "@angular/material/core";
@@ -122,12 +122,12 @@ export class CmatMaterialColorPickerComponent {
122
122
  trackByFn(index, item) {
123
123
  return index || item;
124
124
  }
125
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: CmatMaterialColorPickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
126
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.0", type: CmatMaterialColorPickerComponent, isStandalone: true, selector: "cmat-material-color-picker", inputs: { color: "color", title: "title" }, outputs: { colorChanged: "colorChanged" }, providers: [CMAT_MATERIAL_COLOR_PICKER_VALUE_ACCESSOR], exportAs: ["cmatMaterialColorPicker"], ngImport: i0, template: "<div class=\"rounded\" [ngClass]=\"selectedColor.color\">\r\n <mat-select value=\"init\" [disableOptionCentering]=\"true\" [hideSingleSelectionIndicator]=\"true\"\r\n (openedChange)=\"onMenuOpen($event)\">\r\n <mat-select-trigger class=\"flex p-1\">\r\n <mat-icon [svgIcon]=\"'heroicons_outline:paint-brush'\"></mat-icon>\r\n </mat-select-trigger>\r\n\r\n <header [ngClass]=\"'accent'\" class=\"shadow flex flex-row content-between justify-between p-2\">\r\n <button type=\"button\" mat-icon-button class=\"secondary-text\" [class.invisible]=\"view === 'palettes'\"\r\n (click)=\"goToPalettesView()\" aria-label=\"\u8C03\u8272\u677F\">\r\n <mat-icon svgIcon=\"mat_outline:arrow_back\"></mat-icon>\r\n </button>\r\n <span class=\"align-middle leading-loose text-xl font-bold\">{{title}}</span>\r\n <button type=\"button\" mat-icon-button class=\"remove-color-button secondary-text\" (click)=\"removeColor()\"\r\n aria-label=\"\u79FB\u9664\u989C\u8272\" matTooltip=\"\u79FB\u9664\u989C\u8272\">\r\n <mat-icon color=\"warn\" [svgIcon]=\"'mat_outline:cleaning_services'\"></mat-icon>\r\n </button>\r\n </header>\r\n\r\n <div class=\"flex flex-wrap w-60 m-2\">\r\n <mat-option value=\"init\" class=\"hidden\">\u521D\u59CB\u5316</mat-option>\r\n <div [ngSwitch]=\"view\">\r\n <div *ngSwitchCase=\"'palettes'\">\r\n <div class=\"flex flex-row flex-wrap justify-start content-start colors\">\r\n <div role=\"presentation\" *ngFor=\"let palette of palettes;trackBy: trackByFn\"\r\n class=\"cursor-pointer\" (click)=\"selectPalette(palette)\">\r\n <mat-option\r\n class=\"relative flex w-12 h-12 p-0 pointer-events-none rounded-full bg-transparent hover:opacity-50\"\r\n [value]=\"selectedPalette\">\r\n <mat-icon class=\"absolute m-3 text-white\"\r\n *ngIf=\"selectedColor.color===palette + '-' + selectedHue\"\r\n [svgIcon]=\"'heroicons_outline:check'\"></mat-icon>\r\n <span class=\"flex w-10 h-10 m-1 rounded-full\"\r\n [ngClass]=\"palette + '-' + selectedHue\"></span>\r\n </mat-option>\r\n </div>\r\n </div>\r\n </div>\r\n <div *ngSwitchCase=\"'hues'\">\r\n <div class=\"flex flex-row flex-wrap justify-start content-start colors\">\r\n <div role=\"presentation\" *ngFor=\"let hue of hues;trackBy: trackByFn\" class=\"cursor-pointer\"\r\n (click)=\"selectHue(hue)\">\r\n <mat-option\r\n class=\"relative flex w-12 h-12 p-0 pointer-events-none rounded-full bg-transparent hover:opacity-50\"\r\n [value]=\"selectedHue\">\r\n <mat-icon class=\"absolute m-3 text-white\"\r\n *ngIf=\"selectedColor.color===selectedPalette + '-' + hue\"\r\n [svgIcon]=\"'heroicons_outline:check'\"></mat-icon>\r\n <span class=\"flex w-10 h-10 m-1 rounded-full\"\r\n [ngClass]=\"selectedPalette + '-' + hue\"></span>\r\n </mat-option>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </mat-select>\r\n</div>", styles: ["cmat-material-color-picker .mat-mdc-select-arrow-wrapper{display:none!important}\n"], dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: MatSelectModule }, { kind: "component", type: i1.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "directive", type: i1.MatSelectTrigger, selector: "mat-select-trigger" }, { kind: "component", type: i2.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i4.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i5.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "directive", type: NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], animations: cmatAnimations, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
125
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CmatMaterialColorPickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
126
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.4", type: CmatMaterialColorPickerComponent, isStandalone: true, selector: "cmat-material-color-picker", inputs: { color: "color", title: "title" }, outputs: { colorChanged: "colorChanged" }, providers: [CMAT_MATERIAL_COLOR_PICKER_VALUE_ACCESSOR], exportAs: ["cmatMaterialColorPicker"], ngImport: i0, template: "<div class=\"rounded\" [ngClass]=\"selectedColor.color\">\n <mat-select value=\"init\" [disableOptionCentering]=\"true\" [hideSingleSelectionIndicator]=\"true\"\n (openedChange)=\"onMenuOpen($event)\" panelClass=\"min-w-64\">\n <mat-select-trigger class=\"flex p-1\">\n <mat-icon [svgIcon]=\"'heroicons_outline:paint-brush'\"></mat-icon>\n </mat-select-trigger>\n\n <header [ngClass]=\"'accent'\" class=\"shadow flex flex-row content-between justify-between p-2\">\n <button type=\"button\" mat-icon-button class=\"secondary-text\" [class.invisible]=\"view === 'palettes'\"\n (click)=\"goToPalettesView()\" aria-label=\"\u8C03\u8272\u677F\">\n <mat-icon svgIcon=\"mat_outline:arrow_back\"></mat-icon>\n </button>\n <span class=\"align-middle leading-loose text-xl font-bold\">{{title}}</span>\n <button type=\"button\" mat-icon-button class=\"remove-color-button secondary-text\" (click)=\"removeColor()\"\n aria-label=\"\u79FB\u9664\u989C\u8272\" matTooltip=\"\u79FB\u9664\u989C\u8272\">\n <mat-icon color=\"warn\" [svgIcon]=\"'mat_outline:cleaning_services'\"></mat-icon>\n </button>\n </header>\n\n <div class=\"flex flex-wrap w-60 m-2\">\n <mat-option value=\"init\" class=\"hidden\">\u521D\u59CB\u5316</mat-option>\n <div>\n @switch (view) {\n @case ('palettes') {\n <div>\n <div class=\"flex flex-row flex-wrap justify-start content-start colors\">\n @for (palette of palettes; track trackByFn($index, palette)) {\n <div role=\"presentation\"\n class=\"cursor-pointer\" (click)=\"selectPalette(palette)\">\n <mat-option\n class=\"relative flex w-12 h-12 p-0 pointer-events-none rounded-full bg-transparent hover:opacity-50\"\n [value]=\"selectedPalette\">\n @if (selectedColor.color===palette + '-' + selectedHue) {\n <mat-icon class=\"absolute m-3 text-white\"\n [svgIcon]=\"'heroicons_outline:check'\"></mat-icon>\n }\n <span class=\"flex w-10 h-10 m-1 rounded-full\"\n [ngClass]=\"palette + '-' + selectedHue\"></span>\n </mat-option>\n </div>\n }\n </div>\n </div>\n }\n @case ('hues') {\n <div>\n <div class=\"flex flex-row flex-wrap justify-start content-start colors\">\n @for (hue of hues; track trackByFn($index, hue)) {\n <div role=\"presentation\" class=\"cursor-pointer\"\n (click)=\"selectHue(hue)\">\n <mat-option\n class=\"relative flex w-12 h-12 p-0 pointer-events-none rounded-full bg-transparent hover:opacity-50\"\n [value]=\"selectedHue\">\n @if (selectedColor.color===selectedPalette + '-' + hue) {\n <mat-icon class=\"absolute m-3 text-white\"\n [svgIcon]=\"'heroicons_outline:check'\"></mat-icon>\n }\n <span class=\"flex w-10 h-10 m-1 rounded-full\"\n [ngClass]=\"selectedPalette + '-' + hue\"></span>\n </mat-option>\n </div>\n }\n </div>\n </div>\n }\n }\n </div>\n </div>\n </mat-select>\n</div>", styles: ["cmat-material-color-picker .mat-mdc-select-arrow-wrapper{display:none!important}\n"], dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: MatSelectModule }, { kind: "component", type: i1.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "directive", type: i1.MatSelectTrigger, selector: "mat-select-trigger" }, { kind: "component", type: i2.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i4.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i5.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }], animations: cmatAnimations, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
127
127
  }
128
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: CmatMaterialColorPickerComponent, decorators: [{
128
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CmatMaterialColorPickerComponent, decorators: [{
129
129
  type: Component,
130
- args: [{ selector: 'cmat-material-color-picker', animations: cmatAnimations, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, exportAs: 'cmatMaterialColorPicker', providers: [CMAT_MATERIAL_COLOR_PICKER_VALUE_ACCESSOR], standalone: true, imports: [NgClass, MatSelectModule, MatIconModule, MatButtonModule, MatTooltipModule, NgSwitch, NgSwitchCase, NgFor, NgIf], template: "<div class=\"rounded\" [ngClass]=\"selectedColor.color\">\r\n <mat-select value=\"init\" [disableOptionCentering]=\"true\" [hideSingleSelectionIndicator]=\"true\"\r\n (openedChange)=\"onMenuOpen($event)\">\r\n <mat-select-trigger class=\"flex p-1\">\r\n <mat-icon [svgIcon]=\"'heroicons_outline:paint-brush'\"></mat-icon>\r\n </mat-select-trigger>\r\n\r\n <header [ngClass]=\"'accent'\" class=\"shadow flex flex-row content-between justify-between p-2\">\r\n <button type=\"button\" mat-icon-button class=\"secondary-text\" [class.invisible]=\"view === 'palettes'\"\r\n (click)=\"goToPalettesView()\" aria-label=\"\u8C03\u8272\u677F\">\r\n <mat-icon svgIcon=\"mat_outline:arrow_back\"></mat-icon>\r\n </button>\r\n <span class=\"align-middle leading-loose text-xl font-bold\">{{title}}</span>\r\n <button type=\"button\" mat-icon-button class=\"remove-color-button secondary-text\" (click)=\"removeColor()\"\r\n aria-label=\"\u79FB\u9664\u989C\u8272\" matTooltip=\"\u79FB\u9664\u989C\u8272\">\r\n <mat-icon color=\"warn\" [svgIcon]=\"'mat_outline:cleaning_services'\"></mat-icon>\r\n </button>\r\n </header>\r\n\r\n <div class=\"flex flex-wrap w-60 m-2\">\r\n <mat-option value=\"init\" class=\"hidden\">\u521D\u59CB\u5316</mat-option>\r\n <div [ngSwitch]=\"view\">\r\n <div *ngSwitchCase=\"'palettes'\">\r\n <div class=\"flex flex-row flex-wrap justify-start content-start colors\">\r\n <div role=\"presentation\" *ngFor=\"let palette of palettes;trackBy: trackByFn\"\r\n class=\"cursor-pointer\" (click)=\"selectPalette(palette)\">\r\n <mat-option\r\n class=\"relative flex w-12 h-12 p-0 pointer-events-none rounded-full bg-transparent hover:opacity-50\"\r\n [value]=\"selectedPalette\">\r\n <mat-icon class=\"absolute m-3 text-white\"\r\n *ngIf=\"selectedColor.color===palette + '-' + selectedHue\"\r\n [svgIcon]=\"'heroicons_outline:check'\"></mat-icon>\r\n <span class=\"flex w-10 h-10 m-1 rounded-full\"\r\n [ngClass]=\"palette + '-' + selectedHue\"></span>\r\n </mat-option>\r\n </div>\r\n </div>\r\n </div>\r\n <div *ngSwitchCase=\"'hues'\">\r\n <div class=\"flex flex-row flex-wrap justify-start content-start colors\">\r\n <div role=\"presentation\" *ngFor=\"let hue of hues;trackBy: trackByFn\" class=\"cursor-pointer\"\r\n (click)=\"selectHue(hue)\">\r\n <mat-option\r\n class=\"relative flex w-12 h-12 p-0 pointer-events-none rounded-full bg-transparent hover:opacity-50\"\r\n [value]=\"selectedHue\">\r\n <mat-icon class=\"absolute m-3 text-white\"\r\n *ngIf=\"selectedColor.color===selectedPalette + '-' + hue\"\r\n [svgIcon]=\"'heroicons_outline:check'\"></mat-icon>\r\n <span class=\"flex w-10 h-10 m-1 rounded-full\"\r\n [ngClass]=\"selectedPalette + '-' + hue\"></span>\r\n </mat-option>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </mat-select>\r\n</div>", styles: ["cmat-material-color-picker .mat-mdc-select-arrow-wrapper{display:none!important}\n"] }]
130
+ args: [{ selector: 'cmat-material-color-picker', animations: cmatAnimations, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, exportAs: 'cmatMaterialColorPicker', providers: [CMAT_MATERIAL_COLOR_PICKER_VALUE_ACCESSOR], standalone: true, imports: [NgClass, MatSelectModule, MatIconModule, MatButtonModule, MatTooltipModule], template: "<div class=\"rounded\" [ngClass]=\"selectedColor.color\">\n <mat-select value=\"init\" [disableOptionCentering]=\"true\" [hideSingleSelectionIndicator]=\"true\"\n (openedChange)=\"onMenuOpen($event)\" panelClass=\"min-w-64\">\n <mat-select-trigger class=\"flex p-1\">\n <mat-icon [svgIcon]=\"'heroicons_outline:paint-brush'\"></mat-icon>\n </mat-select-trigger>\n\n <header [ngClass]=\"'accent'\" class=\"shadow flex flex-row content-between justify-between p-2\">\n <button type=\"button\" mat-icon-button class=\"secondary-text\" [class.invisible]=\"view === 'palettes'\"\n (click)=\"goToPalettesView()\" aria-label=\"\u8C03\u8272\u677F\">\n <mat-icon svgIcon=\"mat_outline:arrow_back\"></mat-icon>\n </button>\n <span class=\"align-middle leading-loose text-xl font-bold\">{{title}}</span>\n <button type=\"button\" mat-icon-button class=\"remove-color-button secondary-text\" (click)=\"removeColor()\"\n aria-label=\"\u79FB\u9664\u989C\u8272\" matTooltip=\"\u79FB\u9664\u989C\u8272\">\n <mat-icon color=\"warn\" [svgIcon]=\"'mat_outline:cleaning_services'\"></mat-icon>\n </button>\n </header>\n\n <div class=\"flex flex-wrap w-60 m-2\">\n <mat-option value=\"init\" class=\"hidden\">\u521D\u59CB\u5316</mat-option>\n <div>\n @switch (view) {\n @case ('palettes') {\n <div>\n <div class=\"flex flex-row flex-wrap justify-start content-start colors\">\n @for (palette of palettes; track trackByFn($index, palette)) {\n <div role=\"presentation\"\n class=\"cursor-pointer\" (click)=\"selectPalette(palette)\">\n <mat-option\n class=\"relative flex w-12 h-12 p-0 pointer-events-none rounded-full bg-transparent hover:opacity-50\"\n [value]=\"selectedPalette\">\n @if (selectedColor.color===palette + '-' + selectedHue) {\n <mat-icon class=\"absolute m-3 text-white\"\n [svgIcon]=\"'heroicons_outline:check'\"></mat-icon>\n }\n <span class=\"flex w-10 h-10 m-1 rounded-full\"\n [ngClass]=\"palette + '-' + selectedHue\"></span>\n </mat-option>\n </div>\n }\n </div>\n </div>\n }\n @case ('hues') {\n <div>\n <div class=\"flex flex-row flex-wrap justify-start content-start colors\">\n @for (hue of hues; track trackByFn($index, hue)) {\n <div role=\"presentation\" class=\"cursor-pointer\"\n (click)=\"selectHue(hue)\">\n <mat-option\n class=\"relative flex w-12 h-12 p-0 pointer-events-none rounded-full bg-transparent hover:opacity-50\"\n [value]=\"selectedHue\">\n @if (selectedColor.color===selectedPalette + '-' + hue) {\n <mat-icon class=\"absolute m-3 text-white\"\n [svgIcon]=\"'heroicons_outline:check'\"></mat-icon>\n }\n <span class=\"flex w-10 h-10 m-1 rounded-full\"\n [ngClass]=\"selectedPalette + '-' + hue\"></span>\n </mat-option>\n </div>\n }\n </div>\n </div>\n }\n }\n </div>\n </div>\n </mat-select>\n</div>", styles: ["cmat-material-color-picker .mat-mdc-select-arrow-wrapper{display:none!important}\n"] }]
131
131
  }], ctorParameters: () => [], propDecorators: { colorChanged: [{
132
132
  type: Output
133
133
  }], color: [{
@@ -135,4 +135,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
135
135
  }], title: [{
136
136
  type: Input
137
137
  }] } });
138
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"material-color-picker.component.js","sourceRoot":"","sources":["../../../../../projects/cmat/components/material-color-picker/material-color-picker.component.ts","../../../../../projects/cmat/components/material-color-picker/material-color-picker.component.html"],"names":[],"mappings":"AAAA,yDAAyD;AACzD,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;AAE/H,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AAEjD,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAC;;;;;;;AAE/E,MAAM,CAAC,MAAM,yCAAyC,GAAQ;IAC1D,OAAO,EAAE,iBAAiB;IAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,gCAAgC,CAAC;IAC/D,KAAK,EAAE,IAAI;CACd,CAAC;AAeF,MAAM,OAAO,gCAAgC;IAkBzC;QACI,mBAAmB;QACnB,IAAI,CAAC,YAAY,GAAG,IAAI,YAAY,EAAE,CAAC;QACvC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;QAC3B,IAAI,CAAC,IAAI,GAAG,CAAC,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;QAClF,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,eAAe,GAAG,WAAW,CAAC;QACnC,IAAI,CAAC,IAAI,GAAG,UAAU,CAAC;QAEvB,IAAI,CAAC,YAAY,GAAG,GAAQ,EAAE,GAAG,CAAC,CAAC;QACnC,IAAI,CAAC,aAAa,GAAG,GAAQ,EAAE,GAAG,CAAC,CAAC;QAEpC,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC/B,CAAC;IAED,IAAI,KAAK;QACL,OAAO,IAAI,CAAC,MAAM,CAAC;IACvB,CAAC;IAED,IACI,KAAK,CAAC,KAAK;QACX,IAAI,CAAC,KAAK,IAAI,KAAK,KAAK,EAAE,IAAI,IAAI,CAAC,MAAM,KAAK,KAAK,EAAE;YACjD,OAAO;SACV;QAED,uDAAuD;QACvD,MAAM,UAAU,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAEpC,oDAAoD;QACpD,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QAErD,uBAAuB;QACvB,UAAU,CAAC,GAAG,EAAE,CAAC;QAEjB,0DAA0D;QAC1D,IAAI,CAAC,eAAe,GAAG,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAE5C,4BAA4B;QAC5B,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC/B,CAAC;IAED,8DAA8D;IAC9D,IAAI,KAAK;QACL,OAAO,IAAI,CAAC,MAAM,CAAC;IACvB,CAAC;IAED,IACI,KAAK,CAAC,KAAK;QACX,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACxB,CAAC;IAED,gBAAgB,CAAC,EAAO;QACpB,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;IAC3B,CAAC;IAED,iBAAiB,CAAC,EAAO;QACrB,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;IAC5B,CAAC;IAED,UAAU,CAAC,KAAU;QACjB,iBAAiB;QACjB,IAAI,CAAC,KAAK,EAAE;YACR,OAAO;SACV;QAED,gBAAgB;QAChB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACvB,CAAC;IAED,aAAa,CAAC,OAAe;QACzB,oBAAoB;QACpB,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC;QAEnB,8BAA8B;QAC9B,IAAI,CAAC,eAAe,GAAG,OAAO,CAAC;QAE/B,4BAA4B;QAC5B,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC/B,CAAC;IAED,SAAS,CAAC,GAAW;QACjB,0BAA0B;QAC1B,IAAI,CAAC,WAAW,GAAG,GAAG,CAAC;QAEvB,4BAA4B;QAC5B,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC/B,CAAC;IAED,WAAW;QACP,gCAAgC;QAChC,IAAI,CAAC,IAAI,GAAG,UAAU,CAAC;QAEvB,qCAAqC;QACrC,IAAI,CAAC,eAAe,GAAG,WAAW,CAAC;QACnC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QAEzB,4BAA4B;QAC5B,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC/B,CAAC;IAED,mBAAmB;QACf,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,aAAa,CAAC,OAAO,KAAK,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,aAAa,CAAC,GAAG,KAAK,IAAI,CAAC,WAAW,EAAE;YAC1H,OAAO;SACV;QAED,gCAAgC;QAChC,IAAI,CAAC,aAAa,GAAG;YACjB,OAAO,EAAE,IAAI,CAAC,eAAe;YAC7B,GAAG,EAAE,IAAI,CAAC,WAAW;YACrB,KAAK,EAAE,IAAI,CAAC,eAAe,GAAG,GAAG,GAAG,IAAI,CAAC,WAAW;SACvD,CAAC;QAEF,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC;QAEvC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QAE3C,4BAA4B;QAC5B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAE7C,mBAAmB;QACnB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAEhD,CAAC;IAED,gBAAgB;QACZ,IAAI,CAAC,IAAI,GAAG,UAAU,CAAC;IAC3B,CAAC;IAED,UAAU,CAAC,MAAe;QACtB,IAAI,MAAM,EAAE;YACR,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC;SACtB;IACL,CAAC;IAED,SAAS,CAAC,KAAa,EAAE,IAAS;QAC9B,OAAO,KAAK,IAAI,IAAI,CAAC;IACzB,CAAC;8GA1JQ,gCAAgC;kGAAhC,gCAAgC,gKAJ9B,CAAC,yCAAyC,CAAC,iEC5B1D,6wHAyDM,4ID3BQ,OAAO,mFAAE,eAAe,qwBAAE,aAAa,mLAAE,eAAe,2IAAE,gBAAgB,6TAAE,QAAQ,6EAAE,YAAY,qFAAE,KAAK,mHAAE,IAAI,+EAN7G,cAAc;;2FAQjB,gCAAgC;kBAZ5C,SAAS;+BACI,4BAA4B,cAG1B,cAAc,iBACX,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM,YACrC,yBAAyB,aACxB,CAAC,yCAAyC,CAAC,cAC1C,IAAI,WACP,CAAC,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,eAAe,EAAE,gBAAgB,EAAE,QAAQ,EAAE,YAAY,EAAE,KAAK,EAAE,IAAI,CAAC;wDAK1H,YAAY;sBADX,MAAM;gBAoCH,KAAK;sBADR,KAAK;gBA4BF,KAAK;sBADR,KAAK","sourcesContent":["/* eslint-disable @typescript-eslint/no-empty-function */\r\nimport { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Input, Output, ViewEncapsulation } from '@angular/core';\r\n\r\nimport { cmatAnimations } from 'cmat/animations';\r\nimport { CmatSelectedColor } from './selected-color';\r\nimport { baseColors } from './base-color';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatSelectModule } from '@angular/material/select';\r\nimport { NgClass, NgSwitch, NgSwitchCase, NgFor, NgIf } from '@angular/common';\r\n\r\nexport const CMAT_MATERIAL_COLOR_PICKER_VALUE_ACCESSOR: any = {\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: forwardRef(() => CmatMaterialColorPickerComponent),\r\n    multi: true\r\n};\r\n\r\n\r\n@Component({\r\n    selector: 'cmat-material-color-picker',\r\n    templateUrl: './material-color-picker.component.html',\r\n    styleUrls: ['./material-color-picker.component.scss'],\r\n    animations: cmatAnimations,\r\n    encapsulation: ViewEncapsulation.None,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    exportAs: 'cmatMaterialColorPicker',\r\n    providers: [CMAT_MATERIAL_COLOR_PICKER_VALUE_ACCESSOR],\r\n    standalone: true,\r\n    imports: [NgClass, MatSelectModule, MatIconModule, MatButtonModule, MatTooltipModule, NgSwitch, NgSwitchCase, NgFor, NgIf]\r\n})\r\nexport class CmatMaterialColorPickerComponent implements ControlValueAccessor {\r\n    // Color changed\r\n    @Output()\r\n    colorChanged: EventEmitter<any>;\r\n\r\n    palettes: string[];\r\n    hues: string[];\r\n    view: string;\r\n    selectedColor: CmatSelectedColor;\r\n    selectedPalette: string;\r\n    selectedHue: string;\r\n\r\n    // Private\r\n    private _color: string;\r\n    private _title: string;\r\n    private _modelChange: (value: any) => void;\r\n    private _modelTouched: (value: any) => void;\r\n\r\n    constructor() {\r\n        // Set the defaults\r\n        this.colorChanged = new EventEmitter();\r\n        this.palettes = baseColors;\r\n        this.hues = ['50', '100', '200', '300', '400', '500', '600', '700', '800', '900'];\r\n        this.selectedHue = '500';\r\n        this.selectedPalette = 'bg-indigo';\r\n        this.view = 'palettes';\r\n\r\n        this._modelChange = (): any => { };\r\n        this._modelTouched = (): any => { };\r\n\r\n        this.updateSelectedColor();\r\n    }\r\n\r\n    get color(): string {\r\n        return this._color;\r\n    }\r\n\r\n    @Input()\r\n    set color(value) {\r\n        if (!value || value === '' || this._color === value) {\r\n            return;\r\n        }\r\n\r\n        // Split the color value (bg-red-400, bg-blue-500 etc.)\r\n        const colorParts = value.split('-');\r\n\r\n        // Take the very last part as the selected hue value\r\n        this.selectedHue = colorParts[colorParts.length - 1];\r\n\r\n        // Remove the last part\r\n        colorParts.pop();\r\n\r\n        // Rejoin the remaining parts as the selected palette name\r\n        this.selectedPalette = colorParts.join('-');\r\n\r\n        // Update the selected color\r\n        this.updateSelectedColor();\r\n    }\r\n\r\n    // eslint-disable-next-line @typescript-eslint/member-ordering\r\n    get title(): string {\r\n        return this._title;\r\n    }\r\n\r\n    @Input()\r\n    set title(value) {\r\n        this._title = value;\r\n    }\r\n\r\n    registerOnChange(fn: any): void {\r\n        this._modelChange = fn;\r\n    }\r\n\r\n    registerOnTouched(fn: any): void {\r\n        this._modelTouched = fn;\r\n    }\r\n\r\n    writeValue(color: any): void {\r\n        // Return if null\r\n        if (!color) {\r\n            return;\r\n        }\r\n\r\n        // Set the color\r\n        this.color = color;\r\n    }\r\n\r\n    selectPalette(palette: string): void {\r\n        // Go to 'hues' view\r\n        this.view = 'hues';\r\n\r\n        // Update the selected palette\r\n        this.selectedPalette = palette;\r\n\r\n        // Update the selected color\r\n        this.updateSelectedColor();\r\n    }\r\n\r\n    selectHue(hue: string): void {\r\n        // Update the selected hue\r\n        this.selectedHue = hue;\r\n\r\n        // Update the selected color\r\n        this.updateSelectedColor();\r\n    }\r\n\r\n    removeColor(): void {\r\n        // Return to the 'palettes' view\r\n        this.view = 'palettes';\r\n\r\n        // Clear the selected palette and hue\r\n        this.selectedPalette = 'bg-indigo';\r\n        this.selectedHue = '500';\r\n\r\n        // Update the selected color\r\n        this.updateSelectedColor();\r\n    }\r\n\r\n    updateSelectedColor(): void {\r\n        if (this.selectedColor && this.selectedColor.palette === this.selectedPalette && this.selectedColor.hue === this.selectedHue) {\r\n            return;\r\n        }\r\n\r\n        // Set the selected color object\r\n        this.selectedColor = {\r\n            palette: this.selectedPalette,\r\n            hue: this.selectedHue,\r\n            color: this.selectedPalette + '-' + this.selectedHue\r\n        };\r\n\r\n        this._color = this.selectedColor.color;\r\n\r\n        this.colorChanged.emit(this.selectedColor);\r\n\r\n        // Mark the model as touched\r\n        this._modelTouched(this.selectedColor.color);\r\n\r\n        // Update the model\r\n        this._modelChange(this.selectedColor.color);\r\n\r\n    }\r\n\r\n    goToPalettesView(): void {\r\n        this.view = 'palettes';\r\n    }\r\n\r\n    onMenuOpen(opened: boolean): void {\r\n        if (opened) {\r\n            this.view = 'hues';\r\n        }\r\n    }\r\n\r\n    trackByFn(index: number, item: any): any {\r\n        return index || item;\r\n    }\r\n}\r\n","<div class=\"rounded\" [ngClass]=\"selectedColor.color\">\r\n    <mat-select value=\"init\" [disableOptionCentering]=\"true\" [hideSingleSelectionIndicator]=\"true\"\r\n        (openedChange)=\"onMenuOpen($event)\">\r\n        <mat-select-trigger class=\"flex p-1\">\r\n            <mat-icon [svgIcon]=\"'heroicons_outline:paint-brush'\"></mat-icon>\r\n        </mat-select-trigger>\r\n\r\n        <header [ngClass]=\"'accent'\" class=\"shadow flex flex-row content-between justify-between p-2\">\r\n            <button type=\"button\" mat-icon-button class=\"secondary-text\" [class.invisible]=\"view === 'palettes'\"\r\n                (click)=\"goToPalettesView()\" aria-label=\"调色板\">\r\n                <mat-icon svgIcon=\"mat_outline:arrow_back\"></mat-icon>\r\n            </button>\r\n            <span class=\"align-middle leading-loose text-xl font-bold\">{{title}}</span>\r\n            <button type=\"button\" mat-icon-button class=\"remove-color-button secondary-text\" (click)=\"removeColor()\"\r\n                aria-label=\"移除颜色\" matTooltip=\"移除颜色\">\r\n                <mat-icon color=\"warn\" [svgIcon]=\"'mat_outline:cleaning_services'\"></mat-icon>\r\n            </button>\r\n        </header>\r\n\r\n        <div class=\"flex flex-wrap w-60 m-2\">\r\n            <mat-option value=\"init\" class=\"hidden\">初始化</mat-option>\r\n            <div [ngSwitch]=\"view\">\r\n                <div *ngSwitchCase=\"'palettes'\">\r\n                    <div class=\"flex flex-row flex-wrap justify-start content-start colors\">\r\n                        <div role=\"presentation\" *ngFor=\"let palette of palettes;trackBy: trackByFn\"\r\n                            class=\"cursor-pointer\" (click)=\"selectPalette(palette)\">\r\n                            <mat-option\r\n                                class=\"relative flex w-12 h-12 p-0 pointer-events-none rounded-full bg-transparent hover:opacity-50\"\r\n                                [value]=\"selectedPalette\">\r\n                                <mat-icon class=\"absolute m-3 text-white\"\r\n                                    *ngIf=\"selectedColor.color===palette + '-' + selectedHue\"\r\n                                    [svgIcon]=\"'heroicons_outline:check'\"></mat-icon>\r\n                                <span class=\"flex w-10 h-10 m-1 rounded-full\"\r\n                                    [ngClass]=\"palette + '-' + selectedHue\"></span>\r\n                            </mat-option>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n                <div *ngSwitchCase=\"'hues'\">\r\n                    <div class=\"flex flex-row flex-wrap justify-start content-start colors\">\r\n                        <div role=\"presentation\" *ngFor=\"let hue of hues;trackBy: trackByFn\" class=\"cursor-pointer\"\r\n                            (click)=\"selectHue(hue)\">\r\n                            <mat-option\r\n                                class=\"relative flex w-12 h-12 p-0 pointer-events-none rounded-full bg-transparent hover:opacity-50\"\r\n                                [value]=\"selectedHue\">\r\n                                <mat-icon class=\"absolute m-3 text-white\"\r\n                                    *ngIf=\"selectedColor.color===selectedPalette + '-' + hue\"\r\n                                    [svgIcon]=\"'heroicons_outline:check'\"></mat-icon>\r\n                                <span class=\"flex w-10 h-10 m-1 rounded-full\"\r\n                                    [ngClass]=\"selectedPalette + '-' + hue\"></span>\r\n                            </mat-option>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </mat-select>\r\n</div>"]}
138
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"material-color-picker.component.js","sourceRoot":"","sources":["../../../../../projects/cmat/components/material-color-picker/material-color-picker.component.ts","../../../../../projects/cmat/components/material-color-picker/material-color-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-empty-function */\r\nimport { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Input, Output, ViewEncapsulation } from '@angular/core';\r\n\r\nimport { cmatAnimations } from 'cmat/animations';\r\nimport { CmatSelectedColor } from './selected-color';\r\nimport { baseColors } from './base-color';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatSelectModule } from '@angular/material/select';\r\nimport { NgClass } from '@angular/common';\r\n\r\nexport const CMAT_MATERIAL_COLOR_PICKER_VALUE_ACCESSOR: any = {\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: forwardRef(() => CmatMaterialColorPickerComponent),\r\n    multi: true\r\n};\r\n\r\n\r\n@Component({\r\n    selector: 'cmat-material-color-picker',\r\n    templateUrl: './material-color-picker.component.html',\r\n    styleUrls: ['./material-color-picker.component.scss'],\r\n    animations: cmatAnimations,\r\n    encapsulation: ViewEncapsulation.None,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    exportAs: 'cmatMaterialColorPicker',\r\n    providers: [CMAT_MATERIAL_COLOR_PICKER_VALUE_ACCESSOR],\r\n    standalone: true,\r\n    imports: [NgClass, MatSelectModule, MatIconModule, MatButtonModule, MatTooltipModule]\r\n})\r\nexport class CmatMaterialColorPickerComponent implements ControlValueAccessor {\r\n    // Color changed\r\n    @Output()\r\n    colorChanged: EventEmitter<any>;\r\n\r\n    palettes: string[];\r\n    hues: string[];\r\n    view: string;\r\n    selectedColor: CmatSelectedColor;\r\n    selectedPalette: string;\r\n    selectedHue: string;\r\n\r\n    // Private\r\n    private _color: string;\r\n    private _title: string;\r\n    private _modelChange: (value: any) => void;\r\n    private _modelTouched: (value: any) => void;\r\n\r\n    constructor() {\r\n        // Set the defaults\r\n        this.colorChanged = new EventEmitter();\r\n        this.palettes = baseColors;\r\n        this.hues = ['50', '100', '200', '300', '400', '500', '600', '700', '800', '900'];\r\n        this.selectedHue = '500';\r\n        this.selectedPalette = 'bg-indigo';\r\n        this.view = 'palettes';\r\n\r\n        this._modelChange = (): any => { };\r\n        this._modelTouched = (): any => { };\r\n\r\n        this.updateSelectedColor();\r\n    }\r\n\r\n    get color(): string {\r\n        return this._color;\r\n    }\r\n\r\n    @Input()\r\n    set color(value) {\r\n        if (!value || value === '' || this._color === value) {\r\n            return;\r\n        }\r\n\r\n        // Split the color value (bg-red-400, bg-blue-500 etc.)\r\n        const colorParts = value.split('-');\r\n\r\n        // Take the very last part as the selected hue value\r\n        this.selectedHue = colorParts[colorParts.length - 1];\r\n\r\n        // Remove the last part\r\n        colorParts.pop();\r\n\r\n        // Rejoin the remaining parts as the selected palette name\r\n        this.selectedPalette = colorParts.join('-');\r\n\r\n        // Update the selected color\r\n        this.updateSelectedColor();\r\n    }\r\n\r\n    // eslint-disable-next-line @typescript-eslint/member-ordering\r\n    get title(): string {\r\n        return this._title;\r\n    }\r\n\r\n    @Input()\r\n    set title(value) {\r\n        this._title = value;\r\n    }\r\n\r\n    registerOnChange(fn: any): void {\r\n        this._modelChange = fn;\r\n    }\r\n\r\n    registerOnTouched(fn: any): void {\r\n        this._modelTouched = fn;\r\n    }\r\n\r\n    writeValue(color: any): void {\r\n        // Return if null\r\n        if (!color) {\r\n            return;\r\n        }\r\n\r\n        // Set the color\r\n        this.color = color;\r\n    }\r\n\r\n    selectPalette(palette: string): void {\r\n        // Go to 'hues' view\r\n        this.view = 'hues';\r\n\r\n        // Update the selected palette\r\n        this.selectedPalette = palette;\r\n\r\n        // Update the selected color\r\n        this.updateSelectedColor();\r\n    }\r\n\r\n    selectHue(hue: string): void {\r\n        // Update the selected hue\r\n        this.selectedHue = hue;\r\n\r\n        // Update the selected color\r\n        this.updateSelectedColor();\r\n    }\r\n\r\n    removeColor(): void {\r\n        // Return to the 'palettes' view\r\n        this.view = 'palettes';\r\n\r\n        // Clear the selected palette and hue\r\n        this.selectedPalette = 'bg-indigo';\r\n        this.selectedHue = '500';\r\n\r\n        // Update the selected color\r\n        this.updateSelectedColor();\r\n    }\r\n\r\n    updateSelectedColor(): void {\r\n        if (this.selectedColor && this.selectedColor.palette === this.selectedPalette && this.selectedColor.hue === this.selectedHue) {\r\n            return;\r\n        }\r\n\r\n        // Set the selected color object\r\n        this.selectedColor = {\r\n            palette: this.selectedPalette,\r\n            hue: this.selectedHue,\r\n            color: this.selectedPalette + '-' + this.selectedHue\r\n        };\r\n\r\n        this._color = this.selectedColor.color;\r\n\r\n        this.colorChanged.emit(this.selectedColor);\r\n\r\n        // Mark the model as touched\r\n        this._modelTouched(this.selectedColor.color);\r\n\r\n        // Update the model\r\n        this._modelChange(this.selectedColor.color);\r\n\r\n    }\r\n\r\n    goToPalettesView(): void {\r\n        this.view = 'palettes';\r\n    }\r\n\r\n    onMenuOpen(opened: boolean): void {\r\n        if (opened) {\r\n            this.view = 'hues';\r\n        }\r\n    }\r\n\r\n    trackByFn(index: number, item: any): any {\r\n        return index || item;\r\n    }\r\n}\r\n","<div class=\"rounded\" [ngClass]=\"selectedColor.color\">\n  <mat-select value=\"init\" [disableOptionCentering]=\"true\" [hideSingleSelectionIndicator]=\"true\"\n    (openedChange)=\"onMenuOpen($event)\" panelClass=\"min-w-64\">\n    <mat-select-trigger class=\"flex p-1\">\n      <mat-icon [svgIcon]=\"'heroicons_outline:paint-brush'\"></mat-icon>\n    </mat-select-trigger>\n\n    <header [ngClass]=\"'accent'\" class=\"shadow flex flex-row content-between justify-between p-2\">\n      <button type=\"button\" mat-icon-button class=\"secondary-text\" [class.invisible]=\"view === 'palettes'\"\n        (click)=\"goToPalettesView()\" aria-label=\"调色板\">\n        <mat-icon svgIcon=\"mat_outline:arrow_back\"></mat-icon>\n      </button>\n      <span class=\"align-middle leading-loose text-xl font-bold\">{{title}}</span>\n      <button type=\"button\" mat-icon-button class=\"remove-color-button secondary-text\" (click)=\"removeColor()\"\n        aria-label=\"移除颜色\" matTooltip=\"移除颜色\">\n        <mat-icon color=\"warn\" [svgIcon]=\"'mat_outline:cleaning_services'\"></mat-icon>\n      </button>\n    </header>\n\n    <div class=\"flex flex-wrap w-60 m-2\">\n      <mat-option value=\"init\" class=\"hidden\">初始化</mat-option>\n      <div>\n        @switch (view) {\n          @case ('palettes') {\n            <div>\n              <div class=\"flex flex-row flex-wrap justify-start content-start colors\">\n                @for (palette of palettes; track trackByFn($index, palette)) {\n                  <div role=\"presentation\"\n                    class=\"cursor-pointer\" (click)=\"selectPalette(palette)\">\n                    <mat-option\n                      class=\"relative flex w-12 h-12 p-0 pointer-events-none rounded-full bg-transparent hover:opacity-50\"\n                      [value]=\"selectedPalette\">\n                      @if (selectedColor.color===palette + '-' + selectedHue) {\n                        <mat-icon class=\"absolute m-3 text-white\"\n                        [svgIcon]=\"'heroicons_outline:check'\"></mat-icon>\n                      }\n                      <span class=\"flex w-10 h-10 m-1 rounded-full\"\n                      [ngClass]=\"palette + '-' + selectedHue\"></span>\n                    </mat-option>\n                  </div>\n                }\n              </div>\n            </div>\n          }\n          @case ('hues') {\n            <div>\n              <div class=\"flex flex-row flex-wrap justify-start content-start colors\">\n                @for (hue of hues; track trackByFn($index, hue)) {\n                  <div role=\"presentation\" class=\"cursor-pointer\"\n                    (click)=\"selectHue(hue)\">\n                    <mat-option\n                      class=\"relative flex w-12 h-12 p-0 pointer-events-none rounded-full bg-transparent hover:opacity-50\"\n                      [value]=\"selectedHue\">\n                      @if (selectedColor.color===selectedPalette + '-' + hue) {\n                        <mat-icon class=\"absolute m-3 text-white\"\n                        [svgIcon]=\"'heroicons_outline:check'\"></mat-icon>\n                      }\n                      <span class=\"flex w-10 h-10 m-1 rounded-full\"\n                      [ngClass]=\"selectedPalette + '-' + hue\"></span>\n                    </mat-option>\n                  </div>\n                }\n              </div>\n            </div>\n          }\n        }\n      </div>\n    </div>\n  </mat-select>\n</div>"]}
@@ -1,5 +1,4 @@
1
1
  import { ChangeDetectionStrategy, Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation } from '@angular/core';
2
- import { NgIf, NgFor } from '@angular/common';
3
2
  import * as i0 from "@angular/core";
4
3
  /**
5
4
  * An internal class that represents the data corresponding to a single calendar cell.
@@ -49,12 +48,12 @@ export class CmatDatetimepickerCalendarBodyComponent {
49
48
  trackByFn(index, item) {
50
49
  return item.value || index;
51
50
  }
52
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: CmatDatetimepickerCalendarBodyComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
53
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.0", type: CmatDatetimepickerCalendarBodyComponent, isStandalone: true, selector: "[cmat-datetimepicker-calendar-body]", inputs: { label: "label", rows: "rows", todayValue: "todayValue", selectedValue: "selectedValue", labelMinRequiredCells: "labelMinRequiredCells", numCols: "numCols", allowDisabledSelection: "allowDisabledSelection", activeCell: "activeCell" }, outputs: { selectedValueChange: "selectedValueChange" }, host: { properties: { "class": "this.class" } }, exportAs: ["cmatDatetimepickerCalendarBody"], ngImport: i0, template: "<!--\r\n If there's not enough space in the first row, create a separate label row. We mark this row as\r\n aria-hidden because we don't want it to be read out as one of the weeks in the month.\r\n-->\r\n<tr *ngIf=\"_firstRowOffset < labelMinRequiredCells\" aria-hidden=\"true\">\r\n <td [attr.colspan]=\"numCols\" class=\"cmat-datetimepicker-calendar-body-label\">{{ label }}</td>\r\n</tr>\r\n\r\n<!-- Create the first row separately so we can include a special spacer cell. -->\r\n<tr *ngFor=\"let row of rows; let rowIndex = index\" role=\"row\">\r\n <!--\r\n We mark this cell as aria-hidden so it doesn't get read out as one of the days in the week.\r\n -->\r\n <td *ngIf=\"rowIndex === 0 && _firstRowOffset\" [attr.colspan]=\"_firstRowOffset\" aria-hidden=\"true\"\r\n class=\"cmat-datetimepicker-calendar-body-label\">\r\n {{ _firstRowOffset >= labelMinRequiredCells ? label : '' }}\r\n </td>\r\n <td role=\"presentation\" (click)=\"cellClicked(item)\"\r\n *ngFor=\"let item of row; let colIndex = index;trackBy: trackByFn\" [attr.aria-disabled]=\"!item.enabled || null\"\r\n [attr.aria-label]=\"item.ariaLabel\"\r\n [class.cmat-datetimepicker-calendar-body-active]=\"isActiveCell(rowIndex, colIndex)\"\r\n [class.cmat-datetimepicker-calendar-body-disabled]=\"!item.enabled\"\r\n class=\"cmat-datetimepicker-calendar-body-cell\" role=\"button\">\r\n <div [attr.aria-selected]=\"selectedValue === item.value\"\r\n [class.cmat-datetimepicker-calendar-body-selected]=\"selectedValue === item.value\"\r\n [class.cmat-datetimepicker-calendar-body-today]=\"todayValue === item.value\"\r\n class=\"cmat-datetimepicker-calendar-body-cell-content\">\r\n {{ item.displayValue }}\r\n </div>\r\n </td>\r\n</tr>", styles: [".cmat-datetimepicker-calendar-body{min-width:224px}.cmat-datetimepicker-calendar-body-label{height:0;line-height:0;text-align:left;padding:7.1428571429% 4.7142857143%}[dir=rtl] .cmat-datetimepicker-calendar-body-label{text-align:right}.cmat-datetimepicker-calendar-body-cell{position:relative;width:14.2857142857%;height:0;line-height:0;padding:7.1428571429% 0;text-align:center;outline:none;cursor:pointer}.cmat-datetimepicker-calendar-body-disabled{cursor:default;pointer-events:none}.cmat-datetimepicker-calendar-body-cell-content{position:absolute;top:5%;left:5%;display:flex;align-items:center;justify-content:center;box-sizing:border-box;width:90%;height:90%;border:1px solid transparent;border-radius:999px}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
51
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CmatDatetimepickerCalendarBodyComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
52
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.4", type: CmatDatetimepickerCalendarBodyComponent, isStandalone: true, selector: "[cmat-datetimepicker-calendar-body]", inputs: { label: "label", rows: "rows", todayValue: "todayValue", selectedValue: "selectedValue", labelMinRequiredCells: "labelMinRequiredCells", numCols: "numCols", allowDisabledSelection: "allowDisabledSelection", activeCell: "activeCell" }, outputs: { selectedValueChange: "selectedValueChange" }, host: { properties: { "class": "this.class" } }, exportAs: ["cmatDatetimepickerCalendarBody"], ngImport: i0, template: "<!--\nIf there's not enough space in the first row, create a separate label row. We mark this row as\naria-hidden because we don't want it to be read out as one of the weeks in the month.\n-->\n@if (_firstRowOffset < labelMinRequiredCells) {\n <tr aria-hidden=\"true\">\n <td [attr.colspan]=\"numCols\" class=\"cmat-datetimepicker-calendar-body-label\">{{ label }}</td>\n </tr>\n}\n\n<!-- Create the first row separately so we can include a special spacer cell. -->\n@for (row of rows; track row; let rowIndex = $index) {\n <tr role=\"row\">\n <!--\n We mark this cell as aria-hidden so it doesn't get read out as one of the days in the week.\n -->\n @if (rowIndex === 0 && _firstRowOffset) {\n <td [attr.colspan]=\"_firstRowOffset\" aria-hidden=\"true\"\n class=\"cmat-datetimepicker-calendar-body-label\">\n {{ _firstRowOffset >= labelMinRequiredCells ? label : '' }}\n </td>\n }\n @for (item of row; track trackByFn(colIndex, item); let colIndex = $index) {\n <td role=\"presentation\" (click)=\"cellClicked(item)\"\n [attr.aria-disabled]=\"!item.enabled || null\"\n [attr.aria-label]=\"item.ariaLabel\"\n [class.cmat-datetimepicker-calendar-body-active]=\"isActiveCell(rowIndex, colIndex)\"\n [class.cmat-datetimepicker-calendar-body-disabled]=\"!item.enabled\"\n class=\"cmat-datetimepicker-calendar-body-cell\" role=\"button\">\n <div [attr.aria-selected]=\"selectedValue === item.value\"\n [class.cmat-datetimepicker-calendar-body-selected]=\"selectedValue === item.value\"\n [class.cmat-datetimepicker-calendar-body-today]=\"todayValue === item.value\"\n class=\"cmat-datetimepicker-calendar-body-cell-content\">\n {{ item.displayValue }}\n </div>\n </td>\n }\n </tr>\n}", styles: [".cmat-datetimepicker-calendar-body{min-width:224px}.cmat-datetimepicker-calendar-body-label{height:0;line-height:0;text-align:left;padding:7.1428571429% 4.7142857143%}[dir=rtl] .cmat-datetimepicker-calendar-body-label{text-align:right}.cmat-datetimepicker-calendar-body-cell{position:relative;width:14.2857142857%;height:0;line-height:0;padding:7.1428571429% 0;text-align:center;outline:none;cursor:pointer}.cmat-datetimepicker-calendar-body-disabled{cursor:default;pointer-events:none}.cmat-datetimepicker-calendar-body-cell-content{position:absolute;top:5%;left:5%;display:flex;align-items:center;justify-content:center;box-sizing:border-box;width:90%;height:90%;border:1px solid transparent;border-radius:999px}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
54
53
  }
55
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: CmatDatetimepickerCalendarBodyComponent, decorators: [{
54
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CmatDatetimepickerCalendarBodyComponent, decorators: [{
56
55
  type: Component,
57
- args: [{ selector: '[cmat-datetimepicker-calendar-body]', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, exportAs: 'cmatDatetimepickerCalendarBody', standalone: true, imports: [NgIf, NgFor], template: "<!--\r\n If there's not enough space in the first row, create a separate label row. We mark this row as\r\n aria-hidden because we don't want it to be read out as one of the weeks in the month.\r\n-->\r\n<tr *ngIf=\"_firstRowOffset < labelMinRequiredCells\" aria-hidden=\"true\">\r\n <td [attr.colspan]=\"numCols\" class=\"cmat-datetimepicker-calendar-body-label\">{{ label }}</td>\r\n</tr>\r\n\r\n<!-- Create the first row separately so we can include a special spacer cell. -->\r\n<tr *ngFor=\"let row of rows; let rowIndex = index\" role=\"row\">\r\n <!--\r\n We mark this cell as aria-hidden so it doesn't get read out as one of the days in the week.\r\n -->\r\n <td *ngIf=\"rowIndex === 0 && _firstRowOffset\" [attr.colspan]=\"_firstRowOffset\" aria-hidden=\"true\"\r\n class=\"cmat-datetimepicker-calendar-body-label\">\r\n {{ _firstRowOffset >= labelMinRequiredCells ? label : '' }}\r\n </td>\r\n <td role=\"presentation\" (click)=\"cellClicked(item)\"\r\n *ngFor=\"let item of row; let colIndex = index;trackBy: trackByFn\" [attr.aria-disabled]=\"!item.enabled || null\"\r\n [attr.aria-label]=\"item.ariaLabel\"\r\n [class.cmat-datetimepicker-calendar-body-active]=\"isActiveCell(rowIndex, colIndex)\"\r\n [class.cmat-datetimepicker-calendar-body-disabled]=\"!item.enabled\"\r\n class=\"cmat-datetimepicker-calendar-body-cell\" role=\"button\">\r\n <div [attr.aria-selected]=\"selectedValue === item.value\"\r\n [class.cmat-datetimepicker-calendar-body-selected]=\"selectedValue === item.value\"\r\n [class.cmat-datetimepicker-calendar-body-today]=\"todayValue === item.value\"\r\n class=\"cmat-datetimepicker-calendar-body-cell-content\">\r\n {{ item.displayValue }}\r\n </div>\r\n </td>\r\n</tr>", styles: [".cmat-datetimepicker-calendar-body{min-width:224px}.cmat-datetimepicker-calendar-body-label{height:0;line-height:0;text-align:left;padding:7.1428571429% 4.7142857143%}[dir=rtl] .cmat-datetimepicker-calendar-body-label{text-align:right}.cmat-datetimepicker-calendar-body-cell{position:relative;width:14.2857142857%;height:0;line-height:0;padding:7.1428571429% 0;text-align:center;outline:none;cursor:pointer}.cmat-datetimepicker-calendar-body-disabled{cursor:default;pointer-events:none}.cmat-datetimepicker-calendar-body-cell-content{position:absolute;top:5%;left:5%;display:flex;align-items:center;justify-content:center;box-sizing:border-box;width:90%;height:90%;border:1px solid transparent;border-radius:999px}\n"] }]
56
+ args: [{ selector: '[cmat-datetimepicker-calendar-body]', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, exportAs: 'cmatDatetimepickerCalendarBody', standalone: true, imports: [], template: "<!--\nIf there's not enough space in the first row, create a separate label row. We mark this row as\naria-hidden because we don't want it to be read out as one of the weeks in the month.\n-->\n@if (_firstRowOffset < labelMinRequiredCells) {\n <tr aria-hidden=\"true\">\n <td [attr.colspan]=\"numCols\" class=\"cmat-datetimepicker-calendar-body-label\">{{ label }}</td>\n </tr>\n}\n\n<!-- Create the first row separately so we can include a special spacer cell. -->\n@for (row of rows; track row; let rowIndex = $index) {\n <tr role=\"row\">\n <!--\n We mark this cell as aria-hidden so it doesn't get read out as one of the days in the week.\n -->\n @if (rowIndex === 0 && _firstRowOffset) {\n <td [attr.colspan]=\"_firstRowOffset\" aria-hidden=\"true\"\n class=\"cmat-datetimepicker-calendar-body-label\">\n {{ _firstRowOffset >= labelMinRequiredCells ? label : '' }}\n </td>\n }\n @for (item of row; track trackByFn(colIndex, item); let colIndex = $index) {\n <td role=\"presentation\" (click)=\"cellClicked(item)\"\n [attr.aria-disabled]=\"!item.enabled || null\"\n [attr.aria-label]=\"item.ariaLabel\"\n [class.cmat-datetimepicker-calendar-body-active]=\"isActiveCell(rowIndex, colIndex)\"\n [class.cmat-datetimepicker-calendar-body-disabled]=\"!item.enabled\"\n class=\"cmat-datetimepicker-calendar-body-cell\" role=\"button\">\n <div [attr.aria-selected]=\"selectedValue === item.value\"\n [class.cmat-datetimepicker-calendar-body-selected]=\"selectedValue === item.value\"\n [class.cmat-datetimepicker-calendar-body-today]=\"todayValue === item.value\"\n class=\"cmat-datetimepicker-calendar-body-cell-content\">\n {{ item.displayValue }}\n </div>\n </td>\n }\n </tr>\n}", styles: [".cmat-datetimepicker-calendar-body{min-width:224px}.cmat-datetimepicker-calendar-body-label{height:0;line-height:0;text-align:left;padding:7.1428571429% 4.7142857143%}[dir=rtl] .cmat-datetimepicker-calendar-body-label{text-align:right}.cmat-datetimepicker-calendar-body-cell{position:relative;width:14.2857142857%;height:0;line-height:0;padding:7.1428571429% 0;text-align:center;outline:none;cursor:pointer}.cmat-datetimepicker-calendar-body-disabled{cursor:default;pointer-events:none}.cmat-datetimepicker-calendar-body-cell-content{position:absolute;top:5%;left:5%;display:flex;align-items:center;justify-content:center;box-sizing:border-box;width:90%;height:90%;border:1px solid transparent;border-radius:999px}\n"] }]
58
57
  }], propDecorators: { label: [{
59
58
  type: Input
60
59
  }], rows: [{
@@ -77,4 +76,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
77
76
  type: HostBinding,
78
77
  args: ['class']
79
78
  }] } });
80
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-body.js","sourceRoot":"","sources":["../../../../../projects/cmat/components/material-datetimepicker/calendar-body.ts","../../../../../projects/cmat/components/material-datetimepicker/calendar-body.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;AAChI,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;;AAE9C;;GAEG;AACH,MAAM,OAAO,uCAAuC;IAChD,YAAmB,KAAa,EACrB,YAAoB,EACpB,SAAiB,EACjB,OAAgB;QAHR,UAAK,GAAL,KAAK,CAAQ;QACrB,iBAAY,GAAZ,YAAY,CAAQ;QACpB,cAAS,GAAT,SAAS,CAAQ;QACjB,YAAO,GAAP,OAAO,CAAS;IAC3B,CAAC;CACJ;AAED;;GAEG;AAWH,MAAM,OAAO,uCAAuC;IAVpD;QA0BI,0CAA0C;QACjC,YAAO,GAAG,CAAC,CAAC;QAErB,oDAAoD;QAC3C,2BAAsB,GAAG,KAAK,CAAC;QAExC,uDAAuD;QAC9C,eAAU,GAAG,CAAC,CAAC;QAExB,0CAA0C;QAChC,wBAAmB,GAAG,IAAI,YAAY,EAAU,CAAC;QAErC,UAAK,GAAG,mCAAmC,CAAC;KA6BrE;IA3BG,2EAA2E;IAC3E,IAAI,eAAe;QACf,OAAO,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;YACzD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/C,CAAC;IAED,WAAW,CAAC,IAA6C;QACrD,IAAI,CAAC,IAAI,CAAC,sBAAsB,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YAC/C,OAAO;SACV;QACD,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9C,CAAC;IAED,YAAY,CAAC,QAAgB,EAAE,QAAgB;QAC3C,IAAI,UAAU,GAAG,QAAQ,GAAG,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC;QAEpD,sEAAsE;QACtE,IAAI,QAAQ,EAAE;YACV,UAAU,IAAI,IAAI,CAAC,eAAe,CAAC;SACtC;QAED,OAAO,UAAU,KAAK,IAAI,CAAC,UAAU,CAAC;IAC1C,CAAC;IAED,SAAS,CAAC,KAAa,EAAE,IAA6C;QAClE,OAAO,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC;IAC/B,CAAC;8GAxDQ,uCAAuC;kGAAvC,uCAAuC,2eC3BpD,kzDA8BK,swBDLS,IAAI,6FAAE,KAAK;;2FAEZ,uCAAuC;kBAVnD,SAAS;+BACI,qCAAqC,iBAGhC,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM,YACrC,gCAAgC,cAC9B,IAAI,WACP,CAAC,IAAI,EAAE,KAAK,CAAC;8BAIb,KAAK;sBAAb,KAAK;gBAGG,IAAI;sBAAZ,KAAK;gBAGG,UAAU;sBAAlB,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBAGG,qBAAqB;sBAA7B,KAAK;gBAGG,OAAO;sBAAf,KAAK;gBAGG,sBAAsB;sBAA9B,KAAK;gBAGG,UAAU;sBAAlB,KAAK;gBAGI,mBAAmB;sBAA5B,MAAM;gBAEe,KAAK;sBAA1B,WAAW;uBAAC,OAAO","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation } from '@angular/core';\r\nimport { NgIf, NgFor } from '@angular/common';\r\n\r\n/**\r\n * An internal class that represents the data corresponding to a single calendar cell.\r\n */\r\nexport class CmatDatetimepickerCalendarCellComponent {\r\n    constructor(public value: number,\r\n        public displayValue: string,\r\n        public ariaLabel: string,\r\n        public enabled: boolean) {\r\n    }\r\n}\r\n\r\n/**\r\n * An internal component used to display calendar data in a table.\r\n */\r\n@Component({\r\n    selector: '[cmat-datetimepicker-calendar-body]',\r\n    templateUrl: 'calendar-body.html',\r\n    styleUrls: ['calendar-body.scss'],\r\n    encapsulation: ViewEncapsulation.None,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    exportAs: 'cmatDatetimepickerCalendarBody',\r\n    standalone: true,\r\n    imports: [NgIf, NgFor]\r\n})\r\nexport class CmatDatetimepickerCalendarBodyComponent {\r\n    /** The label for the table. (e.g. \"Jan 2017\"). */\r\n    @Input() label: string;\r\n\r\n    /** The cells to display in the table. */\r\n    @Input() rows: CmatDatetimepickerCalendarCellComponent[][];\r\n\r\n    /** The value in the table that corresponds to today. */\r\n    @Input() todayValue: number | null;\r\n\r\n    /** The value in the table that is currently selected. */\r\n    @Input() selectedValue: number | null;\r\n\r\n    /** The minimum number of free cells needed to fit the label in the first row. */\r\n    @Input() labelMinRequiredCells: number;\r\n\r\n    /** The number of columns in the table. */\r\n    @Input() numCols = 7;\r\n\r\n    /** Whether to allow selection of disabled cells. */\r\n    @Input() allowDisabledSelection = false;\r\n\r\n    /** The cell number of the active cell in the table. */\r\n    @Input() activeCell = 0;\r\n\r\n    /** Emits when a new value is selected. */\r\n    @Output() selectedValueChange = new EventEmitter<number>();\r\n\r\n    @HostBinding('class') class = 'cmat-datetimepicker-calendar-body';\r\n\r\n    /** The number of blank cells to put at the beginning for the first row. */\r\n    get _firstRowOffset(): number {\r\n        return this.rows && this.rows.length && this.rows[0].length ?\r\n            this.numCols - this.rows[0].length : 0;\r\n    }\r\n\r\n    cellClicked(cell: CmatDatetimepickerCalendarCellComponent): void {\r\n        if (!this.allowDisabledSelection && !cell.enabled) {\r\n            return;\r\n        }\r\n        this.selectedValueChange.emit(cell.value);\r\n    }\r\n\r\n    isActiveCell(rowIndex: number, colIndex: number): boolean {\r\n        let cellNumber = rowIndex * this.numCols + colIndex;\r\n\r\n        // Account for the fact that the first row may not have as many cells.\r\n        if (rowIndex) {\r\n            cellNumber -= this._firstRowOffset;\r\n        }\r\n\r\n        return cellNumber === this.activeCell;\r\n    }\r\n\r\n    trackByFn(index: number, item: CmatDatetimepickerCalendarCellComponent): any {\r\n        return item.value || index;\r\n    }\r\n}\r\n","<!--\r\n  If there's not enough space in the first row, create a separate label row. We mark this row as\r\n  aria-hidden because we don't want it to be read out as one of the weeks in the month.\r\n-->\r\n<tr *ngIf=\"_firstRowOffset < labelMinRequiredCells\" aria-hidden=\"true\">\r\n    <td [attr.colspan]=\"numCols\" class=\"cmat-datetimepicker-calendar-body-label\">{{ label }}</td>\r\n</tr>\r\n\r\n<!-- Create the first row separately so we can include a special spacer cell. -->\r\n<tr *ngFor=\"let row of rows; let rowIndex = index\" role=\"row\">\r\n    <!--\r\n      We mark this cell as aria-hidden so it doesn't get read out as one of the days in the week.\r\n    -->\r\n    <td *ngIf=\"rowIndex === 0 && _firstRowOffset\" [attr.colspan]=\"_firstRowOffset\" aria-hidden=\"true\"\r\n        class=\"cmat-datetimepicker-calendar-body-label\">\r\n        {{ _firstRowOffset >= labelMinRequiredCells ? label : '' }}\r\n    </td>\r\n    <td role=\"presentation\" (click)=\"cellClicked(item)\"\r\n        *ngFor=\"let item of row; let colIndex = index;trackBy: trackByFn\" [attr.aria-disabled]=\"!item.enabled || null\"\r\n        [attr.aria-label]=\"item.ariaLabel\"\r\n        [class.cmat-datetimepicker-calendar-body-active]=\"isActiveCell(rowIndex, colIndex)\"\r\n        [class.cmat-datetimepicker-calendar-body-disabled]=\"!item.enabled\"\r\n        class=\"cmat-datetimepicker-calendar-body-cell\" role=\"button\">\r\n        <div [attr.aria-selected]=\"selectedValue === item.value\"\r\n            [class.cmat-datetimepicker-calendar-body-selected]=\"selectedValue === item.value\"\r\n            [class.cmat-datetimepicker-calendar-body-today]=\"todayValue === item.value\"\r\n            class=\"cmat-datetimepicker-calendar-body-cell-content\">\r\n            {{ item.displayValue }}\r\n        </div>\r\n    </td>\r\n</tr>"]}
79
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-body.js","sourceRoot":"","sources":["../../../../../projects/cmat/components/material-datetimepicker/calendar-body.ts","../../../../../projects/cmat/components/material-datetimepicker/calendar-body.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;;AAGhI;;GAEG;AACH,MAAM,OAAO,uCAAuC;IAChD,YAAmB,KAAa,EACrB,YAAoB,EACpB,SAAiB,EACjB,OAAgB;QAHR,UAAK,GAAL,KAAK,CAAQ;QACrB,iBAAY,GAAZ,YAAY,CAAQ;QACpB,cAAS,GAAT,SAAS,CAAQ;QACjB,YAAO,GAAP,OAAO,CAAS;IAC3B,CAAC;CACJ;AAED;;GAEG;AAWH,MAAM,OAAO,uCAAuC;IAVpD;QA0BI,0CAA0C;QACjC,YAAO,GAAG,CAAC,CAAC;QAErB,oDAAoD;QAC3C,2BAAsB,GAAG,KAAK,CAAC;QAExC,uDAAuD;QAC9C,eAAU,GAAG,CAAC,CAAC;QAExB,0CAA0C;QAChC,wBAAmB,GAAG,IAAI,YAAY,EAAU,CAAC;QAErC,UAAK,GAAG,mCAAmC,CAAC;KA6BrE;IA3BG,2EAA2E;IAC3E,IAAI,eAAe;QACf,OAAO,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;YACzD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/C,CAAC;IAED,WAAW,CAAC,IAA6C;QACrD,IAAI,CAAC,IAAI,CAAC,sBAAsB,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YAC/C,OAAO;SACV;QACD,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9C,CAAC;IAED,YAAY,CAAC,QAAgB,EAAE,QAAgB;QAC3C,IAAI,UAAU,GAAG,QAAQ,GAAG,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC;QAEpD,sEAAsE;QACtE,IAAI,QAAQ,EAAE;YACV,UAAU,IAAI,IAAI,CAAC,eAAe,CAAC;SACtC;QAED,OAAO,UAAU,KAAK,IAAI,CAAC,UAAU,CAAC;IAC1C,CAAC;IAED,SAAS,CAAC,KAAa,EAAE,IAA6C;QAClE,OAAO,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC;IAC/B,CAAC;8GAxDQ,uCAAuC;kGAAvC,uCAAuC,2eC3BpD,myDAsCC;;2FDXY,uCAAuC;kBAVnD,SAAS;+BACI,qCAAqC,iBAGhC,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM,YACrC,gCAAgC,cAC9B,IAAI,WACP,EAAE;8BAIF,KAAK;sBAAb,KAAK;gBAGG,IAAI;sBAAZ,KAAK;gBAGG,UAAU;sBAAlB,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBAGG,qBAAqB;sBAA7B,KAAK;gBAGG,OAAO;sBAAf,KAAK;gBAGG,sBAAsB;sBAA9B,KAAK;gBAGG,UAAU;sBAAlB,KAAK;gBAGI,mBAAmB;sBAA5B,MAAM;gBAEe,KAAK;sBAA1B,WAAW;uBAAC,OAAO","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation } from '@angular/core';\r\n\r\n\r\n/**\r\n * An internal class that represents the data corresponding to a single calendar cell.\r\n */\r\nexport class CmatDatetimepickerCalendarCellComponent {\r\n    constructor(public value: number,\r\n        public displayValue: string,\r\n        public ariaLabel: string,\r\n        public enabled: boolean) {\r\n    }\r\n}\r\n\r\n/**\r\n * An internal component used to display calendar data in a table.\r\n */\r\n@Component({\r\n    selector: '[cmat-datetimepicker-calendar-body]',\r\n    templateUrl: 'calendar-body.html',\r\n    styleUrls: ['calendar-body.scss'],\r\n    encapsulation: ViewEncapsulation.None,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    exportAs: 'cmatDatetimepickerCalendarBody',\r\n    standalone: true,\r\n    imports: []\r\n})\r\nexport class CmatDatetimepickerCalendarBodyComponent {\r\n    /** The label for the table. (e.g. \"Jan 2017\"). */\r\n    @Input() label: string;\r\n\r\n    /** The cells to display in the table. */\r\n    @Input() rows: CmatDatetimepickerCalendarCellComponent[][];\r\n\r\n    /** The value in the table that corresponds to today. */\r\n    @Input() todayValue: number | null;\r\n\r\n    /** The value in the table that is currently selected. */\r\n    @Input() selectedValue: number | null;\r\n\r\n    /** The minimum number of free cells needed to fit the label in the first row. */\r\n    @Input() labelMinRequiredCells: number;\r\n\r\n    /** The number of columns in the table. */\r\n    @Input() numCols = 7;\r\n\r\n    /** Whether to allow selection of disabled cells. */\r\n    @Input() allowDisabledSelection = false;\r\n\r\n    /** The cell number of the active cell in the table. */\r\n    @Input() activeCell = 0;\r\n\r\n    /** Emits when a new value is selected. */\r\n    @Output() selectedValueChange = new EventEmitter<number>();\r\n\r\n    @HostBinding('class') class = 'cmat-datetimepicker-calendar-body';\r\n\r\n    /** The number of blank cells to put at the beginning for the first row. */\r\n    get _firstRowOffset(): number {\r\n        return this.rows && this.rows.length && this.rows[0].length ?\r\n            this.numCols - this.rows[0].length : 0;\r\n    }\r\n\r\n    cellClicked(cell: CmatDatetimepickerCalendarCellComponent): void {\r\n        if (!this.allowDisabledSelection && !cell.enabled) {\r\n            return;\r\n        }\r\n        this.selectedValueChange.emit(cell.value);\r\n    }\r\n\r\n    isActiveCell(rowIndex: number, colIndex: number): boolean {\r\n        let cellNumber = rowIndex * this.numCols + colIndex;\r\n\r\n        // Account for the fact that the first row may not have as many cells.\r\n        if (rowIndex) {\r\n            cellNumber -= this._firstRowOffset;\r\n        }\r\n\r\n        return cellNumber === this.activeCell;\r\n    }\r\n\r\n    trackByFn(index: number, item: CmatDatetimepickerCalendarCellComponent): any {\r\n        return item.value || index;\r\n    }\r\n}\r\n","<!--\nIf there's not enough space in the first row, create a separate label row. We mark this row as\naria-hidden because we don't want it to be read out as one of the weeks in the month.\n-->\n@if (_firstRowOffset < labelMinRequiredCells) {\n  <tr aria-hidden=\"true\">\n    <td [attr.colspan]=\"numCols\" class=\"cmat-datetimepicker-calendar-body-label\">{{ label }}</td>\n  </tr>\n}\n\n<!-- Create the first row separately so we can include a special spacer cell. -->\n@for (row of rows; track row; let rowIndex = $index) {\n  <tr role=\"row\">\n    <!--\n    We mark this cell as aria-hidden so it doesn't get read out as one of the days in the week.\n    -->\n    @if (rowIndex === 0 && _firstRowOffset) {\n      <td [attr.colspan]=\"_firstRowOffset\" aria-hidden=\"true\"\n        class=\"cmat-datetimepicker-calendar-body-label\">\n        {{ _firstRowOffset >= labelMinRequiredCells ? label : '' }}\n      </td>\n    }\n    @for (item of row; track trackByFn(colIndex, item); let colIndex = $index) {\n      <td role=\"presentation\" (click)=\"cellClicked(item)\"\n        [attr.aria-disabled]=\"!item.enabled || null\"\n        [attr.aria-label]=\"item.ariaLabel\"\n        [class.cmat-datetimepicker-calendar-body-active]=\"isActiveCell(rowIndex, colIndex)\"\n        [class.cmat-datetimepicker-calendar-body-disabled]=\"!item.enabled\"\n        class=\"cmat-datetimepicker-calendar-body-cell\" role=\"button\">\n        <div [attr.aria-selected]=\"selectedValue === item.value\"\n          [class.cmat-datetimepicker-calendar-body-selected]=\"selectedValue === item.value\"\n          [class.cmat-datetimepicker-calendar-body-today]=\"todayValue === item.value\"\n          class=\"cmat-datetimepicker-calendar-body-cell-content\">\n          {{ item.displayValue }}\n        </div>\n      </td>\n    }\n  </tr>\n}"]}