@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.
- package/README.md +686 -33
- package/assets/scss/ckeditor5.scss +60 -2
- package/assets/scss/core/bootstrap.scss +17 -0
- package/assets/scss/core/form.scss +4 -1
- package/assets/scss/core/grid.scss +40 -0
- package/assets/scss/sd-core.scss +1 -0
- package/components/avatar/index.d.ts +1 -0
- package/components/avatar/src/avatar.component.d.ts +19 -0
- package/components/badge/src/badge.component.d.ts +77 -19
- package/components/button/src/button.component.d.ts +30 -28
- package/components/code-editor/index.d.ts +1 -0
- package/components/code-editor/src/code-editor.component.d.ts +25 -0
- package/components/document-builder/index.d.ts +1 -0
- package/components/document-builder/src/document-builder.component.d.ts +12 -41
- package/components/document-builder/src/document-builder.model.d.ts +14 -11
- package/components/document-builder/src/plugins/block-space/block-space.plugin.d.ts +9 -0
- package/components/document-builder/src/plugins/ck-comment/ck-comment.plugin.d.ts +44 -0
- package/components/document-builder/src/plugins/ck-comment/ck-comment.plugin.model.d.ts +57 -0
- package/components/document-builder/src/plugins/heading/heading.plugin.d.ts +1 -0
- package/components/document-builder/src/plugins/highlight-range/highlight-range.plugin.d.ts +4 -0
- package/components/document-builder/src/plugins/image-custom/image-custom.plugin.d.ts +31 -0
- package/components/document-builder/src/plugins/index.d.ts +7 -2
- package/components/document-builder/src/plugins/page-orientation/page-orientation.plugin.d.ts +2 -2
- package/components/document-builder/src/plugins/paste-handler/filters/bookmark.d.ts +14 -0
- package/components/document-builder/src/plugins/paste-handler/filters/br.d.ts +15 -0
- package/components/document-builder/src/plugins/paste-handler/filters/image.d.ts +25 -0
- package/components/document-builder/src/plugins/paste-handler/filters/list.d.ts +29 -0
- package/components/document-builder/src/plugins/paste-handler/filters/parse.d.ts +35 -0
- package/components/document-builder/src/plugins/paste-handler/filters/removeboldwrapper.d.ts +15 -0
- package/components/document-builder/src/plugins/paste-handler/filters/removegooglesheetstag.d.ts +15 -0
- package/components/document-builder/src/plugins/paste-handler/filters/removeinvalidtablewidth.d.ts +15 -0
- package/components/document-builder/src/plugins/paste-handler/filters/removemsattributes.d.ts +15 -0
- package/components/document-builder/src/plugins/paste-handler/filters/removestyleblock.d.ts +15 -0
- package/components/document-builder/src/plugins/paste-handler/filters/removexmlns.d.ts +15 -0
- package/components/document-builder/src/plugins/paste-handler/filters/replacemsfootnotes.d.ts +54 -0
- package/components/document-builder/src/plugins/paste-handler/filters/replacetabswithinprewithspaces.d.ts +24 -0
- package/components/document-builder/src/plugins/paste-handler/filters/space.d.ts +27 -0
- package/components/document-builder/src/plugins/paste-handler/filters/table.d.ts +16 -0
- package/components/document-builder/src/plugins/paste-handler/filters/utils.d.ts +25 -0
- package/components/document-builder/src/plugins/paste-handler/index.d.ts +35 -0
- package/components/document-builder/src/plugins/paste-handler/normalizers/googledocsnormalizer.d.ts +31 -0
- package/components/document-builder/src/plugins/paste-handler/normalizers/googlesheetsnormalizer.d.ts +31 -0
- package/components/document-builder/src/plugins/paste-handler/normalizers/mswordnormalizer.d.ts +29 -0
- package/components/document-builder/src/plugins/paste-handler/types.d.ts +30 -0
- package/components/document-builder/src/plugins/table-custom/index.d.ts +34 -0
- package/components/document-builder/src/plugins/variable/variable.plugin.d.ts +39 -0
- package/components/index.d.ts +4 -0
- package/components/mini-editor/index.d.ts +2 -0
- package/components/mini-editor/src/mini-editor.component.d.ts +90 -0
- package/components/mini-editor/src/mini-editor.model.d.ts +44 -0
- package/components/section/src/section.component.d.ts +10 -11
- package/components/side-drawer/src/side-drawer.component.d.ts +11 -24
- package/components/tab-router/src/components/tab-router-item/tab-router-item.component.d.ts +4 -1
- package/components/tab-router/src/components/tab-router-outlet/tab-router-outlet.component.d.ts +3 -15
- package/components/table/src/components/column-filter/column-filter.component.d.ts +3 -3
- package/components/table/src/components/desktop-cell/desktop-cell.component.d.ts +12 -2
- package/components/table/src/components/desktop-cell-view/desktop-cell-view.component.d.ts +12 -2
- package/components/table/src/components/external-filter/external-filter.component.d.ts +1 -1
- package/components/table/src/components/selector-action/action-filter.pipe.d.ts +11 -10
- package/components/table/src/components/selector-action/selector-action.component.d.ts +5 -3
- package/components/table/src/directives/index.d.ts +2 -0
- package/components/table/src/directives/sd-table-column-filter-def.directive.d.ts +9 -0
- package/components/table/src/directives/sticky-shadow.directive.d.ts +17 -0
- package/components/table/src/models/table-column.model.d.ts +34 -34
- package/components/table/src/models/table-command.model.d.ts +7 -3
- package/components/table/src/models/table-item.model.d.ts +5 -4
- package/components/table/src/models/table-option-config.model.d.ts +5 -0
- package/components/table/src/models/table-option-export.model.d.ts +3 -2
- package/components/table/src/models/table-option-selector.model.d.ts +11 -10
- package/components/table/src/models/table-option.model.d.ts +10 -9
- package/components/table/src/services/index.d.ts +3 -0
- package/components/table/src/services/table-export/table-export.service.d.ts +26 -0
- package/components/table/src/services/table-filter/table-filter.model.d.ts +5 -4
- package/components/table/src/services/table-format/table-format.service.d.ts +16 -0
- package/components/table/src/table.component.d.ts +39 -53
- package/components/upload-file/src/configurations/upload-file.configuration.d.ts +1 -1
- package/components/upload-file/src/services/upload-file.service.d.ts +0 -1
- package/components/upload-file/src/upload-file.component.d.ts +49 -54
- package/components/view/index.d.ts +1 -0
- package/components/view/src/view.component.d.ts +16 -0
- package/components/workflow/src/models/form-generic-component.model.d.ts +5 -4
- package/components/workflow/src/models/index.d.ts +1 -0
- package/directives/index.d.ts +1 -0
- package/directives/src/sd-href.directive.d.ts +9 -0
- package/fesm2022/sd-angular-core-components-avatar.mjs +103 -0
- package/fesm2022/sd-angular-core-components-avatar.mjs.map +1 -0
- package/fesm2022/sd-angular-core-components-badge.mjs +101 -91
- package/fesm2022/sd-angular-core-components-badge.mjs.map +1 -1
- package/fesm2022/sd-angular-core-components-button.mjs +70 -96
- package/fesm2022/sd-angular-core-components-button.mjs.map +1 -1
- package/fesm2022/sd-angular-core-components-code-editor.mjs +129 -0
- package/fesm2022/sd-angular-core-components-code-editor.mjs.map +1 -0
- package/fesm2022/sd-angular-core-components-document-builder.mjs +3994 -608
- package/fesm2022/sd-angular-core-components-document-builder.mjs.map +1 -1
- package/fesm2022/sd-angular-core-components-history.mjs +1 -1
- package/fesm2022/sd-angular-core-components-history.mjs.map +1 -1
- package/fesm2022/sd-angular-core-components-import-excel.mjs +1 -1
- package/fesm2022/sd-angular-core-components-import-excel.mjs.map +1 -1
- package/fesm2022/sd-angular-core-components-mini-editor.mjs +326 -0
- package/fesm2022/sd-angular-core-components-mini-editor.mjs.map +1 -0
- package/fesm2022/sd-angular-core-components-preview.mjs +1 -1
- package/fesm2022/sd-angular-core-components-preview.mjs.map +1 -1
- package/fesm2022/sd-angular-core-components-section.mjs +24 -42
- package/fesm2022/sd-angular-core-components-section.mjs.map +1 -1
- package/fesm2022/sd-angular-core-components-side-drawer.mjs +78 -84
- package/fesm2022/sd-angular-core-components-side-drawer.mjs.map +1 -1
- package/fesm2022/sd-angular-core-components-tab-router.mjs +152 -226
- package/fesm2022/sd-angular-core-components-tab-router.mjs.map +1 -1
- package/fesm2022/sd-angular-core-components-table.mjs +1129 -1131
- package/fesm2022/sd-angular-core-components-table.mjs.map +1 -1
- package/fesm2022/sd-angular-core-components-upload-file.mjs +339 -444
- package/fesm2022/sd-angular-core-components-upload-file.mjs.map +1 -1
- package/fesm2022/sd-angular-core-components-view.mjs +45 -0
- package/fesm2022/sd-angular-core-components-view.mjs.map +1 -0
- package/fesm2022/sd-angular-core-components-workflow.mjs +47 -57
- package/fesm2022/sd-angular-core-components-workflow.mjs.map +1 -1
- package/fesm2022/sd-angular-core-components.mjs +4 -0
- package/fesm2022/sd-angular-core-components.mjs.map +1 -1
- package/fesm2022/sd-angular-core-directives.mjs +80 -27
- package/fesm2022/sd-angular-core-directives.mjs.map +1 -1
- package/fesm2022/sd-angular-core-forms-autocomplete.mjs +274 -364
- package/fesm2022/sd-angular-core-forms-autocomplete.mjs.map +1 -1
- package/fesm2022/sd-angular-core-forms-chip-calendar.mjs +5 -2
- package/fesm2022/sd-angular-core-forms-chip-calendar.mjs.map +1 -1
- package/fesm2022/sd-angular-core-forms-chip.mjs +5 -2
- package/fesm2022/sd-angular-core-forms-chip.mjs.map +1 -1
- package/fesm2022/sd-angular-core-forms-date-range.mjs +160 -245
- package/fesm2022/sd-angular-core-forms-date-range.mjs.map +1 -1
- package/fesm2022/sd-angular-core-forms-date.mjs +153 -273
- package/fesm2022/sd-angular-core-forms-date.mjs.map +1 -1
- package/fesm2022/sd-angular-core-forms-datetime.mjs +152 -288
- package/fesm2022/sd-angular-core-forms-datetime.mjs.map +1 -1
- package/fesm2022/sd-angular-core-forms-input-number.mjs +191 -338
- package/fesm2022/sd-angular-core-forms-input-number.mjs.map +1 -1
- package/fesm2022/sd-angular-core-forms-input.mjs +149 -287
- package/fesm2022/sd-angular-core-forms-input.mjs.map +1 -1
- package/fesm2022/sd-angular-core-forms-radio.mjs +3 -2
- package/fesm2022/sd-angular-core-forms-radio.mjs.map +1 -1
- package/fesm2022/sd-angular-core-forms-select.mjs +375 -448
- package/fesm2022/sd-angular-core-forms-select.mjs.map +1 -1
- package/fesm2022/sd-angular-core-forms-textarea.mjs +138 -227
- package/fesm2022/sd-angular-core-forms-textarea.mjs.map +1 -1
- package/fesm2022/sd-angular-core-modules-keycloak.mjs +126 -0
- package/fesm2022/sd-angular-core-modules-keycloak.mjs.map +1 -0
- package/fesm2022/sd-angular-core-modules-layout.mjs +454 -453
- package/fesm2022/sd-angular-core-modules-layout.mjs.map +1 -1
- package/fesm2022/sd-angular-core-modules.mjs +1 -1
- package/fesm2022/sd-angular-core-services-api.mjs +5 -10
- package/fesm2022/sd-angular-core-services-api.mjs.map +1 -1
- package/fesm2022/sd-angular-core-services-confirm.mjs +2 -2
- package/fesm2022/sd-angular-core-services-confirm.mjs.map +1 -1
- package/fesm2022/sd-angular-core-services-docx.mjs +173 -0
- package/fesm2022/sd-angular-core-services-docx.mjs.map +1 -0
- package/fesm2022/sd-angular-core-services-notify.mjs +2 -2
- package/fesm2022/sd-angular-core-services-notify.mjs.map +1 -1
- package/fesm2022/sd-angular-core-services.mjs +1 -0
- package/fesm2022/sd-angular-core-services.mjs.map +1 -1
- package/fesm2022/sd-angular-core-utilities-extensions.mjs +21 -45
- package/fesm2022/sd-angular-core-utilities-extensions.mjs.map +1 -1
- package/fesm2022/sd-angular-core-utilities-models.mjs +15 -1
- package/fesm2022/sd-angular-core-utilities-models.mjs.map +1 -1
- package/forms/autocomplete/src/autocomplete.component.d.ts +50 -55
- package/forms/chip/src/chip.component.d.ts +3 -2
- package/forms/chip-calendar/src/chip-calendar.component.d.ts +3 -2
- package/forms/date/src/date.component.d.ts +43 -46
- package/forms/date-range/src/date-range.component.d.ts +30 -34
- package/forms/datetime/src/datetime.component.d.ts +43 -49
- package/forms/input/src/input.component.d.ts +48 -57
- package/forms/input-number/src/input-number.component.d.ts +48 -54
- package/forms/select/src/select.component.d.ts +62 -64
- package/forms/textarea/src/textarea.component.d.ts +36 -42
- package/modules/index.d.ts +1 -1
- package/modules/keycloak/index.d.ts +4 -0
- package/modules/keycloak/keycloak.configuration.d.ts +11 -0
- package/modules/keycloak/keycloak.interceptor.d.ts +2 -0
- package/modules/keycloak/keycloak.module.d.ts +18 -0
- package/modules/keycloak/keycloak.service.d.ts +14 -0
- package/modules/layout/components/layout-main/layout-main.component.d.ts +7 -12
- package/modules/layout/components/page/page.component.d.ts +5 -7
- package/modules/layout/components/sidebar-v1/components/sidebar/sidebar.component.d.ts +22 -29
- package/modules/layout/components/sidebar-v1/components/user/user.component.d.ts +11 -17
- package/modules/layout/components/sidebar-v1/main.component.d.ts +14 -14
- package/modules/layout/configurations/layout.configuration.d.ts +46 -3
- package/modules/layout/modules/forbidden/pages/root/root.component.d.ts +3 -8
- package/modules/layout/modules/home/components/home-page/home-page.component.d.ts +2 -5
- package/modules/layout/modules/not-found/pages/root/root.component.d.ts +3 -8
- package/modules/layout/pipes/high-light-search.pipe.d.ts +1 -1
- package/modules/layout/services/index.d.ts +1 -0
- package/modules/layout/services/layout.service.d.ts +10 -0
- package/modules/layout/services/menu/menu.model.d.ts +2 -0
- package/modules/layout/services/storage/storage.service.d.ts +0 -3
- package/package.json +93 -70
- package/sd-angular-core-19.0.0-beta.60.tgz +0 -0
- package/services/api/src/api.model.d.ts +6 -1
- package/services/confirm/src/lib/confirm.service.d.ts +1 -0
- package/services/docx/index.d.ts +1 -0
- package/services/docx/src/lib/docx.model.d.ts +9 -0
- package/services/docx/src/lib/docx.service.d.ts +13 -0
- package/services/docx/src/public-api.d.ts +2 -0
- package/services/index.d.ts +1 -0
- package/services/notify/index.d.ts +1 -0
- package/services/notify/src/notify.model.d.ts +1 -1
- package/services/notify/src/notify.service.d.ts +5 -5
- package/utilities/extensions/src/string.extension.d.ts +2 -0
- package/utilities/extensions/src/utility.extension.d.ts +1 -0
- package/utilities/models/index.d.ts +3 -0
- package/utilities/models/src/filter.model.d.ts +14 -2
- package/utilities/models/src/icon.model.d.ts +2 -0
- package/utilities/models/src/nested-key-of.model.d.ts +5 -0
- package/utilities/models/src/pattern.model.d.ts +1 -1
- package/utilities/models/src/unwrap-signal.model.d.ts +6 -0
- package/components/document-builder/src/plugins/comment/comment.plugin.d.ts +0 -4
- package/components/document-builder/src/plugins/table-fit/table-fit.plugin.d.ts +0 -4
- package/fesm2022/sd-angular-core-modules-oidc.mjs +0 -127
- package/fesm2022/sd-angular-core-modules-oidc.mjs.map +0 -1
- package/modules/oidc/dynamic-sts.loader.d.ts +0 -11
- package/modules/oidc/index.d.ts +0 -2
- package/modules/oidc/oidc.configuration.d.ts +0 -11
- 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?:
|
|
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?:
|
|
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']
|
|
16
|
-
color: SdBadge['color']
|
|
17
|
-
icon?:
|
|
18
|
-
title?:
|
|
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:
|
|
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:
|
|
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 {
|
|
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 {
|
|
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
|
|
37
|
+
items: (filterRequest: SdTableFilterRequest<T>, pagingReq: SdPagingReq<T>) => Promise<{
|
|
37
38
|
items: T[];
|
|
38
39
|
total: number;
|
|
39
40
|
}>;
|
|
@@ -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<
|
|
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,
|
|
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
|
|
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
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
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
|
-
|
|
70
|
+
tableConfiguration: ISdTableConfiguration | null;
|
|
71
|
+
constructor();
|
|
81
72
|
ngOnInit(): void;
|
|
82
73
|
ngAfterViewInit(): void;
|
|
83
74
|
ngOnDestroy(): void;
|
|
84
|
-
|
|
85
|
-
requireFiltered: boolean;
|
|
75
|
+
getFilterRequest: () => SdTableFilterRequest;
|
|
86
76
|
reload: (force?: boolean, scrollTop?: boolean) => Promise<void>;
|
|
87
|
-
|
|
88
|
-
|
|
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>,
|
|
110
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<SdTable<any>, "sd-table", 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
|
|
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,69 +1,64 @@
|
|
|
1
1
|
import { CdkDragDrop } from '@angular/cdk/drag-drop';
|
|
2
|
-
import {
|
|
3
|
-
import { FormGroup
|
|
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 {
|
|
9
|
-
import { PreviewFile
|
|
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>
|
|
10
|
+
export declare class SdUploadFile<TArgs = any> {
|
|
12
11
|
#private;
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
maxOfImage: number
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
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, { "
|
|
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'];
|
package/directives/index.d.ts
CHANGED
|
@@ -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
|
+
}
|