@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.
- package/dist/cjs/design-system.cjs.js +1 -1
- package/dist/cjs/loader.cjs.js +1 -1
- package/dist/cjs/sd-badge.cjs.entry.js +1 -1
- package/dist/cjs/sd-button.sd-tooltip-portal.entry.cjs.js.map +1 -1
- package/dist/cjs/sd-button_2.cjs.entry.js +6 -5
- package/dist/cjs/sd-card.cjs.entry.js +20 -0
- package/dist/cjs/sd-card.entry.cjs.js.map +1 -0
- 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
- package/dist/cjs/sd-checkbox_9.cjs.entry.js +59 -32
- package/dist/cjs/sd-date-box.cjs.entry.js +2 -2
- package/dist/cjs/sd-date-picker.cjs.entry.js +2 -2
- package/dist/cjs/sd-date-range-picker.cjs.entry.js +2 -2
- package/dist/cjs/sd-guide.cjs.entry.js +65 -53
- package/dist/cjs/sd-guide.entry.cjs.js.map +1 -1
- package/dist/cjs/sd-pagination_2.cjs.entry.js +4 -4
- package/dist/cjs/sd-popover.cjs.entry.js +2 -2
- package/dist/cjs/sd-table.cjs.entry.js +4 -4
- package/dist/cjs/sd-table.entry.cjs.js.map +1 -1
- package/dist/cjs/sd-tag.cjs.entry.js +1 -1
- package/dist/collection/collection-manifest.json +2 -1
- package/dist/collection/components/assets/index.js +2 -0
- package/dist/collection/components/assets/index.js.map +1 -1
- package/dist/collection/components/assets/minus/Minus12.js +3 -0
- package/dist/collection/components/assets/minus/Minus12.js.map +1 -0
- package/dist/collection/components/assets/minus/index.js +5 -0
- package/dist/collection/components/assets/minus/index.js.map +1 -0
- package/dist/collection/components/sd-badge/sd-badge.js +1 -1
- package/dist/collection/components/sd-button/sd-button.css +1 -1
- package/dist/collection/components/sd-button/sd-button.js +14 -39
- package/dist/collection/components/sd-button/sd-button.js.map +1 -1
- package/dist/collection/components/sd-card/sd-card.css +1372 -0
- package/dist/collection/components/sd-card/sd-card.js +64 -0
- package/dist/collection/components/sd-card/sd-card.js.map +1 -0
- package/dist/collection/components/sd-checkbox/sd-checkbox.css +1370 -6
- package/dist/collection/components/sd-checkbox/sd-checkbox.js +35 -40
- package/dist/collection/components/sd-checkbox/sd-checkbox.js.map +1 -1
- package/dist/collection/components/sd-date-box/sd-date-box.js +2 -2
- package/dist/collection/components/sd-date-picker/sd-date-picker.js +2 -2
- package/dist/collection/components/sd-date-range-picker/sd-date-range-picker.js +2 -2
- package/dist/collection/components/sd-guide/sd-guide.css +8 -0
- package/dist/collection/components/sd-guide/sd-guide.js +66 -54
- package/dist/collection/components/sd-guide/sd-guide.js.map +1 -1
- package/dist/collection/components/sd-icon/sd-icon.js +2 -2
- package/dist/collection/components/sd-input/sd-input.js +2 -2
- package/dist/collection/components/sd-pagination/sd-pagination.js +2 -2
- package/dist/collection/components/sd-popover/sd-popover.js +3 -3
- package/dist/collection/components/sd-portal/sd-portal.js +1 -1
- package/dist/collection/components/sd-select/sd-select-option/sd-select-option.css +1 -0
- package/dist/collection/components/sd-select/sd-select-option/sd-select-option.js +10 -6
- package/dist/collection/components/sd-select/sd-select-option/sd-select-option.js.map +1 -1
- package/dist/collection/components/sd-select/sd-select.css +2 -0
- package/dist/collection/components/sd-select/sd-select.js +2 -2
- package/dist/collection/components/sd-select-multiple/sd-select-multiple.js +2 -2
- package/dist/collection/components/sd-select-multiple-group/sd-select-multiple-group.js +2 -2
- package/dist/collection/components/sd-select-multiple-group/sd-select-option-group/sd-select-option-group.js +10 -6
- package/dist/collection/components/sd-select-multiple-group/sd-select-option-group/sd-select-option-group.js.map +1 -1
- package/dist/collection/components/sd-table/sd-table.js +8 -10
- package/dist/collection/components/sd-table/sd-table.js.map +1 -1
- package/dist/collection/components/sd-tag/sd-tag.js +1 -1
- package/dist/collection/components/sd-tooltip/sd-tooltip.js +3 -3
- package/dist/collection/components/sd-tooltip-portal/sd-tooltip-portal.js +1 -1
- package/dist/components/p-1jmdnu3I.js +118 -0
- package/dist/components/p-1jmdnu3I.js.map +1 -0
- package/dist/components/{p-tyC8W4sw.js → p-7xizrxZ5.js} +9 -9
- package/dist/components/p-7xizrxZ5.js.map +1 -0
- package/dist/components/{p-Cw2pw4LC.js → p-B1kMis4e.js} +7 -7
- package/dist/components/{p-Cw2pw4LC.js.map → p-B1kMis4e.js.map} +1 -1
- package/dist/components/{p-DVFPBdfj.js → p-BOsnXzkr.js} +15 -3
- package/dist/components/p-BOsnXzkr.js.map +1 -0
- package/dist/components/{p-BBm_kUA7.js → p-BTSN9ENi.js} +5 -5
- package/dist/components/{p-BBm_kUA7.js.map → p-BTSN9ENi.js.map} +1 -1
- package/dist/components/{p-DfkKMnWF.js → p-B_s4RQWY.js} +15 -11
- package/dist/components/p-B_s4RQWY.js.map +1 -0
- package/dist/components/{p-BQR8GTeD.js → p-D_m-rDEx.js} +4 -4
- package/dist/components/{p-BQR8GTeD.js.map → p-D_m-rDEx.js.map} +1 -1
- package/dist/components/{p-Cf4fh47I.js → p-UtZuVoJ9.js} +14 -10
- package/dist/components/p-UtZuVoJ9.js.map +1 -0
- package/dist/components/{p-BqCRj-SM.js → p-az-fZTqo.js} +3 -3
- package/dist/components/{p-BqCRj-SM.js.map → p-az-fZTqo.js.map} +1 -1
- package/dist/components/{p-D0hPGqjM.js → p-x0iTdFk8.js} +5 -5
- package/dist/components/{p-D0hPGqjM.js.map → p-x0iTdFk8.js.map} +1 -1
- package/dist/components/{p-D267VRcj.js → p-yJmTynI0.js} +3 -3
- package/dist/components/{p-D267VRcj.js.map → p-yJmTynI0.js.map} +1 -1
- package/dist/components/sd-badge.js +1 -1
- package/dist/components/sd-button.js +1 -1
- package/dist/components/sd-card.d.ts +11 -0
- package/dist/components/sd-card.js +42 -0
- package/dist/components/sd-card.js.map +1 -0
- package/dist/components/sd-checkbox.js +1 -1
- package/dist/components/sd-date-box.js +1 -1
- package/dist/components/sd-date-picker.js +6 -6
- package/dist/components/sd-date-range-picker.js +6 -6
- package/dist/components/sd-guide.js +69 -57
- package/dist/components/sd-guide.js.map +1 -1
- package/dist/components/sd-icon.js +1 -1
- package/dist/components/sd-input.js +1 -1
- package/dist/components/sd-pagination.js +1 -1
- package/dist/components/sd-popover.js +5 -5
- package/dist/components/sd-portal.js +1 -1
- package/dist/components/sd-select-multiple-group.js +7 -7
- package/dist/components/sd-select-multiple.js +7 -7
- package/dist/components/sd-select-option-group.js +1 -1
- package/dist/components/sd-select-option.js +1 -1
- package/dist/components/sd-select.js +8 -8
- package/dist/components/sd-select.js.map +1 -1
- package/dist/components/sd-table.js +10 -10
- package/dist/components/sd-table.js.map +1 -1
- package/dist/components/sd-tag.js +1 -1
- package/dist/components/sd-tooltip-portal.js +1 -1
- package/dist/components/sd-tooltip.js +1 -1
- package/dist/design-system/design-system.esm.js +1 -1
- package/dist/design-system/{p-ab46652a.entry.js → p-240de5df.entry.js} +2 -2
- package/dist/design-system/p-2e519819.entry.js +2 -0
- package/dist/design-system/p-2e519819.entry.js.map +1 -0
- package/dist/design-system/{p-a7ef9b22.entry.js → p-4eaf6262.entry.js} +2 -2
- package/dist/design-system/p-5f6c69ed.entry.js +2 -0
- package/dist/design-system/p-5f6c69ed.entry.js.map +1 -0
- package/dist/design-system/{p-7ae03d45.entry.js → p-62c12ab7.entry.js} +2 -2
- package/dist/design-system/p-62c12ab7.entry.js.map +1 -0
- package/dist/design-system/{p-b5abb919.entry.js → p-71716c18.entry.js} +2 -2
- package/dist/design-system/{p-70a394fe.entry.js → p-87da8d28.entry.js} +2 -2
- package/dist/design-system/p-87da8d28.entry.js.map +1 -0
- package/dist/design-system/{p-cdaa51d7.entry.js → p-ac9a20b4.entry.js} +2 -2
- package/dist/design-system/p-ac9a20b4.entry.js.map +1 -0
- package/dist/design-system/{p-131f639a.entry.js → p-b037ea76.entry.js} +2 -2
- package/dist/design-system/{p-0529b7d6.entry.js → p-b4e3145a.entry.js} +2 -2
- package/dist/design-system/{p-02d30a1b.entry.js → p-bd9e799c.entry.js} +2 -2
- package/dist/design-system/{p-52454cc4.entry.js → p-d185bd2e.entry.js} +2 -2
- package/dist/design-system/sd-button.sd-tooltip-portal.entry.esm.js.map +1 -1
- package/dist/design-system/sd-card.entry.esm.js.map +1 -0
- 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
- package/dist/design-system/sd-guide.entry.esm.js.map +1 -1
- package/dist/design-system/sd-table.entry.esm.js.map +1 -1
- package/dist/esm/design-system.js +1 -1
- package/dist/esm/loader.js +1 -1
- package/dist/esm/sd-badge.entry.js +1 -1
- package/dist/esm/sd-button.sd-tooltip-portal.entry.js.map +1 -1
- package/dist/esm/sd-button_2.entry.js +6 -5
- package/dist/esm/sd-card.entry.js +18 -0
- package/dist/esm/sd-card.entry.js.map +1 -0
- 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
- package/dist/esm/sd-checkbox_9.entry.js +59 -32
- package/dist/esm/sd-date-box.entry.js +2 -2
- package/dist/esm/sd-date-picker.entry.js +2 -2
- package/dist/esm/sd-date-range-picker.entry.js +2 -2
- package/dist/esm/sd-guide.entry.js +65 -53
- package/dist/esm/sd-guide.entry.js.map +1 -1
- package/dist/esm/sd-pagination_2.entry.js +4 -4
- package/dist/esm/sd-popover.entry.js +2 -2
- package/dist/esm/sd-table.entry.js +4 -4
- package/dist/esm/sd-table.entry.js.map +1 -1
- package/dist/esm/sd-tag.entry.js +1 -1
- package/dist/types/components/assets/index.d.ts +3 -0
- package/dist/types/components/assets/minus/Minus12.d.ts +1 -0
- package/dist/types/components/assets/minus/index.d.ts +3 -0
- package/dist/types/components/sd-button/sd-button.d.ts +1 -2
- package/dist/types/components/sd-card/sd-card.d.ts +5 -0
- package/dist/types/components/sd-checkbox/sd-checkbox.d.ts +6 -5
- package/dist/types/components/sd-guide/sd-guide.d.ts +2 -11
- package/dist/types/components.d.ts +43 -42
- package/hydrate/index.js +177 -113
- package/hydrate/index.mjs +177 -113
- package/package.json +2 -2
- package/dist/components/p-Cf4fh47I.js.map +0 -1
- package/dist/components/p-CuDrOaaO.js +0 -112
- package/dist/components/p-CuDrOaaO.js.map +0 -1
- package/dist/components/p-DVFPBdfj.js.map +0 -1
- package/dist/components/p-DfkKMnWF.js.map +0 -1
- package/dist/components/p-tyC8W4sw.js.map +0 -1
- package/dist/design-system/p-3fe6dda9.entry.js +0 -2
- package/dist/design-system/p-3fe6dda9.entry.js.map +0 -1
- package/dist/design-system/p-70a394fe.entry.js.map +0 -1
- package/dist/design-system/p-7ae03d45.entry.js.map +0 -1
- package/dist/design-system/p-cdaa51d7.entry.js.map +0 -1
- /package/dist/design-system/{p-ab46652a.entry.js.map → p-240de5df.entry.js.map} +0 -0
- /package/dist/design-system/{p-a7ef9b22.entry.js.map → p-4eaf6262.entry.js.map} +0 -0
- /package/dist/design-system/{p-b5abb919.entry.js.map → p-71716c18.entry.js.map} +0 -0
- /package/dist/design-system/{p-131f639a.entry.js.map → p-b037ea76.entry.js.map} +0 -0
- /package/dist/design-system/{p-0529b7d6.entry.js.map → p-b4e3145a.entry.js.map} +0 -0
- /package/dist/design-system/{p-02d30a1b.entry.js.map → p-bd9e799c.entry.js.map} +0 -0
- /package/dist/design-system/{p-52454cc4.entry.js.map → p-d185bd2e.entry.js.map} +0 -0
|
@@ -3,27 +3,38 @@
|
|
|
3
3
|
var index = require('./index-D1tXBb8y.js');
|
|
4
4
|
var color = require('./color-Oz29vj7L.js');
|
|
5
5
|
|
|
6
|
-
const sdGuideCss = "@charset \"UTF-8\";@font-face{font-family:\"Pretendard\";font-weight:800;font-display:swap;src:local(\"Pretendard-ExtraBold\"), url(\"./fonts/Pretendard-ExtraBold.subset.woff2\") format(\"font-woff2\"), url(\"./fonts/Pretendard-ExtraBold.ttf\") format(\"truetype\")}@font-face{font-family:\"Pretendard\";font-weight:700;font-display:swap;src:local(\"Pretendard-Bold\"), url(\"./fonts/Pretendard-Bold.subset.woff2\") format(\"font-woff2\"), url(\"./fonts/Pretendard-Bold.ttf\") format(\"truetype\")}@font-face{font-family:\"Pretendard\";font-weight:600;font-display:swap;src:local(\"Pretendard-SemiBold\"), url(\"./fonts/Pretendard-SemiBold.subset.woff2\") format(\"font-woff2\"), url(\"./fonts/Pretendard-SemiBold.ttf\") format(\"truetype\")}@font-face{font-family:\"Pretendard\";font-weight:500;font-display:swap;src:local(\"Pretendard-Medium\"), url(\"./fonts/Pretendard-Medium.subset.woff2\") format(\"font-woff2\"), url(\"./fonts/Pretendard-Medium.ttf\") format(\"truetype\")}@font-face{font-family:\"Pretendard\";font-weight:400;font-display:swap;src:local(\"Pretendard-Regular\"), url(\"./fonts/Pretendard-Regular.subset.woff2\") format(\"font-woff2\"), url(\"./fonts/Pretendard-Regular.ttf\") format(\"truetype\")}@font-face{font-family:\"Pretendard\";font-weight:300;font-display:swap;src:local(\"Pretendard-Light\"), url(\"./fonts/Pretendard-Light.subset.woff2\") format(\"font-woff2\"), url(\"./fonts/Pretendard-Light.ttf\") format(\"truetype\")}.sc-sd-guide:root{--font-family-base:\"Pretendard\", -apple-system, BlinkMacSystemFont, system-ui, sans-serif}html.sc-sd-guide{font-family:\"Pretendard\", -apple-system, BlinkMacSystemFont, system-ui, sans-serif}.bg-primary.sc-sd-guide{background-color:var(--color-primary, #051d36)}.bg-secondary.sc-sd-guide{background-color:var(--color-secondary, #555555)}.bg-accent.sc-sd-guide{background-color:var(--color-accent, #9c27b0)}.bg-positive.sc-sd-guide{background-color:var(--color-positive, #0075ff)}.bg-negative.sc-sd-guide{background-color:var(--color-negative, #e30000)}.bg-info.sc-sd-guide{background-color:var(--color-info, #00cd52)}.bg-warning.sc-sd-guide{background-color:var(--color-warning, #f2c037)}.bg-red_99.sc-sd-guide{background-color:var(--color-red_99, #220000)}.bg-red_95.sc-sd-guide{background-color:var(--color-red_95, #440000)}.bg-red_90.sc-sd-guide{background-color:var(--color-red_90, #5E0000)}.bg-red_85.sc-sd-guide{background-color:var(--color-red_85, #820000)}.bg-red_80.sc-sd-guide{background-color:var(--color-red_80, #AD0000)}.bg-red_75.sc-sd-guide{background-color:var(--color-red_75, #E30000)}.bg-red_70.sc-sd-guide{background-color:var(--color-red_70, #FB4444)}.bg-red_60.sc-sd-guide{background-color:var(--color-red_60, #FF7C7C)}.bg-red_45.sc-sd-guide{background-color:var(--color-red_45, #FFB5B5)}.bg-red_30.sc-sd-guide{background-color:var(--color-red_30, #FFD3D3)}.bg-red_20.sc-sd-guide{background-color:var(--color-red_20, #FCE6E6)}.bg-red_15.sc-sd-guide{background-color:var(--color-red_15, #FCEFEF)}.bg-caution_bg.sc-sd-guide{background-color:var(--color-caution_bg, #FEF1F1)}.bg-caution_icon.sc-sd-guide{background-color:var(--color-caution_icon, #fd9595)}.bg-orange_99.sc-sd-guide{background-color:var(--color-orange_99, #2F1100)}.bg-orange_95.sc-sd-guide{background-color:var(--color-orange_95, #4D1B00)}.bg-orange_90.sc-sd-guide{background-color:var(--color-orange_90, #752A00)}.bg-orange_85.sc-sd-guide{background-color:var(--color-orange_85, #9B3700)}.bg-orange_75.sc-sd-guide{background-color:var(--color-orange_75, #CE4900)}.bg-orange_65.sc-sd-guide{background-color:var(--color-orange_65, #FF6B00)}.bg-orange_60.sc-sd-guide{background-color:var(--color-orange_60, #FF7F22)}.bg-orange_55.sc-sd-guide{background-color:var(--color-orange_55, #FFA452)}.bg-orange_45.sc-sd-guide{background-color:var(--color-orange_45, #FFBC81)}.bg-orange_35.sc-sd-guide{background-color:var(--color-orange_35, #FFD5AF)}.bg-orange_20.sc-sd-guide{background-color:var(--color-orange_20, #FFEAD7)}.bg-orange_10.sc-sd-guide{background-color:var(--color-orange_10, #FEF1EA)}.bg-header_alert.sc-sd-guide{background-color:var(--color-header_alert, #FF7A00)}.bg-yellow_95.sc-sd-guide{background-color:var(--color-yellow_95, #322700)}.bg-yellow_90.sc-sd-guide{background-color:var(--color-yellow_90, #453702)}.bg-yellow_80.sc-sd-guide{background-color:var(--color-yellow_80, #6C5602)}.bg-yellow_70.sc-sd-guide{background-color:var(--color-yellow_70, #9C7A00)}.bg-yellow_60.sc-sd-guide{background-color:var(--color-yellow_60, #C49900)}.bg-yellow_50.sc-sd-guide{background-color:var(--color-yellow_50, #EBB800)}.bg-yellow_45.sc-sd-guide{background-color:var(--color-yellow_45, #FFC700)}.bg-yellow_40.sc-sd-guide{background-color:var(--color-yellow_40, #FFD643)}.bg-yellow_30.sc-sd-guide{background-color:var(--color-yellow_30, #FEE17C)}.bg-yellow_25.sc-sd-guide{background-color:var(--color-yellow_25, #FFE99E)}.bg-yellow_20.sc-sd-guide{background-color:var(--color-yellow_20, #FEF1C4)}.bg-yellow_10.sc-sd-guide{background-color:var(--color-yellow_10, #FFF7DD)}.bg-olive_95.sc-sd-guide{background-color:var(--color-olive_95, #2C2C00)}.bg-olive_90.sc-sd-guide{background-color:var(--color-olive_90, #454500)}.bg-olive_80.sc-sd-guide{background-color:var(--color-olive_80, #636300)}.bg-olive_70.sc-sd-guide{background-color:var(--color-olive_70, #838300)}.bg-olive_65.sc-sd-guide{background-color:var(--color-olive_65, #A5A500)}.bg-olive_55.sc-sd-guide{background-color:var(--color-olive_55, #C7C700)}.bg-olive_45.sc-sd-guide{background-color:var(--color-olive_45, #DDDD12)}.bg-olive_30.sc-sd-guide{background-color:var(--color-olive_30, #EEEE37)}.bg-olive_20.sc-sd-guide{background-color:var(--color-olive_20, #F6F65F)}.bg-olive_15.sc-sd-guide{background-color:var(--color-olive_15, #FAFAA1)}.bg-olive_10.sc-sd-guide{background-color:var(--color-olive_10, #FBFBBF)}.bg-olive_05.sc-sd-guide{background-color:var(--color-olive_05, #FEFED9)}.bg-green_99.sc-sd-guide{background-color:var(--color-green_99, #001D0B)}.bg-green_95.sc-sd-guide{background-color:var(--color-green_95, #003013)}.bg-green_90.sc-sd-guide{background-color:var(--color-green_90, #00461C)}.bg-green_85.sc-sd-guide{background-color:var(--color-green_85, #006629)}.bg-green_80.sc-sd-guide{background-color:var(--color-green_80, #007B31)}.bg-green_75.sc-sd-guide{background-color:var(--color-green_75, #00973C)}.bg-green_70.sc-sd-guide{background-color:var(--color-green_70, #12B553)}.bg-green_65.sc-sd-guide{background-color:var(--color-green_65, #2BCE6C)}.bg-green_55.sc-sd-guide{background-color:var(--color-green_55, #6DE39C)}.bg-green_45.sc-sd-guide{background-color:var(--color-green_45, #ACF4C9)}.bg-green_25.sc-sd-guide{background-color:var(--color-green_25, #D4FAE3)}.bg-green_15.sc-sd-guide{background-color:var(--color-green_15, #E8F9EF)}.bg-steelblue_99.sc-sd-guide{background-color:var(--color-steelblue_99, #021a25)}.bg-steelblue_95.sc-sd-guide{background-color:var(--color-steelblue_95, #02212f)}.bg-steelblue_90.sc-sd-guide{background-color:var(--color-steelblue_90, #032d40)}.bg-steelblue_85.sc-sd-guide{background-color:var(--color-steelblue_85, #033f59)}.bg-steelblue_80.sc-sd-guide{background-color:var(--color-steelblue_80, #06587d)}.bg-steelblue_75.sc-sd-guide{background-color:var(--color-steelblue_75, #066d9b)}.bg-steelblue_70.sc-sd-guide{background-color:var(--color-steelblue_70, #128fc7)}.bg-steelblue_65.sc-sd-guide{background-color:var(--color-steelblue_65, #229fd7)}.bg-steelblue_60.sc-sd-guide{background-color:var(--color-steelblue_60, #50bff0)}.bg-steelblue_45.sc-sd-guide{background-color:var(--color-steelblue_45, #a4e2fd)}.bg-steelblue_25.sc-sd-guide{background-color:var(--color-steelblue_25, #d9f2fd)}.bg-steelblue_10.sc-sd-guide{background-color:var(--color-steelblue_10, #ecf8fd)}.bg-oceanblue_99.sc-sd-guide{background-color:var(--color-oceanblue_99, #011428)}.bg-oceanblue_95.sc-sd-guide{background-color:var(--color-oceanblue_95, #03172d)}.bg-oceanblue_90.sc-sd-guide{background-color:var(--color-oceanblue_90, #051d36)}.bg-oceanblue_85.sc-sd-guide{background-color:var(--color-oceanblue_85, #07284a)}.bg-oceanblue_80.sc-sd-guide{background-color:var(--color-oceanblue_80, #004177)}.bg-oceanblue_75.sc-sd-guide{background-color:var(--color-oceanblue_75, #025497)}.bg-oceanblue_70.sc-sd-guide{background-color:var(--color-oceanblue_70, #006ac1)}.bg-oceanblue_65.sc-sd-guide{background-color:var(--color-oceanblue_65, #1f8ae1)}.bg-oceanblue_60.sc-sd-guide{background-color:var(--color-oceanblue_60, #5cb0f3)}.bg-oceanblue_50.sc-sd-guide{background-color:var(--color-oceanblue_50, #9cd1fc)}.bg-oceanblue_25.sc-sd-guide{background-color:var(--color-oceanblue_25, #d5ebfe)}.bg-oceanblue_15.sc-sd-guide{background-color:var(--color-oceanblue_15, #eaf5fe)}.bg-brilliantblue_99.sc-sd-guide{background-color:var(--color-brilliantblue_99, #001226)}.bg-brilliantblue_95.sc-sd-guide{background-color:var(--color-brilliantblue_95, #001b39)}.bg-brilliantblue_90.sc-sd-guide{background-color:var(--color-brilliantblue_90, #002b5e)}.bg-brilliantblue_85.sc-sd-guide{background-color:var(--color-brilliantblue_85, #004290)}.bg-brilliantblue_80.sc-sd-guide{background-color:var(--color-brilliantblue_80, #005cc9)}.bg-brilliantblue_75.sc-sd-guide{background-color:var(--color-brilliantblue_75, #0075ff)}.bg-brilliantblue_70.sc-sd-guide{background-color:var(--color-brilliantblue_70, #2d8dff)}.bg-brilliantblue_60.sc-sd-guide{background-color:var(--color-brilliantblue_60, #64abff)}.bg-brilliantblue_50.sc-sd-guide{background-color:var(--color-brilliantblue_50, #93c4ff)}.bg-brilliantblue_40.sc-sd-guide{background-color:var(--color-brilliantblue_40, #bbdaff)}.bg-brilliantblue_25.sc-sd-guide{background-color:var(--color-brilliantblue_25, #d9eaff)}.bg-brilliantblue_20.sc-sd-guide{background-color:var(--color-brilliantblue_20, #e6f1ff)}.bg-brilliantblue_10.sc-sd-guide{background-color:var(--color-brilliantblue_10, #eff6ff)}.bg-brilliantblue_05.sc-sd-guide{background-color:var(--color-brilliantblue_05, #f5faff)}.bg-grey_95.sc-sd-guide{background-color:var(--color-grey_95, #222222)}.bg-grey_90.sc-sd-guide{background-color:var(--color-grey_90, #333333)}.bg-grey_85.sc-sd-guide{background-color:var(--color-grey_85, #444444)}.bg-grey_80.sc-sd-guide{background-color:var(--color-grey_80, #555555)}.bg-grey_70.sc-sd-guide{background-color:var(--color-grey_70, #737373)}.bg-grey_65.sc-sd-guide{background-color:var(--color-grey_65, #888888)}.bg-grey_60.sc-sd-guide{background-color:var(--color-grey_60, #999999)}.bg-grey_55.sc-sd-guide{background-color:var(--color-grey_55, #aaaaaa)}.bg-grey_50.sc-sd-guide{background-color:var(--color-grey_50, #bbbbbb)}.bg-grey_45.sc-sd-guide{background-color:var(--color-grey_45, #cccccc)}.bg-grey_35.sc-sd-guide{background-color:var(--color-grey_35, #D8D8D8)}.bg-grey_30.sc-sd-guide{background-color:var(--color-grey_30, #e1e1e1)}.bg-grey_25.sc-sd-guide{background-color:var(--color-grey_25, #E5E5E5)}.bg-grey_20.sc-sd-guide{background-color:var(--color-grey_20, #eeeeee)}.bg-grey_10.sc-sd-guide{background-color:var(--color-grey_10, #f6f6f6)}.bg-grey_05.sc-sd-guide{background-color:var(--color-grey_05, #f9f9f9)}.bg-white.sc-sd-guide{background-color:var(--color-white, #ffffff)}.bg-black.sc-sd-guide{background-color:var(--color-black, #000000)}.text-primary.sc-sd-guide{color:var(--color-primary, #051d36)}.text-secondary.sc-sd-guide{color:var(--color-secondary, #555555)}.text-accent.sc-sd-guide{color:var(--color-accent, #9c27b0)}.text-positive.sc-sd-guide{color:var(--color-positive, #0075ff)}.text-negative.sc-sd-guide{color:var(--color-negative, #e30000)}.text-info.sc-sd-guide{color:var(--color-info, #00cd52)}.text-warning.sc-sd-guide{color:var(--color-warning, #f2c037)}.text-red_99.sc-sd-guide{color:var(--color-red_99, #220000)}.text-red_95.sc-sd-guide{color:var(--color-red_95, #440000)}.text-red_90.sc-sd-guide{color:var(--color-red_90, #5E0000)}.text-red_85.sc-sd-guide{color:var(--color-red_85, #820000)}.text-red_80.sc-sd-guide{color:var(--color-red_80, #AD0000)}.text-red_75.sc-sd-guide{color:var(--color-red_75, #E30000)}.text-red_70.sc-sd-guide{color:var(--color-red_70, #FB4444)}.text-red_60.sc-sd-guide{color:var(--color-red_60, #FF7C7C)}.text-red_45.sc-sd-guide{color:var(--color-red_45, #FFB5B5)}.text-red_30.sc-sd-guide{color:var(--color-red_30, #FFD3D3)}.text-red_20.sc-sd-guide{color:var(--color-red_20, #FCE6E6)}.text-red_15.sc-sd-guide{color:var(--color-red_15, #FCEFEF)}.text-caution_bg.sc-sd-guide{color:var(--color-caution_bg, #FEF1F1)}.text-caution_icon.sc-sd-guide{color:var(--color-caution_icon, #fd9595)}.text-orange_99.sc-sd-guide{color:var(--color-orange_99, #2F1100)}.text-orange_95.sc-sd-guide{color:var(--color-orange_95, #4D1B00)}.text-orange_90.sc-sd-guide{color:var(--color-orange_90, #752A00)}.text-orange_85.sc-sd-guide{color:var(--color-orange_85, #9B3700)}.text-orange_75.sc-sd-guide{color:var(--color-orange_75, #CE4900)}.text-orange_65.sc-sd-guide{color:var(--color-orange_65, #FF6B00)}.text-orange_60.sc-sd-guide{color:var(--color-orange_60, #FF7F22)}.text-orange_55.sc-sd-guide{color:var(--color-orange_55, #FFA452)}.text-orange_45.sc-sd-guide{color:var(--color-orange_45, #FFBC81)}.text-orange_35.sc-sd-guide{color:var(--color-orange_35, #FFD5AF)}.text-orange_20.sc-sd-guide{color:var(--color-orange_20, #FFEAD7)}.text-orange_10.sc-sd-guide{color:var(--color-orange_10, #FEF1EA)}.text-header_alert.sc-sd-guide{color:var(--color-header_alert, #FF7A00)}.text-yellow_95.sc-sd-guide{color:var(--color-yellow_95, #322700)}.text-yellow_90.sc-sd-guide{color:var(--color-yellow_90, #453702)}.text-yellow_80.sc-sd-guide{color:var(--color-yellow_80, #6C5602)}.text-yellow_70.sc-sd-guide{color:var(--color-yellow_70, #9C7A00)}.text-yellow_60.sc-sd-guide{color:var(--color-yellow_60, #C49900)}.text-yellow_50.sc-sd-guide{color:var(--color-yellow_50, #EBB800)}.text-yellow_45.sc-sd-guide{color:var(--color-yellow_45, #FFC700)}.text-yellow_40.sc-sd-guide{color:var(--color-yellow_40, #FFD643)}.text-yellow_30.sc-sd-guide{color:var(--color-yellow_30, #FEE17C)}.text-yellow_25.sc-sd-guide{color:var(--color-yellow_25, #FFE99E)}.text-yellow_20.sc-sd-guide{color:var(--color-yellow_20, #FEF1C4)}.text-yellow_10.sc-sd-guide{color:var(--color-yellow_10, #FFF7DD)}.text-olive_95.sc-sd-guide{color:var(--color-olive_95, #2C2C00)}.text-olive_90.sc-sd-guide{color:var(--color-olive_90, #454500)}.text-olive_80.sc-sd-guide{color:var(--color-olive_80, #636300)}.text-olive_70.sc-sd-guide{color:var(--color-olive_70, #838300)}.text-olive_65.sc-sd-guide{color:var(--color-olive_65, #A5A500)}.text-olive_55.sc-sd-guide{color:var(--color-olive_55, #C7C700)}.text-olive_45.sc-sd-guide{color:var(--color-olive_45, #DDDD12)}.text-olive_30.sc-sd-guide{color:var(--color-olive_30, #EEEE37)}.text-olive_20.sc-sd-guide{color:var(--color-olive_20, #F6F65F)}.text-olive_15.sc-sd-guide{color:var(--color-olive_15, #FAFAA1)}.text-olive_10.sc-sd-guide{color:var(--color-olive_10, #FBFBBF)}.text-olive_05.sc-sd-guide{color:var(--color-olive_05, #FEFED9)}.text-green_99.sc-sd-guide{color:var(--color-green_99, #001D0B)}.text-green_95.sc-sd-guide{color:var(--color-green_95, #003013)}.text-green_90.sc-sd-guide{color:var(--color-green_90, #00461C)}.text-green_85.sc-sd-guide{color:var(--color-green_85, #006629)}.text-green_80.sc-sd-guide{color:var(--color-green_80, #007B31)}.text-green_75.sc-sd-guide{color:var(--color-green_75, #00973C)}.text-green_70.sc-sd-guide{color:var(--color-green_70, #12B553)}.text-green_65.sc-sd-guide{color:var(--color-green_65, #2BCE6C)}.text-green_55.sc-sd-guide{color:var(--color-green_55, #6DE39C)}.text-green_45.sc-sd-guide{color:var(--color-green_45, #ACF4C9)}.text-green_25.sc-sd-guide{color:var(--color-green_25, #D4FAE3)}.text-green_15.sc-sd-guide{color:var(--color-green_15, #E8F9EF)}.text-steelblue_99.sc-sd-guide{color:var(--color-steelblue_99, #021a25)}.text-steelblue_95.sc-sd-guide{color:var(--color-steelblue_95, #02212f)}.text-steelblue_90.sc-sd-guide{color:var(--color-steelblue_90, #032d40)}.text-steelblue_85.sc-sd-guide{color:var(--color-steelblue_85, #033f59)}.text-steelblue_80.sc-sd-guide{color:var(--color-steelblue_80, #06587d)}.text-steelblue_75.sc-sd-guide{color:var(--color-steelblue_75, #066d9b)}.text-steelblue_70.sc-sd-guide{color:var(--color-steelblue_70, #128fc7)}.text-steelblue_65.sc-sd-guide{color:var(--color-steelblue_65, #229fd7)}.text-steelblue_60.sc-sd-guide{color:var(--color-steelblue_60, #50bff0)}.text-steelblue_45.sc-sd-guide{color:var(--color-steelblue_45, #a4e2fd)}.text-steelblue_25.sc-sd-guide{color:var(--color-steelblue_25, #d9f2fd)}.text-steelblue_10.sc-sd-guide{color:var(--color-steelblue_10, #ecf8fd)}.text-oceanblue_99.sc-sd-guide{color:var(--color-oceanblue_99, #011428)}.text-oceanblue_95.sc-sd-guide{color:var(--color-oceanblue_95, #03172d)}.text-oceanblue_90.sc-sd-guide{color:var(--color-oceanblue_90, #051d36)}.text-oceanblue_85.sc-sd-guide{color:var(--color-oceanblue_85, #07284a)}.text-oceanblue_80.sc-sd-guide{color:var(--color-oceanblue_80, #004177)}.text-oceanblue_75.sc-sd-guide{color:var(--color-oceanblue_75, #025497)}.text-oceanblue_70.sc-sd-guide{color:var(--color-oceanblue_70, #006ac1)}.text-oceanblue_65.sc-sd-guide{color:var(--color-oceanblue_65, #1f8ae1)}.text-oceanblue_60.sc-sd-guide{color:var(--color-oceanblue_60, #5cb0f3)}.text-oceanblue_50.sc-sd-guide{color:var(--color-oceanblue_50, #9cd1fc)}.text-oceanblue_25.sc-sd-guide{color:var(--color-oceanblue_25, #d5ebfe)}.text-oceanblue_15.sc-sd-guide{color:var(--color-oceanblue_15, #eaf5fe)}.text-brilliantblue_99.sc-sd-guide{color:var(--color-brilliantblue_99, #001226)}.text-brilliantblue_95.sc-sd-guide{color:var(--color-brilliantblue_95, #001b39)}.text-brilliantblue_90.sc-sd-guide{color:var(--color-brilliantblue_90, #002b5e)}.text-brilliantblue_85.sc-sd-guide{color:var(--color-brilliantblue_85, #004290)}.text-brilliantblue_80.sc-sd-guide{color:var(--color-brilliantblue_80, #005cc9)}.text-brilliantblue_75.sc-sd-guide{color:var(--color-brilliantblue_75, #0075ff)}.text-brilliantblue_70.sc-sd-guide{color:var(--color-brilliantblue_70, #2d8dff)}.text-brilliantblue_60.sc-sd-guide{color:var(--color-brilliantblue_60, #64abff)}.text-brilliantblue_50.sc-sd-guide{color:var(--color-brilliantblue_50, #93c4ff)}.text-brilliantblue_40.sc-sd-guide{color:var(--color-brilliantblue_40, #bbdaff)}.text-brilliantblue_25.sc-sd-guide{color:var(--color-brilliantblue_25, #d9eaff)}.text-brilliantblue_20.sc-sd-guide{color:var(--color-brilliantblue_20, #e6f1ff)}.text-brilliantblue_10.sc-sd-guide{color:var(--color-brilliantblue_10, #eff6ff)}.text-brilliantblue_05.sc-sd-guide{color:var(--color-brilliantblue_05, #f5faff)}.text-grey_95.sc-sd-guide{color:var(--color-grey_95, #222222)}.text-grey_90.sc-sd-guide{color:var(--color-grey_90, #333333)}.text-grey_85.sc-sd-guide{color:var(--color-grey_85, #444444)}.text-grey_80.sc-sd-guide{color:var(--color-grey_80, #555555)}.text-grey_70.sc-sd-guide{color:var(--color-grey_70, #737373)}.text-grey_65.sc-sd-guide{color:var(--color-grey_65, #888888)}.text-grey_60.sc-sd-guide{color:var(--color-grey_60, #999999)}.text-grey_55.sc-sd-guide{color:var(--color-grey_55, #aaaaaa)}.text-grey_50.sc-sd-guide{color:var(--color-grey_50, #bbbbbb)}.text-grey_45.sc-sd-guide{color:var(--color-grey_45, #cccccc)}.text-grey_35.sc-sd-guide{color:var(--color-grey_35, #D8D8D8)}.text-grey_30.sc-sd-guide{color:var(--color-grey_30, #e1e1e1)}.text-grey_25.sc-sd-guide{color:var(--color-grey_25, #E5E5E5)}.text-grey_20.sc-sd-guide{color:var(--color-grey_20, #eeeeee)}.text-grey_10.sc-sd-guide{color:var(--color-grey_10, #f6f6f6)}.text-grey_05.sc-sd-guide{color:var(--color-grey_05, #f9f9f9)}.text-white.sc-sd-guide{color:var(--color-white, #ffffff)}.text-black.sc-sd-guide{color:var(--color-black, #000000)}*.sc-sd-guide,*.sc-sd-guide::before,*.sc-sd-guide::after{box-sizing:border-box}html.sc-sd-guide{-moz-text-size-adjust:none;-webkit-text-size-adjust:none;text-size-adjust:none}body.sc-sd-guide,h1.sc-sd-guide,h2.sc-sd-guide,h3.sc-sd-guide,h4.sc-sd-guide,p.sc-sd-guide,figure.sc-sd-guide,blockquote.sc-sd-guide,dl.sc-sd-guide,dd.sc-sd-guide{margin-block-end:0}ul[role=list].sc-sd-guide,ol[role=list].sc-sd-guide{list-style:none}body.sc-sd-guide{min-height:100vh;line-height:1.5}h1.sc-sd-guide,h2.sc-sd-guide,h3.sc-sd-guide,h4.sc-sd-guide,button.sc-sd-guide,input.sc-sd-guide,label.sc-sd-guide{line-height:1}h1.sc-sd-guide,h2.sc-sd-guide,h3.sc-sd-guide,h4.sc-sd-guide{text-wrap:balance}a.sc-sd-guide:not([class]){text-decoration-skip-ink:auto;color:currentColor}img.sc-sd-guide,picture.sc-sd-guide{max-width:100%;display:block}input.sc-sd-guide,button.sc-sd-guide,textarea.sc-sd-guide,select.sc-sd-guide{font-size:inherit}.sc-sd-guide:target{scroll-margin-block:5ex}button.sc-sd-guide{background:none;border:none;cursor:pointer;padding:0;outline:0}button.sc-sd-guide:focus{outline:0 !important}.sc-sd-guide-h{display:inline-block;height:fit-content;line-height:0}.text-center.sc-sd-guide{text-align:center}.text-right.sc-sd-guide{text-align:right}.text-left.sc-sd-guide{text-align:left}input[type=text].sc-sd-guide,input[type=number].sc-sd-guide,input[type=password].sc-sd-guide,input[type=email].sc-sd-guide,input[type=tel].sc-sd-guide,textarea.sc-sd-guide{padding-block:0px;padding-inline:0px}.sd-hoverable.sc-sd-guide:hover>.sd-focus-helper.sc-sd-guide{background:currentColor;opacity:0.15}.sd-hoverable.sc-sd-guide:hover>.sd-focus-helper.sc-sd-guide:before{opacity:0.1}.sd-hoverable.sc-sd-guide:hover>.sd-focus-helper.sc-sd-guide:after{opacity:0.4}.sd-focus-helper.sc-sd-guide{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:inherit;opacity:0;transition:background-color 0.3s cubic-bezier(0.25, 0.8, 0.5, 1), opacity 0.4s cubic-bezier(0.25, 0.8, 0.5, 1)}.sd-focus-helper.sc-sd-guide:before,.sd-focus-helper.sc-sd-guide:after{content:\"\";position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;border-radius:inherit;transition:background-color 0.3s cubic-bezier(0.25, 0.8, 0.5, 1), opacity 0.6s cubic-bezier(0.25, 0.8, 0.5, 1)}.sd-focus-helper.sc-sd-guide:before{background:#000000}.sd-focus-helper.sc-sd-guide:after{background:#ffffff}.sd-tooltip-menu.sc-sd-guide{width:fit-content;padding:8px 16px;border-radius:4px;color:white;background:#07284a;font-size:12px;position:relative;box-sizing:border-box;display:flex;align-items:start;justify-content:center;gap:12px}.sd-tooltip-menu--with-close.sc-sd-guide{padding-right:12px !important}.sd-tooltip-menu__arrow.sc-sd-guide{position:absolute;display:flex;width:9.6px;height:7.2px}.sd-tooltip-menu__arrow.sc-sd-guide svg.sc-sd-guide{width:100%;height:100%}.sd-tooltip-menu__arrow--top.sc-sd-guide{bottom:-7.2px;left:50%;transform:translateX(-50%)}.sd-tooltip-menu__arrow--bottom.sc-sd-guide{top:-7.2px;left:50%;transform:translateX(-50%) rotate(180deg)}.sd-tooltip-menu__arrow--left.sc-sd-guide{right:-7.2px;top:50%;transform:translateY(-50%) rotate(-90deg)}.sd-tooltip-menu__arrow--right.sc-sd-guide{left:-7.2px;top:50%;transform:translateY(-50%) rotate(90deg)}.sd-tooltip-menu__content.sc-sd-guide{line-height:20px;font-weight:500}.sd-tooltip-menu__close-button.sc-sd-guide{padding-top:4px;display:flex}.sd-tooltip-menu__close-button.sc-sd-guide button.sc-sd-guide{padding:0;background:none;border:none;cursor:pointer}.sd-popover-menu.sc-sd-guide{width:fit-content;padding:12px 20px;border-radius:4px;color:white;background:#07284a;font-size:12px;position:relative;box-sizing:border-box}.sd-popover-menu__arrow.sc-sd-guide{position:absolute;display:flex;width:9.6px;height:7.2px}.sd-popover-menu__arrow.sc-sd-guide svg.sc-sd-guide{width:100%;height:100%}.sd-popover-menu__arrow--top.sc-sd-guide{bottom:-7.2px;left:50%;transform:translateX(-50%)}.sd-popover-menu__arrow--bottom.sc-sd-guide{top:-7.2px;left:50%;transform:translateX(-50%) rotate(180deg)}.sd-popover-menu__arrow--left.sc-sd-guide{right:-7.2px;top:50%;transform:translateY(-50%) rotate(-90deg)}.sd-popover-menu__arrow--right.sc-sd-guide{left:-7.2px;top:50%;transform:translateY(-50%) rotate(90deg)}.sd-popover-menu__content.sc-sd-guide{font-size:12px;line-height:20px}.sd-popover-menu__content.sc-sd-guide .sd-popover-menu__title.sc-sd-guide{font-weight:700;margin-bottom:4px}.sd-popover-menu__content.sc-sd-guide .sd-popover-menu__messages.sc-sd-guide{font-weight:500}.sd-popover-menu__content.sc-sd-guide .sd-popover-menu__buttons.sc-sd-guide{margin-top:12px;display:flex;gap:8px;align-items:center}.sd-popover-menu__content.sc-sd-guide .sd-popover-menu__buttons--1.sc-sd-guide{justify-content:flex-end}.sd-popover-menu__content.sc-sd-guide .sd-popover-menu__buttons--2.sc-sd-guide{justify-content:space-between}.sd-popover-menu__close-button.sc-sd-guide{position:absolute;top:16px;right:12px;padding:0;background:none;border:none;cursor:pointer}.sd-guide__popup.sc-sd-guide{position:relative;padding:20px 32px;border-radius:8px;box-shadow:4px 4px 24px 4px rgba(0, 0, 0, 0.1);background:white}.sd-guide__popup__close.sc-sd-guide{position:absolute;top:12px;right:12px}.sd-guide__popup__header.sc-sd-guide{display:flex;align-items:center;gap:8px;margin-bottom:12px}.sd-guide__popup__header.sc-sd-guide .sd-guide__popup__title.sc-sd-guide{margin-top:0;font-size:16px;font-weight:700;line-height:26px;color:#333333}.sd-guide__popup__list.sc-sd-guide{width:100%;padding:0;margin:0}.sd-guide__popup__list__item.sc-sd-guide{display:flex;width:100%;align-items:start;list-style:none;color:#333333;font-size:12px;font-weight:400}.sd-guide__popup__list__item.sc-sd-guide p.sc-sd-guide{width:100%;padding:0;margin:0;word-wrap:break-word;word-break:break-word;white-space:normal;overflow-wrap:break-word;min-width:0}.sd-guide__popup__list__item.sc-sd-guide::before{display:block;content:\"-\";width:6px;color:#333333;font-size:12px;font-weight:400;margin-left:10px;margin-right:12px;flex-shrink:0}.sd-guide__popup__list__item--depth-2.sc-sd-guide::before{content:\"•\"}.sd-guide__popup__list__item--depth-2.sc-sd-guide{padding-left:26px}";
|
|
6
|
+
const sdGuideCss = "@charset \"UTF-8\";@font-face{font-family:\"Pretendard\";font-weight:800;font-display:swap;src:local(\"Pretendard-ExtraBold\"), url(\"./fonts/Pretendard-ExtraBold.subset.woff2\") format(\"font-woff2\"), url(\"./fonts/Pretendard-ExtraBold.ttf\") format(\"truetype\")}@font-face{font-family:\"Pretendard\";font-weight:700;font-display:swap;src:local(\"Pretendard-Bold\"), url(\"./fonts/Pretendard-Bold.subset.woff2\") format(\"font-woff2\"), url(\"./fonts/Pretendard-Bold.ttf\") format(\"truetype\")}@font-face{font-family:\"Pretendard\";font-weight:600;font-display:swap;src:local(\"Pretendard-SemiBold\"), url(\"./fonts/Pretendard-SemiBold.subset.woff2\") format(\"font-woff2\"), url(\"./fonts/Pretendard-SemiBold.ttf\") format(\"truetype\")}@font-face{font-family:\"Pretendard\";font-weight:500;font-display:swap;src:local(\"Pretendard-Medium\"), url(\"./fonts/Pretendard-Medium.subset.woff2\") format(\"font-woff2\"), url(\"./fonts/Pretendard-Medium.ttf\") format(\"truetype\")}@font-face{font-family:\"Pretendard\";font-weight:400;font-display:swap;src:local(\"Pretendard-Regular\"), url(\"./fonts/Pretendard-Regular.subset.woff2\") format(\"font-woff2\"), url(\"./fonts/Pretendard-Regular.ttf\") format(\"truetype\")}@font-face{font-family:\"Pretendard\";font-weight:300;font-display:swap;src:local(\"Pretendard-Light\"), url(\"./fonts/Pretendard-Light.subset.woff2\") format(\"font-woff2\"), url(\"./fonts/Pretendard-Light.ttf\") format(\"truetype\")}.sc-sd-guide:root{--font-family-base:\"Pretendard\", -apple-system, BlinkMacSystemFont, system-ui, sans-serif}html.sc-sd-guide{font-family:\"Pretendard\", -apple-system, BlinkMacSystemFont, system-ui, sans-serif}.bg-primary.sc-sd-guide{background-color:var(--color-primary, #051d36)}.bg-secondary.sc-sd-guide{background-color:var(--color-secondary, #555555)}.bg-accent.sc-sd-guide{background-color:var(--color-accent, #9c27b0)}.bg-positive.sc-sd-guide{background-color:var(--color-positive, #0075ff)}.bg-negative.sc-sd-guide{background-color:var(--color-negative, #e30000)}.bg-info.sc-sd-guide{background-color:var(--color-info, #00cd52)}.bg-warning.sc-sd-guide{background-color:var(--color-warning, #f2c037)}.bg-red_99.sc-sd-guide{background-color:var(--color-red_99, #220000)}.bg-red_95.sc-sd-guide{background-color:var(--color-red_95, #440000)}.bg-red_90.sc-sd-guide{background-color:var(--color-red_90, #5E0000)}.bg-red_85.sc-sd-guide{background-color:var(--color-red_85, #820000)}.bg-red_80.sc-sd-guide{background-color:var(--color-red_80, #AD0000)}.bg-red_75.sc-sd-guide{background-color:var(--color-red_75, #E30000)}.bg-red_70.sc-sd-guide{background-color:var(--color-red_70, #FB4444)}.bg-red_60.sc-sd-guide{background-color:var(--color-red_60, #FF7C7C)}.bg-red_45.sc-sd-guide{background-color:var(--color-red_45, #FFB5B5)}.bg-red_30.sc-sd-guide{background-color:var(--color-red_30, #FFD3D3)}.bg-red_20.sc-sd-guide{background-color:var(--color-red_20, #FCE6E6)}.bg-red_15.sc-sd-guide{background-color:var(--color-red_15, #FCEFEF)}.bg-caution_bg.sc-sd-guide{background-color:var(--color-caution_bg, #FEF1F1)}.bg-caution_icon.sc-sd-guide{background-color:var(--color-caution_icon, #fd9595)}.bg-orange_99.sc-sd-guide{background-color:var(--color-orange_99, #2F1100)}.bg-orange_95.sc-sd-guide{background-color:var(--color-orange_95, #4D1B00)}.bg-orange_90.sc-sd-guide{background-color:var(--color-orange_90, #752A00)}.bg-orange_85.sc-sd-guide{background-color:var(--color-orange_85, #9B3700)}.bg-orange_75.sc-sd-guide{background-color:var(--color-orange_75, #CE4900)}.bg-orange_65.sc-sd-guide{background-color:var(--color-orange_65, #FF6B00)}.bg-orange_60.sc-sd-guide{background-color:var(--color-orange_60, #FF7F22)}.bg-orange_55.sc-sd-guide{background-color:var(--color-orange_55, #FFA452)}.bg-orange_45.sc-sd-guide{background-color:var(--color-orange_45, #FFBC81)}.bg-orange_35.sc-sd-guide{background-color:var(--color-orange_35, #FFD5AF)}.bg-orange_20.sc-sd-guide{background-color:var(--color-orange_20, #FFEAD7)}.bg-orange_10.sc-sd-guide{background-color:var(--color-orange_10, #FEF1EA)}.bg-header_alert.sc-sd-guide{background-color:var(--color-header_alert, #FF7A00)}.bg-yellow_95.sc-sd-guide{background-color:var(--color-yellow_95, #322700)}.bg-yellow_90.sc-sd-guide{background-color:var(--color-yellow_90, #453702)}.bg-yellow_80.sc-sd-guide{background-color:var(--color-yellow_80, #6C5602)}.bg-yellow_70.sc-sd-guide{background-color:var(--color-yellow_70, #9C7A00)}.bg-yellow_60.sc-sd-guide{background-color:var(--color-yellow_60, #C49900)}.bg-yellow_50.sc-sd-guide{background-color:var(--color-yellow_50, #EBB800)}.bg-yellow_45.sc-sd-guide{background-color:var(--color-yellow_45, #FFC700)}.bg-yellow_40.sc-sd-guide{background-color:var(--color-yellow_40, #FFD643)}.bg-yellow_30.sc-sd-guide{background-color:var(--color-yellow_30, #FEE17C)}.bg-yellow_25.sc-sd-guide{background-color:var(--color-yellow_25, #FFE99E)}.bg-yellow_20.sc-sd-guide{background-color:var(--color-yellow_20, #FEF1C4)}.bg-yellow_10.sc-sd-guide{background-color:var(--color-yellow_10, #FFF7DD)}.bg-olive_95.sc-sd-guide{background-color:var(--color-olive_95, #2C2C00)}.bg-olive_90.sc-sd-guide{background-color:var(--color-olive_90, #454500)}.bg-olive_80.sc-sd-guide{background-color:var(--color-olive_80, #636300)}.bg-olive_70.sc-sd-guide{background-color:var(--color-olive_70, #838300)}.bg-olive_65.sc-sd-guide{background-color:var(--color-olive_65, #A5A500)}.bg-olive_55.sc-sd-guide{background-color:var(--color-olive_55, #C7C700)}.bg-olive_45.sc-sd-guide{background-color:var(--color-olive_45, #DDDD12)}.bg-olive_30.sc-sd-guide{background-color:var(--color-olive_30, #EEEE37)}.bg-olive_20.sc-sd-guide{background-color:var(--color-olive_20, #F6F65F)}.bg-olive_15.sc-sd-guide{background-color:var(--color-olive_15, #FAFAA1)}.bg-olive_10.sc-sd-guide{background-color:var(--color-olive_10, #FBFBBF)}.bg-olive_05.sc-sd-guide{background-color:var(--color-olive_05, #FEFED9)}.bg-green_99.sc-sd-guide{background-color:var(--color-green_99, #001D0B)}.bg-green_95.sc-sd-guide{background-color:var(--color-green_95, #003013)}.bg-green_90.sc-sd-guide{background-color:var(--color-green_90, #00461C)}.bg-green_85.sc-sd-guide{background-color:var(--color-green_85, #006629)}.bg-green_80.sc-sd-guide{background-color:var(--color-green_80, #007B31)}.bg-green_75.sc-sd-guide{background-color:var(--color-green_75, #00973C)}.bg-green_70.sc-sd-guide{background-color:var(--color-green_70, #12B553)}.bg-green_65.sc-sd-guide{background-color:var(--color-green_65, #2BCE6C)}.bg-green_55.sc-sd-guide{background-color:var(--color-green_55, #6DE39C)}.bg-green_45.sc-sd-guide{background-color:var(--color-green_45, #ACF4C9)}.bg-green_25.sc-sd-guide{background-color:var(--color-green_25, #D4FAE3)}.bg-green_15.sc-sd-guide{background-color:var(--color-green_15, #E8F9EF)}.bg-steelblue_99.sc-sd-guide{background-color:var(--color-steelblue_99, #021a25)}.bg-steelblue_95.sc-sd-guide{background-color:var(--color-steelblue_95, #02212f)}.bg-steelblue_90.sc-sd-guide{background-color:var(--color-steelblue_90, #032d40)}.bg-steelblue_85.sc-sd-guide{background-color:var(--color-steelblue_85, #033f59)}.bg-steelblue_80.sc-sd-guide{background-color:var(--color-steelblue_80, #06587d)}.bg-steelblue_75.sc-sd-guide{background-color:var(--color-steelblue_75, #066d9b)}.bg-steelblue_70.sc-sd-guide{background-color:var(--color-steelblue_70, #128fc7)}.bg-steelblue_65.sc-sd-guide{background-color:var(--color-steelblue_65, #229fd7)}.bg-steelblue_60.sc-sd-guide{background-color:var(--color-steelblue_60, #50bff0)}.bg-steelblue_45.sc-sd-guide{background-color:var(--color-steelblue_45, #a4e2fd)}.bg-steelblue_25.sc-sd-guide{background-color:var(--color-steelblue_25, #d9f2fd)}.bg-steelblue_10.sc-sd-guide{background-color:var(--color-steelblue_10, #ecf8fd)}.bg-oceanblue_99.sc-sd-guide{background-color:var(--color-oceanblue_99, #011428)}.bg-oceanblue_95.sc-sd-guide{background-color:var(--color-oceanblue_95, #03172d)}.bg-oceanblue_90.sc-sd-guide{background-color:var(--color-oceanblue_90, #051d36)}.bg-oceanblue_85.sc-sd-guide{background-color:var(--color-oceanblue_85, #07284a)}.bg-oceanblue_80.sc-sd-guide{background-color:var(--color-oceanblue_80, #004177)}.bg-oceanblue_75.sc-sd-guide{background-color:var(--color-oceanblue_75, #025497)}.bg-oceanblue_70.sc-sd-guide{background-color:var(--color-oceanblue_70, #006ac1)}.bg-oceanblue_65.sc-sd-guide{background-color:var(--color-oceanblue_65, #1f8ae1)}.bg-oceanblue_60.sc-sd-guide{background-color:var(--color-oceanblue_60, #5cb0f3)}.bg-oceanblue_50.sc-sd-guide{background-color:var(--color-oceanblue_50, #9cd1fc)}.bg-oceanblue_25.sc-sd-guide{background-color:var(--color-oceanblue_25, #d5ebfe)}.bg-oceanblue_15.sc-sd-guide{background-color:var(--color-oceanblue_15, #eaf5fe)}.bg-brilliantblue_99.sc-sd-guide{background-color:var(--color-brilliantblue_99, #001226)}.bg-brilliantblue_95.sc-sd-guide{background-color:var(--color-brilliantblue_95, #001b39)}.bg-brilliantblue_90.sc-sd-guide{background-color:var(--color-brilliantblue_90, #002b5e)}.bg-brilliantblue_85.sc-sd-guide{background-color:var(--color-brilliantblue_85, #004290)}.bg-brilliantblue_80.sc-sd-guide{background-color:var(--color-brilliantblue_80, #005cc9)}.bg-brilliantblue_75.sc-sd-guide{background-color:var(--color-brilliantblue_75, #0075ff)}.bg-brilliantblue_70.sc-sd-guide{background-color:var(--color-brilliantblue_70, #2d8dff)}.bg-brilliantblue_60.sc-sd-guide{background-color:var(--color-brilliantblue_60, #64abff)}.bg-brilliantblue_50.sc-sd-guide{background-color:var(--color-brilliantblue_50, #93c4ff)}.bg-brilliantblue_40.sc-sd-guide{background-color:var(--color-brilliantblue_40, #bbdaff)}.bg-brilliantblue_25.sc-sd-guide{background-color:var(--color-brilliantblue_25, #d9eaff)}.bg-brilliantblue_20.sc-sd-guide{background-color:var(--color-brilliantblue_20, #e6f1ff)}.bg-brilliantblue_10.sc-sd-guide{background-color:var(--color-brilliantblue_10, #eff6ff)}.bg-brilliantblue_05.sc-sd-guide{background-color:var(--color-brilliantblue_05, #f5faff)}.bg-grey_95.sc-sd-guide{background-color:var(--color-grey_95, #222222)}.bg-grey_90.sc-sd-guide{background-color:var(--color-grey_90, #333333)}.bg-grey_85.sc-sd-guide{background-color:var(--color-grey_85, #444444)}.bg-grey_80.sc-sd-guide{background-color:var(--color-grey_80, #555555)}.bg-grey_70.sc-sd-guide{background-color:var(--color-grey_70, #737373)}.bg-grey_65.sc-sd-guide{background-color:var(--color-grey_65, #888888)}.bg-grey_60.sc-sd-guide{background-color:var(--color-grey_60, #999999)}.bg-grey_55.sc-sd-guide{background-color:var(--color-grey_55, #aaaaaa)}.bg-grey_50.sc-sd-guide{background-color:var(--color-grey_50, #bbbbbb)}.bg-grey_45.sc-sd-guide{background-color:var(--color-grey_45, #cccccc)}.bg-grey_35.sc-sd-guide{background-color:var(--color-grey_35, #D8D8D8)}.bg-grey_30.sc-sd-guide{background-color:var(--color-grey_30, #e1e1e1)}.bg-grey_25.sc-sd-guide{background-color:var(--color-grey_25, #E5E5E5)}.bg-grey_20.sc-sd-guide{background-color:var(--color-grey_20, #eeeeee)}.bg-grey_10.sc-sd-guide{background-color:var(--color-grey_10, #f6f6f6)}.bg-grey_05.sc-sd-guide{background-color:var(--color-grey_05, #f9f9f9)}.bg-white.sc-sd-guide{background-color:var(--color-white, #ffffff)}.bg-black.sc-sd-guide{background-color:var(--color-black, #000000)}.text-primary.sc-sd-guide{color:var(--color-primary, #051d36)}.text-secondary.sc-sd-guide{color:var(--color-secondary, #555555)}.text-accent.sc-sd-guide{color:var(--color-accent, #9c27b0)}.text-positive.sc-sd-guide{color:var(--color-positive, #0075ff)}.text-negative.sc-sd-guide{color:var(--color-negative, #e30000)}.text-info.sc-sd-guide{color:var(--color-info, #00cd52)}.text-warning.sc-sd-guide{color:var(--color-warning, #f2c037)}.text-red_99.sc-sd-guide{color:var(--color-red_99, #220000)}.text-red_95.sc-sd-guide{color:var(--color-red_95, #440000)}.text-red_90.sc-sd-guide{color:var(--color-red_90, #5E0000)}.text-red_85.sc-sd-guide{color:var(--color-red_85, #820000)}.text-red_80.sc-sd-guide{color:var(--color-red_80, #AD0000)}.text-red_75.sc-sd-guide{color:var(--color-red_75, #E30000)}.text-red_70.sc-sd-guide{color:var(--color-red_70, #FB4444)}.text-red_60.sc-sd-guide{color:var(--color-red_60, #FF7C7C)}.text-red_45.sc-sd-guide{color:var(--color-red_45, #FFB5B5)}.text-red_30.sc-sd-guide{color:var(--color-red_30, #FFD3D3)}.text-red_20.sc-sd-guide{color:var(--color-red_20, #FCE6E6)}.text-red_15.sc-sd-guide{color:var(--color-red_15, #FCEFEF)}.text-caution_bg.sc-sd-guide{color:var(--color-caution_bg, #FEF1F1)}.text-caution_icon.sc-sd-guide{color:var(--color-caution_icon, #fd9595)}.text-orange_99.sc-sd-guide{color:var(--color-orange_99, #2F1100)}.text-orange_95.sc-sd-guide{color:var(--color-orange_95, #4D1B00)}.text-orange_90.sc-sd-guide{color:var(--color-orange_90, #752A00)}.text-orange_85.sc-sd-guide{color:var(--color-orange_85, #9B3700)}.text-orange_75.sc-sd-guide{color:var(--color-orange_75, #CE4900)}.text-orange_65.sc-sd-guide{color:var(--color-orange_65, #FF6B00)}.text-orange_60.sc-sd-guide{color:var(--color-orange_60, #FF7F22)}.text-orange_55.sc-sd-guide{color:var(--color-orange_55, #FFA452)}.text-orange_45.sc-sd-guide{color:var(--color-orange_45, #FFBC81)}.text-orange_35.sc-sd-guide{color:var(--color-orange_35, #FFD5AF)}.text-orange_20.sc-sd-guide{color:var(--color-orange_20, #FFEAD7)}.text-orange_10.sc-sd-guide{color:var(--color-orange_10, #FEF1EA)}.text-header_alert.sc-sd-guide{color:var(--color-header_alert, #FF7A00)}.text-yellow_95.sc-sd-guide{color:var(--color-yellow_95, #322700)}.text-yellow_90.sc-sd-guide{color:var(--color-yellow_90, #453702)}.text-yellow_80.sc-sd-guide{color:var(--color-yellow_80, #6C5602)}.text-yellow_70.sc-sd-guide{color:var(--color-yellow_70, #9C7A00)}.text-yellow_60.sc-sd-guide{color:var(--color-yellow_60, #C49900)}.text-yellow_50.sc-sd-guide{color:var(--color-yellow_50, #EBB800)}.text-yellow_45.sc-sd-guide{color:var(--color-yellow_45, #FFC700)}.text-yellow_40.sc-sd-guide{color:var(--color-yellow_40, #FFD643)}.text-yellow_30.sc-sd-guide{color:var(--color-yellow_30, #FEE17C)}.text-yellow_25.sc-sd-guide{color:var(--color-yellow_25, #FFE99E)}.text-yellow_20.sc-sd-guide{color:var(--color-yellow_20, #FEF1C4)}.text-yellow_10.sc-sd-guide{color:var(--color-yellow_10, #FFF7DD)}.text-olive_95.sc-sd-guide{color:var(--color-olive_95, #2C2C00)}.text-olive_90.sc-sd-guide{color:var(--color-olive_90, #454500)}.text-olive_80.sc-sd-guide{color:var(--color-olive_80, #636300)}.text-olive_70.sc-sd-guide{color:var(--color-olive_70, #838300)}.text-olive_65.sc-sd-guide{color:var(--color-olive_65, #A5A500)}.text-olive_55.sc-sd-guide{color:var(--color-olive_55, #C7C700)}.text-olive_45.sc-sd-guide{color:var(--color-olive_45, #DDDD12)}.text-olive_30.sc-sd-guide{color:var(--color-olive_30, #EEEE37)}.text-olive_20.sc-sd-guide{color:var(--color-olive_20, #F6F65F)}.text-olive_15.sc-sd-guide{color:var(--color-olive_15, #FAFAA1)}.text-olive_10.sc-sd-guide{color:var(--color-olive_10, #FBFBBF)}.text-olive_05.sc-sd-guide{color:var(--color-olive_05, #FEFED9)}.text-green_99.sc-sd-guide{color:var(--color-green_99, #001D0B)}.text-green_95.sc-sd-guide{color:var(--color-green_95, #003013)}.text-green_90.sc-sd-guide{color:var(--color-green_90, #00461C)}.text-green_85.sc-sd-guide{color:var(--color-green_85, #006629)}.text-green_80.sc-sd-guide{color:var(--color-green_80, #007B31)}.text-green_75.sc-sd-guide{color:var(--color-green_75, #00973C)}.text-green_70.sc-sd-guide{color:var(--color-green_70, #12B553)}.text-green_65.sc-sd-guide{color:var(--color-green_65, #2BCE6C)}.text-green_55.sc-sd-guide{color:var(--color-green_55, #6DE39C)}.text-green_45.sc-sd-guide{color:var(--color-green_45, #ACF4C9)}.text-green_25.sc-sd-guide{color:var(--color-green_25, #D4FAE3)}.text-green_15.sc-sd-guide{color:var(--color-green_15, #E8F9EF)}.text-steelblue_99.sc-sd-guide{color:var(--color-steelblue_99, #021a25)}.text-steelblue_95.sc-sd-guide{color:var(--color-steelblue_95, #02212f)}.text-steelblue_90.sc-sd-guide{color:var(--color-steelblue_90, #032d40)}.text-steelblue_85.sc-sd-guide{color:var(--color-steelblue_85, #033f59)}.text-steelblue_80.sc-sd-guide{color:var(--color-steelblue_80, #06587d)}.text-steelblue_75.sc-sd-guide{color:var(--color-steelblue_75, #066d9b)}.text-steelblue_70.sc-sd-guide{color:var(--color-steelblue_70, #128fc7)}.text-steelblue_65.sc-sd-guide{color:var(--color-steelblue_65, #229fd7)}.text-steelblue_60.sc-sd-guide{color:var(--color-steelblue_60, #50bff0)}.text-steelblue_45.sc-sd-guide{color:var(--color-steelblue_45, #a4e2fd)}.text-steelblue_25.sc-sd-guide{color:var(--color-steelblue_25, #d9f2fd)}.text-steelblue_10.sc-sd-guide{color:var(--color-steelblue_10, #ecf8fd)}.text-oceanblue_99.sc-sd-guide{color:var(--color-oceanblue_99, #011428)}.text-oceanblue_95.sc-sd-guide{color:var(--color-oceanblue_95, #03172d)}.text-oceanblue_90.sc-sd-guide{color:var(--color-oceanblue_90, #051d36)}.text-oceanblue_85.sc-sd-guide{color:var(--color-oceanblue_85, #07284a)}.text-oceanblue_80.sc-sd-guide{color:var(--color-oceanblue_80, #004177)}.text-oceanblue_75.sc-sd-guide{color:var(--color-oceanblue_75, #025497)}.text-oceanblue_70.sc-sd-guide{color:var(--color-oceanblue_70, #006ac1)}.text-oceanblue_65.sc-sd-guide{color:var(--color-oceanblue_65, #1f8ae1)}.text-oceanblue_60.sc-sd-guide{color:var(--color-oceanblue_60, #5cb0f3)}.text-oceanblue_50.sc-sd-guide{color:var(--color-oceanblue_50, #9cd1fc)}.text-oceanblue_25.sc-sd-guide{color:var(--color-oceanblue_25, #d5ebfe)}.text-oceanblue_15.sc-sd-guide{color:var(--color-oceanblue_15, #eaf5fe)}.text-brilliantblue_99.sc-sd-guide{color:var(--color-brilliantblue_99, #001226)}.text-brilliantblue_95.sc-sd-guide{color:var(--color-brilliantblue_95, #001b39)}.text-brilliantblue_90.sc-sd-guide{color:var(--color-brilliantblue_90, #002b5e)}.text-brilliantblue_85.sc-sd-guide{color:var(--color-brilliantblue_85, #004290)}.text-brilliantblue_80.sc-sd-guide{color:var(--color-brilliantblue_80, #005cc9)}.text-brilliantblue_75.sc-sd-guide{color:var(--color-brilliantblue_75, #0075ff)}.text-brilliantblue_70.sc-sd-guide{color:var(--color-brilliantblue_70, #2d8dff)}.text-brilliantblue_60.sc-sd-guide{color:var(--color-brilliantblue_60, #64abff)}.text-brilliantblue_50.sc-sd-guide{color:var(--color-brilliantblue_50, #93c4ff)}.text-brilliantblue_40.sc-sd-guide{color:var(--color-brilliantblue_40, #bbdaff)}.text-brilliantblue_25.sc-sd-guide{color:var(--color-brilliantblue_25, #d9eaff)}.text-brilliantblue_20.sc-sd-guide{color:var(--color-brilliantblue_20, #e6f1ff)}.text-brilliantblue_10.sc-sd-guide{color:var(--color-brilliantblue_10, #eff6ff)}.text-brilliantblue_05.sc-sd-guide{color:var(--color-brilliantblue_05, #f5faff)}.text-grey_95.sc-sd-guide{color:var(--color-grey_95, #222222)}.text-grey_90.sc-sd-guide{color:var(--color-grey_90, #333333)}.text-grey_85.sc-sd-guide{color:var(--color-grey_85, #444444)}.text-grey_80.sc-sd-guide{color:var(--color-grey_80, #555555)}.text-grey_70.sc-sd-guide{color:var(--color-grey_70, #737373)}.text-grey_65.sc-sd-guide{color:var(--color-grey_65, #888888)}.text-grey_60.sc-sd-guide{color:var(--color-grey_60, #999999)}.text-grey_55.sc-sd-guide{color:var(--color-grey_55, #aaaaaa)}.text-grey_50.sc-sd-guide{color:var(--color-grey_50, #bbbbbb)}.text-grey_45.sc-sd-guide{color:var(--color-grey_45, #cccccc)}.text-grey_35.sc-sd-guide{color:var(--color-grey_35, #D8D8D8)}.text-grey_30.sc-sd-guide{color:var(--color-grey_30, #e1e1e1)}.text-grey_25.sc-sd-guide{color:var(--color-grey_25, #E5E5E5)}.text-grey_20.sc-sd-guide{color:var(--color-grey_20, #eeeeee)}.text-grey_10.sc-sd-guide{color:var(--color-grey_10, #f6f6f6)}.text-grey_05.sc-sd-guide{color:var(--color-grey_05, #f9f9f9)}.text-white.sc-sd-guide{color:var(--color-white, #ffffff)}.text-black.sc-sd-guide{color:var(--color-black, #000000)}*.sc-sd-guide,*.sc-sd-guide::before,*.sc-sd-guide::after{box-sizing:border-box}html.sc-sd-guide{-moz-text-size-adjust:none;-webkit-text-size-adjust:none;text-size-adjust:none}body.sc-sd-guide,h1.sc-sd-guide,h2.sc-sd-guide,h3.sc-sd-guide,h4.sc-sd-guide,p.sc-sd-guide,figure.sc-sd-guide,blockquote.sc-sd-guide,dl.sc-sd-guide,dd.sc-sd-guide{margin-block-end:0}ul[role=list].sc-sd-guide,ol[role=list].sc-sd-guide{list-style:none}body.sc-sd-guide{min-height:100vh;line-height:1.5}h1.sc-sd-guide,h2.sc-sd-guide,h3.sc-sd-guide,h4.sc-sd-guide,button.sc-sd-guide,input.sc-sd-guide,label.sc-sd-guide{line-height:1}h1.sc-sd-guide,h2.sc-sd-guide,h3.sc-sd-guide,h4.sc-sd-guide{text-wrap:balance}a.sc-sd-guide:not([class]){text-decoration-skip-ink:auto;color:currentColor}img.sc-sd-guide,picture.sc-sd-guide{max-width:100%;display:block}input.sc-sd-guide,button.sc-sd-guide,textarea.sc-sd-guide,select.sc-sd-guide{font-size:inherit}.sc-sd-guide:target{scroll-margin-block:5ex}button.sc-sd-guide{background:none;border:none;cursor:pointer;padding:0;outline:0}button.sc-sd-guide:focus{outline:0 !important}.sc-sd-guide-h{display:inline-block;height:fit-content;line-height:0}.text-center.sc-sd-guide{text-align:center}.text-right.sc-sd-guide{text-align:right}.text-left.sc-sd-guide{text-align:left}input[type=text].sc-sd-guide,input[type=number].sc-sd-guide,input[type=password].sc-sd-guide,input[type=email].sc-sd-guide,input[type=tel].sc-sd-guide,textarea.sc-sd-guide{padding-block:0px;padding-inline:0px}.sd-hoverable.sc-sd-guide:hover>.sd-focus-helper.sc-sd-guide{background:currentColor;opacity:0.15}.sd-hoverable.sc-sd-guide:hover>.sd-focus-helper.sc-sd-guide:before{opacity:0.1}.sd-hoverable.sc-sd-guide:hover>.sd-focus-helper.sc-sd-guide:after{opacity:0.4}.sd-focus-helper.sc-sd-guide{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:inherit;opacity:0;transition:background-color 0.3s cubic-bezier(0.25, 0.8, 0.5, 1), opacity 0.4s cubic-bezier(0.25, 0.8, 0.5, 1)}.sd-focus-helper.sc-sd-guide:before,.sd-focus-helper.sc-sd-guide:after{content:\"\";position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;border-radius:inherit;transition:background-color 0.3s cubic-bezier(0.25, 0.8, 0.5, 1), opacity 0.6s cubic-bezier(0.25, 0.8, 0.5, 1)}.sd-focus-helper.sc-sd-guide:before{background:#000000}.sd-focus-helper.sc-sd-guide:after{background:#ffffff}.sd-tooltip-menu.sc-sd-guide{width:fit-content;padding:8px 16px;border-radius:4px;color:white;background:#07284a;font-size:12px;position:relative;box-sizing:border-box;display:flex;align-items:start;justify-content:center;gap:12px}.sd-tooltip-menu--with-close.sc-sd-guide{padding-right:12px !important}.sd-tooltip-menu__arrow.sc-sd-guide{position:absolute;display:flex;width:9.6px;height:7.2px}.sd-tooltip-menu__arrow.sc-sd-guide svg.sc-sd-guide{width:100%;height:100%}.sd-tooltip-menu__arrow--top.sc-sd-guide{bottom:-7.2px;left:50%;transform:translateX(-50%)}.sd-tooltip-menu__arrow--bottom.sc-sd-guide{top:-7.2px;left:50%;transform:translateX(-50%) rotate(180deg)}.sd-tooltip-menu__arrow--left.sc-sd-guide{right:-7.2px;top:50%;transform:translateY(-50%) rotate(-90deg)}.sd-tooltip-menu__arrow--right.sc-sd-guide{left:-7.2px;top:50%;transform:translateY(-50%) rotate(90deg)}.sd-tooltip-menu__content.sc-sd-guide{line-height:20px;font-weight:500}.sd-tooltip-menu__close-button.sc-sd-guide{padding-top:4px;display:flex}.sd-tooltip-menu__close-button.sc-sd-guide button.sc-sd-guide{padding:0;background:none;border:none;cursor:pointer}.sd-popover-menu.sc-sd-guide{width:fit-content;padding:12px 20px;border-radius:4px;color:white;background:#07284a;font-size:12px;position:relative;box-sizing:border-box}.sd-popover-menu__arrow.sc-sd-guide{position:absolute;display:flex;width:9.6px;height:7.2px}.sd-popover-menu__arrow.sc-sd-guide svg.sc-sd-guide{width:100%;height:100%}.sd-popover-menu__arrow--top.sc-sd-guide{bottom:-7.2px;left:50%;transform:translateX(-50%)}.sd-popover-menu__arrow--bottom.sc-sd-guide{top:-7.2px;left:50%;transform:translateX(-50%) rotate(180deg)}.sd-popover-menu__arrow--left.sc-sd-guide{right:-7.2px;top:50%;transform:translateY(-50%) rotate(-90deg)}.sd-popover-menu__arrow--right.sc-sd-guide{left:-7.2px;top:50%;transform:translateY(-50%) rotate(90deg)}.sd-popover-menu__content.sc-sd-guide{font-size:12px;line-height:20px}.sd-popover-menu__content.sc-sd-guide .sd-popover-menu__title.sc-sd-guide{font-weight:700;margin-bottom:4px}.sd-popover-menu__content.sc-sd-guide .sd-popover-menu__messages.sc-sd-guide{font-weight:500}.sd-popover-menu__content.sc-sd-guide .sd-popover-menu__buttons.sc-sd-guide{margin-top:12px;display:flex;gap:8px;align-items:center}.sd-popover-menu__content.sc-sd-guide .sd-popover-menu__buttons--1.sc-sd-guide{justify-content:flex-end}.sd-popover-menu__content.sc-sd-guide .sd-popover-menu__buttons--2.sc-sd-guide{justify-content:space-between}.sd-popover-menu__close-button.sc-sd-guide{position:absolute;top:16px;right:12px;padding:0;background:none;border:none;cursor:pointer}.sd-guide.sc-sd-guide .sc-sd-guide:deep(.sd-button){padding:0 16px 0 12px;border-radius:16px}.sd-guide.sc-sd-guide .sc-sd-guide:deep(.sd-button) .sd-button__content.sc-sd-guide .sd-button__label.sc-sd-guide{color:#333333}.sd-guide__popup.sc-sd-guide{position:relative;padding:20px 32px;border-radius:8px;box-shadow:4px 4px 24px 4px rgba(0, 0, 0, 0.1);background:white}.sd-guide__popup__close.sc-sd-guide{position:absolute;top:12px;right:12px}.sd-guide__popup__header.sc-sd-guide{display:flex;align-items:center;gap:8px;margin-bottom:12px}.sd-guide__popup__header.sc-sd-guide .sd-guide__popup__title.sc-sd-guide{margin-top:0;font-size:16px;font-weight:700;line-height:26px;color:#333333}.sd-guide__popup__list.sc-sd-guide{width:100%;padding:0;margin:0}.sd-guide__popup__list__item.sc-sd-guide{display:flex;width:100%;align-items:start;list-style:none;color:#333333;font-size:12px;font-weight:400}.sd-guide__popup__list__item.sc-sd-guide p.sc-sd-guide{width:100%;padding:0;margin:0;word-wrap:break-word;word-break:break-word;white-space:normal;overflow-wrap:break-word;min-width:0}.sd-guide__popup__list__item.sc-sd-guide::before{display:block;content:\"-\";width:6px;color:#333333;font-size:12px;font-weight:400;margin-left:10px;margin-right:12px;flex-shrink:0}.sd-guide__popup__list__item--depth-2.sc-sd-guide::before{content:\"•\"}.sd-guide__popup__list__item--depth-2.sc-sd-guide{padding-left:26px}";
|
|
7
7
|
|
|
8
|
+
const GUIDE_LABEL = {
|
|
9
|
+
help: '활용 TIP',
|
|
10
|
+
pdf: 'PDF Guide',
|
|
11
|
+
youtube: 'Video Guide',
|
|
12
|
+
notion: '사용 가이드',
|
|
13
|
+
event: 'Event Button',
|
|
14
|
+
};
|
|
15
|
+
const GUIDE_ICON = {
|
|
16
|
+
help: {
|
|
17
|
+
name: 'helpOutline',
|
|
18
|
+
size: 20,
|
|
19
|
+
color: color.colors.green_65,
|
|
20
|
+
},
|
|
21
|
+
pdf: { name: 'pdf', size: 20, color: color.colors.red_75 },
|
|
22
|
+
youtube: { name: 'youtube', size: 20, color: color.colors.red_75 },
|
|
23
|
+
notion: { name: 'notion', size: 16, color: color.colors.black },
|
|
24
|
+
event: { name: 'event', size: 16, color: color.colors.brilliantblue_70 },
|
|
25
|
+
};
|
|
8
26
|
const SdGuide = class {
|
|
9
27
|
constructor(hostRef) {
|
|
10
28
|
index.registerInstance(this, hostRef);
|
|
11
29
|
}
|
|
12
30
|
get el() { return index.getElement(this); }
|
|
13
31
|
type = 'help';
|
|
14
|
-
|
|
32
|
+
label = '';
|
|
15
33
|
message = '';
|
|
16
34
|
guideUrl = '';
|
|
17
35
|
popupWidth;
|
|
18
36
|
popupShow = false;
|
|
19
37
|
guideRef;
|
|
20
|
-
static guideTitle = {
|
|
21
|
-
help: '활용 Tip',
|
|
22
|
-
pdf: 'PDF Guide',
|
|
23
|
-
youtube: 'Video Guide',
|
|
24
|
-
notion: '사용 가이드',
|
|
25
|
-
event: 'Event Button',
|
|
26
|
-
};
|
|
27
38
|
handleClickGuide = () => {
|
|
28
39
|
if (this.type === 'help') {
|
|
29
40
|
this.popupShow = !this.popupShow;
|
|
@@ -33,58 +44,59 @@ const SdGuide = class {
|
|
|
33
44
|
window.open(this.guideUrl, '_blank');
|
|
34
45
|
}
|
|
35
46
|
};
|
|
36
|
-
|
|
37
|
-
const classes = ['sd-guide'];
|
|
38
|
-
classes.push(`sd-guide--${this.type}`);
|
|
47
|
+
get guideClass() {
|
|
48
|
+
const classes = ['sd-guide', `sd-guide--${this.type}`];
|
|
39
49
|
if (this.popupShow)
|
|
40
50
|
classes.push('sd-guide--active');
|
|
41
51
|
return classes.join(' ');
|
|
42
52
|
}
|
|
43
|
-
getGuideStyle() {
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
return { name: 'event', size: 16, color: color.colors.brilliantblue_70 };
|
|
69
|
-
}
|
|
70
|
-
return { name: 'helpOutline', size: 20, color: this.popupShow ? color.colors.white : color.colors.green_65 };
|
|
71
|
-
}
|
|
53
|
+
// private getGuideStyle(): StyleProps {
|
|
54
|
+
// const styles: StyleProps = {};
|
|
55
|
+
// if (this.type === 'help') {
|
|
56
|
+
// styles['--guide-border'] = this.popupShow ? colors.green_65 : colors.grey_45;
|
|
57
|
+
// styles['--guide-color'] = this.popupShow ? colors.white : colors.grey_90;
|
|
58
|
+
// styles['--guide-background'] = this.popupShow ? colors.green_65 : colors.white;
|
|
59
|
+
// } else {
|
|
60
|
+
// styles['--guide-border'] = colors.grey_45;
|
|
61
|
+
// styles['--guide-color'] = colors.grey_90;
|
|
62
|
+
// styles['--guide-background'] = colors.white;
|
|
63
|
+
// }
|
|
64
|
+
// return styles;
|
|
65
|
+
// }
|
|
66
|
+
// private getGuidIcon(): { name: IconName; size: number; color: string } {
|
|
67
|
+
// if (this.type === 'pdf') {
|
|
68
|
+
// return { name: 'pdf', size: 20, color: colors.red_75 };
|
|
69
|
+
// } else if (this.type === 'youtube') {
|
|
70
|
+
// return { name: 'youtube', size: 20, color: colors.red_75 };
|
|
71
|
+
// } else if (this.type === 'notion') {
|
|
72
|
+
// return { name: 'notion', size: 16, color: colors.black };
|
|
73
|
+
// } else if (this.type === 'event') {
|
|
74
|
+
// return { name: 'event', size: 16, color: colors.brilliantblue_70 };
|
|
75
|
+
// }
|
|
76
|
+
// return { name: 'helpOutline', size: 20, color: this.popupShow ? colors.white : colors.green_65 };
|
|
77
|
+
// }
|
|
72
78
|
closeDropdown = () => {
|
|
73
79
|
this.popupShow = false;
|
|
74
80
|
};
|
|
75
81
|
render() {
|
|
76
|
-
const { name: iconName, size: iconSize, color: iconColor } = this.getGuidIcon();
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
82
|
+
// const { name: iconName, size: iconSize, color: iconColor } = this.getGuidIcon();
|
|
83
|
+
const { name: iconName, size: iconSize, color: iconColor } = GUIDE_ICON[this.type];
|
|
84
|
+
return (index.h(index.Host, { key: '9f8b8af98d5bbcbde8544d0e8e337068e8e5778d' }, index.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,
|
|
85
|
+
// iconStyle={{ marginRight: '4px' }}
|
|
86
|
+
// buttonStyle={{
|
|
87
|
+
// height: '28px',
|
|
88
|
+
// minHeight: '28px',
|
|
89
|
+
// padding: '4px 12px',
|
|
90
|
+
// borderRadius: '16px',
|
|
91
|
+
// borderColor: 'var(--guide-border)',
|
|
92
|
+
// color: 'var(--guide-color)',
|
|
93
|
+
// fontSize: '12px',
|
|
94
|
+
// fontWeight: '400',
|
|
95
|
+
// backgroundColor: 'var(--guide-background)',
|
|
96
|
+
// }}
|
|
97
|
+
onSdClick: this.handleClickGuide }), this.type === 'help' && this.popupShow && (index.h("sd-portal", { key: '5e199a2c2d5bc42fa87c651ef4d07fa0ab091558', open: this.popupShow, parentRef: this.guideRef, onSdClose: this.closeDropdown, offset: [0, 4] }, index.h("div", { key: '625d746fedfc57df447f754ae477d89058152ead', class: "sd-guide__popup", style: { width: this.popupWidth ? this.popupWidth + 'px' : '426px' } }, index.h("sd-button", { key: 'ac0f7809af22910f677df3a3ec48dd370dac0f9e', class: "sd-guide__popup__close", icon: "close", color: color.colors.grey_65, size: "md", variant: "ghost", noHover: true,
|
|
98
|
+
// buttonStyle={{ padding: '0px', minHeight: '0px' }}
|
|
99
|
+
onSdClick: this.closeDropdown }), index.h("div", { key: '747244da8b2cd0c6b59bdaa2bc7967017dcc1a6b', class: "sd-guide__popup__header" }, index.h("sd-icon", { key: '7899329aed456415febc12184d7fb276eeb011fd', name: "helpOutline", size: 24, color: color.colors.green_65 }), index.h("h3", { key: '9cbbe86aa294d9831e1f7a3a6a0aece5b74b6171', class: "sd-guide__popup__title" }, this.label || GUIDE_LABEL[this.type])), index.h("ul", { key: '1a2cc3226c080db952adcf458511a5efec61e797', class: "sd-guide__popup__list" }, this.renderListItem(this.message)))))));
|
|
88
100
|
}
|
|
89
101
|
// 현재 2depth까지만 스타일 적용
|
|
90
102
|
renderListItem(message, depth = 0) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sd-guide.entry.cjs.js","sources":["src/components/sd-guide/sd-guide.scss?tag=sd-guide&encapsulation=scoped","src/components/sd-guide/sd-guide.tsx"],"sourcesContent":["@import '../../styles/global.scss';\r\n\r\n.sd-guide__popup {\r\n position: relative;\r\n padding: 20px 32px;\r\n border-radius: 8px;\r\n box-shadow: 4px 4px 24px 4px rgba(0, 0, 0, 0.1);\r\n background: white;\r\n\r\n &__close {\r\n position: absolute;\r\n top: 12px;\r\n right: 12px;\r\n }\r\n\r\n &__header {\r\n display: flex;\r\n align-items: center;\r\n gap: 8px;\r\n margin-bottom: 12px;\r\n\r\n .sd-guide__popup__title {\r\n margin-top: 0;\r\n font-size: 16px;\r\n font-weight: 700;\r\n line-height: 26px;\r\n color: $grey_90;\r\n }\r\n }\r\n\r\n &__list {\r\n width: 100%;\r\n padding: 0;\r\n margin: 0;\r\n\r\n &__item {\r\n display: flex;\r\n width: 100%;\r\n align-items: start;\r\n list-style: none;\r\n color: $grey_90;\r\n font-size: 12px;\r\n font-weight: 400;\r\n\r\n p {\r\n width: 100%;\r\n padding: 0;\r\n margin: 0;\r\n word-wrap: break-word;\r\n word-break: break-word;\r\n white-space: normal;\r\n overflow-wrap: break-word;\r\n min-width: 0;\r\n }\r\n\r\n &::before {\r\n display: block;\r\n content: '-';\r\n width: 6px;\r\n color: $grey_90;\r\n font-size: 12px;\r\n font-weight: 400;\r\n margin-left: 10px;\r\n margin-right: 12px;\r\n flex-shrink: 0;\r\n }\r\n\r\n &--depth-2 {\r\n &::before {\r\n content: '•';\r\n }\r\n padding-left: 26px;\r\n }\r\n }\r\n }\r\n}\r\n","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, ' ');\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"],"names":["colors","h","Host"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"sd-guide.entry.cjs.js","sources":["src/components/sd-guide/sd-guide.scss?tag=sd-guide&encapsulation=scoped","src/components/sd-guide/sd-guide.tsx"],"sourcesContent":["@import '../../styles/global.scss';\r\n\r\n.sd-guide {\r\n // &--active {\r\n // .ad-button {\r\n // }\r\n // }\r\n :deep(.sd-button) {\r\n padding: 0 16px 0 12px;\r\n border-radius: 16px;\r\n\r\n .sd-button__content {\r\n .sd-button__label {\r\n color: $grey_90;\r\n }\r\n }\r\n }\r\n}\r\n\r\n.sd-guide__popup {\r\n position: relative;\r\n padding: 20px 32px;\r\n border-radius: 8px;\r\n box-shadow: 4px 4px 24px 4px rgba(0, 0, 0, 0.1);\r\n background: white;\r\n\r\n &__close {\r\n position: absolute;\r\n top: 12px;\r\n right: 12px;\r\n }\r\n\r\n &__header {\r\n display: flex;\r\n align-items: center;\r\n gap: 8px;\r\n margin-bottom: 12px;\r\n\r\n .sd-guide__popup__title {\r\n margin-top: 0;\r\n font-size: 16px;\r\n font-weight: 700;\r\n line-height: 26px;\r\n color: $grey_90;\r\n }\r\n }\r\n\r\n &__list {\r\n width: 100%;\r\n padding: 0;\r\n margin: 0;\r\n\r\n &__item {\r\n display: flex;\r\n width: 100%;\r\n align-items: start;\r\n list-style: none;\r\n color: $grey_90;\r\n font-size: 12px;\r\n font-weight: 400;\r\n\r\n p {\r\n width: 100%;\r\n padding: 0;\r\n margin: 0;\r\n word-wrap: break-word;\r\n word-break: break-word;\r\n white-space: normal;\r\n overflow-wrap: break-word;\r\n min-width: 0;\r\n }\r\n\r\n &::before {\r\n display: block;\r\n content: '-';\r\n width: 6px;\r\n color: $grey_90;\r\n font-size: 12px;\r\n font-weight: 400;\r\n margin-left: 10px;\r\n margin-right: 12px;\r\n flex-shrink: 0;\r\n }\r\n\r\n &--depth-2 {\r\n &::before {\r\n content: '•';\r\n }\r\n padding-left: 26px;\r\n }\r\n }\r\n }\r\n}\r\n","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, ' ');\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"],"names":["colors","h","Host"],"mappings":"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"}
|
|
@@ -83,12 +83,12 @@ const SdPagination = class {
|
|
|
83
83
|
}
|
|
84
84
|
}
|
|
85
85
|
render() {
|
|
86
|
-
return (index.h("div", { key: '
|
|
86
|
+
return (index.h("div", { key: 'ae962ed1dfbcb79c23c402d52d0a83822b54d4b3', class: this.paginationClasses }, index.h("div", { key: 'efa0dfbcc8d71d2b9ff5b02334a3d1e119a7f469', class: "prepend-btns" }, this.renderPrevButtons()), this.simple ? (index.h("div", { class: "pagination-info" }, index.h("span", { class: "current-page" }, this.currentPage), index.h("span", null, "/"), index.h("span", { class: "last-page" }, this.lastPage))) : (this.pageNumbers.map(n => (index.h("button", { type: "button", "aria-current": this.currentPage === n ? 'page' : undefined, class: {
|
|
87
87
|
'pagination-btn': true,
|
|
88
88
|
'pagination-btn--selected': this.currentPage === n,
|
|
89
89
|
}, disabled: this.currentPage === n, style: {
|
|
90
90
|
'--pagination-btn-width': `${this.buttonWidth}px`,
|
|
91
|
-
}, onClick: () => this.handlePageChange(n) }, n)))), index.h("div", { key: '
|
|
91
|
+
}, onClick: () => this.handlePageChange(n) }, n)))), index.h("div", { key: 'f0bd3b291453696e22a34f182a852a2a092874f2', class: "append-btns" }, this.renderNextButtons())));
|
|
92
92
|
}
|
|
93
93
|
static get watchers() { return {
|
|
94
94
|
"currentPage": ["onPropChange"],
|
|
@@ -129,11 +129,11 @@ const SdTooltip = class {
|
|
|
129
129
|
: {
|
|
130
130
|
onClick: () => (console.log('click tooltip'), (this.showTooltip = !this.showTooltip)),
|
|
131
131
|
};
|
|
132
|
-
return (index.h(index.Fragment, { key: '
|
|
132
|
+
return (index.h(index.Fragment, { key: 'db5f9498990b6cc3941a1f276dc7b437f00ae3b1' }, this.label ? (index.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-tooltip", ...handleTrigger })) : (index.h("sd-icon", { ref: el => (this.buttonEl = el), name: this.icon, size: this.iconSize, color: this.color, class: "sd-tooltip", ...handleTrigger })), this.showTooltip && (index.h("sd-tooltip-portal", { key: '19e133936ac7d7efc95292c0053a6eace81e7ccb', parentRef: this.buttonEl, onSdClose: () => this.handleClose(), placement: this.placement }, index.h("div", { key: '2d0fed8f8f2f3e6dfe860c78f4c1af99f595e4d4', class: {
|
|
133
133
|
'sd-tooltip-menu': true,
|
|
134
134
|
[`sd-tooltip-menu--${this.placement}`]: true,
|
|
135
135
|
'sd-tooltip-menu--with-close': this.useClose,
|
|
136
|
-
} }, index.h("i", { key: '
|
|
136
|
+
} }, index.h("i", { key: '6ec7ba058e541d65eae3b5100ca8eb741a04d814', class: `sd-tooltip-menu__arrow sd-tooltip-menu__arrow--${this.placement}` }, index.h(tooltipArrow.TooltipArrow, { key: '550d0629d949f9da13117c3c569e886b44e8b9bd' })), index.h("div", { key: '4a1fc247b84457ee8c962804ca91bd93b4de8948', class: "sd-tooltip-menu__content" }, index.h("slot", { key: '444c621343b3eeba8f89e85f06b9b66e39b626b1' }, this.el.textContent)), this.useClose && (index.h("div", { key: '570364c37b97299922b4c52192d52d1e0e20228d', class: "sd-tooltip-menu__close-button" }, index.h("button", { key: '0e126ad1ed0238e8adbf7a82132e28c90bffa1a5', onClick: () => this.handleClose() }, index.h("sd-icon", { key: '796643e7a212b7a65f81671c46e2b992fe1ae0d1', name: "close", size: "12", color: "#AAAAAA" })))))))));
|
|
137
137
|
}
|
|
138
138
|
};
|
|
139
139
|
SdTooltip.style = sdTooltipCss;
|
|
@@ -39,11 +39,11 @@ const SdPopover = class {
|
|
|
39
39
|
this.showPopover = false;
|
|
40
40
|
};
|
|
41
41
|
render() {
|
|
42
|
-
return (index.h(index.Fragment, { key: '
|
|
42
|
+
return (index.h(index.Fragment, { key: 'fb877e8d016d13fb33b49a1a4dbfed9fc01b1336' }, this.label ? (index.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)) })) : (index.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 && (index.h("sd-tooltip-portal", { key: '02208721da61cb84086a57c823f8e31775fdbd5e', parentRef: this.buttonEl, onSdClose: this.handleClose, placement: this.placement }, index.h("div", { key: '3f3c4fc690dac5061bda08af37121e2b98374979', class: {
|
|
43
43
|
'sd-popover-menu': true,
|
|
44
44
|
[`sd-popover-menu--${this.placement}`]: true,
|
|
45
45
|
[this.menuClass]: !!this.menuClass,
|
|
46
|
-
} }, index.h("i", { key: '
|
|
46
|
+
} }, index.h("i", { key: '6f0df95bafc2cbf564fd0e5a133c89f03c3a924b', class: `sd-popover-menu__arrow sd-popover-menu__arrow--${this.placement}` }, index.h(tooltipArrow.TooltipArrow, { key: '535acee0be86db4ed58d6cc1631732541f1e475e' })), index.h("div", { key: 'd4366800a8cbd5a1f9630344a5ca4241b0eaa8dd', class: "sd-popover-menu__content" }, this.menuTitle && index.h("div", { key: '1cd9de3129988c5d26be0ded5b03520ab591cb9a', class: "sd-popover-menu__title" }, this.menuTitle), this.messages.length > 0 && (index.h("div", { key: '5aae57948bd5e0fd98e73a8ae504b77ce6cdbe07', class: "sd-popover-menu__messages" }, this.messages.map(message => (index.h("div", null, message))))), this.buttons.length > 0 && (index.h("div", { key: '814ac9ba0b2cf4367bb4cd5e688fa5433fee7126', class: `sd-popover-menu__buttons sd-popover-menu__buttons--${this.buttons.length}` }, this.buttons.map(button => (index.h("sd-button", { ...button })))))), this.useClose && (index.h("button", { key: 'a21ad0a5e28f8609b2f9d9accd0be5d81ed9de5b', class: "sd-popover-menu__close-button", onClick: () => this.handleClose() }, index.h("sd-icon", { key: '10738ec0926ea5fbc0b30b5c8c08b6cc37bf47d3', name: "close", size: "12", color: "#AAAAAA" }))))))));
|
|
47
47
|
}
|
|
48
48
|
static get watchers() { return {
|
|
49
49
|
"show": ["watchShowHandler"]
|
|
@@ -11,8 +11,8 @@ const SdTable = class {
|
|
|
11
11
|
this.sdPageChange = index.createEvent(this, "sdPageChange");
|
|
12
12
|
}
|
|
13
13
|
get el() { return index.getElement(this); }
|
|
14
|
-
columns
|
|
15
|
-
rows
|
|
14
|
+
columns;
|
|
15
|
+
rows;
|
|
16
16
|
selected = new Set();
|
|
17
17
|
rowKey = 'id';
|
|
18
18
|
selectable = false;
|
|
@@ -202,10 +202,10 @@ const SdTable = class {
|
|
|
202
202
|
}))))));
|
|
203
203
|
}
|
|
204
204
|
render() {
|
|
205
|
-
return (index.h(index.Host, { key: '
|
|
205
|
+
return (index.h(index.Host, { key: '84e1e86a1f537814c86b4d23e19d9e15110feeb5' }, index.h("div", { key: '38c189caa26fb8b32021e4445e0e9673c2913852', class: "sd-table__wrapper", style: {
|
|
206
206
|
'--table-width': this.width,
|
|
207
207
|
'--table-height': this.height,
|
|
208
|
-
} }, index.h("div", { key: '
|
|
208
|
+
} }, index.h("div", { key: 'e81e3a04ac13e9b049acda3ba3503d15dfcb0b5b', class: "sd-table__container" }, index.h("div", { key: '4be117d9789efd655e288159512947f272704bc6', class: "sd-table__middle" }, index.h("table", { key: '7b9985d135355e1c4fc5b96b098f044c8d4d4405', part: "table", class: this.sdTableClasses }, this.renderHeader(), this.renderBody())), index.h("div", { key: '0bef58541461eae84d674ebf6ff776ffe21778d2', class: "sd-table__bottom" })), this.pagination && this.innerRows.length > 0 && (index.h("div", { key: '0dbf69c7b87b3eb0cff3409fc3e3be8a03c66699', class: "sd-table__pagination" }, index.h("sd-pagination", { key: 'f924fd4b198f1015a9468673887e199e155ed821', currentPage: this.currentPage, lastPage: this.lastPageNumber, onPageChange: (e) => {
|
|
209
209
|
this.currentPage = e.detail;
|
|
210
210
|
this.sdPageChange.emit(this.currentPage);
|
|
211
211
|
} }))))));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sd-table.entry.cjs.js","sources":["src/components/sd-table/sd-table.scss?tag=sd-table","src/components/sd-table/sd-table.tsx"],"sourcesContent":["@import '../../styles/global.scss';\r\n\r\n.sd-table__wrapper {\r\n height: var(--table-height, auto);\r\n width: var(--table-width, 100%);\r\n\r\n .sd-table__container {\r\n width: 100%;\r\n height: auto;\r\n border: 1px solid $grey_30;\r\n border-radius: 8px;\r\n font-size: 12px;\r\n overflow: hidden;\r\n\r\n .sd-table__middle {\r\n overflow: auto;\r\n will-change: scroll-position;\r\n height: var(--table-height, auto);\r\n @extend %scrollBar;\r\n\r\n .sd-table {\r\n width: 100%;\r\n border-collapse: separate;\r\n border-spacing: 0;\r\n table-layout: fixed;\r\n\r\n &--selectable {\r\n td.sd-td--selected,\r\n th.sd-th--selected {\r\n width: 52px !important;\r\n max-width: 52px !important;\r\n min-width: 52px !important;\r\n padding: 0 10px 0 24px;\r\n text-align: left;\r\n }\r\n }\r\n\r\n &--sticky-header {\r\n thead {\r\n position: sticky;\r\n top: 0;\r\n z-index: 120;\r\n }\r\n }\r\n\r\n &--sticky-column {\r\n th.sticky-left,\r\n th.sticky-right {\r\n position: sticky;\r\n background-color: $th-bg;\r\n z-index: 110 !important;\r\n }\r\n td.sticky-left,\r\n td.sticky-right {\r\n position: sticky;\r\n background-color: white;\r\n z-index: 100 !important;\r\n }\r\n\r\n .sticky-left {\r\n left: var(--sticky-left-offset, 0);\r\n }\r\n .sticky-right {\r\n right: var(--sticky-right-offset, 0);\r\n }\r\n\r\n th.sticky-cell {\r\n position: sticky;\r\n z-index: 102;\r\n background-color: $th-bg;\r\n }\r\n td.sticky-cell {\r\n position: sticky;\r\n z-index: 101;\r\n background-color: white;\r\n }\r\n }\r\n\r\n &--scrolled-left {\r\n th.sticky-left-edge,\r\n td.sticky-left-edge {\r\n overflow: visible;\r\n &:after {\r\n content: '';\r\n position: absolute;\r\n top: 0;\r\n left: 100%;\r\n right: -20px;\r\n width: 20px;\r\n height: 100%;\r\n z-index: 101 !important;\r\n box-shadow: inset 12px 0 20px -25px;\r\n opacity: 1;\r\n pointer-events: none;\r\n }\r\n }\r\n }\r\n\r\n &--scrolled-right {\r\n th.sticky-right-edge,\r\n td.sticky-right-edge {\r\n overflow: visible;\r\n\r\n &:after {\r\n content: '';\r\n position: absolute;\r\n top: 0;\r\n left: -20px;\r\n width: 20px;\r\n height: 100%;\r\n z-index: 101 !important;\r\n box-shadow: inset -12px 0 20px -25px;\r\n opacity: 1;\r\n pointer-events: none;\r\n }\r\n }\r\n }\r\n\r\n &--no-data {\r\n thead {\r\n opacity: 0.4;\r\n tr {\r\n th {\r\n &.sd-th {\r\n border-bottom: 1px solid rgba(225, 225, 225, 0.4) !important;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n\r\n td,\r\n th,\r\n .sd-th__content--label {\r\n overflow: hidden;\r\n white-space: nowrap;\r\n text-overflow: ellipsis;\r\n word-break: keep-all;\r\n }\r\n\r\n thead {\r\n height: 36px;\r\n\r\n tr {\r\n width: 100%;\r\n\r\n th {\r\n background: $th-bg;\r\n height: 36px;\r\n padding: 0 16px;\r\n font-weight: 500;\r\n vertical-align: middle;\r\n border-bottom: 1px solid $grey_30;\r\n -webkit-user-select: none;\r\n user-select: none;\r\n position: relative;\r\n\r\n &.sd-th {\r\n .sd-th__content {\r\n display: flex;\r\n flex-flow: row nowrap;\r\n align-items: center;\r\n gap: 4px;\r\n\r\n &--left {\r\n justify-content: flex-start;\r\n }\r\n &--center {\r\n justify-content: center;\r\n }\r\n &--right {\r\n justify-content: flex-end;\r\n }\r\n }\r\n\r\n .sd-th__resizer {\r\n position: absolute;\r\n top: 50%;\r\n right: 0;\r\n transform: translateY(-50%);\r\n width: 4px;\r\n height: 16px;\r\n cursor: col-resize;\r\n z-index: 3;\r\n border-left: 1px solid $grey_45;\r\n border-right: 1px solid $grey_45;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n\r\n tbody {\r\n tr {\r\n &:last-of-type {\r\n td {\r\n border-bottom: none;\r\n }\r\n }\r\n td {\r\n height: 44px;\r\n padding: 0 16px;\r\n border-bottom: 1px solid $grey_30;\r\n background: white;\r\n vertical-align: middle;\r\n\r\n &.sd-td {\r\n &--left {\r\n text-align: left;\r\n }\r\n &--center {\r\n text-align: center;\r\n }\r\n &--right {\r\n text-align: right;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n }\r\n }\r\n\r\n .sd-table__bottom {\r\n background: white;\r\n text-align: center;\r\n }\r\n }\r\n\r\n .sd-table__pagination {\r\n background: $grey_05;\r\n height: 48px;\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n border: 1px solid $grey_30;\r\n border-top: none;\r\n border-radius: 8px;\r\n }\r\n}\r\n","import {\r\n Component,\r\n Element,\r\n Prop,\r\n State,\r\n Event,\r\n Watch,\r\n h,\r\n EventEmitter,\r\n Host,\r\n} from '@stencil/core';\r\n\r\nexport type SdTableSortDir = 'asc' | 'desc' | 'none';\r\n\r\nexport interface SdTableColumn {\r\n name: string;\r\n label: string;\r\n field: string | ((row: any) => any);\r\n align?: 'left' | 'center' | 'right';\r\n width?: string;\r\n format?: (value: any, row: any) => string;\r\n visible?: boolean;\r\n usePageMoveIcon?: boolean;\r\n tooltip?: string[];\r\n tooltipOptions?: Record<string, any>;\r\n}\r\n\r\nexport interface Row {\r\n [key: string]: any;\r\n}\r\n\r\n@Component({\r\n tag: 'sd-table',\r\n styleUrl: 'sd-table.scss',\r\n})\r\nexport class SdTable {\r\n @Element() el!: HTMLElement;\r\n\r\n @Prop() columns: SdTableColumn[] = [];\r\n @Prop({ mutable: true }) rows: Row[] = [];\r\n @Prop({ mutable: true }) selected: Set<Row> = new Set();\r\n @Prop() rowKey: string = 'id';\r\n @Prop() selectable: boolean = false;\r\n @Prop() resizable: boolean = false;\r\n @Prop() width?: string;\r\n @Prop() height?: string;\r\n @Prop() stickyHeader: boolean = false;\r\n @Prop() stickyColumn: { left?: number; right?: number } = { left: 0, right: 0 };\r\n @Prop() noDataLabel: string = '데이터가 없습니다.';\r\n @Prop() pagination?: {\r\n page: number;\r\n rowsPerPage: number;\r\n lastPage?: number;\r\n };\r\n @Prop() bodyCellRenderer?: (\r\n column: SdTableColumn,\r\n row: Row,\r\n ) => HTMLElement | string | null | undefined;\r\n\r\n @Event() sdSelectChange!: EventEmitter<Row[]>;\r\n @Event() sdPageChange!: EventEmitter<number>;\r\n\r\n @State() currentPage: number = this.pagination?.page || 1;\r\n @State() innerRows: Row[] = [];\r\n @State() innerSelected: Set<Row> = new Set();\r\n @State() columnWidths: number[] = [];\r\n @State() scrolledLeft: boolean = false;\r\n @State() scrolledRight: boolean = false;\r\n\r\n @Watch('columns')\r\n handleColumnsChange(newCols: SdTableColumn[]) {\r\n this.columnWidths = newCols.map(c => parseInt(c.width || '120', 10));\r\n }\r\n\r\n @Watch('rows')\r\n handleRowsChange(newRows: Row[]) {\r\n this.innerRows = [...newRows];\r\n }\r\n\r\n @Watch('selected')\r\n handleSelectedChange(newSelected: Set<Row>) {\r\n this.innerSelected = new Set(newSelected);\r\n }\r\n\r\n @Watch('pagination')\r\n handlePaginationChange(\r\n newVal?: { page: number; rowsPerPage: number; lastPage?: number } | undefined,\r\n ) {\r\n if (newVal?.page && newVal.page !== this.currentPage) this.currentPage = newVal.page;\r\n }\r\n\r\n componentWillLoad() {\r\n this.innerRows = [...this.rows];\r\n this.innerSelected = new Set(this.selected);\r\n this.columnWidths = this.columns.map(c => parseInt(c.width || '120', 10));\r\n }\r\n\r\n componentDidLoad() {\r\n const middle = this.el.querySelector('.sd-table__middle');\r\n if (!middle) return;\r\n\r\n const onScroll = () => {\r\n const { scrollLeft, scrollWidth, clientWidth } = middle as HTMLElement;\r\n this.scrolledLeft = scrollLeft > 0;\r\n this.scrolledRight = scrollLeft + clientWidth < scrollWidth;\r\n };\r\n middle.addEventListener('scroll', onScroll, { passive: true });\r\n onScroll();\r\n }\r\n\r\n // ----- Derived getters -----\r\n private get visibleColumns(): SdTableColumn[] {\r\n return this.columns.filter(col => col.visible !== false);\r\n }\r\n\r\n private get paginatedRows(): Row[] {\r\n if (!this.pagination) return this.innerRows;\r\n\r\n const { rowsPerPage = this.rows.length } = this.pagination || {};\r\n\r\n const result = this.innerRows.slice(\r\n (this.currentPage - 1) * rowsPerPage,\r\n this.currentPage * rowsPerPage,\r\n );\r\n\r\n return result;\r\n }\r\n\r\n private get lastPageNumber(): number {\r\n const { lastPage, rowsPerPage = this.rows.length } = this.pagination || {};\r\n\r\n return lastPage ?? Math.max(1, Math.ceil(this.rows.length / rowsPerPage));\r\n }\r\n\r\n private get sdTableClasses() {\r\n return [\r\n 'sd-table',\r\n this.stickyHeader && 'sd-table--sticky-header',\r\n this.selectable && 'sd-table--selectable',\r\n this.resizable && 'sd-table--resizable',\r\n !this.innerRows.length && 'sd-table--no-data',\r\n ((this.stickyColumn?.left ?? 0) > 0 || (this.stickyColumn?.right ?? 0) > 0) &&\r\n 'sd-table--sticky-column',\r\n this.scrolledLeft && 'sd-table--scrolled-left',\r\n this.scrolledRight && 'sd-table--scrolled-right',\r\n ]\r\n .filter(Boolean)\r\n .join(' ');\r\n }\r\n\r\n // ----- Selection -----\r\n private isRowSelected(row: Row): boolean {\r\n return Array.from(this.innerSelected).some(r => r[this.rowKey] === row[this.rowKey]);\r\n }\r\n\r\n private updateRowSelect(row: Row) {\r\n const selectedArray = Array.from(this.innerSelected);\r\n const exists = this.isRowSelected(row);\r\n const newSelected = exists\r\n ? selectedArray.filter(r => r[this.rowKey] !== row[this.rowKey])\r\n : [...selectedArray, row];\r\n\r\n // 동일 상태면 set하지 않음 → 불필요 렌더 방지\r\n if (newSelected.length === selectedArray.length) return;\r\n\r\n this.innerSelected = new Set(newSelected);\r\n this.sdSelectChange.emit(Array.from(this.innerSelected));\r\n }\r\n\r\n private toggleSelectAll(checked: boolean | any[]) {\r\n if (checked) {\r\n const pageRows = new Set([...this.paginatedRows]);\r\n this.innerSelected = new Set([...this.innerSelected, ...pageRows]);\r\n } else {\r\n const currentPageKeys = this.paginatedRows.map(r => r[this.rowKey]);\r\n this.innerSelected = new Set(\r\n [...this.innerSelected].filter(r => !currentPageKeys.includes(r[this.rowKey])),\r\n );\r\n }\r\n\r\n this.sdSelectChange.emit(Array.from(this.innerSelected));\r\n }\r\n\r\n private get isAllChecked(): boolean | null {\r\n const total = this.paginatedRows.length;\r\n const selectedCount = this.paginatedRows.filter(row =>\r\n Array.from(this.innerSelected).some(\r\n selectedRow => selectedRow[this.rowKey] === row[this.rowKey],\r\n ),\r\n ).length;\r\n\r\n if (selectedCount === 0) return false; // 아무것도 안 선택됨\r\n if (selectedCount === total) return true; // 전부 선택됨\r\n return null; // 일부만 선택됨\r\n }\r\n\r\n // ----- Helpers -----\r\n private getStickyStyle(colIdx: number) {\r\n const leftOffset =\r\n this.columnWidths.slice(0, colIdx).reduce((a, b) => a + b, 0) + (this.selectable ? 52 : 0);\r\n const rightOffset = this.columnWidths\r\n .filter((_, i) => i >= this.visibleColumns.length - (this.stickyColumn.right || 0) && i > colIdx)\r\n .reduce((a, b) => a + b, 0);\r\n return {\r\n '--sticky-left-offset': `${leftOffset}px`,\r\n '--sticky-right-offset': `${rightOffset}px`,\r\n 'width': `${this.columnWidths[colIdx]}px`,\r\n 'minWidth': `${this.columnWidths[colIdx]}px`,\r\n 'maxWidth': `${this.columnWidths[colIdx]}px`,\r\n };\r\n }\r\n\r\n private handleResize(index: number, event: MouseEvent) {\r\n const startX = event.clientX;\r\n const startWidth = this.columnWidths[index];\r\n\r\n const handleMouseMove = (moveEvent: MouseEvent) => {\r\n const newWidth = Math.max(startWidth + moveEvent.clientX - startX, 50);\r\n\r\n this.columnWidths = this.columnWidths.map((width, idx) => (idx === index ? newWidth : width));\r\n };\r\n\r\n const handleMouseUp = () => {\r\n document.removeEventListener('mousemove', handleMouseMove);\r\n document.removeEventListener('mouseup', handleMouseUp);\r\n };\r\n\r\n document.addEventListener('mousemove', handleMouseMove);\r\n document.addEventListener('mouseup', handleMouseUp);\r\n }\r\n\r\n private getCellValue(column: SdTableColumn, row: Row) {\r\n const { field, format, name } = column;\r\n const value = typeof field === 'function' ? field(row) : field ? row[field] : row[name];\r\n return format ? format(value, row) : value;\r\n }\r\n\r\n // ----- Render -----\r\n private renderHeader() {\r\n return (\r\n <thead>\r\n <tr>\r\n {this.selectable && (\r\n <th\r\n class={{\r\n 'sd-th': true,\r\n 'sd-th--selected': true,\r\n 'sticky-left': Boolean(this.stickyColumn.left && this.stickyColumn.left > 0),\r\n }}\r\n style={{\r\n '--sticky-left-offset': '0px',\r\n }}\r\n >\r\n <sd-checkbox\r\n checked={this.isAllChecked}\r\n disabled={!this.paginatedRows.length}\r\n onSdChange={(e: CustomEvent<boolean | any[]>) => this.toggleSelectAll(e.detail)}\r\n ></sd-checkbox>\r\n </th>\r\n )}\r\n {this.visibleColumns.map((col, colIdx) => (\r\n <th\r\n key={col.name}\r\n class={{\r\n 'sd-th': true,\r\n 'sticky-left': Boolean(this.stickyColumn.left && colIdx < this.stickyColumn.left),\r\n 'sticky-right': Boolean(\r\n this.stickyColumn.right && colIdx >= this.visibleColumns.length - this.stickyColumn.right!,\r\n ),\r\n 'sticky-left-edge': Boolean(\r\n this.stickyColumn.left && colIdx === this.stickyColumn.left - 1,\r\n ),\r\n 'sticky-right-edge': Boolean(\r\n this.stickyColumn.right &&\r\n colIdx === this.visibleColumns.length - this.stickyColumn.right!,\r\n ),\r\n }}\r\n style={this.getStickyStyle(colIdx)}\r\n >\r\n <div class={`sd-th__content sd-th__content--${col.align || 'left'}`}>\r\n <div class=\"sd-th__content--label\">{col.label}</div>\r\n\r\n {col.usePageMoveIcon && <sd-icon name=\"pageMove\" size=\"12\" color=\"#006AC1\" />}\r\n\r\n {col.tooltip && (\r\n <sd-tooltip {...col.tooltipOptions}>\r\n {col.tooltip.map(text => (\r\n <div>{text}</div>\r\n ))}\r\n </sd-tooltip>\r\n )}\r\n </div>\r\n\r\n {this.resizable && (\r\n <div\r\n class=\"sd-th__resizer\"\r\n onMouseDown={(evt: MouseEvent) => this.handleResize(colIdx, evt)}\r\n ></div>\r\n )}\r\n </th>\r\n ))}\r\n </tr>\r\n </thead>\r\n );\r\n }\r\n\r\n private renderBody() {\r\n if (!this.paginatedRows.length)\r\n return (\r\n <tbody part=\"tbody-empty\">\r\n <tr>\r\n <td colSpan={this.visibleColumns.length + (this.selectable ? 1 : 0)}>{this.noDataLabel}</td>\r\n </tr>\r\n </tbody>\r\n );\r\n\r\n return (\r\n <tbody>\r\n {this.paginatedRows.map(row => (\r\n <tr key={row[this.rowKey]} class=\"hover:bg-Grey_Lighten-6\">\r\n {this.selectable && (\r\n <td\r\n class={{\r\n 'sd-td': true,\r\n 'sd-td--selected': true,\r\n 'sticky-left': Boolean(this.stickyColumn.left && this.stickyColumn.left > 0),\r\n }}\r\n style={{\r\n '--sticky-left-offset': '0px',\r\n }}\r\n >\r\n <sd-checkbox\r\n checked={this.isRowSelected(row)}\r\n disabled={!this.paginatedRows.length}\r\n onSdChange={() => this.updateRowSelect(row)}\r\n ></sd-checkbox>\r\n </td>\r\n )}\r\n {this.visibleColumns.map((column, colIdx) => {\r\n const rendered = this.bodyCellRenderer?.(column, row);\r\n\r\n return (\r\n <td\r\n key={column.name}\r\n part={`td-${column.name}`}\r\n class={{\r\n 'sd-td': true,\r\n [`sd-td--${column.align || 'left'}`]: true,\r\n 'sticky-left': Boolean(this.stickyColumn.left && colIdx < this.stickyColumn.left),\r\n 'sticky-right': Boolean(\r\n this.stickyColumn.right &&\r\n colIdx >= this.visibleColumns.length - this.stickyColumn.right!,\r\n ),\r\n 'sticky-left-edge': Boolean(\r\n this.stickyColumn.left && colIdx === this.stickyColumn.left - 1,\r\n ),\r\n 'sticky-right-edge': Boolean(\r\n this.stickyColumn.right &&\r\n colIdx === this.visibleColumns.length - this.stickyColumn.right!,\r\n ),\r\n }}\r\n style={this.getStickyStyle(colIdx)}\r\n >\r\n {rendered ? (\r\n typeof rendered === 'string' ? (\r\n <span innerHTML={rendered}></span>\r\n ) : (\r\n rendered\r\n )\r\n ) : (\r\n this.getCellValue(column, row)\r\n )}\r\n </td>\r\n );\r\n })}\r\n </tr>\r\n ))}\r\n </tbody>\r\n );\r\n }\r\n\r\n render() {\r\n return (\r\n <Host>\r\n <div\r\n class=\"sd-table__wrapper\"\r\n style={{\r\n '--table-width': this.width,\r\n '--table-height': this.height,\r\n }}\r\n >\r\n <div class=\"sd-table__container\">\r\n <div class=\"sd-table__middle\">\r\n <table part=\"table\" class={this.sdTableClasses}>\r\n {this.renderHeader()}\r\n\r\n {this.renderBody()}\r\n </table>\r\n </div>\r\n\r\n <div class=\"sd-table__bottom\"></div>\r\n </div>\r\n {this.pagination && this.innerRows.length > 0 && (\r\n <div class=\"sd-table__pagination\">\r\n <sd-pagination\r\n currentPage={this.currentPage}\r\n lastPage={this.lastPageNumber}\r\n onPageChange={(e: CustomEvent<number>) => {\r\n this.currentPage = e.detail;\r\n this.sdPageChange.emit(this.currentPage);\r\n }}\r\n ></sd-pagination>\r\n </div>\r\n )}\r\n </div>\r\n </Host>\r\n );\r\n }\r\n}\r\n"],"names":["h","Host"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"sd-table.entry.cjs.js","sources":["src/components/sd-table/sd-table.scss?tag=sd-table","src/components/sd-table/sd-table.tsx"],"sourcesContent":["@import '../../styles/global.scss';\r\n\r\n.sd-table__wrapper {\r\n height: var(--table-height, auto);\r\n width: var(--table-width, 100%);\r\n\r\n .sd-table__container {\r\n width: 100%;\r\n height: auto;\r\n border: 1px solid $grey_30;\r\n border-radius: 8px;\r\n font-size: 12px;\r\n overflow: hidden;\r\n\r\n .sd-table__middle {\r\n overflow: auto;\r\n will-change: scroll-position;\r\n height: var(--table-height, auto);\r\n @extend %scrollBar;\r\n\r\n .sd-table {\r\n width: 100%;\r\n border-collapse: separate;\r\n border-spacing: 0;\r\n table-layout: fixed;\r\n\r\n &--selectable {\r\n td.sd-td--selected,\r\n th.sd-th--selected {\r\n width: 52px !important;\r\n max-width: 52px !important;\r\n min-width: 52px !important;\r\n padding: 0 10px 0 24px;\r\n text-align: left;\r\n }\r\n }\r\n\r\n &--sticky-header {\r\n thead {\r\n position: sticky;\r\n top: 0;\r\n z-index: 120;\r\n }\r\n }\r\n\r\n &--sticky-column {\r\n th.sticky-left,\r\n th.sticky-right {\r\n position: sticky;\r\n background-color: $th-bg;\r\n z-index: 110 !important;\r\n }\r\n td.sticky-left,\r\n td.sticky-right {\r\n position: sticky;\r\n background-color: white;\r\n z-index: 100 !important;\r\n }\r\n\r\n .sticky-left {\r\n left: var(--sticky-left-offset, 0);\r\n }\r\n .sticky-right {\r\n right: var(--sticky-right-offset, 0);\r\n }\r\n\r\n th.sticky-cell {\r\n position: sticky;\r\n z-index: 102;\r\n background-color: $th-bg;\r\n }\r\n td.sticky-cell {\r\n position: sticky;\r\n z-index: 101;\r\n background-color: white;\r\n }\r\n }\r\n\r\n &--scrolled-left {\r\n th.sticky-left-edge,\r\n td.sticky-left-edge {\r\n overflow: visible;\r\n &:after {\r\n content: '';\r\n position: absolute;\r\n top: 0;\r\n left: 100%;\r\n right: -20px;\r\n width: 20px;\r\n height: 100%;\r\n z-index: 101 !important;\r\n box-shadow: inset 12px 0 20px -25px;\r\n opacity: 1;\r\n pointer-events: none;\r\n }\r\n }\r\n }\r\n\r\n &--scrolled-right {\r\n th.sticky-right-edge,\r\n td.sticky-right-edge {\r\n overflow: visible;\r\n\r\n &:after {\r\n content: '';\r\n position: absolute;\r\n top: 0;\r\n left: -20px;\r\n width: 20px;\r\n height: 100%;\r\n z-index: 101 !important;\r\n box-shadow: inset -12px 0 20px -25px;\r\n opacity: 1;\r\n pointer-events: none;\r\n }\r\n }\r\n }\r\n\r\n &--no-data {\r\n thead {\r\n opacity: 0.4;\r\n tr {\r\n th {\r\n &.sd-th {\r\n border-bottom: 1px solid rgba(225, 225, 225, 0.4) !important;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n\r\n td,\r\n th,\r\n .sd-th__content--label {\r\n overflow: hidden;\r\n white-space: nowrap;\r\n text-overflow: ellipsis;\r\n word-break: keep-all;\r\n }\r\n\r\n thead {\r\n height: 36px;\r\n\r\n tr {\r\n width: 100%;\r\n\r\n th {\r\n background: $th-bg;\r\n height: 36px;\r\n padding: 0 16px;\r\n font-weight: 500;\r\n vertical-align: middle;\r\n border-bottom: 1px solid $grey_30;\r\n -webkit-user-select: none;\r\n user-select: none;\r\n position: relative;\r\n\r\n &.sd-th {\r\n .sd-th__content {\r\n display: flex;\r\n flex-flow: row nowrap;\r\n align-items: center;\r\n gap: 4px;\r\n\r\n &--left {\r\n justify-content: flex-start;\r\n }\r\n &--center {\r\n justify-content: center;\r\n }\r\n &--right {\r\n justify-content: flex-end;\r\n }\r\n }\r\n\r\n .sd-th__resizer {\r\n position: absolute;\r\n top: 50%;\r\n right: 0;\r\n transform: translateY(-50%);\r\n width: 4px;\r\n height: 16px;\r\n cursor: col-resize;\r\n z-index: 3;\r\n border-left: 1px solid $grey_45;\r\n border-right: 1px solid $grey_45;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n\r\n tbody {\r\n tr {\r\n &:last-of-type {\r\n td {\r\n border-bottom: none;\r\n }\r\n }\r\n td {\r\n height: 44px;\r\n padding: 0 16px;\r\n border-bottom: 1px solid $grey_30;\r\n background: white;\r\n vertical-align: middle;\r\n\r\n &.sd-td {\r\n &--left {\r\n text-align: left;\r\n }\r\n &--center {\r\n text-align: center;\r\n }\r\n &--right {\r\n text-align: right;\r\n }\r\n }\r\n }\r\n }\r\n }\r\n }\r\n }\r\n\r\n .sd-table__bottom {\r\n background: white;\r\n text-align: center;\r\n }\r\n }\r\n\r\n .sd-table__pagination {\r\n background: $grey_05;\r\n height: 48px;\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n border: 1px solid $grey_30;\r\n border-top: none;\r\n border-radius: 8px;\r\n }\r\n}\r\n","import {\r\n Component,\r\n Element,\r\n Prop,\r\n State,\r\n Event,\r\n Watch,\r\n h,\r\n EventEmitter,\r\n Host,\r\n} from '@stencil/core';\r\nimport { CheckedType } from '../sd-checkbox/sd-checkbox';\r\n\r\nexport type SdTableSortDir = 'asc' | 'desc' | 'none';\r\n\r\nexport interface SdTableColumn {\r\n name: string;\r\n label: string;\r\n field: string | ((row: any) => any);\r\n align?: 'left' | 'center' | 'right';\r\n width?: string;\r\n format?: (value: any, row: any) => string;\r\n visible?: boolean;\r\n usePageMoveIcon?: boolean;\r\n tooltip?: string[];\r\n tooltipOptions?: Record<string, any>;\r\n}\r\n\r\nexport interface Row {\r\n [key: string]: any;\r\n}\r\n\r\n@Component({\r\n tag: 'sd-table',\r\n styleUrl: 'sd-table.scss',\r\n})\r\nexport class SdTable {\r\n @Element() el!: HTMLElement;\r\n\r\n @Prop() columns!: SdTableColumn[];\r\n @Prop({ mutable: true }) rows!: Row[];\r\n @Prop({ mutable: true }) selected: Set<Row> = new Set();\r\n @Prop() rowKey: string = 'id';\r\n @Prop() selectable: boolean = false;\r\n @Prop() resizable: boolean = false;\r\n @Prop() width?: string;\r\n @Prop() height?: string;\r\n @Prop() stickyHeader: boolean = false;\r\n @Prop() stickyColumn: { left?: number; right?: number } = { left: 0, right: 0 };\r\n @Prop() noDataLabel: string = '데이터가 없습니다.';\r\n @Prop() pagination?: {\r\n page: number;\r\n rowsPerPage: number;\r\n lastPage?: number;\r\n };\r\n @Prop() bodyCellRenderer?: (\r\n column: SdTableColumn,\r\n row: Row,\r\n ) => HTMLElement | string | null | undefined;\r\n\r\n @Event() sdSelectChange!: EventEmitter<Row[]>;\r\n @Event() sdPageChange!: EventEmitter<number>;\r\n\r\n @State() currentPage: number = this.pagination?.page || 1;\r\n @State() innerRows: Row[] = [];\r\n @State() innerSelected: Set<Row> = new Set();\r\n @State() columnWidths: number[] = [];\r\n @State() scrolledLeft: boolean = false;\r\n @State() scrolledRight: boolean = false;\r\n\r\n @Watch('columns')\r\n handleColumnsChange(newCols: SdTableColumn[]) {\r\n this.columnWidths = newCols.map(c => parseInt(c.width || '120', 10));\r\n }\r\n\r\n @Watch('rows')\r\n handleRowsChange(newRows: Row[]) {\r\n this.innerRows = [...newRows];\r\n }\r\n\r\n @Watch('selected')\r\n handleSelectedChange(newSelected: Set<Row>) {\r\n this.innerSelected = new Set(newSelected);\r\n }\r\n\r\n @Watch('pagination')\r\n handlePaginationChange(\r\n newVal?: { page: number; rowsPerPage: number; lastPage?: number } | undefined,\r\n ) {\r\n if (newVal?.page && newVal.page !== this.currentPage) this.currentPage = newVal.page;\r\n }\r\n\r\n componentWillLoad() {\r\n this.innerRows = [...this.rows];\r\n this.innerSelected = new Set(this.selected);\r\n this.columnWidths = this.columns.map(c => parseInt(c.width || '120', 10));\r\n }\r\n\r\n componentDidLoad() {\r\n const middle = this.el.querySelector('.sd-table__middle');\r\n if (!middle) return;\r\n\r\n const onScroll = () => {\r\n const { scrollLeft, scrollWidth, clientWidth } = middle as HTMLElement;\r\n this.scrolledLeft = scrollLeft > 0;\r\n this.scrolledRight = scrollLeft + clientWidth < scrollWidth;\r\n };\r\n middle.addEventListener('scroll', onScroll, { passive: true });\r\n onScroll();\r\n }\r\n\r\n // ----- Derived getters -----\r\n private get visibleColumns(): SdTableColumn[] {\r\n return this.columns.filter(col => col.visible !== false);\r\n }\r\n\r\n private get paginatedRows(): Row[] {\r\n if (!this.pagination) return this.innerRows;\r\n\r\n const { rowsPerPage = this.rows.length } = this.pagination || {};\r\n\r\n const result = this.innerRows.slice(\r\n (this.currentPage - 1) * rowsPerPage,\r\n this.currentPage * rowsPerPage,\r\n );\r\n\r\n return result;\r\n }\r\n\r\n private get lastPageNumber(): number {\r\n const { lastPage, rowsPerPage = this.rows.length } = this.pagination || {};\r\n\r\n return lastPage ?? Math.max(1, Math.ceil(this.rows.length / rowsPerPage));\r\n }\r\n\r\n private get sdTableClasses() {\r\n return [\r\n 'sd-table',\r\n this.stickyHeader && 'sd-table--sticky-header',\r\n this.selectable && 'sd-table--selectable',\r\n this.resizable && 'sd-table--resizable',\r\n !this.innerRows.length && 'sd-table--no-data',\r\n ((this.stickyColumn?.left ?? 0) > 0 || (this.stickyColumn?.right ?? 0) > 0) &&\r\n 'sd-table--sticky-column',\r\n this.scrolledLeft && 'sd-table--scrolled-left',\r\n this.scrolledRight && 'sd-table--scrolled-right',\r\n ]\r\n .filter(Boolean)\r\n .join(' ');\r\n }\r\n\r\n // ----- Selection -----\r\n private isRowSelected(row: Row): boolean {\r\n return Array.from(this.innerSelected).some(r => r[this.rowKey] === row[this.rowKey]);\r\n }\r\n\r\n private updateRowSelect(row: Row) {\r\n const selectedArray = Array.from(this.innerSelected);\r\n const exists = this.isRowSelected(row);\r\n const newSelected = exists\r\n ? selectedArray.filter(r => r[this.rowKey] !== row[this.rowKey])\r\n : [...selectedArray, row];\r\n\r\n // 동일 상태면 set하지 않음 → 불필요 렌더 방지\r\n if (newSelected.length === selectedArray.length) return;\r\n\r\n this.innerSelected = new Set(newSelected);\r\n this.sdSelectChange.emit(Array.from(this.innerSelected));\r\n }\r\n\r\n private toggleSelectAll(checked: CheckedType) {\r\n if (checked) {\r\n const pageRows = new Set([...this.paginatedRows]);\r\n this.innerSelected = new Set([...this.innerSelected, ...pageRows]);\r\n } else {\r\n const currentPageKeys = this.paginatedRows.map(r => r[this.rowKey]);\r\n this.innerSelected = new Set(\r\n [...this.innerSelected].filter(r => !currentPageKeys.includes(r[this.rowKey])),\r\n );\r\n }\r\n\r\n this.sdSelectChange.emit(Array.from(this.innerSelected));\r\n }\r\n\r\n private get isAllChecked(): boolean | null {\r\n const total = this.paginatedRows.length;\r\n const selectedCount = this.paginatedRows.filter(row =>\r\n Array.from(this.innerSelected).some(\r\n selectedRow => selectedRow[this.rowKey] === row[this.rowKey],\r\n ),\r\n ).length;\r\n\r\n if (selectedCount === 0) return false; // 아무것도 안 선택됨\r\n if (selectedCount === total) return true; // 전부 선택됨\r\n return null; // 일부만 선택됨\r\n }\r\n\r\n // ----- Helpers -----\r\n private getStickyStyle(colIdx: number) {\r\n const leftOffset =\r\n this.columnWidths.slice(0, colIdx).reduce((a, b) => a + b, 0) + (this.selectable ? 52 : 0);\r\n const rightOffset = this.columnWidths\r\n .filter((_, i) => i >= this.visibleColumns.length - (this.stickyColumn.right || 0) && i > colIdx)\r\n .reduce((a, b) => a + b, 0);\r\n return {\r\n '--sticky-left-offset': `${leftOffset}px`,\r\n '--sticky-right-offset': `${rightOffset}px`,\r\n 'width': `${this.columnWidths[colIdx]}px`,\r\n 'minWidth': `${this.columnWidths[colIdx]}px`,\r\n 'maxWidth': `${this.columnWidths[colIdx]}px`,\r\n };\r\n }\r\n\r\n private handleResize(index: number, event: MouseEvent) {\r\n const startX = event.clientX;\r\n const startWidth = this.columnWidths[index];\r\n\r\n const handleMouseMove = (moveEvent: MouseEvent) => {\r\n const newWidth = Math.max(startWidth + moveEvent.clientX - startX, 50);\r\n\r\n this.columnWidths = this.columnWidths.map((width, idx) => (idx === index ? newWidth : width));\r\n };\r\n\r\n const handleMouseUp = () => {\r\n document.removeEventListener('mousemove', handleMouseMove);\r\n document.removeEventListener('mouseup', handleMouseUp);\r\n };\r\n\r\n document.addEventListener('mousemove', handleMouseMove);\r\n document.addEventListener('mouseup', handleMouseUp);\r\n }\r\n\r\n private getCellValue(column: SdTableColumn, row: Row) {\r\n const { field, format, name } = column;\r\n const value = typeof field === 'function' ? field(row) : field ? row[field] : row[name];\r\n return format ? format(value, row) : value;\r\n }\r\n\r\n // ----- Render -----\r\n private renderHeader() {\r\n return (\r\n <thead>\r\n <tr>\r\n {this.selectable && (\r\n <th\r\n class={{\r\n 'sd-th': true,\r\n 'sd-th--selected': true,\r\n 'sticky-left': Boolean(this.stickyColumn.left && this.stickyColumn.left > 0),\r\n }}\r\n style={{\r\n '--sticky-left-offset': '0px',\r\n }}\r\n >\r\n <sd-checkbox\r\n checked={this.isAllChecked}\r\n disabled={!this.paginatedRows.length}\r\n onSdChange={(e: CustomEvent<CheckedType>) => this.toggleSelectAll(e.detail)}\r\n ></sd-checkbox>\r\n </th>\r\n )}\r\n {this.visibleColumns.map((col, colIdx) => (\r\n <th\r\n key={col.name}\r\n class={{\r\n 'sd-th': true,\r\n 'sticky-left': Boolean(this.stickyColumn.left && colIdx < this.stickyColumn.left),\r\n 'sticky-right': Boolean(\r\n this.stickyColumn.right && colIdx >= this.visibleColumns.length - this.stickyColumn.right!,\r\n ),\r\n 'sticky-left-edge': Boolean(\r\n this.stickyColumn.left && colIdx === this.stickyColumn.left - 1,\r\n ),\r\n 'sticky-right-edge': Boolean(\r\n this.stickyColumn.right &&\r\n colIdx === this.visibleColumns.length - this.stickyColumn.right!,\r\n ),\r\n }}\r\n style={this.getStickyStyle(colIdx)}\r\n >\r\n <div class={`sd-th__content sd-th__content--${col.align || 'left'}`}>\r\n <div class=\"sd-th__content--label\">{col.label}</div>\r\n\r\n {col.usePageMoveIcon && <sd-icon name=\"pageMove\" size=\"12\" color=\"#006AC1\" />}\r\n\r\n {col.tooltip && (\r\n <sd-tooltip {...col.tooltipOptions}>\r\n {col.tooltip.map(text => (\r\n <div>{text}</div>\r\n ))}\r\n </sd-tooltip>\r\n )}\r\n </div>\r\n\r\n {this.resizable && (\r\n <div\r\n class=\"sd-th__resizer\"\r\n onMouseDown={(evt: MouseEvent) => this.handleResize(colIdx, evt)}\r\n ></div>\r\n )}\r\n </th>\r\n ))}\r\n </tr>\r\n </thead>\r\n );\r\n }\r\n\r\n private renderBody() {\r\n if (!this.paginatedRows.length)\r\n return (\r\n <tbody part=\"tbody-empty\">\r\n <tr>\r\n <td colSpan={this.visibleColumns.length + (this.selectable ? 1 : 0)}>{this.noDataLabel}</td>\r\n </tr>\r\n </tbody>\r\n );\r\n\r\n return (\r\n <tbody>\r\n {this.paginatedRows.map(row => (\r\n <tr key={row[this.rowKey]} class=\"hover:bg-Grey_Lighten-6\">\r\n {this.selectable && (\r\n <td\r\n class={{\r\n 'sd-td': true,\r\n 'sd-td--selected': true,\r\n 'sticky-left': Boolean(this.stickyColumn.left && this.stickyColumn.left > 0),\r\n }}\r\n style={{\r\n '--sticky-left-offset': '0px',\r\n }}\r\n >\r\n <sd-checkbox\r\n checked={this.isRowSelected(row)}\r\n disabled={!this.paginatedRows.length}\r\n onSdChange={() => this.updateRowSelect(row)}\r\n ></sd-checkbox>\r\n </td>\r\n )}\r\n {this.visibleColumns.map((column, colIdx) => {\r\n const rendered = this.bodyCellRenderer?.(column, row);\r\n\r\n return (\r\n <td\r\n key={column.name}\r\n part={`td-${column.name}`}\r\n class={{\r\n 'sd-td': true,\r\n [`sd-td--${column.align || 'left'}`]: true,\r\n 'sticky-left': Boolean(this.stickyColumn.left && colIdx < this.stickyColumn.left),\r\n 'sticky-right': Boolean(\r\n this.stickyColumn.right &&\r\n colIdx >= this.visibleColumns.length - this.stickyColumn.right!,\r\n ),\r\n 'sticky-left-edge': Boolean(\r\n this.stickyColumn.left && colIdx === this.stickyColumn.left - 1,\r\n ),\r\n 'sticky-right-edge': Boolean(\r\n this.stickyColumn.right &&\r\n colIdx === this.visibleColumns.length - this.stickyColumn.right!,\r\n ),\r\n }}\r\n style={this.getStickyStyle(colIdx)}\r\n >\r\n {rendered ? (\r\n typeof rendered === 'string' ? (\r\n <span innerHTML={rendered}></span>\r\n ) : (\r\n rendered\r\n )\r\n ) : (\r\n this.getCellValue(column, row)\r\n )}\r\n </td>\r\n );\r\n })}\r\n </tr>\r\n ))}\r\n </tbody>\r\n );\r\n }\r\n\r\n render() {\r\n return (\r\n <Host>\r\n <div\r\n class=\"sd-table__wrapper\"\r\n style={{\r\n '--table-width': this.width,\r\n '--table-height': this.height,\r\n }}\r\n >\r\n <div class=\"sd-table__container\">\r\n <div class=\"sd-table__middle\">\r\n <table part=\"table\" class={this.sdTableClasses}>\r\n {this.renderHeader()}\r\n\r\n {this.renderBody()}\r\n </table>\r\n </div>\r\n\r\n <div class=\"sd-table__bottom\"></div>\r\n </div>\r\n {this.pagination && this.innerRows.length > 0 && (\r\n <div class=\"sd-table__pagination\">\r\n <sd-pagination\r\n currentPage={this.currentPage}\r\n lastPage={this.lastPageNumber}\r\n onPageChange={(e: CustomEvent<number>) => {\r\n this.currentPage = e.detail;\r\n this.sdPageChange.emit(this.currentPage);\r\n }}\r\n ></sd-pagination>\r\n </div>\r\n )}\r\n </div>\r\n </Host>\r\n );\r\n }\r\n}\r\n"],"names":["h","Host"],"mappings":"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"}
|
|
@@ -45,7 +45,7 @@ const SdTag = class {
|
|
|
45
45
|
}
|
|
46
46
|
render() {
|
|
47
47
|
const tagClasses = this.getTagClasses();
|
|
48
|
-
return (index.h("span", { key: '
|
|
48
|
+
return (index.h("span", { key: 'eff57a253b788f0435525cae9a15881cce8a08a0', class: tagClasses, style: {
|
|
49
49
|
'--tag-bg-color': this.bgColor,
|
|
50
50
|
'--tag-text-color': this.textColor,
|
|
51
51
|
}, "aria-label": this.label || 'tag' }, this.renderContent()));
|