@sd-angular/core 19.0.0-beta.5 → 19.0.0-beta.50

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 (185) 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/grid.scss +40 -0
  5. package/assets/scss/sd-core.scss +1 -0
  6. package/components/avatar/index.d.ts +1 -0
  7. package/components/avatar/src/avatar.component.d.ts +15 -0
  8. package/components/badge/src/badge.component.d.ts +77 -19
  9. package/components/button/src/button.component.d.ts +26 -28
  10. package/components/code-editor/index.d.ts +1 -0
  11. package/components/code-editor/src/code-editor.component.d.ts +25 -0
  12. package/components/document-builder/index.d.ts +1 -0
  13. package/components/document-builder/src/document-builder.component.d.ts +18 -36
  14. package/components/document-builder/src/document-builder.model.d.ts +10 -10
  15. package/components/document-builder/src/plugins/block-space/block-space.plugin.d.ts +9 -0
  16. package/components/document-builder/src/plugins/ck-comment/ck-comment.plugin.d.ts +44 -0
  17. package/components/document-builder/src/plugins/ck-comment/ck-comment.plugin.model.d.ts +56 -0
  18. package/components/document-builder/src/plugins/heading/heading.plugin.d.ts +1 -0
  19. package/components/document-builder/src/plugins/highlight-range/highlight-range.plugin.d.ts +4 -0
  20. package/components/document-builder/src/plugins/image-custom/image-custom.plugin.d.ts +31 -0
  21. package/components/document-builder/src/plugins/index.d.ts +7 -2
  22. package/components/document-builder/src/plugins/page-orientation/page-orientation.plugin.d.ts +2 -2
  23. package/components/document-builder/src/plugins/paste-handler/filters/bookmark.d.ts +14 -0
  24. package/components/document-builder/src/plugins/paste-handler/filters/br.d.ts +15 -0
  25. package/components/document-builder/src/plugins/paste-handler/filters/image.d.ts +25 -0
  26. package/components/document-builder/src/plugins/paste-handler/filters/list.d.ts +29 -0
  27. package/components/document-builder/src/plugins/paste-handler/filters/parse.d.ts +35 -0
  28. package/components/document-builder/src/plugins/paste-handler/filters/removeboldwrapper.d.ts +15 -0
  29. package/components/document-builder/src/plugins/paste-handler/filters/removegooglesheetstag.d.ts +15 -0
  30. package/components/document-builder/src/plugins/paste-handler/filters/removeinvalidtablewidth.d.ts +15 -0
  31. package/components/document-builder/src/plugins/paste-handler/filters/removemsattributes.d.ts +15 -0
  32. package/components/document-builder/src/plugins/paste-handler/filters/removestyleblock.d.ts +15 -0
  33. package/components/document-builder/src/plugins/paste-handler/filters/removexmlns.d.ts +15 -0
  34. package/components/document-builder/src/plugins/paste-handler/filters/replacemsfootnotes.d.ts +54 -0
  35. package/components/document-builder/src/plugins/paste-handler/filters/replacetabswithinprewithspaces.d.ts +24 -0
  36. package/components/document-builder/src/plugins/paste-handler/filters/space.d.ts +27 -0
  37. package/components/document-builder/src/plugins/paste-handler/filters/table.d.ts +16 -0
  38. package/components/document-builder/src/plugins/paste-handler/filters/utils.d.ts +25 -0
  39. package/components/document-builder/src/plugins/paste-handler/index.d.ts +35 -0
  40. package/components/document-builder/src/plugins/paste-handler/normalizers/googledocsnormalizer.d.ts +31 -0
  41. package/components/document-builder/src/plugins/paste-handler/normalizers/googlesheetsnormalizer.d.ts +31 -0
  42. package/components/document-builder/src/plugins/paste-handler/normalizers/mswordnormalizer.d.ts +29 -0
  43. package/components/document-builder/src/plugins/paste-handler/types.d.ts +30 -0
  44. package/components/document-builder/src/plugins/table-custom/index.d.ts +34 -0
  45. package/components/index.d.ts +4 -0
  46. package/components/mini-editor/index.d.ts +2 -0
  47. package/components/mini-editor/src/mini-editor.component.d.ts +90 -0
  48. package/components/mini-editor/src/mini-editor.model.d.ts +44 -0
  49. package/components/side-drawer/src/side-drawer.component.d.ts +1 -2
  50. package/components/tab-router/src/components/tab-router-item/tab-router-item.component.d.ts +4 -1
  51. package/components/tab-router/src/components/tab-router-outlet/tab-router-outlet.component.d.ts +3 -15
  52. package/components/table/src/components/selector-action/action-filter.pipe.d.ts +11 -10
  53. package/components/table/src/directives/index.d.ts +2 -0
  54. package/components/table/src/directives/sd-table-column-filter-def.directive.d.ts +9 -0
  55. package/components/table/src/directives/sticky-shadow.directive.d.ts +17 -0
  56. package/components/table/src/models/table-column.model.d.ts +32 -32
  57. package/components/table/src/models/table-command.model.d.ts +7 -3
  58. package/components/table/src/models/table-item.model.d.ts +5 -4
  59. package/components/table/src/models/table-option-export.model.d.ts +3 -2
  60. package/components/table/src/models/table-option-selector.model.d.ts +11 -10
  61. package/components/table/src/models/table-option.model.d.ts +10 -8
  62. package/components/table/src/services/table-filter/table-filter.model.d.ts +2 -2
  63. package/components/table/src/table.component.d.ts +33 -35
  64. package/components/view/index.d.ts +1 -0
  65. package/components/view/src/view.component.d.ts +16 -0
  66. package/components/workflow/src/models/index.d.ts +1 -0
  67. package/directives/index.d.ts +1 -0
  68. package/directives/src/sd-href.directive.d.ts +9 -0
  69. package/fesm2022/sd-angular-core-components-avatar.mjs +90 -0
  70. package/fesm2022/sd-angular-core-components-avatar.mjs.map +1 -0
  71. package/fesm2022/sd-angular-core-components-badge.mjs +101 -91
  72. package/fesm2022/sd-angular-core-components-badge.mjs.map +1 -1
  73. package/fesm2022/sd-angular-core-components-button.mjs +64 -96
  74. package/fesm2022/sd-angular-core-components-button.mjs.map +1 -1
  75. package/fesm2022/sd-angular-core-components-code-editor.mjs +129 -0
  76. package/fesm2022/sd-angular-core-components-code-editor.mjs.map +1 -0
  77. package/fesm2022/sd-angular-core-components-document-builder.mjs +3635 -521
  78. package/fesm2022/sd-angular-core-components-document-builder.mjs.map +1 -1
  79. package/fesm2022/sd-angular-core-components-history.mjs +1 -1
  80. package/fesm2022/sd-angular-core-components-history.mjs.map +1 -1
  81. package/fesm2022/sd-angular-core-components-import-excel.mjs +1 -1
  82. package/fesm2022/sd-angular-core-components-import-excel.mjs.map +1 -1
  83. package/fesm2022/sd-angular-core-components-mini-editor.mjs +326 -0
  84. package/fesm2022/sd-angular-core-components-mini-editor.mjs.map +1 -0
  85. package/fesm2022/sd-angular-core-components-preview.mjs +1 -1
  86. package/fesm2022/sd-angular-core-components-preview.mjs.map +1 -1
  87. package/fesm2022/sd-angular-core-components-side-drawer.mjs +21 -8
  88. package/fesm2022/sd-angular-core-components-side-drawer.mjs.map +1 -1
  89. package/fesm2022/sd-angular-core-components-tab-router.mjs +152 -226
  90. package/fesm2022/sd-angular-core-components-tab-router.mjs.map +1 -1
  91. package/fesm2022/sd-angular-core-components-table.mjs +646 -460
  92. package/fesm2022/sd-angular-core-components-table.mjs.map +1 -1
  93. package/fesm2022/sd-angular-core-components-upload-file.mjs +1 -1
  94. package/fesm2022/sd-angular-core-components-upload-file.mjs.map +1 -1
  95. package/fesm2022/sd-angular-core-components-view.mjs +45 -0
  96. package/fesm2022/sd-angular-core-components-view.mjs.map +1 -0
  97. package/fesm2022/sd-angular-core-components-workflow.mjs +33 -43
  98. package/fesm2022/sd-angular-core-components-workflow.mjs.map +1 -1
  99. package/fesm2022/sd-angular-core-components.mjs +4 -0
  100. package/fesm2022/sd-angular-core-components.mjs.map +1 -1
  101. package/fesm2022/sd-angular-core-directives.mjs +80 -27
  102. package/fesm2022/sd-angular-core-directives.mjs.map +1 -1
  103. package/fesm2022/sd-angular-core-forms-autocomplete.mjs +257 -363
  104. package/fesm2022/sd-angular-core-forms-autocomplete.mjs.map +1 -1
  105. package/fesm2022/sd-angular-core-forms-date-range.mjs +145 -245
  106. package/fesm2022/sd-angular-core-forms-date-range.mjs.map +1 -1
  107. package/fesm2022/sd-angular-core-forms-date.mjs +137 -273
  108. package/fesm2022/sd-angular-core-forms-date.mjs.map +1 -1
  109. package/fesm2022/sd-angular-core-forms-datetime.mjs +136 -288
  110. package/fesm2022/sd-angular-core-forms-datetime.mjs.map +1 -1
  111. package/fesm2022/sd-angular-core-forms-input-number.mjs +174 -337
  112. package/fesm2022/sd-angular-core-forms-input-number.mjs.map +1 -1
  113. package/fesm2022/sd-angular-core-forms-input.mjs +130 -285
  114. package/fesm2022/sd-angular-core-forms-input.mjs.map +1 -1
  115. package/fesm2022/sd-angular-core-forms-radio.mjs +3 -2
  116. package/fesm2022/sd-angular-core-forms-radio.mjs.map +1 -1
  117. package/fesm2022/sd-angular-core-forms-select.mjs +336 -421
  118. package/fesm2022/sd-angular-core-forms-select.mjs.map +1 -1
  119. package/fesm2022/sd-angular-core-forms-textarea.mjs +121 -226
  120. package/fesm2022/sd-angular-core-forms-textarea.mjs.map +1 -1
  121. package/fesm2022/sd-angular-core-modules-keycloak.mjs +126 -0
  122. package/fesm2022/sd-angular-core-modules-keycloak.mjs.map +1 -0
  123. package/fesm2022/sd-angular-core-modules-layout.mjs +440 -431
  124. package/fesm2022/sd-angular-core-modules-layout.mjs.map +1 -1
  125. package/fesm2022/sd-angular-core-modules.mjs +1 -1
  126. package/fesm2022/sd-angular-core-services-confirm.mjs +2 -2
  127. package/fesm2022/sd-angular-core-services-confirm.mjs.map +1 -1
  128. package/fesm2022/sd-angular-core-services-docx.mjs +173 -0
  129. package/fesm2022/sd-angular-core-services-docx.mjs.map +1 -0
  130. package/fesm2022/sd-angular-core-services-notify.mjs +2 -2
  131. package/fesm2022/sd-angular-core-services-notify.mjs.map +1 -1
  132. package/fesm2022/sd-angular-core-services.mjs +1 -0
  133. package/fesm2022/sd-angular-core-services.mjs.map +1 -1
  134. package/fesm2022/sd-angular-core-utilities-extensions.mjs +10 -6
  135. package/fesm2022/sd-angular-core-utilities-extensions.mjs.map +1 -1
  136. package/fesm2022/sd-angular-core-utilities-models.mjs +15 -1
  137. package/fesm2022/sd-angular-core-utilities-models.mjs.map +1 -1
  138. package/forms/autocomplete/src/autocomplete.component.d.ts +51 -56
  139. package/forms/date/src/date.component.d.ts +41 -45
  140. package/forms/date-range/src/date-range.component.d.ts +28 -33
  141. package/forms/datetime/src/datetime.component.d.ts +41 -48
  142. package/forms/input/src/input.component.d.ts +46 -56
  143. package/forms/input-number/src/input-number.component.d.ts +47 -54
  144. package/forms/select/src/select.component.d.ts +58 -58
  145. package/forms/textarea/src/textarea.component.d.ts +34 -41
  146. package/modules/index.d.ts +1 -1
  147. package/modules/keycloak/index.d.ts +4 -0
  148. package/modules/keycloak/keycloak.configuration.d.ts +11 -0
  149. package/modules/keycloak/keycloak.interceptor.d.ts +2 -0
  150. package/modules/keycloak/keycloak.module.d.ts +18 -0
  151. package/modules/keycloak/keycloak.service.d.ts +14 -0
  152. package/modules/layout/components/layout-main/layout-main.component.d.ts +7 -12
  153. package/modules/layout/components/sidebar-v1/components/sidebar/sidebar.component.d.ts +22 -29
  154. package/modules/layout/components/sidebar-v1/components/user/user.component.d.ts +11 -17
  155. package/modules/layout/components/sidebar-v1/main.component.d.ts +14 -14
  156. package/modules/layout/configurations/layout.configuration.d.ts +46 -3
  157. package/modules/layout/modules/forbidden/pages/root/root.component.d.ts +3 -8
  158. package/modules/layout/modules/home/components/home-page/home-page.component.d.ts +2 -5
  159. package/modules/layout/modules/not-found/pages/root/root.component.d.ts +3 -8
  160. package/modules/layout/services/index.d.ts +1 -0
  161. package/modules/layout/services/layout.service.d.ts +10 -0
  162. package/modules/layout/services/menu/menu.model.d.ts +2 -0
  163. package/modules/layout/services/storage/storage.service.d.ts +0 -3
  164. package/package.json +91 -68
  165. package/services/confirm/src/lib/confirm.service.d.ts +1 -0
  166. package/services/docx/index.d.ts +1 -0
  167. package/services/docx/src/lib/docx.model.d.ts +9 -0
  168. package/services/docx/src/lib/docx.service.d.ts +13 -0
  169. package/services/docx/src/public-api.d.ts +2 -0
  170. package/services/index.d.ts +1 -0
  171. package/utilities/extensions/src/string.extension.d.ts +2 -0
  172. package/utilities/models/index.d.ts +3 -0
  173. package/utilities/models/src/filter.model.d.ts +14 -2
  174. package/utilities/models/src/icon.model.d.ts +2 -0
  175. package/utilities/models/src/nested-key-of.model.d.ts +5 -0
  176. package/utilities/models/src/pattern.model.d.ts +1 -1
  177. package/utilities/models/src/unwrap-signal.model.d.ts +6 -0
  178. package/components/document-builder/src/plugins/comment/comment.plugin.d.ts +0 -4
  179. package/components/document-builder/src/plugins/table-fit/table-fit.plugin.d.ts +0 -4
  180. package/fesm2022/sd-angular-core-modules-oidc.mjs +0 -127
  181. package/fesm2022/sd-angular-core-modules-oidc.mjs.map +0 -1
  182. package/modules/oidc/dynamic-sts.loader.d.ts +0 -11
  183. package/modules/oidc/index.d.ts +0 -2
  184. package/modules/oidc/oidc.configuration.d.ts +0 -11
  185. package/modules/oidc/oidc.module.d.ts +0 -14
@@ -17,15 +17,73 @@
17
17
  // Import the editor styles.
18
18
  // @import '@ckeditor/ckeditor5-editor-classic/dist/index.css';
19
19
  @import '@ckeditor/ckeditor5-essentials/dist/index.css';
20
+ @import '@ckeditor/ckeditor5-page-break/dist/index.css';
20
21
  @import '@ckeditor/ckeditor5-autoformat/dist/index.css';
21
22
  @import '@ckeditor/ckeditor5-basic-styles/dist/index.css';
22
23
  // @import '@ckeditor/ckeditor5-block-quote/dist/index.css';
23
24
  @import '@ckeditor/ckeditor5-heading/dist/index.css';
24
- @import '@ckeditor/ckeditor5-image/dist/index.css';
25
+ // @import '@ckeditor/ckeditor5-image/dist/index.css';
26
+ @import '@ckeditor/ckeditor5-image/dist/index-editor.css';
25
27
  @import '@ckeditor/ckeditor5-indent/dist/index.css';
26
28
  @import '@ckeditor/ckeditor5-link/dist/index.css';
27
29
  @import '@ckeditor/ckeditor5-list/dist/index.css';
28
30
  // @import '@ckeditor/ckeditor5-media-embed/dist/index.css';
29
31
  @import '@ckeditor/ckeditor5-paste-from-office/dist/index.css';
30
- @import '@ckeditor/ckeditor5-table/dist/index.css';
32
+
33
+ // hung.pham16: không sử dụng default styles của ckeditor vì server không hỗ trợ
34
+ // @import '@ckeditor/ckeditor5-table/dist/index.css';
35
+ @import '@ckeditor/ckeditor5-table/dist/index-editor.css';
36
+
31
37
  // @import '@ckeditor/ckeditor5-mention/dist/index.css';
38
+
39
+ // Custom toolbar
40
+ .ck-editor {
41
+ /* --- 1. GIẢM KÍCH THƯỚC ICON VÀ CHỮ --- */
42
+ /* Giảm cỡ chữ trong dropdown (mặc định khoảng 13px) */
43
+ --ck-font-size-base: 11px !important;
44
+
45
+ /* Giảm kích thước Icon (mặc định 20px) */
46
+ --ck-icon-size: 16px !important;
47
+
48
+ /* --- 2. TỐI ƯU KHOẢNG CÁCH (Padding/Margin) --- */
49
+
50
+ /* Giảm khoảng cách giữa các nút */
51
+ --ck-spacing-small: 2px !important;
52
+ --ck-spacing-standard: 6px !important;
53
+ --ck-spacing-large: 8px !important;
54
+
55
+ /* */
56
+ --ck-color-table-focused-cell-background: transparent !important;
57
+ --ck-table-content-default-border-color: transparent !important;
58
+
59
+ //
60
+ --ck-insert-table-dropdown-padding: 10px;
61
+ --ck-insert-table-dropdown-box-height: 16px;
62
+ --ck-insert-table-dropdown-box-width: 16px;
63
+ --ck-insert-table-dropdown-box-margin: 1px;
64
+
65
+ --ck-focus-ring: 1px solid var(--ck-color-base-border);
66
+ }
67
+
68
+ /* Giảm độ cao của thanh toolbar (cho gọn) */
69
+ .ck-toolbar {
70
+ min-height: 32px !important; /* Mặc định thường là 40px */
71
+ padding: 2px !important;
72
+
73
+ /* Làm màu nền toolbar nhạt hơn cho hiện đại */
74
+ background: #f8f9fa !important;
75
+ border-bottom: 1px solid #e0e0e0 !important;
76
+ }
77
+
78
+ .ck-toolbar__items {
79
+ /* Chỉnh nút bấm trong toolbar nhỏ lại */
80
+ > .ck-button {
81
+ padding: 2px 4px !important; /* Giảm padding trái phải của nút */
82
+ min-height: 24px !important;
83
+ }
84
+
85
+ /* Chỉnh lại dropdown (Heading, Font Size) cho khớp */
86
+ > .ck-dropdown {
87
+ min-height: 24px !important;
88
+ }
89
+ }
@@ -81,6 +81,23 @@
81
81
  .fs-#{$i} {
82
82
  font-size: #{$i}px !important;
83
83
  }
84
+
85
+ // Gap
86
+ .gap-#{$i} {
87
+ gap: #{$i}px !important;
88
+ }
89
+
90
+ .gap-y-#{$i} {
91
+ row-gap: #{$i}px !important;
92
+ }
93
+
94
+ .gap-x-#{$i} {
95
+ column-gap: #{$i}px !important;
96
+ }
97
+ }
98
+
99
+ .flex-1 {
100
+ flex: 1;
84
101
  }
85
102
 
86
103
  .w-full {
@@ -0,0 +1,40 @@
1
+ /* ==========================================================================
2
+ CSS GRID UTILITIES
3
+ ========================================================================== */
4
+
5
+ /* 1. Kích hoạt Grid cơ bản */
6
+ .sd-grid-container {
7
+ display: grid;
8
+ column-gap: 8px;
9
+ row-gap: 0px;
10
+
11
+ /* 2. Định nghĩa tổng số cột của Grid Cha (từ 1 đến 12 cột) */
12
+ @for $i from 1 through 12 {
13
+ &.grid-cols-#{$i} {
14
+ /* Dùng minmax(0, 1fr) thay vì 1fr để chống vỡ layout khi nội dung text quá dài */
15
+ grid-template-columns: repeat($i, minmax(0, 1fr));
16
+ }
17
+ }
18
+
19
+ /* 3. Tiện ích chiếm CỘT (Column Spanning) cho phần tử con */
20
+ @for $i from 1 through 12 {
21
+ .col-span-#{$i} {
22
+ grid-column: span #{$i} / span #{$i};
23
+ }
24
+ }
25
+ /* Chiếm toàn bộ số cột hiện có (Full width) */
26
+ .col-span-full {
27
+ grid-column: 1 / -1;
28
+ }
29
+
30
+ /* 4. Tiện ích chiếm HÀNG (Row Spanning) cho phần tử con */
31
+ @for $i from 1 through 12 {
32
+ .row-span-#{$i} {
33
+ grid-row: span #{$i} / span #{$i};
34
+ }
35
+ }
36
+ /* Chiếm toàn bộ hàng (Full height) */
37
+ .row-span-full {
38
+ grid-row: 1 / -1;
39
+ }
40
+ }
@@ -7,6 +7,7 @@
7
7
  @use './core/typography.scss';
8
8
  @use './core/print.scss';
9
9
  @use './core/elevation.scss';
10
+ @use './core/grid.scss';
10
11
  @use './themes/default.scss';
11
12
  @use './themes/material-theme.scss';
12
13
 
@@ -0,0 +1 @@
1
+ export * from './src/avatar.component';
@@ -0,0 +1,15 @@
1
+ import { OnInit } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export declare class SdAvatar implements OnInit {
4
+ #private;
5
+ src: string | undefined | null;
6
+ size: number;
7
+ name: string;
8
+ isUrl: boolean;
9
+ initials: string;
10
+ bgColor: string;
11
+ ngOnInit(): void;
12
+ handleError(): void;
13
+ static ɵfac: i0.ɵɵFactoryDeclaration<SdAvatar, never>;
14
+ static ɵcmp: i0.ɵɵComponentDeclaration<SdAvatar, "sd-avatar", never, { "src": { "alias": "src"; "required": true; }; "size": { "alias": "size"; "required": false; }; "name": { "alias": "name"; "required": false; }; }, {}, never, never, true, never>;
15
+ }
@@ -1,27 +1,85 @@
1
1
  import { EventEmitter } from '@angular/core';
2
2
  import { SdColor, SdSize } from '@sd-angular/core/utilities/models';
3
+ import { MaterialIconFontSet } from '@sd-angular/core/utilities/models';
3
4
  import * as i0 from "@angular/core";
5
+ export type SdBadgeType = 'tag' | 'round' | 'icon';
4
6
  export declare class SdBadge {
5
7
  defaultIcon: string;
6
- type: 'tag' | 'round' | 'icon';
7
- set _type(type: 'tag' | 'round' | 'icon' | undefined | null);
8
- color: SdColor;
9
- set _color(color: SdColor | undefined | null);
10
- set primary(value: boolean | '');
11
- set secondary(value: boolean | '');
12
- set success(value: boolean | '' | undefined | null);
13
- set info(value: boolean | '' | undefined | null);
14
- set warning(value: boolean | '' | undefined | null);
15
- set error(value: boolean | '' | undefined | null);
16
- fontSet: 'material-icons' | 'material-icons-outlined' | 'material-icons-round' | 'material-icons-sharp';
17
- set _fontSet(fontSet: 'material-icons' | 'material-icons-outlined' | 'material-icons-round' | 'material-icons-sharp' | undefined | null);
18
- title: string | number | undefined | null;
19
- description: string | undefined | null;
20
- tooltip: string | undefined | null;
21
- icon: string | undefined | null;
22
- size: SdSize;
23
- sdClick: EventEmitter<any>;
8
+ type: import("@angular/core").InputSignalWithTransform<SdBadgeType, SdBadgeType | null | undefined>;
9
+ color: import("@angular/core").InputSignalWithTransform<SdColor, SdColor | null | undefined>;
10
+ primary: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
11
+ secondary: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
12
+ success: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
13
+ info: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
14
+ warning: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
15
+ error: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
16
+ fontSet: import("@angular/core").InputSignalWithTransform<MaterialIconFontSet, MaterialIconFontSet | null | undefined>;
17
+ title: import("@angular/core").InputSignal<string | number | null | undefined>;
18
+ description: import("@angular/core").InputSignal<string | null | undefined>;
19
+ tooltip: import("@angular/core").InputSignal<string | null | undefined>;
20
+ icon: import("@angular/core").InputSignal<string | null | undefined>;
21
+ size: import("@angular/core").InputSignalWithTransform<SdSize, SdSize | null | undefined>;
22
+ click: EventEmitter<Event>;
24
23
  onClick: (event: Event) => void;
24
+ effectiveColor: import("@angular/core").Signal<SdColor>;
25
+ baseColorClasses: import("@angular/core").Signal<{
26
+ 'c-primary': boolean;
27
+ 'c-secondary': boolean;
28
+ 'c-info': boolean;
29
+ 'c-success': boolean;
30
+ 'c-warning': boolean;
31
+ 'c-error': boolean;
32
+ }>;
33
+ iconColorClasses: import("@angular/core").Signal<{
34
+ 'c-primary': boolean;
35
+ 'c-black400': boolean;
36
+ 'c-info': boolean;
37
+ 'c-success': boolean;
38
+ 'c-warning': boolean;
39
+ 'c-error': boolean;
40
+ }>;
41
+ iconSizeAndFontClasses: import("@angular/core").Signal<{
42
+ 'c-xs': boolean;
43
+ 'c-sm': boolean;
44
+ 'c-md': boolean;
45
+ 'c-lg': boolean;
46
+ 'material-icons': boolean;
47
+ 'material-icons-outlined': boolean;
48
+ 'material-icons-round': boolean;
49
+ 'material-icons-sharp': boolean;
50
+ }>;
51
+ tagIconCombinedClasses: import("@angular/core").Signal<{
52
+ 'c-primary': boolean;
53
+ 'c-secondary': boolean;
54
+ 'c-info': boolean;
55
+ 'c-success': boolean;
56
+ 'c-warning': boolean;
57
+ 'c-error': boolean;
58
+ 'c-xs': boolean;
59
+ 'c-sm': boolean;
60
+ 'c-md': boolean;
61
+ 'c-lg': boolean;
62
+ 'material-icons': boolean;
63
+ 'material-icons-outlined': boolean;
64
+ 'material-icons-round': boolean;
65
+ 'material-icons-sharp': boolean;
66
+ }>;
67
+ iconCombinedClasses: import("@angular/core").Signal<{
68
+ 'c-primary': boolean;
69
+ 'c-black400': boolean;
70
+ 'c-info': boolean;
71
+ 'c-success': boolean;
72
+ 'c-warning': boolean;
73
+ 'c-error': boolean;
74
+ 'c-xs': boolean;
75
+ 'c-sm': boolean;
76
+ 'c-md': boolean;
77
+ 'c-lg': boolean;
78
+ 'material-icons': boolean;
79
+ 'material-icons-outlined': boolean;
80
+ 'material-icons-round': boolean;
81
+ 'material-icons-sharp': boolean;
82
+ }>;
25
83
  static ɵfac: i0.ɵɵFactoryDeclaration<SdBadge, never>;
26
- static ɵcmp: i0.ɵɵComponentDeclaration<SdBadge, "sd-badge", never, { "_type": { "alias": "type"; "required": false; }; "_color": { "alias": "color"; "required": false; }; "primary": { "alias": "primary"; "required": false; }; "secondary": { "alias": "secondary"; "required": false; }; "success": { "alias": "success"; "required": false; }; "info": { "alias": "info"; "required": false; }; "warning": { "alias": "warning"; "required": false; }; "error": { "alias": "error"; "required": false; }; "_fontSet": { "alias": "fontSet"; "required": false; }; "title": { "alias": "title"; "required": false; }; "description": { "alias": "description"; "required": false; }; "tooltip": { "alias": "tooltip"; "required": false; }; "icon": { "alias": "icon"; "required": false; }; "size": { "alias": "size"; "required": false; }; }, { "sdClick": "sdClick"; }, never, never, true, never>;
84
+ static ɵcmp: i0.ɵɵComponentDeclaration<SdBadge, "sd-badge", never, { "type": { "alias": "type"; "required": false; "isSignal": true; }; "color": { "alias": "color"; "required": false; "isSignal": true; }; "primary": { "alias": "primary"; "required": false; "isSignal": true; }; "secondary": { "alias": "secondary"; "required": false; "isSignal": true; }; "success": { "alias": "success"; "required": false; "isSignal": true; }; "info": { "alias": "info"; "required": false; "isSignal": true; }; "warning": { "alias": "warning"; "required": false; "isSignal": true; }; "error": { "alias": "error"; "required": false; "isSignal": true; }; "fontSet": { "alias": "fontSet"; "required": false; "isSignal": true; }; "title": { "alias": "title"; "required": false; "isSignal": true; }; "description": { "alias": "description"; "required": false; "isSignal": true; }; "tooltip": { "alias": "tooltip"; "required": false; "isSignal": true; }; "icon": { "alias": "icon"; "required": false; "isSignal": true; }; "size": { "alias": "size"; "required": false; "isSignal": true; }; }, { "click": "click"; }, never, never, true, never>;
27
85
  }
@@ -1,39 +1,37 @@
1
- import { EventEmitter, OnDestroy, OnInit } from '@angular/core';
1
+ import { OnDestroy, OnInit } from '@angular/core';
2
2
  import { SdBaseSecureComponent } from '@sd-angular/core/components/base';
3
- import { SdColor } from '@sd-angular/core/utilities/models';
3
+ import { MaterialIconFontSet, SdColor } from '@sd-angular/core/utilities/models';
4
4
  import * as i0 from "@angular/core";
5
+ export type SdButtonType = 'fill' | 'light' | 'outline' | 'link';
6
+ export type SdButtonSize = 'sm' | 'md' | 'lg';
5
7
  export declare class SdButton extends SdBaseSecureComponent implements OnInit, OnDestroy {
6
8
  #private;
7
- autoId?: string;
8
- set _autoId(val: string | undefined | null);
9
- type: 'fill' | 'light' | 'outline' | 'link';
10
- set _type(type: 'fill' | 'light' | 'outline' | 'link' | undefined | null);
11
- color: SdColor;
12
- set _color(color: SdColor | undefined | null);
13
- title: string | undefined | null;
14
- width: string | undefined | null;
15
- size: 'sm' | 'md' | 'lg' | undefined | null;
16
- tooltip: string | undefined | null;
17
- prefixIcon: string | undefined | null;
18
- suffixIcon: string | undefined | null;
19
- fontSet: 'material-icons' | 'material-icons-outlined' | 'material-icons-round' | 'material-icons-sharp' | 'material-symbols-outlined';
20
- set _fontSet(fontSet: SdButton['fontSet'] | undefined | null);
21
- disabled: boolean;
22
- get disabledAttr(): "true" | null;
23
- set _disabled(value: '' | boolean | undefined | null);
24
- loading: boolean;
25
- click: EventEmitter<Event>;
26
- constructor();
27
- ngOnInit(): void;
28
- onInternalClick(event: Event): void;
29
- ngOnDestroy(): void;
30
- get buttonClasses(): {
9
+ private el;
10
+ autoIdInput: import("@angular/core").InputSignal<string | null | undefined>;
11
+ type: import("@angular/core").InputSignalWithTransform<SdButtonType, SdButtonType | null | undefined>;
12
+ color: import("@angular/core").InputSignalWithTransform<SdColor, SdColor | null | undefined>;
13
+ size: import("@angular/core").InputSignalWithTransform<SdButtonSize, SdButtonSize | null | undefined>;
14
+ fontSet: import("@angular/core").InputSignalWithTransform<MaterialIconFontSet, MaterialIconFontSet | null | undefined>;
15
+ title: import("@angular/core").InputSignal<string | null | undefined>;
16
+ width: import("@angular/core").InputSignal<string | null | undefined>;
17
+ tooltip: import("@angular/core").InputSignal<string | null | undefined>;
18
+ prefixIcon: import("@angular/core").InputSignal<string | null | undefined>;
19
+ suffixIcon: import("@angular/core").InputSignal<string | null | undefined>;
20
+ disabled: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
21
+ loading: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
22
+ autoId: import("@angular/core").Signal<string | undefined>;
23
+ buttonClasses: import("@angular/core").Signal<{
31
24
  'c-square': boolean | "" | null | undefined;
32
25
  'c-sm': boolean;
33
26
  'c-md': boolean;
34
27
  'c-lg': boolean;
35
28
  'c-disabled': boolean;
36
- };
29
+ }>;
30
+ click: import("@angular/core").OutputEmitterRef<Event>;
31
+ constructor();
32
+ ngOnInit(): void;
33
+ onInternalClick(event: Event): void;
34
+ ngOnDestroy(): void;
37
35
  static ɵfac: i0.ɵɵFactoryDeclaration<SdButton, never>;
38
- static ɵcmp: i0.ɵɵComponentDeclaration<SdButton, "sd-button", never, { "_autoId": { "alias": "autoId"; "required": false; }; "_type": { "alias": "type"; "required": false; }; "_color": { "alias": "color"; "required": false; }; "title": { "alias": "title"; "required": false; }; "width": { "alias": "width"; "required": false; }; "size": { "alias": "size"; "required": false; }; "tooltip": { "alias": "tooltip"; "required": false; }; "prefixIcon": { "alias": "prefixIcon"; "required": false; }; "suffixIcon": { "alias": "suffixIcon"; "required": false; }; "_fontSet": { "alias": "fontSet"; "required": false; }; "_disabled": { "alias": "disabled"; "required": false; }; "loading": { "alias": "loading"; "required": false; }; }, { "click": "click"; }, never, never, true, never>;
36
+ static ɵcmp: i0.ɵɵComponentDeclaration<SdButton, "sd-button", never, { "autoIdInput": { "alias": "autoId"; "required": false; "isSignal": true; }; "type": { "alias": "type"; "required": false; "isSignal": true; }; "color": { "alias": "color"; "required": false; "isSignal": true; }; "size": { "alias": "size"; "required": false; "isSignal": true; }; "fontSet": { "alias": "fontSet"; "required": false; "isSignal": true; }; "title": { "alias": "title"; "required": false; "isSignal": true; }; "width": { "alias": "width"; "required": false; "isSignal": true; }; "tooltip": { "alias": "tooltip"; "required": false; "isSignal": true; }; "prefixIcon": { "alias": "prefixIcon"; "required": false; "isSignal": true; }; "suffixIcon": { "alias": "suffixIcon"; "required": false; "isSignal": true; }; "disabled": { "alias": "disabled"; "required": false; "isSignal": true; }; "loading": { "alias": "loading"; "required": false; "isSignal": true; }; }, { "click": "click"; }, never, never, true, never>;
39
37
  }
@@ -0,0 +1 @@
1
+ export * from './src/code-editor.component';
@@ -0,0 +1,25 @@
1
+ import { SafeHtml } from '@angular/platform-browser';
2
+ import 'prismjs/components/prism-typescript';
3
+ import 'prismjs/components/prism-json';
4
+ import 'prismjs/components/prism-css';
5
+ import 'prismjs/components/prism-scss';
6
+ import 'prismjs/components/prism-markup';
7
+ import * as i0 from "@angular/core";
8
+ export type CodeLanguage = 'html' | 'typescript' | 'json' | 'css' | 'scss';
9
+ export declare class SdCodeEditor {
10
+ #private;
11
+ valueModel: import("@angular/core").ModelSignal<any>;
12
+ language: import("@angular/core").InputSignal<CodeLanguage>;
13
+ maxHeight: import("@angular/core").InputSignal<string>;
14
+ viewed: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
15
+ copied: import("@angular/core").WritableSignal<boolean>;
16
+ textValue: import("@angular/core").WritableSignal<string>;
17
+ prismLang: import("@angular/core").Signal<CodeLanguage | "markup">;
18
+ private _lastEmittedValue;
19
+ constructor();
20
+ highlightedCode: import("@angular/core").Signal<SafeHtml>;
21
+ onTextChange(newText: string): void;
22
+ copyToClipboard(): void;
23
+ static ɵfac: i0.ɵɵFactoryDeclaration<SdCodeEditor, never>;
24
+ static ɵcmp: i0.ɵɵComponentDeclaration<SdCodeEditor, "sd-code-editor", never, { "valueModel": { "alias": "model"; "required": false; "isSignal": true; }; "language": { "alias": "language"; "required": false; "isSignal": true; }; "maxHeight": { "alias": "maxHeight"; "required": false; "isSignal": true; }; "viewed": { "alias": "viewed"; "required": false; "isSignal": true; }; }, { "valueModel": "modelChange"; }, never, never, true, never>;
25
+ }
@@ -1,3 +1,4 @@
1
1
  export * from './src/components';
2
2
  export * from './src/document-builder.model';
3
3
  export * from './src/document-builder.component';
4
+ export * from './src/plugins/ck-comment/ck-comment.plugin.model';
@@ -1,6 +1,7 @@
1
1
  import { EventEmitter } from '@angular/core';
2
2
  import { ClassicEditor, ModelRange } from 'ckeditor5';
3
- import { SdDocumentBuilderComment, SdDocumentBuilderHeading, SdDocumentBuilderOption, SdDocumentBuilderVariable, SdEditorConfig } from './document-builder.model';
3
+ import { CkCommentPlugin } from './plugins';
4
+ import { SdDocumentBuilderHeading, SdDocumentBuilderOption, SdDocumentBuilderVariable, SdEditorConfig } from './document-builder.model';
4
5
  import * as i0 from "@angular/core";
5
6
  export declare class SdDocumentBuilder {
6
7
  #private;
@@ -19,49 +20,28 @@ export declare class SdDocumentBuilder {
19
20
  getOrientation: () => "PORTRAIT" | "LANDSCAPE";
20
21
  scrollToTop(): void;
21
22
  heading: {
22
- all: () => SdDocumentBuilderHeading[];
23
- scroll: (id: string) => void;
24
- };
25
- comment: {
26
- /**
27
- * Lấy tất cả comments trong document
28
- * @returns Danh sách tất cả comments
29
- */
30
- all: () => SdDocumentBuilderComment[];
31
- /**
32
- * Thêm comment vào vùng text đang được chọn
33
- * @param comment - Dữ liệu comment
34
- * @param data - Dữ liệu extra data
35
- * @returns SdDocumentBuilderComment hoặc null nếu không có text được chọn
36
- */
37
- add: <T = any>(range: ModelRange, comment: string, data?: T) => SdDocumentBuilderComment<T> | null;
38
23
  /**
39
- * Cập nhật nội dung comment
40
- * @param markerId - ID của marker
41
- * @param commentData - Dữ liệu mới
42
- * @returns Comment đã cập nhật hoặc null
24
+ * Lấy tất cả headings trong document
25
+ * @returns Danh sách tất cả headings
43
26
  */
44
- update: <T = any>(markerId: string, comment: string, data?: T) => SdDocumentBuilderComment<T> | null;
27
+ all: () => SdDocumentBuilderHeading[];
45
28
  /**
46
- * Lấy chi tiết comment theo markerId
47
- * @param markerId - ID của marker
48
- * @returns Comment hoặc null
29
+ * Scroll tới vị trí của heading
30
+ * @param id - ID của heading cần scroll tới
49
31
  */
50
- detail: (markerId: string) => SdDocumentBuilderComment | null;
32
+ scroll: (id: string) => void;
33
+ };
34
+ getCommentPluginAPI(): CkCommentPlugin | null;
35
+ variable: {
51
36
  /**
52
- * Xóa comment theo markerId
53
- * @param markerId - ID của marker cần xóa
54
- * @returns true nếu xóa thành công, false nếu không tìm thấy
37
+ * Lấy tất cả variabes trong document
38
+ * @returns Danh sách tất cả variables
55
39
  */
56
- remove: (markerId: string) => boolean;
40
+ all: <T = any>() => SdDocumentBuilderVariable<T>[];
57
41
  /**
58
- * Scroll đến vị trí comment
59
- * @param markerId - ID của marker cần scroll tới
42
+ * Scroll tới vị trí của variable
43
+ * @param uuid - uuid của variable FE sẽ tự sinh sau mỗi lần drop vào editor
60
44
  */
61
- scroll: (markerId: string) => void;
62
- };
63
- variable: {
64
- all: () => SdDocumentBuilderVariable[];
65
45
  scroll: (uuid: string) => void;
66
46
  };
67
47
  /**
@@ -77,6 +57,8 @@ export declare class SdDocumentBuilder {
77
57
  header?: string;
78
58
  footer?: string;
79
59
  }): void;
60
+ hightSelectRange: (range: ModelRange) => void;
61
+ removeHighlightSeclectRange: () => void;
80
62
  static ɵfac: i0.ɵɵFactoryDeclaration<SdDocumentBuilder, never>;
81
63
  static ɵcmp: i0.ɵɵComponentDeclaration<SdDocumentBuilder, "sd-document-builder", never, { "option": { "alias": "option"; "required": true; }; "_disabled": { "alias": "disabled"; "required": false; }; }, { "contentChange": "contentChange"; }, never, never, true, never>;
82
64
  }
@@ -1,13 +1,14 @@
1
- import { EditorConfig, EventInfo, ModelDocumentSelection, ModelRange } from 'ckeditor5';
1
+ import { EditorConfig, EventInfo, ModelDocumentSelection, ViewDataTransfer } from 'ckeditor5';
2
+ import { CkCommentConfig } from './plugins/ck-comment/ck-comment.plugin.model';
2
3
  export type SdEditorConfig = EditorConfig & {
3
4
  getOption?: () => SdDocumentBuilderOption;
4
5
  };
5
6
  export interface SdDocumentBuilderOption {
6
7
  onDropVariable?: (variable: SdDocumentBuilderVariable, dropIndex: number) => boolean | Promise<boolean | SdDocumentBuilderVariable>;
7
- onAddComment?: (range: ModelRange) => void;
8
- onSelectComment?: (markerId: string) => void;
8
+ comment?: CkCommentConfig;
9
9
  onSelection?: (selection: ModelDocumentSelection, $event: EventInfo<string, unknown>) => void;
10
10
  onOrientation?: (orientation: 'PORTRAIT' | 'LANDSCAPE') => void;
11
+ onPaste?: (data: SdPasteEventData) => void | Promise<void>;
11
12
  orientation?: 'PORTRAIT' | 'LANDSCAPE';
12
13
  }
13
14
  export interface SdDocumentBuilderVariable<T = any> {
@@ -17,16 +18,15 @@ export interface SdDocumentBuilderVariable<T = any> {
17
18
  display: string;
18
19
  data?: T;
19
20
  }
20
- export interface SdDocumentBuilderComment<T = any> {
21
- markerId: string;
22
- selectedText: string;
23
- comment?: string;
24
- createdAt?: Date;
25
- data?: T;
26
- }
27
21
  export interface SdDocumentBuilderHeading {
28
22
  id: string;
29
23
  text: string;
30
24
  level: number;
31
25
  type: string;
32
26
  }
27
+ export interface SdPasteEventData {
28
+ html?: string;
29
+ text: string;
30
+ source: 'word' | 'excel' | 'google-docs' | 'web' | 'unknown';
31
+ dataTransfer: ViewDataTransfer;
32
+ }
@@ -0,0 +1,9 @@
1
+ import { Plugin } from 'ckeditor5';
2
+ /**
3
+ * Plugin để thêm margin-bottom: 4px cho các block elements
4
+ * (paragraph, heading, list, table) thông qua downcast conversion
5
+ */
6
+ export declare class BlockSpace extends Plugin {
7
+ static get pluginName(): string;
8
+ init(): void;
9
+ }
@@ -0,0 +1,44 @@
1
+ import { Plugin, ContextualBalloon } from 'ckeditor5';
2
+ import { CkComment, CkCommentConfig, CkCommentColors } from './ck-comment.plugin.model';
3
+ export declare class CkCommentPlugin extends Plugin {
4
+ #private;
5
+ static get pluginName(): string;
6
+ static get requires(): (typeof ContextualBalloon)[];
7
+ static readonly PENDING_MARKER_ID = "__pending_comment__";
8
+ static readonly DEFAULT_SEARCH_RANGE = 5;
9
+ static readonly DEFAULT_MAX_TEXT_LENGTH = 1000;
10
+ static readonly DEFAULT_COLORS: CkCommentColors;
11
+ init(): void;
12
+ /**
13
+ * Thiết lập config với callbacks
14
+ */
15
+ setConfig(config: CkCommentConfig): void;
16
+ /**
17
+ * Thêm comment và tạo marker
18
+ */
19
+ addComment(comment: CkComment): boolean;
20
+ /**
21
+ * Xóa comment theo id
22
+ */
23
+ removeComment(id: string | number): boolean;
24
+ /**
25
+ * Chọn comment theo id - chỉ thêm class highlight, không bôi đen text
26
+ */
27
+ selectComment(id: string | number, scrollIntoView?: boolean): void;
28
+ /**
29
+ * Thiết lập tất cả comments (khôi phục từ dữ liệu)
30
+ */
31
+ setComments(comments: CkComment[]): void;
32
+ /**
33
+ * Lấy tất cả comments
34
+ */
35
+ get comments(): CkComment[];
36
+ /**
37
+ * Thiết lập pending highlight cho selection (khi user đang nhập nội dung comment)
38
+ */
39
+ setPendingSelection(startPath: number[], endPath: number[]): boolean;
40
+ /**
41
+ * Xóa pending highlight và fire onCancelPending callback
42
+ */
43
+ clearPendingSelection(): void;
44
+ }
@@ -0,0 +1,56 @@
1
+ import { ModelRange } from 'ckeditor5';
2
+ /**
3
+ * Comment status based on text changes
4
+ */
5
+ export type CkCommentStatus = 'normal' | 'modified' | 'broken';
6
+ /**
7
+ * Color configuration for comment markers
8
+ */
9
+ export interface CkCommentColors {
10
+ marker?: string;
11
+ markerSelected?: string;
12
+ markerPending?: string;
13
+ markerModified?: string;
14
+ markerBroken?: string;
15
+ }
16
+ /**
17
+ * Comment data structure for CkCommentPlugin
18
+ */
19
+ export interface CkComment<T = any> {
20
+ id: string | number;
21
+ startPath: number[];
22
+ endPath: number[];
23
+ originalText: string;
24
+ currentText: string;
25
+ status: CkCommentStatus;
26
+ data?: T;
27
+ }
28
+ /**
29
+ * Config for CkCommentPlugin
30
+ */
31
+ export interface CkCommentConfig {
32
+ onPendingComment?: (comment: CkComment) => void;
33
+ onAddComment?: (comment: CkComment) => void;
34
+ onSelectComment?: (id: string | number) => void;
35
+ onRemoveComment?: (id: string | number) => void;
36
+ onChange?: (comments: CkComment[]) => void;
37
+ onCancelPending?: () => void;
38
+ onError?: (error: {
39
+ code: string;
40
+ message: string;
41
+ data?: any;
42
+ }) => void;
43
+ searchRange?: number;
44
+ debug?: boolean;
45
+ colors?: CkCommentColors;
46
+ maxTextLength?: number;
47
+ }
48
+ /**
49
+ * Data returned when user selects text for comment
50
+ */
51
+ export interface CkCommentSelection {
52
+ range: ModelRange;
53
+ startPath: number[];
54
+ endPath: number[];
55
+ text: string;
56
+ }
@@ -1,4 +1,5 @@
1
1
  import { Plugin } from 'ckeditor5';
2
2
  export declare class HeadingPlugin extends Plugin {
3
+ static get pluginName(): string;
3
4
  init(): void;
4
5
  }
@@ -0,0 +1,4 @@
1
+ import { Plugin } from 'ckeditor5';
2
+ export declare class HighlightRangePlugin extends Plugin {
3
+ init(): void;
4
+ }