@sellmate/design-system 0.0.13 → 0.0.15

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 (181) hide show
  1. package/dist/cjs/design-system.cjs.js +1 -1
  2. package/dist/cjs/loader.cjs.js +1 -1
  3. package/dist/cjs/sd-badge.cjs.entry.js +1 -1
  4. package/dist/cjs/sd-button.sd-tooltip-portal.entry.cjs.js.map +1 -1
  5. package/dist/cjs/sd-button_2.cjs.entry.js +6 -5
  6. package/dist/cjs/sd-card.cjs.entry.js +20 -0
  7. package/dist/cjs/sd-card.entry.cjs.js.map +1 -0
  8. package/dist/cjs/sd-checkbox.sd-icon.sd-input.sd-portal.sd-select.sd-select-multiple.sd-select-multiple-group.sd-select-option.sd-select-option-group.entry.cjs.js.map +1 -1
  9. package/dist/cjs/sd-checkbox_9.cjs.entry.js +59 -32
  10. package/dist/cjs/sd-date-box.cjs.entry.js +2 -2
  11. package/dist/cjs/sd-date-picker.cjs.entry.js +2 -2
  12. package/dist/cjs/sd-date-range-picker.cjs.entry.js +2 -2
  13. package/dist/cjs/sd-guide.cjs.entry.js +65 -53
  14. package/dist/cjs/sd-guide.entry.cjs.js.map +1 -1
  15. package/dist/cjs/sd-pagination_2.cjs.entry.js +4 -4
  16. package/dist/cjs/sd-popover.cjs.entry.js +2 -2
  17. package/dist/cjs/sd-table.cjs.entry.js +4 -4
  18. package/dist/cjs/sd-table.entry.cjs.js.map +1 -1
  19. package/dist/cjs/sd-tag.cjs.entry.js +1 -1
  20. package/dist/collection/collection-manifest.json +2 -1
  21. package/dist/collection/components/assets/index.js +2 -0
  22. package/dist/collection/components/assets/index.js.map +1 -1
  23. package/dist/collection/components/assets/minus/Minus12.js +3 -0
  24. package/dist/collection/components/assets/minus/Minus12.js.map +1 -0
  25. package/dist/collection/components/assets/minus/index.js +5 -0
  26. package/dist/collection/components/assets/minus/index.js.map +1 -0
  27. package/dist/collection/components/sd-badge/sd-badge.js +1 -1
  28. package/dist/collection/components/sd-button/sd-button.css +1 -1
  29. package/dist/collection/components/sd-button/sd-button.js +14 -39
  30. package/dist/collection/components/sd-button/sd-button.js.map +1 -1
  31. package/dist/collection/components/sd-card/sd-card.css +1372 -0
  32. package/dist/collection/components/sd-card/sd-card.js +64 -0
  33. package/dist/collection/components/sd-card/sd-card.js.map +1 -0
  34. package/dist/collection/components/sd-checkbox/sd-checkbox.css +1370 -6
  35. package/dist/collection/components/sd-checkbox/sd-checkbox.js +35 -40
  36. package/dist/collection/components/sd-checkbox/sd-checkbox.js.map +1 -1
  37. package/dist/collection/components/sd-date-box/sd-date-box.js +2 -2
  38. package/dist/collection/components/sd-date-picker/sd-date-picker.js +2 -2
  39. package/dist/collection/components/sd-date-range-picker/sd-date-range-picker.js +2 -2
  40. package/dist/collection/components/sd-guide/sd-guide.css +8 -0
  41. package/dist/collection/components/sd-guide/sd-guide.js +66 -54
  42. package/dist/collection/components/sd-guide/sd-guide.js.map +1 -1
  43. package/dist/collection/components/sd-icon/sd-icon.js +2 -2
  44. package/dist/collection/components/sd-input/sd-input.js +2 -2
  45. package/dist/collection/components/sd-pagination/sd-pagination.js +2 -2
  46. package/dist/collection/components/sd-popover/sd-popover.js +3 -3
  47. package/dist/collection/components/sd-portal/sd-portal.js +1 -1
  48. package/dist/collection/components/sd-select/sd-select-option/sd-select-option.css +1 -0
  49. package/dist/collection/components/sd-select/sd-select-option/sd-select-option.js +10 -6
  50. package/dist/collection/components/sd-select/sd-select-option/sd-select-option.js.map +1 -1
  51. package/dist/collection/components/sd-select/sd-select.css +2 -0
  52. package/dist/collection/components/sd-select/sd-select.js +2 -2
  53. package/dist/collection/components/sd-select-multiple/sd-select-multiple.js +2 -2
  54. package/dist/collection/components/sd-select-multiple-group/sd-select-multiple-group.js +2 -2
  55. package/dist/collection/components/sd-select-multiple-group/sd-select-option-group/sd-select-option-group.js +10 -6
  56. package/dist/collection/components/sd-select-multiple-group/sd-select-option-group/sd-select-option-group.js.map +1 -1
  57. package/dist/collection/components/sd-table/sd-table.js +8 -10
  58. package/dist/collection/components/sd-table/sd-table.js.map +1 -1
  59. package/dist/collection/components/sd-tag/sd-tag.js +1 -1
  60. package/dist/collection/components/sd-tooltip/sd-tooltip.js +3 -3
  61. package/dist/collection/components/sd-tooltip-portal/sd-tooltip-portal.js +1 -1
  62. package/dist/components/p-1jmdnu3I.js +118 -0
  63. package/dist/components/p-1jmdnu3I.js.map +1 -0
  64. package/dist/components/{p-tyC8W4sw.js → p-7xizrxZ5.js} +9 -9
  65. package/dist/components/p-7xizrxZ5.js.map +1 -0
  66. package/dist/components/{p-Cw2pw4LC.js → p-B1kMis4e.js} +7 -7
  67. package/dist/components/{p-Cw2pw4LC.js.map → p-B1kMis4e.js.map} +1 -1
  68. package/dist/components/{p-DVFPBdfj.js → p-BOsnXzkr.js} +15 -3
  69. package/dist/components/p-BOsnXzkr.js.map +1 -0
  70. package/dist/components/{p-BBm_kUA7.js → p-BTSN9ENi.js} +5 -5
  71. package/dist/components/{p-BBm_kUA7.js.map → p-BTSN9ENi.js.map} +1 -1
  72. package/dist/components/{p-DfkKMnWF.js → p-B_s4RQWY.js} +15 -11
  73. package/dist/components/p-B_s4RQWY.js.map +1 -0
  74. package/dist/components/{p-BQR8GTeD.js → p-D_m-rDEx.js} +4 -4
  75. package/dist/components/{p-BQR8GTeD.js.map → p-D_m-rDEx.js.map} +1 -1
  76. package/dist/components/{p-Cf4fh47I.js → p-UtZuVoJ9.js} +14 -10
  77. package/dist/components/p-UtZuVoJ9.js.map +1 -0
  78. package/dist/components/{p-BqCRj-SM.js → p-az-fZTqo.js} +3 -3
  79. package/dist/components/{p-BqCRj-SM.js.map → p-az-fZTqo.js.map} +1 -1
  80. package/dist/components/{p-D0hPGqjM.js → p-x0iTdFk8.js} +5 -5
  81. package/dist/components/{p-D0hPGqjM.js.map → p-x0iTdFk8.js.map} +1 -1
  82. package/dist/components/{p-D267VRcj.js → p-yJmTynI0.js} +3 -3
  83. package/dist/components/{p-D267VRcj.js.map → p-yJmTynI0.js.map} +1 -1
  84. package/dist/components/sd-badge.js +1 -1
  85. package/dist/components/sd-button.js +1 -1
  86. package/dist/components/sd-card.d.ts +11 -0
  87. package/dist/components/sd-card.js +42 -0
  88. package/dist/components/sd-card.js.map +1 -0
  89. package/dist/components/sd-checkbox.js +1 -1
  90. package/dist/components/sd-date-box.js +1 -1
  91. package/dist/components/sd-date-picker.js +6 -6
  92. package/dist/components/sd-date-range-picker.js +6 -6
  93. package/dist/components/sd-guide.js +69 -57
  94. package/dist/components/sd-guide.js.map +1 -1
  95. package/dist/components/sd-icon.js +1 -1
  96. package/dist/components/sd-input.js +1 -1
  97. package/dist/components/sd-pagination.js +1 -1
  98. package/dist/components/sd-popover.js +5 -5
  99. package/dist/components/sd-portal.js +1 -1
  100. package/dist/components/sd-select-multiple-group.js +7 -7
  101. package/dist/components/sd-select-multiple.js +7 -7
  102. package/dist/components/sd-select-option-group.js +1 -1
  103. package/dist/components/sd-select-option.js +1 -1
  104. package/dist/components/sd-select.js +8 -8
  105. package/dist/components/sd-select.js.map +1 -1
  106. package/dist/components/sd-table.js +10 -10
  107. package/dist/components/sd-table.js.map +1 -1
  108. package/dist/components/sd-tag.js +1 -1
  109. package/dist/components/sd-tooltip-portal.js +1 -1
  110. package/dist/components/sd-tooltip.js +1 -1
  111. package/dist/design-system/design-system.esm.js +1 -1
  112. package/dist/design-system/{p-ab46652a.entry.js → p-240de5df.entry.js} +2 -2
  113. package/dist/design-system/p-2e519819.entry.js +2 -0
  114. package/dist/design-system/p-2e519819.entry.js.map +1 -0
  115. package/dist/design-system/{p-a7ef9b22.entry.js → p-4eaf6262.entry.js} +2 -2
  116. package/dist/design-system/p-5f6c69ed.entry.js +2 -0
  117. package/dist/design-system/p-5f6c69ed.entry.js.map +1 -0
  118. package/dist/design-system/{p-7ae03d45.entry.js → p-62c12ab7.entry.js} +2 -2
  119. package/dist/design-system/p-62c12ab7.entry.js.map +1 -0
  120. package/dist/design-system/{p-b5abb919.entry.js → p-71716c18.entry.js} +2 -2
  121. package/dist/design-system/{p-70a394fe.entry.js → p-87da8d28.entry.js} +2 -2
  122. package/dist/design-system/p-87da8d28.entry.js.map +1 -0
  123. package/dist/design-system/{p-cdaa51d7.entry.js → p-ac9a20b4.entry.js} +2 -2
  124. package/dist/design-system/p-ac9a20b4.entry.js.map +1 -0
  125. package/dist/design-system/{p-131f639a.entry.js → p-b037ea76.entry.js} +2 -2
  126. package/dist/design-system/{p-0529b7d6.entry.js → p-b4e3145a.entry.js} +2 -2
  127. package/dist/design-system/{p-02d30a1b.entry.js → p-bd9e799c.entry.js} +2 -2
  128. package/dist/design-system/{p-52454cc4.entry.js → p-d185bd2e.entry.js} +2 -2
  129. package/dist/design-system/sd-button.sd-tooltip-portal.entry.esm.js.map +1 -1
  130. package/dist/design-system/sd-card.entry.esm.js.map +1 -0
  131. package/dist/design-system/sd-checkbox.sd-icon.sd-input.sd-portal.sd-select.sd-select-multiple.sd-select-multiple-group.sd-select-option.sd-select-option-group.entry.esm.js.map +1 -1
  132. package/dist/design-system/sd-guide.entry.esm.js.map +1 -1
  133. package/dist/design-system/sd-table.entry.esm.js.map +1 -1
  134. package/dist/esm/design-system.js +1 -1
  135. package/dist/esm/loader.js +1 -1
  136. package/dist/esm/sd-badge.entry.js +1 -1
  137. package/dist/esm/sd-button.sd-tooltip-portal.entry.js.map +1 -1
  138. package/dist/esm/sd-button_2.entry.js +6 -5
  139. package/dist/esm/sd-card.entry.js +18 -0
  140. package/dist/esm/sd-card.entry.js.map +1 -0
  141. package/dist/esm/sd-checkbox.sd-icon.sd-input.sd-portal.sd-select.sd-select-multiple.sd-select-multiple-group.sd-select-option.sd-select-option-group.entry.js.map +1 -1
  142. package/dist/esm/sd-checkbox_9.entry.js +59 -32
  143. package/dist/esm/sd-date-box.entry.js +2 -2
  144. package/dist/esm/sd-date-picker.entry.js +2 -2
  145. package/dist/esm/sd-date-range-picker.entry.js +2 -2
  146. package/dist/esm/sd-guide.entry.js +65 -53
  147. package/dist/esm/sd-guide.entry.js.map +1 -1
  148. package/dist/esm/sd-pagination_2.entry.js +4 -4
  149. package/dist/esm/sd-popover.entry.js +2 -2
  150. package/dist/esm/sd-table.entry.js +4 -4
  151. package/dist/esm/sd-table.entry.js.map +1 -1
  152. package/dist/esm/sd-tag.entry.js +1 -1
  153. package/dist/types/components/assets/index.d.ts +3 -0
  154. package/dist/types/components/assets/minus/Minus12.d.ts +1 -0
  155. package/dist/types/components/assets/minus/index.d.ts +3 -0
  156. package/dist/types/components/sd-button/sd-button.d.ts +1 -2
  157. package/dist/types/components/sd-card/sd-card.d.ts +5 -0
  158. package/dist/types/components/sd-checkbox/sd-checkbox.d.ts +6 -5
  159. package/dist/types/components/sd-guide/sd-guide.d.ts +2 -11
  160. package/dist/types/components.d.ts +43 -42
  161. package/hydrate/index.js +177 -113
  162. package/hydrate/index.mjs +177 -113
  163. package/package.json +2 -2
  164. package/dist/components/p-Cf4fh47I.js.map +0 -1
  165. package/dist/components/p-CuDrOaaO.js +0 -112
  166. package/dist/components/p-CuDrOaaO.js.map +0 -1
  167. package/dist/components/p-DVFPBdfj.js.map +0 -1
  168. package/dist/components/p-DfkKMnWF.js.map +0 -1
  169. package/dist/components/p-tyC8W4sw.js.map +0 -1
  170. package/dist/design-system/p-3fe6dda9.entry.js +0 -2
  171. package/dist/design-system/p-3fe6dda9.entry.js.map +0 -1
  172. package/dist/design-system/p-70a394fe.entry.js.map +0 -1
  173. package/dist/design-system/p-7ae03d45.entry.js.map +0 -1
  174. package/dist/design-system/p-cdaa51d7.entry.js.map +0 -1
  175. /package/dist/design-system/{p-ab46652a.entry.js.map → p-240de5df.entry.js.map} +0 -0
  176. /package/dist/design-system/{p-a7ef9b22.entry.js.map → p-4eaf6262.entry.js.map} +0 -0
  177. /package/dist/design-system/{p-b5abb919.entry.js.map → p-71716c18.entry.js.map} +0 -0
  178. /package/dist/design-system/{p-131f639a.entry.js.map → p-b037ea76.entry.js.map} +0 -0
  179. /package/dist/design-system/{p-0529b7d6.entry.js.map → p-b4e3145a.entry.js.map} +0 -0
  180. /package/dist/design-system/{p-02d30a1b.entry.js.map → p-bd9e799c.entry.js.map} +0 -0
  181. /package/dist/design-system/{p-52454cc4.entry.js.map → p-d185bd2e.entry.js.map} +0 -0
@@ -2,14 +2,13 @@ import { h, Host, } from "@stencil/core";
2
2
  export class SdCheckbox {
3
3
  el;
4
4
  /** 현재 선택 상태 또는 배열 형태의 값 */
5
- checked = false;
5
+ checked;
6
6
  /** 배열 모드에서의 개별 값 */
7
7
  val;
8
8
  /** 비활성화 여부 */
9
9
  disabled = false;
10
10
  /** 표시할 라벨 텍스트 */
11
11
  label = '';
12
- checkboxStyle = {};
13
12
  /** 내부 체크 상태 */
14
13
  isChecked = false;
15
14
  /** 값 변경 이벤트 */
@@ -17,18 +16,27 @@ export class SdCheckbox {
17
16
  componentWillLoad() {
18
17
  this.updateCheckedState(this.checked);
19
18
  }
19
+ componentWillRender() {
20
+ this.updateCheckedState(this.checked);
21
+ }
20
22
  watchValueHandler(newValue) {
21
23
  this.updateCheckedState(newValue);
22
24
  }
23
- getCheckboxClasses() {
24
- const classes = ['sd-checkbox', `sd-checkbox--${this.isChecked ? 'checked' : 'unchecked'}`];
25
+ get checkboxClasses() {
26
+ const classes = [
27
+ 'sd-checkbox',
28
+ `sd-checkbox--${this.isChecked ? 'checked' : this.isChecked === null ? 'indeterminate' : 'unchecked'}`,
29
+ ];
25
30
  if (this.disabled) {
26
31
  classes.push('sd-checkbox--disabled');
27
32
  }
28
33
  return classes.join(' ');
29
34
  }
30
35
  updateCheckedState(value) {
31
- if (typeof value === 'boolean') {
36
+ if (value === null) {
37
+ this.isChecked = null;
38
+ }
39
+ else if (typeof value === 'boolean') {
32
40
  this.isChecked = value;
33
41
  }
34
42
  else if (Array.isArray(value)) {
@@ -48,7 +56,6 @@ export class SdCheckbox {
48
56
  else if (Array.isArray(this.checked)) {
49
57
  if (this.val === undefined) {
50
58
  console.warn('A "val" property is required when using an array for the "value" property.');
51
- return;
52
59
  }
53
60
  const valueSet = new Set(this.checked);
54
61
  valueSet.has(this.val) ? valueSet.delete(this.val) : valueSet.add(this.val);
@@ -60,7 +67,7 @@ export class SdCheckbox {
60
67
  this.sdChange.emit(newValue);
61
68
  };
62
69
  render() {
63
- return (h(Host, { key: '6e88ca34b4464d33b0aa54880eff5821d5c612d9' }, h("label", { key: '392dc3fe13ef18eb34625b830702f390131d2bab', class: this.getCheckboxClasses() }, h("input", { key: 'ed84bc69e4928488cf1ae76e62b0cbea4ca6a636', type: "checkbox", checked: this.isChecked, disabled: this.disabled, onChange: this.handleChange }), h("div", { key: 'e434643d9bda619da1af184ea93b333364cc4972', class: "sd-checkbox__bg", style: this.checkboxStyle }, this.isChecked ? (h("sd-icon", { name: "check", size: 12, color: this.disabled ? '#888888' : 'white' })) : null), this.label && h("span", { key: '84d72a707e97e7b22a2c3183353bc295340ba490', class: "sd-checkbox__label" }, this.label))));
70
+ return (h(Host, { key: '953aa5173d5e89247d80f3ee4c258f322122df24' }, h("label", { key: 'ef7e3b50f134307ecbfee42daf8e858891fcea75', "aria-checked": this.isChecked === null ? 'mixed' : this.isChecked.toString(), "aria-disabled": this.disabled.toString(), role: "checkbox", "aria-label": this.label || 'checkbox', class: this.checkboxClasses }, h("input", { key: 'd10e690b3cfd6141ff091563189540ad6c50b4a8', type: "checkbox", value: this.val, checked: !!this.isChecked, disabled: this.disabled, onChange: this.handleChange, name: this.label || 'checkbox' }), h("div", { key: '0bc77af921869f65ccd0ce220d6198160efb46e4', class: "sd-checkbox__bg" }, this.isChecked !== false ? (h("sd-icon", { name: this.isChecked === true ? 'check' : 'minus', size: 12, color: this.disabled ? '#888888' : 'white' })) : null), this.label && h("span", { key: '0d111f7f1e6d19cb0da67589c1ec4853ab543e71', class: "sd-checkbox__label" }, this.label))));
64
71
  }
65
72
  static get is() { return "sd-checkbox"; }
66
73
  static get encapsulation() { return "scoped"; }
@@ -77,14 +84,20 @@ export class SdCheckbox {
77
84
  static get properties() {
78
85
  return {
79
86
  "checked": {
80
- "type": "any",
87
+ "type": "boolean",
81
88
  "mutable": false,
82
89
  "complexType": {
83
- "original": "any[] | any",
84
- "resolved": "any",
85
- "references": {}
90
+ "original": "CheckedType",
91
+ "resolved": "any[] | boolean | null",
92
+ "references": {
93
+ "CheckedType": {
94
+ "location": "local",
95
+ "path": "C:/Users/KimMeeKyeong/Documents/sellmate/frontend/design-system/packages/stencil/src/components/sd-checkbox/sd-checkbox.tsx",
96
+ "id": "src/components/sd-checkbox/sd-checkbox.tsx::CheckedType"
97
+ }
98
+ }
86
99
  },
87
- "required": false,
100
+ "required": true,
88
101
  "optional": false,
89
102
  "docs": {
90
103
  "tags": [],
@@ -93,8 +106,7 @@ export class SdCheckbox {
93
106
  "getter": false,
94
107
  "setter": false,
95
108
  "reflect": false,
96
- "attribute": "checked",
97
- "defaultValue": "false"
109
+ "attribute": "checked"
98
110
  },
99
111
  "val": {
100
112
  "type": "any",
@@ -154,29 +166,6 @@ export class SdCheckbox {
154
166
  "reflect": false,
155
167
  "attribute": "label",
156
168
  "defaultValue": "''"
157
- },
158
- "checkboxStyle": {
159
- "type": "unknown",
160
- "mutable": false,
161
- "complexType": {
162
- "original": "StyleProps",
163
- "resolved": "{ [key: string]: any; }",
164
- "references": {
165
- "StyleProps": {
166
- "location": "global",
167
- "id": "global::StyleProps"
168
- }
169
- }
170
- },
171
- "required": false,
172
- "optional": false,
173
- "docs": {
174
- "tags": [],
175
- "text": ""
176
- },
177
- "getter": false,
178
- "setter": false,
179
- "defaultValue": "{}"
180
169
  }
181
170
  };
182
171
  }
@@ -197,9 +186,15 @@ export class SdCheckbox {
197
186
  "text": "\uAC12 \uBCC0\uACBD \uC774\uBCA4\uD2B8"
198
187
  },
199
188
  "complexType": {
200
- "original": "any | any[]",
201
- "resolved": "any",
202
- "references": {}
189
+ "original": "CheckedType",
190
+ "resolved": "any[] | boolean | null",
191
+ "references": {
192
+ "CheckedType": {
193
+ "location": "local",
194
+ "path": "C:/Users/KimMeeKyeong/Documents/sellmate/frontend/design-system/packages/stencil/src/components/sd-checkbox/sd-checkbox.tsx",
195
+ "id": "src/components/sd-checkbox/sd-checkbox.tsx::CheckedType"
196
+ }
197
+ }
203
198
  }
204
199
  }];
205
200
  }
@@ -1 +1 @@
1
- {"version":3,"file":"sd-checkbox.js","sourceRoot":"","sources":["../../../src/components/sd-checkbox/sd-checkbox.tsx"],"names":[],"mappings":"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","sourcesContent":["import {\r\n Component,\r\n Prop,\r\n h,\r\n Element,\r\n Event,\r\n EventEmitter,\r\n State,\r\n Watch,\r\n Host,\r\n} from '@stencil/core';\r\n\r\n@Component({\r\n tag: 'sd-checkbox',\r\n styleUrl: 'sd-checkbox.scss',\r\n scoped: true,\r\n})\r\nexport class SdCheckbox {\r\n @Element() el!: HTMLElement;\r\n\r\n /** 현재 선택 상태 또는 배열 형태의 값 */\r\n @Prop() checked: any[] | any = false;\r\n\r\n /** 배열 모드에서의 개별 값 */\r\n @Prop() val?: any;\r\n\r\n /** 비활성화 여부 */\r\n @Prop() disabled: boolean = false;\r\n\r\n /** 표시할 라벨 텍스트 */\r\n @Prop() label: string = '';\r\n\r\n @Prop() checkboxStyle: StyleProps = {};\r\n\r\n /** 내부 체크 상태 */\r\n @State() private isChecked: boolean = false;\r\n\r\n /** 값 변경 이벤트 */\r\n @Event() sdChange!: EventEmitter<any | any[]>;\r\n\r\n componentWillLoad() {\r\n this.updateCheckedState(this.checked);\r\n }\r\n\r\n @Watch('checked')\r\n watchValueHandler(newValue: any | any[]) {\r\n this.updateCheckedState(newValue);\r\n }\r\n\r\n private getCheckboxClasses(): string {\r\n const classes = ['sd-checkbox', `sd-checkbox--${this.isChecked ? 'checked' : 'unchecked'}`];\r\n\r\n if (this.disabled) {\r\n classes.push('sd-checkbox--disabled');\r\n }\r\n\r\n return classes.join(' ');\r\n }\r\n\r\n private updateCheckedState(value: any | any[]) {\r\n if (typeof value === 'boolean') {\r\n this.isChecked = value;\r\n } else if (Array.isArray(value)) {\r\n this.isChecked = this.val !== undefined && value.includes(this.val);\r\n } else {\r\n this.isChecked = false;\r\n }\r\n }\r\n\r\n private handleChange = () => {\r\n if (this.disabled) return;\r\n\r\n let newValue: any | any[];\r\n\r\n if (typeof this.checked === 'boolean') {\r\n newValue = !this.checked;\r\n } else if (Array.isArray(this.checked)) {\r\n if (this.val === undefined) {\r\n console.warn('A \"val\" property is required when using an array for the \"value\" property.');\r\n return;\r\n }\r\n\r\n const valueSet = new Set(this.checked);\r\n valueSet.has(this.val) ? valueSet.delete(this.val) : valueSet.add(this.val);\r\n newValue = Array.from(valueSet);\r\n } else {\r\n newValue = !this.isChecked;\r\n }\r\n\r\n this.sdChange.emit(newValue);\r\n };\r\n\r\n render() {\r\n return (\r\n <Host>\r\n <label class={this.getCheckboxClasses()}>\r\n <input\r\n type=\"checkbox\"\r\n checked={this.isChecked}\r\n disabled={this.disabled}\r\n onChange={this.handleChange}\r\n />\r\n <div class=\"sd-checkbox__bg\" style={this.checkboxStyle}>\r\n {this.isChecked ? (\r\n <sd-icon name=\"check\" size={12} color={this.disabled ? '#888888' : 'white'} />\r\n ) : null}\r\n </div>\r\n {this.label && <span class=\"sd-checkbox__label\">{this.label}</span>}\r\n </label>\r\n </Host>\r\n );\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"sd-checkbox.js","sourceRoot":"","sources":["../../../src/components/sd-checkbox/sd-checkbox.tsx"],"names":[],"mappings":"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","sourcesContent":["import {\r\n Component,\r\n Prop,\r\n h,\r\n Element,\r\n Event,\r\n EventEmitter,\r\n State,\r\n Watch,\r\n Host,\r\n} from '@stencil/core';\r\n\r\nexport type CheckedType = boolean | any[] | null;\r\n\r\n@Component({\r\n tag: 'sd-checkbox',\r\n styleUrl: 'sd-checkbox.scss',\r\n scoped: true,\r\n})\r\nexport class SdCheckbox {\r\n @Element() el!: HTMLElement;\r\n\r\n /** 현재 선택 상태 또는 배열 형태의 값 */\r\n @Prop() checked!: CheckedType;\r\n\r\n /** 배열 모드에서의 개별 값 */\r\n @Prop() val?: any;\r\n\r\n /** 비활성화 여부 */\r\n @Prop() disabled: boolean = false;\r\n\r\n /** 표시할 라벨 텍스트 */\r\n @Prop() label: string = '';\r\n\r\n /** 내부 체크 상태 */\r\n @State() private isChecked: boolean | null = false;\r\n\r\n /** 값 변경 이벤트 */\r\n @Event() sdChange!: EventEmitter<CheckedType>;\r\n\r\n componentWillLoad() {\r\n this.updateCheckedState(this.checked);\r\n }\r\n\r\n componentWillRender() {\r\n this.updateCheckedState(this.checked);\r\n }\r\n\r\n @Watch('checked')\r\n watchValueHandler(newValue: CheckedType) {\r\n this.updateCheckedState(newValue);\r\n }\r\n\r\n private get checkboxClasses(): string {\r\n const classes = [\r\n 'sd-checkbox',\r\n `sd-checkbox--${this.isChecked ? 'checked' : this.isChecked === null ? 'indeterminate' : 'unchecked'}`,\r\n ];\r\n\r\n if (this.disabled) {\r\n classes.push('sd-checkbox--disabled');\r\n }\r\n\r\n return classes.join(' ');\r\n }\r\n\r\n private updateCheckedState(value: CheckedType) {\r\n if (value === null) {\r\n this.isChecked = null;\r\n } else if (typeof value === 'boolean') {\r\n this.isChecked = value;\r\n } else if (Array.isArray(value)) {\r\n this.isChecked = this.val !== undefined && value.includes(this.val);\r\n } else {\r\n this.isChecked = false;\r\n }\r\n }\r\n\r\n private handleChange = () => {\r\n if (this.disabled) return;\r\n\r\n let newValue: CheckedType;\r\n\r\n if (typeof this.checked === 'boolean') {\r\n newValue = !this.checked;\r\n } else if (Array.isArray(this.checked)) {\r\n if (this.val === undefined) {\r\n console.warn('A \"val\" property is required when using an array for the \"value\" property.');\r\n }\r\n\r\n const valueSet = new Set(this.checked);\r\n valueSet.has(this.val) ? valueSet.delete(this.val) : valueSet.add(this.val);\r\n newValue = Array.from(valueSet);\r\n } else {\r\n newValue = !this.isChecked;\r\n }\r\n\r\n this.sdChange.emit(newValue);\r\n };\r\n\r\n render() {\r\n return (\r\n <Host>\r\n <label\r\n aria-checked={this.isChecked === null ? 'mixed' : this.isChecked.toString()}\r\n aria-disabled={this.disabled.toString()}\r\n role=\"checkbox\"\r\n aria-label={this.label || 'checkbox'}\r\n class={this.checkboxClasses}\r\n >\r\n <input\r\n type=\"checkbox\"\r\n value={this.val}\r\n checked={!!this.isChecked}\r\n disabled={this.disabled}\r\n onChange={this.handleChange}\r\n name={this.label || 'checkbox'}\r\n />\r\n <div class=\"sd-checkbox__bg\">\r\n {this.isChecked !== false ? (\r\n <sd-icon\r\n name={this.isChecked === true ? 'check' : 'minus'}\r\n size={12}\r\n color={this.disabled ? '#888888' : 'white'}\r\n />\r\n ) : null}\r\n </div>\r\n {this.label && <span class=\"sd-checkbox__label\">{this.label}</span>}\r\n </label>\r\n </Host>\r\n );\r\n }\r\n}\r\n"]}
@@ -23,7 +23,7 @@ export class SdDateBox {
23
23
  this.sdMouseOver?.emit(this.date);
24
24
  }
25
25
  render() {
26
- return (h(Host, { key: '992ba0be8b908a910f2d572c665fce75570e7956', role: "button", "aria-disabled": this.disabled ? 'true' : 'false', tabindex: this.disabled ? -1 : 0, class: {
26
+ return (h(Host, { key: 'ace5d023959d41d2a2255e70ad9d5bad9df4f9fe', role: "button", "aria-disabled": this.disabled ? 'true' : 'false', tabindex: this.disabled ? -1 : 0, class: {
27
27
  'sd-date-box': true,
28
28
  'sd-hoverable': !this.disabled || !this.selected || this.type === '',
29
29
  'sd-date-box--disabled': this.disabled,
@@ -34,7 +34,7 @@ export class SdDateBox {
34
34
  'sd-date-box--in-range': this.inRange,
35
35
  'sd-date-box--type-start': this.type === 'start',
36
36
  'sd-date-box--type-end': this.type === 'end',
37
- }, onClick: () => this.handleClickDate(), onMouseOver: () => this.handleHoverDate() }, h("div", { key: '5673658e4532547f57e86babfce2ac9c8399cfa7', class: "sd-date-box__content" }, h("div", { key: '1e978a0bbf7a1f3e8d13d541d5d75e1b8568ddd8', class: "sd-date-box__label" }, this.date))));
37
+ }, onClick: () => this.handleClickDate(), onMouseOver: () => this.handleHoverDate() }, h("div", { key: '2fdeea79f2eeb28da3b9999f7326996531cb6c88', class: "sd-date-box__content" }, h("div", { key: '0f7839e75905b04f99a23603326099953f5e2990', class: "sd-date-box__label" }, this.date))));
38
38
  }
39
39
  static get is() { return "sd-date-box"; }
40
40
  static get encapsulation() { return "scoped"; }
@@ -74,9 +74,9 @@ export class SdDatePicker {
74
74
  this.isOpen = false;
75
75
  };
76
76
  render() {
77
- return (h(Host, { key: '31250b271bdfe3c4ce671e5a337e1eefbff206d4', class: "sd-date-picker" }, h("sd-input", { key: '19a53a715cf767cfaa78bcbb1177618fa3333305', ref: el => (this.inputEl = el), value: this.date, label: this.label, "inside-label": true, readonly: true, disabled: this.disabled, inputClass: "text-center", inputStyle: {
77
+ return (h(Host, { key: 'f445a752123f1a1a7f8d28ca7472a8ffabda9441', class: "sd-date-picker" }, h("sd-input", { key: '85662ea61b192562311af23f67c1a1ad05636813', ref: el => (this.inputEl = el), value: this.date, label: this.label, "inside-label": true, readonly: true, disabled: this.disabled, inputClass: "text-center", inputStyle: {
78
78
  margin: '0 0 0 8px',
79
- }, onClick: () => this.openMenu() }, h("sd-icon", { key: '7cb545aa2caf117b9681bea5a1cab5c21f5804df', slot: "prefix", name: "date", size: "16", color: "#737373", class: "date-icon", onClick: () => this.openMenu() })), this.isOpen && (h("sd-portal", { key: '08c8ec69c57aa9899e3c93978965883525fe635d', open: this.isOpen, parentRef: this.inputEl, onSdClose: this.handleClose }, h("div", { key: '64f68877a65206743517e6db5b3221527128597b', class: "sd-date-picker__menu" }, h("div", { key: 'f527835c913d10eadf17bb8ef4b7068675c23bc2', class: "sd-date-picker__header" }, h("div", { key: 'ecd393d337e3a0ffc3915e5a02de10a0b429e744', class: "year-nav" }, h("button", { key: '72f9f4ce5f04a32d54d74666f83add668c7c91cd', type: "button", name: "prev-year", title: "Previous Year", onClick: () => this.setCurrentYear(this.currentYear - 1) }, h("sd-icon", { key: '1331873a57d9658704fc8c14ec4db51713759aa4', name: "arrowLeft", size: "12", color: "#CCCCCC" })), h("span", { key: '8369803e76f17dace570294b0469a8cdc889dd07', class: "year-nav__current" }, this.currentYear), h("button", { key: '2c6dde370f92cdc6b43deb159cdd44f0ff61b463', type: "button", name: "next-year", title: "Next Year", onClick: () => this.setCurrentYear(this.currentYear + 1) }, h("sd-icon", { key: 'e0ada642507fadecc58cc1b19dce43a5a96d61fe', name: "arrowRight", size: "12", color: "#CCCCCC" }))), h("div", { key: '8bef4214917e837edf0f6d5ae6c80d2b8bc0abc7', class: "month-nav" }, h("button", { key: '1e4fef6ee5fc4da3aac9c429da37b1a5be6b4059', type: "button", name: "prev-month", title: "Previous ", onClick: () => this.handleUpdateMonth('prev') }, h("sd-icon", { key: '4a1537b2afb6cbd4653046416a2d0a3a0424e09e', name: "arrowLeft", size: "12", color: "#CCCCCC" })), h("span", { key: '39f866e69fab5c86589f039773abdc9267748242', class: "month-nav__current" }, this.currentMonth, "\uC6D4"), h("button", { key: 'cbc177a8850d37ba170eb85d9cf330af198066e4', type: "button", name: "next-month", title: "Next Month", onClick: () => this.handleUpdateMonth('next') }, h("sd-icon", { key: '530bd26b28a779b25e72fe90f4a77d8b2e2f0311', name: "arrowRight", size: "12", color: "#CCCCCC" })))), h("div", { key: '283742d67f2916e4fe44efea649442872681506e', class: "sd-date-picker__days" }, ['일', '월', '화', '수', '목', '금', '토'].map(day => (h("div", { key: day, class: "day" }, day)))), h("div", { key: '6fe54b4404d793ca629574b2eeac9b05bff2afde', class: "sd-date-picker__body" }, [
79
+ }, onClick: () => this.openMenu() }, h("sd-icon", { key: '41634f9170073fbde5e44c55b5985da90763f819', slot: "prefix", name: "date", size: "16", color: "#737373", class: "date-icon", onClick: () => this.openMenu() })), this.isOpen && (h("sd-portal", { key: 'ce630583ef81cd72ad1b8fdaab7cab2d1df278cb', open: this.isOpen, parentRef: this.inputEl, onSdClose: this.handleClose }, h("div", { key: '55d4c73a3e17991ebf68495d7bed96399857de1e', class: "sd-date-picker__menu" }, h("div", { key: '0800e3a37eec27bb8a8c59a2ebd8ffdbf4e813a7', class: "sd-date-picker__header" }, h("div", { key: '1518b578ad87a0f5875d980d1c974492f32714e3', class: "year-nav" }, h("button", { key: 'e70f1d4e73650c7bccb1629b679ca366717e5506', type: "button", name: "prev-year", title: "Previous Year", onClick: () => this.setCurrentYear(this.currentYear - 1) }, h("sd-icon", { key: 'f679a54b76e304d08c132d6784575831a5d5d61b', name: "arrowLeft", size: "12", color: "#CCCCCC" })), h("span", { key: '634dcbfe81d328cbc0460958208dc17aaf218158', class: "year-nav__current" }, this.currentYear), h("button", { key: '7e7cef51d7b47b7280cfff4234b88394708ea01a', type: "button", name: "next-year", title: "Next Year", onClick: () => this.setCurrentYear(this.currentYear + 1) }, h("sd-icon", { key: '8a6fc4a40f567d2d1ffef5dbc08de5148203970c', name: "arrowRight", size: "12", color: "#CCCCCC" }))), h("div", { key: '8fad6e92b899a0cb38398ec2f4036b959377d99b', class: "month-nav" }, h("button", { key: '3180c35ad42239a6a97480a4db860182b98724f3', type: "button", name: "prev-month", title: "Previous ", onClick: () => this.handleUpdateMonth('prev') }, h("sd-icon", { key: '6ccef0b13fde4124e0e14959687f60dab753ae51', name: "arrowLeft", size: "12", color: "#CCCCCC" })), h("span", { key: 'db7db67a1a77f02451bc0a7c97e87e3cd6c9d453', class: "month-nav__current" }, this.currentMonth, "\uC6D4"), h("button", { key: '5df06269331e9f7ee1cb4801bfd713d433f00af4', type: "button", name: "next-month", title: "Next Month", onClick: () => this.handleUpdateMonth('next') }, h("sd-icon", { key: '65b0f49b205e9aa38a46cbe672665b31c9ffe542', name: "arrowRight", size: "12", color: "#CCCCCC" })))), h("div", { key: '68f3c05f2ffb57b7fc032209dd709e5eaa6fcbdd', class: "sd-date-picker__days" }, ['일', '월', '화', '수', '목', '금', '토'].map(day => (h("div", { key: day, class: "day" }, day)))), h("div", { key: '452c22746ace6b3923acf4912edba2509a56b369', class: "sd-date-picker__body" }, [
80
80
  ...this.calendar.prevMonthDays,
81
81
  ...this.calendar.days,
82
82
  ...this.calendar.afterMonthDays,
@@ -137,9 +137,9 @@ export class SdDateRangePicker {
137
137
  this.isOpen = false;
138
138
  };
139
139
  render() {
140
- return (h(Host, { key: '60ab93954c070ffbbc8c5c81d39b9e2202d682fa', class: "sd-date-range-picker" }, h("sd-input", { key: 'df6974fedf73ec6de8c0aec7bf27bd87088065bf', ref: el => (this.inputEl = el), value: `${this.dateRange[0]} ~ ${this.dateRange[1]}`, label: this.label, "inside-label": true, readonly: true, disabled: this.disabled, inputClass: "text-center", inputStyle: {
140
+ return (h(Host, { key: '3d95128a2a654e38ceae60e6b89482a454488286', class: "sd-date-range-picker" }, h("sd-input", { key: '4f170abfe6214ffa1044020b2cd59a9219f3ef09', ref: el => (this.inputEl = el), value: `${this.dateRange[0]} ~ ${this.dateRange[1]}`, label: this.label, "inside-label": true, readonly: true, disabled: this.disabled, inputClass: "text-center", inputStyle: {
141
141
  margin: '0 0 0 8px',
142
- }, onClick: () => this.openMenu() }, h("sd-icon", { key: '79d0e2596a741260072d5331c13e5afb94f09b9a', slot: "prefix", name: "date", size: "16", color: "#737373", class: "date-icon", onClick: () => this.openMenu() })), this.isOpen && (h("sd-portal", { key: 'e16e7401cd86bcb63d9278b6ddb00bd8b193fa52', open: this.isOpen, parentRef: this.inputEl, onSdClose: this.handleClose }, h("div", { key: 'beb8f1550889104fccb9e240588d9ec9b58a85fa', class: "sd-date-range-picker__menu" }, h("div", { key: '28cfcef75b4e5485098dff0e322cdd2725ce6abd', class: "sd-date-range-picker__header mb-16pxr flex flex-nowrap items-center justify-center" }, h("button", { key: '77452ba7a29869efcb59a42214927a932ed91da7', type: "button", name: "prev", title: "Previous", onClick: () => this.setPrevYear(this.prevYear - 1) }, h("sd-icon", { key: '2a526f4f91b1814be3fd69f9ef7fe019cfa212c9', name: "arrowLeft", size: "12", color: "#CCCCCC" })), h("div", { key: 'dd721be8b6a0040ce9d7d18f4cb4663ca8b66577', class: "header-label" }, this.prevYear), h("button", { key: '2b2d6ce769945ce408c019be1e0a9ea3e18c7ed8', type: "button", name: "next", title: "Next", onClick: () => this.setPrevYear(this.prevYear + 1) }, h("sd-icon", { key: '59107ca17a8dc3f4b6c6f126fb6a8dfba9b43b4e', name: "arrowRight", size: "12", color: "#CCCCCC" }))), h("div", { key: 'e11121959ec1b0d7531ae8fe654d23b10e417802', class: "sd-date-range-picker__body" }, [this.prevCalendar, this.nextCalendar].map((calendar, index) => (h(Fragment, null, index === 1 && h("div", { class: "separator" }), h("div", { key: index, class: "calendar-container" }, h("div", { class: "calendar-header" }, h("button", { type: "button", name: "month", title: "Month", class: index === 0 ? 'header-button-prev' : 'header-button-next', onClick: () => this.updateYearMonth(index === 0 ? 'prev' : 'next') }, h("sd-icon", { name: index === 0 ? 'arrowLeft' : 'arrowRight', size: "12", color: "#CCCCCC" })), index === 0
142
+ }, onClick: () => this.openMenu() }, h("sd-icon", { key: '7c12c7e3331638f333efdea4bcd3d452eb032561', slot: "prefix", name: "date", size: "16", color: "#737373", class: "date-icon", onClick: () => this.openMenu() })), this.isOpen && (h("sd-portal", { key: '7312ab4a79877de6d6be3edaa404e0b9c52e28d8', open: this.isOpen, parentRef: this.inputEl, onSdClose: this.handleClose }, h("div", { key: '20a485d128de2b2d0a8043cb5fe0de990364bbd8', class: "sd-date-range-picker__menu" }, h("div", { key: '19a0489246b5dccc183f3d3a040086a6a2c565f3', class: "sd-date-range-picker__header mb-16pxr flex flex-nowrap items-center justify-center" }, h("button", { key: '1f9c5f1188234e2306c033e8e67f9a106b3b39bc', type: "button", name: "prev", title: "Previous", onClick: () => this.setPrevYear(this.prevYear - 1) }, h("sd-icon", { key: '52805839d2092886fe4f07c9f95a2e948b00c917', name: "arrowLeft", size: "12", color: "#CCCCCC" })), h("div", { key: 'e9f323504223ccfbc4b5703346a310e58d1621c3', class: "header-label" }, this.prevYear), h("button", { key: '810c6fb9eaa16291550455ac1099c15da7b80ed6', type: "button", name: "next", title: "Next", onClick: () => this.setPrevYear(this.prevYear + 1) }, h("sd-icon", { key: '44cf361ed854292f90c954522c356e17d5a45d29', name: "arrowRight", size: "12", color: "#CCCCCC" }))), h("div", { key: '4cc859482a2c010261b64b8ce15f5c754a2234fd', class: "sd-date-range-picker__body" }, [this.prevCalendar, this.nextCalendar].map((calendar, index) => (h(Fragment, null, index === 1 && h("div", { class: "separator" }), h("div", { key: index, class: "calendar-container" }, h("div", { class: "calendar-header" }, h("button", { type: "button", name: "month", title: "Month", class: index === 0 ? 'header-button-prev' : 'header-button-next', onClick: () => this.updateYearMonth(index === 0 ? 'prev' : 'next') }, h("sd-icon", { name: index === 0 ? 'arrowLeft' : 'arrowRight', size: "12", color: "#CCCCCC" })), index === 0
143
143
  ? `${this.prevYear}.${String(this.prevMonth).padStart(2, '0')}`
144
144
  : `${this.nextYear}.${String(this.nextMonth).padStart(2, '0')}`), h("div", { class: "calendar-days" }, ['일', '월', '화', '수', '목', '금', '토'].map(day => (h("sd-date-box", { key: day, date: day, disabled: true, class: "day" })))), h("div", { class: "calendar-body mt-12pxr grid grid-cols-7 gap-y-8pxr" }, [...calendar.prevMonthDays, ...calendar.days, ...calendar.afterMonthDays].map((day, idx) => (h("sd-date-box", { key: `prev${day}_${idx}`, date: !day ? '' : Number(day), selected: this.dateRange.some(date => date ===
145
145
  this.dateUtil.formatDate(index === 0 ? this.prevYear : this.nextYear, index === 0 ? this.prevMonth : this.nextMonth, Number(day))), type: this.getDateBoxType(this.dateUtil.formatDate(index === 0 ? this.prevYear : this.nextYear, index === 0 ? this.prevMonth : this.nextMonth, Number(day))), isToday: today ===
@@ -1360,6 +1360,14 @@ textarea {
1360
1360
  cursor: pointer;
1361
1361
  }
1362
1362
 
1363
+ .sd-guide :deep(.sd-button) {
1364
+ padding: 0 16px 0 12px;
1365
+ border-radius: 16px;
1366
+ }
1367
+ .sd-guide :deep(.sd-button) .sd-button__content .sd-button__label {
1368
+ color: #333333;
1369
+ }
1370
+
1363
1371
  .sd-guide__popup {
1364
1372
  position: relative;
1365
1373
  padding: 20px 32px;
@@ -1,21 +1,32 @@
1
1
  import { Host, h } from "@stencil/core";
2
2
  import colors from "../../styles/color.json";
3
+ const GUIDE_LABEL = {
4
+ help: '활용 TIP',
5
+ pdf: 'PDF Guide',
6
+ youtube: 'Video Guide',
7
+ notion: '사용 가이드',
8
+ event: 'Event Button',
9
+ };
10
+ const GUIDE_ICON = {
11
+ help: {
12
+ name: 'helpOutline',
13
+ size: 20,
14
+ color: colors.green_65,
15
+ },
16
+ pdf: { name: 'pdf', size: 20, color: colors.red_75 },
17
+ youtube: { name: 'youtube', size: 20, color: colors.red_75 },
18
+ notion: { name: 'notion', size: 16, color: colors.black },
19
+ event: { name: 'event', size: 16, color: colors.brilliantblue_70 },
20
+ };
3
21
  export class SdGuide {
4
22
  el;
5
23
  type = 'help';
6
- popupTitle = '';
24
+ label = '';
7
25
  message = '';
8
26
  guideUrl = '';
9
27
  popupWidth;
10
28
  popupShow = false;
11
29
  guideRef;
12
- static guideTitle = {
13
- help: '활용 Tip',
14
- pdf: 'PDF Guide',
15
- youtube: 'Video Guide',
16
- notion: '사용 가이드',
17
- event: 'Event Button',
18
- };
19
30
  handleClickGuide = () => {
20
31
  if (this.type === 'help') {
21
32
  this.popupShow = !this.popupShow;
@@ -25,58 +36,59 @@ export class SdGuide {
25
36
  window.open(this.guideUrl, '_blank');
26
37
  }
27
38
  };
28
- getGuideClasses() {
29
- const classes = ['sd-guide'];
30
- classes.push(`sd-guide--${this.type}`);
39
+ get guideClass() {
40
+ const classes = ['sd-guide', `sd-guide--${this.type}`];
31
41
  if (this.popupShow)
32
42
  classes.push('sd-guide--active');
33
43
  return classes.join(' ');
34
44
  }
35
- getGuideStyle() {
36
- const styles = {};
37
- if (this.type === 'help') {
38
- styles['--guide-border'] = this.popupShow ? colors.green_65 : colors.grey_45;
39
- styles['--guide-color'] = this.popupShow ? colors.white : colors.grey_90;
40
- styles['--guide-background'] = this.popupShow ? colors.green_65 : colors.white;
41
- }
42
- else {
43
- styles['--guide-border'] = colors.grey_45;
44
- styles['--guide-color'] = colors.grey_90;
45
- styles['--guide-background'] = colors.white;
46
- }
47
- return styles;
48
- }
49
- getGuidIcon() {
50
- if (this.type === 'pdf') {
51
- return { name: 'pdf', size: 20, color: colors.red_75 };
52
- }
53
- else if (this.type === 'youtube') {
54
- return { name: 'youtube', size: 20, color: colors.red_75 };
55
- }
56
- else if (this.type === 'notion') {
57
- return { name: 'notion', size: 16, color: colors.black };
58
- }
59
- else if (this.type === 'event') {
60
- return { name: 'event', size: 16, color: colors.brilliantblue_70 };
61
- }
62
- return { name: 'helpOutline', size: 20, color: this.popupShow ? colors.white : colors.green_65 };
63
- }
45
+ // private getGuideStyle(): StyleProps {
46
+ // const styles: StyleProps = {};
47
+ // if (this.type === 'help') {
48
+ // styles['--guide-border'] = this.popupShow ? colors.green_65 : colors.grey_45;
49
+ // styles['--guide-color'] = this.popupShow ? colors.white : colors.grey_90;
50
+ // styles['--guide-background'] = this.popupShow ? colors.green_65 : colors.white;
51
+ // } else {
52
+ // styles['--guide-border'] = colors.grey_45;
53
+ // styles['--guide-color'] = colors.grey_90;
54
+ // styles['--guide-background'] = colors.white;
55
+ // }
56
+ // return styles;
57
+ // }
58
+ // private getGuidIcon(): { name: IconName; size: number; color: string } {
59
+ // if (this.type === 'pdf') {
60
+ // return { name: 'pdf', size: 20, color: colors.red_75 };
61
+ // } else if (this.type === 'youtube') {
62
+ // return { name: 'youtube', size: 20, color: colors.red_75 };
63
+ // } else if (this.type === 'notion') {
64
+ // return { name: 'notion', size: 16, color: colors.black };
65
+ // } else if (this.type === 'event') {
66
+ // return { name: 'event', size: 16, color: colors.brilliantblue_70 };
67
+ // }
68
+ // return { name: 'helpOutline', size: 20, color: this.popupShow ? colors.white : colors.green_65 };
69
+ // }
64
70
  closeDropdown = () => {
65
71
  this.popupShow = false;
66
72
  };
67
73
  render() {
68
- const { name: iconName, size: iconSize, color: iconColor } = this.getGuidIcon();
69
- return (h(Host, { key: 'd3975227833fe5304ee63c26989724bf505e4e6c', style: this.getGuideStyle() }, h("sd-button", { key: '7d9c8788d6022f718e986c1a30591f5fcf7dab91', ref: el => (this.guideRef = el), class: this.getGuideClasses(), variant: "outline", label: SdGuide.guideTitle[this.type], size: "md", color: "var(--guide-color)", icon: iconName, iconColor: iconColor, iconSize: iconSize, iconStyle: { marginRight: '4px' }, buttonStyle: {
70
- height: '28px',
71
- minHeight: '28px',
72
- padding: '4px 12px',
73
- borderRadius: '16px',
74
- borderColor: 'var(--guide-border)',
75
- color: 'var(--guide-color)',
76
- fontSize: '12px',
77
- fontWeight: '400',
78
- backgroundColor: 'var(--guide-background)',
79
- }, onSdClick: this.handleClickGuide }), this.type === 'help' && this.popupShow && (h("sd-portal", { key: 'f0b87eea6c9abe2b61d4e3a30b931b54585219ae', open: this.popupShow, parentRef: this.guideRef, onSdClose: this.closeDropdown, offset: [0, 24] }, h("div", { key: 'b151630790e32f2da7f54307853d728ac08d8cfd', class: "sd-guide__popup", style: { width: this.popupWidth ? this.popupWidth + 'px' : '426px' } }, h("sd-button", { key: 'e265b60f46ed7f76e9c021d5c673d44ed02f0ee6', class: "sd-guide__popup__close", icon: "close", color: colors.grey_65, size: "md", variant: "ghost", noHover: true, buttonStyle: { padding: '0px', minHeight: '0px' }, onSdClick: this.closeDropdown }), h("div", { key: '50406979d5c832abb262ea121b3c1cd0fb464b77', class: "sd-guide__popup__header" }, h("sd-icon", { key: '2e0fd5798d96b58c732a88e4917a7c9d47e28901', name: "helpOutline", size: 24, color: colors.green_65 }), h("h3", { key: 'ab6f05250c499dc741b118ddf346857f2c55969f', class: "sd-guide__popup__title" }, this.popupTitle || SdGuide.guideTitle[this.type])), h("ul", { key: '6676f25ca3f75a5fb306013ad1efc33e5ccac1c2', class: "sd-guide__popup__list" }, this.renderListItem(this.message)))))));
74
+ // const { name: iconName, size: iconSize, color: iconColor } = this.getGuidIcon();
75
+ const { name: iconName, size: iconSize, color: iconColor } = GUIDE_ICON[this.type];
76
+ return (h(Host, { key: '9f8b8af98d5bbcbde8544d0e8e337068e8e5778d' }, h("sd-button", { key: '13cd8b97e2c017f5e31344cb9ded45015bfe8364', ref: el => (this.guideRef = el), class: this.guideClass, variant: "outline", label: GUIDE_LABEL[this.type], size: "sm", color: "grey_45", icon: iconName, iconColor: iconColor, iconSize: iconSize,
77
+ // iconStyle={{ marginRight: '4px' }}
78
+ // buttonStyle={{
79
+ // height: '28px',
80
+ // minHeight: '28px',
81
+ // padding: '4px 12px',
82
+ // borderRadius: '16px',
83
+ // borderColor: 'var(--guide-border)',
84
+ // color: 'var(--guide-color)',
85
+ // fontSize: '12px',
86
+ // fontWeight: '400',
87
+ // backgroundColor: 'var(--guide-background)',
88
+ // }}
89
+ onSdClick: this.handleClickGuide }), this.type === 'help' && this.popupShow && (h("sd-portal", { key: '5e199a2c2d5bc42fa87c651ef4d07fa0ab091558', open: this.popupShow, parentRef: this.guideRef, onSdClose: this.closeDropdown, offset: [0, 4] }, h("div", { key: '625d746fedfc57df447f754ae477d89058152ead', class: "sd-guide__popup", style: { width: this.popupWidth ? this.popupWidth + 'px' : '426px' } }, h("sd-button", { key: 'ac0f7809af22910f677df3a3ec48dd370dac0f9e', class: "sd-guide__popup__close", icon: "close", color: colors.grey_65, size: "md", variant: "ghost", noHover: true,
90
+ // buttonStyle={{ padding: '0px', minHeight: '0px' }}
91
+ onSdClick: this.closeDropdown }), h("div", { key: '747244da8b2cd0c6b59bdaa2bc7967017dcc1a6b', class: "sd-guide__popup__header" }, h("sd-icon", { key: '7899329aed456415febc12184d7fb276eeb011fd', name: "helpOutline", size: 24, color: colors.green_65 }), h("h3", { key: '9cbbe86aa294d9831e1f7a3a6a0aece5b74b6171', class: "sd-guide__popup__title" }, this.label || GUIDE_LABEL[this.type])), h("ul", { key: '1a2cc3226c080db952adcf458511a5efec61e797', class: "sd-guide__popup__list" }, this.renderListItem(this.message)))))));
80
92
  }
81
93
  // 현재 2depth까지만 스타일 적용
82
94
  renderListItem(message, depth = 0) {
@@ -133,7 +145,7 @@ export class SdGuide {
133
145
  "attribute": "type",
134
146
  "defaultValue": "'help'"
135
147
  },
136
- "popupTitle": {
148
+ "label": {
137
149
  "type": "string",
138
150
  "mutable": false,
139
151
  "complexType": {
@@ -150,7 +162,7 @@ export class SdGuide {
150
162
  "getter": false,
151
163
  "setter": false,
152
164
  "reflect": false,
153
- "attribute": "popup-title",
165
+ "attribute": "label",
154
166
  "defaultValue": "''"
155
167
  },
156
168
  "message": {
@@ -1 +1 @@
1
- {"version":3,"file":"sd-guide.js","sourceRoot":"","sources":["../../../src/components/sd-guide/sd-guide.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,EAAE,MAAM,eAAe,CAAC;AACzE,OAAO,MAAM,MAAM,yBAAyB,CAAC;AAS7C,MAAM,OAAO,OAAO;IACR,EAAE,CAAe;IAEpB,IAAI,GAAc,MAAM,CAAC;IACzB,UAAU,GAAW,EAAE,CAAC;IACxB,OAAO,GAAsB,EAAE,CAAC;IAChC,QAAQ,GAAW,EAAE,CAAC;IACtB,UAAU,CAAU;IAEnB,SAAS,GAAY,KAAK,CAAC;IAE5B,QAAQ,CAAe;IAE/B,MAAM,CAAC,UAAU,GAAG;QACnB,IAAI,EAAE,QAAQ;QACd,GAAG,EAAE,WAAW;QAChB,OAAO,EAAE,aAAa;QACtB,MAAM,EAAE,QAAQ;QAChB,KAAK,EAAE,cAAc;KACrB,CAAC;IAEM,gBAAgB,GAAG,GAAG,EAAE;QAC/B,IAAI,IAAI,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;YAC1B,IAAI,CAAC,SAAS,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC;YACjC,OAAO;QACR,CAAC;QAED,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QACtC,CAAC;IACF,CAAC,CAAC;IAEM,eAAe;QACtB,MAAM,OAAO,GAAG,CAAC,UAAU,CAAC,CAAC;QAE7B,OAAO,CAAC,IAAI,CAAC,aAAa,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;QAEvC,IAAI,IAAI,CAAC,SAAS;YAAE,OAAO,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;QAErD,OAAO,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC1B,CAAC;IAEO,aAAa;QACpB,MAAM,MAAM,GAAe,EAAE,CAAC;QAE9B,IAAI,IAAI,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;YAC1B,MAAM,CAAC,gBAAgB,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC;YAC7E,MAAM,CAAC,eAAe,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC;YACzE,MAAM,CAAC,oBAAoB,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;QAChF,CAAC;aAAM,CAAC;YACP,MAAM,CAAC,gBAAgB,CAAC,GAAG,MAAM,CAAC,OAAO,CAAC;YAC1C,MAAM,CAAC,eAAe,CAAC,GAAG,MAAM,CAAC,OAAO,CAAC;YACzC,MAAM,CAAC,oBAAoB,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC;QAC7C,CAAC;QAED,OAAO,MAAM,CAAC;IACf,CAAC;IAEO,WAAW;QAClB,IAAI,IAAI,CAAC,IAAI,KAAK,KAAK,EAAE,CAAC;YACzB,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC;QACxD,CAAC;aAAM,IAAI,IAAI,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;YACpC,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC;QAC5D,CAAC;aAAM,IAAI,IAAI,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;YACnC,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,CAAC;QAC1D,CAAC;aAAM,IAAI,IAAI,CAAC,IAAI,KAAK,OAAO,EAAE,CAAC;YAClC,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,gBAAgB,EAAE,CAAC;QACpE,CAAC;QAED,OAAO,EAAE,IAAI,EAAE,aAAa,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;IAClG,CAAC;IAED,aAAa,GAAG,GAAG,EAAE;QACpB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACxB,CAAC,CAAC;IAEF,MAAM;QACL,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;QAEhF,OAAO,CACN,EAAC,IAAI,qDAAC,KAAK,EAAE,IAAI,CAAC,aAAa,EAAE;YAChC,kEACC,GAAG,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ,GAAG,EAA4B,CAAC,EACzD,KAAK,EAAE,IAAI,CAAC,eAAe,EAAE,EAC7B,OAAO,EAAC,SAAS,EACjB,KAAK,EAAE,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,EACpC,IAAI,EAAC,IAAI,EACT,KAAK,EAAC,oBAAoB,EAC1B,IAAI,EAAE,QAAQ,EACd,SAAS,EAAE,SAAS,EACpB,QAAQ,EAAE,QAAQ,EAClB,SAAS,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,EACjC,WAAW,EAAE;oBACZ,MAAM,EAAE,MAAM;oBACd,SAAS,EAAE,MAAM;oBACjB,OAAO,EAAE,UAAU;oBACnB,YAAY,EAAE,MAAM;oBACpB,WAAW,EAAE,qBAAqB;oBAClC,KAAK,EAAE,oBAAoB;oBAC3B,QAAQ,EAAE,MAAM;oBAChB,UAAU,EAAE,KAAK;oBACjB,eAAe,EAAE,yBAAyB;iBAC1C,EACD,SAAS,EAAE,IAAI,CAAC,gBAAgB,GAC/B;YACD,IAAI,CAAC,IAAI,KAAK,MAAM,IAAI,IAAI,CAAC,SAAS,IAAI,CAC1C,kEACC,IAAI,EAAE,IAAI,CAAC,SAAS,EACpB,SAAS,EAAE,IAAI,CAAC,QAAQ,EACxB,SAAS,EAAE,IAAI,CAAC,aAAa,EAC7B,MAAM,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC;gBAEf,4DACC,KAAK,EAAC,iBAAiB,EACvB,KAAK,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,CAAC,CAAC,OAAO,EAAS;oBAE3E,kEACC,KAAK,EAAC,wBAAwB,EAC9B,IAAI,EAAC,OAAO,EACZ,KAAK,EAAE,MAAM,CAAC,OAAO,EACrB,IAAI,EAAC,IAAI,EACT,OAAO,EAAC,OAAO,EACf,OAAO,QACP,WAAW,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,EACjD,SAAS,EAAE,IAAI,CAAC,aAAa,GAC5B;oBACF,4DAAK,KAAK,EAAC,yBAAyB;wBACnC,gEAAS,IAAI,EAAC,aAAa,EAAC,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,QAAQ,GAAI;wBAChE,2DAAI,KAAK,EAAC,wBAAwB,IAAE,IAAI,CAAC,UAAU,IAAI,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAM,CACrF;oBACN,2DAAI,KAAK,EAAC,uBAAuB,IAAE,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,CAAM,CACrE,CACK,CACZ,CACK,CACP,CAAC;IACH,CAAC;IAED,sBAAsB;IACtB,cAAc,CAAC,OAA0B,EAAE,QAAgB,CAAC;QAC3D,MAAM,SAAS,GAAkB,EAAE,CAAC;QAEpC,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;YAC5B,MAAM,QAAQ,GAAG,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,GAAG,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC;YACzE,SAAS,CAAC,IAAI,CAAC,GAAG,QAAQ,CAAC,IAAI,EAAE,CAAC,CAAC;QACpC,CAAC;aAAM,CAAC;YACP,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC,CAAC;QAC/C,CAAC;QAED,OAAO,SAAS,CAAC;IAClB,CAAC;IAED,QAAQ,GAAG,CAAC,OAAe,EAAE,KAAa,EAAE,EAAE;QAC7C,MAAM,WAAW,GAAG,OAAO,CAAC,OAAO,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;QACrD,OAAO,CACN,UAAI,KAAK,EAAE,kEAAkE,KAAK,EAAE;YACnF,SAAG,SAAS,EAAE,WAAW,GAAM,CAC3B,CACL,CAAC;IACH,CAAC,CAAC","sourcesContent":["import { Component, Element, Host, Prop, State, h } from '@stencil/core';\r\nimport colors from '../../styles/color.json';\r\n\r\ntype GuideType = 'help' | 'pdf' | 'youtube' | 'notion' | 'event';\r\n\r\n@Component({\r\n tag: 'sd-guide',\r\n styleUrl: 'sd-guide.scss',\r\n scoped: true,\r\n})\r\nexport class SdGuide {\r\n @Element() el!: HTMLElement;\r\n\r\n @Prop() type: GuideType = 'help';\r\n @Prop() popupTitle: string = '';\r\n @Prop() message: string | string[] = '';\r\n @Prop() guideUrl: string = '';\r\n @Prop() popupWidth?: number;\r\n\r\n @State() popupShow: boolean = false;\r\n\r\n private guideRef?: HTMLElement;\r\n\r\n static guideTitle = {\r\n help: '활용 Tip',\r\n pdf: 'PDF Guide',\r\n youtube: 'Video Guide',\r\n notion: '사용 가이드',\r\n event: 'Event Button',\r\n };\r\n\r\n private handleClickGuide = () => {\r\n if (this.type === 'help') {\r\n this.popupShow = !this.popupShow;\r\n return;\r\n }\r\n\r\n if (this.guideUrl) {\r\n window.open(this.guideUrl, '_blank');\r\n }\r\n };\r\n\r\n private getGuideClasses(): string {\r\n const classes = ['sd-guide'];\r\n\r\n classes.push(`sd-guide--${this.type}`);\r\n\r\n if (this.popupShow) classes.push('sd-guide--active');\r\n\r\n return classes.join(' ');\r\n }\r\n\r\n private getGuideStyle(): StyleProps {\r\n const styles: StyleProps = {};\r\n\r\n if (this.type === 'help') {\r\n styles['--guide-border'] = this.popupShow ? colors.green_65 : colors.grey_45;\r\n styles['--guide-color'] = this.popupShow ? colors.white : colors.grey_90;\r\n styles['--guide-background'] = this.popupShow ? colors.green_65 : colors.white;\r\n } else {\r\n styles['--guide-border'] = colors.grey_45;\r\n styles['--guide-color'] = colors.grey_90;\r\n styles['--guide-background'] = colors.white;\r\n }\r\n\r\n return styles;\r\n }\r\n\r\n private getGuidIcon(): { name: IconName; size: number; color: string } {\r\n if (this.type === 'pdf') {\r\n return { name: 'pdf', size: 20, color: colors.red_75 };\r\n } else if (this.type === 'youtube') {\r\n return { name: 'youtube', size: 20, color: colors.red_75 };\r\n } else if (this.type === 'notion') {\r\n return { name: 'notion', size: 16, color: colors.black };\r\n } else if (this.type === 'event') {\r\n return { name: 'event', size: 16, color: colors.brilliantblue_70 };\r\n }\r\n\r\n return { name: 'helpOutline', size: 20, color: this.popupShow ? colors.white : colors.green_65 };\r\n }\r\n\r\n closeDropdown = () => {\r\n this.popupShow = false;\r\n };\r\n\r\n render() {\r\n const { name: iconName, size: iconSize, color: iconColor } = this.getGuidIcon();\r\n\r\n return (\r\n <Host style={this.getGuideStyle()}>\r\n <sd-button\r\n ref={el => (this.guideRef = el as unknown as HTMLElement)}\r\n class={this.getGuideClasses()}\r\n variant=\"outline\"\r\n label={SdGuide.guideTitle[this.type]}\r\n size=\"md\"\r\n color=\"var(--guide-color)\"\r\n icon={iconName}\r\n iconColor={iconColor}\r\n iconSize={iconSize}\r\n iconStyle={{ marginRight: '4px' }}\r\n buttonStyle={{\r\n height: '28px',\r\n minHeight: '28px',\r\n padding: '4px 12px',\r\n borderRadius: '16px',\r\n borderColor: 'var(--guide-border)',\r\n color: 'var(--guide-color)',\r\n fontSize: '12px',\r\n fontWeight: '400',\r\n backgroundColor: 'var(--guide-background)',\r\n }}\r\n onSdClick={this.handleClickGuide}\r\n />\r\n {this.type === 'help' && this.popupShow && (\r\n <sd-portal\r\n open={this.popupShow}\r\n parentRef={this.guideRef}\r\n onSdClose={this.closeDropdown}\r\n offset={[0, 24]}\r\n >\r\n <div\r\n class=\"sd-guide__popup\"\r\n style={{ width: this.popupWidth ? this.popupWidth + 'px' : '426px' } as any}\r\n >\r\n <sd-button\r\n class=\"sd-guide__popup__close\"\r\n icon=\"close\"\r\n color={colors.grey_65}\r\n size=\"md\"\r\n variant=\"ghost\"\r\n noHover\r\n buttonStyle={{ padding: '0px', minHeight: '0px' }}\r\n onSdClick={this.closeDropdown}\r\n />\r\n <div class=\"sd-guide__popup__header\">\r\n <sd-icon name=\"helpOutline\" size={24} color={colors.green_65} />\r\n <h3 class=\"sd-guide__popup__title\">{this.popupTitle || SdGuide.guideTitle[this.type]}</h3>\r\n </div>\r\n <ul class=\"sd-guide__popup__list\">{this.renderListItem(this.message)}</ul>\r\n </div>\r\n </sd-portal>\r\n )}\r\n </Host>\r\n );\r\n }\r\n\r\n // 현재 2depth까지만 스타일 적용\r\n renderListItem(message: string | string[], depth: number = 0): HTMLElement[] {\r\n const listItems: HTMLElement[] = [];\r\n\r\n if (Array.isArray(message)) {\r\n const depthMsg = message.map(msg => this.renderListItem(msg, depth + 1));\r\n listItems.push(...depthMsg.flat());\r\n } else {\r\n listItems.push(this.renderLi(message, depth));\r\n }\r\n\r\n return listItems;\r\n }\r\n\r\n renderLi = (message: string, depth: number) => {\r\n const listContent = message.replace(/ /gi, '&nbsp;');\r\n return (\r\n <li class={`sd-guide__popup__list__item sd-guide__popup__list__item--depth-${depth}`}>\r\n <p innerHTML={listContent}></p>\r\n </li>\r\n );\r\n };\r\n}\r\n"]}
1
+ {"version":3,"file":"sd-guide.js","sourceRoot":"","sources":["../../../src/components/sd-guide/sd-guide.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Element, Host, Prop, State, h } from '@stencil/core';\r\nimport colors from '../../styles/color.json';\r\n\r\ntype GuideType = 'help' | 'pdf' | 'youtube' | 'notion' | 'event';\r\n\r\nconst GUIDE_LABEL = {\r\n help: '활용 TIP',\r\n pdf: 'PDF Guide',\r\n youtube: 'Video Guide',\r\n notion: '사용 가이드',\r\n event: 'Event Button',\r\n};\r\n\r\nconst GUIDE_ICON = {\r\n help: {\r\n name: 'helpOutline',\r\n size: 20,\r\n color: colors.green_65,\r\n },\r\n pdf: { name: 'pdf', size: 20, color: colors.red_75 },\r\n youtube: { name: 'youtube', size: 20, color: colors.red_75 },\r\n notion: { name: 'notion', size: 16, color: colors.black },\r\n event: { name: 'event', size: 16, color: colors.brilliantblue_70 },\r\n} as const;\r\n\r\n@Component({\r\n tag: 'sd-guide',\r\n styleUrl: 'sd-guide.scss',\r\n scoped: true,\r\n})\r\nexport class SdGuide {\r\n @Element() el!: HTMLElement;\r\n\r\n @Prop() type: GuideType = 'help';\r\n @Prop() label: string = '';\r\n @Prop() message: string | string[] = '';\r\n @Prop() guideUrl: string = '';\r\n @Prop() popupWidth?: number;\r\n\r\n @State() popupShow: boolean = false;\r\n\r\n private guideRef?: HTMLElement;\r\n\r\n private handleClickGuide = () => {\r\n if (this.type === 'help') {\r\n this.popupShow = !this.popupShow;\r\n return;\r\n }\r\n\r\n if (this.guideUrl) {\r\n window.open(this.guideUrl, '_blank');\r\n }\r\n };\r\n\r\n private get guideClass(): string {\r\n const classes = ['sd-guide', `sd-guide--${this.type}`];\r\n\r\n if (this.popupShow) classes.push('sd-guide--active');\r\n\r\n return classes.join(' ');\r\n }\r\n\r\n // private getGuideStyle(): StyleProps {\r\n // const styles: StyleProps = {};\r\n\r\n // if (this.type === 'help') {\r\n // styles['--guide-border'] = this.popupShow ? colors.green_65 : colors.grey_45;\r\n // styles['--guide-color'] = this.popupShow ? colors.white : colors.grey_90;\r\n // styles['--guide-background'] = this.popupShow ? colors.green_65 : colors.white;\r\n // } else {\r\n // styles['--guide-border'] = colors.grey_45;\r\n // styles['--guide-color'] = colors.grey_90;\r\n // styles['--guide-background'] = colors.white;\r\n // }\r\n\r\n // return styles;\r\n // }\r\n\r\n // private getGuidIcon(): { name: IconName; size: number; color: string } {\r\n // if (this.type === 'pdf') {\r\n // return { name: 'pdf', size: 20, color: colors.red_75 };\r\n // } else if (this.type === 'youtube') {\r\n // return { name: 'youtube', size: 20, color: colors.red_75 };\r\n // } else if (this.type === 'notion') {\r\n // return { name: 'notion', size: 16, color: colors.black };\r\n // } else if (this.type === 'event') {\r\n // return { name: 'event', size: 16, color: colors.brilliantblue_70 };\r\n // }\r\n\r\n // return { name: 'helpOutline', size: 20, color: this.popupShow ? colors.white : colors.green_65 };\r\n // }\r\n\r\n closeDropdown = () => {\r\n this.popupShow = false;\r\n };\r\n\r\n render() {\r\n // const { name: iconName, size: iconSize, color: iconColor } = this.getGuidIcon();\r\n const { name: iconName, size: iconSize, color: iconColor } = GUIDE_ICON[this.type];\r\n\r\n return (\r\n <Host>\r\n <sd-button\r\n ref={el => (this.guideRef = el as unknown as HTMLElement)}\r\n class={this.guideClass}\r\n variant=\"outline\"\r\n label={GUIDE_LABEL[this.type]}\r\n size=\"sm\"\r\n color=\"grey_45\"\r\n icon={iconName}\r\n iconColor={iconColor}\r\n iconSize={iconSize}\r\n // iconStyle={{ marginRight: '4px' }}\r\n // buttonStyle={{\r\n // height: '28px',\r\n // minHeight: '28px',\r\n // padding: '4px 12px',\r\n // borderRadius: '16px',\r\n // borderColor: 'var(--guide-border)',\r\n // color: 'var(--guide-color)',\r\n // fontSize: '12px',\r\n // fontWeight: '400',\r\n // backgroundColor: 'var(--guide-background)',\r\n // }}\r\n onSdClick={this.handleClickGuide}\r\n />\r\n {this.type === 'help' && this.popupShow && (\r\n <sd-portal\r\n open={this.popupShow}\r\n parentRef={this.guideRef}\r\n onSdClose={this.closeDropdown}\r\n offset={[0, 4]}\r\n >\r\n <div\r\n class=\"sd-guide__popup\"\r\n style={{ width: this.popupWidth ? this.popupWidth + 'px' : '426px' } as any}\r\n >\r\n <sd-button\r\n class=\"sd-guide__popup__close\"\r\n icon=\"close\"\r\n color={colors.grey_65}\r\n size=\"md\"\r\n variant=\"ghost\"\r\n noHover\r\n // buttonStyle={{ padding: '0px', minHeight: '0px' }}\r\n onSdClick={this.closeDropdown}\r\n />\r\n <div class=\"sd-guide__popup__header\">\r\n <sd-icon name=\"helpOutline\" size={24} color={colors.green_65} />\r\n <h3 class=\"sd-guide__popup__title\">{this.label || GUIDE_LABEL[this.type]}</h3>\r\n </div>\r\n <ul class=\"sd-guide__popup__list\">{this.renderListItem(this.message)}</ul>\r\n </div>\r\n </sd-portal>\r\n )}\r\n </Host>\r\n );\r\n }\r\n\r\n // 현재 2depth까지만 스타일 적용\r\n renderListItem(message: string | string[], depth: number = 0): HTMLElement[] {\r\n const listItems: HTMLElement[] = [];\r\n\r\n if (Array.isArray(message)) {\r\n const depthMsg = message.map(msg => this.renderListItem(msg, depth + 1));\r\n listItems.push(...depthMsg.flat());\r\n } else {\r\n listItems.push(this.renderLi(message, depth));\r\n }\r\n\r\n return listItems;\r\n }\r\n\r\n renderLi = (message: string, depth: number) => {\r\n const listContent = message.replace(/ /gi, '&nbsp;');\r\n return (\r\n <li class={`sd-guide__popup__list__item sd-guide__popup__list__item--depth-${depth}`}>\r\n <p innerHTML={listContent}></p>\r\n </li>\r\n );\r\n };\r\n}\r\n"]}
@@ -25,7 +25,7 @@ export class SdIcon {
25
25
  }
26
26
  render() {
27
27
  const IconComponent = Icons[this.name]?.[this.size];
28
- return (h("i", { key: '2618a42977f5d3340d9e2daf15b4ddda67689cf5', class: this.getIconClasses(), style: this.iconStyle }, h(IconComponent, { key: 'f8ff1fe92433c2ba82fed4223fc6e4678e52c34b', color: this.resolvedColor })));
28
+ return (h("i", { key: 'b727103f18fb77aeffa1e826154ca3cffbd9fd1b', class: this.getIconClasses(), style: this.iconStyle }, h(IconComponent, { key: '1993b16afde46ce507ed442c20d24179cbd079c7', color: this.resolvedColor })));
29
29
  }
30
30
  static get is() { return "sd-icon"; }
31
31
  static get encapsulation() { return "scoped"; }
@@ -46,7 +46,7 @@ export class SdIcon {
46
46
  "mutable": false,
47
47
  "complexType": {
48
48
  "original": "IconName",
49
- "resolved": "\"arrowDown\" | \"arrowLeft\" | \"arrowLeftEnd\" | \"arrowRight\" | \"arrowRightEnd\" | \"arrowUp\" | \"check\" | \"close\" | \"date\" | \"event\" | \"helpOutline\" | \"notion\" | \"pageMove\" | \"pdf\" | \"search\" | \"youtube\"",
49
+ "resolved": "\"arrowDown\" | \"arrowLeft\" | \"arrowLeftEnd\" | \"arrowRight\" | \"arrowRightEnd\" | \"arrowUp\" | \"check\" | \"close\" | \"date\" | \"event\" | \"helpOutline\" | \"minus\" | \"notion\" | \"pageMove\" | \"pdf\" | \"search\" | \"youtube\"",
50
50
  "references": {
51
51
  "IconName": {
52
52
  "location": "global",
@@ -89,11 +89,11 @@ export class SdInput {
89
89
  '--input-width': typeof this.width === 'number' ? `${this.width}px` : this.width,
90
90
  }
91
91
  : {};
92
- return (h(Host, { key: 'd96f6ba31f2a6933ad3b079f096bbf90f9a17fb9', style: inputWidth }, this.label && h("div", { key: '02758b3e02a680f1287e9dddf1d4a7ce5c1fd9c2', class: "sd-input__label" }, this.label), h("label", { key: 'fbac7be9d0de9041dae55be4c8ed88d9fa9019de', class: {
92
+ return (h(Host, { key: '9a0b975f20b4b8bbc8bff2aef4ee9036450921d4', style: inputWidth }, this.label && h("div", { key: 'ec6c840dcdaa7b9788c32ecbd03dc5daee74c748', class: "sd-input__label" }, this.label), h("label", { key: '4c11c34fd26897b50e0cfbb569de476c9e06884c', class: {
93
93
  'sd-input': true,
94
94
  [this.getInputStatus()]: true,
95
95
  'sd-input--barcode': !!this.barcode,
96
- }, onMouseEnter: () => (this.hovered = true), onMouseLeave: () => (this.hovered = false), style: this.inputStyle }, h("slot", { key: '1d0b462c1b57372b864d4991109b6d7bb08f7355', name: "prefix" }), h("input", { key: '25f3186a06e7535b95eebf6aa553f5e50a091d97', ref: el => (this.nativeEl = el), class: `sd-input__native_element ${this.inputClass}`, type: "text", value: this.internalValue || '', placeholder: this.placeholder, disabled: this.disabled, readonly: this.readonly, autofocus: this.autoFocus, onInput: this.handleInput, onChange: this.handleChange, onFocus: event => this.handleFocus('focus', event), onBlur: event => this.handleFocus('blur', event) }), h("slot", { key: 'cdbc64c69645c0585ad5835bfcc36af54c2de33f', name: "suffix" }), this.clearable && this.internalValue && (h("sd-icon", { key: 'f6088690c7d34249509dffedd2fe6b3eb280dd01', name: "close", color: "#888", style: { marginRight: '-4px', marginLeft: '8px', cursor: 'pointer' }, onClick: () => {
96
+ }, onMouseEnter: () => (this.hovered = true), onMouseLeave: () => (this.hovered = false), style: this.inputStyle }, h("slot", { key: '0d7df02ed548b12f415bd72f84ea411fde5ef549', name: "prefix" }), h("input", { key: '6203dcb95fd486d263e0fe33495243e95c332e1a', ref: el => (this.nativeEl = el), class: `sd-input__native_element ${this.inputClass}`, type: "text", value: this.internalValue || '', placeholder: this.placeholder, disabled: this.disabled, readonly: this.readonly, autofocus: this.autoFocus, onInput: this.handleInput, onChange: this.handleChange, onFocus: event => this.handleFocus('focus', event), onBlur: event => this.handleFocus('blur', event) }), h("slot", { key: '21544173b390be5607c50faf84f1d47fa703e8bf', name: "suffix" }), this.clearable && this.internalValue && (h("sd-icon", { key: '39ed103b452ae49e2f492d8d0072ee42a842c4c0', name: "close", color: "#888", style: { marginRight: '-4px', marginLeft: '8px', cursor: 'pointer' }, onClick: () => {
97
97
  this.internalValue = '';
98
98
  this.sdChange?.emit(this.internalValue);
99
99
  this.sdInput?.emit(this.internalValue);
@@ -73,12 +73,12 @@ export class SdPagination {
73
73
  }
74
74
  }
75
75
  render() {
76
- return (h("div", { key: 'a59ec8c79042ac6b245dc796099b18f574a59045', class: this.paginationClasses }, h("div", { key: 'd4d951dc0f5c8b5212a21eaa02389344768ad15c', class: "prepend-btns" }, this.renderPrevButtons()), this.simple ? (h("div", { class: "pagination-info" }, h("span", { class: "current-page" }, this.currentPage), h("span", null, "/"), h("span", { class: "last-page" }, this.lastPage))) : (this.pageNumbers.map(n => (h("button", { type: "button", "aria-current": this.currentPage === n ? 'page' : undefined, class: {
76
+ return (h("div", { key: 'ae962ed1dfbcb79c23c402d52d0a83822b54d4b3', class: this.paginationClasses }, h("div", { key: 'efa0dfbcc8d71d2b9ff5b02334a3d1e119a7f469', class: "prepend-btns" }, this.renderPrevButtons()), this.simple ? (h("div", { class: "pagination-info" }, h("span", { class: "current-page" }, this.currentPage), h("span", null, "/"), h("span", { class: "last-page" }, this.lastPage))) : (this.pageNumbers.map(n => (h("button", { type: "button", "aria-current": this.currentPage === n ? 'page' : undefined, class: {
77
77
  'pagination-btn': true,
78
78
  'pagination-btn--selected': this.currentPage === n,
79
79
  }, disabled: this.currentPage === n, style: {
80
80
  '--pagination-btn-width': `${this.buttonWidth}px`,
81
- }, onClick: () => this.handlePageChange(n) }, n)))), h("div", { key: '90070d87eae5ba4d7e45c8b1163c6d910b202427', class: "append-btns" }, this.renderNextButtons())));
81
+ }, onClick: () => this.handlePageChange(n) }, n)))), h("div", { key: 'f0bd3b291453696e22a34f182a852a2a092874f2', class: "append-btns" }, this.renderNextButtons())));
82
82
  }
83
83
  static get is() { return "sd-pagination"; }
84
84
  static get encapsulation() { return "shadow"; }
@@ -31,11 +31,11 @@ export class SdPopover {
31
31
  this.showPopover = false;
32
32
  };
33
33
  render() {
34
- return (h(Fragment, { key: 'e058418533929563a9ea1991823ec5bf2406e5f6' }, this.label ? (h("sd-button", { ref: el => (this.buttonEl = el), label: this.label, icon: this.icon, size: this.buttonSize, color: this.color, variant: this.buttonVariant, class: "sd-popover", onClick: () => (console.log('click popover'), (this.showPopover = !this.showPopover)) })) : (h("sd-icon", { ref: el => (this.buttonEl = el), name: this.icon, size: this.iconSize, color: this.color, class: "sd-popover", onClick: () => (console.log('click popover'), (this.showPopover = !this.showPopover)) })), this.showPopover && (h("sd-tooltip-portal", { key: 'debecbef44714e705bf87bded2b7a85d016faba1', parentRef: this.buttonEl, onSdClose: this.handleClose, placement: this.placement }, h("div", { key: '26afb49bf9bc4c8227427a9fe93280e5435d20fc', class: {
34
+ return (h(Fragment, { key: 'fb877e8d016d13fb33b49a1a4dbfed9fc01b1336' }, this.label ? (h("sd-button", { ref: el => (this.buttonEl = el), label: this.label, icon: this.icon, size: this.buttonSize, color: this.color, variant: this.buttonVariant, class: "sd-popover", onClick: () => (console.log('click popover'), (this.showPopover = !this.showPopover)) })) : (h("sd-icon", { ref: el => (this.buttonEl = el), name: this.icon, size: this.iconSize, color: this.color, class: "sd-popover", onClick: () => (console.log('click popover'), (this.showPopover = !this.showPopover)) })), this.showPopover && (h("sd-tooltip-portal", { key: '02208721da61cb84086a57c823f8e31775fdbd5e', parentRef: this.buttonEl, onSdClose: this.handleClose, placement: this.placement }, h("div", { key: '3f3c4fc690dac5061bda08af37121e2b98374979', class: {
35
35
  'sd-popover-menu': true,
36
36
  [`sd-popover-menu--${this.placement}`]: true,
37
37
  [this.menuClass]: !!this.menuClass,
38
- } }, h("i", { key: '52dd82b64d1d4ae5ec3741febb07ef553e50f42d', class: `sd-popover-menu__arrow sd-popover-menu__arrow--${this.placement}` }, h(TooltipArrow, { key: 'e94ac6ea51e421546a813406d1821e6f3727e7bd' })), h("div", { key: '0abdb59077846308b2ccff14339eb193f8073433', class: "sd-popover-menu__content" }, this.menuTitle && h("div", { key: '9b0f289d9f7dbfb09c3e0a8b4162af97aef53e73', class: "sd-popover-menu__title" }, this.menuTitle), this.messages.length > 0 && (h("div", { key: '6311f5e4a7ae9699d65d344f0b407b3715f2e072', class: "sd-popover-menu__messages" }, this.messages.map(message => (h("div", null, message))))), this.buttons.length > 0 && (h("div", { key: '65b7ea1a67400b1887248a615fdb1ba93928e34a', class: `sd-popover-menu__buttons sd-popover-menu__buttons--${this.buttons.length}` }, this.buttons.map(button => (h("sd-button", { ...button })))))), this.useClose && (h("button", { key: '9032a6f6381cdf0b4bd3df689280aadb8357ffa6', class: "sd-popover-menu__close-button", onClick: () => this.handleClose() }, h("sd-icon", { key: '6ac75128090091c510065cb7317478722a35de7c', name: "close", size: "12", color: "#AAAAAA" }))))))));
38
+ } }, h("i", { key: '6f0df95bafc2cbf564fd0e5a133c89f03c3a924b', class: `sd-popover-menu__arrow sd-popover-menu__arrow--${this.placement}` }, h(TooltipArrow, { key: '535acee0be86db4ed58d6cc1631732541f1e475e' })), h("div", { key: 'd4366800a8cbd5a1f9630344a5ca4241b0eaa8dd', class: "sd-popover-menu__content" }, this.menuTitle && h("div", { key: '1cd9de3129988c5d26be0ded5b03520ab591cb9a', class: "sd-popover-menu__title" }, this.menuTitle), this.messages.length > 0 && (h("div", { key: '5aae57948bd5e0fd98e73a8ae504b77ce6cdbe07', class: "sd-popover-menu__messages" }, this.messages.map(message => (h("div", null, message))))), this.buttons.length > 0 && (h("div", { key: '814ac9ba0b2cf4367bb4cd5e688fa5433fee7126', class: `sd-popover-menu__buttons sd-popover-menu__buttons--${this.buttons.length}` }, this.buttons.map(button => (h("sd-button", { ...button })))))), this.useClose && (h("button", { key: 'a21ad0a5e28f8609b2f9d9accd0be5d81ed9de5b', class: "sd-popover-menu__close-button", onClick: () => this.handleClose() }, h("sd-icon", { key: '10738ec0926ea5fbc0b30b5c8c08b6cc37bf47d3', name: "close", size: "12", color: "#AAAAAA" }))))))));
39
39
  }
40
40
  static get is() { return "sd-popover"; }
41
41
  static get encapsulation() { return "shadow"; }
@@ -116,7 +116,7 @@ export class SdPopover {
116
116
  "mutable": false,
117
117
  "complexType": {
118
118
  "original": "IconName",
119
- "resolved": "\"arrowDown\" | \"arrowLeft\" | \"arrowLeftEnd\" | \"arrowRight\" | \"arrowRightEnd\" | \"arrowUp\" | \"check\" | \"close\" | \"date\" | \"event\" | \"helpOutline\" | \"notion\" | \"pageMove\" | \"pdf\" | \"search\" | \"youtube\"",
119
+ "resolved": "\"arrowDown\" | \"arrowLeft\" | \"arrowLeftEnd\" | \"arrowRight\" | \"arrowRightEnd\" | \"arrowUp\" | \"check\" | \"close\" | \"date\" | \"event\" | \"helpOutline\" | \"minus\" | \"notion\" | \"pageMove\" | \"pdf\" | \"search\" | \"youtube\"",
120
120
  "references": {
121
121
  "IconName": {
122
122
  "location": "global",
@@ -92,7 +92,7 @@ export class SdPortal {
92
92
  this.sdClose.emit();
93
93
  }
94
94
  render() {
95
- return h("slot", { key: '2423eed047adb72c699ad363c5f756820f0ccad2' });
95
+ return h("slot", { key: '00e0fc50bd1da8ae4f43b61ddcc37614a4738dde' });
96
96
  }
97
97
  static get is() { return "sd-portal"; }
98
98
  static get properties() {
@@ -1370,6 +1370,7 @@ textarea {
1370
1370
  padding: 4px 12px;
1371
1371
  font-size: 12px;
1372
1372
  line-height: 20px;
1373
+ cursor: pointer;
1373
1374
  }
1374
1375
  .sd-select__option__checkbox-wrapper {
1375
1376
  display: flex;