@simplysm/sd-claude 14.0.47 → 14.0.49

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 (130) hide show
  1. package/{claude/references/sd-simplysm14/sd-claude/usage.md → README.md} +2 -2
  2. package/claude/rules/sd-claude-rules.md +25 -10
  3. package/claude/rules/sd-options.md +11 -6
  4. package/claude/sd-subagent-start.sh +6 -0
  5. package/claude/settings.json +1 -12
  6. package/claude/skills/sd-check/SKILL.md +43 -12
  7. package/claude/skills/sd-claude-docs/SKILL.md +30 -58
  8. package/claude/skills/sd-claude-docs/references/package-claudemd.md +12 -0
  9. package/claude/skills/sd-claude-docs/references/package-doc-gen.md +26 -13
  10. package/claude/skills/sd-commit/SKILL.md +1 -1
  11. package/claude/skills/sd-debug/SKILL.md +5 -3
  12. package/claude/skills/sd-deliverable/SKILL.md +1 -1
  13. package/claude/skills/sd-dev/SKILL.md +14 -9
  14. package/claude/skills/sd-doc-extract/SKILL.md +8 -10
  15. package/claude/skills/sd-doc-extract/_common.py +8 -1
  16. package/claude/skills/sd-doc-extract/_extract_docx.py +74 -34
  17. package/claude/skills/sd-doc-extract/_extract_pdf.py +12 -1
  18. package/claude/skills/sd-doc-extract/_extract_pptx.py +103 -23
  19. package/claude/skills/sd-doc-extract/_extract_xlsb.py +93 -4
  20. package/claude/skills/sd-doc-extract/_extract_xlsx.py +98 -36
  21. package/claude/skills/sd-doc-extract/extract.py +22 -3
  22. package/claude/skills/sd-inner-clarify/SKILL.md +78 -0
  23. package/claude/skills/sd-inner-debug/SKILL.md +1 -1
  24. package/claude/skills/sd-inner-review/SKILL.md +13 -0
  25. package/claude/skills/sd-issue/SKILL.md +1 -1
  26. package/claude/skills/sd-outlook/SKILL.md +1 -1
  27. package/claude/skills/sd-plan/SKILL.md +50 -17
  28. package/claude/skills/sd-prompt/SKILL.md +180 -178
  29. package/claude/skills/sd-prompt/references/eval-runner.md +5 -30
  30. package/claude/skills/sd-prompt/references/sd-eval-env-template.md +23 -0
  31. package/claude/skills/sd-refactor/SKILL.md +2 -2
  32. package/claude/skills/sd-tdd/SKILL.md +45 -16
  33. package/claude/skills/sd-use/SKILL.md +84 -80
  34. package/claude/skills/sd-wbs/SKILL.md +84 -27
  35. package/{claude/references/sd-simplysm14/sd-claude/docs → docs}/assets.md +2 -3
  36. package/{claude/references/sd-simplysm14/sd-claude/docs → docs}/hooks.md +7 -6
  37. package/{claude/references/sd-simplysm14/sd-claude/docs → docs}/scripts.md +1 -9
  38. package/package.json +3 -2
  39. package/scripts/sync.mjs +4 -2
  40. package/claude/references/sd-simplysm14/angular/docs/bootstrap.md +0 -48
  41. package/claude/references/sd-simplysm14/angular/docs/directives.md +0 -236
  42. package/claude/references/sd-simplysm14/angular/docs/features.md +0 -379
  43. package/claude/references/sd-simplysm14/angular/docs/pipes.md +0 -32
  44. package/claude/references/sd-simplysm14/angular/docs/plugins.md +0 -37
  45. package/claude/references/sd-simplysm14/angular/docs/provider-types.md +0 -283
  46. package/claude/references/sd-simplysm14/angular/docs/providers.md +0 -379
  47. package/claude/references/sd-simplysm14/angular/docs/styling.md +0 -222
  48. package/claude/references/sd-simplysm14/angular/docs/type-utilities.md +0 -250
  49. package/claude/references/sd-simplysm14/angular/docs/ui-data.md +0 -275
  50. package/claude/references/sd-simplysm14/angular/docs/ui-form.md +0 -490
  51. package/claude/references/sd-simplysm14/angular/docs/ui-layout.md +0 -140
  52. package/claude/references/sd-simplysm14/angular/docs/ui-navigation.md +0 -273
  53. package/claude/references/sd-simplysm14/angular/docs/ui-overlay.md +0 -157
  54. package/claude/references/sd-simplysm14/angular/docs/ui-visual.md +0 -127
  55. package/claude/references/sd-simplysm14/angular/docs/utils.md +0 -295
  56. package/claude/references/sd-simplysm14/angular/usage.md +0 -489
  57. package/claude/references/sd-simplysm14/capacitor-plugin-auto-update/usage.md +0 -182
  58. package/claude/references/sd-simplysm14/capacitor-plugin-file-system/docs/file-operations.md +0 -154
  59. package/claude/references/sd-simplysm14/capacitor-plugin-file-system/docs/permissions.md +0 -84
  60. package/claude/references/sd-simplysm14/capacitor-plugin-file-system/docs/storage-paths.md +0 -107
  61. package/claude/references/sd-simplysm14/capacitor-plugin-file-system/docs/types.md +0 -83
  62. package/claude/references/sd-simplysm14/capacitor-plugin-file-system/usage.md +0 -133
  63. package/claude/references/sd-simplysm14/capacitor-plugin-intent/usage.md +0 -203
  64. package/claude/references/sd-simplysm14/capacitor-plugin-usb-storage/usage.md +0 -258
  65. package/claude/references/sd-simplysm14/core-browser/usage.md +0 -306
  66. package/claude/references/sd-simplysm14/core-common/docs/errors.md +0 -82
  67. package/claude/references/sd-simplysm14/core-common/docs/extensions.md +0 -167
  68. package/claude/references/sd-simplysm14/core-common/docs/features.md +0 -136
  69. package/claude/references/sd-simplysm14/core-common/docs/types.md +0 -245
  70. package/claude/references/sd-simplysm14/core-common/docs/utils.md +0 -591
  71. package/claude/references/sd-simplysm14/core-common/usage.md +0 -255
  72. package/claude/references/sd-simplysm14/core-node/docs/child-process.md +0 -182
  73. package/claude/references/sd-simplysm14/core-node/docs/features.md +0 -214
  74. package/claude/references/sd-simplysm14/core-node/docs/file-system.md +0 -509
  75. package/claude/references/sd-simplysm14/core-node/docs/file-watching.md +0 -139
  76. package/claude/references/sd-simplysm14/core-node/docs/logging.md +0 -180
  77. package/claude/references/sd-simplysm14/core-node/docs/path.md +0 -176
  78. package/claude/references/sd-simplysm14/core-node/docs/utilities-cpx.md +0 -194
  79. package/claude/references/sd-simplysm14/core-node/docs/utilities-fsx.md +0 -469
  80. package/claude/references/sd-simplysm14/core-node/docs/utilities-pathx.md +0 -151
  81. package/claude/references/sd-simplysm14/core-node/docs/worker-threads.md +0 -334
  82. package/claude/references/sd-simplysm14/core-node/docs/worker.md +0 -205
  83. package/claude/references/sd-simplysm14/core-node/usage.md +0 -259
  84. package/claude/references/sd-simplysm14/excel/docs/core-classes.md +0 -453
  85. package/claude/references/sd-simplysm14/excel/docs/types.md +0 -459
  86. package/claude/references/sd-simplysm14/excel/docs/utilities.md +0 -194
  87. package/claude/references/sd-simplysm14/excel/docs/wrapper.md +0 -73
  88. package/claude/references/sd-simplysm14/excel/usage.md +0 -134
  89. package/claude/references/sd-simplysm14/lint/usage.md +0 -130
  90. package/claude/references/sd-simplysm14/orm-common/docs/core.md +0 -188
  91. package/claude/references/sd-simplysm14/orm-common/docs/expression.md +0 -190
  92. package/claude/references/sd-simplysm14/orm-common/docs/models.md +0 -17
  93. package/claude/references/sd-simplysm14/orm-common/docs/query-builder.md +0 -97
  94. package/claude/references/sd-simplysm14/orm-common/docs/queryable-executable.md +0 -250
  95. package/claude/references/sd-simplysm14/orm-common/docs/schema-builders.md +0 -364
  96. package/claude/references/sd-simplysm14/orm-common/docs/types.md +0 -522
  97. package/claude/references/sd-simplysm14/orm-common/usage.md +0 -229
  98. package/claude/references/sd-simplysm14/orm-node/docs/connections.md +0 -137
  99. package/claude/references/sd-simplysm14/orm-node/docs/core.md +0 -131
  100. package/claude/references/sd-simplysm14/orm-node/docs/types.md +0 -173
  101. package/claude/references/sd-simplysm14/orm-node/usage.md +0 -143
  102. package/claude/references/sd-simplysm14/sd-cli/usage.md +0 -782
  103. package/claude/references/sd-simplysm14/service-client/docs/features.md +0 -217
  104. package/claude/references/sd-simplysm14/service-client/docs/main.md +0 -148
  105. package/claude/references/sd-simplysm14/service-client/docs/protocol.md +0 -53
  106. package/claude/references/sd-simplysm14/service-client/docs/transport.md +0 -131
  107. package/claude/references/sd-simplysm14/service-client/docs/types.md +0 -129
  108. package/claude/references/sd-simplysm14/service-client/usage.md +0 -202
  109. package/claude/references/sd-simplysm14/service-common/docs/app-structure.md +0 -175
  110. package/claude/references/sd-simplysm14/service-common/docs/events.md +0 -64
  111. package/claude/references/sd-simplysm14/service-common/docs/protocol.md +0 -331
  112. package/claude/references/sd-simplysm14/service-common/docs/service-types.md +0 -90
  113. package/claude/references/sd-simplysm14/service-common/docs/types.md +0 -19
  114. package/claude/references/sd-simplysm14/service-common/usage.md +0 -154
  115. package/claude/references/sd-simplysm14/service-server/docs/auth.md +0 -64
  116. package/claude/references/sd-simplysm14/service-server/docs/core.md +0 -174
  117. package/claude/references/sd-simplysm14/service-server/docs/legacy.md +0 -25
  118. package/claude/references/sd-simplysm14/service-server/docs/main.md +0 -88
  119. package/claude/references/sd-simplysm14/service-server/docs/protocol.md +0 -33
  120. package/claude/references/sd-simplysm14/service-server/docs/services.md +0 -94
  121. package/claude/references/sd-simplysm14/service-server/docs/transport-http.md +0 -93
  122. package/claude/references/sd-simplysm14/service-server/docs/transport-socket.md +0 -119
  123. package/claude/references/sd-simplysm14/service-server/docs/types.md +0 -36
  124. package/claude/references/sd-simplysm14/service-server/docs/utils.md +0 -22
  125. package/claude/references/sd-simplysm14/service-server/usage.md +0 -171
  126. package/claude/references/sd-simplysm14/storage/usage.md +0 -301
  127. package/claude/references/sd-simplysm14.md +0 -35
  128. package/claude/rules/sd-clarify.md +0 -23
  129. package/claude/sd-session-start.sh +0 -10
  130. /package/{claude/references/sd-simplysm14/sd-claude/docs → docs}/cli.md +0 -0
@@ -1,490 +0,0 @@
1
- # UI - Form
2
-
3
- ## Buttons
4
-
5
- ### `SdButton`
6
-
7
- 버튼 컴포넌트.
8
-
9
- ```typescript
10
- @Component({ selector: "sd-button" })
11
- class SdButton {
12
- type = input<"button" | "submit">("button");
13
- theme = input<"primary" | "secondary" | "info" | ... | "link" | "link-primary" | ... | "link-rev">();
14
- inline = input(false, { transform: booleanAttribute });
15
- inset = input(false, { transform: booleanAttribute });
16
- size = input<"sm" | "lg">();
17
- disabled = input(false, { transform: booleanAttribute });
18
- buttonStyle = input<string>();
19
- buttonClass = input<string>();
20
- }
21
- ```
22
-
23
- | Input | Type | Default | Description |
24
- |-------|------|---------|-------------|
25
- | `type` | `"button" \| "submit"` | `"button"` | 버튼 HTML 타입 |
26
- | `theme` | `string \| undefined` | `undefined` | 테마 (primary, secondary, info, success, warning, danger, gray, blue-gray, link, link-primary, link-secondary, link-info, link-success, link-warning, link-danger, link-gray, link-blue-gray, link-rev) |
27
- | `inline` | `boolean` | `false` | 인라인 표시 |
28
- | `inset` | `boolean` | `false` | 테두리 없는 삽입 스타일 |
29
- | `size` | `"sm" \| "lg" \| undefined` | `undefined` | 크기 |
30
- | `disabled` | `boolean` | `false` | 비활성화 |
31
- | `buttonStyle` | `string \| undefined` | `undefined` | 버튼 인라인 스타일 |
32
- | `buttonClass` | `string \| undefined` | `undefined` | 버튼 CSS 클래스 |
33
-
34
- 호스트 속성: `data-sd-theme`, `data-sd-inline`, `data-sd-size`, `data-sd-inset`, `data-sd-disabled`
35
-
36
- ### `SdAnchor`
37
-
38
- 앵커(인라인 버튼) 컴포넌트. 텍스트 내 클릭 가능 요소.
39
-
40
- ```typescript
41
- @Component({ selector: "sd-anchor" })
42
- class SdAnchor {
43
- disabled = input(false, { transform: booleanAttribute });
44
- theme = input<"primary" | "secondary" | "info" | "success" | "warning" | "danger" | "gray" | "blue-gray">("primary");
45
- }
46
- ```
47
-
48
- | Input | Type | Default | Description |
49
- |-------|------|---------|-------------|
50
- | `disabled` | `boolean` | `false` | 비활성화 |
51
- | `theme` | `string` | `"primary"` | 테마 색상 |
52
-
53
- ### `SdAdditionalButton`
54
-
55
- 추가 동작 버튼. 드롭다운 포함.
56
-
57
- ```typescript
58
- @Component({ selector: "sd-additional-button" })
59
- class SdAdditionalButton {
60
- size = input<"sm" | "lg">();
61
- inset = input(false, { transform: booleanAttribute });
62
- }
63
- ```
64
-
65
- ### `SdModalSelectButton`
66
-
67
- 모달을 열어 선택하는 버튼 컴포넌트. 선택/지우기 버튼과 값 표시 영역으로 구성.
68
-
69
- ```typescript
70
- @Component({ selector: "sd-modal-select-button" })
71
- class SdModalSelectButton<T extends object, K, M extends keyof SelectModeValue<K>> {
72
- modal = input.required<SdSelectModalInfo<SdSelectModal<T>>>();
73
- value = model<SelectModeValue<K>[M]>();
74
- selectedItems = model<T[]>([]);
75
- disabled = input(false, { transform: booleanAttribute });
76
- required = input(false, { transform: booleanAttribute });
77
- inset = input(false, { transform: booleanAttribute });
78
- size = input<"sm" | "lg">();
79
- selectMode = input<M>("single" as M);
80
- modalOptions = input<SdModalOptions>();
81
- searchIcon = input(tablerSearch);
82
- }
83
- ```
84
-
85
- | Input | Type | Default | Description |
86
- |-------|------|---------|-------------|
87
- | `modal` | `SdSelectModalInfo<...>` | required | 모달 정보 |
88
- | `value` | `SelectModeValue<K>[M]` | - | 선택된 값 (two-way) |
89
- | `selectedItems` | `T[]` | `[]` | 선택된 항목 객체 배열 (two-way) |
90
- | `disabled` | `boolean` | `false` | 비활성화 |
91
- | `required` | `boolean` | `false` | 필수 (지우기 버튼 숨김) |
92
- | `inset` | `boolean` | `false` | 삽입 스타일 |
93
- | `size` | `"sm" \| "lg" \| undefined` | `undefined` | 크기 |
94
- | `selectMode` | `M` | `"single"` | 선택 모드 |
95
- | `modalOptions` | `SdModalOptions \| undefined` | `undefined` | 모달 옵션 |
96
- | `searchIcon` | `string` | `tablerSearch` | 검색 아이콘 |
97
-
98
- ## Inputs
99
-
100
- ### `SdTextfield`
101
-
102
- 텍스트 입력 컴포넌트. 13가지 타입을 지원한다.
103
-
104
- ```typescript
105
- @Component({ selector: "sd-textfield" })
106
- class SdTextfield<K extends keyof SdTextfieldTypes> {
107
- value = model<SdTextfieldTypes[K]>();
108
- type = input.required<K>();
109
- placeholder = input<string>();
110
- title = input<string>();
111
- inputStyle = input<string>();
112
- inputClass = input<string>();
113
- disabled = input(false, { transform: booleanAttribute });
114
- readonly = input(false, { transform: booleanAttribute });
115
- required = input(false, { transform: booleanAttribute });
116
- min = input<SdTextfieldTypes[K]>();
117
- max = input<SdTextfieldTypes[K]>();
118
- minlength = input<number>();
119
- maxlength = input<number>();
120
- pattern = input<string>();
121
- validatorFn = input<(value: SdTextfieldTypes[K] | undefined) => string | undefined>();
122
- format = input<string>();
123
- step = input<number>();
124
- autocomplete = input<string>();
125
- useNumberComma = input(true, { transform: booleanAttribute });
126
- minDigits = input<number>();
127
- inline = input(false, { transform: booleanAttribute });
128
- inset = input(false, { transform: booleanAttribute });
129
- size = input<"sm" | "lg">();
130
- theme = input<string>();
131
- }
132
- ```
133
-
134
- | Input | Type | Default | Description |
135
- |-------|------|---------|-------------|
136
- | `type` | `keyof SdTextfieldTypes` | required | 입력 타입 (number, text, password, color, email, format, date, month, year, datetime, datetime-sec, time, time-sec) |
137
- | `value` | `SdTextfieldTypes[K] \| undefined` | - | 값 (two-way) |
138
- | `placeholder` | `string \| undefined` | `undefined` | 플레이스홀더 |
139
- | `title` | `string \| undefined` | `undefined` | title 속성 (없으면 placeholder 사용) |
140
- | `inputStyle` | `string \| undefined` | `undefined` | input 인라인 스타일 |
141
- | `inputClass` | `string \| undefined` | `undefined` | input CSS 클래스 |
142
- | `disabled` | `boolean` | `false` | 비활성화 |
143
- | `readonly` | `boolean` | `false` | 읽기 전용 |
144
- | `required` | `boolean` | `false` | 필수 |
145
- | `min` | `SdTextfieldTypes[K] \| undefined` | `undefined` | 최소값 |
146
- | `max` | `SdTextfieldTypes[K] \| undefined` | `undefined` | 최대값 |
147
- | `minlength` | `number \| undefined` | `undefined` | 최소 길이 |
148
- | `maxlength` | `number \| undefined` | `undefined` | 최대 길이 |
149
- | `pattern` | `string \| undefined` | `undefined` | 입력 패턴 (정규식) |
150
- | `validatorFn` | `((value) => string \| undefined) \| undefined` | `undefined` | 커스텀 유효성 검증 함수 (에러 메시지 반환) |
151
- | `format` | `string \| undefined` | `undefined` | format 타입에서 사용할 포맷 문자열 |
152
- | `step` | `number \| undefined` | `undefined` | 증감 단위 |
153
- | `autocomplete` | `string \| undefined` | `undefined` | autocomplete 속성 |
154
- | `useNumberComma` | `boolean` | `true` | number 타입에서 천 단위 쉼표 사용 |
155
- | `minDigits` | `number \| undefined` | `undefined` | number 타입 최소 자릿수 |
156
- | `inline` | `boolean` | `false` | 인라인 표시 |
157
- | `inset` | `boolean` | `false` | 삽입 스타일 |
158
- | `size` | `"sm" \| "lg" \| undefined` | `undefined` | 크기 |
159
- | `theme` | `string \| undefined` | `undefined` | 테마 |
160
-
161
- ### `SdTextarea`
162
-
163
- 멀티라인 텍스트 입력 컴포넌트.
164
-
165
- ```typescript
166
- @Component({ selector: "sd-textarea" })
167
- class SdTextarea {
168
- value = model<string>();
169
- placeholder = input<string>();
170
- title = input<string>();
171
- minRows = input<number>(1);
172
- disabled = input(false, { transform: booleanAttribute });
173
- readonly = input(false, { transform: booleanAttribute });
174
- required = input(false, { transform: booleanAttribute });
175
- inline = input(false, { transform: booleanAttribute });
176
- inset = input(false, { transform: booleanAttribute });
177
- size = input<"sm" | "lg">();
178
- validatorFn = input<(value: string | undefined) => string | undefined>();
179
- theme = input<string>();
180
- inputStyle = input<string>();
181
- inputClass = input<string>();
182
- }
183
- ```
184
-
185
- ### `SdNumpad`
186
-
187
- 숫자 패드 컴포넌트.
188
-
189
- ```typescript
190
- @Component({ selector: "sd-numpad" })
191
- class SdNumpad {
192
- placeholder = input<string>();
193
- value = model<number>();
194
- required = input(false, { transform: booleanAttribute });
195
- inputDisabled = input(false, { transform: booleanAttribute });
196
- useEnterButton = input(false, { transform: booleanAttribute });
197
- useMinusButton = input(false, { transform: booleanAttribute });
198
-
199
- enterButtonClick = output();
200
- }
201
- ```
202
-
203
- | Input | Type | Default | Description |
204
- |-------|------|---------|-------------|
205
- | `placeholder` | `string \| undefined` | `undefined` | 플레이스홀더 |
206
- | `value` | `number \| undefined` | - | 값 (two-way) |
207
- | `required` | `boolean` | `false` | 필수 |
208
- | `inputDisabled` | `boolean` | `false` | 입력 필드 비활성화 |
209
- | `useEnterButton` | `boolean` | `false` | 엔터 버튼 표시 |
210
- | `useMinusButton` | `boolean` | `false` | 마이너스 버튼 표시 |
211
-
212
- | Output | Type | Description |
213
- |--------|------|-------------|
214
- | `enterButtonClick` | `void` | 엔터 버튼 클릭 시 발생 |
215
-
216
- ### `SdRange`
217
-
218
- 범위 슬라이더 컴포넌트.
219
-
220
- ```typescript
221
- @Component({ selector: "sd-range" })
222
- class SdRange<K extends keyof SdTextfieldTypes> {
223
- type = input.required<K>();
224
- from = model<SdTextfieldTypes[K]>();
225
- to = model<SdTextfieldTypes[K]>();
226
- inputStyle = input<string>();
227
- required = input(false, { transform: booleanAttribute });
228
- disabled = input(false, { transform: booleanAttribute });
229
- }
230
- ```
231
-
232
- ### `SdDateRangePicker`
233
-
234
- 날짜 범위 선택기.
235
-
236
- ```typescript
237
- @Component({ selector: "sd-date-range-picker" })
238
- class SdDateRangePicker {
239
- periodType = model<"일" | "월" | "범위">("범위");
240
- from = model<DateOnly>();
241
- to = model<DateOnly>();
242
- required = input(false, { transform: booleanAttribute });
243
- }
244
- ```
245
-
246
- | Input | Type | Default | Description |
247
- |-------|------|---------|-------------|
248
- | `periodType` | `"일" \| "월" \| "범위"` | `"범위"` | 기간 선택 타입 (two-way) |
249
- | `from` | `DateOnly \| undefined` | - | 시작일 (two-way) |
250
- | `to` | `DateOnly \| undefined` | - | 종료일 (two-way) |
251
- | `required` | `boolean` | `false` | 필수 |
252
-
253
- ## Choice
254
-
255
- ### `SdStatePreset`
256
-
257
- 상태 프리셋 저장/불러오기 컴포넌트. 사용자 설정을 저장하고 복원한다.
258
-
259
- ```typescript
260
- @Component({ selector: "sd-state-preset" })
261
- class SdStatePreset {
262
- key = input.required<string>();
263
- state = model<any>();
264
- size = input<"sm" | "lg">();
265
- }
266
- ```
267
-
268
- | Input | Type | Default | Description |
269
- |-------|------|---------|-------------|
270
- | `key` | `string` | required | 프리셋 저장 키 |
271
- | `state` | `any` | - | 상태 데이터 (two-way) |
272
- | `size` | `"sm" \| "lg" \| undefined` | `undefined` | 크기 |
273
-
274
- ### `SdStatePresetDef`
275
-
276
- ```typescript
277
- interface SdStatePresetDef {
278
- name: string;
279
- state: any;
280
- }
281
- ```
282
-
283
- | Field | Type | Description |
284
- |-------|------|-------------|
285
- | `name` | `string` | 프리셋 이름 |
286
- | `state` | `any` | 저장된 상태 데이터 |
287
-
288
- ## Checkbox
289
-
290
- ### `SdCheckbox`
291
-
292
- 체크박스 컴포넌트.
293
-
294
- ```typescript
295
- @Component({ selector: "sd-checkbox" })
296
- class SdCheckbox {
297
- value = model(false);
298
- canChangeFn = input<(item: boolean) => boolean | Promise<boolean>>(() => true);
299
- icon = input(tablerCheck);
300
- radio = input(false, { transform: booleanAttribute });
301
- disabled = input(false, { transform: booleanAttribute });
302
- size = input<"sm" | "lg">();
303
- inline = input(false, { transform: booleanAttribute });
304
- inset = input(false, { transform: booleanAttribute });
305
- theme = input<"primary" | "secondary" | ...>();
306
- contentStyle = input<string>();
307
- }
308
- ```
309
-
310
- | Input | Type | Default | Description |
311
- |-------|------|---------|-------------|
312
- | `value` | `boolean` | `false` | 체크 여부 (two-way) |
313
- | `canChangeFn` | `(item: boolean) => boolean \| Promise<boolean>` | `() => true` | 값 변경 가능 여부 함수 |
314
- | `icon` | `string` | `tablerCheck` | 체크 아이콘 |
315
- | `radio` | `boolean` | `false` | 라디오 버튼 스타일 |
316
- | `disabled` | `boolean` | `false` | 비활성화 |
317
- | `size` | `"sm" \| "lg" \| undefined` | `undefined` | 크기 |
318
- | `inline` | `boolean` | `false` | 인라인 표시 |
319
- | `inset` | `boolean` | `false` | 삽입 스타일 |
320
- | `theme` | `string \| undefined` | `undefined` | 테마 색상 |
321
- | `contentStyle` | `string \| undefined` | `undefined` | 컨텐츠 인라인 스타일 |
322
-
323
- ### `SdSwitch`
324
-
325
- 스위치 토글 컴포넌트.
326
-
327
- ```typescript
328
- @Component({ selector: "sd-switch" })
329
- class SdSwitch {
330
- value = model(false);
331
- canChangeFn = input<(item: boolean) => boolean | Promise<boolean>>(() => true);
332
- disabled = input(false, { transform: booleanAttribute });
333
- inline = input(false, { transform: booleanAttribute });
334
- inset = input(false, { transform: booleanAttribute });
335
- size = input<"sm" | "lg">();
336
- theme = input<string>();
337
- }
338
- ```
339
-
340
- ### `SdCheckboxGroup`
341
-
342
- 체크박스 그룹 컴포넌트.
343
-
344
- ```typescript
345
- @Component({ selector: "sd-checkbox-group" })
346
- class SdCheckboxGroup<T> {
347
- value = model<T[]>([]);
348
- disabled = input(false, { transform: booleanAttribute });
349
- }
350
- ```
351
-
352
- ### `SdCheckboxGroupItem`
353
-
354
- 체크박스 그룹 항목.
355
-
356
- ```typescript
357
- @Component({ selector: "sd-checkbox-group-item" })
358
- class SdCheckboxGroupItem<T> {
359
- value = input.required<T>();
360
- inline = input(false, { transform: booleanAttribute });
361
- }
362
- ```
363
-
364
- ## Editor
365
-
366
- ### `SdTiptapEditor`
367
-
368
- TipTap 기반 리치 텍스트 에디터.
369
-
370
- ```typescript
371
- @Component({ selector: "sd-tiptap-editor" })
372
- class SdTiptapEditor {
373
- value = model<string>();
374
- disabled = input(false, { transform: booleanAttribute });
375
- readonly = input(false, { transform: booleanAttribute });
376
- required = input(false, { transform: booleanAttribute });
377
- placeholder = input<string>();
378
- validatorFn = input<(value: string | undefined) => string | undefined>();
379
- extensions = input<AnyExtension[]>();
380
- }
381
- ```
382
-
383
- | Input | Type | Default | Description |
384
- |-------|------|---------|-------------|
385
- | `value` | `string \| undefined` | - | HTML 콘텐츠 (two-way) |
386
- | `disabled` | `boolean` | `false` | 비활성화 |
387
- | `readonly` | `boolean` | `false` | 읽기 전용 |
388
- | `required` | `boolean` | `false` | 필수 |
389
- | `placeholder` | `string \| undefined` | `undefined` | 플레이스홀더 |
390
- | `validatorFn` | `((value) => string \| undefined) \| undefined` | `undefined` | 커스텀 유효성 검증 함수 |
391
- | `extensions` | `AnyExtension[] \| undefined` | `undefined` | 추가 TipTap 확장 |
392
-
393
- ## Select
394
-
395
- ### `SdSelect`
396
-
397
- 드롭다운 선택 컴포넌트. single/multi 모드를 지원한다.
398
-
399
- ```typescript
400
- @Component({ selector: "sd-select" })
401
- class SdSelect<T, M extends keyof SelectModeValue<T>> {
402
- selectMode = input("single" as M);
403
- value = model<SelectModeValue<any>[M]>();
404
- placeholder = input<string>();
405
- disabled = input(false, { transform: booleanAttribute });
406
- inline = input(false, { transform: booleanAttribute });
407
- inset = input(false, { transform: booleanAttribute });
408
- size = input<"sm" | "lg">();
409
- required = input(false, { transform: booleanAttribute });
410
- hideSelectAll = input(false, { transform: booleanAttribute });
411
- multiSelectionDisplayDirection = input<"vertical">();
412
- items = input<T[]>();
413
- getChildrenFn = input<(item: T) => T[] | undefined>();
414
- contentClass = input<string>();
415
- contentStyle = input<string>();
416
- }
417
- ```
418
-
419
- | Input | Type | Default | Description |
420
- |-------|------|---------|-------------|
421
- | `selectMode` | `M` | `"single"` | 선택 모드 |
422
- | `value` | `SelectModeValue<any>[M]` | - | 선택된 값 (two-way) |
423
- | `placeholder` | `string \| undefined` | `undefined` | 플레이스홀더 |
424
- | `disabled` | `boolean` | `false` | 비활성화 |
425
- | `inline` | `boolean` | `false` | 인라인 표시 |
426
- | `inset` | `boolean` | `false` | 삽입 스타일 |
427
- | `size` | `"sm" \| "lg" \| undefined` | `undefined` | 크기 |
428
- | `required` | `boolean` | `false` | 필수 |
429
- | `hideSelectAll` | `boolean` | `false` | multi 모드에서 전체 선택 숨김 |
430
- | `multiSelectionDisplayDirection` | `"vertical" \| undefined` | `undefined` | multi 모드 표시 방향 |
431
- | `items` | `T[] \| undefined` | `undefined` | 항목 배열 (selectMode가 "multi"일 때 내부 목록 렌더링용) |
432
- | `getChildrenFn` | `((item) => T[] \| undefined) \| undefined` | `undefined` | 트리 구조 자식 함수 |
433
- | `contentClass` | `string \| undefined` | `undefined` | 컨텐츠 CSS 클래스 |
434
- | `contentStyle` | `string \| undefined` | `undefined` | 컨텐츠 인라인 스타일 |
435
-
436
- ### `SelectModeValue`
437
-
438
- ```typescript
439
- type SelectModeValue<T> = {
440
- multi: T[];
441
- single: T;
442
- }
443
- ```
444
-
445
- ### `SdSelectItem`
446
-
447
- 드롭다운 선택 항목.
448
-
449
- ```typescript
450
- @Component({ selector: "sd-select-item" })
451
- class SdSelectItem<T> {
452
- value = input.required<T>();
453
- disabled = input(false, { transform: booleanAttribute });
454
- hidden = input(false, { transform: booleanAttribute });
455
- }
456
- ```
457
-
458
- ### `SdSelectButton`
459
-
460
- 버튼 스타일 선택 컴포넌트.
461
-
462
- ```typescript
463
- @Component({ selector: "sd-select-button" })
464
- class SdSelectButton<T> { }
465
- ```
466
-
467
- ## Form
468
-
469
- ### `SdForm`
470
-
471
- 폼 래퍼 컴포넌트. `<form>` 태그를 렌더링하며 submit 이벤트 처리 및 유효성 검증을 수행한다.
472
-
473
- ```typescript
474
- @Component({ selector: "sd-form" })
475
- class SdForm {
476
- formSubmit = output<SubmitEvent>();
477
- formInvalid = output();
478
-
479
- requestSubmit(): void;
480
- }
481
- ```
482
-
483
- | Output | Type | Description |
484
- |--------|------|-------------|
485
- | `formSubmit` | `SubmitEvent` | 유효성 검증 통과 시 발생 |
486
- | `formInvalid` | `void` | 유효성 검증 실패 시 발생 (`reportValidity()` 호출 후) |
487
-
488
- | Method | Description |
489
- |--------|-------------|
490
- | `requestSubmit()` | 프로그래밍 방식으로 submit 트리거 |
@@ -1,140 +0,0 @@
1
- # UI - Layout
2
-
3
- ## `SdDockContainer`
4
-
5
- 도킹 레이아웃 컨테이너. `SdDock`과 함께 사용하여 상/하/좌/우 고정 영역을 만든다.
6
-
7
- ```typescript
8
- @Component({ selector: "sd-dock-container" })
9
- class SdDockContainer { }
10
- ```
11
-
12
- ## `SdDock`
13
-
14
- 도킹 영역 컴포넌트. `SdDockContainer` 내부에서 사용.
15
-
16
- ```typescript
17
- @Component({ selector: "sd-dock" })
18
- class SdDock {
19
- key = input<string>();
20
- position = input<"top" | "bottom" | "right" | "left">("top");
21
- resizable = input(false, { transform: booleanAttribute });
22
- }
23
- ```
24
-
25
- | Input | Type | Default | Description |
26
- |-------|------|---------|-------------|
27
- | `key` | `string \| undefined` | `undefined` | 리사이즈 설정 저장 키 |
28
- | `position` | `"top" \| "bottom" \| "right" \| "left"` | `"top"` | 도킹 위치 |
29
- | `resizable` | `boolean` | `false` | 크기 조절 가능 여부 |
30
-
31
- ## `SdGap`
32
-
33
- 간격(gap) 컴포넌트. 요소 사이에 공간을 추가한다.
34
-
35
- ```typescript
36
- @Component({ selector: "sd-gap" })
37
- class SdGap { }
38
- ```
39
-
40
- ## `SdKanbanBoard`
41
-
42
- 칸반 보드 컨테이너. 드래그앤드롭을 지원한다.
43
-
44
- ```typescript
45
- @Component({ selector: "sd-kanban-board" })
46
- class SdKanbanBoard<L, T> {
47
- selectedValues = model<T[]>([]);
48
- drop = output<SdKanbanBoardDropInfo<L, T>>();
49
- }
50
- ```
51
-
52
- | Input | Type | Default | Description |
53
- |-------|------|---------|-------------|
54
- | `selectedValues` | `T[]` | `[]` | 선택된 칸반 아이템 값 배열 (two-way) |
55
-
56
- ### `SdKanbanBoardDropInfo`
57
-
58
- ```typescript
59
- interface SdKanbanBoardDropInfo<L, T> {
60
- sourceKanbanValue?: T;
61
- targetLaneValue?: L;
62
- targetKanbanValue?: T;
63
- }
64
- ```
65
-
66
- | Field | Type | Description |
67
- |-------|------|-------------|
68
- | `sourceKanbanValue` | `T \| undefined` | 드래그한 칸반 아이템의 값 |
69
- | `targetLaneValue` | `L \| undefined` | 드롭 대상 레인의 값 |
70
- | `targetKanbanValue` | `T \| undefined` | 드롭 대상 칸반 아이템의 값 (칸반 위에 드롭 시) |
71
-
72
- ### `SdKanbanDragRef`
73
-
74
- ```typescript
75
- interface SdKanbanDragRef<_L, T> {
76
- value(): T | undefined;
77
- heightOnDrag(): number;
78
- }
79
- ```
80
-
81
- | Field | Type | Description |
82
- |-------|------|-------------|
83
- | `value()` | `T \| undefined` | 드래그 중인 칸반 아이템의 값 |
84
- | `heightOnDrag()` | `number` | 드래그 시작 시점의 요소 높이 |
85
-
86
- ### `SdKanbanDropTarget`
87
-
88
- ```typescript
89
- interface SdKanbanDropTarget<L, T> {
90
- targetLaneValue(): L | undefined;
91
- targetKanbanValue?(): T | undefined;
92
- }
93
- ```
94
-
95
- | Field | Type | Description |
96
- |-------|------|-------------|
97
- | `targetLaneValue()` | `L \| undefined` | 드롭 대상 레인의 값 |
98
- | `targetKanbanValue?()` | `T \| undefined` | 드롭 대상 칸반 아이템의 값 (optional) |
99
-
100
- ## `SdKanban`
101
-
102
- 칸반 아이템 컴포넌트.
103
-
104
- ```typescript
105
- @Component({ selector: "sd-kanban" })
106
- class SdKanban<L, T> {
107
- value = input<T>();
108
- selectable = input(false, { transform: booleanAttribute });
109
- draggable = input(false, { transform: booleanAttribute });
110
- contentClass = input<string>();
111
- }
112
- ```
113
-
114
- | Input | Type | Default | Description |
115
- |-------|------|---------|-------------|
116
- | `value` | `T \| undefined` | `undefined` | 칸반 아이템의 값 |
117
- | `selectable` | `boolean` | `false` | 선택 가능 여부 |
118
- | `draggable` | `boolean` | `false` | 드래그 가능 여부 |
119
- | `contentClass` | `string \| undefined` | `undefined` | 컨텐츠 CSS 클래스 |
120
-
121
- ## `SdKanbanLane`
122
-
123
- 칸반 레인 컴포넌트.
124
-
125
- ```typescript
126
- @Component({ selector: "sd-kanban-lane" })
127
- class SdKanbanLane<L, T> {
128
- busy = input(false, { transform: booleanAttribute });
129
- useCollapse = input(false, { transform: booleanAttribute });
130
- collapse = model(false);
131
- value = input<L>();
132
- }
133
- ```
134
-
135
- | Input | Type | Default | Description |
136
- |-------|------|---------|-------------|
137
- | `busy` | `boolean` | `false` | busy 상태 |
138
- | `useCollapse` | `boolean` | `false` | 접기 기능 사용 |
139
- | `collapse` | `boolean` | `false` | 접힘 상태 (two-way) |
140
- | `value` | `L \| undefined` | `undefined` | 레인의 값 |