@sellmate/design-system 0.0.15 → 0.0.17

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 (223) hide show
  1. package/dist/cjs/design-system.cjs.js +2 -2
  2. package/dist/cjs/{index-D1tXBb8y.js → index-BxN2rEJl.js} +3 -3
  3. package/dist/cjs/index-BxN2rEJl.js.map +1 -0
  4. package/dist/cjs/loader.cjs.js +2 -2
  5. package/dist/cjs/sd-badge.cjs.entry.js +2 -2
  6. package/dist/cjs/sd-badge.entry.cjs.js.map +1 -1
  7. package/dist/cjs/sd-button.sd-tooltip-portal.entry.cjs.js.map +1 -1
  8. package/dist/cjs/sd-button_2.cjs.entry.js +3 -3
  9. package/dist/cjs/sd-card.cjs.entry.js +2 -2
  10. package/dist/cjs/sd-card.entry.cjs.js.map +1 -1
  11. 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
  12. package/dist/cjs/sd-checkbox_9.cjs.entry.js +12 -12
  13. package/dist/cjs/sd-date-box.cjs.entry.js +2 -2
  14. package/dist/cjs/sd-date-box.entry.cjs.js.map +1 -1
  15. package/dist/cjs/sd-date-picker.cjs.entry.js +2 -2
  16. package/dist/cjs/sd-date-picker.entry.cjs.js.map +1 -1
  17. package/dist/cjs/sd-date-range-picker.cjs.entry.js +2 -2
  18. package/dist/cjs/sd-date-range-picker.entry.cjs.js.map +1 -1
  19. package/dist/cjs/sd-guide.cjs.entry.js +5 -6
  20. package/dist/cjs/sd-guide.entry.cjs.js.map +1 -1
  21. package/dist/cjs/sd-pagination.sd-tooltip.entry.cjs.js.map +1 -1
  22. package/dist/cjs/sd-pagination_2.cjs.entry.js +4 -4
  23. package/dist/cjs/sd-popover.cjs.entry.js +3 -3
  24. package/dist/cjs/sd-popover.entry.cjs.js.map +1 -1
  25. package/dist/cjs/sd-table.cjs.entry.js +11 -5
  26. package/dist/cjs/sd-table.entry.cjs.js.map +1 -1
  27. package/dist/cjs/sd-tag.cjs.entry.js +1 -1
  28. package/dist/cjs/{tooltipArrow-D4Vc_pEU.js → tooltipArrow-ByThZw_g.js} +3 -3
  29. package/dist/cjs/{tooltipArrow-D4Vc_pEU.js.map → tooltipArrow-ByThZw_g.js.map} +1 -1
  30. package/dist/collection/components/sd-badge/sd-badge.css +4 -52
  31. package/dist/collection/components/sd-button/sd-button.css +0 -52
  32. package/dist/collection/components/sd-button/sd-button.js +1 -2
  33. package/dist/collection/components/sd-button/sd-button.js.map +1 -1
  34. package/dist/collection/components/sd-card/sd-card.css +2 -52
  35. package/dist/collection/components/sd-checkbox/sd-checkbox.css +0 -52
  36. package/dist/collection/components/sd-checkbox/sd-checkbox.js +1 -2
  37. package/dist/collection/components/sd-checkbox/sd-checkbox.js.map +1 -1
  38. package/dist/collection/components/sd-date-box/sd-date-box.css +0 -52
  39. package/dist/collection/components/sd-date-picker/sd-date-picker.css +0 -52
  40. package/dist/collection/components/sd-date-range-picker/sd-date-range-picker.css +0 -52
  41. package/dist/collection/components/sd-guide/sd-guide.css +1438 -46
  42. package/dist/collection/components/sd-guide/sd-guide.js +3 -5
  43. package/dist/collection/components/sd-guide/sd-guide.js.map +1 -1
  44. package/dist/collection/components/sd-icon/sd-icon.js +1 -2
  45. package/dist/collection/components/sd-icon/sd-icon.js.map +1 -1
  46. package/dist/collection/components/sd-input/sd-input.css +22 -52
  47. package/dist/collection/components/sd-input/sd-input.js +1 -1
  48. package/dist/collection/components/sd-input/sd-input.js.map +1 -1
  49. package/dist/collection/components/sd-pagination/sd-pagination.css +0 -52
  50. package/dist/collection/components/sd-popover/sd-popover.css +0 -52
  51. package/dist/collection/components/sd-select/sd-select-option/sd-select-option.css +0 -52
  52. package/dist/collection/components/sd-select/sd-select.css +0 -52
  53. package/dist/collection/components/sd-select-multiple/sd-select-multiple.css +0 -52
  54. package/dist/collection/components/sd-select-multiple-group/sd-select-multiple-group.css +0 -52
  55. package/dist/collection/components/sd-select-multiple-group/sd-select-option-group/sd-select-option-group.css +0 -52
  56. package/dist/collection/components/sd-table/sd-table.css +0 -52
  57. package/dist/collection/components/sd-table/sd-table.js +9 -3
  58. package/dist/collection/components/sd-table/sd-table.js.map +1 -1
  59. package/dist/collection/components/sd-tooltip/sd-tooltip.css +0 -52
  60. package/dist/components/index.js +1 -1
  61. package/dist/components/p-03XlrG8V.js +78 -0
  62. package/dist/components/{p-D_m-rDEx.js.map → p-03XlrG8V.js.map} +1 -1
  63. package/dist/components/{p-BOsnXzkr.js → p-B60pARKe.js} +6 -6
  64. package/dist/components/p-B60pARKe.js.map +1 -0
  65. package/dist/components/p-BSERuUHP.js +130 -0
  66. package/dist/components/{p-x0iTdFk8.js.map → p-BSERuUHP.js.map} +1 -1
  67. package/dist/components/{p-yJmTynI0.js → p-BXPm14Mz.js} +3 -3
  68. package/dist/components/{p-yJmTynI0.js.map → p-BXPm14Mz.js.map} +1 -1
  69. package/dist/components/p-Biihf4L_.js +104 -0
  70. package/dist/components/p-Biihf4L_.js.map +1 -0
  71. package/dist/components/p-C9h8A06v.js +95 -0
  72. package/dist/components/{p-B1kMis4e.js.map → p-C9h8A06v.js.map} +1 -1
  73. package/dist/components/p-ChtYytaJ.js +167 -0
  74. package/dist/components/p-ChtYytaJ.js.map +1 -0
  75. package/dist/components/p-CjFMRk1X.js +110 -0
  76. package/dist/components/{p-UtZuVoJ9.js.map → p-CjFMRk1X.js.map} +1 -1
  77. package/dist/components/p-Ctp8Jcfa.js +118 -0
  78. package/dist/components/p-Ctp8Jcfa.js.map +1 -0
  79. package/dist/components/{p-az-fZTqo.js → p-CxfkkYH4.js} +3 -3
  80. package/dist/components/{p-az-fZTqo.js.map → p-CxfkkYH4.js.map} +1 -1
  81. package/dist/components/{p-CLODAhOA.js → p-D_VunbXE.js} +3 -3
  82. package/dist/components/p-D_VunbXE.js.map +1 -0
  83. package/dist/components/p-OUj9ew5s.js +97 -0
  84. package/dist/components/{p-B_s4RQWY.js.map → p-OUj9ew5s.js.map} +1 -1
  85. package/dist/components/{p-Bws0p2kF.js → p-Pgg2vJbw.js} +3 -3
  86. package/dist/components/{p-Bws0p2kF.js.map → p-Pgg2vJbw.js.map} +1 -1
  87. package/dist/components/{p-sQ8mybM7.js → p-VEsa5ImC.js} +3 -3
  88. package/dist/components/{p-sQ8mybM7.js.map → p-VEsa5ImC.js.map} +1 -1
  89. package/dist/components/sd-badge.js +2 -2
  90. package/dist/components/sd-badge.js.map +1 -1
  91. package/dist/components/sd-button.js +1 -1
  92. package/dist/components/sd-card.js +2 -2
  93. package/dist/components/sd-card.js.map +1 -1
  94. package/dist/components/sd-checkbox.js +1 -1
  95. package/dist/components/sd-date-box.js +1 -1
  96. package/dist/components/sd-date-picker.js +6 -6
  97. package/dist/components/sd-date-picker.js.map +1 -1
  98. package/dist/components/sd-date-range-picker.js +6 -6
  99. package/dist/components/sd-date-range-picker.js.map +1 -1
  100. package/dist/components/sd-guide.js +9 -10
  101. package/dist/components/sd-guide.js.map +1 -1
  102. package/dist/components/sd-icon.js +1 -1
  103. package/dist/components/sd-input.js +1 -1
  104. package/dist/components/sd-pagination.js +1 -1
  105. package/dist/components/sd-popover.js +6 -6
  106. package/dist/components/sd-popover.js.map +1 -1
  107. package/dist/components/sd-portal.js +1 -1
  108. package/dist/components/sd-select-multiple-group.js +8 -8
  109. package/dist/components/sd-select-multiple-group.js.map +1 -1
  110. package/dist/components/sd-select-multiple.js +8 -8
  111. package/dist/components/sd-select-multiple.js.map +1 -1
  112. package/dist/components/sd-select-option-group.js +1 -1
  113. package/dist/components/sd-select-option.js +1 -1
  114. package/dist/components/sd-select.js +8 -8
  115. package/dist/components/sd-select.js.map +1 -1
  116. package/dist/components/sd-table.js +17 -11
  117. package/dist/components/sd-table.js.map +1 -1
  118. package/dist/components/sd-tag.js +1 -1
  119. package/dist/components/sd-tooltip-portal.js +1 -1
  120. package/dist/components/sd-tooltip.js +1 -1
  121. package/dist/design-system/design-system.css +1 -1
  122. package/dist/design-system/design-system.esm.js +1 -1
  123. package/dist/design-system/p-172ac888.entry.js +2 -0
  124. package/dist/design-system/{p-b4e3145a.entry.js.map → p-172ac888.entry.js.map} +1 -1
  125. package/dist/design-system/p-17a6e9a6.entry.js +2 -0
  126. package/dist/design-system/{p-b037ea76.entry.js.map → p-17a6e9a6.entry.js.map} +1 -1
  127. package/dist/design-system/p-26ee9e78.entry.js +2 -0
  128. package/dist/design-system/p-26ee9e78.entry.js.map +1 -0
  129. package/dist/design-system/p-273d1488.entry.js +2 -0
  130. package/dist/design-system/{p-bd9e799c.entry.js.map → p-273d1488.entry.js.map} +1 -1
  131. package/dist/design-system/{p-240de5df.entry.js → p-3435bfa7.entry.js} +2 -2
  132. package/dist/design-system/p-53475fb4.entry.js +2 -0
  133. package/dist/design-system/{p-2e519819.entry.js.map → p-53475fb4.entry.js.map} +1 -1
  134. package/dist/design-system/p-68ce5720.entry.js +2 -0
  135. package/dist/design-system/{p-d185bd2e.entry.js.map → p-68ce5720.entry.js.map} +1 -1
  136. package/dist/design-system/p-7e7c4c50.entry.js +2 -0
  137. package/dist/design-system/{p-4eaf6262.entry.js.map → p-7e7c4c50.entry.js.map} +1 -1
  138. package/dist/design-system/p-9c782858.entry.js +2 -0
  139. package/dist/design-system/{p-62c12ab7.entry.js.map → p-9c782858.entry.js.map} +1 -1
  140. package/dist/design-system/{p-D8LjiNqp.js → p-B2E2_4lK.js} +2 -2
  141. package/dist/design-system/{p-D8LjiNqp.js.map → p-B2E2_4lK.js.map} +1 -1
  142. package/dist/design-system/p-BAZEKdOK.js +3 -0
  143. package/dist/design-system/p-BAZEKdOK.js.map +1 -0
  144. package/dist/design-system/p-f998a926.entry.js +2 -0
  145. package/dist/design-system/p-f998a926.entry.js.map +1 -0
  146. package/dist/design-system/p-f9d2e115.entry.js +2 -0
  147. package/dist/design-system/{p-71716c18.entry.js.map → p-f9d2e115.entry.js.map} +1 -1
  148. package/dist/design-system/p-fbff7da1.entry.js +2 -0
  149. package/dist/design-system/{p-87da8d28.entry.js.map → p-fbff7da1.entry.js.map} +1 -1
  150. package/dist/design-system/sd-badge.entry.esm.js.map +1 -1
  151. package/dist/design-system/sd-button.sd-tooltip-portal.entry.esm.js.map +1 -1
  152. package/dist/design-system/sd-card.entry.esm.js.map +1 -1
  153. 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
  154. package/dist/design-system/sd-date-box.entry.esm.js.map +1 -1
  155. package/dist/design-system/sd-date-picker.entry.esm.js.map +1 -1
  156. package/dist/design-system/sd-date-range-picker.entry.esm.js.map +1 -1
  157. package/dist/design-system/sd-guide.entry.esm.js.map +1 -1
  158. package/dist/design-system/sd-pagination.sd-tooltip.entry.esm.js.map +1 -1
  159. package/dist/design-system/sd-popover.entry.esm.js.map +1 -1
  160. package/dist/design-system/sd-table.entry.esm.js.map +1 -1
  161. package/dist/esm/design-system.js +3 -3
  162. package/dist/esm/{index-DON0UcbL.js → index-BAZEKdOK.js} +3 -3
  163. package/dist/esm/index-BAZEKdOK.js.map +1 -0
  164. package/dist/esm/loader.js +3 -3
  165. package/dist/esm/sd-badge.entry.js +2 -2
  166. package/dist/esm/sd-badge.entry.js.map +1 -1
  167. package/dist/esm/sd-button.sd-tooltip-portal.entry.js.map +1 -1
  168. package/dist/esm/sd-button_2.entry.js +3 -3
  169. package/dist/esm/sd-card.entry.js +2 -2
  170. package/dist/esm/sd-card.entry.js.map +1 -1
  171. 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
  172. package/dist/esm/sd-checkbox_9.entry.js +12 -12
  173. package/dist/esm/sd-date-box.entry.js +2 -2
  174. package/dist/esm/sd-date-box.entry.js.map +1 -1
  175. package/dist/esm/sd-date-picker.entry.js +2 -2
  176. package/dist/esm/sd-date-picker.entry.js.map +1 -1
  177. package/dist/esm/sd-date-range-picker.entry.js +2 -2
  178. package/dist/esm/sd-date-range-picker.entry.js.map +1 -1
  179. package/dist/esm/sd-guide.entry.js +5 -6
  180. package/dist/esm/sd-guide.entry.js.map +1 -1
  181. package/dist/esm/sd-pagination.sd-tooltip.entry.js.map +1 -1
  182. package/dist/esm/sd-pagination_2.entry.js +4 -4
  183. package/dist/esm/sd-popover.entry.js +3 -3
  184. package/dist/esm/sd-popover.entry.js.map +1 -1
  185. package/dist/esm/sd-table.entry.js +11 -5
  186. package/dist/esm/sd-table.entry.js.map +1 -1
  187. package/dist/esm/sd-tag.entry.js +1 -1
  188. package/dist/esm/{tooltipArrow-Dv8Sb6cw.js → tooltipArrow-BWyXCaKj.js} +3 -3
  189. package/dist/esm/{tooltipArrow-Dv8Sb6cw.js.map → tooltipArrow-BWyXCaKj.js.map} +1 -1
  190. package/hydrate/index.js +39 -34
  191. package/hydrate/index.mjs +39 -34
  192. package/package.json +2 -2
  193. package/dist/cjs/index-D1tXBb8y.js.map +0 -1
  194. package/dist/components/p-1jmdnu3I.js +0 -118
  195. package/dist/components/p-1jmdnu3I.js.map +0 -1
  196. package/dist/components/p-7xizrxZ5.js +0 -104
  197. package/dist/components/p-7xizrxZ5.js.map +0 -1
  198. package/dist/components/p-B1kMis4e.js +0 -95
  199. package/dist/components/p-BOsnXzkr.js.map +0 -1
  200. package/dist/components/p-BTSN9ENi.js +0 -167
  201. package/dist/components/p-BTSN9ENi.js.map +0 -1
  202. package/dist/components/p-B_s4RQWY.js +0 -97
  203. package/dist/components/p-CLODAhOA.js.map +0 -1
  204. package/dist/components/p-D_m-rDEx.js +0 -78
  205. package/dist/components/p-UtZuVoJ9.js +0 -110
  206. package/dist/components/p-x0iTdFk8.js +0 -130
  207. package/dist/design-system/p-2e519819.entry.js +0 -2
  208. package/dist/design-system/p-4eaf6262.entry.js +0 -2
  209. package/dist/design-system/p-5f6c69ed.entry.js +0 -2
  210. package/dist/design-system/p-5f6c69ed.entry.js.map +0 -1
  211. package/dist/design-system/p-62c12ab7.entry.js +0 -2
  212. package/dist/design-system/p-71716c18.entry.js +0 -2
  213. package/dist/design-system/p-87da8d28.entry.js +0 -2
  214. package/dist/design-system/p-DON0UcbL.js +0 -3
  215. package/dist/design-system/p-DON0UcbL.js.map +0 -1
  216. package/dist/design-system/p-ac9a20b4.entry.js +0 -2
  217. package/dist/design-system/p-ac9a20b4.entry.js.map +0 -1
  218. package/dist/design-system/p-b037ea76.entry.js +0 -2
  219. package/dist/design-system/p-b4e3145a.entry.js +0 -2
  220. package/dist/design-system/p-bd9e799c.entry.js +0 -2
  221. package/dist/design-system/p-d185bd2e.entry.js +0 -2
  222. package/dist/esm/index-DON0UcbL.js.map +0 -1
  223. /package/dist/design-system/{p-240de5df.entry.js.map → p-3435bfa7.entry.js.map} +0 -0
@@ -73,8 +73,7 @@ export class SdGuide {
73
73
  render() {
74
74
  // const { name: iconName, size: iconSize, color: iconColor } = this.getGuidIcon();
75
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' }}
76
+ return (h(Host, { key: 'e7148c94652d2e5a05a8fbdcdccd4b5189787061' }, h("sd-button", { key: '37cfdf20a31e5b0694cfbeabf068534a4dca0a7a', ref: el => (this.guideRef = el), class: this.guideClass, variant: this.popupShow ? 'primary' : 'outline', label: GUIDE_LABEL[this.type], size: "sm", color: "grey_45", icon: iconName, iconColor: iconColor, iconSize: iconSize,
78
77
  // buttonStyle={{
79
78
  // height: '28px',
80
79
  // minHeight: '28px',
@@ -86,9 +85,9 @@ export class SdGuide {
86
85
  // fontWeight: '400',
87
86
  // backgroundColor: 'var(--guide-background)',
88
87
  // }}
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,
88
+ onSdClick: this.handleClickGuide }), this.type === 'help' && this.popupShow && (h("sd-portal", { key: '00581c68ec13b7da4126d4467fc989037983cc40', open: this.popupShow, parentRef: this.guideRef, onSdClose: this.closeDropdown, offset: [0, 4] }, h("div", { key: '387ab5da8f3cebb18fb0efd4905be983dde04078', class: "sd-guide__popup", style: { width: this.popupWidth ? this.popupWidth + 'px' : '426px' } }, h("sd-button", { key: '929be3f65eed31422f40f9785abdfc1b8d658a26', class: "sd-guide__popup__close", icon: "close", color: colors.grey_65, size: "md", variant: "ghost", noHover: true,
90
89
  // 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)))))));
90
+ onSdClick: this.closeDropdown }), h("div", { key: '6cf04080dc39b2e69cc960d832934dfd2f6e5230', class: "sd-guide__popup__header" }, h("sd-icon", { key: 'aed951b851f54d1afb8b3a1b37f47099d3df674b', name: "helpOutline", size: 24, color: colors.green_65 }), h("h3", { key: '485cfad889037e280cdd32d5616ab682f87159b1', class: "sd-guide__popup__title" }, this.label || GUIDE_LABEL[this.type])), h("ul", { key: '56b75b1d4fa43a7b08d4752a5360951a1e19dfa1', class: "sd-guide__popup__list" }, this.renderListItem(this.message)))))));
92
91
  }
93
92
  // 현재 2depth까지만 스타일 적용
94
93
  renderListItem(message, depth = 0) {
@@ -107,7 +106,6 @@ export class SdGuide {
107
106
  return (h("li", { class: `sd-guide__popup__list__item sd-guide__popup__list__item--depth-${depth}` }, h("p", { innerHTML: listContent })));
108
107
  };
109
108
  static get is() { return "sd-guide"; }
110
- static get encapsulation() { return "scoped"; }
111
109
  static get originalStyleUrls() {
112
110
  return {
113
111
  "$": ["sd-guide.scss"]
@@ -1 +1 @@
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"]}
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})\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={this.popupShow ? 'primary' : '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 // 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,10 +25,9 @@ export class SdIcon {
25
25
  }
26
26
  render() {
27
27
  const IconComponent = Icons[this.name]?.[this.size];
28
- return (h("i", { key: 'b727103f18fb77aeffa1e826154ca3cffbd9fd1b', class: this.getIconClasses(), style: this.iconStyle }, h(IconComponent, { key: '1993b16afde46ce507ed442c20d24179cbd079c7', color: this.resolvedColor })));
28
+ return (h("i", { key: 'c0d4a3993efc47345406ba9b30e49cefaa14f8da', class: this.getIconClasses(), style: this.iconStyle }, h(IconComponent, { key: '47476081ac11dd8ef1b04d9372d05f4afe72b323', color: this.resolvedColor })));
29
29
  }
30
30
  static get is() { return "sd-icon"; }
31
- static get encapsulation() { return "scoped"; }
32
31
  static get originalStyleUrls() {
33
32
  return {
34
33
  "$": ["sd-icon.scss"]
@@ -1 +1 @@
1
- {"version":3,"file":"sd-icon.js","sourceRoot":"","sources":["../../../src/components/sd-icon/sd-icon.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AACxC,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAOjD,MAAM,OAAO,MAAM;IAClB,WAAW;IACH,IAAI,CAAY;IAExB,aAAa;IACL,IAAI,GAAoB,EAAE,CAAC;IAEnC,aAAa;IACL,KAAK,CAAU;IAEvB,8BAA8B;IACtB,MAAM,CAAsB;IAEpC,iBAAiB;IACT,KAAK,CAAU;IAEf,SAAS,GAAe,EAAE,CAAC;IAE3B,cAAc;QACrB,MAAM,OAAO,GAAG,CAAC,SAAS,CAAC,CAAC;QAE5B,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YACjB,OAAO,CAAC,IAAI,CAAC,mBAAmB,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;QAChD,CAAC;QAED,OAAO,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC1B,CAAC;IAED,IAAY,aAAa;QACxB,OAAO,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAED,MAAM;QACL,MAAM,aAAa,GAAI,KAAa,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAE7D,OAAO,CACN,0DAAG,KAAK,EAAE,IAAI,CAAC,cAAc,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,SAAS;YACrD,EAAC,aAAa,qDAAC,KAAK,EAAE,IAAI,CAAC,aAAa,GAAI,CACzC,CACJ,CAAC;IACH,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACD","sourcesContent":["import { Component, Prop, h } from '@stencil/core';\r\nimport { Icons } from '../assets/index';\r\nimport { resolveColor } from '../../utils/color';\r\n\r\n@Component({\r\n tag: 'sd-icon',\r\n styleUrl: 'sd-icon.scss',\r\n scoped: true,\r\n})\r\nexport class SdIcon {\r\n /** 아이콘명 */\r\n @Prop() name!: IconName;\r\n\r\n /** 아이콘 크기 */\r\n @Prop() size: number | string = 12;\r\n\r\n /** 아이콘 색상 */\r\n @Prop() color?: string;\r\n\r\n /** 회전 각도 (0, 90, 180, 270) */\r\n @Prop() rotate?: 0 | 90 | 180 | 270;\r\n\r\n /** 접근성을 위한 라벨 */\r\n @Prop() label?: string;\r\n\r\n @Prop() iconStyle: StyleProps = {};\r\n\r\n private getIconClasses(): string {\r\n const classes = ['sd-icon'];\r\n\r\n if (this.rotate) {\r\n classes.push(`sd-icon--rotate-${this.rotate}`);\r\n }\r\n\r\n return classes.join(' ');\r\n }\r\n\r\n private get resolvedColor(): string {\r\n return resolveColor(this.color);\r\n }\r\n\r\n render() {\r\n const IconComponent = (Icons as any)[this.name]?.[this.size];\r\n\r\n return (\r\n <i class={this.getIconClasses()} style={this.iconStyle}>\r\n <IconComponent color={this.resolvedColor} />\r\n </i>\r\n );\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"sd-icon.js","sourceRoot":"","sources":["../../../src/components/sd-icon/sd-icon.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AACxC,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAMjD,MAAM,OAAO,MAAM;IAClB,WAAW;IACH,IAAI,CAAY;IAExB,aAAa;IACL,IAAI,GAAoB,EAAE,CAAC;IAEnC,aAAa;IACL,KAAK,CAAU;IAEvB,8BAA8B;IACtB,MAAM,CAAsB;IAEpC,iBAAiB;IACT,KAAK,CAAU;IAEf,SAAS,GAAe,EAAE,CAAC;IAE3B,cAAc;QACrB,MAAM,OAAO,GAAG,CAAC,SAAS,CAAC,CAAC;QAE5B,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YACjB,OAAO,CAAC,IAAI,CAAC,mBAAmB,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;QAChD,CAAC;QAED,OAAO,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC1B,CAAC;IAED,IAAY,aAAa;QACxB,OAAO,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAED,MAAM;QACL,MAAM,aAAa,GAAI,KAAa,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAE7D,OAAO,CACN,0DAAG,KAAK,EAAE,IAAI,CAAC,cAAc,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,SAAS;YACrD,EAAC,aAAa,qDAAC,KAAK,EAAE,IAAI,CAAC,aAAa,GAAI,CACzC,CACJ,CAAC;IACH,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACD","sourcesContent":["import { Component, Prop, h } from '@stencil/core';\r\nimport { Icons } from '../assets/index';\r\nimport { resolveColor } from '../../utils/color';\r\n\r\n@Component({\r\n tag: 'sd-icon',\r\n styleUrl: 'sd-icon.scss',\r\n})\r\nexport class SdIcon {\r\n /** 아이콘명 */\r\n @Prop() name!: IconName;\r\n\r\n /** 아이콘 크기 */\r\n @Prop() size: number | string = 12;\r\n\r\n /** 아이콘 색상 */\r\n @Prop() color?: string;\r\n\r\n /** 회전 각도 (0, 90, 180, 270) */\r\n @Prop() rotate?: 0 | 90 | 180 | 270;\r\n\r\n /** 접근성을 위한 라벨 */\r\n @Prop() label?: string;\r\n\r\n @Prop() iconStyle: StyleProps = {};\r\n\r\n private getIconClasses(): string {\r\n const classes = ['sd-icon'];\r\n\r\n if (this.rotate) {\r\n classes.push(`sd-icon--rotate-${this.rotate}`);\r\n }\r\n\r\n return classes.join(' ');\r\n }\r\n\r\n private get resolvedColor(): string {\r\n return resolveColor(this.color);\r\n }\r\n\r\n render() {\r\n const IconComponent = (Icons as any)[this.name]?.[this.size];\r\n\r\n return (\r\n <i class={this.getIconClasses()} style={this.iconStyle}>\r\n <IconComponent color={this.resolvedColor} />\r\n </i>\r\n );\r\n }\r\n}\r\n"]}
@@ -1,55 +1,3 @@
1
- /*
2
- Copyright (c) 2021 Kil Hyung-jin, with Reserved Font Name Pretendard.
3
- https://github.com/orioncactus/pretendard
4
-
5
- This Font Software is licensed under the SIL Open Font License, Version 1.1.
6
- This license is copied below, and is also available with a FAQ at:
7
- http://scripts.sil.org/OFL
8
- */
9
- @font-face {
10
- font-family: "Pretendard";
11
- font-weight: 800;
12
- font-display: swap;
13
- src: local("Pretendard-ExtraBold"), url("./fonts/Pretendard-ExtraBold.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-ExtraBold.ttf") format("truetype"); /* Safari, Android, iOS */
14
- }
15
- @font-face {
16
- font-family: "Pretendard";
17
- font-weight: 700;
18
- font-display: swap;
19
- src: local("Pretendard-Bold"), url("./fonts/Pretendard-Bold.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Bold.ttf") format("truetype"); /* Safari, Android, iOS */
20
- }
21
- @font-face {
22
- font-family: "Pretendard";
23
- font-weight: 600;
24
- font-display: swap;
25
- src: local("Pretendard-SemiBold"), url("./fonts/Pretendard-SemiBold.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-SemiBold.ttf") format("truetype"); /* Safari, Android, iOS */
26
- }
27
- @font-face {
28
- font-family: "Pretendard";
29
- font-weight: 500;
30
- font-display: swap;
31
- src: local("Pretendard-Medium"), url("./fonts/Pretendard-Medium.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Medium.ttf") format("truetype"); /* Safari, Android, iOS */
32
- }
33
- @font-face {
34
- font-family: "Pretendard";
35
- font-weight: 400;
36
- font-display: swap;
37
- src: local("Pretendard-Regular"), url("./fonts/Pretendard-Regular.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Regular.ttf") format("truetype"); /* Safari, Android, iOS */
38
- }
39
- @font-face {
40
- font-family: "Pretendard";
41
- font-weight: 300;
42
- font-display: swap;
43
- src: local("Pretendard-Light"), url("./fonts/Pretendard-Light.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Light.ttf") format("truetype"); /* Safari, Android, iOS */
44
- }
45
- :root {
46
- --font-family-base: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
47
- }
48
-
49
- html {
50
- font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
51
- }
52
-
53
1
  /* === Background Colors === */
54
2
  .bg-primary {
55
3
  background-color: var(--color-primary, #051d36);
@@ -1359,6 +1307,24 @@ textarea {
1359
1307
  cursor: pointer;
1360
1308
  }
1361
1309
 
1310
+ :host {
1311
+ line-height: 0;
1312
+ }
1313
+
1314
+ .sd-icon {
1315
+ line-height: 0;
1316
+ vertical-align: middle;
1317
+ }
1318
+ .sd-icon--rotate-90 {
1319
+ transform: rotate(90deg);
1320
+ }
1321
+ .sd-icon--rotate-180 {
1322
+ transform: rotate(180deg);
1323
+ }
1324
+ .sd-icon--rotate-270 {
1325
+ transform: rotate(270deg);
1326
+ }
1327
+
1362
1328
  .sd-input {
1363
1329
  display: flex;
1364
1330
  width: var(--input-width, 100%);
@@ -1414,4 +1380,8 @@ textarea {
1414
1380
  height: 20px;
1415
1381
  line-height: 20px;
1416
1382
  color: #aaaaaa;
1383
+ }
1384
+ .sd-input .sd-input__clear-icon {
1385
+ cursor: pointer;
1386
+ margin-left: 8px;
1417
1387
  }
@@ -93,7 +93,7 @@ export class SdInput {
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: '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: () => {
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: 'af486def3d146c4638d1f6fecf95a6de61e8d528', name: "close", color: "#888", class: "sd-input__clear-icon", onClick: () => {
97
97
  this.internalValue = '';
98
98
  this.sdChange?.emit(this.internalValue);
99
99
  this.sdInput?.emit(this.internalValue);
@@ -1 +1 @@
1
- {"version":3,"file":"sd-input.js","sourceRoot":"","sources":["../../../src/components/sd-input/sd-input.tsx"],"names":[],"mappings":"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","sourcesContent":["import {\r\n Component,\r\n Element,\r\n Host,\r\n Prop,\r\n State,\r\n Watch,\r\n Event,\r\n EventEmitter,\r\n h,\r\n Method,\r\n} from '@stencil/core';\r\n\r\n@Component({\r\n tag: 'sd-input',\r\n styleUrl: 'sd-input.scss',\r\n})\r\nexport class SdInput {\r\n @Element() el!: HTMLElement;\r\n\r\n @Prop({ mutable: true }) value?: string | number | null = null;\r\n @Prop() label?: string;\r\n @Prop() placeholder: string = '입력해 주세요.';\r\n @Prop() disabled: boolean = false;\r\n @Prop() clearable: boolean = false;\r\n @Prop() width?: number | string;\r\n @Prop() barcode?: boolean = false;\r\n @Prop() rules?: Array<(value: string | number | null) => boolean | string>;\r\n @Prop() autoFocus: boolean = false;\r\n @Prop() status?: 'default' | 'pass' | 'error';\r\n @Prop() inputClass: string = '';\r\n @Prop() readonly: boolean = false;\r\n\r\n // props - custom styles\r\n @Prop() inputStyle: { [key: string]: string } = {};\r\n\r\n @State() private internalValue: string | number | null = null;\r\n @State() private error: boolean = false;\r\n @State() private focused: boolean = false;\r\n @State() private hovered: boolean = false;\r\n\r\n private nativeEl: HTMLInputElement | undefined = undefined;\r\n\r\n @Event() sdClick?: EventEmitter<string | number | null>;\r\n @Event() sdInput?: EventEmitter<string | number | null>;\r\n @Event() sdChange?: EventEmitter<string | number | null>;\r\n @Event() sdFocus?: EventEmitter<Event>;\r\n @Event() sdBlur?: EventEmitter<Event>;\r\n\r\n @Watch('value')\r\n valueChanged(newValue: string | number | null) {\r\n this.internalValue = newValue;\r\n }\r\n\r\n @Watch('internalValue')\r\n internalValueChanged(newValue: string | number | null) {\r\n if (newValue !== this.value) {\r\n this.value = newValue;\r\n this.sdInput?.emit(this.value);\r\n }\r\n\r\n if (!this.rules || this.rules.length === 0) return;\r\n this.error = false;\r\n for (const rule of this.rules) {\r\n const result = rule(newValue);\r\n if (result !== true) {\r\n this.error = true;\r\n break;\r\n }\r\n }\r\n }\r\n\r\n @Method()\r\n async getNativeElement(): Promise<HTMLInputElement | null> {\r\n return this.nativeEl || null;\r\n }\r\n\r\n componentWillLoad() {\r\n if (this.value) {\r\n this.internalValue = this.value;\r\n }\r\n }\r\n\r\n private handleInput = (event: Event) => {\r\n const target = event.target as HTMLInputElement;\r\n this.internalValue = target.value;\r\n this.sdInput?.emit(this.internalValue);\r\n };\r\n\r\n private handleChange = (event: Event) => {\r\n const target = event.target as HTMLInputElement;\r\n this.internalValue = target.value;\r\n this.sdChange?.emit(this.internalValue);\r\n };\r\n\r\n private handleFocus = (type: 'focus' | 'blur', event: Event) => {\r\n this.focused = type === 'focus';\r\n\r\n if (type === 'blur') this.sdBlur?.emit(event);\r\n else this.sdFocus?.emit(event);\r\n };\r\n\r\n getInputStatus() {\r\n // input 상태 우선순위: hovered > focused > status(상태 주입) > error(rules 검사)\r\n if (this.disabled) return 'sd-input--disabled';\r\n if (this.hovered) return 'sd-input--hovered';\r\n if (this.focused) return 'sd-input--focused';\r\n if (this.status) return `sd-input--${this.status}`;\r\n if (this.error) return 'sd-input--error';\r\n return '';\r\n }\r\n\r\n render() {\r\n const inputWidth = this.width\r\n ? {\r\n '--input-width': typeof this.width === 'number' ? `${this.width}px` : this.width,\r\n }\r\n : {};\r\n\r\n return (\r\n <Host style={inputWidth}>\r\n {this.label && <div class=\"sd-input__label\">{this.label}</div>}\r\n <label\r\n class={{\r\n 'sd-input': true,\r\n [this.getInputStatus()]: true,\r\n 'sd-input--barcode': !!this.barcode,\r\n }}\r\n onMouseEnter={() => (this.hovered = true)}\r\n onMouseLeave={() => (this.hovered = false)}\r\n style={this.inputStyle}\r\n >\r\n <slot name=\"prefix\"></slot>\r\n <input\r\n ref={el => (this.nativeEl = el)}\r\n class={`sd-input__native_element ${this.inputClass}`}\r\n type=\"text\"\r\n value={this.internalValue || ''}\r\n placeholder={this.placeholder}\r\n disabled={this.disabled}\r\n readonly={this.readonly}\r\n autofocus={this.autoFocus}\r\n onInput={this.handleInput}\r\n onChange={this.handleChange}\r\n onFocus={event => this.handleFocus('focus', event)}\r\n onBlur={event => this.handleFocus('blur', event)}\r\n />\r\n <slot name=\"suffix\"></slot>\r\n {this.clearable && this.internalValue && (\r\n <sd-icon\r\n name=\"close\"\r\n color=\"#888\"\r\n style={{ marginRight: '-4px', marginLeft: '8px', cursor: 'pointer' }}\r\n onClick={() => {\r\n this.internalValue = '';\r\n this.sdChange?.emit(this.internalValue);\r\n this.sdInput?.emit(this.internalValue);\r\n }}\r\n />\r\n )}\r\n </label>\r\n </Host>\r\n );\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"sd-input.js","sourceRoot":"","sources":["../../../src/components/sd-input/sd-input.tsx"],"names":[],"mappings":"AAAA,OAAO,EACN,SAAS,EACT,OAAO,EACP,IAAI,EACJ,IAAI,EACJ,KAAK,EACL,KAAK,EACL,KAAK,EAEL,CAAC,EACD,MAAM,GACN,MAAM,eAAe,CAAC;AAMvB,MAAM,OAAO,OAAO;IACR,EAAE,CAAe;IAEH,KAAK,GAA4B,IAAI,CAAC;IACvD,KAAK,CAAU;IACf,WAAW,GAAW,UAAU,CAAC;IACjC,QAAQ,GAAY,KAAK,CAAC;IAC1B,SAAS,GAAY,KAAK,CAAC;IAC3B,KAAK,CAAmB;IACxB,OAAO,GAAa,KAAK,CAAC;IAC1B,KAAK,CAA8D;IACnE,SAAS,GAAY,KAAK,CAAC;IAC3B,MAAM,CAAgC;IACtC,UAAU,GAAW,EAAE,CAAC;IACxB,QAAQ,GAAY,KAAK,CAAC;IAElC,yBAAyB;IACjB,UAAU,GAA8B,EAAE,CAAC;IAElC,aAAa,GAA2B,IAAI,CAAC;IAC7C,KAAK,GAAY,KAAK,CAAC;IACvB,OAAO,GAAY,KAAK,CAAC;IACzB,OAAO,GAAY,KAAK,CAAC;IAElC,QAAQ,GAAiC,SAAS,CAAC;IAElD,OAAO,CAAwC;IAC/C,OAAO,CAAwC;IAC/C,QAAQ,CAAwC;IAChD,OAAO,CAAuB;IAC9B,MAAM,CAAuB;IAGtC,YAAY,CAAC,QAAgC;QAC5C,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC;IAC/B,CAAC;IAGD,oBAAoB,CAAC,QAAgC;QACpD,IAAI,QAAQ,KAAK,IAAI,CAAC,KAAK,EAAE,CAAC;YAC7B,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAC;YACtB,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAChC,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO;QACnD,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YAC/B,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC;YAC9B,IAAI,MAAM,KAAK,IAAI,EAAE,CAAC;gBACrB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;gBAClB,MAAM;YACP,CAAC;QACF,CAAC;IACF,CAAC;IAGD,KAAK,CAAC,gBAAgB;QACrB,OAAO,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC;IAC9B,CAAC;IAED,iBAAiB;QAChB,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YAChB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC;QACjC,CAAC;IACF,CAAC;IAEO,WAAW,GAAG,CAAC,KAAY,EAAE,EAAE;QACtC,MAAM,MAAM,GAAG,KAAK,CAAC,MAA0B,CAAC;QAChD,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,KAAK,CAAC;QAClC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IACxC,CAAC,CAAC;IAEM,YAAY,GAAG,CAAC,KAAY,EAAE,EAAE;QACvC,MAAM,MAAM,GAAG,KAAK,CAAC,MAA0B,CAAC;QAChD,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,KAAK,CAAC;QAClC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IACzC,CAAC,CAAC;IAEM,WAAW,GAAG,CAAC,IAAsB,EAAE,KAAY,EAAE,EAAE;QAC9D,IAAI,CAAC,OAAO,GAAG,IAAI,KAAK,OAAO,CAAC;QAEhC,IAAI,IAAI,KAAK,MAAM;YAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;;YACzC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC,CAAC;IAEF,cAAc;QACb,qEAAqE;QACrE,IAAI,IAAI,CAAC,QAAQ;YAAE,OAAO,oBAAoB,CAAC;QAC/C,IAAI,IAAI,CAAC,OAAO;YAAE,OAAO,mBAAmB,CAAC;QAC7C,IAAI,IAAI,CAAC,OAAO;YAAE,OAAO,mBAAmB,CAAC;QAC7C,IAAI,IAAI,CAAC,MAAM;YAAE,OAAO,aAAa,IAAI,CAAC,MAAM,EAAE,CAAC;QACnD,IAAI,IAAI,CAAC,KAAK;YAAE,OAAO,iBAAiB,CAAC;QACzC,OAAO,EAAE,CAAC;IACX,CAAC;IAED,MAAM;QACL,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK;YAC5B,CAAC,CAAC;gBACC,eAAe,EAAE,OAAO,IAAI,CAAC,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK;aAChF;YACH,CAAC,CAAC,EAAE,CAAC;QAEN,OAAO,CACN,EAAC,IAAI,qDAAC,KAAK,EAAE,UAAU;YACrB,IAAI,CAAC,KAAK,IAAI,4DAAK,KAAK,EAAC,iBAAiB,IAAE,IAAI,CAAC,KAAK,CAAO;YAC9D,8DACC,KAAK,EAAE;oBACN,UAAU,EAAE,IAAI;oBAChB,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,EAAE,IAAI;oBAC7B,mBAAmB,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO;iBACnC,EACD,YAAY,EAAE,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,EACzC,YAAY,EAAE,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,EAC1C,KAAK,EAAE,IAAI,CAAC,UAAU;gBAEtB,6DAAM,IAAI,EAAC,QAAQ,GAAQ;gBAC3B,8DACC,GAAG,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC,EAC/B,KAAK,EAAE,4BAA4B,IAAI,CAAC,UAAU,EAAE,EACpD,IAAI,EAAC,MAAM,EACX,KAAK,EAAE,IAAI,CAAC,aAAa,IAAI,EAAE,EAC/B,WAAW,EAAE,IAAI,CAAC,WAAW,EAC7B,QAAQ,EAAE,IAAI,CAAC,QAAQ,EACvB,QAAQ,EAAE,IAAI,CAAC,QAAQ,EACvB,SAAS,EAAE,IAAI,CAAC,SAAS,EACzB,OAAO,EAAE,IAAI,CAAC,WAAW,EACzB,QAAQ,EAAE,IAAI,CAAC,YAAY,EAC3B,OAAO,EAAE,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,KAAK,CAAC,EAClD,MAAM,EAAE,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,KAAK,CAAC,GAC/C;gBACF,6DAAM,IAAI,EAAC,QAAQ,GAAQ;gBAC1B,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,aAAa,IAAI,CACxC,gEACC,IAAI,EAAC,OAAO,EACZ,KAAK,EAAC,MAAM,EACZ,KAAK,EAAC,sBAAsB,EAC5B,OAAO,EAAE,GAAG,EAAE;wBACb,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;wBACxB,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;wBACxC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;oBACxC,CAAC,GACA,CACF,CACM,CACF,CACP,CAAC;IACH,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACD","sourcesContent":["import {\r\n Component,\r\n Element,\r\n Host,\r\n Prop,\r\n State,\r\n Watch,\r\n Event,\r\n EventEmitter,\r\n h,\r\n Method,\r\n} from '@stencil/core';\r\n\r\n@Component({\r\n tag: 'sd-input',\r\n styleUrl: 'sd-input.scss',\r\n})\r\nexport class SdInput {\r\n @Element() el!: HTMLElement;\r\n\r\n @Prop({ mutable: true }) value?: string | number | null = null;\r\n @Prop() label?: string;\r\n @Prop() placeholder: string = '입력해 주세요.';\r\n @Prop() disabled: boolean = false;\r\n @Prop() clearable: boolean = false;\r\n @Prop() width?: number | string;\r\n @Prop() barcode?: boolean = false;\r\n @Prop() rules?: Array<(value: string | number | null) => boolean | string>;\r\n @Prop() autoFocus: boolean = false;\r\n @Prop() status?: 'default' | 'pass' | 'error';\r\n @Prop() inputClass: string = '';\r\n @Prop() readonly: boolean = false;\r\n\r\n // props - custom styles\r\n @Prop() inputStyle: { [key: string]: string } = {};\r\n\r\n @State() private internalValue: string | number | null = null;\r\n @State() private error: boolean = false;\r\n @State() private focused: boolean = false;\r\n @State() private hovered: boolean = false;\r\n\r\n private nativeEl: HTMLInputElement | undefined = undefined;\r\n\r\n @Event() sdClick?: EventEmitter<string | number | null>;\r\n @Event() sdInput?: EventEmitter<string | number | null>;\r\n @Event() sdChange?: EventEmitter<string | number | null>;\r\n @Event() sdFocus?: EventEmitter<Event>;\r\n @Event() sdBlur?: EventEmitter<Event>;\r\n\r\n @Watch('value')\r\n valueChanged(newValue: string | number | null) {\r\n this.internalValue = newValue;\r\n }\r\n\r\n @Watch('internalValue')\r\n internalValueChanged(newValue: string | number | null) {\r\n if (newValue !== this.value) {\r\n this.value = newValue;\r\n this.sdInput?.emit(this.value);\r\n }\r\n\r\n if (!this.rules || this.rules.length === 0) return;\r\n this.error = false;\r\n for (const rule of this.rules) {\r\n const result = rule(newValue);\r\n if (result !== true) {\r\n this.error = true;\r\n break;\r\n }\r\n }\r\n }\r\n\r\n @Method()\r\n async getNativeElement(): Promise<HTMLInputElement | null> {\r\n return this.nativeEl || null;\r\n }\r\n\r\n componentWillLoad() {\r\n if (this.value) {\r\n this.internalValue = this.value;\r\n }\r\n }\r\n\r\n private handleInput = (event: Event) => {\r\n const target = event.target as HTMLInputElement;\r\n this.internalValue = target.value;\r\n this.sdInput?.emit(this.internalValue);\r\n };\r\n\r\n private handleChange = (event: Event) => {\r\n const target = event.target as HTMLInputElement;\r\n this.internalValue = target.value;\r\n this.sdChange?.emit(this.internalValue);\r\n };\r\n\r\n private handleFocus = (type: 'focus' | 'blur', event: Event) => {\r\n this.focused = type === 'focus';\r\n\r\n if (type === 'blur') this.sdBlur?.emit(event);\r\n else this.sdFocus?.emit(event);\r\n };\r\n\r\n getInputStatus() {\r\n // input 상태 우선순위: hovered > focused > status(상태 주입) > error(rules 검사)\r\n if (this.disabled) return 'sd-input--disabled';\r\n if (this.hovered) return 'sd-input--hovered';\r\n if (this.focused) return 'sd-input--focused';\r\n if (this.status) return `sd-input--${this.status}`;\r\n if (this.error) return 'sd-input--error';\r\n return '';\r\n }\r\n\r\n render() {\r\n const inputWidth = this.width\r\n ? {\r\n '--input-width': typeof this.width === 'number' ? `${this.width}px` : this.width,\r\n }\r\n : {};\r\n\r\n return (\r\n <Host style={inputWidth}>\r\n {this.label && <div class=\"sd-input__label\">{this.label}</div>}\r\n <label\r\n class={{\r\n 'sd-input': true,\r\n [this.getInputStatus()]: true,\r\n 'sd-input--barcode': !!this.barcode,\r\n }}\r\n onMouseEnter={() => (this.hovered = true)}\r\n onMouseLeave={() => (this.hovered = false)}\r\n style={this.inputStyle}\r\n >\r\n <slot name=\"prefix\"></slot>\r\n <input\r\n ref={el => (this.nativeEl = el)}\r\n class={`sd-input__native_element ${this.inputClass}`}\r\n type=\"text\"\r\n value={this.internalValue || ''}\r\n placeholder={this.placeholder}\r\n disabled={this.disabled}\r\n readonly={this.readonly}\r\n autofocus={this.autoFocus}\r\n onInput={this.handleInput}\r\n onChange={this.handleChange}\r\n onFocus={event => this.handleFocus('focus', event)}\r\n onBlur={event => this.handleFocus('blur', event)}\r\n />\r\n <slot name=\"suffix\"></slot>\r\n {this.clearable && this.internalValue && (\r\n <sd-icon\r\n name=\"close\"\r\n color=\"#888\"\r\n class=\"sd-input__clear-icon\"\r\n onClick={() => {\r\n this.internalValue = '';\r\n this.sdChange?.emit(this.internalValue);\r\n this.sdInput?.emit(this.internalValue);\r\n }}\r\n />\r\n )}\r\n </label>\r\n </Host>\r\n );\r\n }\r\n}\r\n"]}
@@ -1,55 +1,3 @@
1
- /*
2
- Copyright (c) 2021 Kil Hyung-jin, with Reserved Font Name Pretendard.
3
- https://github.com/orioncactus/pretendard
4
-
5
- This Font Software is licensed under the SIL Open Font License, Version 1.1.
6
- This license is copied below, and is also available with a FAQ at:
7
- http://scripts.sil.org/OFL
8
- */
9
- @font-face {
10
- font-family: "Pretendard";
11
- font-weight: 800;
12
- font-display: swap;
13
- src: local("Pretendard-ExtraBold"), url("./fonts/Pretendard-ExtraBold.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-ExtraBold.ttf") format("truetype"); /* Safari, Android, iOS */
14
- }
15
- @font-face {
16
- font-family: "Pretendard";
17
- font-weight: 700;
18
- font-display: swap;
19
- src: local("Pretendard-Bold"), url("./fonts/Pretendard-Bold.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Bold.ttf") format("truetype"); /* Safari, Android, iOS */
20
- }
21
- @font-face {
22
- font-family: "Pretendard";
23
- font-weight: 600;
24
- font-display: swap;
25
- src: local("Pretendard-SemiBold"), url("./fonts/Pretendard-SemiBold.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-SemiBold.ttf") format("truetype"); /* Safari, Android, iOS */
26
- }
27
- @font-face {
28
- font-family: "Pretendard";
29
- font-weight: 500;
30
- font-display: swap;
31
- src: local("Pretendard-Medium"), url("./fonts/Pretendard-Medium.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Medium.ttf") format("truetype"); /* Safari, Android, iOS */
32
- }
33
- @font-face {
34
- font-family: "Pretendard";
35
- font-weight: 400;
36
- font-display: swap;
37
- src: local("Pretendard-Regular"), url("./fonts/Pretendard-Regular.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Regular.ttf") format("truetype"); /* Safari, Android, iOS */
38
- }
39
- @font-face {
40
- font-family: "Pretendard";
41
- font-weight: 300;
42
- font-display: swap;
43
- src: local("Pretendard-Light"), url("./fonts/Pretendard-Light.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Light.ttf") format("truetype"); /* Safari, Android, iOS */
44
- }
45
- :root {
46
- --font-family-base: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
47
- }
48
-
49
- html {
50
- font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
51
- }
52
-
53
1
  /* === Background Colors === */
54
2
  .bg-primary {
55
3
  background-color: var(--color-primary, #051d36);
@@ -1,55 +1,3 @@
1
- /*
2
- Copyright (c) 2021 Kil Hyung-jin, with Reserved Font Name Pretendard.
3
- https://github.com/orioncactus/pretendard
4
-
5
- This Font Software is licensed under the SIL Open Font License, Version 1.1.
6
- This license is copied below, and is also available with a FAQ at:
7
- http://scripts.sil.org/OFL
8
- */
9
- @font-face {
10
- font-family: "Pretendard";
11
- font-weight: 800;
12
- font-display: swap;
13
- src: local("Pretendard-ExtraBold"), url("./fonts/Pretendard-ExtraBold.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-ExtraBold.ttf") format("truetype"); /* Safari, Android, iOS */
14
- }
15
- @font-face {
16
- font-family: "Pretendard";
17
- font-weight: 700;
18
- font-display: swap;
19
- src: local("Pretendard-Bold"), url("./fonts/Pretendard-Bold.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Bold.ttf") format("truetype"); /* Safari, Android, iOS */
20
- }
21
- @font-face {
22
- font-family: "Pretendard";
23
- font-weight: 600;
24
- font-display: swap;
25
- src: local("Pretendard-SemiBold"), url("./fonts/Pretendard-SemiBold.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-SemiBold.ttf") format("truetype"); /* Safari, Android, iOS */
26
- }
27
- @font-face {
28
- font-family: "Pretendard";
29
- font-weight: 500;
30
- font-display: swap;
31
- src: local("Pretendard-Medium"), url("./fonts/Pretendard-Medium.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Medium.ttf") format("truetype"); /* Safari, Android, iOS */
32
- }
33
- @font-face {
34
- font-family: "Pretendard";
35
- font-weight: 400;
36
- font-display: swap;
37
- src: local("Pretendard-Regular"), url("./fonts/Pretendard-Regular.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Regular.ttf") format("truetype"); /* Safari, Android, iOS */
38
- }
39
- @font-face {
40
- font-family: "Pretendard";
41
- font-weight: 300;
42
- font-display: swap;
43
- src: local("Pretendard-Light"), url("./fonts/Pretendard-Light.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Light.ttf") format("truetype"); /* Safari, Android, iOS */
44
- }
45
- :root {
46
- --font-family-base: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
47
- }
48
-
49
- html {
50
- font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
51
- }
52
-
53
1
  /* === Background Colors === */
54
2
  .bg-primary {
55
3
  background-color: var(--color-primary, #051d36);
@@ -1,55 +1,3 @@
1
- /*
2
- Copyright (c) 2021 Kil Hyung-jin, with Reserved Font Name Pretendard.
3
- https://github.com/orioncactus/pretendard
4
-
5
- This Font Software is licensed under the SIL Open Font License, Version 1.1.
6
- This license is copied below, and is also available with a FAQ at:
7
- http://scripts.sil.org/OFL
8
- */
9
- @font-face {
10
- font-family: "Pretendard";
11
- font-weight: 800;
12
- font-display: swap;
13
- src: local("Pretendard-ExtraBold"), url("./fonts/Pretendard-ExtraBold.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-ExtraBold.ttf") format("truetype"); /* Safari, Android, iOS */
14
- }
15
- @font-face {
16
- font-family: "Pretendard";
17
- font-weight: 700;
18
- font-display: swap;
19
- src: local("Pretendard-Bold"), url("./fonts/Pretendard-Bold.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Bold.ttf") format("truetype"); /* Safari, Android, iOS */
20
- }
21
- @font-face {
22
- font-family: "Pretendard";
23
- font-weight: 600;
24
- font-display: swap;
25
- src: local("Pretendard-SemiBold"), url("./fonts/Pretendard-SemiBold.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-SemiBold.ttf") format("truetype"); /* Safari, Android, iOS */
26
- }
27
- @font-face {
28
- font-family: "Pretendard";
29
- font-weight: 500;
30
- font-display: swap;
31
- src: local("Pretendard-Medium"), url("./fonts/Pretendard-Medium.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Medium.ttf") format("truetype"); /* Safari, Android, iOS */
32
- }
33
- @font-face {
34
- font-family: "Pretendard";
35
- font-weight: 400;
36
- font-display: swap;
37
- src: local("Pretendard-Regular"), url("./fonts/Pretendard-Regular.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Regular.ttf") format("truetype"); /* Safari, Android, iOS */
38
- }
39
- @font-face {
40
- font-family: "Pretendard";
41
- font-weight: 300;
42
- font-display: swap;
43
- src: local("Pretendard-Light"), url("./fonts/Pretendard-Light.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Light.ttf") format("truetype"); /* Safari, Android, iOS */
44
- }
45
- :root {
46
- --font-family-base: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
47
- }
48
-
49
- html {
50
- font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
51
- }
52
-
53
1
  /* === Background Colors === */
54
2
  .bg-primary {
55
3
  background-color: var(--color-primary, #051d36);
@@ -1,55 +1,3 @@
1
- /*
2
- Copyright (c) 2021 Kil Hyung-jin, with Reserved Font Name Pretendard.
3
- https://github.com/orioncactus/pretendard
4
-
5
- This Font Software is licensed under the SIL Open Font License, Version 1.1.
6
- This license is copied below, and is also available with a FAQ at:
7
- http://scripts.sil.org/OFL
8
- */
9
- @font-face {
10
- font-family: "Pretendard";
11
- font-weight: 800;
12
- font-display: swap;
13
- src: local("Pretendard-ExtraBold"), url("./fonts/Pretendard-ExtraBold.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-ExtraBold.ttf") format("truetype"); /* Safari, Android, iOS */
14
- }
15
- @font-face {
16
- font-family: "Pretendard";
17
- font-weight: 700;
18
- font-display: swap;
19
- src: local("Pretendard-Bold"), url("./fonts/Pretendard-Bold.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Bold.ttf") format("truetype"); /* Safari, Android, iOS */
20
- }
21
- @font-face {
22
- font-family: "Pretendard";
23
- font-weight: 600;
24
- font-display: swap;
25
- src: local("Pretendard-SemiBold"), url("./fonts/Pretendard-SemiBold.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-SemiBold.ttf") format("truetype"); /* Safari, Android, iOS */
26
- }
27
- @font-face {
28
- font-family: "Pretendard";
29
- font-weight: 500;
30
- font-display: swap;
31
- src: local("Pretendard-Medium"), url("./fonts/Pretendard-Medium.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Medium.ttf") format("truetype"); /* Safari, Android, iOS */
32
- }
33
- @font-face {
34
- font-family: "Pretendard";
35
- font-weight: 400;
36
- font-display: swap;
37
- src: local("Pretendard-Regular"), url("./fonts/Pretendard-Regular.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Regular.ttf") format("truetype"); /* Safari, Android, iOS */
38
- }
39
- @font-face {
40
- font-family: "Pretendard";
41
- font-weight: 300;
42
- font-display: swap;
43
- src: local("Pretendard-Light"), url("./fonts/Pretendard-Light.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Light.ttf") format("truetype"); /* Safari, Android, iOS */
44
- }
45
- :root {
46
- --font-family-base: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
47
- }
48
-
49
- html {
50
- font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
51
- }
52
-
53
1
  /* === Background Colors === */
54
2
  .bg-primary {
55
3
  background-color: var(--color-primary, #051d36);
@@ -1,55 +1,3 @@
1
- /*
2
- Copyright (c) 2021 Kil Hyung-jin, with Reserved Font Name Pretendard.
3
- https://github.com/orioncactus/pretendard
4
-
5
- This Font Software is licensed under the SIL Open Font License, Version 1.1.
6
- This license is copied below, and is also available with a FAQ at:
7
- http://scripts.sil.org/OFL
8
- */
9
- @font-face {
10
- font-family: "Pretendard";
11
- font-weight: 800;
12
- font-display: swap;
13
- src: local("Pretendard-ExtraBold"), url("./fonts/Pretendard-ExtraBold.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-ExtraBold.ttf") format("truetype"); /* Safari, Android, iOS */
14
- }
15
- @font-face {
16
- font-family: "Pretendard";
17
- font-weight: 700;
18
- font-display: swap;
19
- src: local("Pretendard-Bold"), url("./fonts/Pretendard-Bold.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Bold.ttf") format("truetype"); /* Safari, Android, iOS */
20
- }
21
- @font-face {
22
- font-family: "Pretendard";
23
- font-weight: 600;
24
- font-display: swap;
25
- src: local("Pretendard-SemiBold"), url("./fonts/Pretendard-SemiBold.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-SemiBold.ttf") format("truetype"); /* Safari, Android, iOS */
26
- }
27
- @font-face {
28
- font-family: "Pretendard";
29
- font-weight: 500;
30
- font-display: swap;
31
- src: local("Pretendard-Medium"), url("./fonts/Pretendard-Medium.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Medium.ttf") format("truetype"); /* Safari, Android, iOS */
32
- }
33
- @font-face {
34
- font-family: "Pretendard";
35
- font-weight: 400;
36
- font-display: swap;
37
- src: local("Pretendard-Regular"), url("./fonts/Pretendard-Regular.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Regular.ttf") format("truetype"); /* Safari, Android, iOS */
38
- }
39
- @font-face {
40
- font-family: "Pretendard";
41
- font-weight: 300;
42
- font-display: swap;
43
- src: local("Pretendard-Light"), url("./fonts/Pretendard-Light.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Light.ttf") format("truetype"); /* Safari, Android, iOS */
44
- }
45
- :root {
46
- --font-family-base: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
47
- }
48
-
49
- html {
50
- font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
51
- }
52
-
53
1
  /* === Background Colors === */
54
2
  .bg-primary {
55
3
  background-color: var(--color-primary, #051d36);
@@ -1,55 +1,3 @@
1
- /*
2
- Copyright (c) 2021 Kil Hyung-jin, with Reserved Font Name Pretendard.
3
- https://github.com/orioncactus/pretendard
4
-
5
- This Font Software is licensed under the SIL Open Font License, Version 1.1.
6
- This license is copied below, and is also available with a FAQ at:
7
- http://scripts.sil.org/OFL
8
- */
9
- @font-face {
10
- font-family: "Pretendard";
11
- font-weight: 800;
12
- font-display: swap;
13
- src: local("Pretendard-ExtraBold"), url("./fonts/Pretendard-ExtraBold.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-ExtraBold.ttf") format("truetype"); /* Safari, Android, iOS */
14
- }
15
- @font-face {
16
- font-family: "Pretendard";
17
- font-weight: 700;
18
- font-display: swap;
19
- src: local("Pretendard-Bold"), url("./fonts/Pretendard-Bold.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Bold.ttf") format("truetype"); /* Safari, Android, iOS */
20
- }
21
- @font-face {
22
- font-family: "Pretendard";
23
- font-weight: 600;
24
- font-display: swap;
25
- src: local("Pretendard-SemiBold"), url("./fonts/Pretendard-SemiBold.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-SemiBold.ttf") format("truetype"); /* Safari, Android, iOS */
26
- }
27
- @font-face {
28
- font-family: "Pretendard";
29
- font-weight: 500;
30
- font-display: swap;
31
- src: local("Pretendard-Medium"), url("./fonts/Pretendard-Medium.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Medium.ttf") format("truetype"); /* Safari, Android, iOS */
32
- }
33
- @font-face {
34
- font-family: "Pretendard";
35
- font-weight: 400;
36
- font-display: swap;
37
- src: local("Pretendard-Regular"), url("./fonts/Pretendard-Regular.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Regular.ttf") format("truetype"); /* Safari, Android, iOS */
38
- }
39
- @font-face {
40
- font-family: "Pretendard";
41
- font-weight: 300;
42
- font-display: swap;
43
- src: local("Pretendard-Light"), url("./fonts/Pretendard-Light.subset.woff2") format("font-woff2"), url("./fonts/Pretendard-Light.ttf") format("truetype"); /* Safari, Android, iOS */
44
- }
45
- :root {
46
- --font-family-base: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
47
- }
48
-
49
- html {
50
- font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
51
- }
52
-
53
1
  /* === Background Colors === */
54
2
  .bg-primary {
55
3
  background-color: var(--color-primary, #051d36);