@operato/input 2.0.0-alpha.99 → 2.0.0-beta.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 (235) hide show
  1. package/CHANGELOG.md +246 -0
  2. package/demo/index-barcode.html +4 -4
  3. package/demo/index-checkbox.html +4 -4
  4. package/demo/index-code.html +4 -4
  5. package/demo/index-options.html +2 -2
  6. package/dist/src/ox-buttons-radio.d.ts +9 -5
  7. package/dist/src/ox-buttons-radio.js +43 -11
  8. package/dist/src/ox-buttons-radio.js.map +1 -1
  9. package/dist/src/ox-checkbox.js +23 -19
  10. package/dist/src/ox-checkbox.js.map +1 -1
  11. package/dist/src/ox-input-3axis.js +12 -1
  12. package/dist/src/ox-input-3axis.js.map +1 -1
  13. package/dist/src/ox-input-3dish.js +16 -11
  14. package/dist/src/ox-input-3dish.js.map +1 -1
  15. package/dist/src/ox-input-angle.js +8 -1
  16. package/dist/src/ox-input-angle.js.map +1 -1
  17. package/dist/src/ox-input-barcode.js +11 -8
  18. package/dist/src/ox-input-barcode.js.map +1 -1
  19. package/dist/src/ox-input-code.js +3 -0
  20. package/dist/src/ox-input-code.js.map +1 -1
  21. package/dist/src/ox-input-color.js +8 -6
  22. package/dist/src/ox-input-color.js.map +1 -1
  23. package/dist/src/ox-input-crontab.js +29 -25
  24. package/dist/src/ox-input-crontab.js.map +1 -1
  25. package/dist/src/ox-input-data.js +15 -6
  26. package/dist/src/ox-input-data.js.map +1 -1
  27. package/dist/src/ox-input-duration.js +15 -34
  28. package/dist/src/ox-input-duration.js.map +1 -1
  29. package/dist/src/ox-input-file.js +18 -14
  30. package/dist/src/ox-input-file.js.map +1 -1
  31. package/dist/src/ox-input-hashtags.js +13 -14
  32. package/dist/src/ox-input-hashtags.js.map +1 -1
  33. package/dist/src/ox-input-i18n-label.js +4 -4
  34. package/dist/src/ox-input-i18n-label.js.map +1 -1
  35. package/dist/src/ox-input-image.js +2 -2
  36. package/dist/src/ox-input-image.js.map +1 -1
  37. package/dist/src/ox-input-key-values.js +6 -6
  38. package/dist/src/ox-input-key-values.js.map +1 -1
  39. package/dist/src/ox-input-mass-fraction.js +5 -5
  40. package/dist/src/ox-input-mass-fraction.js.map +1 -1
  41. package/dist/src/ox-input-multiple-colors.js +2 -2
  42. package/dist/src/ox-input-multiple-colors.js.map +1 -1
  43. package/dist/src/ox-input-options.js +6 -6
  44. package/dist/src/ox-input-options.js.map +1 -1
  45. package/dist/src/ox-input-partition-keys.js +6 -6
  46. package/dist/src/ox-input-partition-keys.js.map +1 -1
  47. package/dist/src/ox-input-privilege.js +13 -16
  48. package/dist/src/ox-input-privilege.js.map +1 -1
  49. package/dist/src/ox-input-quantifier.js +5 -5
  50. package/dist/src/ox-input-quantifier.js.map +1 -1
  51. package/dist/src/ox-input-range.js +8 -8
  52. package/dist/src/ox-input-range.js.map +1 -1
  53. package/dist/src/ox-input-search.js +5 -6
  54. package/dist/src/ox-input-search.js.map +1 -1
  55. package/dist/src/ox-input-select-buttons.d.ts +2 -0
  56. package/dist/src/ox-input-select-buttons.js +14 -21
  57. package/dist/src/ox-input-select-buttons.js.map +1 -1
  58. package/dist/src/ox-input-table.js +1 -1
  59. package/dist/src/ox-input-table.js.map +1 -1
  60. package/dist/src/ox-input-unit-number.js +5 -5
  61. package/dist/src/ox-input-unit-number.js.map +1 -1
  62. package/dist/src/ox-input-value-map.js +9 -13
  63. package/dist/src/ox-input-value-map.js.map +1 -1
  64. package/dist/src/ox-input-value-ranges.js +7 -7
  65. package/dist/src/ox-input-value-ranges.js.map +1 -1
  66. package/dist/src/ox-input-work-shift.js +7 -7
  67. package/dist/src/ox-input-work-shift.js.map +1 -1
  68. package/dist/src/ox-select.d.ts +9 -1
  69. package/dist/src/ox-select.js +51 -17
  70. package/dist/src/ox-select.js.map +1 -1
  71. package/dist/src/ox-zoomable-image.d.ts +17 -0
  72. package/dist/src/ox-zoomable-image.js +80 -0
  73. package/dist/src/ox-zoomable-image.js.map +1 -0
  74. package/dist/stories/ox-buttons-radio.stories.d.ts +31 -0
  75. package/dist/stories/ox-buttons-radio.stories.js +81 -0
  76. package/dist/stories/ox-buttons-radio.stories.js.map +1 -0
  77. package/dist/stories/ox-checkbox.stories.d.ts +6 -0
  78. package/dist/stories/ox-checkbox.stories.js +57 -13
  79. package/dist/stories/ox-checkbox.stories.js.map +1 -1
  80. package/dist/stories/ox-input-3axis.stories.d.ts +5 -0
  81. package/dist/stories/ox-input-3axis.stories.js +32 -10
  82. package/dist/stories/ox-input-3axis.stories.js.map +1 -1
  83. package/dist/stories/ox-input-3dish.stories.d.ts +5 -0
  84. package/dist/stories/ox-input-3dish.stories.js +35 -13
  85. package/dist/stories/ox-input-3dish.stories.js.map +1 -1
  86. package/dist/stories/ox-input-angle.stories.d.ts +5 -0
  87. package/dist/stories/ox-input-angle.stories.js +36 -13
  88. package/dist/stories/ox-input-angle.stories.js.map +1 -1
  89. package/dist/stories/ox-input-barcode.stories.d.ts +5 -0
  90. package/dist/stories/ox-input-barcode.stories.js +35 -18
  91. package/dist/stories/ox-input-barcode.stories.js.map +1 -1
  92. package/dist/stories/ox-input-code.stories.d.ts +5 -0
  93. package/dist/stories/ox-input-code.stories.js +38 -13
  94. package/dist/stories/ox-input-code.stories.js.map +1 -1
  95. package/dist/stories/ox-input-crontab.stories.d.ts +5 -0
  96. package/dist/stories/ox-input-crontab.stories.js +35 -12
  97. package/dist/stories/ox-input-crontab.stories.js.map +1 -1
  98. package/dist/stories/ox-input-data.stories.d.ts +5 -0
  99. package/dist/stories/ox-input-data.stories.js +34 -11
  100. package/dist/stories/ox-input-data.stories.js.map +1 -1
  101. package/dist/stories/ox-input-duration.stories.d.ts +5 -0
  102. package/dist/stories/ox-input-duration.stories.js +36 -13
  103. package/dist/stories/ox-input-duration.stories.js.map +1 -1
  104. package/dist/stories/ox-input-file.stories.d.ts +5 -0
  105. package/dist/stories/ox-input-file.stories.js +39 -16
  106. package/dist/stories/ox-input-file.stories.js.map +1 -1
  107. package/dist/stories/ox-input-hashtags.stories.d.ts +5 -0
  108. package/dist/stories/ox-input-hashtags.stories.js +35 -12
  109. package/dist/stories/ox-input-hashtags.stories.js.map +1 -1
  110. package/dist/stories/ox-input-i18n-label.stories.d.ts +5 -0
  111. package/dist/stories/ox-input-i18n-label.stories.js +35 -12
  112. package/dist/stories/ox-input-i18n-label.stories.js.map +1 -1
  113. package/dist/stories/ox-input-key-values.stories.d.ts +5 -0
  114. package/dist/stories/ox-input-key-values.stories.js +35 -12
  115. package/dist/stories/ox-input-key-values.stories.js.map +1 -1
  116. package/dist/stories/ox-input-mass-fraction.stories.d.ts +5 -0
  117. package/dist/stories/ox-input-mass-fraction.stories.js +36 -13
  118. package/dist/stories/ox-input-mass-fraction.stories.js.map +1 -1
  119. package/dist/stories/ox-input-multiple-colors.stories.d.ts +5 -0
  120. package/dist/stories/ox-input-multiple-colors.stories.js +31 -149
  121. package/dist/stories/ox-input-multiple-colors.stories.js.map +1 -1
  122. package/dist/stories/ox-input-options.stories.d.ts +5 -0
  123. package/dist/stories/ox-input-options.stories.js +34 -11
  124. package/dist/stories/ox-input-options.stories.js.map +1 -1
  125. package/dist/stories/ox-input-partition-keys.stories.d.ts +5 -0
  126. package/dist/stories/ox-input-partition-keys.stories.js +34 -11
  127. package/dist/stories/ox-input-partition-keys.stories.js.map +1 -1
  128. package/dist/stories/ox-input-privilege.stories.d.ts +5 -0
  129. package/dist/stories/ox-input-privilege.stories.js +36 -18
  130. package/dist/stories/ox-input-privilege.stories.js.map +1 -1
  131. package/dist/stories/ox-input-quantifier.stories.d.ts +5 -0
  132. package/dist/stories/ox-input-quantifier.stories.js +37 -10
  133. package/dist/stories/ox-input-quantifier.stories.js.map +1 -1
  134. package/dist/stories/ox-input-range.stories.d.ts +5 -0
  135. package/dist/stories/ox-input-range.stories.js +32 -5
  136. package/dist/stories/ox-input-range.stories.js.map +1 -1
  137. package/dist/stories/ox-input-search.stories.d.ts +5 -0
  138. package/dist/stories/ox-input-search.stories.js +35 -12
  139. package/dist/stories/ox-input-search.stories.js.map +1 -1
  140. package/dist/stories/ox-input-select-buttons.stories.d.ts +5 -0
  141. package/dist/stories/ox-input-select-buttons.stories.js +36 -14
  142. package/dist/stories/ox-input-select-buttons.stories.js.map +1 -1
  143. package/dist/stories/ox-input-unit.stories.d.ts +5 -0
  144. package/dist/stories/ox-input-unit.stories.js +40 -13
  145. package/dist/stories/ox-input-unit.stories.js.map +1 -1
  146. package/dist/stories/ox-input-value-map.stories.d.ts +5 -0
  147. package/dist/stories/ox-input-value-map.stories.js +36 -13
  148. package/dist/stories/ox-input-value-map.stories.js.map +1 -1
  149. package/dist/stories/ox-input-value-ranges.stories.d.ts +5 -0
  150. package/dist/stories/ox-input-value-ranges.stories.js +36 -13
  151. package/dist/stories/ox-input-value-ranges.stories.js.map +1 -1
  152. package/dist/stories/ox-input-work-shift.stories.d.ts +5 -0
  153. package/dist/stories/ox-input-work-shift.stories.js +36 -13
  154. package/dist/stories/ox-input-work-shift.stories.js.map +1 -1
  155. package/dist/stories/ox-select-set-options.stories.d.ts +53 -0
  156. package/dist/stories/ox-select-set-options.stories.js +183 -0
  157. package/dist/stories/ox-select-set-options.stories.js.map +1 -0
  158. package/dist/stories/ox-select.stories.d.ts +5 -0
  159. package/dist/stories/ox-select.stories.js +33 -7
  160. package/dist/stories/ox-select.stories.js.map +1 -1
  161. package/dist/tsconfig.tsbuildinfo +1 -1
  162. package/package.json +7 -7
  163. package/src/ox-buttons-radio.ts +37 -5
  164. package/src/ox-checkbox.ts +23 -19
  165. package/src/ox-input-3axis.ts +12 -1
  166. package/src/ox-input-3dish.ts +16 -11
  167. package/src/ox-input-angle.ts +8 -1
  168. package/src/ox-input-barcode.ts +11 -8
  169. package/src/ox-input-code.ts +3 -0
  170. package/src/ox-input-color.ts +8 -6
  171. package/src/ox-input-crontab.ts +29 -25
  172. package/src/ox-input-data.ts +15 -6
  173. package/src/ox-input-duration.ts +15 -34
  174. package/src/ox-input-file.ts +18 -14
  175. package/src/ox-input-hashtags.ts +14 -16
  176. package/src/ox-input-i18n-label.ts +4 -4
  177. package/src/ox-input-image.ts +2 -2
  178. package/src/ox-input-key-values.ts +6 -6
  179. package/src/ox-input-mass-fraction.ts +5 -5
  180. package/src/ox-input-multiple-colors.ts +2 -2
  181. package/src/ox-input-options.ts +6 -6
  182. package/src/ox-input-partition-keys.ts +6 -6
  183. package/src/ox-input-privilege.ts +13 -16
  184. package/src/ox-input-quantifier.ts +5 -5
  185. package/src/ox-input-range.ts +8 -8
  186. package/src/ox-input-search.ts +5 -6
  187. package/src/ox-input-select-buttons.ts +19 -24
  188. package/src/ox-input-table.ts +1 -1
  189. package/src/ox-input-unit-number.ts +5 -5
  190. package/src/ox-input-value-map.ts +9 -13
  191. package/src/ox-input-value-ranges.ts +7 -7
  192. package/src/ox-input-work-shift.ts +7 -7
  193. package/src/ox-select.ts +60 -13
  194. package/src/ox-zoomable-image.ts +75 -0
  195. package/stories/ox-buttons-radio.stories.ts +96 -0
  196. package/stories/ox-checkbox.stories.ts +61 -14
  197. package/stories/ox-input-3axis.stories.ts +35 -12
  198. package/stories/ox-input-3dish.stories.ts +38 -15
  199. package/stories/ox-input-angle.stories.ts +39 -15
  200. package/stories/ox-input-barcode.stories.ts +37 -18
  201. package/stories/ox-input-code.stories.ts +42 -15
  202. package/stories/ox-input-crontab.stories.ts +43 -14
  203. package/stories/ox-input-data.stories.ts +38 -14
  204. package/stories/ox-input-duration.stories.ts +39 -15
  205. package/stories/ox-input-file.stories.ts +41 -16
  206. package/stories/ox-input-hashtags.stories.ts +42 -12
  207. package/stories/ox-input-i18n-label.stories.ts +55 -31
  208. package/stories/ox-input-key-values.stories.ts +44 -14
  209. package/stories/ox-input-mass-fraction.stories.ts +40 -15
  210. package/stories/ox-input-multiple-colors.stories.ts +34 -151
  211. package/stories/ox-input-options.stories.ts +37 -13
  212. package/stories/ox-input-partition-keys.stories.ts +42 -13
  213. package/stories/ox-input-privilege.stories.ts +45 -20
  214. package/stories/ox-input-quantifier.stories.ts +38 -10
  215. package/stories/ox-input-range.stories.ts +34 -5
  216. package/stories/ox-input-search.stories.ts +37 -12
  217. package/stories/ox-input-select-buttons.stories.ts +40 -16
  218. package/stories/ox-input-unit.stories.ts +43 -14
  219. package/stories/ox-input-value-map.stories.ts +40 -15
  220. package/stories/ox-input-value-ranges.stories.ts +40 -15
  221. package/stories/ox-input-work-shift.stories.ts +39 -15
  222. package/stories/ox-select-set-options.stories.ts +215 -0
  223. package/stories/ox-select.stories.ts +37 -7
  224. package/themes/dark-hc.css +151 -0
  225. package/themes/dark-mc.css +151 -0
  226. package/themes/dark.css +151 -0
  227. package/themes/grist-theme.css +169 -0
  228. package/themes/light-hc.css +151 -0
  229. package/themes/light-mc.css +151 -0
  230. package/themes/light.css +151 -0
  231. package/themes/md-typescale-styles.css +100 -0
  232. package/themes/spacing.css +43 -0
  233. package/themes/state-color.css +6 -0
  234. package/themes/app-theme.css +0 -145
  235. package/themes/input-theme.css +0 -32
package/CHANGELOG.md CHANGED
@@ -3,6 +3,252 @@
3
3
  All notable changes to this project will be documented in this file.
4
4
  See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
5
5
 
6
+ ## [2.0.0-beta.0](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.158...v2.0.0-beta.0) (2024-06-01)
7
+
8
+ **Note:** Version bump only for package @operato/input
9
+
10
+
11
+
12
+
13
+
14
+ ## [2.0.0-alpha.157](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.156...v2.0.0-alpha.157) (2024-06-01)
15
+
16
+ **Note:** Version bump only for package @operato/input
17
+
18
+
19
+
20
+
21
+
22
+ ## [2.0.0-alpha.156](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.155...v2.0.0-alpha.156) (2024-06-01)
23
+
24
+
25
+ ### :bug: Bug Fix
26
+
27
+ * theming styles ([3b282c2](https://github.com/hatiolab/operato/commit/3b282c21d93af03bacc5aa40027591e005f1a067))
28
+
29
+
30
+
31
+ ## [2.0.0-alpha.154](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.153...v2.0.0-alpha.154) (2024-06-01)
32
+
33
+ **Note:** Version bump only for package @operato/input
34
+
35
+
36
+
37
+
38
+
39
+ ## [2.0.0-alpha.152](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.151...v2.0.0-alpha.152) (2024-05-30)
40
+
41
+
42
+ ### :bug: Bug Fix
43
+
44
+ * theming style - background-color ([48a0fe4](https://github.com/hatiolab/operato/commit/48a0fe49a533ae1fbd7931a2951b6a68e9c39b01))
45
+
46
+
47
+
48
+ ## [2.0.0-alpha.151](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.150...v2.0.0-alpha.151) (2024-05-30)
49
+
50
+
51
+ ### :bug: Bug Fix
52
+
53
+ * theming styles ([c5f59c2](https://github.com/hatiolab/operato/commit/c5f59c2e55a36eedf9056bcf2187c218556ded3e))
54
+
55
+
56
+
57
+ ## [2.0.0-alpha.150](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.149...v2.0.0-alpha.150) (2024-05-30)
58
+
59
+
60
+ ### :bug: Bug Fix
61
+
62
+ * theming styles ([4f2c9bb](https://github.com/hatiolab/operato/commit/4f2c9bbc1ad4f27d99a18e99c10604b3db480899))
63
+
64
+
65
+
66
+ ## [2.0.0-alpha.149](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.148...v2.0.0-alpha.149) (2024-05-30)
67
+
68
+
69
+ ### :bug: Bug Fix
70
+
71
+ * styles ([9ec269b](https://github.com/hatiolab/operato/commit/9ec269b18bc82a931083137214fb6e3017201107))
72
+
73
+
74
+
75
+ ## [2.0.0-alpha.148](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.147...v2.0.0-alpha.148) (2024-05-30)
76
+
77
+
78
+ ### :rocket: New Features
79
+
80
+ * md3 ([2d85145](https://github.com/hatiolab/operato/commit/2d8514510e4dd88d3ff0652e0b22c9992cabce5c))
81
+ * md3 ([55b7496](https://github.com/hatiolab/operato/commit/55b7496ea46a6b65ac6ab71bc1be7c89d1ba91e5))
82
+
83
+
84
+ ### :sparkles: Styling
85
+
86
+ * input ([b44bf8d](https://github.com/hatiolab/operato/commit/b44bf8d0a100fc59ecf79f0a832a445f90d2f4ee))
87
+ * list, grid, card ([773b57c](https://github.com/hatiolab/operato/commit/773b57c8f85536ddfc2bd883f0209341c0ff2a0b))
88
+ * popup ([f881e3b](https://github.com/hatiolab/operato/commit/f881e3b1b70acd957a4ba5565bc0b90f0ef18d00))
89
+ * themes update, ox-buttons-radio, ox-checkbo ([0da66c4](https://github.com/hatiolab/operato/commit/0da66c47f053ee6675a247d6968ceaf818f06ad3))
90
+
91
+
92
+ ### :bug: Bug Fix
93
+
94
+ * color theme ([8498761](https://github.com/hatiolab/operato/commit/8498761842ba6c53b98f14ec1ba061d090a997c8))
95
+ * dark theme for event-view ([0480a3d](https://github.com/hatiolab/operato/commit/0480a3d970a488e9f0cd93a1af66b4516c44b4bb))
96
+ * input button style on dark theme ([b8d1a3f](https://github.com/hatiolab/operato/commit/b8d1a3f68c490fd9d1f38b3bbaba40292dd6b88c))
97
+ * missing code from ox-select stories ([bd229bb](https://github.com/hatiolab/operato/commit/bd229bb4fdb1d0b6db61977fb2452bdfe8c98950))
98
+ * ox-buttons-radio ([339e0bc](https://github.com/hatiolab/operato/commit/339e0bcfee9288e1144189ed2f0ac27935c7a6d8))
99
+ * ox-input-select-buttons story ([8efa3c6](https://github.com/hatiolab/operato/commit/8efa3c6e7428eef23cfe10757c155b62a9d59ab4))
100
+ * revoke ox-input-barcode ([db50995](https://github.com/hatiolab/operato/commit/db50995c0685f0ca81e5d26025ebe502f83ec077))
101
+
102
+
103
+
104
+ ## [2.0.0-alpha.146](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.145...v2.0.0-alpha.146) (2024-05-29)
105
+
106
+
107
+ ### :rocket: New Features
108
+
109
+ * ox-select.setOptions(..) method ([e026449](https://github.com/hatiolab/operato/commit/e0264494780fed696b95f16431f774c7a49e4cde))
110
+
111
+
112
+
113
+ ## [2.0.0-alpha.145](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.144...v2.0.0-alpha.145) (2024-05-28)
114
+
115
+ **Note:** Version bump only for package @operato/input
116
+
117
+
118
+
119
+
120
+
121
+ ## [2.0.0-alpha.142](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.141...v2.0.0-alpha.142) (2024-05-21)
122
+
123
+ **Note:** Version bump only for package @operato/input
124
+
125
+
126
+
127
+
128
+
129
+ ## [2.0.0-alpha.134](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.133...v2.0.0-alpha.134) (2024-05-13)
130
+
131
+ **Note:** Version bump only for package @operato/input
132
+
133
+
134
+
135
+
136
+
137
+ ## [2.0.0-alpha.133](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.132...v2.0.0-alpha.133) (2024-05-12)
138
+
139
+
140
+ ### :rocket: New Features
141
+
142
+ * add personalization for ox-filter-form-base ([c60874c](https://github.com/hatiolab/operato/commit/c60874c9f3f6ca2ef68f81d62cd3781fd62074fe))
143
+
144
+
145
+
146
+ ## [2.0.0-alpha.129](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.128...v2.0.0-alpha.129) (2024-05-08)
147
+
148
+ **Note:** Version bump only for package @operato/input
149
+
150
+
151
+
152
+
153
+
154
+ ## [2.0.0-alpha.124](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.123...v2.0.0-alpha.124) (2024-05-08)
155
+
156
+ **Note:** Version bump only for package @operato/input
157
+
158
+
159
+
160
+
161
+
162
+ ## [2.0.0-alpha.123](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.122...v2.0.0-alpha.123) (2024-05-07)
163
+
164
+
165
+ ### :rocket: New Features
166
+
167
+ * ox-zoomable-image ([dbeb528](https://github.com/hatiolab/operato/commit/dbeb528ca4d2afcef0ac6b365bb3c02b286211f9))
168
+
169
+
170
+
171
+ ## [2.0.0-alpha.122](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.121...v2.0.0-alpha.122) (2024-05-06)
172
+
173
+
174
+ ### :bug: Bug Fix
175
+
176
+ * ox-input-select-button ([1e1be72](https://github.com/hatiolab/operato/commit/1e1be72dcb5d5d23e2d0df0701b0da04855e73d2))
177
+
178
+
179
+
180
+ ## [2.0.0-alpha.120](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.119...v2.0.0-alpha.120) (2024-05-05)
181
+
182
+ **Note:** Version bump only for package @operato/input
183
+
184
+
185
+
186
+
187
+
188
+ ## [2.0.0-alpha.118](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.117...v2.0.0-alpha.118) (2024-05-04)
189
+
190
+ **Note:** Version bump only for package @operato/input
191
+
192
+
193
+
194
+
195
+
196
+ ## [2.0.0-alpha.116](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.115...v2.0.0-alpha.116) (2024-05-04)
197
+
198
+ **Note:** Version bump only for package @operato/input
199
+
200
+
201
+
202
+
203
+
204
+ ## [2.0.0-alpha.114](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.113...v2.0.0-alpha.114) (2024-05-04)
205
+
206
+ **Note:** Version bump only for package @operato/input
207
+
208
+
209
+
210
+
211
+
212
+ ## [2.0.0-alpha.111](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.110...v2.0.0-alpha.111) (2024-05-02)
213
+
214
+ **Note:** Version bump only for package @operato/input
215
+
216
+
217
+
218
+
219
+
220
+ ## [2.0.0-alpha.110](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.109...v2.0.0-alpha.110) (2024-05-02)
221
+
222
+ **Note:** Version bump only for package @operato/input
223
+
224
+
225
+
226
+
227
+
228
+ ## [2.0.0-alpha.107](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.106...v2.0.0-alpha.107) (2024-05-01)
229
+
230
+ **Note:** Version bump only for package @operato/input
231
+
232
+
233
+
234
+
235
+
236
+ ## [2.0.0-alpha.102](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.101...v2.0.0-alpha.102) (2024-04-22)
237
+
238
+ **Note:** Version bump only for package @operato/input
239
+
240
+
241
+
242
+
243
+
244
+ ## [2.0.0-alpha.100](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.99...v2.0.0-alpha.100) (2024-04-21)
245
+
246
+ **Note:** Version bump only for package @operato/input
247
+
248
+
249
+
250
+
251
+
6
252
  ## [2.0.0-alpha.99](https://github.com/hatiolab/operato/compare/v2.0.0-alpha.98...v2.0.0-alpha.99) (2024-04-21)
7
253
 
8
254
  **Note:** Version bump only for package @operato/input
@@ -1,4 +1,4 @@
1
- <!DOCTYPE html>
1
+ <!doctype html>
2
2
  <html lang="en-GB">
3
3
  <head>
4
4
  <meta charset="utf-8" />
@@ -13,13 +13,13 @@
13
13
  --ox-checkbox-border: 1px solid rgba(0, 0, 0, 0.3);
14
14
  --ox-checkbox-border-radius: var(--border-radius, 4px);
15
15
  --ox-checkbox-size: 15px;
16
- --ox-checkbox-background-color: var(--theme-white-color, #fff);
17
- --ox-checkbox-label-color: var(--primary-text-color, #3a5877);
16
+ --ox-checkbox-background-color: var(--md-sys-color-surface, #fff);
17
+ --ox-checkbox-label-color: var(--md-sys-color-on-primary-container, #3a5877);
18
18
  --ox-checkbox-label-margin: 0 0 0 7px;
19
19
 
20
20
  /* checkbox checked */
21
21
  --ox-checkbox-checked-background-color: var(--ox-checkbox-background-color);
22
- --ox-checkbox-checked-color: var(--primary-color, #38a25b);
22
+ --ox-checkbox-checked-color: var(--md-sys-color-on-primary-container, #38a25b);
23
23
  --ox-checkbox-checked-border: 1px solid var(--ox-checkbox-checked-color);
24
24
  --ox-checkbox-checked-font-weight: bold;
25
25
 
@@ -1,4 +1,4 @@
1
- <!DOCTYPE html>
1
+ <!doctype html>
2
2
  <html lang="en-GB">
3
3
  <head>
4
4
  <meta charset="utf-8" />
@@ -13,13 +13,13 @@
13
13
  --ox-checkbox-border: 1px solid rgba(0, 0, 0, 0.3);
14
14
  --ox-checkbox-border-radius: var(--border-radius, 4px);
15
15
  --ox-checkbox-size: 15px;
16
- --ox-checkbox-background-color: var(--theme-white-color, #fff);
17
- --ox-checkbox-label-color: var(--primary-text-color, #3a5877);
16
+ --ox-checkbox-background-color: var(--md-sys-color-surface, #fff);
17
+ --ox-checkbox-label-color: var(--md-sys-color-on-primary-container, #3a5877);
18
18
  --ox-checkbox-label-margin: 0 0 0 7px;
19
19
 
20
20
  /* checkbox checked */
21
21
  --ox-checkbox-checked-background-color: var(--ox-checkbox-background-color);
22
- --ox-checkbox-checked-color: var(--primary-color, #38a25b);
22
+ --ox-checkbox-checked-color: var(--md-sys-color-on-primary-container, #38a25b);
23
23
  --ox-checkbox-checked-border: 1px solid var(--ox-checkbox-checked-color);
24
24
  --ox-checkbox-checked-font-weight: bold;
25
25
 
@@ -1,4 +1,4 @@
1
- <!DOCTYPE html>
1
+ <!doctype html>
2
2
  <html lang="en-GB">
3
3
  <head>
4
4
  <meta charset="utf-8" />
@@ -13,13 +13,13 @@
13
13
  --ox-checkbox-border: 1px solid rgba(0, 0, 0, 0.3);
14
14
  --ox-checkbox-border-radius: var(--border-radius, 4px);
15
15
  --ox-checkbox-size: 15px;
16
- --ox-checkbox-background-color: var(--theme-white-color, #fff);
17
- --ox-checkbox-label-color: var(--primary-text-color, #3a5877);
16
+ --ox-checkbox-background-color: var(--md-sys-color-surface, #fff);
17
+ --ox-checkbox-label-color: var(--md-sys-color-on-primary-container, #3a5877);
18
18
  --ox-checkbox-label-margin: 0 0 0 7px;
19
19
 
20
20
  /* checkbox checked */
21
21
  --ox-checkbox-checked-background-color: var(--ox-checkbox-background-color);
22
- --ox-checkbox-checked-color: var(--primary-color, #38a25b);
22
+ --ox-checkbox-checked-color: var(--md-sys-color-on-primary-container, #38a25b);
23
23
  --ox-checkbox-checked-border: 1px solid var(--ox-checkbox-checked-color);
24
24
  --ox-checkbox-checked-font-weight: bold;
25
25
 
@@ -1,4 +1,4 @@
1
- <!DOCTYPE html>
1
+ <!doctype html>
2
2
  <html lang="en-GB">
3
3
  <head>
4
4
  <meta charset="utf-8" />
@@ -34,7 +34,7 @@
34
34
  console.log('form value', new FormData(form).get('options'))
35
35
  }}
36
36
  ></ox-input-options>
37
- <input type="button" value="Sort" @click=${e => sort()}></input>
37
+ <input type="button" value="Sort" @click=${e => sort()} />
38
38
  `,
39
39
  form
40
40
  )
@@ -8,13 +8,17 @@ import { OxFormField } from './ox-form-field';
8
8
 
9
9
  Example:
10
10
 
11
- <ox-buttons-radio @change=${e => this._onChange(e)} value=${value}>
12
- <div value="top"></div>
13
- <div value="middle"></div>
14
- <div value="bottom"></div>
11
+ <ox-buttons-radio
12
+ class="light"
13
+ @change=${(e: CustomEvent) => console.log(e.detail)}
14
+ value="1"
15
+ >
16
+ <md-outlined-button data-value="1" ?active=${value == '1'}>Option 1</md-outlined-button>
17
+ <md-outlined-button data-value="2" ?active=${value == '2'}>Option 2</md-outlined-button>
18
+ <md-outlined-button data-value="3" ?active=${value == '3'}>Option 3</md-outlined-button>
15
19
  </ox-buttons-radio>
16
20
  */
17
- export declare class PropertyButtonsRadio extends OxFormField {
21
+ export declare class OxButtonsRadio extends OxFormField {
18
22
  static styles: import("lit").CSSResult[];
19
23
  /**
20
24
  * `value`는 버튼의 눌린 상태를 값으로 갖는 속성이다.
@@ -10,13 +10,17 @@ import { OxFormField } from './ox-form-field';
10
10
 
11
11
  Example:
12
12
 
13
- <ox-buttons-radio @change=${e => this._onChange(e)} value=${value}>
14
- <div value="top"></div>
15
- <div value="middle"></div>
16
- <div value="bottom"></div>
13
+ <ox-buttons-radio
14
+ class="light"
15
+ @change=${(e: CustomEvent) => console.log(e.detail)}
16
+ value="1"
17
+ >
18
+ <md-outlined-button data-value="1" ?active=${value == '1'}>Option 1</md-outlined-button>
19
+ <md-outlined-button data-value="2" ?active=${value == '2'}>Option 2</md-outlined-button>
20
+ <md-outlined-button data-value="3" ?active=${value == '3'}>Option 3</md-outlined-button>
17
21
  </ox-buttons-radio>
18
22
  */
19
- let PropertyButtonsRadio = class PropertyButtonsRadio extends OxFormField {
23
+ let OxButtonsRadio = class OxButtonsRadio extends OxFormField {
20
24
  constructor() {
21
25
  super(...arguments);
22
26
  /**
@@ -31,6 +35,34 @@ let PropertyButtonsRadio = class PropertyButtonsRadio extends OxFormField {
31
35
  css `
32
36
  :host {
33
37
  display: inline-block;
38
+ background-color: var(--ox-buttons-radio-background-color, var(--md-sys-color-surface));
39
+
40
+ --md-outlined-button-label-text-color: var(--md-sys-color-on-surface-variant);
41
+ --md-outlined-button-label-text-size: var(--md-sys-typescale-label-large-size, 0.875rem);
42
+ --md-outlined-button-container-height: var(--form-element-height-medium);
43
+ --md-outlined-button-container-shape: var(--md-sys-shape-corner-small);
44
+ --md-outlined-button-leading-space: var(--spacing-large);
45
+ --md-outlined-button-trailing-space: var(--spacing-large);
46
+ --md-outlined-button-hover-label-text-color: var(--md-sys-color-primary);
47
+ --md-outlined-button-pressed-outline-color: var(--md-sys-color-primary);
48
+ --md-outlined-button-pressed-label-text-color: var(--md-sys-color-primary);
49
+
50
+ --md-filled-button-container-color: var(--md-sys-color-primary);
51
+ --md-filled-button-label-text-color: var(--md-sys-color-primary-container);
52
+ --md-filled-button-label-text-size: var(--md-sys-typescale-label-large-size, 0.875rem);
53
+ --md-filled-button-container-height: var(--form-element-height-medium);
54
+ --md-filled-button-container-shape: var(--md-sys-shape-corner-small);
55
+ --md-filled-button-leading-space: var(--spacing-large);
56
+ --md-filled-button-trailing-space: var(--spacing-large);
57
+ --md-filled-button-hover-label-text-color: var(--md-sys-color-secondary-container);
58
+ --md-filled-button-pressed-label-text-color: var(--md-sys-color-secondary-container);
59
+ --md-filled-button-focus-label-text-color: var(--md-sys-color-secondary-container);
60
+
61
+ --md-text-button-container-height: var(--form-element-height-medium);
62
+ --md-text-button-container-shape: var(--md-sys-shape-corner-small);
63
+
64
+ --md-elevated-button-container-height: var(--form-element-height-medium);
65
+ --md-elevated-button-container-shape: var(--md-sys-shape-corner-small);
34
66
  }
35
67
  `
36
68
  ]; }
@@ -93,15 +125,15 @@ let PropertyButtonsRadio = class PropertyButtonsRadio extends OxFormField {
93
125
  };
94
126
  __decorate([
95
127
  property({ type: Object })
96
- ], PropertyButtonsRadio.prototype, "value", void 0);
128
+ ], OxButtonsRadio.prototype, "value", void 0);
97
129
  __decorate([
98
130
  property({ type: Boolean })
99
- ], PropertyButtonsRadio.prototype, "mandatory", void 0);
131
+ ], OxButtonsRadio.prototype, "mandatory", void 0);
100
132
  __decorate([
101
133
  state()
102
- ], PropertyButtonsRadio.prototype, "_slotObserver", void 0);
103
- PropertyButtonsRadio = __decorate([
134
+ ], OxButtonsRadio.prototype, "_slotObserver", void 0);
135
+ OxButtonsRadio = __decorate([
104
136
  customElement('ox-buttons-radio')
105
- ], PropertyButtonsRadio);
106
- export { PropertyButtonsRadio };
137
+ ], OxButtonsRadio);
138
+ export { OxButtonsRadio };
107
139
  //# sourceMappingURL=ox-buttons-radio.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"ox-buttons-radio.js","sourceRoot":"","sources":["../../src/ox-buttons-radio.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license Copyright © HatioLab Inc. All rights reserved.\n */\n\nimport { css, html, PropertyValues } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\n\nimport { OxFormField } from './ox-form-field'\n\n/**\n여러 버튼 중에서 하나만 눌리거나, 모두 눌리지 않은 상태만을 갖는 라디오 형태의 버튼이다.\n\nExample:\n\n <ox-buttons-radio @change=${e => this._onChange(e)} value=${value}>\n <div value=\"top\"></div>\n <div value=\"middle\"></div>\n <div value=\"bottom\"></div>\n </ox-buttons-radio>\n*/\n@customElement('ox-buttons-radio')\nexport class PropertyButtonsRadio extends OxFormField {\n static styles = [\n css`\n :host {\n display: inline-block;\n }\n `\n ]\n\n /**\n * `value`는 버튼의 눌린 상태를 값으로 갖는 속성이다.\n */\n @property({ type: Object }) value: Object | null = null\n @property({ type: Boolean }) mandatory!: boolean\n\n @state() _slotObserver: MutationObserver = new MutationObserver(mutations => {\n this._onChanged()\n })\n\n render() {\n return html` <slot @click=${(e: Event) => this._onTapButton(e)}></slot> `\n }\n\n connectedCallback() {\n super.connectedCallback()\n\n this._slotObserver?.observe(this, { childList: true })\n }\n\n disconnectedCallback() {\n super.disconnectedCallback()\n\n this._slotObserver?.disconnect()\n }\n\n updated(changes: PropertyValues<this>) {\n changes.has('value') && this._onChanged()\n }\n\n get buttons() {\n return Array.from(this.querySelectorAll('*'))\n }\n\n _onChanged() {\n this.buttons.forEach(button => {\n if (this.value === button.getAttribute('data-value')) {\n button.setAttribute('active', '')\n } else {\n button.removeAttribute('active')\n }\n })\n }\n\n _onTapButton(e: Event) {\n var target = e.target as HTMLElement\n target = target.closest('[data-value]') as HTMLElement\n\n if (!target || target === this) {\n return\n }\n\n var old = this.value\n\n if (!this.mandatory) {\n if (!target.getAttribute('active')) {\n this.value = target.getAttribute('data-value')\n target.setAttribute('active', '')\n } else {\n this.value = null\n target.removeAttribute('active')\n }\n } else {\n this.value = target.getAttribute('data-value')\n target.setAttribute('active', '')\n }\n\n if (old !== this.value) {\n this.dispatchEvent(\n new CustomEvent('change', {\n bubbles: true,\n composed: true,\n detail: this.value\n })\n )\n }\n }\n}\n"]}
1
+ {"version":3,"file":"ox-buttons-radio.js","sourceRoot":"","sources":["../../src/ox-buttons-radio.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license Copyright © HatioLab Inc. All rights reserved.\n */\n\nimport { css, html, PropertyValues } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\n\nimport { OxFormField } from './ox-form-field'\n\n/**\n여러 버튼 중에서 하나만 눌리거나, 모두 눌리지 않은 상태만을 갖는 라디오 형태의 버튼이다.\n\nExample:\n\n <ox-buttons-radio\n class=\"light\"\n @change=${(e: CustomEvent) => console.log(e.detail)}\n value=\"1\"\n >\n <md-outlined-button data-value=\"1\" ?active=${value == '1'}>Option 1</md-outlined-button>\n <md-outlined-button data-value=\"2\" ?active=${value == '2'}>Option 2</md-outlined-button>\n <md-outlined-button data-value=\"3\" ?active=${value == '3'}>Option 3</md-outlined-button>\n </ox-buttons-radio>\n*/\n@customElement('ox-buttons-radio')\nexport class OxButtonsRadio extends OxFormField {\n static styles = [\n css`\n :host {\n display: inline-block;\n background-color: var(--ox-buttons-radio-background-color, var(--md-sys-color-surface));\n\n --md-outlined-button-label-text-color: var(--md-sys-color-on-surface-variant);\n --md-outlined-button-label-text-size: var(--md-sys-typescale-label-large-size, 0.875rem);\n --md-outlined-button-container-height: var(--form-element-height-medium);\n --md-outlined-button-container-shape: var(--md-sys-shape-corner-small);\n --md-outlined-button-leading-space: var(--spacing-large);\n --md-outlined-button-trailing-space: var(--spacing-large);\n --md-outlined-button-hover-label-text-color: var(--md-sys-color-primary);\n --md-outlined-button-pressed-outline-color: var(--md-sys-color-primary);\n --md-outlined-button-pressed-label-text-color: var(--md-sys-color-primary);\n\n --md-filled-button-container-color: var(--md-sys-color-primary);\n --md-filled-button-label-text-color: var(--md-sys-color-primary-container);\n --md-filled-button-label-text-size: var(--md-sys-typescale-label-large-size, 0.875rem);\n --md-filled-button-container-height: var(--form-element-height-medium);\n --md-filled-button-container-shape: var(--md-sys-shape-corner-small);\n --md-filled-button-leading-space: var(--spacing-large);\n --md-filled-button-trailing-space: var(--spacing-large);\n --md-filled-button-hover-label-text-color: var(--md-sys-color-secondary-container);\n --md-filled-button-pressed-label-text-color: var(--md-sys-color-secondary-container);\n --md-filled-button-focus-label-text-color: var(--md-sys-color-secondary-container);\n\n --md-text-button-container-height: var(--form-element-height-medium);\n --md-text-button-container-shape: var(--md-sys-shape-corner-small);\n\n --md-elevated-button-container-height: var(--form-element-height-medium);\n --md-elevated-button-container-shape: var(--md-sys-shape-corner-small);\n }\n `\n ]\n\n /**\n * `value`는 버튼의 눌린 상태를 값으로 갖는 속성이다.\n */\n @property({ type: Object }) value: Object | null = null\n @property({ type: Boolean }) mandatory!: boolean\n\n @state() _slotObserver: MutationObserver = new MutationObserver(mutations => {\n this._onChanged()\n })\n\n render() {\n return html` <slot @click=${(e: Event) => this._onTapButton(e)}></slot> `\n }\n\n connectedCallback() {\n super.connectedCallback()\n\n this._slotObserver?.observe(this, { childList: true })\n }\n\n disconnectedCallback() {\n super.disconnectedCallback()\n\n this._slotObserver?.disconnect()\n }\n\n updated(changes: PropertyValues<this>) {\n changes.has('value') && this._onChanged()\n }\n\n get buttons() {\n return Array.from(this.querySelectorAll('*'))\n }\n\n _onChanged() {\n this.buttons.forEach(button => {\n if (this.value === button.getAttribute('data-value')) {\n button.setAttribute('active', '')\n } else {\n button.removeAttribute('active')\n }\n })\n }\n\n _onTapButton(e: Event) {\n var target = e.target as HTMLElement\n target = target.closest('[data-value]') as HTMLElement\n\n if (!target || target === this) {\n return\n }\n\n var old = this.value\n\n if (!this.mandatory) {\n if (!target.getAttribute('active')) {\n this.value = target.getAttribute('data-value')\n target.setAttribute('active', '')\n } else {\n this.value = null\n target.removeAttribute('active')\n }\n } else {\n this.value = target.getAttribute('data-value')\n target.setAttribute('active', '')\n }\n\n if (old !== this.value) {\n this.dispatchEvent(\n new CustomEvent('change', {\n bubbles: true,\n composed: true,\n detail: this.value\n })\n )\n }\n }\n}\n"]}
@@ -32,33 +32,36 @@ let OxCheckbox = class OxCheckbox extends OxFormField {
32
32
  cursor: auto;
33
33
  }
34
34
 
35
- [checkbox] {
35
+ .checkbox {
36
36
  display: flex;
37
37
  border-radius: var(--ox-checkbox-border-radius, 4px);
38
- border: var(--ox-checkbox-border, 1px solid rgba(0, 0, 0, 0.3));
39
- background-color: var(--ox-checkbox-background-color, #fff);
38
+ background-color: var(--ox-checkbox-unchecked-background-color, var(--md-sys-color-surface-container-lowest));
39
+ border: var(--ox-checkbox-unchecked-border, 1px solid var(--md-sys-color-outline));
40
40
  width: var(--ox-checkbox-size, 15px);
41
41
  height: var(--ox-checkbox-size, 15px);
42
42
  align-items: center;
43
43
  justify-content: center;
44
44
  }
45
45
 
46
- a {
47
- background-color: var(--ox-checkbox-unchecked-background-color, #fff);
48
- border: var(--ox-checkbox-unchecked-border, 1px solid rgba(0, 0, 0, 0.3));
46
+ :host([indeterminate]) .checkbox {
47
+ background-color: var(--ox-checkbox-unchecked-background-color, var(--md-ref-palette-primary80));
49
48
  }
50
49
 
51
- :host([checked]) a {
52
- background-color: var(--ox-checkbox-checked-background-color, #fff);
53
- border: var(--ox-checkbox-checked-border, 1px solid #38a25b);
50
+ :host([checked]) .checkbox {
51
+ background-color: var(--ox-checkbox-checked-background-color, var(--md-ref-palette-primary60));
54
52
  }
55
53
 
56
54
  path {
57
- fill: var(--ox-checkbox-fill-color, rgba(0, 0, 0, 0.1));
55
+ fill: var(--ox-checkbox-unchecked-color, var(--md-sys-color-surface-container-lowest));
56
+ }
57
+
58
+ :host([indeterminate]) line {
59
+ fill: var(--ox-checkbox-intermidiate-color, var(--md-sys-color-on-surface-variant));
60
+ stroke: var(--ox-checkbox-intermidiate-color, var(--md-sys-color-outline));
58
61
  }
59
62
 
60
63
  :host([checked]) path {
61
- fill: var(--ox-checkbox-checked-color, #38a25b);
64
+ fill: var(--ox-checkbox-checked-color, var(--md-sys-color-on-primary));
62
65
  }
63
66
 
64
67
  svg {
@@ -66,12 +69,13 @@ let OxCheckbox = class OxCheckbox extends OxFormField {
66
69
  height: var(--ox-checkbox-size, 15px);
67
70
  }
68
71
 
69
- [label] {
70
- color: var(--ox-checkbox-label-color, #3a5877);
72
+ .label {
73
+ color: var(--ox-checkbox-label-color, var(--md-sys-color-on-surface-variant));
74
+ font-size: var(--md-sys-typescale-label-large-size, 0.875rem);
75
+ line-height: var(--md-sys-typescale-label-medium-line-height, 1rem);
71
76
  }
72
-
73
- :host([checked]) [label] {
74
- font-weight: var(--ox-checkbox-checked-font-weight, bold);
77
+ :host([checked]) .label {
78
+ font-weight: 700;
75
79
  }
76
80
  `
77
81
  ]; }
@@ -83,11 +87,11 @@ let OxCheckbox = class OxCheckbox extends OxFormField {
83
87
  <slot></slot>
84
88
  </span>`
85
89
  : ''}
86
- <a href="#" @click=${(e) => e.preventDefault()} checkbox>
90
+ <a href="#" @click=${(e) => e.preventDefault()} class="checkbox">
87
91
  ${this.indeterminate ? this.indeterminateIcon : this.checked ? this.checkedIcon : this.uncheckedIcon}
88
92
  </a>
89
93
  ${this._hasInner && !this.left
90
- ? html ` <span label>
94
+ ? html ` <span class="label">
91
95
  <slot></slot>
92
96
  </span>`
93
97
  : ''}
@@ -144,7 +148,7 @@ let OxCheckbox = class OxCheckbox extends OxFormField {
144
148
  get indeterminateIcon() {
145
149
  return html `
146
150
  <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24">
147
- <line x1="4" x2="20" y1="12" y2="12" stroke="rgba(0, 0, 0, 0.7)" stroke-width="2" stroke-linecap="round" />
151
+ <line x1="4" x2="20" y1="12" y2="12" stroke-width="2" stroke-linecap="round" />
148
152
  </svg>
149
153
  `;
150
154
  }
@@ -1 +1 @@
1
- {"version":3,"file":"ox-checkbox.js","sourceRoot":"","sources":["../../src/ox-checkbox.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license Copyright © HatioLab Inc. All rights reserved.\n */\n\n/*\n This component is inspired by https://github.com/Polydile/dile-components, thanks Dile.\n*/\n\nimport { css, html } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\n\nimport { OxFormField } from './ox-form-field'\n\n@customElement('ox-checkbox')\nexport class OxCheckbox extends OxFormField {\n static styles = [\n css`\n div {\n display: flex;\n gap: var(--input-intra-gap, 7px);\n\n align-items: center;\n cursor: pointer;\n }\n\n [disabled] {\n opacity: var(--ox-checkbox-disabled-opacity, 0.5);\n cursor: auto;\n }\n\n [checkbox] {\n display: flex;\n border-radius: var(--ox-checkbox-border-radius, 4px);\n border: var(--ox-checkbox-border, 1px solid rgba(0, 0, 0, 0.3));\n background-color: var(--ox-checkbox-background-color, #fff);\n width: var(--ox-checkbox-size, 15px);\n height: var(--ox-checkbox-size, 15px);\n align-items: center;\n justify-content: center;\n }\n\n a {\n background-color: var(--ox-checkbox-unchecked-background-color, #fff);\n border: var(--ox-checkbox-unchecked-border, 1px solid rgba(0, 0, 0, 0.3));\n }\n\n :host([checked]) a {\n background-color: var(--ox-checkbox-checked-background-color, #fff);\n border: var(--ox-checkbox-checked-border, 1px solid #38a25b);\n }\n\n path {\n fill: var(--ox-checkbox-fill-color, rgba(0, 0, 0, 0.1));\n }\n\n :host([checked]) path {\n fill: var(--ox-checkbox-checked-color, #38a25b);\n }\n\n svg {\n width: var(--ox-checkbox-size, 15px);\n height: var(--ox-checkbox-size, 15px);\n }\n\n [label] {\n color: var(--ox-checkbox-label-color, #3a5877);\n }\n\n :host([checked]) [label] {\n font-weight: var(--ox-checkbox-checked-font-weight, bold);\n }\n `\n ]\n\n @property({ type: Boolean, attribute: 'checked', reflect: true }) checked: boolean | undefined = false\n @property({ type: Boolean, attribute: 'indeterminatable' }) indeterminatable: boolean = false\n @property({ type: Boolean, attribute: 'indeterminate', reflect: true }) indeterminate: boolean = false\n @property({ type: Boolean, attribute: 'left-label' }) left: boolean = false\n\n @state() _hasInner: boolean = !!this.innerHTML.trim().length\n\n render() {\n return html`\n <div @click=${this.onClick} ?disabled=${this.disabled}>\n ${this._hasInner && this.left\n ? html` <span label>\n <slot></slot>\n </span>`\n : ''}\n <a href=\"#\" @click=${(e: Event) => e.preventDefault()} checkbox>\n ${this.indeterminate ? this.indeterminateIcon : this.checked ? this.checkedIcon : this.uncheckedIcon}\n </a>\n ${this._hasInner && !this.left\n ? html` <span label>\n <slot></slot>\n </span>`\n : ''}\n </div>\n `\n }\n\n connectedCallback() {\n super.connectedCallback()\n\n this.setAttribute('tabindex', '0')\n this.addEventListener('keydown', this.onKeyDown.bind(this))\n }\n\n onClick() {\n if (this.disabled) {\n return\n }\n\n if (!this.indeterminatable) {\n this.indeterminate = false\n this.checked = !this.checked\n } else {\n if (this.indeterminate) {\n this.indeterminate = false\n this.checked = true\n } else if (this.checked) {\n this.indeterminate = false\n this.checked = false\n } else {\n this.indeterminate = true\n this.checked = undefined\n }\n }\n\n this.dispatchEvent(\n new CustomEvent('change', {\n bubbles: true,\n composed: true,\n detail: this.checked\n })\n )\n }\n\n get checkedIcon() {\n return html`\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\">\n <path d=\"M9 16.2L4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4L9 16.2z\" />\n </svg>\n `\n }\n\n get uncheckedIcon() {\n return html`\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\">\n <path d=\"M9 16.2L4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4L9 16.2z\" />\n </svg>\n `\n }\n\n get indeterminateIcon() {\n return html`\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\">\n <line x1=\"4\" x2=\"20\" y1=\"12\" y2=\"12\" stroke=\"rgba(0, 0, 0, 0.7)\" stroke-width=\"2\" stroke-linecap=\"round\" />\n </svg>\n `\n }\n\n onKeyDown(e: KeyboardEvent) {\n e.preventDefault()\n\n if (e.key === ' ' || e.key == 'Spacebar') {\n this.onClick()\n }\n }\n\n protected appendFormData({ formData }: FormDataEvent): void {\n this.name && !this.indeterminate && formData.append(this.name, this.checked ? 'true' : 'false')\n }\n}\n"]}
1
+ {"version":3,"file":"ox-checkbox.js","sourceRoot":"","sources":["../../src/ox-checkbox.ts"],"names":[],"mappings":"AAAA;;GAEG;;AAEH;;EAEE;AAEF,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAA;AAC/B,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAA;AAElE,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAA;AAGtC,IAAM,UAAU,GAAhB,MAAM,UAAW,SAAQ,WAAW;IAApC;;QAgE6D,YAAO,GAAwB,KAAK,CAAA;QAC1C,qBAAgB,GAAY,KAAK,CAAA;QACrB,kBAAa,GAAY,KAAK,CAAA;QAChD,SAAI,GAAY,KAAK,CAAA;QAElE,cAAS,GAAY,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC,MAAM,CAAA;IA8F9D,CAAC;aAlKQ,WAAM,GAAG;QACd,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KA2DF;KACF,AA7DY,CA6DZ;IASD,MAAM;QACJ,OAAO,IAAI,CAAA;oBACK,IAAI,CAAC,OAAO,cAAc,IAAI,CAAC,QAAQ;UACjD,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,IAAI;YAC3B,CAAC,CAAC,IAAI,CAAA;;oBAEI;YACV,CAAC,CAAC,EAAE;6BACe,CAAC,CAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,cAAc,EAAE;YACjD,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa;;UAEpG,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,IAAI;YAC5B,CAAC,CAAC,IAAI,CAAA;;oBAEI;YACV,CAAC,CAAC,EAAE;;KAET,CAAA;IACH,CAAC;IAED,iBAAiB;QACf,KAAK,CAAC,iBAAiB,EAAE,CAAA;QAEzB,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,GAAG,CAAC,CAAA;QAClC,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAA;IAC7D,CAAC;IAED,OAAO;QACL,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClB,OAAM;QACR,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC3B,IAAI,CAAC,aAAa,GAAG,KAAK,CAAA;YAC1B,IAAI,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,OAAO,CAAA;QAC9B,CAAC;aAAM,CAAC;YACN,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;gBACvB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAA;gBAC1B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAA;YACrB,CAAC;iBAAM,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;gBACxB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAA;gBAC1B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAA;YACtB,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,aAAa,GAAG,IAAI,CAAA;gBACzB,IAAI,CAAC,OAAO,GAAG,SAAS,CAAA;YAC1B,CAAC;QACH,CAAC;QAED,IAAI,CAAC,aAAa,CAChB,IAAI,WAAW,CAAC,QAAQ,EAAE;YACxB,OAAO,EAAE,IAAI;YACb,QAAQ,EAAE,IAAI;YACd,MAAM,EAAE,IAAI,CAAC,OAAO;SACrB,CAAC,CACH,CAAA;IACH,CAAC;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAA;;;;KAIV,CAAA;IACH,CAAC;IAED,IAAI,aAAa;QACf,OAAO,IAAI,CAAA;;;;KAIV,CAAA;IACH,CAAC;IAED,IAAI,iBAAiB;QACnB,OAAO,IAAI,CAAA;;;;KAIV,CAAA;IACH,CAAC;IAED,SAAS,CAAC,CAAgB;QACxB,CAAC,CAAC,cAAc,EAAE,CAAA;QAElB,IAAI,CAAC,CAAC,GAAG,KAAK,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,UAAU,EAAE,CAAC;YACzC,IAAI,CAAC,OAAO,EAAE,CAAA;QAChB,CAAC;IACH,CAAC;IAES,cAAc,CAAC,EAAE,QAAQ,EAAiB;QAClD,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CAAA;IACjG,CAAC;;AAlGiE;IAAjE,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;2CAAqC;AAC1C;IAA3D,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,SAAS,EAAE,kBAAkB,EAAE,CAAC;oDAAkC;AACrB;IAAvE,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;iDAA+B;AAChD;IAArD,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,CAAC;wCAAsB;AAElE;IAAR,KAAK,EAAE;6CAAoD;AArEjD,UAAU;IADtB,aAAa,CAAC,aAAa,CAAC;GAChB,UAAU,CAmKtB","sourcesContent":["/**\n * @license Copyright © HatioLab Inc. All rights reserved.\n */\n\n/*\n This component is inspired by https://github.com/Polydile/dile-components, thanks Dile.\n*/\n\nimport { css, html } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\n\nimport { OxFormField } from './ox-form-field'\n\n@customElement('ox-checkbox')\nexport class OxCheckbox extends OxFormField {\n static styles = [\n css`\n div {\n display: flex;\n gap: var(--input-intra-gap, 7px);\n\n align-items: center;\n cursor: pointer;\n }\n\n [disabled] {\n opacity: var(--ox-checkbox-disabled-opacity, 0.5);\n cursor: auto;\n }\n\n .checkbox {\n display: flex;\n border-radius: var(--ox-checkbox-border-radius, 4px);\n background-color: var(--ox-checkbox-unchecked-background-color, var(--md-sys-color-surface-container-lowest));\n border: var(--ox-checkbox-unchecked-border, 1px solid var(--md-sys-color-outline));\n width: var(--ox-checkbox-size, 15px);\n height: var(--ox-checkbox-size, 15px);\n align-items: center;\n justify-content: center;\n }\n\n :host([indeterminate]) .checkbox {\n background-color: var(--ox-checkbox-unchecked-background-color, var(--md-ref-palette-primary80));\n }\n\n :host([checked]) .checkbox {\n background-color: var(--ox-checkbox-checked-background-color, var(--md-ref-palette-primary60));\n }\n\n path {\n fill: var(--ox-checkbox-unchecked-color, var(--md-sys-color-surface-container-lowest));\n }\n\n :host([indeterminate]) line {\n fill: var(--ox-checkbox-intermidiate-color, var(--md-sys-color-on-surface-variant));\n stroke: var(--ox-checkbox-intermidiate-color, var(--md-sys-color-outline));\n }\n\n :host([checked]) path {\n fill: var(--ox-checkbox-checked-color, var(--md-sys-color-on-primary));\n }\n\n svg {\n width: var(--ox-checkbox-size, 15px);\n height: var(--ox-checkbox-size, 15px);\n }\n\n .label {\n color: var(--ox-checkbox-label-color, var(--md-sys-color-on-surface-variant));\n font-size: var(--md-sys-typescale-label-large-size, 0.875rem);\n line-height: var(--md-sys-typescale-label-medium-line-height, 1rem);\n }\n :host([checked]) .label {\n font-weight: 700;\n }\n `\n ]\n\n @property({ type: Boolean, attribute: 'checked', reflect: true }) checked: boolean | undefined = false\n @property({ type: Boolean, attribute: 'indeterminatable' }) indeterminatable: boolean = false\n @property({ type: Boolean, attribute: 'indeterminate', reflect: true }) indeterminate: boolean = false\n @property({ type: Boolean, attribute: 'left-label' }) left: boolean = false\n\n @state() _hasInner: boolean = !!this.innerHTML.trim().length\n\n render() {\n return html`\n <div @click=${this.onClick} ?disabled=${this.disabled}>\n ${this._hasInner && this.left\n ? html` <span label>\n <slot></slot>\n </span>`\n : ''}\n <a href=\"#\" @click=${(e: Event) => e.preventDefault()} class=\"checkbox\">\n ${this.indeterminate ? this.indeterminateIcon : this.checked ? this.checkedIcon : this.uncheckedIcon}\n </a>\n ${this._hasInner && !this.left\n ? html` <span class=\"label\">\n <slot></slot>\n </span>`\n : ''}\n </div>\n `\n }\n\n connectedCallback() {\n super.connectedCallback()\n\n this.setAttribute('tabindex', '0')\n this.addEventListener('keydown', this.onKeyDown.bind(this))\n }\n\n onClick() {\n if (this.disabled) {\n return\n }\n\n if (!this.indeterminatable) {\n this.indeterminate = false\n this.checked = !this.checked\n } else {\n if (this.indeterminate) {\n this.indeterminate = false\n this.checked = true\n } else if (this.checked) {\n this.indeterminate = false\n this.checked = false\n } else {\n this.indeterminate = true\n this.checked = undefined\n }\n }\n\n this.dispatchEvent(\n new CustomEvent('change', {\n bubbles: true,\n composed: true,\n detail: this.checked\n })\n )\n }\n\n get checkedIcon() {\n return html`\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\">\n <path d=\"M9 16.2L4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4L9 16.2z\" />\n </svg>\n `\n }\n\n get uncheckedIcon() {\n return html`\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\">\n <path d=\"M9 16.2L4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4L9 16.2z\" />\n </svg>\n `\n }\n\n get indeterminateIcon() {\n return html`\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\">\n <line x1=\"4\" x2=\"20\" y1=\"12\" y2=\"12\" stroke-width=\"2\" stroke-linecap=\"round\" />\n </svg>\n `\n }\n\n onKeyDown(e: KeyboardEvent) {\n e.preventDefault()\n\n if (e.key === ' ' || e.key == 'Spacebar') {\n this.onClick()\n }\n }\n\n protected appendFormData({ formData }: FormDataEvent): void {\n this.name && !this.indeterminate && formData.append(this.name, this.checked ? 'true' : 'false')\n }\n}\n"]}
@@ -13,13 +13,24 @@ let OxInput3Axis = class OxInput3Axis extends OxFormField {
13
13
  display: flex;
14
14
  }
15
15
 
16
+ input {
17
+ box-sizing: border-box;
18
+ padding: 0 var(--spacing-small);
19
+ height: var(--form-element-height-medium);
20
+ border: 1px solid var(--md-sys-color-outline);
21
+ border-radius: var(--md-sys-shape-corner-small);
22
+ background-color: var(--md-sys-color-on-primary);
23
+ font-size: var(--md-sys-typescale-label-large-size, 0.875rem);
24
+ color: var(--md-sys-color-on-primary-container);
25
+ }
26
+
16
27
  input:not(:last-child) {
17
28
  margin-right: var(--margin-default, 2px);
18
29
  }
19
30
 
20
31
  input:focus {
21
32
  outline: none;
22
- border-bottom: 1px solid var(--primary-color);
33
+ border-color: var(--md-sys-color-secondary-fixed-dim);
23
34
  }
24
35
  `
25
36
  ]; }