@bwg-ui/core 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (257) hide show
  1. package/README.md +106 -0
  2. package/dist/chunks/BwgLargeUploader-ByN1XWV4.js +809 -0
  3. package/dist/chunks/BwgLargeUploader-CU0-MVk4.cjs +1 -0
  4. package/dist/chunks/BwgSpace-CnLM4qcg.js +26 -0
  5. package/dist/chunks/BwgSpace-b0hmM1Ht.cjs +1 -0
  6. package/dist/chunks/QuickServiceToggle-CiCuWfCF.cjs +183 -0
  7. package/dist/chunks/QuickServiceToggle-y7esp1kp.js +15510 -0
  8. package/dist/chunks/ServiceCodeContext--ZnMtjzD.cjs +1 -0
  9. package/dist/chunks/ServiceCodeContext-CDZMr3Mm.js +87 -0
  10. package/dist/chunks/UtilsContext-B16Gh9LL.cjs +1 -0
  11. package/dist/chunks/UtilsContext-BbfZYiMR.js +240 -0
  12. package/dist/chunks/_commonjsHelpers-C6fGbg64.js +6 -0
  13. package/dist/chunks/_commonjsHelpers-DwGv2jUC.cjs +1 -0
  14. package/dist/chunks/codeStore-Dt6j826J.cjs +1 -0
  15. package/dist/chunks/codeStore-bxk_q1sl.js +449 -0
  16. package/dist/chunks/commonUtils-BV6WFv-z.js +628 -0
  17. package/dist/chunks/commonUtils-L9Jgc5y-.cjs +1 -0
  18. package/dist/chunks/favoriteStore-CguRSEcH.js +367 -0
  19. package/dist/chunks/favoriteStore-TgeeY32l.cjs +1 -0
  20. package/dist/chunks/jsx-runtime-CeSfJrVB.cjs +30 -0
  21. package/dist/chunks/jsx-runtime-Dpn_P65e.js +633 -0
  22. package/dist/chunks/messageUtils-9DXOwada.js +117 -0
  23. package/dist/chunks/messageUtils-RjJD_ArW.cjs +1 -0
  24. package/dist/chunks/popupStore-CVD8SPTa.cjs +1 -0
  25. package/dist/chunks/popupStore-Dp_fqtim.js +96 -0
  26. package/dist/chunks/realFormat-Cha7OTd9.cjs +1 -0
  27. package/dist/chunks/realFormat-DRGLFabQ.js +304 -0
  28. package/dist/chunks/serviceConfig-BJBsdee_.js +699 -0
  29. package/dist/chunks/serviceConfig-Cr2P4yr4.cjs +2 -0
  30. package/dist/components/common/BwgButtonGroup.d.ts +31 -0
  31. package/dist/components/common/BwgCmptArea.d.ts +16 -0
  32. package/dist/components/common/BwgConfigProvider.d.ts +10 -0
  33. package/dist/components/common/BwgDrawer.d.ts +20 -0
  34. package/dist/components/common/BwgGrid.d.ts +505 -0
  35. package/dist/components/common/BwgInfoArea.d.ts +8 -0
  36. package/dist/components/common/BwgPopup.d.ts +9 -0
  37. package/dist/components/common/BwgSpace.d.ts +11 -0
  38. package/dist/components/common/BwgTable.d.ts +13 -0
  39. package/dist/components/common/BwgTabs.d.ts +5 -0
  40. package/dist/components/common/BwgTitleBox.d.ts +29 -0
  41. package/dist/components/common/BwgView.d.ts +36 -0
  42. package/dist/components/common/ContentBox.d.ts +19 -0
  43. package/dist/components/common/ContentLayOut.d.ts +13 -0
  44. package/dist/components/common/GlobalConfigProvider.d.ts +9 -0
  45. package/dist/components/common/QuickServiceToggle.d.ts +13 -0
  46. package/dist/components/common/SearchBox.d.ts +16 -0
  47. package/dist/components/common/index.cjs +1 -0
  48. package/dist/components/common/index.d.ts +34 -0
  49. package/dist/components/common/index.js +24 -0
  50. package/dist/components/core/BwgButton.d.ts +6 -0
  51. package/dist/components/core/BwgCheck.d.ts +11 -0
  52. package/dist/components/core/BwgCheckList.d.ts +11 -0
  53. package/dist/components/core/BwgDatePicker.d.ts +10 -0
  54. package/dist/components/core/BwgForm.d.ts +6 -0
  55. package/dist/components/core/BwgFormItem.d.ts +17 -0
  56. package/dist/components/core/BwgInput.d.ts +9 -0
  57. package/dist/components/core/BwgLargeUploader.d.ts +15 -0
  58. package/dist/components/core/BwgMaskedInput.d.ts +20 -0
  59. package/dist/components/core/BwgMaskedPicker.d.ts +11 -0
  60. package/dist/components/core/BwgMultiSelect.d.ts +14 -0
  61. package/dist/components/core/BwgNumber.d.ts +13 -0
  62. package/dist/components/core/BwgRadio.d.ts +8 -0
  63. package/dist/components/core/BwgRangePicker.d.ts +12 -0
  64. package/dist/components/core/BwgSearch.d.ts +16 -0
  65. package/dist/components/core/BwgSelect.d.ts +15 -0
  66. package/dist/components/core/BwgTextArea.d.ts +8 -0
  67. package/dist/components/core/BwgUploader.d.ts +34 -0
  68. package/dist/components/core/index.cjs +1 -0
  69. package/dist/components/core/index.d.ts +36 -0
  70. package/dist/components/core/index.js +21 -0
  71. package/dist/components/guide/BwgComponentGuide.d.ts +2 -0
  72. package/dist/components/guide/BwgDeveloperGuide.d.ts +2 -0
  73. package/dist/components/guide/index.cjs +1 -0
  74. package/dist/components/guide/index.d.ts +2 -0
  75. package/dist/components/guide/index.js +7 -0
  76. package/dist/index.cjs +1 -0
  77. package/dist/index.d.ts +5 -0
  78. package/dist/index.js +291 -0
  79. package/dist/provider/contexts/CommonCodeContext.d.ts +46 -0
  80. package/dist/provider/contexts/SearchBoxContext.d.ts +15 -0
  81. package/dist/provider/contexts/ServiceCodeContext.d.ts +108 -0
  82. package/dist/provider/contexts/UtilsContext.d.ts +194 -0
  83. package/dist/provider/contexts/index.d.ts +4 -0
  84. package/dist/provider/hooks/index.d.ts +2 -0
  85. package/dist/provider/hooks/usePopup.d.ts +17 -0
  86. package/dist/provider/hooks/useViewState.d.ts +14 -0
  87. package/dist/provider/index.cjs +1 -0
  88. package/dist/provider/index.d.ts +2 -0
  89. package/dist/provider/index.js +27 -0
  90. package/dist/public/styles/assets/images/contents/icon/ico-business-trip.svg +21 -0
  91. package/dist/public/styles/assets/images/contents/icon/ico-holiday.svg +23 -0
  92. package/dist/public/styles/assets/images/contents/icon/ico-menu-help.svg +5 -0
  93. package/dist/public/styles/assets/images/contents/icon/ico-overtime.svg +17 -0
  94. package/dist/public/styles/assets/images/contents/icon/ico-quick-tab-move.svg +8 -0
  95. package/dist/public/styles/assets/images/contents/icon/quick tab-text.svg +4 -0
  96. package/dist/public/styles/assets/images/contents/icon/quick-tab-text.svg +4 -0
  97. package/dist/public/test.txt +0 -0
  98. package/dist/stores/codeStore.d.ts +173 -0
  99. package/dist/stores/favoriteStore.d.ts +19 -0
  100. package/dist/stores/index.cjs +1 -0
  101. package/dist/stores/index.d.ts +14 -0
  102. package/dist/stores/index.js +20 -0
  103. package/dist/stores/menuStore.d.ts +52 -0
  104. package/dist/stores/popupStore.d.ts +72 -0
  105. package/dist/stores/userStore.d.ts +36 -0
  106. package/dist/styles/assets/fonts/Roboto/Roboto-bold.eot +2751 -0
  107. package/dist/styles/assets/fonts/Roboto/Roboto-bold.svg +626 -0
  108. package/dist/styles/assets/fonts/Roboto/Roboto-bold.ttf +2755 -0
  109. package/dist/styles/assets/fonts/Roboto/Roboto-bold.woff +2755 -0
  110. package/dist/styles/assets/fonts/Roboto/Roboto-bold.woff2 +2754 -0
  111. package/dist/styles/assets/fonts/Roboto/Roboto-medium.eot +0 -0
  112. package/dist/styles/assets/fonts/Roboto/Roboto-medium.svg +1064 -0
  113. package/dist/styles/assets/fonts/Roboto/Roboto-medium.ttf +0 -0
  114. package/dist/styles/assets/fonts/Roboto/Roboto-medium.woff +0 -0
  115. package/dist/styles/assets/fonts/Roboto/Roboto-medium.woff2 +2754 -0
  116. package/dist/styles/assets/fonts/Roboto/Roboto-regular.eot +0 -0
  117. package/dist/styles/assets/fonts/Roboto/Roboto-regular.svg +1063 -0
  118. package/dist/styles/assets/fonts/Roboto/Roboto-regular.ttf +1597 -0
  119. package/dist/styles/assets/fonts/Roboto/Roboto-regular.woff +1597 -0
  120. package/dist/styles/assets/fonts/Roboto/Roboto-regular.woff2 +1597 -0
  121. package/dist/styles/assets/fonts/material/MaterialIcons-Regular.eot +1594 -0
  122. package/dist/styles/assets/fonts/material/MaterialIcons-Regular.ttf +0 -0
  123. package/dist/styles/assets/fonts/material/MaterialIcons-Regular.woff +1594 -0
  124. package/dist/styles/assets/fonts/material/MaterialIcons-Regular.woff2 +1594 -0
  125. package/dist/styles/assets/fonts/material/MaterialSymbolsOutlined.woff2 +0 -0
  126. package/dist/styles/assets/fonts/meiryo/meiryo.ttf +0 -0
  127. package/dist/styles/assets/fonts/meiryo/meiryob.ttf +0 -0
  128. package/dist/styles/assets/fonts/nanumBarun/NanumBarunGothic.eot +0 -0
  129. package/dist/styles/assets/fonts/nanumBarun/NanumBarunGothic.ttf +0 -0
  130. package/dist/styles/assets/fonts/nanumBarun/NanumBarunGothic.woff +0 -0
  131. package/dist/styles/assets/fonts/nanumBarun/NanumBarunGothicBold.eot +0 -0
  132. package/dist/styles/assets/fonts/nanumBarun/NanumBarunGothicBold.ttf +0 -0
  133. package/dist/styles/assets/fonts/nanumBarun/NanumBarunGothicBold.woff +0 -0
  134. package/dist/styles/assets/fonts/nanumBarun/NanumBarunGothicWeb.eot +0 -0
  135. package/dist/styles/assets/fonts/nanumBarun/NanumBarunGothicWeb.ttf +0 -0
  136. package/dist/styles/assets/fonts/nanumBarun/NanumBarunGothicWeb.woff +0 -0
  137. package/dist/styles/assets/fonts/nanumBarun/NanumBarunGothicWebBold.eot +0 -0
  138. package/dist/styles/assets/fonts/nanumBarun/NanumBarunGothicWebBold.ttf +0 -0
  139. package/dist/styles/assets/fonts/nanumBarun/NanumBarunGothicWebBold.woff +0 -0
  140. package/dist/styles/assets/fonts/nanumBarun/NanumBarunGothicWebLight.eot +0 -0
  141. package/dist/styles/assets/fonts/nanumBarun/NanumBarunGothicWebLight.ttf +0 -0
  142. package/dist/styles/assets/fonts/nanumBarun/NanumBarunGothicWebLight.woff +0 -0
  143. package/dist/styles/assets/fonts/notokr/NotoSans-Bold.eot +2314 -0
  144. package/dist/styles/assets/fonts/notokr/NotoSans-Bold.otf +2314 -0
  145. package/dist/styles/assets/fonts/notokr/NotoSans-Bold.svg +47 -0
  146. package/dist/styles/assets/fonts/notokr/NotoSans-Bold.ttf +2301 -0
  147. package/dist/styles/assets/fonts/notokr/NotoSans-Bold.woff +2314 -0
  148. package/dist/styles/assets/fonts/notokr/NotoSans-Bold.woff2 +2315 -0
  149. package/dist/styles/assets/fonts/notokr/NotoSans-Light.otf +0 -0
  150. package/dist/styles/assets/fonts/notokr/NotoSans-Light.woff +0 -0
  151. package/dist/styles/assets/fonts/notokr/NotoSans-Light.woff2 +0 -0
  152. package/dist/styles/assets/fonts/notokr/NotoSans-Medium.eot +0 -0
  153. package/dist/styles/assets/fonts/notokr/NotoSans-Medium.otf +0 -0
  154. package/dist/styles/assets/fonts/notokr/NotoSans-Medium.svg +47 -0
  155. package/dist/styles/assets/fonts/notokr/NotoSans-Medium.ttf +0 -0
  156. package/dist/styles/assets/fonts/notokr/NotoSans-Medium.woff +0 -0
  157. package/dist/styles/assets/fonts/notokr/NotoSans-Medium.woff2 +0 -0
  158. package/dist/styles/assets/fonts/notokr/NotoSans-Regular.eot +0 -0
  159. package/dist/styles/assets/fonts/notokr/NotoSans-Regular.otf +0 -0
  160. package/dist/styles/assets/fonts/notokr/NotoSans-Regular.svg +47 -0
  161. package/dist/styles/assets/fonts/notokr/NotoSans-Regular.ttf +2299 -0
  162. package/dist/styles/assets/fonts/notokr/NotoSans-Regular.woff +0 -0
  163. package/dist/styles/assets/fonts/notokr/NotoSans-Regular.woff2 +0 -0
  164. package/dist/styles/assets/fonts/poppins/Poppins-ExtraLight.eot +0 -0
  165. package/dist/styles/assets/fonts/poppins/Poppins-ExtraLight.ttf +0 -0
  166. package/dist/styles/assets/fonts/poppins/Poppins-ExtraLight.woff +0 -0
  167. package/dist/styles/assets/fonts/poppins/Poppins-ExtraLight.woff2 +0 -0
  168. package/dist/styles/assets/fonts/poppins/Poppins-Light.eot +0 -0
  169. package/dist/styles/assets/fonts/poppins/Poppins-Light.ttf +0 -0
  170. package/dist/styles/assets/fonts/poppins/Poppins-Light.woff +0 -0
  171. package/dist/styles/assets/fonts/poppins/Poppins-Light.woff2 +0 -0
  172. package/dist/styles/assets/fonts/poppins/Poppins-Medium.eot +0 -0
  173. package/dist/styles/assets/fonts/poppins/Poppins-Medium.ttf +0 -0
  174. package/dist/styles/assets/fonts/poppins/Poppins-Medium.woff +0 -0
  175. package/dist/styles/assets/fonts/poppins/Poppins-Medium.woff2 +0 -0
  176. package/dist/styles/assets/fonts/poppins/Poppins-Regular.eot +0 -0
  177. package/dist/styles/assets/fonts/poppins/Poppins-Regular.ttf +0 -0
  178. package/dist/styles/assets/fonts/poppins/Poppins-Regular.woff +0 -0
  179. package/dist/styles/assets/fonts/poppins/Poppins-Regular.woff2 +0 -0
  180. package/dist/styles/assets/fonts/poppins/Poppins-SemiBold.eot +0 -0
  181. package/dist/styles/assets/fonts/poppins/Poppins-SemiBold.ttf +0 -0
  182. package/dist/styles/assets/fonts/poppins/Poppins-SemiBold.woff +0 -0
  183. package/dist/styles/assets/fonts/poppins/Poppins-SemiBold.woff2 +0 -0
  184. package/dist/styles/assets/fonts/pretendard/Pretendard-Black.woff2 +0 -0
  185. package/dist/styles/assets/fonts/pretendard/Pretendard-Bold.woff2 +0 -0
  186. package/dist/styles/assets/fonts/pretendard/Pretendard-ExtraBold.woff2 +0 -0
  187. package/dist/styles/assets/fonts/pretendard/Pretendard-ExtraLight.woff2 +0 -0
  188. package/dist/styles/assets/fonts/pretendard/Pretendard-Light.woff2 +0 -0
  189. package/dist/styles/assets/fonts/pretendard/Pretendard-Medium.woff2 +0 -0
  190. package/dist/styles/assets/fonts/pretendard/Pretendard-Regular.woff2 +0 -0
  191. package/dist/styles/assets/fonts/pretendard/Pretendard-SemiBold.woff2 +0 -0
  192. package/dist/styles/assets/fonts/pretendard/Pretendard-Thin.woff2 +0 -0
  193. package/dist/styles/assets/images/README.md +144 -0
  194. package/dist/styles/assets/images/backgrounds/landing_bg.png +0 -0
  195. package/dist/styles/assets/images/backgrounds/login_bg_01.png +0 -0
  196. package/dist/styles/assets/images/backgrounds/login_bg_02.png +0 -0
  197. package/dist/styles/assets/images/contents/btn/btn-down-on.png +0 -0
  198. package/dist/styles/assets/images/contents/btn/btn-down.png +0 -0
  199. package/dist/styles/assets/images/contents/btn/btn-left-on.png +0 -0
  200. package/dist/styles/assets/images/contents/btn/btn-left.png +0 -0
  201. package/dist/styles/assets/images/contents/btn/btn-right-on.png +0 -0
  202. package/dist/styles/assets/images/contents/btn/btn-right.png +0 -0
  203. package/dist/styles/assets/images/contents/btn/btn-up-on.png +0 -0
  204. package/dist/styles/assets/images/contents/btn/btn-up.png +0 -0
  205. package/dist/styles/assets/images/contents/icon/ico-business-trip.svg +21 -0
  206. package/dist/styles/assets/images/contents/icon/ico-holiday.svg +23 -0
  207. package/dist/styles/assets/images/contents/icon/ico-menu-help.svg +5 -0
  208. package/dist/styles/assets/images/contents/icon/ico-overtime.svg +17 -0
  209. package/dist/styles/assets/images/contents/icon/ico-quick-tab-move.svg +4 -0
  210. package/dist/styles/assets/images/contents/icon/ico-setting.svg +4 -0
  211. package/dist/styles/assets/images/contents/icon/ico_blue.png +0 -0
  212. package/dist/styles/assets/images/contents/icon/ico_red.png +0 -0
  213. package/dist/styles/assets/images/contents/icon/quick tab-text.svg +4 -0
  214. package/dist/styles/assets/images/contents/icon/quick-tab-text.svg +4 -0
  215. package/dist/styles/assets/images/logos/KRX Logo.svg +22 -0
  216. package/dist/styles/assets/images/logos/bwg-logo-blue.png +0 -0
  217. package/dist/styles/assets/images/logos/krx-logo-x2.png +0 -0
  218. package/dist/styles/assets/images/logos/krx-logo.png +0 -0
  219. package/dist/styles/assets/react.svg +1 -0
  220. package/dist/styles/components.css +785 -0
  221. package/dist/styles/fonts.css +101 -0
  222. package/dist/styles/global.css +52 -0
  223. package/dist/styles/index.css +41 -0
  224. package/dist/styles/layout.css +1132 -0
  225. package/dist/styles/login.css +151 -0
  226. package/dist/styles/popup.css +30 -0
  227. package/dist/styles/renderers.css +190 -0
  228. package/dist/styles/size.css +4019 -0
  229. package/dist/styles/variables.css +106 -0
  230. package/dist/test.txt +0 -0
  231. package/dist/types/images.d.ts +25 -0
  232. package/dist/utils/apiUtils.d.ts +85 -0
  233. package/dist/utils/arrayUtils.d.ts +34 -0
  234. package/dist/utils/commonUtils.d.ts +54 -0
  235. package/dist/utils/cookieUtils.d.ts +4 -0
  236. package/dist/utils/dateUtils.d.ts +26 -0
  237. package/dist/utils/envUtils.d.ts +8 -0
  238. package/dist/utils/imageUtils.d.ts +31 -0
  239. package/dist/utils/index.cjs +1 -0
  240. package/dist/utils/index.d.ts +14 -0
  241. package/dist/utils/index.js +211 -0
  242. package/dist/utils/messageUtils.d.ts +65 -0
  243. package/dist/utils/notificationUtils.d.ts +51 -0
  244. package/dist/utils/objectUtils.d.ts +27 -0
  245. package/dist/utils/realFormat.d.ts +242 -0
  246. package/dist/utils/serviceConfig.d.ts +35 -0
  247. package/dist/utils/stringUtils.d.ts +142 -0
  248. package/dist/utils/userUtils.d.ts +19 -0
  249. package/package.json +123 -0
  250. package/public/styles/assets/images/contents/icon/ico-business-trip.svg +21 -0
  251. package/public/styles/assets/images/contents/icon/ico-holiday.svg +23 -0
  252. package/public/styles/assets/images/contents/icon/ico-menu-help.svg +5 -0
  253. package/public/styles/assets/images/contents/icon/ico-overtime.svg +17 -0
  254. package/public/styles/assets/images/contents/icon/ico-quick-tab-move.svg +8 -0
  255. package/public/styles/assets/images/contents/icon/quick tab-text.svg +4 -0
  256. package/public/styles/assets/images/contents/icon/quick-tab-text.svg +4 -0
  257. package/public/test.txt +0 -0
@@ -0,0 +1,785 @@
1
+ /* 컴포넌트별 스타일 */
2
+
3
+ /* 버튼 컴포넌트 */
4
+ .btn-primary {
5
+ background-color: var(--primary-color);
6
+ border-color: var(--primary-color);
7
+ color: var(--text-white);
8
+ transition: var(--transition-normal);
9
+ }
10
+
11
+ .btn-primary:hover {
12
+ background-color: var(--primary-hover);
13
+ border-color: var(--primary-hover);
14
+ transform: translateY(-1px);
15
+ box-shadow: var(--shadow-medium);
16
+ }
17
+
18
+ /* 버튼 기본 스타일 */
19
+ .bwg-btn,
20
+ .bwg-title-box-right .bwg-btn {
21
+ font-size: 13px;
22
+ height: 30px;
23
+ padding: 0px 12px;
24
+ border-radius: var(--border-radius-sm);
25
+ font-weight: var(--font-weight-medium);
26
+ }
27
+ .bwg-title-box-right .bwg-btn {
28
+ border-color: var(--button-default-border);
29
+ }
30
+ .bwg-btn.ant-btn-variant-solid {
31
+ background: var(--button-solid);
32
+ color: var(--button-default);
33
+ border: 0;
34
+ }
35
+ .bwg-btn.ant-btn-variant-solid:not(:disabled):not(.ant-btn-disabled):hover {
36
+ background: var(--button-solid-hover);
37
+ border-color: var(--button-solid-hover);
38
+ }
39
+ .bwg-btn.ant-btn-variant-outlined:not(:disabled):not(.ant-btn-disabled):hover {
40
+ border-color: var(--button-primary);
41
+ border-color: var();
42
+ color: var(--button-primary);
43
+ }
44
+
45
+
46
+ /* 공통 버튼 테마 적용 - BwgView의 공통 버튼 영역에만 적용 */
47
+ .bwg-view .permission-buttons .ant-btn-primary {
48
+ background-color: var(--button-primary) !important;
49
+ border-color: var(--button-primary) !important;
50
+ color: var(--text-white) !important;
51
+ }
52
+
53
+ .bwg-view .permission-buttons .ant-btn-primary:hover {
54
+ background-color: var(--button-primary-hover) !important;
55
+ border-color: var(--button-primary-hover) !important;
56
+ }
57
+
58
+ .bwg-view .permission-buttons .ant-btn-primary:active {
59
+ background-color: var(--button-primary-active) !important;
60
+ border-color: var(--button-primary-active) !important;
61
+ }
62
+
63
+ .bwg-view .permission-buttons .bwg-btn.ant-btn-default {
64
+ background-color: var(--button-default) !important;
65
+ border-color: var(--button-permission-border) !important;
66
+ color: var(--text-secondary) !important;
67
+ }
68
+
69
+ .bwg-view .permission-buttons .ant-btn-default:hover {
70
+ background-color: var(--button-default) !important;
71
+ border-color: var(--button-primary) !important;
72
+ color: var(--button-primary) !important;
73
+ }
74
+
75
+ /* 다크 테마일 때 공통 버튼 텍스트 흰색 */
76
+ [data-theme='dark'] .bwg-view .permission-buttons .ant-btn-default {
77
+ color: var(--text-white) !important;
78
+ }
79
+
80
+ [data-theme='dark'] .bwg-view .permission-buttons .ant-btn-default:hover {
81
+ color: var(--text-white) !important;
82
+ }
83
+
84
+
85
+
86
+ /* 입력 컴포넌트 */
87
+ .input-field {
88
+ border: 1px solid var(--border-color);
89
+ border-radius: var(--border-radius-md);
90
+ padding: var(--spacing-sm) var(--spacing-md);
91
+ transition: var(--transition-normal);
92
+ }
93
+
94
+ .input-field:focus {
95
+ border-color: var(--primary-color);
96
+ box-shadow: 0 0 0 2px rgba(24, 144, 255, 0.2);
97
+ outline: none;
98
+ }
99
+
100
+ /* 카드 컴포넌트 */
101
+ .card {
102
+ background: var(--bg-primary);
103
+ border-radius: var(--border-radius-lg);
104
+ box-shadow: var(--shadow-light);
105
+ padding: var(--spacing-lg);
106
+ transition: var(--transition-normal);
107
+ }
108
+
109
+ .card:hover {
110
+ box-shadow: var(--shadow-medium);
111
+ transform: translateY(-2px);
112
+ }
113
+
114
+ /* 로딩 스피너 */
115
+ .loading-spinner {
116
+ display: flex;
117
+ justify-content: center;
118
+ align-items: center;
119
+ padding: var(--spacing-lg);
120
+ }
121
+
122
+ /* 에러 메시지 */
123
+ .error-message {
124
+ color: #ff4d4f;
125
+ background-color: #fff2f0;
126
+ border: 1px solid #ffccc7;
127
+ border-radius: var(--border-radius-md);
128
+ padding: var(--spacing-sm) var(--spacing-md);
129
+ margin: var(--spacing-sm) 0;
130
+ }
131
+
132
+ /* 성공 메시지 */
133
+ .success-message {
134
+ color: #52c41a;
135
+ background-color: #f6ffed;
136
+ border: 1px solid #b7eb8f;
137
+ border-radius: var(--border-radius-md);
138
+ padding: var(--spacing-sm) var(--spacing-md);
139
+ margin: var(--spacing-sm) 0;
140
+ }
141
+
142
+ /* BwgTitleBox 스타일 */
143
+ .bwg-title-box {
144
+ display: flex;
145
+ justify-content: space-between;
146
+ align-items: center;
147
+ width: 100%;
148
+ min-height: 30px;
149
+ margin-bottom: 15px;
150
+ }
151
+
152
+ .bwg-title-box-left {
153
+ display: flex;
154
+ align-items: center;
155
+ justify-content: flex-start;
156
+ }
157
+
158
+ .bwg-title-box-right {
159
+ display: flex;
160
+ align-items: center;
161
+ justify-content: flex-end;
162
+ }
163
+ .bwg-title-box .ant-typography {
164
+ margin: 0;
165
+ span {
166
+ margin-left: 10px;
167
+ }
168
+ }
169
+
170
+ .ant-typography {
171
+ color: var(--text-primary);
172
+ font-weight: var(--font-weight-bold);
173
+ }
174
+ .bwg-title-box-right .bwg-button-group .ant-flex {
175
+ gap: 6px !important;
176
+ }
177
+ .bwg-title-box-right .ant-btn.ant-btn-variant-outlined:not(:disabled):not(.ant-btn-disabled):hover,
178
+ .bwg-title-box-right .ant-btn.ant-btn-variant-outlined:not(:disabled):not(.ant-btn-disabled):active {
179
+ color: var(--primary-color);
180
+ border-color: var(--primary-color);
181
+ }
182
+
183
+ /* 뷰 컨테이너 스타일 */
184
+ .view-container {
185
+ height: 100%;
186
+ }
187
+
188
+ .view-wrapper {
189
+ background: #f5f5f5;
190
+ width: 100%;
191
+ height: 100%;
192
+ display: flex; /* 또는 grid */
193
+ flex-direction: column; /* 세로로 배치되는 경우 */
194
+ gap: 5px;
195
+ }
196
+
197
+ /* BwgView 헤더 스타일 */
198
+ .bwgview-header-container {
199
+ display: flex;
200
+ flex-direction: column;
201
+ border-radius: var(--border-radius-xxl);
202
+ border: 1px solid var(--border-color);
203
+ background-color: var(--bg-primary);
204
+ padding: 15px 23px;
205
+ }
206
+
207
+ .bwgview-header {
208
+ display: flex;
209
+ justify-content: space-between;
210
+ align-items: center;
211
+ }
212
+
213
+ .bwgview-header-left {
214
+ display: flex;
215
+ align-items: center;
216
+ gap: 8px;
217
+ > .ant-space-gap-col-middle {
218
+ column-gap: 0;
219
+ }
220
+ }
221
+
222
+ .bwgview-header-right {
223
+ display: flex;
224
+ align-items: center;
225
+ gap: 8px;
226
+ }
227
+ .bwgview-header-right .ant-space {
228
+ padding-right: 7px;
229
+ column-gap: 10px;
230
+ .ant-divider-vertical {
231
+ border-inline-start: 1px solid #cecece;
232
+ }
233
+ }
234
+ .bwgview-content {
235
+ height: inherit;
236
+ flex: 1 1;
237
+ }
238
+ .bwgview-header-right .ant-btn {
239
+ box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.1);
240
+ }
241
+
242
+ .bwgview-content-layout {
243
+ width: 100%;
244
+ height: 100%;
245
+ display: flex;
246
+
247
+ &.hz-layout {
248
+ flex-direction: row;
249
+
250
+ &.layout-left {
251
+ justify-content: flex-start;
252
+ }
253
+ &.layout-center {
254
+ justify-content: center;
255
+ }
256
+ &.layout-right {
257
+ justify-content: flex-end;
258
+ }
259
+ &.layout-between {
260
+ justify-content: space-between;
261
+ }
262
+ &.layout-around {
263
+ justify-content: space-around;
264
+ }
265
+
266
+ &.vertical-top {
267
+ align-items: start;
268
+ }
269
+ &.vertical-center {
270
+ align-items: center;
271
+ }
272
+ &.vertical-bottom {
273
+ align-items: end;
274
+ }
275
+ }
276
+
277
+ &.vt-layout {
278
+ flex-direction: column;
279
+ &.layout-left {
280
+ align-items: flex-start;
281
+ }
282
+ &.layout-center {
283
+ align-items: center;
284
+ }
285
+ &.layout-right {
286
+ align-items: flex-end;
287
+ }
288
+
289
+ &.vertical-top {
290
+ justify-content: start;
291
+ }
292
+ &.vertical-center {
293
+ justify-content: center;
294
+ }
295
+ &.vertical-bottom {
296
+ justify-content: end;
297
+ }
298
+ }
299
+ }
300
+
301
+ .bwgview-content-box {
302
+ box-sizing: border-box;
303
+ display: flex;
304
+ flex-direction: column;
305
+
306
+ /* 250826 고현아 추가 */
307
+ border-radius: 15px;
308
+ border: 1px solid var(--border-color);
309
+ padding: 20px 20px 15px;
310
+ background: var(--bg-primary);
311
+
312
+ &.box-st {
313
+ /* border: 1px solid #ddd !important;
314
+ padding: 10px 12px !important;
315
+ border-radius: 8px !important; */
316
+ }
317
+
318
+ &.content-box-left {
319
+ align-items: flex-start;
320
+ }
321
+ &.content-box-center {
322
+ align-items: center;
323
+ }
324
+ &.content-box-right {
325
+ align-items: flex-end;
326
+ }
327
+
328
+ }
329
+ /* 250826 고현아 추가 */
330
+ .none-box-st {
331
+ padding: 0;
332
+ border: 0;
333
+ border-radius: 0;
334
+ background: none;
335
+ }
336
+ .gap10 {
337
+ gap: 10px;
338
+ }
339
+ .gap20 {
340
+ gap: 20px;
341
+ }
342
+
343
+ /* Collapse 헤더 제거 */
344
+ .searchbox-collapse .ant-collapse-header {
345
+ display: none !important;
346
+ padding: 0 !important;
347
+ margin: 0 !important;
348
+ min-height: 0 !important;
349
+ height: 0 !important;
350
+ line-height: 0 !important;
351
+ width: 100% !important;
352
+ }
353
+
354
+ /* Collapse 전체 간격 줄이기 */
355
+ .searchbox-collapse .ant-collapse-item {
356
+ margin-bottom: 4px; /* 기본은 16px 정도 → 줄이기 */
357
+ border-bottom: none; /* 필요 시 선 제거 */
358
+ }
359
+
360
+ /* Collapse 패널 헤더 패딩 제거 */
361
+ .searchbox-collapse .ant-collapse-header {
362
+ padding: 4px 8px 4px 16px !important;
363
+ }
364
+
365
+ /* Collapse 본문 컨텐츠 여백 줄이기 */
366
+ .searchbox-collapse .ant-collapse-content > .ant-collapse-content-box {
367
+ padding: 12px 7px 0 10px !important;
368
+ }
369
+ /* searchBox 내부 폼 인라인으로 변경 */
370
+ .searchbox-collapse .form-component-wrapper .ant-row {
371
+ flex-flow: nowrap;
372
+ }
373
+
374
+
375
+ .pageMenuNm {
376
+ padding-right: 8px;
377
+ font-size: 20px;
378
+ font-weight: var(--font-weight-bold);
379
+ color: var(--text-primary);
380
+ line-height: 32px;
381
+ }
382
+
383
+ .bookmark-icon {
384
+ justify-content: center;
385
+ width: 30px;
386
+ height: 30px;
387
+ margin-right: 5px;
388
+ font-size: 20px;
389
+ color: #FFC352;
390
+ cursor: pointer;
391
+ transition: color 0.2s;
392
+ }
393
+
394
+ .bookmark-icon:hover {
395
+ color: #FFCE21;
396
+ }
397
+ .page-num-tag {
398
+ font-size: 11px;
399
+ font-weight: var(--font-weight-medium);
400
+ margin-inline-end: 0px;
401
+ display: flex;
402
+ justify-content: center;
403
+ align-items: center;
404
+ height: 26px;
405
+ border-color: #B2D1FF;
406
+ background: #ddf1ff;
407
+ color: #4887E5;
408
+ border-radius: 5px;
409
+ }
410
+ .page-num-tag + .menu-help-btn {
411
+ margin-left: 6px;
412
+ }
413
+ .menu-help-btn {
414
+ width: 23px !important;
415
+ height: 23px !important;
416
+ border-radius: var(--border-radius-sm) !important;
417
+ }
418
+
419
+ .bwgHelpIcon {
420
+ display: block;
421
+ width: 23px;
422
+ height: 23px;
423
+ background-image: url(./assets/images/contents/icon/ico-menu-help.svg);
424
+ background-size: contain;
425
+ background-repeat: no-repeat;
426
+ background-position: center;
427
+ }
428
+
429
+
430
+ /* BwgCmptArea 컴포넌트 스타일 */
431
+ .form-component-wrapper {
432
+ display: flex;
433
+ align-items: center;
434
+ }
435
+
436
+ .form-component-wrapper > * {
437
+ width: 100% !important;
438
+ }
439
+
440
+ /* Select 컴포넌트 특별 처리 */
441
+ .form-component-wrapper .ant-select {
442
+ width: 100% !important;
443
+ border-color: var(--border-color);
444
+ border-radius: var(--border-radius-sm);
445
+ color: var(--text-primary);
446
+ }
447
+
448
+ .form-component-wrapper .ant-select-selector {
449
+ width: 100% !important;
450
+ border-color: var(--border-color);
451
+ border-radius: var(--border-radius-sm);
452
+ color: var(--text-primary);
453
+ }
454
+ .ant-select {
455
+ border-radius: var(--border-radius-sm);
456
+ }
457
+
458
+ /* DatePicker 컴포넌트 특별 처리 */
459
+ .form-component-wrapper .ant-picker {
460
+ width: 100% !important;
461
+ border-color: var(--border-color);
462
+ border-radius: var(--border-radius-sm);
463
+ color: var(--text-primary);
464
+
465
+ }
466
+
467
+ /* Input 컴포넌트 특별 처리 */
468
+ .form-component-wrapper .ant-input {
469
+ width: 100% !important;
470
+ border-color: var(--border-color);
471
+ border-radius: var(--border-radius-sm);
472
+ color: var(--text-primary);
473
+ }
474
+
475
+ /* TextArea 컴포넌트 특별 처리 */
476
+ .form-component-wrapper .ant-input-textarea {
477
+ width: 100% !important;
478
+ border-color: var(--border-color);
479
+ border-radius: var(--border-radius-sm);
480
+ color: var(--text-primary);
481
+ }
482
+
483
+ /* Button 컴포넌트는 원래 크기 유지 */
484
+ .form-component-wrapper .ant-btn {
485
+ width: auto !important;
486
+ }
487
+
488
+ /* Space 컴포넌트 내부 버튼들 */
489
+ .form-component-wrapper .ant-space {
490
+ width: 100% !important;
491
+ }
492
+
493
+ .form-component-wrapper .ant-space .ant-btn {
494
+ width: auto !important;
495
+ }
496
+
497
+ /* BwgCmptArea 컴포넌트 공통 스타일 변경 */
498
+ .form-component-wrapper .ant-form-item .ant-form-item-label label {
499
+ color: var(--text-primary);
500
+ > span {
501
+ font-weight: var(--font-weight-semibold) !important;
502
+ }
503
+ }
504
+
505
+ /* bwgForm 공통 스타일 */
506
+ .bwg-form .ant-form-item {
507
+ margin-bottom: 10px;
508
+ }
509
+ .bwg-form .ant-form-item .ant-form-item-label label {
510
+ color: var(--text-primary);
511
+ font-weight: var(--font-weight-semibold);
512
+ }
513
+ /* ERP 공통 폼 스타일 */
514
+ .erp-cmm-form {
515
+ width: 100%;
516
+ }
517
+
518
+ .erp-cmm-form .ant-flex {
519
+ width: 100%;
520
+ }
521
+
522
+ /* sub Form 스타일 */
523
+ .sub-form .ant-form-item .ant-form-item-label label {
524
+ color: #9a9a9a;
525
+ font-weight: var(--font-weight-semibold);
526
+ }
527
+
528
+ .ant-tabs,
529
+ .ant-tabs-content,
530
+ .ant-tabs-tabpane,
531
+ .ant-carousel {
532
+ width: 100%;
533
+ height: 100%;
534
+ }
535
+
536
+ .between-vertical-btn-group {
537
+ display: flex;
538
+ justify-content: center;
539
+ height: 100%;
540
+ button {
541
+ width: 28px;
542
+ height: 28px;
543
+ padding: 0;
544
+ border-color: #e3e3e3;
545
+ }
546
+ &.upDown {
547
+ button {
548
+ margin: 0 3px;
549
+ &.btn-up {
550
+ background: url(./assets/images/contents/btn/btn-up.png) no-repeat
551
+ center;
552
+ &:hover,
553
+ &:active {
554
+ border-color: var(--primary-color);
555
+ background: var(--primary-color) url(./assets/images/contents/btn/btn-up-on.png)
556
+ no-repeat center;
557
+ }
558
+ }
559
+ &.btn-down {
560
+ background: url(./assets/images/contents/btn/btn-down.png) no-repeat
561
+ center;
562
+ &:hover,
563
+ &:active {
564
+ border-color: var(--primary-color);
565
+ background: var(--primary-color) url(./assets/images/contents/btn/btn-down-on.png)
566
+ no-repeat center;
567
+ }
568
+ }
569
+ }
570
+ }
571
+ &.leftRight {
572
+ flex-direction: column;
573
+ button {
574
+ margin: 3px 0;
575
+ &.btn-left {
576
+ background: url(./assets/images/contents/btn/btn-left.png) no-repeat
577
+ center;
578
+ &:hover,
579
+ &:active {
580
+ border-color: var(--primary-color);
581
+ background: var(--primary-color) url(./assets/images/contents/btn/btn-left-on.png)
582
+ no-repeat center;
583
+ }
584
+ }
585
+ &.btn-right {
586
+ background: url(./assets/images/contents/btn/btn-right.png) no-repeat
587
+ center;
588
+ &:hover,
589
+ &:active {
590
+ border-color: var(--primary-color);
591
+ background: var(--primary-color) url(./assets/images/contents/btn/btn-right-on.png)
592
+ no-repeat center;
593
+ }
594
+ }
595
+ }
596
+ }
597
+ }
598
+
599
+ .ant-space-compact.block {
600
+ width: 100%;
601
+ }
602
+
603
+ /* 그리드 검색 박스 */
604
+ .grid-search-box {
605
+ position: absolute;
606
+ top: 5px;
607
+ right: 5px;
608
+ width: 200px;
609
+ height: auto;
610
+ padding: 5px;
611
+ opacity: 1;
612
+ background: var(--bg-primary);
613
+ z-index: 100;
614
+ transform: translateY(0px);
615
+ transition: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
616
+ border-radius: 50px;
617
+ box-shadow: 0 0 8px 0 rgba(0, 0, 0, 0.2);
618
+ .ant-flex {
619
+ gap: 5px;
620
+ align-items: center;
621
+ }
622
+ .ant-input {
623
+ border-radius: 50px 0 0 50px;
624
+ border: 0;
625
+ height: 32px !important;
626
+ padding: 0 5px;
627
+ }
628
+ .ant-space-compact .ant-btn {
629
+ border-radius: 50%;
630
+ border: 0;
631
+ box-shadow: none;
632
+ &:hover,
633
+ &:active {
634
+ color: var(--primary-color);
635
+ }
636
+ }
637
+ .ant-flex > .ant-btn {
638
+ background: var(--button-solid);
639
+ box-shadow: none;
640
+ border-radius: 50%;
641
+ width: 30px;
642
+ height: 30px;
643
+ flex-shrink: 0;
644
+ font-size: 15px;
645
+ line-height: 30px;
646
+ color: var(--text-white);
647
+ }
648
+ .ant-flex > .ant-btn:hover {
649
+ background: var(--button-solid-hover);
650
+ color: var(--button-default);
651
+ }
652
+ }
653
+ .grid-search-box .anticon-search {
654
+ color: #777;
655
+ font-size: var(--font-size-md);
656
+ }
657
+ .bwg-tag {
658
+ font-size: 13px;
659
+ font-weight: var(--font-weight-medium);
660
+ line-height: 23px;
661
+ margin-inline-end: 0;
662
+ border-radius: 50px;
663
+ padding-inline: 13px;
664
+ }
665
+ .bwg-tag.ant-tag-blue {
666
+ color: #2589F4;
667
+ background: #E2F4FF;
668
+ border-color: #CAE6FB;
669
+ }
670
+
671
+
672
+ /* BwgDrawer 헤더 테마 적용 */
673
+ .main-drawer .ant-drawer-header {
674
+ padding: 28px 40px;
675
+ background-color: var(--drawer-header-bg);
676
+ color: var(--text-primary);
677
+ border-bottom: 1px solid #ececec;
678
+ }
679
+
680
+ .main-drawer .ant-drawer-header .ant-drawer-title {
681
+ font-size: var(--font-size-xl) !important;
682
+ color: var(--text-primary);
683
+ }
684
+
685
+ .main-drawer .ant-drawer-header .ant-drawer-close {
686
+ color: #565656 !important;
687
+ }
688
+
689
+ .main-drawer .ant-drawer-header .ant-drawer-close:hover {
690
+ background-color: #E1E3FB;
691
+ }
692
+ .main-drawer .ant-drawer-header .bwg-btn {
693
+ width: 30px;
694
+ height: 30px;
695
+ font-size: 17px;
696
+ color: #565656;
697
+ border-radius: 5px;
698
+ }
699
+ .main-drawer .ant-drawer-header .bwg-btn:hover {
700
+ background-color: #E1E3FB;
701
+ }
702
+
703
+ /* 다크 테마일 때 Drawer 헤더 */
704
+ [data-theme='dark'] .main-drawer .ant-drawer-header {
705
+ background-color: #1f1f1f !important;
706
+ color: var(--text-white) !important;
707
+ }
708
+
709
+ [data-theme='dark'] .main-drawer .ant-drawer-header .ant-drawer-title {
710
+ color: var(--text-white) !important;
711
+ }
712
+
713
+ [data-theme='dark'] .main-drawer .ant-drawer-header .ant-drawer-close {
714
+ color: var(--text-white) !important;
715
+ }
716
+
717
+ [data-theme='dark'] .main-drawer .ant-drawer-header .ant-drawer-close:hover {
718
+ color: #40a9ff !important;
719
+ background-color: #303030 !important;
720
+ }
721
+
722
+ /* 블루 테마일 때 Drawer 헤더 */
723
+ [data-theme='blue'] .main-drawer .ant-drawer-header {
724
+ background-color: #1890ff !important;
725
+ color: var(--text-white) !important;
726
+ }
727
+
728
+ [data-theme='blue'] .main-drawer .ant-drawer-header .ant-drawer-title {
729
+ color: var(--text-white) !important;
730
+ }
731
+
732
+ [data-theme='blue'] .main-drawer .ant-drawer-header .ant-drawer-close {
733
+ color: var(--text-white) !important;
734
+ }
735
+
736
+ [data-theme='blue'] .main-drawer .ant-drawer-header .ant-drawer-close:hover {
737
+ color: var(--text-white) !important;
738
+ background-color: #40a9ff !important;
739
+ }
740
+
741
+ /* 모던 테마일 때 Drawer 헤더 */
742
+ [data-theme='modern'] .main-drawer .ant-drawer-header {
743
+ background-color: var(--drawer-header-bg);
744
+ color: var(--text-primary);
745
+ }
746
+
747
+ [data-theme='modern'] .main-drawer .ant-drawer-header .ant-drawer-title {
748
+ color: var(--text-primary);
749
+ }
750
+
751
+ [data-theme='modern'] .main-drawer .ant-drawer-header .ant-drawer-close {
752
+ color: #565656 !important;
753
+ }
754
+
755
+ [data-theme='modern'] .main-drawer .ant-drawer-header .ant-drawer-close:hover {
756
+ background-color: #E1E3FB !important;
757
+ }
758
+
759
+ /* Drawer footer */
760
+ .main-drawer .ant-drawer-footer {
761
+ padding: 18px 40px;
762
+ border-top: 1px solid var(--button-light-border);
763
+ background: var(--bg-tertiary);
764
+ }
765
+ .main-drawer .ant-drawer-footer .bwg-btn {
766
+ height: var(--button-custom-height);
767
+ min-width: 74px;
768
+ box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.1);
769
+ }
770
+ .main-drawer .ant-drawer-footer .bwg-btn.ant-btn-variant-outlined {
771
+ border-color: var(--button-light-border);
772
+ }
773
+ .main-drawer .ant-drawer-footer .bwg-btn.ant-btn-variant-outlined:hover {
774
+ border-color: var(--button-primary-hover);
775
+ color: var(--button-primary-active);
776
+ }
777
+ .main-drawer .ant-drawer-footer .bwg-btn.ant-btn-variant-outlined:not(.bwg-btn.ant-btn-variant-solid) {
778
+ color: var(--primary-color);
779
+ }
780
+ .drawer-footer-btn-group {
781
+ display: flex;
782
+ align-items: center;
783
+ justify-content: flex-end;
784
+ gap: 6px;
785
+ }