@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.
- package/{claude/references/sd-simplysm14/sd-claude/usage.md → README.md} +2 -2
- package/claude/rules/sd-claude-rules.md +25 -10
- package/claude/rules/sd-options.md +11 -6
- package/claude/sd-subagent-start.sh +6 -0
- package/claude/settings.json +1 -12
- package/claude/skills/sd-check/SKILL.md +43 -12
- package/claude/skills/sd-claude-docs/SKILL.md +30 -58
- package/claude/skills/sd-claude-docs/references/package-claudemd.md +12 -0
- package/claude/skills/sd-claude-docs/references/package-doc-gen.md +26 -13
- package/claude/skills/sd-commit/SKILL.md +1 -1
- package/claude/skills/sd-debug/SKILL.md +5 -3
- package/claude/skills/sd-deliverable/SKILL.md +1 -1
- package/claude/skills/sd-dev/SKILL.md +14 -9
- package/claude/skills/sd-doc-extract/SKILL.md +8 -10
- package/claude/skills/sd-doc-extract/_common.py +8 -1
- package/claude/skills/sd-doc-extract/_extract_docx.py +74 -34
- package/claude/skills/sd-doc-extract/_extract_pdf.py +12 -1
- package/claude/skills/sd-doc-extract/_extract_pptx.py +103 -23
- package/claude/skills/sd-doc-extract/_extract_xlsb.py +93 -4
- package/claude/skills/sd-doc-extract/_extract_xlsx.py +98 -36
- package/claude/skills/sd-doc-extract/extract.py +22 -3
- package/claude/skills/sd-inner-clarify/SKILL.md +78 -0
- package/claude/skills/sd-inner-debug/SKILL.md +1 -1
- package/claude/skills/sd-inner-review/SKILL.md +13 -0
- package/claude/skills/sd-issue/SKILL.md +1 -1
- package/claude/skills/sd-outlook/SKILL.md +1 -1
- package/claude/skills/sd-plan/SKILL.md +50 -17
- package/claude/skills/sd-prompt/SKILL.md +180 -178
- package/claude/skills/sd-prompt/references/eval-runner.md +5 -30
- package/claude/skills/sd-prompt/references/sd-eval-env-template.md +23 -0
- package/claude/skills/sd-refactor/SKILL.md +2 -2
- package/claude/skills/sd-tdd/SKILL.md +45 -16
- package/claude/skills/sd-use/SKILL.md +84 -80
- package/claude/skills/sd-wbs/SKILL.md +84 -27
- package/{claude/references/sd-simplysm14/sd-claude/docs → docs}/assets.md +2 -3
- package/{claude/references/sd-simplysm14/sd-claude/docs → docs}/hooks.md +7 -6
- package/{claude/references/sd-simplysm14/sd-claude/docs → docs}/scripts.md +1 -9
- package/package.json +3 -2
- package/scripts/sync.mjs +4 -2
- package/claude/references/sd-simplysm14/angular/docs/bootstrap.md +0 -48
- package/claude/references/sd-simplysm14/angular/docs/directives.md +0 -236
- package/claude/references/sd-simplysm14/angular/docs/features.md +0 -379
- package/claude/references/sd-simplysm14/angular/docs/pipes.md +0 -32
- package/claude/references/sd-simplysm14/angular/docs/plugins.md +0 -37
- package/claude/references/sd-simplysm14/angular/docs/provider-types.md +0 -283
- package/claude/references/sd-simplysm14/angular/docs/providers.md +0 -379
- package/claude/references/sd-simplysm14/angular/docs/styling.md +0 -222
- package/claude/references/sd-simplysm14/angular/docs/type-utilities.md +0 -250
- package/claude/references/sd-simplysm14/angular/docs/ui-data.md +0 -275
- package/claude/references/sd-simplysm14/angular/docs/ui-form.md +0 -490
- package/claude/references/sd-simplysm14/angular/docs/ui-layout.md +0 -140
- package/claude/references/sd-simplysm14/angular/docs/ui-navigation.md +0 -273
- package/claude/references/sd-simplysm14/angular/docs/ui-overlay.md +0 -157
- package/claude/references/sd-simplysm14/angular/docs/ui-visual.md +0 -127
- package/claude/references/sd-simplysm14/angular/docs/utils.md +0 -295
- package/claude/references/sd-simplysm14/angular/usage.md +0 -489
- package/claude/references/sd-simplysm14/capacitor-plugin-auto-update/usage.md +0 -182
- package/claude/references/sd-simplysm14/capacitor-plugin-file-system/docs/file-operations.md +0 -154
- package/claude/references/sd-simplysm14/capacitor-plugin-file-system/docs/permissions.md +0 -84
- package/claude/references/sd-simplysm14/capacitor-plugin-file-system/docs/storage-paths.md +0 -107
- package/claude/references/sd-simplysm14/capacitor-plugin-file-system/docs/types.md +0 -83
- package/claude/references/sd-simplysm14/capacitor-plugin-file-system/usage.md +0 -133
- package/claude/references/sd-simplysm14/capacitor-plugin-intent/usage.md +0 -203
- package/claude/references/sd-simplysm14/capacitor-plugin-usb-storage/usage.md +0 -258
- package/claude/references/sd-simplysm14/core-browser/usage.md +0 -306
- package/claude/references/sd-simplysm14/core-common/docs/errors.md +0 -82
- package/claude/references/sd-simplysm14/core-common/docs/extensions.md +0 -167
- package/claude/references/sd-simplysm14/core-common/docs/features.md +0 -136
- package/claude/references/sd-simplysm14/core-common/docs/types.md +0 -245
- package/claude/references/sd-simplysm14/core-common/docs/utils.md +0 -591
- package/claude/references/sd-simplysm14/core-common/usage.md +0 -255
- package/claude/references/sd-simplysm14/core-node/docs/child-process.md +0 -182
- package/claude/references/sd-simplysm14/core-node/docs/features.md +0 -214
- package/claude/references/sd-simplysm14/core-node/docs/file-system.md +0 -509
- package/claude/references/sd-simplysm14/core-node/docs/file-watching.md +0 -139
- package/claude/references/sd-simplysm14/core-node/docs/logging.md +0 -180
- package/claude/references/sd-simplysm14/core-node/docs/path.md +0 -176
- package/claude/references/sd-simplysm14/core-node/docs/utilities-cpx.md +0 -194
- package/claude/references/sd-simplysm14/core-node/docs/utilities-fsx.md +0 -469
- package/claude/references/sd-simplysm14/core-node/docs/utilities-pathx.md +0 -151
- package/claude/references/sd-simplysm14/core-node/docs/worker-threads.md +0 -334
- package/claude/references/sd-simplysm14/core-node/docs/worker.md +0 -205
- package/claude/references/sd-simplysm14/core-node/usage.md +0 -259
- package/claude/references/sd-simplysm14/excel/docs/core-classes.md +0 -453
- package/claude/references/sd-simplysm14/excel/docs/types.md +0 -459
- package/claude/references/sd-simplysm14/excel/docs/utilities.md +0 -194
- package/claude/references/sd-simplysm14/excel/docs/wrapper.md +0 -73
- package/claude/references/sd-simplysm14/excel/usage.md +0 -134
- package/claude/references/sd-simplysm14/lint/usage.md +0 -130
- package/claude/references/sd-simplysm14/orm-common/docs/core.md +0 -188
- package/claude/references/sd-simplysm14/orm-common/docs/expression.md +0 -190
- package/claude/references/sd-simplysm14/orm-common/docs/models.md +0 -17
- package/claude/references/sd-simplysm14/orm-common/docs/query-builder.md +0 -97
- package/claude/references/sd-simplysm14/orm-common/docs/queryable-executable.md +0 -250
- package/claude/references/sd-simplysm14/orm-common/docs/schema-builders.md +0 -364
- package/claude/references/sd-simplysm14/orm-common/docs/types.md +0 -522
- package/claude/references/sd-simplysm14/orm-common/usage.md +0 -229
- package/claude/references/sd-simplysm14/orm-node/docs/connections.md +0 -137
- package/claude/references/sd-simplysm14/orm-node/docs/core.md +0 -131
- package/claude/references/sd-simplysm14/orm-node/docs/types.md +0 -173
- package/claude/references/sd-simplysm14/orm-node/usage.md +0 -143
- package/claude/references/sd-simplysm14/sd-cli/usage.md +0 -782
- package/claude/references/sd-simplysm14/service-client/docs/features.md +0 -217
- package/claude/references/sd-simplysm14/service-client/docs/main.md +0 -148
- package/claude/references/sd-simplysm14/service-client/docs/protocol.md +0 -53
- package/claude/references/sd-simplysm14/service-client/docs/transport.md +0 -131
- package/claude/references/sd-simplysm14/service-client/docs/types.md +0 -129
- package/claude/references/sd-simplysm14/service-client/usage.md +0 -202
- package/claude/references/sd-simplysm14/service-common/docs/app-structure.md +0 -175
- package/claude/references/sd-simplysm14/service-common/docs/events.md +0 -64
- package/claude/references/sd-simplysm14/service-common/docs/protocol.md +0 -331
- package/claude/references/sd-simplysm14/service-common/docs/service-types.md +0 -90
- package/claude/references/sd-simplysm14/service-common/docs/types.md +0 -19
- package/claude/references/sd-simplysm14/service-common/usage.md +0 -154
- package/claude/references/sd-simplysm14/service-server/docs/auth.md +0 -64
- package/claude/references/sd-simplysm14/service-server/docs/core.md +0 -174
- package/claude/references/sd-simplysm14/service-server/docs/legacy.md +0 -25
- package/claude/references/sd-simplysm14/service-server/docs/main.md +0 -88
- package/claude/references/sd-simplysm14/service-server/docs/protocol.md +0 -33
- package/claude/references/sd-simplysm14/service-server/docs/services.md +0 -94
- package/claude/references/sd-simplysm14/service-server/docs/transport-http.md +0 -93
- package/claude/references/sd-simplysm14/service-server/docs/transport-socket.md +0 -119
- package/claude/references/sd-simplysm14/service-server/docs/types.md +0 -36
- package/claude/references/sd-simplysm14/service-server/docs/utils.md +0 -22
- package/claude/references/sd-simplysm14/service-server/usage.md +0 -171
- package/claude/references/sd-simplysm14/storage/usage.md +0 -301
- package/claude/references/sd-simplysm14.md +0 -35
- package/claude/rules/sd-clarify.md +0 -23
- package/claude/sd-session-start.sh +0 -10
- /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` | 레인의 값 |
|