x4js 2.0.12 → 2.0.14

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 (284) hide show
  1. package/.vscode/launch.json +14 -0
  2. package/README.md +20 -15
  3. package/{lib/src/demo → demo}/assets/radio.svg +3 -3
  4. package/{lib/src/demo → demo}/index.html +11 -11
  5. package/{lib/src/demo → demo}/main.scss +23 -21
  6. package/{lib/src/demo/main.tsx → demo/main.ts} +324 -323
  7. package/demo/package.json +26 -0
  8. package/demo/scss.d.ts +4 -0
  9. package/demo/svg.d.ts +1 -0
  10. package/demo/tsconfig.json +14 -0
  11. package/lib/README.txt +20 -15
  12. package/lib/cjs/x4.css +1 -1
  13. package/lib/cjs/x4.js +2 -1
  14. package/lib/esm/x4.css +1 -1
  15. package/lib/esm/x4.mjs +2 -1
  16. package/lib/src/components/base.scss +25 -26
  17. package/lib/src/components/boxes/boxes.module.scss +54 -37
  18. package/lib/src/components/boxes/boxes.ts +278 -125
  19. package/lib/src/components/breadcrumb/breadcrumb.scss +56 -0
  20. package/lib/src/components/breadcrumb/breadcrumb.ts +93 -0
  21. package/lib/src/components/breadcrumb/chevron-right.svg +1 -0
  22. package/lib/src/components/btngroup/btngroup.module.scss +40 -28
  23. package/lib/src/components/btngroup/btngroup.ts +152 -101
  24. package/lib/src/components/button/button.module.scss +172 -153
  25. package/lib/src/components/button/button.ts +185 -117
  26. package/lib/src/components/calendar/calendar.module.scss +162 -162
  27. package/lib/src/components/calendar/calendar.ts +326 -325
  28. package/lib/src/components/canvas/canvas.module.scss +25 -0
  29. package/lib/src/components/canvas/canvas.ts +189 -0
  30. package/lib/src/components/canvas/canvas_ex.ts +269 -0
  31. package/lib/src/components/checkbox/check.svg +3 -3
  32. package/lib/src/components/checkbox/checkbox.module.scss +141 -141
  33. package/lib/src/components/checkbox/checkbox.ts +139 -124
  34. package/lib/src/components/colorinput/colorinput.module.scss +64 -64
  35. package/lib/src/components/colorinput/colorinput.ts +90 -87
  36. package/lib/src/components/colorpicker/colorpicker.module.scss +132 -132
  37. package/lib/src/components/colorpicker/colorpicker.ts +481 -476
  38. package/lib/src/components/combobox/combobox.module.scss +132 -120
  39. package/lib/src/components/combobox/combobox.ts +275 -190
  40. package/lib/src/components/combobox/updown.svg +3 -3
  41. package/lib/src/components/components.ts +41 -0
  42. package/lib/src/components/dialog/dialog.module.scss +105 -71
  43. package/lib/src/components/dialog/dialog.ts +212 -92
  44. package/lib/src/components/filedrop/cloud-arrow-up.svg +1 -0
  45. package/lib/src/components/filedrop/filedrop.module.scss +70 -0
  46. package/lib/src/components/filedrop/filedrop.ts +131 -0
  47. package/lib/src/components/form/form.module.scss +38 -34
  48. package/lib/src/components/form/form.ts +172 -36
  49. package/lib/src/components/gridview/arrow-down-light.svg +1 -0
  50. package/lib/src/components/gridview/arrow-up-light.svg +1 -0
  51. package/lib/src/components/gridview/gridview.module.scss +324 -0
  52. package/lib/src/components/gridview/gridview.ts +1175 -0
  53. package/lib/src/components/header/header.module.scss +39 -39
  54. package/lib/src/components/header/header.ts +129 -123
  55. package/lib/src/components/icon/icon.module.scss +30 -30
  56. package/lib/src/components/icon/icon.ts +139 -134
  57. package/lib/src/components/image/image.module.scss +27 -20
  58. package/lib/src/components/image/image.ts +168 -67
  59. package/lib/src/components/input/input.module.scss +74 -69
  60. package/lib/src/components/input/input.ts +398 -274
  61. package/lib/src/components/keyboard/arrow-up.svg +1 -0
  62. package/lib/src/components/keyboard/delete-left.svg +1 -0
  63. package/lib/src/components/keyboard/eye-slash.svg +1 -0
  64. package/lib/src/components/keyboard/keyboard.module.scss +134 -0
  65. package/lib/src/components/keyboard/keyboard.ts +525 -0
  66. package/lib/src/components/label/label.module.scss +76 -52
  67. package/lib/src/components/label/label.ts +97 -55
  68. package/lib/src/components/link/link.ts +81 -0
  69. package/lib/src/components/listbox/listbox.module.scss +161 -103
  70. package/lib/src/components/listbox/listbox.ts +539 -427
  71. package/lib/src/components/menu/menu.module.scss +116 -107
  72. package/lib/src/components/menu/menu.ts +174 -168
  73. package/lib/src/components/messages/messages.module.scss +92 -47
  74. package/lib/src/components/messages/messages.ts +215 -64
  75. package/lib/src/components/messages/pen-field.svg +1 -0
  76. package/lib/src/components/normalize.scss +391 -386
  77. package/lib/src/components/notification/notification.module.scss +83 -81
  78. package/lib/src/components/notification/notification.ts +107 -108
  79. package/lib/src/components/panel/panel.module.scss +59 -47
  80. package/lib/src/components/panel/panel.ts +57 -56
  81. package/lib/src/components/popup/popup.module.scss +45 -43
  82. package/lib/src/components/popup/popup.ts +440 -395
  83. package/lib/src/components/progress/progress.module.scss +56 -56
  84. package/lib/src/components/progress/progress.ts +43 -42
  85. package/lib/src/components/propgrid/folder-closed.svg +1 -0
  86. package/lib/src/components/propgrid/folder-open.svg +1 -0
  87. package/lib/src/components/propgrid/progrid.module.scss +108 -0
  88. package/lib/src/components/propgrid/propgrid.ts +271 -0
  89. package/lib/src/components/propgrid/updown.svg +4 -0
  90. package/lib/src/components/radio/radio.module.scss +147 -0
  91. package/lib/src/components/radio/radio.svg +4 -0
  92. package/lib/src/components/radio/radio.ts +142 -0
  93. package/lib/src/components/rating/rating.module.scss +22 -22
  94. package/lib/src/components/rating/rating.ts +131 -125
  95. package/lib/src/components/select/select.module.scss +9 -0
  96. package/lib/src/components/select/select.ts +134 -0
  97. package/lib/src/components/shared.scss +137 -76
  98. package/lib/src/components/sizers/sizer.module.scss +89 -89
  99. package/lib/src/components/sizers/sizer.ts +130 -119
  100. package/lib/src/components/slider/slider.module.scss +117 -70
  101. package/lib/src/components/slider/slider.ts +197 -142
  102. package/lib/src/components/switch/switch.module.scss +126 -126
  103. package/lib/src/components/switch/switch.ts +61 -55
  104. package/lib/src/components/tabs/tabs.module.scss +45 -46
  105. package/lib/src/components/tabs/tabs.ts +199 -157
  106. package/lib/src/components/textarea/textarea.module.scss +63 -59
  107. package/lib/src/components/textarea/textarea.ts +125 -54
  108. package/lib/src/components/textedit/textedit.module.scss +115 -113
  109. package/lib/src/components/textedit/textedit.ts +110 -82
  110. package/lib/src/components/themes.scss +88 -77
  111. package/lib/src/components/tickline/tickline.module.scss +26 -0
  112. package/lib/src/components/tickline/tickline.ts +82 -0
  113. package/lib/src/components/tooltips/comments-question.svg +1 -0
  114. package/lib/src/components/tooltips/tooltips.scss +71 -50
  115. package/lib/src/components/tooltips/tooltips.ts +108 -102
  116. package/lib/src/components/treeview/treeview.module.scss +184 -115
  117. package/lib/src/components/treeview/treeview.ts +445 -403
  118. package/lib/src/components/viewport/viewport.module.scss +31 -24
  119. package/lib/src/components/viewport/viewport.ts +41 -38
  120. package/lib/src/core/component.ts +1072 -979
  121. package/lib/src/core/core_application.ts +264 -0
  122. package/lib/src/core/core_colors.ts +249 -249
  123. package/lib/src/core/core_data.ts +1309 -0
  124. package/lib/src/core/core_dom.ts +471 -471
  125. package/lib/src/core/core_dragdrop.ts +200 -200
  126. package/lib/src/core/core_element.ts +109 -97
  127. package/lib/src/core/core_events.ts +177 -149
  128. package/lib/src/core/core_i18n.ts +393 -377
  129. package/lib/src/core/core_react.ts +79 -0
  130. package/lib/src/core/core_router.ts +237 -221
  131. package/lib/src/core/core_styles.ts +214 -214
  132. package/lib/src/core/core_svg.ts +711 -550
  133. package/lib/src/core/core_tools.ts +906 -673
  134. package/lib/src/types/scss.d.ts +4 -4
  135. package/lib/src/types/x4react.d.ts +8 -8
  136. package/lib/src/x4.scss +18 -18
  137. package/lib/src/x4.ts +31 -62
  138. package/lib/src/x4tsx.d.ts +25 -0
  139. package/lib/styles/x4.css +1 -1
  140. package/lib/types/x4js.d.ts +853 -127
  141. package/package.json +5 -6
  142. package/scripts/build.mjs +378 -0
  143. package/scripts/prepack.mjs +346 -0
  144. package/src/components/base.scss +25 -0
  145. package/src/components/boxes/boxes.module.scss +54 -0
  146. package/src/components/boxes/boxes.ts +278 -0
  147. package/src/components/breadcrumb/breadcrumb.scss +56 -0
  148. package/src/components/breadcrumb/breadcrumb.ts +93 -0
  149. package/src/components/breadcrumb/chevron-right.svg +1 -0
  150. package/src/components/btngroup/btngroup.module.scss +41 -0
  151. package/src/components/btngroup/btngroup.ts +153 -0
  152. package/src/components/button/button.module.scss +173 -0
  153. package/src/components/button/button.ts +185 -0
  154. package/src/components/calendar/calendar-check-sharp-light.svg +1 -0
  155. package/src/components/calendar/calendar.module.scss +163 -0
  156. package/src/components/calendar/calendar.ts +327 -0
  157. package/src/components/calendar/chevron-left-sharp-light.svg +1 -0
  158. package/src/components/calendar/chevron-right-sharp-light.svg +1 -0
  159. package/src/components/canvas/canvas.module.scss +25 -0
  160. package/src/components/canvas/canvas.ts +189 -0
  161. package/src/components/canvas/canvas_ex.ts +269 -0
  162. package/src/components/checkbox/check.svg +4 -0
  163. package/src/components/checkbox/checkbox.module.scss +142 -0
  164. package/src/components/checkbox/checkbox.ts +140 -0
  165. package/src/components/colorinput/colorinput.module.scss +65 -0
  166. package/src/components/colorinput/colorinput.ts +91 -0
  167. package/src/components/colorinput/crosshairs-simple-sharp-light.svg +1 -0
  168. package/src/components/colorpicker/colorpicker.module.scss +133 -0
  169. package/src/components/colorpicker/colorpicker.ts +482 -0
  170. package/src/components/combobox/combobox.module.scss +133 -0
  171. package/src/components/combobox/combobox.ts +275 -0
  172. package/src/components/combobox/updown.svg +4 -0
  173. package/src/components/components.ts +41 -0
  174. package/src/components/dialog/dialog.module.scss +105 -0
  175. package/src/components/dialog/dialog.ts +212 -0
  176. package/src/components/dialog/xmark-sharp-light.svg +1 -0
  177. package/src/components/filedrop/cloud-arrow-up.svg +1 -0
  178. package/src/components/filedrop/filedrop.module.scss +70 -0
  179. package/src/components/filedrop/filedrop.ts +131 -0
  180. package/src/components/form/form.module.scss +38 -0
  181. package/src/components/form/form.ts +172 -0
  182. package/src/components/gridview/arrow-down-light.svg +1 -0
  183. package/src/components/gridview/arrow-up-light.svg +1 -0
  184. package/src/components/gridview/gridview.module.scss +324 -0
  185. package/src/components/gridview/gridview.ts +1175 -0
  186. package/src/components/header/header.module.scss +40 -0
  187. package/src/components/header/header.ts +130 -0
  188. package/src/components/icon/icon.module.scss +30 -0
  189. package/src/components/icon/icon.ts +139 -0
  190. package/src/components/image/image.module.scss +28 -0
  191. package/src/components/image/image.ts +168 -0
  192. package/src/components/input/input.module.scss +74 -0
  193. package/src/components/input/input.ts +398 -0
  194. package/src/components/keyboard/arrow-up.svg +1 -0
  195. package/src/components/keyboard/delete-left.svg +1 -0
  196. package/src/components/keyboard/eye-slash.svg +1 -0
  197. package/src/components/keyboard/keyboard.module.scss +134 -0
  198. package/src/components/keyboard/keyboard.ts +525 -0
  199. package/src/components/label/label.module.scss +76 -0
  200. package/src/components/label/label.ts +97 -0
  201. package/src/components/link/link.ts +81 -0
  202. package/src/components/listbox/listbox.module.scss +161 -0
  203. package/src/components/listbox/listbox.ts +539 -0
  204. package/src/components/menu/caret-right-solid.svg +1 -0
  205. package/src/components/menu/menu.module.scss +117 -0
  206. package/src/components/menu/menu.ts +174 -0
  207. package/src/components/messages/circle-exclamation.svg +1 -0
  208. package/src/components/messages/messages.module.scss +92 -0
  209. package/src/components/messages/messages.ts +215 -0
  210. package/src/components/messages/pen-field.svg +1 -0
  211. package/src/components/normalize.scss +391 -0
  212. package/src/components/notification/circle-check-solid.svg +1 -0
  213. package/src/components/notification/circle-exclamation-solid.svg +1 -0
  214. package/src/components/notification/circle-notch-light.svg +1 -0
  215. package/src/components/notification/notification.module.scss +84 -0
  216. package/src/components/notification/notification.ts +107 -0
  217. package/src/components/notification/xmark-sharp-light.svg +1 -0
  218. package/src/components/panel/panel.module.scss +60 -0
  219. package/src/components/panel/panel.ts +58 -0
  220. package/src/components/popup/popup.module.scss +45 -0
  221. package/src/components/popup/popup.ts +440 -0
  222. package/src/components/progress/progress.module.scss +57 -0
  223. package/src/components/progress/progress.ts +44 -0
  224. package/src/components/propgrid/folder-closed.svg +1 -0
  225. package/src/components/propgrid/folder-open.svg +1 -0
  226. package/src/components/propgrid/progrid.module.scss +108 -0
  227. package/src/components/propgrid/propgrid.ts +271 -0
  228. package/src/components/propgrid/updown.svg +4 -0
  229. package/src/components/radio/radio.module.scss +147 -0
  230. package/src/components/radio/radio.svg +4 -0
  231. package/src/components/radio/radio.ts +142 -0
  232. package/src/components/rating/rating.module.scss +23 -0
  233. package/src/components/rating/rating.ts +131 -0
  234. package/src/components/rating/star-sharp-light.svg +1 -0
  235. package/src/components/rating/star-sharp-solid.svg +1 -0
  236. package/src/components/select/select.module.scss +9 -0
  237. package/src/components/select/select.ts +134 -0
  238. package/src/components/shared.scss +137 -0
  239. package/src/components/sizers/sizer.module.scss +90 -0
  240. package/src/components/sizers/sizer.ts +131 -0
  241. package/src/components/slider/slider.module.scss +118 -0
  242. package/src/components/slider/slider.ts +198 -0
  243. package/src/components/switch/switch.module.scss +127 -0
  244. package/src/components/switch/switch.ts +62 -0
  245. package/src/components/tabs/tabs.module.scss +45 -0
  246. package/src/components/tabs/tabs.ts +199 -0
  247. package/src/components/textarea/textarea.module.scss +63 -0
  248. package/src/components/textarea/textarea.ts +125 -0
  249. package/src/components/textedit/textedit.module.scss +116 -0
  250. package/src/components/textedit/textedit.ts +110 -0
  251. package/src/components/themes.scss +88 -0
  252. package/src/components/tickline/tickline.module.scss +26 -0
  253. package/src/components/tickline/tickline.ts +82 -0
  254. package/src/components/tooltips/circle-info-sharp-light.svg +1 -0
  255. package/src/components/tooltips/comments-question.svg +1 -0
  256. package/src/components/tooltips/tooltips.scss +72 -0
  257. package/src/components/tooltips/tooltips.ts +109 -0
  258. package/src/components/treeview/chevron-down-light.svg +1 -0
  259. package/src/components/treeview/treeview.module.scss +185 -0
  260. package/src/components/treeview/treeview.ts +445 -0
  261. package/src/components/viewport/viewport.module.scss +32 -0
  262. package/src/components/viewport/viewport.ts +41 -0
  263. package/src/core/component.ts +1072 -0
  264. package/src/core/core_application.ts +264 -0
  265. package/src/core/core_colors.ts +250 -0
  266. package/src/core/core_data.ts +1309 -0
  267. package/src/core/core_dom.ts +471 -0
  268. package/src/core/core_dragdrop.ts +201 -0
  269. package/src/core/core_element.ts +110 -0
  270. package/src/core/core_events.ts +177 -0
  271. package/src/core/core_i18n.ts +393 -0
  272. package/src/core/core_react.ts +79 -0
  273. package/src/core/core_router.ts +237 -0
  274. package/src/core/core_styles.ts +214 -0
  275. package/src/core/core_svg.ts +711 -0
  276. package/src/core/core_tools.ts +906 -0
  277. package/src/types/scss.d.ts +4 -0
  278. package/src/types/svg.d.ts +1 -0
  279. package/src/types/x4react.d.ts +9 -0
  280. package/src/x4.scss +19 -0
  281. package/src/x4.ts +31 -62
  282. package/src/x4tsx.d.ts +25 -0
  283. package/tsconfig.json +14 -0
  284. /package/{lib/src/demo → demo}/assets/house-light.svg +0 -0
@@ -1,142 +1,142 @@
1
- /**
2
- * ___ ___ __
3
- * \ \/ / / _
4
- * \ / /_| |_
5
- * / \____ _|
6
- * /__/\__\ |_|
7
- *
8
- * @file checkbox.module.scss
9
- * @author Etienne Cochard
10
- *
11
- * @copyright (c) 2024 R-libre ingenierie
12
- *
13
- * Use of this source code is governed by an MIT-style license
14
- * that can be found in the LICENSE file or at https://opensource.org/licenses/MIT.
15
- **/
16
-
17
- @use "../shared.scss";
18
-
19
- :root {
20
- --checkbox-background-check: var( --accent-background );
21
- --checkbox-background-check-hover: var( --accent-background-hover );
22
- --checkbox-background-disabled: var( --disabled-color );
23
- --checkbox-background-disabled-check: var( --disabled-background );
24
- --checkbox-color-disabled: var( --disabled-background );
25
- --checkbox-check-border: var( --border );
26
- --checkbox-check-border-hover: var( --border-hover );
27
- }
28
-
29
- .x4checkbox {
30
- @extend .hbox;
31
-
32
- display: flex;
33
- flex-direction: row;
34
- align-items: center;
35
-
36
- margin: 5px;
37
- padding: 4px;
38
- gap: 4px;
39
- cursor: pointer;
40
-
41
- .inner {
42
- height: 1rem;
43
- width: 1rem;
44
- color: white;
45
- position: relative;
46
- order: 1;
47
-
48
- input {
49
- appearance: none;
50
- outline: none;
51
-
52
- cursor: pointer;
53
- display: block;
54
- margin: 0;
55
- padding: 0;
56
- left: 0;
57
- top: 0;
58
- width: 100%;
59
- height: 100%;
60
- transition: opacity .1s ease;
61
-
62
- &:checked {
63
- background-color: var( --checkbox-background-check );
64
- }
65
-
66
- &:checked:hover {
67
- background-color: var( --checkbox-background-check-hover );
68
- }
69
-
70
- &:not(:checked) {
71
- border: 1px solid var( --checkbox-check-border );
72
- }
73
-
74
- &:not(:checked):hover {
75
- border: 1px solid var( --checkbox-check-border-hover );
76
- }
77
- }
78
-
79
- svg {
80
- margin: auto;
81
- pointer-events: none;
82
- position: absolute;
83
- opacity: 0;
84
- left: 0;
85
- right: 0;
86
- top: 0;
87
- bottom: 0;
88
- width: 100%;
89
- height: 50%;
90
- }
91
-
92
- &:has(input:checked) {
93
- input {
94
- opacity: 1;
95
- }
96
-
97
- svg {
98
- opacity: 1;
99
- }
100
- }
101
- }
102
-
103
- &:focus-within {
104
- label #text {
105
- text-decoration: underline;
106
- }
107
- }
108
-
109
- &[disabled] {
110
- &, * {
111
- cursor: not-allowed;
112
- }
113
-
114
- label {
115
-
116
- pointer-events: none;
117
- color: var( --checkbox-color-disabled );
118
- }
119
-
120
- .inner {
121
- pointer-events: none;
122
- input {
123
- background-color: var( --checkbox-background-disabled );
124
-
125
- &:checked {
126
- background-color: var( --checkbox-background-disabled-check );
127
- }
128
- }
129
- }
130
- }
131
-
132
- label {
133
- text-align: right;
134
- cursor: inherit;
135
- order: 2;
136
- }
137
-
138
- &.left #label {
139
- order: 0;
140
- text-align: left;
141
- }
1
+ /**
2
+ * ___ ___ __
3
+ * \ \/ / / _
4
+ * \ / /_| |_
5
+ * / \____ _|
6
+ * /__/\__\ |_|
7
+ *
8
+ * @file checkbox.module.scss
9
+ * @author Etienne Cochard
10
+ *
11
+ * @copyright (c) 2024 R-libre ingenierie
12
+ *
13
+ * Use of this source code is governed by an MIT-style license
14
+ * that can be found in the LICENSE file or at https://opensource.org/licenses/MIT.
15
+ **/
16
+
17
+ @use "../shared.scss";
18
+
19
+ :root {
20
+ --checkbox-background-check: var( --accent-background );
21
+ --checkbox-background-check-hover: var( --accent-background-hover );
22
+ --checkbox-background-disabled: var( --disabled-color );
23
+ --checkbox-background-disabled-check: var( --disabled-background );
24
+ --checkbox-color-disabled: var( --disabled-background );
25
+ --checkbox-check-border: var( --border );
26
+ --checkbox-check-border-hover: var( --border-hover );
27
+ }
28
+
29
+ .x4checkbox {
30
+ @extend .hbox;
31
+
32
+ display: flex;
33
+ flex-direction: row;
34
+ align-items: center;
35
+
36
+ margin: 5px;
37
+ padding: 4px;
38
+ gap: 4px;
39
+ cursor: pointer;
40
+
41
+ .inner {
42
+ height: 1rem;
43
+ width: 1rem;
44
+ color: white;
45
+ position: relative;
46
+ order: 1;
47
+
48
+ input {
49
+ appearance: none;
50
+ outline: none;
51
+
52
+ cursor: pointer;
53
+ display: block;
54
+ margin: 0;
55
+ padding: 0;
56
+ left: 0;
57
+ top: 0;
58
+ width: 100%;
59
+ height: 100%;
60
+ transition: opacity .1s ease;
61
+
62
+ &:checked {
63
+ background-color: var( --checkbox-background-check );
64
+ }
65
+
66
+ &:checked:hover {
67
+ background-color: var( --checkbox-background-check-hover );
68
+ }
69
+
70
+ &:not(:checked) {
71
+ border: 1px solid var( --checkbox-check-border );
72
+ }
73
+
74
+ &:not(:checked):hover {
75
+ border: 1px solid var( --checkbox-check-border-hover );
76
+ }
77
+ }
78
+
79
+ svg {
80
+ margin: auto;
81
+ pointer-events: none;
82
+ position: absolute;
83
+ opacity: 0;
84
+ left: 0;
85
+ right: 0;
86
+ top: 0;
87
+ bottom: 0;
88
+ width: 100%;
89
+ height: 50%;
90
+ }
91
+
92
+ &:has(input:checked) {
93
+ input {
94
+ opacity: 1;
95
+ }
96
+
97
+ svg {
98
+ opacity: 1;
99
+ }
100
+ }
101
+ }
102
+
103
+ &:focus-within {
104
+ label #text {
105
+ text-decoration: underline;
106
+ }
107
+ }
108
+
109
+ &[disabled] {
110
+ &, * {
111
+ cursor: not-allowed;
112
+ }
113
+
114
+ label {
115
+
116
+ pointer-events: none;
117
+ color: var( --checkbox-color-disabled );
118
+ }
119
+
120
+ .inner {
121
+ pointer-events: none;
122
+ input {
123
+ background-color: var( --checkbox-background-disabled );
124
+
125
+ &:checked {
126
+ background-color: var( --checkbox-background-disabled-check );
127
+ }
128
+ }
129
+ }
130
+ }
131
+
132
+ label {
133
+ text-align: right;
134
+ cursor: inherit;
135
+ order: 2;
136
+ }
137
+
138
+ &.left #label {
139
+ order: 0;
140
+ text-align: left;
141
+ }
142
142
  }
@@ -1,125 +1,140 @@
1
- import { Component, ComponentEvents, ComponentProps, EvChange, makeUniqueComponentId } from '../../core/component.js';
2
- import { EventCallback } from '../../core/core_events.js';
3
-
4
- import { Input } from '../input/input';
5
- import { Label } from '../label/label';
6
-
7
- import { svgLoader } from '../icon/icon.js';
8
-
9
- import "./checkbox.module.scss"
10
- import icon from "./check.svg";
11
-
12
- /**
13
- * Checkbox events
14
- */
15
-
16
- interface CheckBoxEvents extends ComponentEvents {
17
- change?: EvChange;
18
- }
19
-
20
- /**
21
- * Checkbox properties.
22
- */
23
-
24
- interface CheckboxProps extends ComponentProps {
25
- label: string; // The text label for the checkbox.
26
- checked?: boolean; // Optional boolean indicating if the checkbox is checked by default.
27
- value?: boolean | number | string; // Optional value associated with the checkbox.
28
- change?: EventCallback<EvChange>;
29
- }
30
-
31
- /**
32
- * Checkbox component that can be checked or unchecked.
33
- */
34
-
35
- export class Checkbox extends Component<CheckboxProps,CheckBoxEvents> {
36
-
37
- readonly _input: Input;
38
-
39
- /**
40
- * Creates an instance of the Checkbox component.
41
- *
42
- * @param {CheckboxProps} props - The properties for the checkbox component, including label, checked state, and value.
43
- * @example
44
- * const checkbox = new Checkbox({ label: 'Accept Terms', checked: true });
45
- */
46
-
47
- constructor( props: CheckboxProps ) {
48
- super( props );
49
-
50
- const inputId = makeUniqueComponentId( );
51
-
52
- this.mapPropEvents( props, 'change' );
53
-
54
- this.setContent( [
55
- new Component( {
56
- cls: 'inner',
57
- content: [
58
- this._input = new Input( {
59
- type:"checkbox",
60
- id: inputId,
61
- checked: props.checked,
62
- dom_events: {
63
- change: ( ) => this._on_change( ),
64
- }
65
- })
66
- ]
67
- }),
68
- new Label( {
69
- tag: 'label',
70
- text: props.label,
71
- labelFor: inputId,
72
- id: undefined
73
- } ),
74
- ])
75
-
76
- svgLoader.load( icon ).then( svg => {
77
- this.query<Label>( '.inner' ).dom.insertAdjacentHTML( "beforeend", svg );
78
- });
79
- }
80
-
81
- /**
82
- * check state changed
83
- */
84
-
85
- private _on_change() {
86
- this.fire('change', { value:this.getCheck() } );
87
- }
88
-
89
- /**
90
- * @return the checked value
91
- */
92
-
93
- public getCheck() {
94
- const d = this._input.dom as HTMLInputElement;
95
- return d.checked;
96
- }
97
-
98
- /**
99
- * change the checked value
100
- * @param {boolean} ck new checked value
101
- */
102
-
103
- public setCheck(ck: boolean) {
104
- const d = this._input.dom as HTMLInputElement;
105
- d.checked = ck;
106
- }
107
-
108
- /**
109
- * change the checkbox label
110
- * @param text
111
- */
112
-
113
- public setLabel(text: string) {
114
- this.query<Label>('label').setText( text );
115
- }
116
-
117
- /**
118
- * toggle the checkbox
119
- */
120
-
121
- public toggle() {
122
- this.setCheck( !this.getCheck() );
123
- }
124
-
1
+ import { Component, ComponentEvents, ComponentProps, EvChange, makeUniqueComponentId } from '../../core/component.js';
2
+ import { EventCallback } from '../../core/core_events.js';
3
+
4
+ import { Input } from '../input/input';
5
+ import { Label } from '../label/label';
6
+
7
+ import { svgLoader } from '../icon/icon.js';
8
+
9
+ import "./checkbox.module.scss"
10
+ import icon from "./check.svg";
11
+ import { class_ns } from '@core/core_tools.js';
12
+
13
+ /**
14
+ * Checkbox events
15
+ */
16
+
17
+ interface CheckBoxEvents extends ComponentEvents {
18
+ change?: EvChange;
19
+ }
20
+
21
+ /**
22
+ * Checkbox properties.
23
+ */
24
+
25
+ interface CheckboxProps extends ComponentProps {
26
+ label: string; // The text label for the checkbox.
27
+ checked?: boolean; // Optional boolean indicating if the checkbox is checked by default.
28
+ value?: boolean | number | string; // Optional value associated with the checkbox.
29
+ name?: string;
30
+ change?: EventCallback<EvChange>;
31
+ }
32
+
33
+ /**
34
+ * Checkbox component that can be checked or unchecked.
35
+ */
36
+
37
+ @class_ns( "x4" )
38
+ export class Checkbox extends Component<CheckboxProps,CheckBoxEvents> {
39
+ readonly _input: Input;
40
+
41
+ /**
42
+ * Creates an instance of the Checkbox component.
43
+ *
44
+ * @param {CheckboxProps} props - The properties for the checkbox component, including label, checked state, and value.
45
+ * @example
46
+ * const checkbox = new Checkbox({ label: 'Accept Terms', checked: true });
47
+ */
48
+
49
+ constructor( props: CheckboxProps ) {
50
+ super( props );
51
+
52
+ const inputId = makeUniqueComponentId( );
53
+
54
+ this.mapPropEvents( props, 'change' );
55
+
56
+ this.setContent( [
57
+ new Component( {
58
+ cls: 'inner',
59
+ content: [
60
+ this._input = new Input( {
61
+ type:"checkbox",
62
+ id: inputId,
63
+ name: props.name,
64
+ checked: props.checked,
65
+ dom_events: {
66
+ change: ( ) => this._on_change( ),
67
+ }
68
+ })
69
+ ]
70
+ }),
71
+ new Label( {
72
+ tag: 'label',
73
+ text: props.label,
74
+ labelFor: inputId,
75
+ id: undefined
76
+ } ),
77
+ ])
78
+
79
+ svgLoader.load( icon ).then( svg => {
80
+ this.query<Label>( '.inner' ).dom.insertAdjacentHTML( "beforeend", svg );
81
+ });
82
+
83
+ this.addDOMEvent('click', (e) => this._on_click(e)); // for outside click
84
+ }
85
+
86
+ /**
87
+ * handle click outside label & input
88
+ */
89
+
90
+ protected _on_click( ev: MouseEvent ) {
91
+ if( ev.target==this.dom ) {
92
+ (this._input.dom as HTMLInputElement).click( );
93
+ ev.preventDefault();
94
+ ev.stopPropagation();
95
+ }
96
+ }
97
+
98
+ /**
99
+ * check state changed
100
+ */
101
+
102
+ private _on_change() {
103
+ this.fire('change', { value:this.getCheck() } );
104
+ }
105
+
106
+ /**
107
+ * @return the checked value
108
+ */
109
+
110
+ public getCheck() {
111
+ return this._input.getCheck();
112
+ }
113
+
114
+ /**
115
+ * change the checked value
116
+ * @param {boolean} ck new checked value
117
+ */
118
+
119
+ public setCheck(ck: boolean) {
120
+ this._input.setCheck( ck );
121
+ }
122
+
123
+ /**
124
+ * change the checkbox label
125
+ * @param text
126
+ */
127
+
128
+ public setLabel(text: string) {
129
+ this.query<Label>('label').setText( text );
130
+ }
131
+
132
+ /**
133
+ * toggle the checkbox
134
+ */
135
+
136
+ public toggle() {
137
+ this.setCheck( !this.getCheck() );
138
+ }
139
+
125
140
  }
@@ -1,65 +1,65 @@
1
- /**
2
- * ___ ___ __
3
- * \ \/ / / _
4
- * \ / /_| |_
5
- * / \____ _|
6
- * /__/\__\ |_|
7
- *
8
- * @file colorinput.module.scss
9
- * @author Etienne Cochard
10
- *
11
- * @copyright (c) 2024 R-libre ingenierie
12
- *
13
- * Use of this source code is governed by an MIT-style license
14
- * that can be found in the LICENSE file or at https://opensource.org/licenses/MIT.
15
- **/
16
-
17
- :root {
18
- --colorinput-btn-background: inherit;
19
- --colorinput-btn-color: var( --text-secondary );
20
- --colorinput-btn-color-hover: var( --text-primary );
21
- }
22
-
23
- .x4colorinput {
24
- margin: 5px;
25
- border-bottom: 1px solid var( --border );
26
- outline: none;
27
-
28
- &:focus-within {
29
- border-bottom-color: var( --border-focus );
30
- }
31
-
32
- .swatch {
33
- margin: 4px;
34
- width: 1rem;
35
- height: 1rem;
36
- }
37
-
38
- input {
39
- outline: none;
40
- margin: 0;
41
- height: 100%;
42
- flex-grow: 1;
43
- }
44
-
45
- .x4button {
46
- margin: 0;
47
- padding: 0;
48
- outline: none;
49
- background-color: var( --combobox-btn-background );
50
- color: var( --colorinput-btn-color );
51
-
52
- #icon {
53
- color: var( --colorinput-btn-color );
54
- }
55
-
56
- &:hover, &:hover #icon {
57
- color: var( --colorinput-btn-color-hover );
58
- }
59
-
60
- &:focus {
61
- //background-color: var( --color-30 );
62
- //color: var( --color-10 );
63
- }
64
- }
1
+ /**
2
+ * ___ ___ __
3
+ * \ \/ / / _
4
+ * \ / /_| |_
5
+ * / \____ _|
6
+ * /__/\__\ |_|
7
+ *
8
+ * @file colorinput.module.scss
9
+ * @author Etienne Cochard
10
+ *
11
+ * @copyright (c) 2024 R-libre ingenierie
12
+ *
13
+ * Use of this source code is governed by an MIT-style license
14
+ * that can be found in the LICENSE file or at https://opensource.org/licenses/MIT.
15
+ **/
16
+
17
+ :root {
18
+ --colorinput-btn-background: inherit;
19
+ --colorinput-btn-color: var( --text-secondary );
20
+ --colorinput-btn-color-hover: var( --text-primary );
21
+ }
22
+
23
+ .x4colorinput {
24
+ margin: 5px;
25
+ border-bottom: 1px solid var( --border );
26
+ outline: none;
27
+
28
+ &:focus-within {
29
+ border-bottom-color: var( --border-focus );
30
+ }
31
+
32
+ .swatch {
33
+ margin: 4px;
34
+ width: 1rem;
35
+ height: 1rem;
36
+ }
37
+
38
+ input {
39
+ outline: none;
40
+ margin: 0;
41
+ height: 100%;
42
+ flex-grow: 1;
43
+ }
44
+
45
+ .x4button {
46
+ margin: 0;
47
+ padding: 0;
48
+ outline: none;
49
+ background-color: var( --combobox-btn-background );
50
+ color: var( --colorinput-btn-color );
51
+
52
+ #icon {
53
+ color: var( --colorinput-btn-color );
54
+ }
55
+
56
+ &:hover, &:hover #icon {
57
+ color: var( --colorinput-btn-color-hover );
58
+ }
59
+
60
+ &:focus {
61
+ //background-color: var( --color-30 );
62
+ //color: var( --color-10 );
63
+ }
64
+ }
65
65
  }