@sd-angular/core 19.0.0-beta.7 → 19.0.0-beta.71

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (237) hide show
  1. package/README.md +686 -33
  2. package/assets/scss/ckeditor5.scss +61 -4
  3. package/assets/scss/core/bootstrap.scss +17 -0
  4. package/assets/scss/core/form.scss +32 -6
  5. package/assets/scss/core/grid.scss +40 -0
  6. package/assets/scss/sd-core.scss +1 -0
  7. package/assets/scss/themes/material-theme.scss +82 -40
  8. package/components/anchor-v2/src/components/anchor-item-v2/anchor-item-v2.component.d.ts +5 -5
  9. package/components/anchor-v2/src/models/sd-anchor-v2.model.d.ts +3 -3
  10. package/components/avatar/index.d.ts +1 -0
  11. package/components/avatar/src/avatar.component.d.ts +19 -0
  12. package/components/badge/src/badge.component.d.ts +77 -19
  13. package/components/button/src/button.component.d.ts +30 -28
  14. package/components/code-editor/index.d.ts +1 -0
  15. package/components/code-editor/src/code-editor.component.d.ts +25 -0
  16. package/components/document-builder/index.d.ts +1 -0
  17. package/components/document-builder/src/document-builder.component.d.ts +12 -41
  18. package/components/document-builder/src/document-builder.model.d.ts +14 -11
  19. package/components/document-builder/src/plugins/block-space/block-space.plugin.d.ts +9 -0
  20. package/components/document-builder/src/plugins/ck-comment/ck-comment.plugin.d.ts +44 -0
  21. package/components/document-builder/src/plugins/ck-comment/ck-comment.plugin.model.d.ts +57 -0
  22. package/components/document-builder/src/plugins/heading/heading.plugin.d.ts +1 -0
  23. package/components/document-builder/src/plugins/highlight-range/highlight-range.plugin.d.ts +4 -0
  24. package/components/document-builder/src/plugins/image-custom/image-custom.plugin.d.ts +31 -0
  25. package/components/document-builder/src/plugins/index.d.ts +7 -2
  26. package/components/document-builder/src/plugins/page-orientation/page-orientation.plugin.d.ts +2 -2
  27. package/components/document-builder/src/plugins/paste-handler/filters/bookmark.d.ts +14 -0
  28. package/components/document-builder/src/plugins/paste-handler/filters/br.d.ts +15 -0
  29. package/components/document-builder/src/plugins/paste-handler/filters/image.d.ts +25 -0
  30. package/components/document-builder/src/plugins/paste-handler/filters/list.d.ts +29 -0
  31. package/components/document-builder/src/plugins/paste-handler/filters/parse.d.ts +35 -0
  32. package/components/document-builder/src/plugins/paste-handler/filters/removeboldwrapper.d.ts +15 -0
  33. package/components/document-builder/src/plugins/paste-handler/filters/removegooglesheetstag.d.ts +15 -0
  34. package/components/document-builder/src/plugins/paste-handler/filters/removeinvalidtablewidth.d.ts +15 -0
  35. package/components/document-builder/src/plugins/paste-handler/filters/removemsattributes.d.ts +15 -0
  36. package/components/document-builder/src/plugins/paste-handler/filters/removestyleblock.d.ts +15 -0
  37. package/components/document-builder/src/plugins/paste-handler/filters/removexmlns.d.ts +15 -0
  38. package/components/document-builder/src/plugins/paste-handler/filters/replacemsfootnotes.d.ts +54 -0
  39. package/components/document-builder/src/plugins/paste-handler/filters/replacetabswithinprewithspaces.d.ts +24 -0
  40. package/components/document-builder/src/plugins/paste-handler/filters/space.d.ts +27 -0
  41. package/components/document-builder/src/plugins/paste-handler/filters/table.d.ts +16 -0
  42. package/components/document-builder/src/plugins/paste-handler/filters/utils.d.ts +25 -0
  43. package/components/document-builder/src/plugins/paste-handler/index.d.ts +35 -0
  44. package/components/document-builder/src/plugins/paste-handler/normalizers/googledocsnormalizer.d.ts +31 -0
  45. package/components/document-builder/src/plugins/paste-handler/normalizers/googlesheetsnormalizer.d.ts +31 -0
  46. package/components/document-builder/src/plugins/paste-handler/normalizers/mswordnormalizer.d.ts +29 -0
  47. package/components/document-builder/src/plugins/paste-handler/types.d.ts +30 -0
  48. package/components/document-builder/src/plugins/table-custom/index.d.ts +34 -0
  49. package/components/document-builder/src/plugins/variable/variable.plugin.d.ts +39 -0
  50. package/components/index.d.ts +4 -0
  51. package/components/mini-editor/index.d.ts +2 -0
  52. package/components/mini-editor/src/mini-editor.component.d.ts +90 -0
  53. package/components/mini-editor/src/mini-editor.model.d.ts +44 -0
  54. package/components/modal/index.d.ts +1 -1
  55. package/components/modal/src/modal.component.d.ts +24 -0
  56. package/components/section/index.d.ts +1 -0
  57. package/components/section/src/section-item/section-item.component.d.ts +7 -0
  58. package/components/section/src/section.component.d.ts +11 -11
  59. package/components/side-drawer/src/side-drawer.component.d.ts +11 -24
  60. package/components/tab-router/src/components/tab-router-item/tab-router-item.component.d.ts +4 -1
  61. package/components/tab-router/src/components/tab-router-outlet/tab-router-outlet.component.d.ts +3 -15
  62. package/components/table/src/components/column-filter/column-filter.component.d.ts +3 -3
  63. package/components/table/src/components/desktop-cell/desktop-cell.component.d.ts +21 -9
  64. package/components/table/src/components/desktop-cell-view/desktop-cell-view.component.d.ts +21 -7
  65. package/components/table/src/components/external-filter/external-filter.component.d.ts +1 -1
  66. package/components/table/src/components/selector-action/action-filter.pipe.d.ts +11 -10
  67. package/components/table/src/components/selector-action/selector-action.component.d.ts +5 -3
  68. package/components/table/src/directives/index.d.ts +2 -0
  69. package/components/table/src/directives/sd-table-column-filter-def.directive.d.ts +9 -0
  70. package/components/table/src/directives/sticky-shadow.directive.d.ts +17 -0
  71. package/components/table/src/models/table-column.model.d.ts +38 -34
  72. package/components/table/src/models/table-command.model.d.ts +7 -3
  73. package/components/table/src/models/table-item.model.d.ts +5 -4
  74. package/components/table/src/models/table-option-config.model.d.ts +5 -0
  75. package/components/table/src/models/table-option-export.model.d.ts +3 -2
  76. package/components/table/src/models/table-option-selector.model.d.ts +11 -10
  77. package/components/table/src/models/table-option.model.d.ts +9 -8
  78. package/components/table/src/services/index.d.ts +3 -0
  79. package/components/table/src/services/table-export/table-export.service.d.ts +26 -0
  80. package/components/table/src/services/table-filter/table-filter.model.d.ts +6 -5
  81. package/components/table/src/services/table-format/table-format.service.d.ts +16 -0
  82. package/components/table/src/table.component.d.ts +39 -53
  83. package/components/upload-file/src/configurations/upload-file.configuration.d.ts +1 -1
  84. package/components/upload-file/src/services/upload-file.service.d.ts +0 -1
  85. package/components/upload-file/src/upload-file.component.d.ts +49 -54
  86. package/components/view/index.d.ts +1 -0
  87. package/components/view/src/view.component.d.ts +16 -0
  88. package/components/workflow/src/models/form-generic-component.model.d.ts +5 -4
  89. package/components/workflow/src/models/index.d.ts +1 -0
  90. package/directives/index.d.ts +2 -0
  91. package/directives/src/sd-href.directive.d.ts +9 -0
  92. package/directives/src/sd-tooltip.directive.d.ts +26 -0
  93. package/fesm2022/sd-angular-core-components-anchor-v2.mjs +15 -15
  94. package/fesm2022/sd-angular-core-components-anchor-v2.mjs.map +1 -1
  95. package/fesm2022/sd-angular-core-components-avatar.mjs +103 -0
  96. package/fesm2022/sd-angular-core-components-avatar.mjs.map +1 -0
  97. package/fesm2022/sd-angular-core-components-badge.mjs +101 -91
  98. package/fesm2022/sd-angular-core-components-badge.mjs.map +1 -1
  99. package/fesm2022/sd-angular-core-components-button.mjs +70 -96
  100. package/fesm2022/sd-angular-core-components-button.mjs.map +1 -1
  101. package/fesm2022/sd-angular-core-components-code-editor.mjs +127 -0
  102. package/fesm2022/sd-angular-core-components-code-editor.mjs.map +1 -0
  103. package/fesm2022/sd-angular-core-components-document-builder.mjs +4006 -611
  104. package/fesm2022/sd-angular-core-components-document-builder.mjs.map +1 -1
  105. package/fesm2022/sd-angular-core-components-history.mjs +1 -1
  106. package/fesm2022/sd-angular-core-components-history.mjs.map +1 -1
  107. package/fesm2022/sd-angular-core-components-import-excel.mjs +1 -1
  108. package/fesm2022/sd-angular-core-components-import-excel.mjs.map +1 -1
  109. package/fesm2022/sd-angular-core-components-mini-editor.mjs +326 -0
  110. package/fesm2022/sd-angular-core-components-mini-editor.mjs.map +1 -0
  111. package/fesm2022/sd-angular-core-components-modal.mjs +57 -91
  112. package/fesm2022/sd-angular-core-components-modal.mjs.map +1 -1
  113. package/fesm2022/sd-angular-core-components-preview.mjs +1 -1
  114. package/fesm2022/sd-angular-core-components-preview.mjs.map +1 -1
  115. package/fesm2022/sd-angular-core-components-quick-action.mjs +2 -2
  116. package/fesm2022/sd-angular-core-components-quick-action.mjs.map +1 -1
  117. package/fesm2022/sd-angular-core-components-section.mjs +41 -43
  118. package/fesm2022/sd-angular-core-components-section.mjs.map +1 -1
  119. package/fesm2022/sd-angular-core-components-side-drawer.mjs +78 -84
  120. package/fesm2022/sd-angular-core-components-side-drawer.mjs.map +1 -1
  121. package/fesm2022/sd-angular-core-components-tab-router.mjs +152 -226
  122. package/fesm2022/sd-angular-core-components-tab-router.mjs.map +1 -1
  123. package/fesm2022/sd-angular-core-components-table.mjs +1188 -1185
  124. package/fesm2022/sd-angular-core-components-table.mjs.map +1 -1
  125. package/fesm2022/sd-angular-core-components-upload-file.mjs +339 -444
  126. package/fesm2022/sd-angular-core-components-upload-file.mjs.map +1 -1
  127. package/fesm2022/sd-angular-core-components-view.mjs +45 -0
  128. package/fesm2022/sd-angular-core-components-view.mjs.map +1 -0
  129. package/fesm2022/sd-angular-core-components-workflow.mjs +47 -57
  130. package/fesm2022/sd-angular-core-components-workflow.mjs.map +1 -1
  131. package/fesm2022/sd-angular-core-components.mjs +4 -0
  132. package/fesm2022/sd-angular-core-components.mjs.map +1 -1
  133. package/fesm2022/sd-angular-core-directives.mjs +286 -27
  134. package/fesm2022/sd-angular-core-directives.mjs.map +1 -1
  135. package/fesm2022/sd-angular-core-forms-autocomplete.mjs +289 -363
  136. package/fesm2022/sd-angular-core-forms-autocomplete.mjs.map +1 -1
  137. package/fesm2022/sd-angular-core-forms-chip-calendar.mjs +170 -189
  138. package/fesm2022/sd-angular-core-forms-chip-calendar.mjs.map +1 -1
  139. package/fesm2022/sd-angular-core-forms-chip.mjs +184 -194
  140. package/fesm2022/sd-angular-core-forms-chip.mjs.map +1 -1
  141. package/fesm2022/sd-angular-core-forms-date-range.mjs +180 -242
  142. package/fesm2022/sd-angular-core-forms-date-range.mjs.map +1 -1
  143. package/fesm2022/sd-angular-core-forms-date.mjs +178 -270
  144. package/fesm2022/sd-angular-core-forms-date.mjs.map +1 -1
  145. package/fesm2022/sd-angular-core-forms-datetime.mjs +177 -285
  146. package/fesm2022/sd-angular-core-forms-datetime.mjs.map +1 -1
  147. package/fesm2022/sd-angular-core-forms-input-number.mjs +210 -337
  148. package/fesm2022/sd-angular-core-forms-input-number.mjs.map +1 -1
  149. package/fesm2022/sd-angular-core-forms-input.mjs +169 -286
  150. package/fesm2022/sd-angular-core-forms-input.mjs.map +1 -1
  151. package/fesm2022/sd-angular-core-forms-radio.mjs +3 -2
  152. package/fesm2022/sd-angular-core-forms-radio.mjs.map +1 -1
  153. package/fesm2022/sd-angular-core-forms-select.mjs +390 -447
  154. package/fesm2022/sd-angular-core-forms-select.mjs.map +1 -1
  155. package/fesm2022/sd-angular-core-forms-textarea.mjs +167 -226
  156. package/fesm2022/sd-angular-core-forms-textarea.mjs.map +1 -1
  157. package/fesm2022/sd-angular-core-modules-keycloak.mjs +126 -0
  158. package/fesm2022/sd-angular-core-modules-keycloak.mjs.map +1 -0
  159. package/fesm2022/sd-angular-core-modules-layout.mjs +454 -453
  160. package/fesm2022/sd-angular-core-modules-layout.mjs.map +1 -1
  161. package/fesm2022/sd-angular-core-modules.mjs +1 -1
  162. package/fesm2022/sd-angular-core-services-api.mjs +5 -10
  163. package/fesm2022/sd-angular-core-services-api.mjs.map +1 -1
  164. package/fesm2022/sd-angular-core-services-confirm.mjs +5 -7
  165. package/fesm2022/sd-angular-core-services-confirm.mjs.map +1 -1
  166. package/fesm2022/sd-angular-core-services-docx.mjs +173 -0
  167. package/fesm2022/sd-angular-core-services-docx.mjs.map +1 -0
  168. package/fesm2022/sd-angular-core-services-notify.mjs +2 -2
  169. package/fesm2022/sd-angular-core-services-notify.mjs.map +1 -1
  170. package/fesm2022/sd-angular-core-services.mjs +1 -0
  171. package/fesm2022/sd-angular-core-services.mjs.map +1 -1
  172. package/fesm2022/sd-angular-core-utilities-extensions.mjs +21 -45
  173. package/fesm2022/sd-angular-core-utilities-extensions.mjs.map +1 -1
  174. package/fesm2022/sd-angular-core-utilities-models.mjs +15 -1
  175. package/fesm2022/sd-angular-core-utilities-models.mjs.map +1 -1
  176. package/forms/autocomplete/src/autocomplete.component.d.ts +55 -55
  177. package/forms/chip/src/chip.component.d.ts +37 -40
  178. package/forms/chip-calendar/src/chip-calendar.component.d.ts +37 -38
  179. package/forms/date/src/date.component.d.ts +48 -46
  180. package/forms/date-range/src/date-range.component.d.ts +35 -34
  181. package/forms/datetime/src/datetime.component.d.ts +48 -49
  182. package/forms/input/src/input.component.d.ts +54 -57
  183. package/forms/input-number/src/input-number.component.d.ts +53 -54
  184. package/forms/select/src/select.component.d.ts +67 -64
  185. package/forms/textarea/src/textarea.component.d.ts +40 -43
  186. package/modules/index.d.ts +1 -1
  187. package/modules/keycloak/index.d.ts +4 -0
  188. package/modules/keycloak/keycloak.configuration.d.ts +11 -0
  189. package/modules/keycloak/keycloak.interceptor.d.ts +2 -0
  190. package/modules/keycloak/keycloak.module.d.ts +18 -0
  191. package/modules/keycloak/keycloak.service.d.ts +14 -0
  192. package/modules/layout/components/layout-main/layout-main.component.d.ts +7 -12
  193. package/modules/layout/components/page/page.component.d.ts +5 -7
  194. package/modules/layout/components/sidebar-v1/components/sidebar/sidebar.component.d.ts +22 -29
  195. package/modules/layout/components/sidebar-v1/components/user/user.component.d.ts +11 -17
  196. package/modules/layout/components/sidebar-v1/main.component.d.ts +14 -14
  197. package/modules/layout/configurations/layout.configuration.d.ts +46 -3
  198. package/modules/layout/modules/forbidden/pages/root/root.component.d.ts +3 -8
  199. package/modules/layout/modules/home/components/home-page/home-page.component.d.ts +2 -5
  200. package/modules/layout/modules/not-found/pages/root/root.component.d.ts +3 -8
  201. package/modules/layout/pipes/high-light-search.pipe.d.ts +1 -1
  202. package/modules/layout/services/index.d.ts +1 -0
  203. package/modules/layout/services/layout.service.d.ts +10 -0
  204. package/modules/layout/services/menu/menu.model.d.ts +2 -0
  205. package/modules/layout/services/storage/storage.service.d.ts +0 -3
  206. package/package.json +87 -64
  207. package/sd-angular-core-19.0.0-beta.71.tgz +0 -0
  208. package/services/api/src/api.model.d.ts +6 -1
  209. package/services/confirm/src/lib/confirm.service.d.ts +1 -0
  210. package/services/docx/index.d.ts +1 -0
  211. package/services/docx/src/lib/docx.model.d.ts +9 -0
  212. package/services/docx/src/lib/docx.service.d.ts +13 -0
  213. package/services/docx/src/public-api.d.ts +2 -0
  214. package/services/index.d.ts +1 -0
  215. package/services/notify/index.d.ts +1 -0
  216. package/services/notify/src/notify.model.d.ts +1 -1
  217. package/services/notify/src/notify.service.d.ts +5 -5
  218. package/utilities/extensions/src/string.extension.d.ts +2 -0
  219. package/utilities/extensions/src/utility.extension.d.ts +1 -0
  220. package/utilities/models/index.d.ts +3 -0
  221. package/utilities/models/src/filter.model.d.ts +17 -4
  222. package/utilities/models/src/icon.model.d.ts +2 -0
  223. package/utilities/models/src/nested-key-of.model.d.ts +5 -0
  224. package/utilities/models/src/order.model.d.ts +2 -1
  225. package/utilities/models/src/paging.model.d.ts +2 -1
  226. package/utilities/models/src/pattern.model.d.ts +1 -1
  227. package/utilities/models/src/unwrap-signal.model.d.ts +6 -0
  228. package/components/document-builder/src/plugins/comment/comment.plugin.d.ts +0 -4
  229. package/components/document-builder/src/plugins/table-fit/table-fit.plugin.d.ts +0 -4
  230. package/components/modal/src/modal/modal.component.d.ts +0 -31
  231. package/fesm2022/sd-angular-core-modules-oidc.mjs +0 -127
  232. package/fesm2022/sd-angular-core-modules-oidc.mjs.map +0 -1
  233. package/modules/oidc/dynamic-sts.loader.d.ts +0 -11
  234. package/modules/oidc/index.d.ts +0 -2
  235. package/modules/oidc/oidc.configuration.d.ts +0 -11
  236. package/modules/oidc/oidc.module.d.ts +0 -14
  237. package/sd-angular-core-19.0.0-beta.7.tgz +0 -0
@@ -1,64 +1,61 @@
1
- import { AfterViewInit, ChangeDetectorRef, ElementRef, EventEmitter, OnDestroy, OnInit } from '@angular/core';
2
- import { FormGroup, NgForm, ValidatorFn } from '@angular/forms';
3
- import { MatFormFieldAppearance } from '@angular/material/form-field';
4
- import { SdLabelDefDirective, SdSuffixDefDirective, SdViewDefDirective } from '@sd-angular/core/forms/directives';
5
- import { ISdFormConfiguration, SdCustomValidator, SdFormControl } from '@sd-angular/core/forms/models';
6
- import { SdPatternType, SdSize } from '@sd-angular/core/utilities/models';
1
+ import { AfterViewInit, ElementRef, EventEmitter, OnDestroy, OnInit, TemplateRef } from '@angular/core';
2
+ import { FormGroup, ValidatorFn } from '@angular/forms';
3
+ import { FloatLabelType, MatFormFieldAppearance } from '@angular/material/form-field';
4
+ import { SdSuffixDefDirective, SdViewDefDirective } from '@sd-angular/core/forms/directives';
5
+ import { SdCustomValidator, SdFormControl } from '@sd-angular/core/forms/models';
6
+ import { SdSize } from '@sd-angular/core/utilities/models';
7
7
  import * as i0 from "@angular/core";
8
8
  export declare class SdInput implements OnDestroy, OnInit, AfterViewInit {
9
9
  #private;
10
- private ref;
11
- private formConfig;
12
10
  id: string;
13
- autoId?: string;
14
- set _autoId(val: string | undefined | null);
15
- set _name(val: string | undefined);
16
- appearance: MatFormFieldAppearance;
17
- size: SdSize;
18
- set _form(val: NgForm | FormGroup | undefined | null);
19
- label?: string;
20
- set _label(val: string | undefined);
21
- helperText?: string;
22
- set _helperText(val: string | undefined);
23
- placeholder?: string;
24
- set _placeholder(val: string | undefined);
25
- type: 'text' | 'number' | 'password' | 'email';
26
- hideInlineError: boolean;
27
- set _hideInlineError(val: boolean | '');
28
- set _blurOnEnter(val: boolean | '');
29
- set model(value: any);
30
- modelChange: EventEmitter<any>;
31
- required: boolean;
32
- set _required(val: boolean | '' | undefined | null);
33
- readonly: boolean;
34
- set _readonly(val: boolean | '');
35
- minlength?: number;
36
- set _minlength(val: number | undefined | null);
37
- maxlength?: number;
38
- set _maxlength(val: number | undefined | null);
39
- set _pattern(val: SdPatternType | string | undefined | null);
40
- patternErrorMessage?: string;
41
- set _patternErrorMessage(val: string | undefined | null);
42
- set _validator(value: SdCustomValidator | undefined);
43
- inlineError?: string;
44
- set _inlineError(val: string);
45
- set disabled(val: boolean | '' | undefined | null);
46
- viewed: boolean;
47
- set _viewed(val: boolean | '' | undefined | null);
48
- hyperlink?: string | null;
49
- tooltip?: string;
50
- sdChange: EventEmitter<any>;
51
- sdFocus: EventEmitter<any>;
52
- sdBlur: EventEmitter<any>;
53
- sdFocusForceBlur: EventEmitter<any>;
54
- keyupEnter: EventEmitter<any>;
55
- control?: ElementRef;
56
- sdSuffixDef?: SdSuffixDefDirective;
57
- sdLabelDef?: SdLabelDefDirective;
58
- sdViewDef?: SdViewDefDirective;
11
+ control: import("@angular/core").Signal<ElementRef<HTMLInputElement> | undefined>;
12
+ sdLabelTemplate: import("@angular/core").Signal<TemplateRef<any> | undefined>;
13
+ sdValueTemplate: import("@angular/core").Signal<TemplateRef<any> | undefined>;
14
+ sdSuffixDef: import("@angular/core").Signal<SdSuffixDefDirective | undefined>;
15
+ sdViewDef: import("@angular/core").Signal<SdViewDefDirective | undefined>;
16
+ autoIdInput: import("@angular/core").InputSignal<string | null | undefined>;
17
+ autoId: import("@angular/core").Signal<string | undefined>;
18
+ name: import("@angular/core").InputSignal<string>;
19
+ appearanceInput: import("@angular/core").InputSignal<MatFormFieldAppearance | undefined>;
20
+ appearance: import("@angular/core").Signal<MatFormFieldAppearance>;
21
+ floatLabel: import("@angular/core").InputSignal<FloatLabelType>;
22
+ size: import("@angular/core").InputSignal<SdSize>;
23
+ form: import("@angular/core").InputSignalWithTransform<FormGroup<any> | undefined, any>;
24
+ label: import("@angular/core").InputSignal<string | undefined>;
25
+ helperText: import("@angular/core").InputSignal<string | undefined>;
26
+ placeholder: import("@angular/core").InputSignal<string | undefined>;
27
+ type: import("@angular/core").InputSignal<"number" | "text" | "password" | "email">;
28
+ hideInlineError: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
29
+ blurOnEnter: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
30
+ required: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
31
+ readonly: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
32
+ disabled: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
33
+ viewed: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
34
+ minlength: import("@angular/core").InputSignalWithTransform<number | undefined, unknown>;
35
+ maxlength: import("@angular/core").InputSignalWithTransform<number | undefined, unknown>;
36
+ pattern: import("@angular/core").InputSignal<string | null | undefined>;
37
+ patternErrorMessage: import("@angular/core").InputSignal<string | null | undefined>;
38
+ resolvedPattern: import("@angular/core").Signal<string | undefined>;
39
+ resolvedPatternErrorMsg: import("@angular/core").Signal<string | undefined>;
40
+ /**
41
+ * Tổng hợp error message đầu tiên để hiển thị trong tooltip khi hideInlineError = true.
42
+ * Dùng getter (không phải computed) vì formControl.errors không phải Angular signal.
43
+ * cdRef.markForCheck() được gọi qua sdChanges subscription nên getter sẽ được re-evaluate đúng cycle.
44
+ */
45
+ get errorTooltipMessage(): string | undefined;
46
+ validator: import("@angular/core").InputSignal<SdCustomValidator | undefined>;
47
+ inlineError: import("@angular/core").InputSignal<string | undefined>;
48
+ hyperlink: import("@angular/core").InputSignal<string | null | undefined>;
49
+ tooltip: import("@angular/core").InputSignal<string | undefined>;
50
+ valueModel: import("@angular/core").ModelSignal<any>;
51
+ sdChange: import("@angular/core").OutputEmitterRef<any>;
52
+ sdFocus: import("@angular/core").OutputEmitterRef<void>;
53
+ sdBlur: import("@angular/core").OutputEmitterRef<any>;
54
+ keyupEnter: import("@angular/core").OutputEmitterRef<any>;
55
+ sdFocusForceBlur: EventEmitter<void>;
59
56
  formControl: SdFormControl;
60
57
  isFocused: boolean;
61
- constructor(ref: ChangeDetectorRef, formConfig: ISdFormConfiguration);
58
+ constructor();
62
59
  ngOnInit(): void;
63
60
  ngAfterViewInit(): void;
64
61
  ngOnDestroy(): void;
@@ -70,7 +67,7 @@ export declare class SdInput implements OnDestroy, OnInit, AfterViewInit {
70
67
  onClick: () => void;
71
68
  blur: () => void;
72
69
  focus: () => void;
73
- static ɵfac: i0.ɵɵFactoryDeclaration<SdInput, [null, { optional: true; }]>;
74
- static ɵcmp: i0.ɵɵComponentDeclaration<SdInput, "sd-input", never, { "_autoId": { "alias": "autoId"; "required": false; }; "_name": { "alias": "name"; "required": false; }; "appearance": { "alias": "appearance"; "required": false; }; "size": { "alias": "size"; "required": false; }; "_form": { "alias": "form"; "required": false; }; "_label": { "alias": "label"; "required": false; }; "_helperText": { "alias": "helperText"; "required": false; }; "_placeholder": { "alias": "placeholder"; "required": false; }; "type": { "alias": "type"; "required": false; }; "_hideInlineError": { "alias": "hideInlineError"; "required": false; }; "_blurOnEnter": { "alias": "blurOnEnter"; "required": false; }; "model": { "alias": "model"; "required": false; }; "_required": { "alias": "required"; "required": false; }; "_readonly": { "alias": "readonly"; "required": false; }; "_minlength": { "alias": "minlength"; "required": false; }; "_maxlength": { "alias": "maxlength"; "required": false; }; "_pattern": { "alias": "pattern"; "required": false; }; "_patternErrorMessage": { "alias": "patternErrorMessage"; "required": false; }; "_validator": { "alias": "validator"; "required": false; }; "_inlineError": { "alias": "inlineError"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "_viewed": { "alias": "viewed"; "required": false; }; "hyperlink": { "alias": "hyperlink"; "required": false; }; "tooltip": { "alias": "tooltip"; "required": false; }; }, { "modelChange": "modelChange"; "sdChange": "sdChange"; "sdFocus": "sdFocus"; "sdBlur": "sdBlur"; "sdFocusForceBlur": "sdFocusForceBlur"; "keyupEnter": "keyupEnter"; }, ["sdSuffixDef", "sdLabelDef", "sdViewDef"], never, true, never>;
70
+ static ɵfac: i0.ɵɵFactoryDeclaration<SdInput, never>;
71
+ static ɵcmp: i0.ɵɵComponentDeclaration<SdInput, "sd-input", never, { "autoIdInput": { "alias": "autoId"; "required": false; "isSignal": true; }; "name": { "alias": "name"; "required": false; "isSignal": true; }; "appearanceInput": { "alias": "appearance"; "required": false; "isSignal": true; }; "floatLabel": { "alias": "floatLabel"; "required": false; "isSignal": true; }; "size": { "alias": "size"; "required": false; "isSignal": true; }; "form": { "alias": "form"; "required": false; "isSignal": true; }; "label": { "alias": "label"; "required": false; "isSignal": true; }; "helperText": { "alias": "helperText"; "required": false; "isSignal": true; }; "placeholder": { "alias": "placeholder"; "required": false; "isSignal": true; }; "type": { "alias": "type"; "required": false; "isSignal": true; }; "hideInlineError": { "alias": "hideInlineError"; "required": false; "isSignal": true; }; "blurOnEnter": { "alias": "blurOnEnter"; "required": false; "isSignal": true; }; "required": { "alias": "required"; "required": false; "isSignal": true; }; "readonly": { "alias": "readonly"; "required": false; "isSignal": true; }; "disabled": { "alias": "disabled"; "required": false; "isSignal": true; }; "viewed": { "alias": "viewed"; "required": false; "isSignal": true; }; "minlength": { "alias": "minlength"; "required": false; "isSignal": true; }; "maxlength": { "alias": "maxlength"; "required": false; "isSignal": true; }; "pattern": { "alias": "pattern"; "required": false; "isSignal": true; }; "patternErrorMessage": { "alias": "patternErrorMessage"; "required": false; "isSignal": true; }; "validator": { "alias": "validator"; "required": false; "isSignal": true; }; "inlineError": { "alias": "inlineError"; "required": false; "isSignal": true; }; "hyperlink": { "alias": "hyperlink"; "required": false; "isSignal": true; }; "tooltip": { "alias": "tooltip"; "required": false; "isSignal": true; }; "valueModel": { "alias": "model"; "required": false; "isSignal": true; }; }, { "valueModel": "modelChange"; "sdChange": "sdChange"; "sdFocus": "sdFocus"; "sdBlur": "sdBlur"; "keyupEnter": "keyupEnter"; "sdFocusForceBlur": "sdFocusForceBlur"; }, ["sdLabelTemplate", "sdValueTemplate", "sdSuffixDef", "sdViewDef"], ["[sdLabel]"], true, never>;
75
72
  }
76
73
  export declare function backendErrorValidator(backendErrorMessage: string): ValidatorFn;
@@ -1,12 +1,10 @@
1
- import { AfterViewInit, ChangeDetectorRef, ElementRef, EventEmitter, OnDestroy, OnInit } from '@angular/core';
1
+ import { AfterViewInit, ElementRef, EventEmitter, OnDestroy, OnInit, TemplateRef } from '@angular/core';
2
2
  import { FormControl, FormGroup, FormGroupDirective, NgForm, ValidatorFn } from '@angular/forms';
3
3
  import { ErrorStateMatcher } from '@angular/material/core';
4
- import { MatFormFieldAppearance } from '@angular/material/form-field';
5
- import { SdLabelDefDirective, SdSuffixDefDirective, SdViewDefDirective } from '@sd-angular/core/forms/directives';
6
- import { ISdFormConfiguration, SdCustomValidator, SdFormControl } from '@sd-angular/core/forms/models';
4
+ import { FloatLabelType, MatFormFieldAppearance } from '@angular/material/form-field';
5
+ import { SdSuffixDefDirective, SdViewDefDirective } from '@sd-angular/core/forms/directives';
6
+ import { SdCustomValidator, SdFormControl } from '@sd-angular/core/forms/models';
7
7
  import { SdSize } from '@sd-angular/core/utilities/models';
8
- import { SdFormatNumberPipe } from '@sd-angular/core/pipes';
9
- import { ISdCoreConfiguration } from '@sd-angular/core/configurations';
10
8
  import * as i0 from "@angular/core";
11
9
  declare class SdInputNumberErrotStateMatcher implements ErrorStateMatcher {
12
10
  private formControl;
@@ -15,58 +13,59 @@ declare class SdInputNumberErrotStateMatcher implements ErrorStateMatcher {
15
13
  }
16
14
  export declare class SdInputNumber implements OnDestroy, OnInit, AfterViewInit {
17
15
  #private;
16
+ id: string;
17
+ control: import("@angular/core").Signal<ElementRef<HTMLInputElement> | undefined>;
18
+ sdLabelTemplate: import("@angular/core").Signal<TemplateRef<any> | undefined>;
19
+ sdValueTemplate: import("@angular/core").Signal<TemplateRef<any> | undefined>;
20
+ sdViewDef: import("@angular/core").Signal<SdViewDefDirective | undefined>;
21
+ sdSuffixDef: import("@angular/core").Signal<SdSuffixDefDirective | undefined>;
18
22
  private ref;
19
- private readonly coreConfiguration;
20
- private readonly formatNumberPipe;
23
+ private coreConfiguration;
24
+ private formatNumberPipe;
21
25
  private formConfig;
22
- id: string;
23
- autoId?: string;
24
- set _autoId(val: string | undefined | null);
25
- set name(val: string | undefined);
26
- size: SdSize;
27
- set form(val: NgForm | FormGroup | undefined | null);
28
- label?: string;
29
- set _label(val: string | undefined);
30
- helperText?: string;
31
- set _helperText(val: string | undefined);
32
- placeholder?: string;
33
- hideInlineError: boolean;
34
- set _hideInlineError(val: boolean | '');
35
- set _blurOnEnter(val: boolean | '');
36
- set model(value: any);
37
- modelChange: EventEmitter<any>;
38
- required: boolean;
39
- set _required(val: boolean | '' | undefined | null);
40
- type?: 'negative' | 'positive';
41
- precision: number;
42
- readonly: boolean;
43
- set _readonly(val: boolean | '');
44
- min?: number;
45
- set _min(val: number | undefined | null);
46
- max?: number;
47
- set _max(val: number | undefined | null);
48
- set validator(validator: SdCustomValidator | undefined);
49
- inlineError?: string;
50
- set _inlineError(val: string);
51
- set disabled(val: boolean | '' | undefined | null);
52
- viewed: boolean;
53
- set _viewed(val: boolean | '' | undefined | null);
54
- hyperlink?: string | null;
55
- appearance: MatFormFieldAppearance;
56
- sdChange: EventEmitter<any>;
57
- sdFocus: EventEmitter<any>;
58
- sdBlur: EventEmitter<any>;
59
- sdFocusForceBlur: EventEmitter<any>;
60
- keyupEnter: EventEmitter<any>;
61
- control?: ElementRef;
26
+ autoIdInput: import("@angular/core").InputSignal<string | null | undefined>;
27
+ autoId: import("@angular/core").Signal<string | undefined>;
28
+ name: import("@angular/core").InputSignal<string>;
29
+ size: import("@angular/core").InputSignal<SdSize>;
30
+ form: import("@angular/core").InputSignalWithTransform<FormGroup<any> | undefined, any>;
31
+ label: import("@angular/core").InputSignal<string | undefined>;
32
+ helperText: import("@angular/core").InputSignal<string | undefined>;
33
+ placeholder: import("@angular/core").InputSignal<string | undefined>;
34
+ hideInlineError: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
35
+ blurOnEnter: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
36
+ required: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
37
+ readonly: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
38
+ disabled: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
39
+ viewed: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
40
+ type: import("@angular/core").InputSignal<"negative" | "positive" | undefined>;
41
+ precision: import("@angular/core").InputSignal<number>;
42
+ min: import("@angular/core").InputSignalWithTransform<number | undefined, unknown>;
43
+ max: import("@angular/core").InputSignalWithTransform<number | undefined, unknown>;
44
+ validator: import("@angular/core").InputSignal<SdCustomValidator | undefined>;
45
+ inlineError: import("@angular/core").InputSignal<string | undefined>;
46
+ /**
47
+ * Tổng hợp error message để hiển thị trong tooltip khi hideInlineError = true.
48
+ * Dùng getter (không phải computed) vì formControl.errors không phải Angular signal.
49
+ */
50
+ get errorTooltipMessage(): string | undefined;
51
+ hyperlink: import("@angular/core").InputSignal<string | null | undefined>;
52
+ appearanceInput: import("@angular/core").InputSignal<MatFormFieldAppearance | undefined>;
53
+ appearance: import("@angular/core").Signal<MatFormFieldAppearance>;
54
+ floatLabel: import("@angular/core").InputSignal<FloatLabelType>;
55
+ valueModel: import("@angular/core").ModelSignal<any>;
56
+ sdChange: import("@angular/core").OutputEmitterRef<any>;
57
+ sdFocus: import("@angular/core").OutputEmitterRef<void>;
58
+ sdBlur: import("@angular/core").OutputEmitterRef<any>;
59
+ keyupEnter: import("@angular/core").OutputEmitterRef<any>;
60
+ sdFocusForceBlur: EventEmitter<void>;
62
61
  formControl: SdFormControl;
63
62
  inputControl: SdFormControl;
64
63
  matcher: SdInputNumberErrotStateMatcher;
65
- sdViewDef?: SdViewDefDirective;
66
- sdSuffixDef?: SdSuffixDefDirective;
67
- sdLabelDef?: SdLabelDefDirective;
68
64
  isFocused: boolean;
69
- constructor(ref: ChangeDetectorRef, coreConfiguration: ISdCoreConfiguration | undefined, formatNumberPipe: SdFormatNumberPipe, formConfig: ISdFormConfiguration);
65
+ decimalSeparator: import("@angular/core").Signal<"," | ".">;
66
+ thousandsSeparator: import("@angular/core").Signal<"," | ".">;
67
+ regexPattern: import("@angular/core").Signal<string>;
68
+ constructor();
70
69
  ngOnInit(): void;
71
70
  ngAfterViewInit(): void;
72
71
  ngOnDestroy(): void;
@@ -82,7 +81,7 @@ export declare class SdInputNumber implements OnDestroy, OnInit, AfterViewInit {
82
81
  onClick: () => void;
83
82
  blur: () => void;
84
83
  focus: () => void;
85
- static ɵfac: i0.ɵɵFactoryDeclaration<SdInputNumber, [null, { optional: true; }, null, { optional: true; }]>;
86
- static ɵcmp: i0.ɵɵComponentDeclaration<SdInputNumber, "sd-input-number", never, { "_autoId": { "alias": "autoId"; "required": false; }; "name": { "alias": "name"; "required": false; }; "size": { "alias": "size"; "required": false; }; "form": { "alias": "form"; "required": false; }; "_label": { "alias": "label"; "required": false; }; "_helperText": { "alias": "helperText"; "required": false; }; "placeholder": { "alias": "placeholder"; "required": false; }; "_hideInlineError": { "alias": "hideInlineError"; "required": false; }; "_blurOnEnter": { "alias": "blurOnEnter"; "required": false; }; "model": { "alias": "model"; "required": false; }; "_required": { "alias": "required"; "required": false; }; "type": { "alias": "type"; "required": false; }; "precision": { "alias": "precision"; "required": false; }; "_readonly": { "alias": "readonly"; "required": false; }; "_min": { "alias": "min"; "required": false; }; "_max": { "alias": "max"; "required": false; }; "validator": { "alias": "validator"; "required": false; }; "_inlineError": { "alias": "inlineError"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "_viewed": { "alias": "viewed"; "required": false; }; "hyperlink": { "alias": "hyperlink"; "required": false; }; "appearance": { "alias": "appearance"; "required": false; }; }, { "modelChange": "modelChange"; "sdChange": "sdChange"; "sdFocus": "sdFocus"; "sdBlur": "sdBlur"; "sdFocusForceBlur": "sdFocusForceBlur"; "keyupEnter": "keyupEnter"; }, ["sdViewDef", "sdSuffixDef", "sdLabelDef"], never, true, never>;
84
+ static ɵfac: i0.ɵɵFactoryDeclaration<SdInputNumber, never>;
85
+ static ɵcmp: i0.ɵɵComponentDeclaration<SdInputNumber, "sd-input-number", never, { "autoIdInput": { "alias": "autoId"; "required": false; "isSignal": true; }; "name": { "alias": "name"; "required": false; "isSignal": true; }; "size": { "alias": "size"; "required": false; "isSignal": true; }; "form": { "alias": "form"; "required": false; "isSignal": true; }; "label": { "alias": "label"; "required": false; "isSignal": true; }; "helperText": { "alias": "helperText"; "required": false; "isSignal": true; }; "placeholder": { "alias": "placeholder"; "required": false; "isSignal": true; }; "hideInlineError": { "alias": "hideInlineError"; "required": false; "isSignal": true; }; "blurOnEnter": { "alias": "blurOnEnter"; "required": false; "isSignal": true; }; "required": { "alias": "required"; "required": false; "isSignal": true; }; "readonly": { "alias": "readonly"; "required": false; "isSignal": true; }; "disabled": { "alias": "disabled"; "required": false; "isSignal": true; }; "viewed": { "alias": "viewed"; "required": false; "isSignal": true; }; "type": { "alias": "type"; "required": false; "isSignal": true; }; "precision": { "alias": "precision"; "required": false; "isSignal": true; }; "min": { "alias": "min"; "required": false; "isSignal": true; }; "max": { "alias": "max"; "required": false; "isSignal": true; }; "validator": { "alias": "validator"; "required": false; "isSignal": true; }; "inlineError": { "alias": "inlineError"; "required": false; "isSignal": true; }; "hyperlink": { "alias": "hyperlink"; "required": false; "isSignal": true; }; "appearanceInput": { "alias": "appearance"; "required": false; "isSignal": true; }; "floatLabel": { "alias": "floatLabel"; "required": false; "isSignal": true; }; "valueModel": { "alias": "model"; "required": false; "isSignal": true; }; }, { "valueModel": "modelChange"; "sdChange": "sdChange"; "sdFocus": "sdFocus"; "sdBlur": "sdBlur"; "keyupEnter": "keyupEnter"; "sdFocusForceBlur": "sdFocusForceBlur"; }, ["sdLabelTemplate", "sdValueTemplate", "sdViewDef", "sdSuffixDef"], ["[sdLabel]"], true, never>;
87
86
  }
88
87
  export {};
@@ -1,72 +1,77 @@
1
- import { AfterViewInit, ChangeDetectorRef, EventEmitter, OnDestroy, OnInit } from '@angular/core';
2
- import { FormControl, FormGroup, NgForm, ValidatorFn } from '@angular/forms';
3
- import { MatFormFieldAppearance } from '@angular/material/form-field';
1
+ import { OnInit, // THÊM IMPORT NÀY
2
+ Signal, TemplateRef } from '@angular/core';
3
+ import { FormControl, FormGroup, ValidatorFn } from '@angular/forms';
4
+ import { FloatLabelType, MatFormFieldAppearance } from '@angular/material/form-field';
4
5
  import { MatInput } from '@angular/material/input';
5
6
  import { MatSelect, MatSelectChange } from '@angular/material/select';
6
- import { MatTooltip } from '@angular/material/tooltip';
7
- import { SdItemDefDefDirective, SdLabelDefDirective, SdViewDefDirective } from '@sd-angular/core/forms/directives';
8
- import { ISdFormConfiguration, SdCustomValidator, SdFormControl, SdSearch, SdSelectionData } from '@sd-angular/core/forms/models';
7
+ import { SdItemDefDefDirective, SdViewDefDirective } from '@sd-angular/core/forms/directives';
8
+ import { SdCustomValidator, SdFormControl, SdSearch, SdSelectionData } from '@sd-angular/core/forms/models';
9
9
  import { SdSize } from '@sd-angular/core/utilities/models';
10
- import { BehaviorSubject, Observable } from 'rxjs';
11
10
  import * as i0 from "@angular/core";
12
- export declare class SdSelect implements OnInit, AfterViewInit, OnDestroy {
11
+ export declare class SdSelect<T extends object | string | number = Record<string, unknown>> implements OnInit {
13
12
  #private;
14
- private ref;
15
- private formConfig;
16
- autoId?: string;
17
- set _autoId(val: string | undefined | null);
18
- set input(input: MatInput);
19
- select?: MatSelect;
20
- set name(val: string | undefined);
21
- appearance: MatFormFieldAppearance;
22
- hideInlineError: boolean;
23
- set _hideInlineError(val: boolean | '');
13
+ id: string;
14
+ matInputRef: Signal<MatInput | undefined>;
15
+ selectRef: Signal<MatSelect | undefined>;
16
+ sdLabelTemplate: Signal<TemplateRef<any> | undefined>;
17
+ sdValueTemplate: Signal<TemplateRef<any> | undefined>;
18
+ itemDef: Signal<SdItemDefDefDirective | undefined>;
19
+ sdViewDef: Signal<SdViewDefDirective | undefined>;
20
+ autoIdInput: import("@angular/core").InputSignal<string | null | undefined>;
21
+ autoId: Signal<string | undefined>;
22
+ name: import("@angular/core").InputSignal<string>;
23
+ size: import("@angular/core").InputSignal<SdSize>;
24
+ form: import("@angular/core").InputSignalWithTransform<FormGroup<any> | undefined, any>;
25
+ label: import("@angular/core").InputSignal<string | undefined>;
26
+ helperText: import("@angular/core").InputSignal<string | undefined>;
27
+ placeholder: import("@angular/core").InputSignal<string | undefined>;
28
+ valueField: import("@angular/core").InputSignal<T extends object ? { [Key in keyof T & string]: T[Key] extends string | number | boolean | Function | Date | null | undefined ? Key : T[Key] extends any[] ? Key : T[Key] extends object ? Key | `${Key}.${T[Key] extends infer T_1 ? T_1 extends T[Key] ? T_1 extends object ? { [Key_1 in keyof T_1 & string]: T_1[Key_1] extends string | number | boolean | Function | Date | null | undefined ? Key_1 : T_1[Key_1] extends any[] ? Key_1 : T_1[Key_1] extends object ? Key_1 | `${Key_1}.${T_1[Key_1] extends infer T_2 ? T_2 extends T_1[Key_1] ? T_2 extends object ? { [Key_2 in keyof T_2 & string]: T_2[Key_2] extends string | number | boolean | Function | Date | null | undefined ? Key_2 : T_2[Key_2] extends any[] ? Key_2 : T_2[Key_2] extends object ? Key_2 | `${Key_2}.${T_2[Key_2] extends infer T_3 ? T_3 extends T_2[Key_2] ? T_3 extends object ? { [Key_3 in keyof T_3 & string]: T_3[Key_3] extends string | number | boolean | Function | Date | null | undefined ? Key_3 : T_3[Key_3] extends any[] ? Key_3 : T_3[Key_3] extends object ? Key_3 : Key_3; }[keyof T_3 & string] : string : never : never}` : Key_2; }[keyof T_2 & string] : string : never : never}` : Key_1; }[keyof T_1 & string] : string : never : never}` : Key; }[keyof T & string] : string>;
29
+ displayField: import("@angular/core").InputSignal<T extends object ? { [Key in keyof T & string]: T[Key] extends string | number | boolean | Function | Date | null | undefined ? Key : T[Key] extends any[] ? Key : T[Key] extends object ? Key | `${Key}.${T[Key] extends infer T_1 ? T_1 extends T[Key] ? T_1 extends object ? { [Key_1 in keyof T_1 & string]: T_1[Key_1] extends string | number | boolean | Function | Date | null | undefined ? Key_1 : T_1[Key_1] extends any[] ? Key_1 : T_1[Key_1] extends object ? Key_1 | `${Key_1}.${T_1[Key_1] extends infer T_2 ? T_2 extends T_1[Key_1] ? T_2 extends object ? { [Key_2 in keyof T_2 & string]: T_2[Key_2] extends string | number | boolean | Function | Date | null | undefined ? Key_2 : T_2[Key_2] extends any[] ? Key_2 : T_2[Key_2] extends object ? Key_2 | `${Key_2}.${T_2[Key_2] extends infer T_3 ? T_3 extends T_2[Key_2] ? T_3 extends object ? { [Key_3 in keyof T_3 & string]: T_3[Key_3] extends string | number | boolean | Function | Date | null | undefined ? Key_3 : T_3[Key_3] extends any[] ? Key_3 : T_3[Key_3] extends object ? Key_3 : Key_3; }[keyof T_3 & string] : string : never : never}` : Key_2; }[keyof T_2 & string] : string : never : never}` : Key_1; }[keyof T_1 & string] : string : never : never}` : Key; }[keyof T & string] : string>;
30
+ disabledField: import("@angular/core").InputSignal<"" | (T extends object ? { [Key in keyof T & string]: T[Key] extends string | number | boolean | Function | Date | null | undefined ? Key : T[Key] extends any[] ? Key : T[Key] extends object ? Key | `${Key}.${T[Key] extends infer T_1 ? T_1 extends T[Key] ? T_1 extends object ? { [Key_1 in keyof T_1 & string]: T_1[Key_1] extends string | number | boolean | Function | Date | null | undefined ? Key_1 : T_1[Key_1] extends any[] ? Key_1 : T_1[Key_1] extends object ? Key_1 | `${Key_1}.${T_1[Key_1] extends infer T_2 ? T_2 extends T_1[Key_1] ? T_2 extends object ? { [Key_2 in keyof T_2 & string]: T_2[Key_2] extends string | number | boolean | Function | Date | null | undefined ? Key_2 : T_2[Key_2] extends any[] ? Key_2 : T_2[Key_2] extends object ? Key_2 | `${Key_2}.${T_2[Key_2] extends infer T_3 ? T_3 extends T_2[Key_2] ? T_3 extends object ? { [Key_3 in keyof T_3 & string]: T_3[Key_3] extends string | number | boolean | Function | Date | null | undefined ? Key_3 : T_3[Key_3] extends any[] ? Key_3 : T_3[Key_3] extends object ? Key_3 : Key_3; }[keyof T_3 & string] : string : never : never}` : Key_2; }[keyof T_2 & string] : string : never : never}` : Key_1; }[keyof T_1 & string] : string : never : never}` : Key; }[keyof T & string] : string)>;
31
+ cacheChecksum: import("@angular/core").InputSignal<any>;
32
+ limit: import("@angular/core").InputSignal<number>;
33
+ hyperlink: import("@angular/core").InputSignal<string | null | undefined>;
34
+ minWidthPanel: import("@angular/core").InputSignalWithTransform<string | number, string | number | null | undefined>;
35
+ hideInlineError: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
36
+ required: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
37
+ disabled: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
38
+ viewed: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
39
+ multiple: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
40
+ validator: import("@angular/core").InputSignal<SdCustomValidator | undefined>;
41
+ inlineError: import("@angular/core").InputSignal<string | undefined>;
42
+ /**
43
+ * Tổng hợp error message để hiển thị trong tooltip khi hideInlineError = true.
44
+ * Dùng getter (không phải computed) vì formControl.errors không phải Angular signal.
45
+ */
46
+ get errorTooltipMessage(): string | undefined;
47
+ appearanceInput: import("@angular/core").InputSignal<MatFormFieldAppearance | undefined>;
48
+ appearance: Signal<MatFormFieldAppearance>;
49
+ floatLabel: import("@angular/core").InputSignal<FloatLabelType>;
50
+ items: import("@angular/core").InputSignal<SdSearch | T[] | Signal<T[]> | null | undefined>;
51
+ valueModel: import("@angular/core").ModelSignal<string | number | boolean | (string | number)[] | null | undefined>;
52
+ sdChange: import("@angular/core").OutputEmitterRef<any>;
53
+ sdSelection: import("@angular/core").OutputEmitterRef<SdSelectionData<any>>;
24
54
  formControl: SdFormControl;
25
55
  inputControl: FormControl<string | null>;
26
- size?: SdSize;
27
- set form(val: NgForm | FormGroup | undefined | null);
28
- label?: string;
29
- set _label(val: string | undefined);
30
- helperText?: string;
31
- set _helperText(val: string | undefined);
32
- placeholder?: string;
33
- display?: Observable<string>;
34
- set model(value: boolean | number | string | (number | string)[] | undefined | null);
35
- set items(items: undefined | null | any[] | SdSearch);
36
- valueField: string;
37
- displayField: string;
38
- disabledField: string;
39
- cacheChecksum: any;
40
- loading$: BehaviorSubject<boolean>;
41
- required: boolean;
42
- set _required(val: boolean | '' | undefined | null);
43
- set _validator(value: SdCustomValidator | undefined);
44
- inlineError?: string;
45
- set _inlineError(val: string);
46
- set disabled(val: boolean | '' | undefined | null);
47
- viewed: boolean;
48
- set _viewed(val: boolean | '' | undefined | null);
49
- viewedText?: Observable<string>;
50
- hyperlink?: string | null;
51
- multiple: boolean;
52
- set _multiple(val: boolean | '' | undefined | null);
53
- limit: number;
54
- filtered: boolean;
55
- itemDef?: SdItemDefDefDirective;
56
- modelChange: EventEmitter<any>;
57
- sdChange: EventEmitter<any>;
58
- sdSelection: EventEmitter<SdSelectionData<any>>;
59
- selectedItems?: Observable<any[]>;
60
- filteredItems?: Observable<any[]>;
56
+ loading: import("@angular/core").WritableSignal<boolean>;
57
+ focused: import("@angular/core").WritableSignal<boolean>;
61
58
  allSelected: boolean;
62
- sdLabelDef?: SdLabelDefDirective;
63
- sdViewDef?: SdViewDefDirective;
64
- isFocused: boolean;
65
- tooltip?: string;
66
- constructor(ref: ChangeDetectorRef, formConfig: ISdFormConfiguration);
59
+ actualItems: Signal<SdSearch | T[] | null | undefined>;
60
+ filteredItems: import("@angular/core").WritableSignal<T[]>;
61
+ selectedItems: import("@angular/core").WritableSignal<T[]>;
62
+ display: import("@angular/core").WritableSignal<string>;
63
+ calculatedPanelWidth: import("@angular/core").WritableSignal<string | number>;
64
+ normalizedValue: Signal<string | number | boolean | (string | number | boolean)[] | null | undefined>;
65
+ filtered: Signal<boolean>;
66
+ delayTime: Signal<0 | 500>;
67
+ itemValue: (item: T) => unknown;
68
+ itemDisplay: (item: T) => string;
69
+ itemDisabled: (item: T) => boolean;
70
+ setNestedValue: (obj: any, path: string, value: any) => void;
71
+ tooltip: Signal<string>;
72
+ updatePanelWidth: () => void;
73
+ constructor();
67
74
  ngOnInit(): void;
68
- ngAfterViewInit(): void;
69
- ngOnDestroy(): void;
70
75
  customInlineErrorValidator(): ValidatorFn;
71
76
  onSelectionChange: (change: MatSelectChange) => void;
72
77
  reValidate: () => void;
@@ -74,8 +79,6 @@ export declare class SdSelect implements OnInit, AfterViewInit, OnDestroy {
74
79
  onClick: () => void;
75
80
  focus: () => void;
76
81
  onOpenedChange: (isOpened: boolean) => void;
77
- onOptionChange: (tooltip: MatTooltip) => void;
78
- trackBy: (index: number, item: any) => any;
79
- static ɵfac: i0.ɵɵFactoryDeclaration<SdSelect, [null, { optional: true; }]>;
80
- static ɵcmp: i0.ɵɵComponentDeclaration<SdSelect, "sd-select", never, { "_autoId": { "alias": "autoId"; "required": false; }; "name": { "alias": "name"; "required": false; }; "appearance": { "alias": "appearance"; "required": false; }; "_hideInlineError": { "alias": "hideInlineError"; "required": false; }; "size": { "alias": "size"; "required": false; }; "form": { "alias": "form"; "required": false; }; "_label": { "alias": "label"; "required": false; }; "_helperText": { "alias": "helperText"; "required": false; }; "placeholder": { "alias": "placeholder"; "required": false; }; "model": { "alias": "model"; "required": false; }; "items": { "alias": "items"; "required": false; }; "valueField": { "alias": "valueField"; "required": true; }; "displayField": { "alias": "displayField"; "required": true; }; "disabledField": { "alias": "disabledField"; "required": false; }; "cacheChecksum": { "alias": "cacheChecksum"; "required": false; }; "_required": { "alias": "required"; "required": false; }; "_validator": { "alias": "validator"; "required": false; }; "_inlineError": { "alias": "inlineError"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "_viewed": { "alias": "viewed"; "required": false; }; "hyperlink": { "alias": "hyperlink"; "required": false; }; "_multiple": { "alias": "multiple"; "required": false; }; "limit": { "alias": "limit"; "required": false; }; }, { "modelChange": "modelChange"; "sdChange": "sdChange"; "sdSelection": "sdSelection"; }, ["itemDef", "sdLabelDef", "sdViewDef"], never, true, never>;
82
+ static ɵfac: i0.ɵɵFactoryDeclaration<SdSelect<any>, never>;
83
+ static ɵcmp: i0.ɵɵComponentDeclaration<SdSelect<any>, "sd-select", never, { "autoIdInput": { "alias": "autoId"; "required": false; "isSignal": true; }; "name": { "alias": "name"; "required": false; "isSignal": true; }; "size": { "alias": "size"; "required": false; "isSignal": true; }; "form": { "alias": "form"; "required": false; "isSignal": true; }; "label": { "alias": "label"; "required": false; "isSignal": true; }; "helperText": { "alias": "helperText"; "required": false; "isSignal": true; }; "placeholder": { "alias": "placeholder"; "required": false; "isSignal": true; }; "valueField": { "alias": "valueField"; "required": true; "isSignal": true; }; "displayField": { "alias": "displayField"; "required": true; "isSignal": true; }; "disabledField": { "alias": "disabledField"; "required": false; "isSignal": true; }; "cacheChecksum": { "alias": "cacheChecksum"; "required": false; "isSignal": true; }; "limit": { "alias": "limit"; "required": false; "isSignal": true; }; "hyperlink": { "alias": "hyperlink"; "required": false; "isSignal": true; }; "minWidthPanel": { "alias": "minWidthPanel"; "required": false; "isSignal": true; }; "hideInlineError": { "alias": "hideInlineError"; "required": false; "isSignal": true; }; "required": { "alias": "required"; "required": false; "isSignal": true; }; "disabled": { "alias": "disabled"; "required": false; "isSignal": true; }; "viewed": { "alias": "viewed"; "required": false; "isSignal": true; }; "multiple": { "alias": "multiple"; "required": false; "isSignal": true; }; "validator": { "alias": "validator"; "required": false; "isSignal": true; }; "inlineError": { "alias": "inlineError"; "required": false; "isSignal": true; }; "appearanceInput": { "alias": "appearance"; "required": false; "isSignal": true; }; "floatLabel": { "alias": "floatLabel"; "required": false; "isSignal": true; }; "items": { "alias": "items"; "required": false; "isSignal": true; }; "valueModel": { "alias": "model"; "required": false; "isSignal": true; }; }, { "valueModel": "modelChange"; "sdChange": "sdChange"; "sdSelection": "sdSelection"; }, ["sdLabelTemplate", "sdValueTemplate", "itemDef", "sdViewDef"], ["[sdLabel]"], true, never>;
81
84
  }
@@ -1,51 +1,48 @@
1
- import { AfterViewInit, ChangeDetectorRef, ElementRef, EventEmitter, OnDestroy, OnInit } from '@angular/core';
2
- import { FormGroup, NgForm, ValidatorFn } from '@angular/forms';
3
- import { MatFormFieldAppearance } from '@angular/material/form-field';
1
+ import { AfterViewInit, ElementRef, OnDestroy, OnInit } from '@angular/core';
2
+ import { FormGroup, ValidatorFn } from '@angular/forms';
3
+ import { FloatLabelType, MatFormFieldAppearance } from '@angular/material/form-field';
4
4
  import { SdLabelDefDirective, SdSuffixDefDirective, SdViewDefDirective } from '@sd-angular/core/forms/directives';
5
- import { ISdFormConfiguration, SdCustomValidator, SdFormControl } from '@sd-angular/core/forms/models';
5
+ import { SdCustomValidator, SdFormControl } from '@sd-angular/core/forms/models';
6
6
  import { SdSize } from '@sd-angular/core/utilities';
7
7
  import * as i0 from "@angular/core";
8
8
  export declare class SdTextarea implements OnInit, AfterViewInit, OnDestroy {
9
9
  #private;
10
- private ref;
11
- private formConfig;
12
10
  id: string;
13
- autoId?: string;
14
- set _autoId(val: string | undefined | null);
15
- set name(val: string | undefined);
16
- size?: SdSize;
17
- appearance: MatFormFieldAppearance;
18
- set form(val: NgForm | FormGroup | undefined | null);
19
- label?: string;
20
- set _label(val: string | undefined);
21
- helperText?: string;
22
- set _helperText(val: string | undefined);
23
- placeholder: string;
24
- rows: number;
25
- set model(value: any);
26
- modelChange: EventEmitter<any>;
27
- sdChange: EventEmitter<any>;
28
- hideInlineError: boolean;
29
- set _hideInlineError(val: boolean | '' | undefined | null);
30
- required: boolean;
31
- set _required(val: boolean | '' | undefined | null);
32
- maxlength: number | null;
33
- set _maxlength(val: number | undefined | null);
34
- set pattern(val: string);
35
- set validator(validator: SdCustomValidator | undefined);
36
- inlineError?: string;
37
- set _inlineError(val: string);
38
- set disabled(val: boolean | '' | undefined | null);
39
- viewed: boolean;
40
- set _viewed(val: boolean | '' | undefined | null);
41
- set _autoHeight(val: boolean | '');
42
- textarea: ElementRef;
43
- sdViewDef?: SdViewDefDirective;
44
- sdLabelDef?: SdLabelDefDirective;
45
- sdSuffixDef?: SdSuffixDefDirective;
46
- isFocused: boolean;
11
+ textareaRef: import("@angular/core").Signal<ElementRef<HTMLTextAreaElement> | undefined>;
12
+ sdViewDef: import("@angular/core").Signal<SdViewDefDirective | undefined>;
13
+ sdLabelDef: import("@angular/core").Signal<SdLabelDefDirective | undefined>;
14
+ sdSuffixDef: import("@angular/core").Signal<SdSuffixDefDirective | undefined>;
15
+ autoIdInput: import("@angular/core").InputSignal<string | null | undefined>;
16
+ autoId: import("@angular/core").Signal<string | undefined>;
17
+ name: import("@angular/core").InputSignal<string>;
18
+ size: import("@angular/core").InputSignal<SdSize>;
19
+ form: import("@angular/core").InputSignalWithTransform<FormGroup<any> | undefined, any>;
20
+ label: import("@angular/core").InputSignalWithTransform<string | undefined, string | null | undefined>;
21
+ helperText: import("@angular/core").InputSignalWithTransform<string | undefined, string | null | undefined>;
22
+ placeholder: import("@angular/core").InputSignalWithTransform<string | undefined, string | null | undefined>;
23
+ rows: import("@angular/core").InputSignal<number>;
24
+ hideInlineError: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
25
+ required: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
26
+ disabled: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
27
+ viewed: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
28
+ autoHeight: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
29
+ maxlength: import("@angular/core").InputSignalWithTransform<number | null, unknown>;
30
+ pattern: import("@angular/core").InputSignalWithTransform<string | undefined, string | null | undefined>;
31
+ validator: import("@angular/core").InputSignal<SdCustomValidator | undefined>;
32
+ inlineError: import("@angular/core").InputSignalWithTransform<string | undefined, string | null | undefined>;
33
+ /**
34
+ * Tổng hợp error message để hiển thị trong tooltip khi hideInlineError = true.
35
+ * Dùng getter (không phải computed) vì formControl.errors không phải Angular signal.
36
+ */
37
+ get errorTooltipMessage(): string | undefined;
38
+ appearanceInput: import("@angular/core").InputSignal<MatFormFieldAppearance | undefined>;
39
+ appearance: import("@angular/core").Signal<MatFormFieldAppearance>;
40
+ floatLabel: import("@angular/core").InputSignal<FloatLabelType>;
41
+ valueModel: import("@angular/core").ModelSignal<any>;
42
+ sdChange: import("@angular/core").OutputEmitterRef<any>;
47
43
  formControl: SdFormControl;
48
- constructor(ref: ChangeDetectorRef, formConfig: ISdFormConfiguration);
44
+ isFocused: boolean;
45
+ constructor();
49
46
  ngOnInit(): void;
50
47
  ngAfterViewInit(): void;
51
48
  ngOnDestroy(): void;
@@ -55,6 +52,6 @@ export declare class SdTextarea implements OnInit, AfterViewInit, OnDestroy {
55
52
  blur: () => void;
56
53
  focus: () => void;
57
54
  customInlineErrorValidator(): ValidatorFn;
58
- static ɵfac: i0.ɵɵFactoryDeclaration<SdTextarea, [null, { optional: true; }]>;
59
- static ɵcmp: i0.ɵɵComponentDeclaration<SdTextarea, "sd-textarea", never, { "_autoId": { "alias": "autoId"; "required": false; }; "name": { "alias": "name"; "required": false; }; "size": { "alias": "size"; "required": false; }; "appearance": { "alias": "appearance"; "required": false; }; "form": { "alias": "form"; "required": false; }; "_label": { "alias": "label"; "required": false; }; "_helperText": { "alias": "helperText"; "required": false; }; "placeholder": { "alias": "placeholder"; "required": false; }; "rows": { "alias": "rows"; "required": false; }; "model": { "alias": "model"; "required": false; }; "_hideInlineError": { "alias": "hideInlineError"; "required": false; }; "_required": { "alias": "required"; "required": false; }; "_maxlength": { "alias": "maxlength"; "required": false; }; "pattern": { "alias": "pattern"; "required": false; }; "validator": { "alias": "validator"; "required": false; }; "_inlineError": { "alias": "inlineError"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "_viewed": { "alias": "viewed"; "required": false; }; "_autoHeight": { "alias": "autoHeight"; "required": false; }; }, { "modelChange": "modelChange"; "sdChange": "sdChange"; }, ["sdViewDef", "sdLabelDef", "sdSuffixDef"], never, true, never>;
55
+ static ɵfac: i0.ɵɵFactoryDeclaration<SdTextarea, never>;
56
+ static ɵcmp: i0.ɵɵComponentDeclaration<SdTextarea, "sd-textarea", never, { "autoIdInput": { "alias": "autoId"; "required": false; "isSignal": true; }; "name": { "alias": "name"; "required": false; "isSignal": true; }; "size": { "alias": "size"; "required": false; "isSignal": true; }; "form": { "alias": "form"; "required": false; "isSignal": true; }; "label": { "alias": "label"; "required": false; "isSignal": true; }; "helperText": { "alias": "helperText"; "required": false; "isSignal": true; }; "placeholder": { "alias": "placeholder"; "required": false; "isSignal": true; }; "rows": { "alias": "rows"; "required": false; "isSignal": true; }; "hideInlineError": { "alias": "hideInlineError"; "required": false; "isSignal": true; }; "required": { "alias": "required"; "required": false; "isSignal": true; }; "disabled": { "alias": "disabled"; "required": false; "isSignal": true; }; "viewed": { "alias": "viewed"; "required": false; "isSignal": true; }; "autoHeight": { "alias": "autoHeight"; "required": false; "isSignal": true; }; "maxlength": { "alias": "maxlength"; "required": false; "isSignal": true; }; "pattern": { "alias": "pattern"; "required": false; "isSignal": true; }; "validator": { "alias": "validator"; "required": false; "isSignal": true; }; "inlineError": { "alias": "inlineError"; "required": false; "isSignal": true; }; "appearanceInput": { "alias": "appearance"; "required": false; "isSignal": true; }; "floatLabel": { "alias": "floatLabel"; "required": false; "isSignal": true; }; "valueModel": { "alias": "model"; "required": false; "isSignal": true; }; }, { "valueModel": "modelChange"; "sdChange": "sdChange"; }, ["sdViewDef", "sdLabelDef", "sdSuffixDef"], never, true, never>;
60
57
  }
@@ -1,4 +1,4 @@
1
- export * from '@sd-angular/core/modules/oidc';
1
+ export * from '@sd-angular/core/modules/keycloak';
2
2
  export * from '@sd-angular/core/modules/permission';
3
3
  export * from '@sd-angular/core/modules/auth';
4
4
  export * from '@sd-angular/core/modules/layout';
@@ -0,0 +1,4 @@
1
+ export * from './keycloak.configuration';
2
+ export * from './keycloak.service';
3
+ export * from './keycloak.interceptor';
4
+ export * from './keycloak.module';
@@ -0,0 +1,11 @@
1
+ import { InjectionToken } from '@angular/core';
2
+ export interface SdKeycloakTenantConfig {
3
+ url: string;
4
+ realm: string;
5
+ clientId: string;
6
+ secureRoutes?: string[];
7
+ }
8
+ export interface ISdKeycloakConfiguration {
9
+ loadTenantConfig: () => Promise<SdKeycloakTenantConfig>;
10
+ }
11
+ export declare const SD_KEYCLOAK_CONFIGURATION: InjectionToken<ISdKeycloakConfiguration>;
@@ -0,0 +1,2 @@
1
+ import { HttpInterceptorFn } from '@angular/common/http';
2
+ export declare const SdKeycloakInterceptor: HttpInterceptorFn;