@sd-angular/core 19.0.0-beta.6 → 19.0.0-beta.60

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 (219) hide show
  1. package/README.md +686 -33
  2. package/assets/scss/ckeditor5.scss +60 -2
  3. package/assets/scss/core/bootstrap.scss +17 -0
  4. package/assets/scss/core/form.scss +4 -1
  5. package/assets/scss/core/grid.scss +40 -0
  6. package/assets/scss/sd-core.scss +1 -0
  7. package/components/avatar/index.d.ts +1 -0
  8. package/components/avatar/src/avatar.component.d.ts +19 -0
  9. package/components/badge/src/badge.component.d.ts +77 -19
  10. package/components/button/src/button.component.d.ts +30 -28
  11. package/components/code-editor/index.d.ts +1 -0
  12. package/components/code-editor/src/code-editor.component.d.ts +25 -0
  13. package/components/document-builder/index.d.ts +1 -0
  14. package/components/document-builder/src/document-builder.component.d.ts +12 -41
  15. package/components/document-builder/src/document-builder.model.d.ts +14 -11
  16. package/components/document-builder/src/plugins/block-space/block-space.plugin.d.ts +9 -0
  17. package/components/document-builder/src/plugins/ck-comment/ck-comment.plugin.d.ts +44 -0
  18. package/components/document-builder/src/plugins/ck-comment/ck-comment.plugin.model.d.ts +57 -0
  19. package/components/document-builder/src/plugins/heading/heading.plugin.d.ts +1 -0
  20. package/components/document-builder/src/plugins/highlight-range/highlight-range.plugin.d.ts +4 -0
  21. package/components/document-builder/src/plugins/image-custom/image-custom.plugin.d.ts +31 -0
  22. package/components/document-builder/src/plugins/index.d.ts +7 -2
  23. package/components/document-builder/src/plugins/page-orientation/page-orientation.plugin.d.ts +2 -2
  24. package/components/document-builder/src/plugins/paste-handler/filters/bookmark.d.ts +14 -0
  25. package/components/document-builder/src/plugins/paste-handler/filters/br.d.ts +15 -0
  26. package/components/document-builder/src/plugins/paste-handler/filters/image.d.ts +25 -0
  27. package/components/document-builder/src/plugins/paste-handler/filters/list.d.ts +29 -0
  28. package/components/document-builder/src/plugins/paste-handler/filters/parse.d.ts +35 -0
  29. package/components/document-builder/src/plugins/paste-handler/filters/removeboldwrapper.d.ts +15 -0
  30. package/components/document-builder/src/plugins/paste-handler/filters/removegooglesheetstag.d.ts +15 -0
  31. package/components/document-builder/src/plugins/paste-handler/filters/removeinvalidtablewidth.d.ts +15 -0
  32. package/components/document-builder/src/plugins/paste-handler/filters/removemsattributes.d.ts +15 -0
  33. package/components/document-builder/src/plugins/paste-handler/filters/removestyleblock.d.ts +15 -0
  34. package/components/document-builder/src/plugins/paste-handler/filters/removexmlns.d.ts +15 -0
  35. package/components/document-builder/src/plugins/paste-handler/filters/replacemsfootnotes.d.ts +54 -0
  36. package/components/document-builder/src/plugins/paste-handler/filters/replacetabswithinprewithspaces.d.ts +24 -0
  37. package/components/document-builder/src/plugins/paste-handler/filters/space.d.ts +27 -0
  38. package/components/document-builder/src/plugins/paste-handler/filters/table.d.ts +16 -0
  39. package/components/document-builder/src/plugins/paste-handler/filters/utils.d.ts +25 -0
  40. package/components/document-builder/src/plugins/paste-handler/index.d.ts +35 -0
  41. package/components/document-builder/src/plugins/paste-handler/normalizers/googledocsnormalizer.d.ts +31 -0
  42. package/components/document-builder/src/plugins/paste-handler/normalizers/googlesheetsnormalizer.d.ts +31 -0
  43. package/components/document-builder/src/plugins/paste-handler/normalizers/mswordnormalizer.d.ts +29 -0
  44. package/components/document-builder/src/plugins/paste-handler/types.d.ts +30 -0
  45. package/components/document-builder/src/plugins/table-custom/index.d.ts +34 -0
  46. package/components/document-builder/src/plugins/variable/variable.plugin.d.ts +39 -0
  47. package/components/index.d.ts +4 -0
  48. package/components/mini-editor/index.d.ts +2 -0
  49. package/components/mini-editor/src/mini-editor.component.d.ts +90 -0
  50. package/components/mini-editor/src/mini-editor.model.d.ts +44 -0
  51. package/components/section/src/section.component.d.ts +10 -11
  52. package/components/side-drawer/src/side-drawer.component.d.ts +11 -24
  53. package/components/tab-router/src/components/tab-router-item/tab-router-item.component.d.ts +4 -1
  54. package/components/tab-router/src/components/tab-router-outlet/tab-router-outlet.component.d.ts +3 -15
  55. package/components/table/src/components/column-filter/column-filter.component.d.ts +3 -3
  56. package/components/table/src/components/desktop-cell/desktop-cell.component.d.ts +12 -2
  57. package/components/table/src/components/desktop-cell-view/desktop-cell-view.component.d.ts +12 -2
  58. package/components/table/src/components/external-filter/external-filter.component.d.ts +1 -1
  59. package/components/table/src/components/selector-action/action-filter.pipe.d.ts +11 -10
  60. package/components/table/src/components/selector-action/selector-action.component.d.ts +5 -3
  61. package/components/table/src/directives/index.d.ts +2 -0
  62. package/components/table/src/directives/sd-table-column-filter-def.directive.d.ts +9 -0
  63. package/components/table/src/directives/sticky-shadow.directive.d.ts +17 -0
  64. package/components/table/src/models/table-column.model.d.ts +34 -34
  65. package/components/table/src/models/table-command.model.d.ts +7 -3
  66. package/components/table/src/models/table-item.model.d.ts +5 -4
  67. package/components/table/src/models/table-option-config.model.d.ts +5 -0
  68. package/components/table/src/models/table-option-export.model.d.ts +3 -2
  69. package/components/table/src/models/table-option-selector.model.d.ts +11 -10
  70. package/components/table/src/models/table-option.model.d.ts +10 -9
  71. package/components/table/src/services/index.d.ts +3 -0
  72. package/components/table/src/services/table-export/table-export.service.d.ts +26 -0
  73. package/components/table/src/services/table-filter/table-filter.model.d.ts +5 -4
  74. package/components/table/src/services/table-format/table-format.service.d.ts +16 -0
  75. package/components/table/src/table.component.d.ts +39 -53
  76. package/components/upload-file/src/configurations/upload-file.configuration.d.ts +1 -1
  77. package/components/upload-file/src/services/upload-file.service.d.ts +0 -1
  78. package/components/upload-file/src/upload-file.component.d.ts +49 -54
  79. package/components/view/index.d.ts +1 -0
  80. package/components/view/src/view.component.d.ts +16 -0
  81. package/components/workflow/src/models/form-generic-component.model.d.ts +5 -4
  82. package/components/workflow/src/models/index.d.ts +1 -0
  83. package/directives/index.d.ts +1 -0
  84. package/directives/src/sd-href.directive.d.ts +9 -0
  85. package/fesm2022/sd-angular-core-components-avatar.mjs +103 -0
  86. package/fesm2022/sd-angular-core-components-avatar.mjs.map +1 -0
  87. package/fesm2022/sd-angular-core-components-badge.mjs +101 -91
  88. package/fesm2022/sd-angular-core-components-badge.mjs.map +1 -1
  89. package/fesm2022/sd-angular-core-components-button.mjs +70 -96
  90. package/fesm2022/sd-angular-core-components-button.mjs.map +1 -1
  91. package/fesm2022/sd-angular-core-components-code-editor.mjs +129 -0
  92. package/fesm2022/sd-angular-core-components-code-editor.mjs.map +1 -0
  93. package/fesm2022/sd-angular-core-components-document-builder.mjs +3994 -608
  94. package/fesm2022/sd-angular-core-components-document-builder.mjs.map +1 -1
  95. package/fesm2022/sd-angular-core-components-history.mjs +1 -1
  96. package/fesm2022/sd-angular-core-components-history.mjs.map +1 -1
  97. package/fesm2022/sd-angular-core-components-import-excel.mjs +1 -1
  98. package/fesm2022/sd-angular-core-components-import-excel.mjs.map +1 -1
  99. package/fesm2022/sd-angular-core-components-mini-editor.mjs +326 -0
  100. package/fesm2022/sd-angular-core-components-mini-editor.mjs.map +1 -0
  101. package/fesm2022/sd-angular-core-components-preview.mjs +1 -1
  102. package/fesm2022/sd-angular-core-components-preview.mjs.map +1 -1
  103. package/fesm2022/sd-angular-core-components-section.mjs +24 -42
  104. package/fesm2022/sd-angular-core-components-section.mjs.map +1 -1
  105. package/fesm2022/sd-angular-core-components-side-drawer.mjs +78 -84
  106. package/fesm2022/sd-angular-core-components-side-drawer.mjs.map +1 -1
  107. package/fesm2022/sd-angular-core-components-tab-router.mjs +152 -226
  108. package/fesm2022/sd-angular-core-components-tab-router.mjs.map +1 -1
  109. package/fesm2022/sd-angular-core-components-table.mjs +1129 -1131
  110. package/fesm2022/sd-angular-core-components-table.mjs.map +1 -1
  111. package/fesm2022/sd-angular-core-components-upload-file.mjs +339 -444
  112. package/fesm2022/sd-angular-core-components-upload-file.mjs.map +1 -1
  113. package/fesm2022/sd-angular-core-components-view.mjs +45 -0
  114. package/fesm2022/sd-angular-core-components-view.mjs.map +1 -0
  115. package/fesm2022/sd-angular-core-components-workflow.mjs +47 -57
  116. package/fesm2022/sd-angular-core-components-workflow.mjs.map +1 -1
  117. package/fesm2022/sd-angular-core-components.mjs +4 -0
  118. package/fesm2022/sd-angular-core-components.mjs.map +1 -1
  119. package/fesm2022/sd-angular-core-directives.mjs +80 -27
  120. package/fesm2022/sd-angular-core-directives.mjs.map +1 -1
  121. package/fesm2022/sd-angular-core-forms-autocomplete.mjs +274 -364
  122. package/fesm2022/sd-angular-core-forms-autocomplete.mjs.map +1 -1
  123. package/fesm2022/sd-angular-core-forms-chip-calendar.mjs +5 -2
  124. package/fesm2022/sd-angular-core-forms-chip-calendar.mjs.map +1 -1
  125. package/fesm2022/sd-angular-core-forms-chip.mjs +5 -2
  126. package/fesm2022/sd-angular-core-forms-chip.mjs.map +1 -1
  127. package/fesm2022/sd-angular-core-forms-date-range.mjs +160 -245
  128. package/fesm2022/sd-angular-core-forms-date-range.mjs.map +1 -1
  129. package/fesm2022/sd-angular-core-forms-date.mjs +153 -273
  130. package/fesm2022/sd-angular-core-forms-date.mjs.map +1 -1
  131. package/fesm2022/sd-angular-core-forms-datetime.mjs +152 -288
  132. package/fesm2022/sd-angular-core-forms-datetime.mjs.map +1 -1
  133. package/fesm2022/sd-angular-core-forms-input-number.mjs +191 -338
  134. package/fesm2022/sd-angular-core-forms-input-number.mjs.map +1 -1
  135. package/fesm2022/sd-angular-core-forms-input.mjs +149 -287
  136. package/fesm2022/sd-angular-core-forms-input.mjs.map +1 -1
  137. package/fesm2022/sd-angular-core-forms-radio.mjs +3 -2
  138. package/fesm2022/sd-angular-core-forms-radio.mjs.map +1 -1
  139. package/fesm2022/sd-angular-core-forms-select.mjs +375 -448
  140. package/fesm2022/sd-angular-core-forms-select.mjs.map +1 -1
  141. package/fesm2022/sd-angular-core-forms-textarea.mjs +138 -227
  142. package/fesm2022/sd-angular-core-forms-textarea.mjs.map +1 -1
  143. package/fesm2022/sd-angular-core-modules-keycloak.mjs +126 -0
  144. package/fesm2022/sd-angular-core-modules-keycloak.mjs.map +1 -0
  145. package/fesm2022/sd-angular-core-modules-layout.mjs +454 -453
  146. package/fesm2022/sd-angular-core-modules-layout.mjs.map +1 -1
  147. package/fesm2022/sd-angular-core-modules.mjs +1 -1
  148. package/fesm2022/sd-angular-core-services-api.mjs +5 -10
  149. package/fesm2022/sd-angular-core-services-api.mjs.map +1 -1
  150. package/fesm2022/sd-angular-core-services-confirm.mjs +2 -2
  151. package/fesm2022/sd-angular-core-services-confirm.mjs.map +1 -1
  152. package/fesm2022/sd-angular-core-services-docx.mjs +173 -0
  153. package/fesm2022/sd-angular-core-services-docx.mjs.map +1 -0
  154. package/fesm2022/sd-angular-core-services-notify.mjs +2 -2
  155. package/fesm2022/sd-angular-core-services-notify.mjs.map +1 -1
  156. package/fesm2022/sd-angular-core-services.mjs +1 -0
  157. package/fesm2022/sd-angular-core-services.mjs.map +1 -1
  158. package/fesm2022/sd-angular-core-utilities-extensions.mjs +21 -45
  159. package/fesm2022/sd-angular-core-utilities-extensions.mjs.map +1 -1
  160. package/fesm2022/sd-angular-core-utilities-models.mjs +15 -1
  161. package/fesm2022/sd-angular-core-utilities-models.mjs.map +1 -1
  162. package/forms/autocomplete/src/autocomplete.component.d.ts +50 -55
  163. package/forms/chip/src/chip.component.d.ts +3 -2
  164. package/forms/chip-calendar/src/chip-calendar.component.d.ts +3 -2
  165. package/forms/date/src/date.component.d.ts +43 -46
  166. package/forms/date-range/src/date-range.component.d.ts +30 -34
  167. package/forms/datetime/src/datetime.component.d.ts +43 -49
  168. package/forms/input/src/input.component.d.ts +48 -57
  169. package/forms/input-number/src/input-number.component.d.ts +48 -54
  170. package/forms/select/src/select.component.d.ts +62 -64
  171. package/forms/textarea/src/textarea.component.d.ts +36 -42
  172. package/modules/index.d.ts +1 -1
  173. package/modules/keycloak/index.d.ts +4 -0
  174. package/modules/keycloak/keycloak.configuration.d.ts +11 -0
  175. package/modules/keycloak/keycloak.interceptor.d.ts +2 -0
  176. package/modules/keycloak/keycloak.module.d.ts +18 -0
  177. package/modules/keycloak/keycloak.service.d.ts +14 -0
  178. package/modules/layout/components/layout-main/layout-main.component.d.ts +7 -12
  179. package/modules/layout/components/page/page.component.d.ts +5 -7
  180. package/modules/layout/components/sidebar-v1/components/sidebar/sidebar.component.d.ts +22 -29
  181. package/modules/layout/components/sidebar-v1/components/user/user.component.d.ts +11 -17
  182. package/modules/layout/components/sidebar-v1/main.component.d.ts +14 -14
  183. package/modules/layout/configurations/layout.configuration.d.ts +46 -3
  184. package/modules/layout/modules/forbidden/pages/root/root.component.d.ts +3 -8
  185. package/modules/layout/modules/home/components/home-page/home-page.component.d.ts +2 -5
  186. package/modules/layout/modules/not-found/pages/root/root.component.d.ts +3 -8
  187. package/modules/layout/pipes/high-light-search.pipe.d.ts +1 -1
  188. package/modules/layout/services/index.d.ts +1 -0
  189. package/modules/layout/services/layout.service.d.ts +10 -0
  190. package/modules/layout/services/menu/menu.model.d.ts +2 -0
  191. package/modules/layout/services/storage/storage.service.d.ts +0 -3
  192. package/package.json +93 -70
  193. package/sd-angular-core-19.0.0-beta.60.tgz +0 -0
  194. package/services/api/src/api.model.d.ts +6 -1
  195. package/services/confirm/src/lib/confirm.service.d.ts +1 -0
  196. package/services/docx/index.d.ts +1 -0
  197. package/services/docx/src/lib/docx.model.d.ts +9 -0
  198. package/services/docx/src/lib/docx.service.d.ts +13 -0
  199. package/services/docx/src/public-api.d.ts +2 -0
  200. package/services/index.d.ts +1 -0
  201. package/services/notify/index.d.ts +1 -0
  202. package/services/notify/src/notify.model.d.ts +1 -1
  203. package/services/notify/src/notify.service.d.ts +5 -5
  204. package/utilities/extensions/src/string.extension.d.ts +2 -0
  205. package/utilities/extensions/src/utility.extension.d.ts +1 -0
  206. package/utilities/models/index.d.ts +3 -0
  207. package/utilities/models/src/filter.model.d.ts +14 -2
  208. package/utilities/models/src/icon.model.d.ts +2 -0
  209. package/utilities/models/src/nested-key-of.model.d.ts +5 -0
  210. package/utilities/models/src/pattern.model.d.ts +1 -1
  211. package/utilities/models/src/unwrap-signal.model.d.ts +6 -0
  212. package/components/document-builder/src/plugins/comment/comment.plugin.d.ts +0 -4
  213. package/components/document-builder/src/plugins/table-fit/table-fit.plugin.d.ts +0 -4
  214. package/fesm2022/sd-angular-core-modules-oidc.mjs +0 -127
  215. package/fesm2022/sd-angular-core-modules-oidc.mjs.map +0 -1
  216. package/modules/oidc/dynamic-sts.loader.d.ts +0 -11
  217. package/modules/oidc/index.d.ts +0 -2
  218. package/modules/oidc/oidc.configuration.d.ts +0 -11
  219. package/modules/oidc/oidc.module.d.ts +0 -14
@@ -1,9 +1,13 @@
1
- import { SdColor } from '@sd-angular/core/utilities/models';
1
+ import { MaterialIconFontSet, SdColor } from '@sd-angular/core/utilities/models';
2
+ export interface SdTableCommandOption<T = any> {
3
+ align?: 'left' | 'right';
4
+ commands?: SdTableCommand<T>[];
5
+ }
2
6
  export type SdTableCommand<T = any> = SdTableCommandNormal<T> | SdTableCommandChildren<T>;
3
7
  export interface SdTableCommandNormal<T = any> {
4
8
  color?: SdColor;
5
9
  icon?: string | ((rowData: T) => string);
6
- fontSet?: 'material-icons' | 'material-icons-outlined' | 'material-icons-round' | 'material-icons-sharp';
10
+ fontSet?: MaterialIconFontSet;
7
11
  title?: string | ((rowData: T) => string);
8
12
  disabled?: boolean | ((rowData: T) => boolean);
9
13
  hidden?: boolean | ((rowData: T) => boolean | Promise<boolean>);
@@ -12,7 +16,7 @@ export interface SdTableCommandNormal<T = any> {
12
16
  }
13
17
  export interface SdTableCommandChildren<T = any> {
14
18
  icon?: string | ((rowData: T) => string);
15
- fontSet?: 'material-icons' | 'material-icons-outlined' | 'material-icons-round' | 'material-icons-sharp';
19
+ fontSet?: MaterialIconFontSet;
16
20
  title?: string | ((rowData: T) => string);
17
21
  disabled?: boolean | ((rowData: T) => boolean);
18
22
  hidden?: boolean | ((rowData: T) => boolean | Promise<boolean>);
@@ -1,4 +1,5 @@
1
1
  import { SdBadge } from '@sd-angular/core/components/badge';
2
+ import { SdUnwrapSignal } from '@sd-angular/core/utilities/models';
2
3
  export interface SdTableMetaSelector {
3
4
  selectable?: boolean;
4
5
  isSelected?: boolean;
@@ -12,10 +13,10 @@ export interface SdTableMetaExpand {
12
13
  export interface SdTableDisplay {
13
14
  tooltip?: string;
14
15
  badge?: {
15
- type: SdBadge['type'] | undefined | null;
16
- color: SdBadge['color'] | undefined | null;
17
- icon?: string | undefined | null;
18
- title?: string | number | null | undefined;
16
+ type: SdUnwrapSignal<SdBadge['type']>;
17
+ color: SdUnwrapSignal<SdBadge['color']>;
18
+ icon?: SdUnwrapSignal<SdBadge['icon']>;
19
+ title?: SdUnwrapSignal<SdBadge['title']>;
19
20
  };
20
21
  cellStyle?: Record<string, string>;
21
22
  data: string | number | undefined | null;
@@ -14,6 +14,7 @@ export interface ConfiguredColumn {
14
14
  width?: string;
15
15
  invisible?: boolean;
16
16
  fixed?: boolean;
17
+ charLimited?: boolean;
17
18
  }
18
19
  export interface ConfiguredTable {
19
20
  columns?: ConfiguredColumn[];
@@ -27,6 +28,10 @@ export interface ConfiguredTableResult {
27
28
  title?: string;
28
29
  width?: string;
29
30
  }>;
31
+ charLimitedColumn: Record<string, {
32
+ title?: string;
33
+ width?: string;
34
+ }>;
30
35
  firstColumns: SdTableColumn[];
31
36
  secondColumns: SdTableColumn[];
32
37
  firstHeaders: string[];
@@ -1,3 +1,4 @@
1
+ import { SdNestedKeyOf } from '@sd-angular/core/utilities';
1
2
  import { SdTableFilterRequest } from '../services/table-filter/table-filter.model';
2
3
  export type SdTableOptionExport<T = any> = SdTableOptionExportDefault<T> | SdTableOptionExportCustom;
3
4
  export interface SdTableOptionExportDefault<T = any> {
@@ -22,7 +23,7 @@ export interface SdTableOptionExportCustom {
22
23
  onExport: (filterRequest: SdTableFilterRequest) => Promise<void>;
23
24
  }
24
25
  export interface SdTableOptionExportColumn<T = any> {
25
- field: Extract<keyof T, string>;
26
+ field: SdNestedKeyOf<T>;
26
27
  title: string;
27
28
  description?: string;
28
29
  width?: string;
@@ -35,7 +36,7 @@ export interface SdTableOptionExportSheet<T = any> {
35
36
  name: string;
36
37
  items: T[] | (() => T[] | Promise<T[]>);
37
38
  headers: {
38
- value: Extract<keyof T, string>;
39
+ value: SdNestedKeyOf<T>;
39
40
  display: string;
40
41
  }[];
41
42
  }
@@ -1,4 +1,5 @@
1
1
  import { SdButton } from '@sd-angular/core/components/button';
2
+ import { SdUnwrapSignal } from '@sd-angular/core/utilities/models';
2
3
  export interface SdTableOptionSelector<T = any> {
3
4
  visible?: boolean;
4
5
  single?: boolean;
@@ -11,22 +12,22 @@ export interface SdTableOptionSelector<T = any> {
11
12
  export type SdTableAction<T = any> = SdTableActionNormal<T> | SdTableActionChildren<T>;
12
13
  export interface SdTableActionNormal<T = any> {
13
14
  icon?: string;
14
- fontSet?: SdButton['fontSet'];
15
- tooltip?: SdButton['tooltip'];
16
- title?: SdButton['title'];
17
- color?: SdButton['color'];
18
- type?: SdButton['type'];
15
+ fontSet?: SdUnwrapSignal<SdButton['fontSet']>;
16
+ tooltip?: SdUnwrapSignal<SdButton['tooltip']>;
17
+ title?: SdUnwrapSignal<SdButton['title']>;
18
+ color?: SdUnwrapSignal<SdButton['color']>;
19
+ type?: SdUnwrapSignal<SdButton['type']>;
19
20
  hidden?: boolean | ((rowData?: T) => boolean);
20
21
  isGrouped?: boolean;
21
22
  click: (selectedItems?: T[]) => void;
22
23
  }
23
24
  interface SdTableActionChildren<T = any> {
24
25
  icon?: string;
25
- fontSet?: SdButton['fontSet'];
26
- tooltip?: SdButton['tooltip'];
27
- title?: SdButton['title'];
28
- color?: SdButton['color'];
29
- type?: SdButton['type'];
26
+ fontSet?: SdUnwrapSignal<SdButton['fontSet']>;
27
+ tooltip?: SdUnwrapSignal<SdButton['tooltip']>;
28
+ title?: SdUnwrapSignal<SdButton['title']>;
29
+ color?: SdUnwrapSignal<SdButton['color']>;
30
+ type?: SdUnwrapSignal<SdButton['type']>;
30
31
  hidden?: boolean | ((rowData?: T) => boolean);
31
32
  isGrouped?: boolean;
32
33
  children: SdTableActionNormal<T>[];
@@ -1,16 +1,16 @@
1
- import { SdTableColumn } from './table-column.model';
2
- import { SdTableCommand } from './table-command.model';
1
+ import { SdPagingReq } from '@sd-angular/core/utilities';
3
2
  import { SdTableFilterRequest, SdTableOptionFilter } from '../services/table-filter/table-filter.model';
3
+ import { SdTableColumn } from './table-column.model';
4
+ import { SdTableCommand, SdTableCommandOption } from './table-command.model';
5
+ import { TableOptionConfig } from './table-option-config.model';
6
+ import { SdTableOptionExpand } from './table-option-expand.model';
4
7
  import { SdTableOptionExport } from './table-option-export.model';
8
+ import { SdTableOptionGroup } from './table-option-group.model';
9
+ import { SdTableOptionPaginate } from './table-option-paginate.model';
5
10
  import { SdTableOptionReload } from './table-option-reload.model';
6
- import { SdTableOptionExpand } from './table-option-expand.model';
7
11
  import { SdTableOptionSelector } from './table-option-selector.model';
8
- import { SdTableOptionStyle } from './table-option-style.model';
9
- import { SdTableOptionGroup } from './table-option-group.model';
10
12
  import { SdTableOptionSort } from './table-option-sort.model';
11
- import { SdTableOptionPaginate } from './table-option-paginate.model';
12
- import { TableOptionConfig } from './table-option-config.model';
13
- import { SdPagingReq } from '@sd-angular/core/utilities';
13
+ import { SdTableOptionStyle } from './table-option-style.model';
14
14
  export type SdTableOption<T = any> = SdTableLocalOption<T> | SdTableServerOption<T>;
15
15
  interface SdTableBaseOption<T = any> {
16
16
  key?: string;
@@ -24,6 +24,7 @@ interface SdTableBaseOption<T = any> {
24
24
  group?: SdTableOptionGroup<T>;
25
25
  filter?: SdTableOptionFilter;
26
26
  commands?: SdTableCommand<T>[];
27
+ command?: SdTableCommandOption<T>;
27
28
  columns: SdTableColumn<T>[];
28
29
  style?: SdTableOptionStyle<T>;
29
30
  }
@@ -33,7 +34,7 @@ interface SdTableLocalOption<T = any> extends SdTableBaseOption<T> {
33
34
  }
34
35
  interface SdTableServerOption<T = any> extends SdTableBaseOption<T> {
35
36
  type: 'server';
36
- items: (filterRequest: SdTableFilterRequest<T>, pagingReq?: SdPagingReq) => Promise<{
37
+ items: (filterRequest: SdTableFilterRequest<T>, pagingReq: SdPagingReq<T>) => Promise<{
37
38
  items: T[];
38
39
  total: number;
39
40
  }>;
@@ -0,0 +1,3 @@
1
+ export * from './table-export/table-export.service';
2
+ export * from './table-format/table-format.service';
3
+ export * from './config.service';
@@ -0,0 +1,26 @@
1
+ import { SdExcelColumn } from '@sd-angular/core/services';
2
+ import { ConfiguredTableResult } from '../../models/table-option-config.model';
3
+ import { SdTableOption } from '../../models/table-option.model';
4
+ import { SdTableFilterRequest } from '../table-filter/table-filter.model';
5
+ import * as i0 from "@angular/core";
6
+ export interface SdTableExportContext<T = any> {
7
+ option: SdTableOption<T>;
8
+ configuration?: ConfiguredTableResult;
9
+ total: number;
10
+ cacheObjValues: Record<string, Record<string, string>>;
11
+ fetchChunk: (pageNumber: number, pageSize: number) => Promise<T[] | {
12
+ items: any[];
13
+ total: number;
14
+ }>;
15
+ getFilterInfo: () => SdTableFilterRequest;
16
+ }
17
+ export declare class TableExportService {
18
+ #private;
19
+ exporting: import("@angular/core").WritableSignal<boolean>;
20
+ exportTitle: import("@angular/core").WritableSignal<string>;
21
+ exportExcel: (context: SdTableExportContext, columns?: SdExcelColumn[]) => Promise<void>;
22
+ exportCSV: (context: SdTableExportContext, columns?: SdExcelColumn[]) => Promise<void>;
23
+ exportCustom: (context: SdTableExportContext) => void;
24
+ static ɵfac: i0.ɵɵFactoryDeclaration<TableExportService, never>;
25
+ static ɵprov: i0.ɵɵInjectableDeclaration<TableExportService>;
26
+ }
@@ -1,8 +1,8 @@
1
- import { Observable } from 'rxjs';
2
- import { SdTableColumn } from '../../models/table-column.model';
3
1
  import { TemplateRef } from '@angular/core';
4
2
  import { SdSearch } from '@sd-angular/core/forms';
5
- import { SdOperator, SdOrder, SdPagingReq } from '@sd-angular/core/utilities';
3
+ import { SdNestedKeyOf, SdOperator, SdOrder, SdPagingReq } from '@sd-angular/core/utilities';
4
+ import { Observable } from 'rxjs';
5
+ import { SdTableColumn } from '../../models/table-column.model';
6
6
  export interface SdTableQuickFilter {
7
7
  code: string;
8
8
  columnFilter: Record<string, any>;
@@ -20,7 +20,7 @@ export interface TableFilterValue {
20
20
  }
21
21
  export interface SdTableFilterRequest<T = any> {
22
22
  columnOperator: Record<string, SdOperator>;
23
- rawColumnFilter: Record<keyof T, any>;
23
+ rawColumnFilter: Record<SdNestedKeyOf<T>, any>;
24
24
  rawExternalFilter: Record<string, any>;
25
25
  pageNumber: number;
26
26
  pageSize: number;
@@ -68,6 +68,7 @@ interface BaseFilter<TData = any> {
68
68
  hidden?: boolean;
69
69
  defaultOperator?: SdOperator;
70
70
  data?: TData;
71
+ onChange?: (value: any) => void;
71
72
  }
72
73
  interface TextFilter<TData = any> extends BaseFilter<TData> {
73
74
  type: 'string';
@@ -0,0 +1,16 @@
1
+ import { SdTableColumn } from '../../models/table-column.model';
2
+ import { SdTableItem } from '../../models/table-item.model';
3
+ import * as i0 from "@angular/core";
4
+ export declare class TableFormatService {
5
+ #private;
6
+ /**
7
+ * Tải và cache các giá trị từ điển cho cột 'values'
8
+ */
9
+ loadValues(columns: SdTableColumn[], cacheValues: Record<string, any[]>, cacheObjValues: Record<string, Record<string, string>>): Promise<void>;
10
+ /**
11
+ * Chuyển đổi dữ liệu thô thành SdTableItem kèm các thiết lập hiển thị (Display Meta)
12
+ */
13
+ format<T = any>(rawItems: T[], columns: SdTableColumn[], cacheValues: Record<string, any[]>, cacheObjValues: Record<string, Record<string, string>>): Promise<SdTableItem<T>[]>;
14
+ static ɵfac: i0.ɵɵFactoryDeclaration<TableFormatService, never>;
15
+ static ɵprov: i0.ɵɵInjectableDeclaration<TableFormatService>;
16
+ }
@@ -1,19 +1,18 @@
1
- import { AfterViewInit, ChangeDetectorRef, OnDestroy, OnInit, QueryList } from '@angular/core';
1
+ import { AfterViewInit, OnDestroy, OnInit } from '@angular/core';
2
2
  import { MatPaginator, MatPaginatorIntl } from '@angular/material/paginator';
3
3
  import { MatSort } from '@angular/material/sort';
4
4
  import { MatTable } from '@angular/material/table';
5
- import { SdExcelColumn, SdExcelService, SdNotifyService } from '@sd-angular/core/services';
5
+ import { SdExcelColumn } from '@sd-angular/core/services';
6
6
  import { SdTabelCellDefDirective } from './directives/sd-table-cell-def.directive';
7
7
  import { SdMaterialSubInformationDefDirective } from './directives/sd-table-expand-def.directive';
8
8
  import { SdTableFilterDefDirective } from './directives/sd-table-filter-def.directive';
9
9
  import { SdMaterialFooterDefDirective } from './directives/sd-table-footer-def.directive';
10
10
  import { SdTableColumn } from './models/table-column.model';
11
11
  import { SdTableOption } from './models/table-option.model';
12
- import { TableFilterRegister } from './services/table-filter/table-filter.model';
12
+ import { SdTableFilterRequest, TableFilterRegister } from './services/table-filter/table-filter.model';
13
13
  import { SdBaseSecureComponent } from '@sd-angular/core/components/base';
14
14
  import { SdQuickAction } from '@sd-angular/core/components/quick-action';
15
15
  import { SdScrollDirective } from '@sd-angular/core/directives';
16
- import { SdFormatNumberPipe } from '@sd-angular/core/pipes';
17
16
  import { SdOperator } from '@sd-angular/core/utilities';
18
17
  import { ExternalFilterComponent } from './components';
19
18
  import { ConfigComponent } from './components/config/config.component';
@@ -21,8 +20,6 @@ import { SdPopupExport } from './components/popup-export/popup-export.component'
21
20
  import { ISdTableConfiguration } from './configurations';
22
21
  import { SdTableItem } from './models/table-item.model';
23
22
  import { ConfiguredTableResult } from './models/table-option-config.model';
24
- import { ConfigService } from './services/config.service';
25
- import { SdTableFilterService } from './services/table-filter/table-filter.service';
26
23
  import * as i0 from "@angular/core";
27
24
  export declare class MatPaginatorIntlCro extends MatPaginatorIntl {
28
25
  firstPageLabel: string;
@@ -36,60 +33,49 @@ export declare class MatPaginatorIntlCro extends MatPaginatorIntl {
36
33
  }
37
34
  export declare class SdTable<T = unknown> extends SdBaseSecureComponent implements OnInit, AfterViewInit, OnDestroy {
38
35
  #private;
39
- private ref;
40
- private formatNumberPipe;
41
- tableConfiguration: ISdTableConfiguration | undefined;
42
- private configService;
43
- private excelService;
44
- private notifyService;
45
- private gridFilterService;
46
- autoId?: string;
47
- set _autoId(val: string | undefined | null);
48
- table?: MatTable<any>;
49
- configComponent?: ConfigComponent;
50
- sdPopupExport?: SdPopupExport;
51
- scroll?: SdScrollDirective;
36
+ autoIdInput: import("@angular/core").InputSignal<string | null | undefined>;
37
+ autoId: import("@angular/core").Signal<string | undefined>;
38
+ option: import("@angular/core").InputSignal<SdTableOption<T>>;
39
+ table: import("@angular/core").Signal<MatTable<any> | undefined>;
40
+ configComponent: import("@angular/core").Signal<ConfigComponent | undefined>;
41
+ sdPopupExport: import("@angular/core").Signal<SdPopupExport | undefined>;
42
+ scroll: import("@angular/core").Signal<SdScrollDirective | undefined>;
43
+ quickAction: import("@angular/core").Signal<SdQuickAction | undefined>;
44
+ externalFilter: import("@angular/core").Signal<ExternalFilterComponent | undefined>;
45
+ paginator: import("@angular/core").Signal<MatPaginator | undefined>;
46
+ sort: import("@angular/core").Signal<MatSort | undefined>;
47
+ sdSubInformation: import("@angular/core").Signal<SdMaterialSubInformationDefDirective | undefined>;
48
+ sdCellDefs: import("@angular/core").Signal<readonly SdTabelCellDefDirective[]>;
49
+ sdFooterDefs: import("@angular/core").Signal<readonly SdMaterialFooterDefDirective[]>;
50
+ sdFilterDefs: import("@angular/core").Signal<readonly SdTableFilterDefDirective[]>;
51
+ cellDef: import("@angular/core").Signal<Record<string, SdTabelCellDefDirective>>;
52
+ footerDef: import("@angular/core").Signal<Record<string, SdMaterialFooterDefDirective>>;
53
+ hasFooter: import("@angular/core").Signal<boolean>;
54
+ tableOption: import("@angular/core").WritableSignal<SdTableOption<T> | undefined>;
55
+ configuration: import("@angular/core").WritableSignal<ConfiguredTableResult | undefined>;
56
+ items: import("@angular/core").WritableSignal<SdTableItem<T>[]>;
57
+ selectedTableItems: import("@angular/core").WritableSignal<SdTableItem<T>[]>;
58
+ total: import("@angular/core").WritableSignal<number | undefined>;
59
+ loading: import("@angular/core").WritableSignal<boolean>;
60
+ exporting: import("@angular/core").WritableSignal<boolean>;
61
+ isSelectAll: import("@angular/core").WritableSignal<boolean>;
62
+ exportTitle: import("@angular/core").WritableSignal<string>;
63
+ isFiltered: import("@angular/core").WritableSignal<boolean>;
64
+ requireFiltered: import("@angular/core").WritableSignal<boolean>;
52
65
  filterRegister: TableFilterRegister;
53
66
  key: string;
54
- quickAction?: SdQuickAction;
55
- externalFilter?: ExternalFilterComponent;
56
- tableOption: SdTableOption<T>;
57
- configuration?: ConfiguredTableResult;
58
- set option(option: SdTableOption);
59
- items: SdTableItem<T>[];
60
- selectedTableItems: SdTableItem<T>[];
61
- total?: number;
62
- loading: boolean;
63
- isHiddenPaginator: boolean;
64
- set paginator(paginator: MatPaginator);
65
- set sort(sort: MatSort);
66
- sdSubInformation?: SdMaterialSubInformationDefDirective;
67
- sdCellDefs: QueryList<SdTabelCellDefDirective>;
68
- cellDef: Record<string, SdTabelCellDefDirective>;
69
- sdFooterDefs: QueryList<SdMaterialFooterDefDirective>;
70
- footerDef: Record<string, SdMaterialFooterDefDirective>;
71
- hasFooter: boolean;
72
- sdFilterDefs: QueryList<SdTableFilterDefDirective>;
73
- filterDefs: SdTableFilterDefDirective[];
74
67
  columnOperator: Record<string, SdOperator>;
75
68
  columnFilter?: Record<string, any>;
76
- exporting: boolean;
77
- isSelectAll: boolean;
78
- exportTitle: string;
79
69
  cacheValues: Record<string, any[]>;
80
- constructor(ref: ChangeDetectorRef, formatNumberPipe: SdFormatNumberPipe, tableConfiguration: ISdTableConfiguration | undefined, configService: ConfigService, excelService: SdExcelService, notifyService: SdNotifyService, gridFilterService: SdTableFilterService);
70
+ tableConfiguration: ISdTableConfiguration | null;
71
+ constructor();
81
72
  ngOnInit(): void;
82
73
  ngAfterViewInit(): void;
83
74
  ngOnDestroy(): void;
84
- isFiltered: boolean;
85
- requireFiltered: boolean;
75
+ getFilterRequest: () => SdTableFilterRequest;
86
76
  reload: (force?: boolean, scrollTop?: boolean) => Promise<void>;
87
- onExport: (args?: {
88
- columns?: SdExcelColumn[];
89
- isCSV?: boolean;
90
- }) => Promise<void>;
91
- exportExcel: () => void;
92
- exportCSV: () => void;
77
+ exportExcel: (columns?: SdExcelColumn[]) => void;
78
+ exportCSV: (columns?: SdExcelColumn[]) => void;
93
79
  exportCustom: () => void;
94
80
  onFilterChange: () => void;
95
81
  onExpand: (rowData: SdTableItem<T>) => Promise<void>;
@@ -106,6 +92,6 @@ export declare class SdTable<T = unknown> extends SdBaseSecureComponent implemen
106
92
  detectChanges: () => void;
107
93
  onOperatorChange: (column: SdTableColumn, operator: SdOperator) => void;
108
94
  trackBy: (index: number, item: SdTableItem) => string;
109
- static ɵfac: i0.ɵɵFactoryDeclaration<SdTable<any>, [null, null, { optional: true; }, null, null, null, null]>;
110
- static ɵcmp: i0.ɵɵComponentDeclaration<SdTable<any>, "sd-table", never, { "_autoId": { "alias": "autoId"; "required": false; }; "option": { "alias": "option"; "required": false; }; }, {}, ["sdSubInformation", "sdCellDefs", "sdFooterDefs", "sdFilterDefs"], ["[sdTableTop]"], true, never>;
95
+ static ɵfac: i0.ɵɵFactoryDeclaration<SdTable<any>, never>;
96
+ static ɵcmp: i0.ɵɵComponentDeclaration<SdTable<any>, "sd-table", never, { "autoIdInput": { "alias": "autoId"; "required": false; "isSignal": true; }; "option": { "alias": "option"; "required": true; "isSignal": true; }; }, {}, ["sdSubInformation", "sdCellDefs", "sdFooterDefs", "sdFilterDefs"], ["[sdTableTop]"], true, never>;
111
97
  }
@@ -4,7 +4,7 @@ export interface ISdUploadFileConfiguration<TArgs = any> {
4
4
  details: SdUploadFileFuncDetails<TArgs>;
5
5
  download?: SdUploadFileFuncDownload<TArgs>;
6
6
  }
7
- export declare const SD_UPLOAD_FILE_CONFIG: InjectionToken<ISdUploadFileConfiguration<any>>;
7
+ export declare const SD_UPLOAD_FILE_CONFIGURATION: InjectionToken<ISdUploadFileConfiguration<any>>;
8
8
  export type SdUploadFileFuncUpload<TArgs> = (files: File[], args?: TArgs) => Promise<string[]>;
9
9
  export type SdUploadFileFuncDetails<TArgs> = (idOrKey: (string | number)[], args?: TArgs) => Promise<SdUploadFileDetail[]>;
10
10
  export type SdUploadFileFuncDownload<TArgs> = (idOrKey: string | number, args?: TArgs) => Promise<void>;
@@ -1,7 +1,6 @@
1
1
  import * as i0 from "@angular/core";
2
2
  export declare class UploadFileService {
3
3
  #private;
4
- constructor();
5
4
  isHashedKey: (key: string) => boolean;
6
5
  get: (key: string) => File | null;
7
6
  add: (file: File) => string | null;
@@ -1,69 +1,64 @@
1
1
  import { CdkDragDrop } from '@angular/cdk/drag-drop';
2
- import { AfterViewInit, ChangeDetectorRef, ElementRef, EventEmitter, OnDestroy, QueryList } from '@angular/core';
3
- import { FormGroup, NgForm } from '@angular/forms';
2
+ import { ElementRef } from '@angular/core';
3
+ import { FormGroup } from '@angular/forms';
4
4
  import { SdLabelDefDirective } from '@sd-angular/core/forms/directives';
5
5
  import { SdFormControl } from '@sd-angular/core/forms/models';
6
- import { SdConfirmService, SdNotifyService } from '@sd-angular/core/services';
7
6
  import { PreviewComponent } from './components/preview/preview.component';
8
- import { ISdUploadFileConfiguration, SdUploadFileFuncDetails } from './configurations';
9
- import { PreviewFile, UploadFileService } from './services';
7
+ import { SdUploadFileFuncDetails } from './configurations';
8
+ import { PreviewFile } from './services';
10
9
  import * as i0 from "@angular/core";
11
- export declare class SdUploadFile<TArgs = any> implements AfterViewInit, OnDestroy {
10
+ export declare class SdUploadFile<TArgs = any> {
12
11
  #private;
13
- private ref;
14
- private notifyService;
15
- private confirmService;
16
- private readonly uploadFileConfig;
17
- private uploadFileService;
18
- previewFile?: PreviewComponent;
19
- id: string;
20
- selectedFile?: PreviewFile | null;
21
- formControl: SdFormControl;
22
- set _form(val: NgForm | FormGroup);
23
- set _name(val: string | undefined);
24
- args?: TArgs;
25
- label?: string;
26
- helperText?: string;
27
- set _helperText(val: string | undefined);
28
- description?: string;
29
- type: 'image' | 'document' | 'file';
30
- set _type(type: 'image' | 'document' | 'file' | undefined | null);
31
- set disabled(val: boolean | '' | undefined | null);
32
- required: boolean;
33
- set _required(val: boolean | '' | undefined | null);
34
- extensions: string[];
35
- set _extensions(extensions: string[] | undefined | null);
36
- max: number;
37
- set _max(max: number | undefined | null);
38
- maxOfImage: number;
39
- set _maxOfImage(value: number | undefined | null);
40
- maxSize?: number;
41
- maxWidth?: number;
42
- maxHeight?: number;
43
- scaleToPixel?: number;
44
- previewWidth: string;
45
- previewHeight: string;
46
- align: 'left' | 'center';
47
- details?: SdUploadFileFuncDetails<any>;
48
- imageValidator?: (image: HTMLImageElement) => string;
49
- previewFiles: PreviewFile[];
50
- set model(model: (string | number | undefined | null)[] | undefined | null);
51
- loaded: EventEmitter<PreviewFile[]>;
52
- modelChange: EventEmitter<(string | number)[]>;
53
- filesChanged: EventEmitter<(string | File)[]>;
54
- dropElements?: QueryList<ElementRef>;
55
- canvas?: ElementRef;
56
- sdLabelDef?: SdLabelDefDirective;
57
- constructor(ref: ChangeDetectorRef, notifyService: SdNotifyService, confirmService: SdConfirmService, uploadFileConfig: ISdUploadFileConfiguration, uploadFileService: UploadFileService);
58
- ngAfterViewInit(): void;
59
- ngOnDestroy(): void;
12
+ readonly id: string;
13
+ readonly formControl: SdFormControl;
14
+ readonly previewFiles: import("@angular/core").WritableSignal<PreviewFile[]>;
15
+ readonly selectedFile: import("@angular/core").WritableSignal<PreviewFile | null | undefined>;
16
+ readonly previewFileComponent: import("@angular/core").Signal<PreviewComponent | undefined>;
17
+ readonly dropElements: import("@angular/core").Signal<readonly ElementRef<any>[]>;
18
+ readonly sdLabelDef: import("@angular/core").Signal<SdLabelDefDirective | undefined>;
19
+ readonly args: import("@angular/core").InputSignal<TArgs | undefined>;
20
+ readonly label: import("@angular/core").InputSignal<string | undefined>;
21
+ readonly description: import("@angular/core").InputSignal<string | undefined>;
22
+ readonly previewWidth: import("@angular/core").InputSignal<string>;
23
+ readonly previewHeight: import("@angular/core").InputSignal<string>;
24
+ readonly align: import("@angular/core").InputSignal<"left" | "center">;
25
+ readonly details: import("@angular/core").InputSignal<SdUploadFileFuncDetails<any> | undefined>;
26
+ readonly imageValidator: import("@angular/core").InputSignal<((image: HTMLImageElement) => string) | undefined>;
27
+ readonly maxSize: import("@angular/core").InputSignal<number | undefined>;
28
+ readonly maxWidth: import("@angular/core").InputSignal<number | undefined>;
29
+ readonly maxHeight: import("@angular/core").InputSignal<number | undefined>;
30
+ readonly scaleToPixel: import("@angular/core").InputSignal<number | undefined>;
31
+ form: import("@angular/core").InputSignalWithTransform<FormGroup<any> | undefined, any>;
32
+ readonly nameInput: import("@angular/core").InputSignalWithTransform<string, string | undefined>;
33
+ readonly required: import("@angular/core").InputSignalWithTransform<boolean, boolean | "" | null | undefined>;
34
+ readonly type: import("@angular/core").InputSignalWithTransform<"image" | "document" | "file", "image" | "document" | "file" | null | undefined>;
35
+ readonly helperText: import("@angular/core").InputSignal<string | undefined>;
36
+ readonly max: import("@angular/core").InputSignalWithTransform<number, number | null | undefined>;
37
+ readonly maxOfImage: import("@angular/core").InputSignalWithTransform<number, number | null | undefined>;
38
+ readonly extensions: import("@angular/core").InputSignalWithTransform<string[], string[] | null | undefined>;
39
+ readonly disabled: import("@angular/core").InputSignalWithTransform<boolean, boolean | "" | null | undefined>;
40
+ readonly generatedDescription: import("@angular/core").Signal<string | undefined>;
41
+ readonly loaded: import("@angular/core").OutputEmitterRef<PreviewFile[]>;
42
+ readonly filesChanged: import("@angular/core").OutputEmitterRef<(string | File)[]>;
43
+ readonly model: import("@angular/core").ModelSignal<(string | number)[]>;
44
+ constructor();
60
45
  onUpload: () => void;
61
46
  onRemove: (file: PreviewFile) => void;
62
47
  onDrop: (event: CdkDragDrop<string[]>) => void;
63
48
  onImgError: (previewFile: PreviewFile) => void;
64
49
  onSelect: (file: PreviewFile) => void;
50
+ /**
51
+ * Lấy danh sách các File từ previewFiles (chưa upload).
52
+ */
65
53
  getFiles: () => Promise<File[]>;
54
+ /**
55
+ * Thực hiện upload các file và gán giá trị, output trả ra mảng idOrKeys.
56
+ * HÀM NÀY BẮT BUỘC PHẢI GỌI TRƯỚC KHI GỌI VỀ SERVER.
57
+ */
66
58
  upload: () => Promise<void>;
59
+ /**
60
+ * Mở popup preview ảnh.
61
+ */
67
62
  preview: () => Promise<void>;
68
63
  /**
69
64
  * Tải xuống một tệp tin dựa trên đối tượng PreviewFile.
@@ -77,5 +72,5 @@ export declare class SdUploadFile<TArgs = any> implements AfterViewInit, OnDestr
77
72
  onDownload: (previewFile: PreviewFile) => void;
78
73
  isLastVisibleOverlay(fileIndex: number): boolean;
79
74
  static ɵfac: i0.ɵɵFactoryDeclaration<SdUploadFile<any>, never>;
80
- static ɵcmp: i0.ɵɵComponentDeclaration<SdUploadFile<any>, "sd-upload-file", never, { "_form": { "alias": "form"; "required": false; }; "_name": { "alias": "name"; "required": false; }; "args": { "alias": "args"; "required": false; }; "label": { "alias": "label"; "required": false; }; "_helperText": { "alias": "helperText"; "required": false; }; "description": { "alias": "description"; "required": false; }; "_type": { "alias": "type"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "_required": { "alias": "required"; "required": false; }; "_extensions": { "alias": "extensions"; "required": false; }; "_max": { "alias": "max"; "required": false; }; "_maxOfImage": { "alias": "maxOfImage"; "required": false; }; "maxSize": { "alias": "maxSize"; "required": false; }; "maxWidth": { "alias": "maxWidth"; "required": false; }; "maxHeight": { "alias": "maxHeight"; "required": false; }; "scaleToPixel": { "alias": "scaleToPixel"; "required": false; }; "previewWidth": { "alias": "previewWidth"; "required": false; }; "previewHeight": { "alias": "previewHeight"; "required": false; }; "align": { "alias": "align"; "required": false; }; "details": { "alias": "details"; "required": false; }; "imageValidator": { "alias": "imageValidator"; "required": false; }; "model": { "alias": "model"; "required": false; }; }, { "loaded": "loaded"; "modelChange": "modelChange"; "filesChanged": "filesChanged"; }, ["sdLabelDef"], never, true, never>;
75
+ static ɵcmp: i0.ɵɵComponentDeclaration<SdUploadFile<any>, "sd-upload-file", never, { "args": { "alias": "args"; "required": false; "isSignal": true; }; "label": { "alias": "label"; "required": false; "isSignal": true; }; "description": { "alias": "description"; "required": false; "isSignal": true; }; "previewWidth": { "alias": "previewWidth"; "required": false; "isSignal": true; }; "previewHeight": { "alias": "previewHeight"; "required": false; "isSignal": true; }; "align": { "alias": "align"; "required": false; "isSignal": true; }; "details": { "alias": "details"; "required": false; "isSignal": true; }; "imageValidator": { "alias": "imageValidator"; "required": false; "isSignal": true; }; "maxSize": { "alias": "maxSize"; "required": false; "isSignal": true; }; "maxWidth": { "alias": "maxWidth"; "required": false; "isSignal": true; }; "maxHeight": { "alias": "maxHeight"; "required": false; "isSignal": true; }; "scaleToPixel": { "alias": "scaleToPixel"; "required": false; "isSignal": true; }; "form": { "alias": "form"; "required": false; "isSignal": true; }; "nameInput": { "alias": "name"; "required": false; "isSignal": true; }; "required": { "alias": "required"; "required": false; "isSignal": true; }; "type": { "alias": "type"; "required": false; "isSignal": true; }; "helperText": { "alias": "helperText"; "required": false; "isSignal": true; }; "max": { "alias": "max"; "required": false; "isSignal": true; }; "maxOfImage": { "alias": "maxOfImage"; "required": false; "isSignal": true; }; "extensions": { "alias": "extensions"; "required": false; "isSignal": true; }; "disabled": { "alias": "disabled"; "required": false; "isSignal": true; }; "model": { "alias": "model"; "required": false; "isSignal": true; }; }, { "loaded": "loaded"; "filesChanged": "filesChanged"; "model": "modelChange"; }, ["sdLabelDef"], never, true, never>;
81
76
  }
@@ -0,0 +1 @@
1
+ export * from './src/view.component';
@@ -0,0 +1,16 @@
1
+ import { TemplateRef } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export declare class SdView {
4
+ label: import("@angular/core").InputSignal<string | null | undefined>;
5
+ value: import("@angular/core").InputSignal<any>;
6
+ display: import("@angular/core").InputSignal<string | null | undefined>;
7
+ hyperlink: import("@angular/core").InputSignal<string | null | undefined>;
8
+ labelTemplate: import("@angular/core").InputSignal<TemplateRef<any> | undefined>;
9
+ valueTemplate: import("@angular/core").InputSignal<TemplateRef<any> | undefined>;
10
+ contentLabelTemplate: import("@angular/core").Signal<TemplateRef<any> | undefined>;
11
+ contentValueTemplate: import("@angular/core").Signal<TemplateRef<any> | undefined>;
12
+ activeLabelTemplate: import("@angular/core").Signal<TemplateRef<any> | undefined>;
13
+ activeValueTemplate: import("@angular/core").Signal<TemplateRef<any> | undefined>;
14
+ static ɵfac: i0.ɵɵFactoryDeclaration<SdView, never>;
15
+ static ɵcmp: i0.ɵɵComponentDeclaration<SdView, "sd-view", never, { "label": { "alias": "label"; "required": false; "isSignal": true; }; "value": { "alias": "value"; "required": false; "isSignal": true; }; "display": { "alias": "display"; "required": true; "isSignal": true; }; "hyperlink": { "alias": "hyperlink"; "required": false; "isSignal": true; }; "labelTemplate": { "alias": "labelTemplate"; "required": false; "isSignal": true; }; "valueTemplate": { "alias": "valueTemplate"; "required": false; "isSignal": true; }; }, {}, ["contentLabelTemplate", "contentValueTemplate"], never, true, never>;
16
+ }
@@ -5,6 +5,7 @@ import { SdPatternType } from '@sd-angular/core/utilities/models';
5
5
  import { SdFormGenericSelectionStaticItem } from './form-generic-definition-selection.model';
6
6
  import { SdFormGenericExpression } from './form-generic-expression.model';
7
7
  import { SdFormGeneric } from './form-generic.model';
8
+ import { SdUnwrapSignal } from '@sd-angular/core/utilities/models';
8
9
  export interface SdFormRenderConfiguration {
9
10
  onLoaded?: () => void;
10
11
  components: SdFormGeneric['components'];
@@ -158,10 +159,10 @@ export interface SdFormGenericGroup {
158
159
  export interface SdFormGenericUpload extends SdFormGenericComponentBase {
159
160
  type: 'upload';
160
161
  properties?: {
161
- type?: SdUploadFile['type'];
162
- maxSize?: SdUploadFile['maxSize'];
163
- max?: SdUploadFile['max'];
164
- extensions?: SdUploadFile['extensions'];
162
+ type?: SdUnwrapSignal<SdUploadFile['type']>;
163
+ maxSize?: SdUnwrapSignal<SdUploadFile['maxSize']>;
164
+ max?: SdUnwrapSignal<SdUploadFile['max']>;
165
+ extensions?: SdUnwrapSignal<SdUploadFile['extensions']>;
165
166
  args?: Record<string, any>;
166
167
  source?: 'ALL' | 'PHOTO_LIBRARY' | 'CAPTURE';
167
168
  } & SdFormGenericComponentBase['properties'];
@@ -1,4 +1,5 @@
1
1
  export * from './form-render';
2
+ export * from './form-generic.model';
2
3
  export * from './form-generic-component.model';
3
4
  export * from './form-generic-template.model';
4
5
  export * from './form-generic-definition-selection.model';
@@ -2,3 +2,4 @@ export * from './src/sd-scroll.directive';
2
2
  export * from './src/sd-desktop.directive';
3
3
  export * from './src/sd-mobile.directive';
4
4
  export * from './src/sd-hover-copy.directive';
5
+ export * from './src/sd-href.directive';
@@ -0,0 +1,9 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class SdHrefDirective {
3
+ #private;
4
+ url: string;
5
+ get href(): string;
6
+ onClick(event: Event): void;
7
+ static ɵfac: i0.ɵɵFactoryDeclaration<SdHrefDirective, never>;
8
+ static ɵdir: i0.ɵɵDirectiveDeclaration<SdHrefDirective, "a[sdHref]", never, { "url": { "alias": "sdHref"; "required": false; }; }, {}, never, never, true, never>;
9
+ }