react-miui 0.0.1 → 0.3.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 (352) hide show
  1. package/CHANGELOG.md +46 -0
  2. package/README.md +10 -1
  3. package/assets/back.svg +1 -0
  4. package/dist/components/form/Checkbox.module.scss +13 -6
  5. package/dist/components/form/Toggle.d.ts +8 -0
  6. package/dist/components/form/Toggle.d.ts.map +1 -0
  7. package/dist/components/form/Toggle.js +40 -0
  8. package/dist/components/form/Toggle.js.map +1 -0
  9. package/dist/components/form/Toggle.module.scss +46 -0
  10. package/dist/components/icons/Back.d.ts +7 -0
  11. package/dist/components/icons/Back.d.ts.map +1 -0
  12. package/dist/components/icons/Back.js +13 -0
  13. package/dist/components/icons/Back.js.map +1 -0
  14. package/dist/components/icons/Checkmark.d.ts.map +1 -1
  15. package/dist/components/icons/Checkmark.js.map +1 -1
  16. package/dist/components/icons/Icon.d.ts +12 -0
  17. package/dist/components/icons/Icon.d.ts.map +1 -0
  18. package/dist/components/icons/Icon.js +40 -0
  19. package/dist/components/icons/Icon.js.map +1 -0
  20. package/dist/components/layout/header/Header.d.ts +13 -0
  21. package/dist/components/layout/header/Header.d.ts.map +1 -0
  22. package/dist/components/layout/header/Header.js +43 -0
  23. package/dist/components/layout/header/Header.js.map +1 -0
  24. package/dist/components/layout/header/Header.module.scss +89 -0
  25. package/dist/components/layout/header/HeaderIconAction.d.ts +17 -0
  26. package/dist/components/layout/header/HeaderIconAction.d.ts.map +1 -0
  27. package/dist/components/layout/header/HeaderIconAction.js +40 -0
  28. package/dist/components/layout/header/HeaderIconAction.js.map +1 -0
  29. package/dist/components/layout/header/HeaderIconAction.module.scss +22 -0
  30. package/dist/components/layout/header/StickyHeader.d.ts +10 -0
  31. package/dist/components/layout/header/StickyHeader.d.ts.map +1 -0
  32. package/dist/components/layout/header/StickyHeader.js +34 -0
  33. package/dist/components/layout/header/StickyHeader.js.map +1 -0
  34. package/dist/components/layout/header/StickyHeader.module.scss +18 -0
  35. package/dist/components/layout/list/Item.d.ts +14 -0
  36. package/dist/components/layout/list/Item.d.ts.map +1 -0
  37. package/dist/components/layout/list/Item.js +50 -0
  38. package/dist/components/layout/list/Item.js.map +1 -0
  39. package/dist/components/layout/list/Item.module.scss +23 -0
  40. package/dist/components/layout/list/List.d.ts +4 -0
  41. package/dist/components/layout/list/List.d.ts.map +1 -0
  42. package/dist/components/layout/list/List.js +13 -0
  43. package/dist/components/layout/list/List.js.map +1 -0
  44. package/dist/components/layout/list/List.module.scss +4 -0
  45. package/dist/components/ui/action/Action.d.ts +17 -0
  46. package/dist/components/ui/action/Action.d.ts.map +1 -0
  47. package/dist/components/ui/action/Action.js +44 -0
  48. package/dist/components/ui/action/Action.js.map +1 -0
  49. package/dist/components/ui/action/Action.module.scss +26 -0
  50. package/dist/components/ui/action/EqualActions.d.ts +7 -0
  51. package/dist/components/ui/action/EqualActions.d.ts.map +1 -0
  52. package/dist/components/ui/action/EqualActions.js +23 -0
  53. package/dist/components/ui/action/EqualActions.js.map +1 -0
  54. package/dist/components/ui/action/EqualActions.module.scss +6 -0
  55. package/dist/components/ui/button/Button.d.ts +8 -0
  56. package/dist/components/ui/button/Button.d.ts.map +1 -0
  57. package/dist/components/ui/button/Button.js +20 -0
  58. package/dist/components/ui/button/Button.js.map +1 -0
  59. package/dist/components/ui/button/Button.module.scss +25 -0
  60. package/dist/components/ui/directionPad/Button.d.ts +7 -0
  61. package/dist/components/ui/directionPad/Button.d.ts.map +1 -0
  62. package/dist/components/ui/directionPad/Button.js +14 -0
  63. package/dist/components/ui/directionPad/Button.js.map +1 -0
  64. package/dist/components/ui/directionPad/Middle.d.ts +8 -0
  65. package/dist/components/ui/directionPad/Middle.d.ts.map +1 -0
  66. package/dist/components/ui/directionPad/Middle.js +13 -0
  67. package/dist/components/ui/directionPad/Middle.js.map +1 -0
  68. package/dist/components/ui/directionPad/Pad.d.ts +12 -0
  69. package/dist/components/ui/directionPad/Pad.d.ts.map +1 -0
  70. package/dist/components/ui/directionPad/Pad.js +23 -0
  71. package/dist/components/ui/directionPad/Pad.js.map +1 -0
  72. package/dist/components/ui/directionPad/Pad.module.scss +45 -0
  73. package/dist/demo/Demo.d.ts.map +1 -1
  74. package/dist/demo/Demo.js +2 -1
  75. package/dist/demo/Demo.js.map +1 -1
  76. package/dist/demo/Main.d.ts.map +1 -1
  77. package/dist/demo/Main.js +36 -8
  78. package/dist/demo/Main.js.map +1 -1
  79. package/dist/demo/Main.module.scss +13 -0
  80. package/dist/demo/Menu.d.ts +6 -1
  81. package/dist/demo/Menu.d.ts.map +1 -1
  82. package/dist/demo/Menu.js +20 -4
  83. package/dist/demo/Menu.js.map +1 -1
  84. package/dist/demo/Menu.module.scss +30 -8
  85. package/dist/demo/components/form/Checkbox.d.ts.map +1 -1
  86. package/dist/demo/components/form/Checkbox.js +3 -2
  87. package/dist/demo/components/form/Checkbox.js.map +1 -1
  88. package/dist/demo/components/form/Toggle.d.ts +4 -0
  89. package/dist/demo/components/form/Toggle.d.ts.map +1 -0
  90. package/dist/demo/components/form/Toggle.js +65 -0
  91. package/dist/demo/components/form/Toggle.js.map +1 -0
  92. package/dist/demo/components/form/Toggle.module.scss +5 -0
  93. package/dist/demo/components/layout/header/Header.d.ts +8 -0
  94. package/dist/demo/components/layout/header/Header.d.ts.map +1 -0
  95. package/dist/demo/components/layout/header/Header.js +60 -0
  96. package/dist/demo/components/layout/header/Header.js.map +1 -0
  97. package/dist/demo/components/layout/header/StickyHeader.d.ts +9 -0
  98. package/dist/demo/components/layout/header/StickyHeader.d.ts.map +1 -0
  99. package/dist/demo/components/layout/header/StickyHeader.js +73 -0
  100. package/dist/demo/components/layout/header/StickyHeader.js.map +1 -0
  101. package/dist/demo/components/layout/list/List.Item.d.ts +4 -0
  102. package/dist/demo/components/layout/list/List.Item.d.ts.map +1 -0
  103. package/dist/demo/components/layout/list/List.Item.js +42 -0
  104. package/dist/demo/components/layout/list/List.Item.js.map +1 -0
  105. package/dist/demo/components/layout/list/List.Item.module.scss +3 -0
  106. package/dist/demo/components/ui/action/Action.d.ts +8 -0
  107. package/dist/demo/components/ui/action/Action.d.ts.map +1 -0
  108. package/dist/demo/components/ui/action/Action.js +83 -0
  109. package/dist/demo/components/ui/action/Action.js.map +1 -0
  110. package/dist/demo/components/ui/action/ActionDemo.module.scss +3 -0
  111. package/dist/demo/components/ui/button/ButtonDemo.d.ts +4 -0
  112. package/dist/demo/components/ui/button/ButtonDemo.d.ts.map +1 -0
  113. package/dist/demo/components/ui/button/ButtonDemo.js +20 -0
  114. package/dist/demo/components/ui/button/ButtonDemo.js.map +1 -0
  115. package/dist/demo/components/ui/directionPad/Pad.d.ts +4 -0
  116. package/dist/demo/components/ui/directionPad/Pad.d.ts.map +1 -0
  117. package/dist/demo/components/ui/directionPad/Pad.js +49 -0
  118. package/dist/demo/components/ui/directionPad/Pad.js.map +1 -0
  119. package/dist/demo/components/ui/icons/Icons.d.ts +4 -0
  120. package/dist/demo/components/ui/icons/Icons.d.ts.map +1 -0
  121. package/dist/demo/components/ui/icons/Icons.js +20 -0
  122. package/dist/demo/components/ui/icons/Icons.js.map +1 -0
  123. package/dist/demo/components/ui/icons/Icons.module.scss +4 -0
  124. package/dist/demo/componentsMap.d.ts +13 -0
  125. package/dist/demo/componentsMap.d.ts.map +1 -0
  126. package/dist/demo/componentsMap.js +112 -0
  127. package/dist/demo/componentsMap.js.map +1 -0
  128. package/dist/demo/utils/makeVariants.d.ts +3 -0
  129. package/dist/demo/utils/makeVariants.d.ts.map +1 -0
  130. package/dist/demo/utils/makeVariants.js +14 -0
  131. package/dist/demo/utils/makeVariants.js.map +1 -0
  132. package/dist/global.scss +34 -13
  133. package/dist/index.d.ts +8 -1
  134. package/dist/index.d.ts.map +1 -1
  135. package/dist/index.js +8 -1
  136. package/dist/index.js.map +1 -1
  137. package/dist/pages/_app.d.ts.map +1 -1
  138. package/dist/pages/_app.js +5 -1
  139. package/dist/pages/_app.js.map +1 -1
  140. package/dist/pages/react-miui.d.ts +4 -0
  141. package/dist/pages/react-miui.d.ts.map +1 -0
  142. package/dist/pages/react-miui.js +11 -0
  143. package/dist/pages/react-miui.js.map +1 -0
  144. package/dist/types.d.ts +4 -0
  145. package/dist/types.d.ts.map +1 -0
  146. package/dist/types.js +3 -0
  147. package/dist/types.js.map +1 -0
  148. package/docs/assets/js/search.js +1 -1
  149. package/docs/assets/js/search.json +1 -1
  150. package/docs/enums/ICON.html +182 -0
  151. package/docs/index.html +38 -5
  152. package/docs/modules/StickyHeader.html +159 -0
  153. package/docs/modules.html +121 -5
  154. package/docs/pages/Tutorials/Test.html +6 -3
  155. package/esm/components/form/Checkbox.module.scss +13 -6
  156. package/esm/components/form/Toggle.d.ts +8 -0
  157. package/esm/components/form/Toggle.d.ts.map +1 -0
  158. package/esm/components/form/Toggle.js +15 -0
  159. package/esm/components/form/Toggle.js.map +1 -0
  160. package/esm/components/form/Toggle.module.scss +46 -0
  161. package/esm/components/icons/Back.d.ts +7 -0
  162. package/esm/components/icons/Back.d.ts.map +1 -0
  163. package/esm/components/icons/Back.js +7 -0
  164. package/esm/components/icons/Back.js.map +1 -0
  165. package/esm/components/icons/Checkmark.d.ts.map +1 -1
  166. package/esm/components/icons/Checkmark.js.map +1 -1
  167. package/esm/components/icons/Icon.d.ts +12 -0
  168. package/esm/components/icons/Icon.d.ts.map +1 -0
  169. package/esm/components/icons/Icon.js +21 -0
  170. package/esm/components/icons/Icon.js.map +1 -0
  171. package/esm/components/layout/header/Header.d.ts +13 -0
  172. package/esm/components/layout/header/Header.d.ts.map +1 -0
  173. package/esm/components/layout/header/Header.js +37 -0
  174. package/esm/components/layout/header/Header.js.map +1 -0
  175. package/esm/components/layout/header/Header.module.scss +89 -0
  176. package/esm/components/layout/header/HeaderIconAction.d.ts +17 -0
  177. package/esm/components/layout/header/HeaderIconAction.d.ts.map +1 -0
  178. package/esm/components/layout/header/HeaderIconAction.js +23 -0
  179. package/esm/components/layout/header/HeaderIconAction.js.map +1 -0
  180. package/esm/components/layout/header/HeaderIconAction.module.scss +22 -0
  181. package/esm/components/layout/header/StickyHeader.d.ts +10 -0
  182. package/esm/components/layout/header/StickyHeader.d.ts.map +1 -0
  183. package/esm/components/layout/header/StickyHeader.js +28 -0
  184. package/esm/components/layout/header/StickyHeader.js.map +1 -0
  185. package/esm/components/layout/header/StickyHeader.module.scss +18 -0
  186. package/esm/components/layout/list/Item.d.ts +14 -0
  187. package/esm/components/layout/list/Item.d.ts.map +1 -0
  188. package/esm/components/layout/list/Item.js +33 -0
  189. package/esm/components/layout/list/Item.js.map +1 -0
  190. package/esm/components/layout/list/Item.module.scss +23 -0
  191. package/esm/components/layout/list/List.d.ts +4 -0
  192. package/esm/components/layout/list/List.d.ts.map +1 -0
  193. package/esm/components/layout/list/List.js +7 -0
  194. package/esm/components/layout/list/List.js.map +1 -0
  195. package/esm/components/layout/list/List.module.scss +4 -0
  196. package/esm/components/ui/action/Action.d.ts +17 -0
  197. package/esm/components/ui/action/Action.d.ts.map +1 -0
  198. package/esm/components/ui/action/Action.js +27 -0
  199. package/esm/components/ui/action/Action.js.map +1 -0
  200. package/esm/components/ui/action/Action.module.scss +26 -0
  201. package/esm/components/ui/action/EqualActions.d.ts +7 -0
  202. package/esm/components/ui/action/EqualActions.d.ts.map +1 -0
  203. package/esm/components/ui/action/EqualActions.js +17 -0
  204. package/esm/components/ui/action/EqualActions.js.map +1 -0
  205. package/esm/components/ui/action/EqualActions.module.scss +6 -0
  206. package/esm/components/ui/button/Button.d.ts +8 -0
  207. package/esm/components/ui/button/Button.d.ts.map +1 -0
  208. package/esm/components/ui/button/Button.js +14 -0
  209. package/esm/components/ui/button/Button.js.map +1 -0
  210. package/esm/components/ui/button/Button.module.scss +25 -0
  211. package/esm/components/ui/directionPad/Button.d.ts +7 -0
  212. package/esm/components/ui/directionPad/Button.d.ts.map +1 -0
  213. package/esm/components/ui/directionPad/Button.js +8 -0
  214. package/esm/components/ui/directionPad/Button.js.map +1 -0
  215. package/esm/components/ui/directionPad/Middle.d.ts +8 -0
  216. package/esm/components/ui/directionPad/Middle.d.ts.map +1 -0
  217. package/esm/components/ui/directionPad/Middle.js +7 -0
  218. package/esm/components/ui/directionPad/Middle.js.map +1 -0
  219. package/esm/components/ui/directionPad/Pad.d.ts +12 -0
  220. package/esm/components/ui/directionPad/Pad.d.ts.map +1 -0
  221. package/esm/components/ui/directionPad/Pad.js +17 -0
  222. package/esm/components/ui/directionPad/Pad.js.map +1 -0
  223. package/esm/components/ui/directionPad/Pad.module.scss +45 -0
  224. package/esm/demo/Demo.d.ts.map +1 -1
  225. package/esm/demo/Demo.js +2 -1
  226. package/esm/demo/Demo.js.map +1 -1
  227. package/esm/demo/Main.d.ts.map +1 -1
  228. package/esm/demo/Main.js +37 -9
  229. package/esm/demo/Main.js.map +1 -1
  230. package/esm/demo/Main.module.scss +13 -0
  231. package/esm/demo/Menu.d.ts +6 -1
  232. package/esm/demo/Menu.d.ts.map +1 -1
  233. package/esm/demo/Menu.js +20 -4
  234. package/esm/demo/Menu.js.map +1 -1
  235. package/esm/demo/Menu.module.scss +30 -8
  236. package/esm/demo/components/form/Checkbox.d.ts.map +1 -1
  237. package/esm/demo/components/form/Checkbox.js +4 -3
  238. package/esm/demo/components/form/Checkbox.js.map +1 -1
  239. package/esm/demo/components/form/Toggle.d.ts +4 -0
  240. package/esm/demo/components/form/Toggle.d.ts.map +1 -0
  241. package/esm/demo/components/form/Toggle.js +40 -0
  242. package/esm/demo/components/form/Toggle.js.map +1 -0
  243. package/esm/demo/components/form/Toggle.module.scss +5 -0
  244. package/esm/demo/components/layout/header/Header.d.ts +8 -0
  245. package/esm/demo/components/layout/header/Header.d.ts.map +1 -0
  246. package/esm/demo/components/layout/header/Header.js +50 -0
  247. package/esm/demo/components/layout/header/Header.js.map +1 -0
  248. package/esm/demo/components/layout/header/StickyHeader.d.ts +9 -0
  249. package/esm/demo/components/layout/header/StickyHeader.d.ts.map +1 -0
  250. package/esm/demo/components/layout/header/StickyHeader.js +62 -0
  251. package/esm/demo/components/layout/header/StickyHeader.js.map +1 -0
  252. package/esm/demo/components/layout/list/List.Item.d.ts +4 -0
  253. package/esm/demo/components/layout/list/List.Item.d.ts.map +1 -0
  254. package/esm/demo/components/layout/list/List.Item.js +17 -0
  255. package/esm/demo/components/layout/list/List.Item.js.map +1 -0
  256. package/esm/demo/components/layout/list/List.Item.module.scss +3 -0
  257. package/esm/demo/components/ui/action/Action.d.ts +8 -0
  258. package/esm/demo/components/ui/action/Action.d.ts.map +1 -0
  259. package/esm/demo/components/ui/action/Action.js +73 -0
  260. package/esm/demo/components/ui/action/Action.js.map +1 -0
  261. package/esm/demo/components/ui/action/ActionDemo.module.scss +3 -0
  262. package/esm/demo/components/ui/button/ButtonDemo.d.ts +4 -0
  263. package/esm/demo/components/ui/button/ButtonDemo.d.ts.map +1 -0
  264. package/esm/demo/components/ui/button/ButtonDemo.js +14 -0
  265. package/esm/demo/components/ui/button/ButtonDemo.js.map +1 -0
  266. package/esm/demo/components/ui/directionPad/Pad.d.ts +4 -0
  267. package/esm/demo/components/ui/directionPad/Pad.d.ts.map +1 -0
  268. package/esm/demo/components/ui/directionPad/Pad.js +27 -0
  269. package/esm/demo/components/ui/directionPad/Pad.js.map +1 -0
  270. package/esm/demo/components/ui/icons/Icons.d.ts +4 -0
  271. package/esm/demo/components/ui/icons/Icons.d.ts.map +1 -0
  272. package/esm/demo/components/ui/icons/Icons.js +14 -0
  273. package/esm/demo/components/ui/icons/Icons.js.map +1 -0
  274. package/esm/demo/components/ui/icons/Icons.module.scss +4 -0
  275. package/esm/demo/componentsMap.d.ts +13 -0
  276. package/esm/demo/componentsMap.d.ts.map +1 -0
  277. package/esm/demo/componentsMap.js +109 -0
  278. package/esm/demo/componentsMap.js.map +1 -0
  279. package/esm/demo/utils/makeVariants.d.ts +3 -0
  280. package/esm/demo/utils/makeVariants.d.ts.map +1 -0
  281. package/esm/demo/utils/makeVariants.js +11 -0
  282. package/esm/demo/utils/makeVariants.js.map +1 -0
  283. package/esm/global.scss +34 -13
  284. package/esm/index.d.ts +8 -1
  285. package/esm/index.d.ts.map +1 -1
  286. package/esm/index.js +8 -1
  287. package/esm/index.js.map +1 -1
  288. package/esm/pages/_app.d.ts.map +1 -1
  289. package/esm/pages/_app.js +5 -1
  290. package/esm/pages/_app.js.map +1 -1
  291. package/esm/pages/react-miui.d.ts +4 -0
  292. package/esm/pages/react-miui.d.ts.map +1 -0
  293. package/esm/pages/react-miui.js +6 -0
  294. package/esm/pages/react-miui.js.map +1 -0
  295. package/esm/types.d.ts +4 -0
  296. package/esm/types.d.ts.map +1 -0
  297. package/esm/types.js +2 -0
  298. package/esm/types.js.map +1 -0
  299. package/package.json +9 -7
  300. package/src/components/form/Checkbox.module.scss +13 -6
  301. package/src/components/form/Toggle.module.scss +46 -0
  302. package/src/components/form/Toggle.tsx +33 -0
  303. package/src/components/icons/Back.tsx +15 -0
  304. package/src/components/icons/Checkmark.tsx +5 -2
  305. package/src/components/icons/Icon.tsx +30 -0
  306. package/src/components/layout/header/Header.module.scss +89 -0
  307. package/src/components/layout/header/Header.tsx +65 -0
  308. package/src/components/layout/header/HeaderIconAction.module.scss +22 -0
  309. package/src/components/layout/header/HeaderIconAction.tsx +49 -0
  310. package/src/components/layout/header/StickyHeader.module.scss +18 -0
  311. package/src/components/layout/header/StickyHeader.tsx +54 -0
  312. package/src/components/layout/list/Item.module.scss +23 -0
  313. package/src/components/layout/list/Item.tsx +50 -0
  314. package/src/components/layout/list/List.module.scss +4 -0
  315. package/src/components/layout/list/List.tsx +11 -0
  316. package/src/components/ui/action/Action.module.scss +26 -0
  317. package/src/components/ui/action/Action.tsx +58 -0
  318. package/src/components/ui/action/EqualActions.module.scss +6 -0
  319. package/src/components/ui/action/EqualActions.tsx +30 -0
  320. package/src/components/ui/button/Button.module.scss +25 -0
  321. package/src/components/ui/button/Button.tsx +25 -0
  322. package/src/components/ui/directionPad/Button.tsx +15 -0
  323. package/src/components/ui/directionPad/Middle.tsx +16 -0
  324. package/src/components/ui/directionPad/Pad.module.scss +45 -0
  325. package/src/components/ui/directionPad/Pad.tsx +35 -0
  326. package/src/demo/Demo.tsx +2 -1
  327. package/src/demo/Main.module.scss +13 -0
  328. package/src/demo/Main.tsx +53 -10
  329. package/src/demo/Menu.module.scss +30 -8
  330. package/src/demo/Menu.tsx +33 -7
  331. package/src/demo/components/form/Checkbox.tsx +7 -3
  332. package/src/demo/components/form/Toggle.module.scss +5 -0
  333. package/src/demo/components/form/Toggle.tsx +59 -0
  334. package/src/demo/components/layout/header/Header.tsx +119 -0
  335. package/src/demo/components/layout/header/StickyHeader.tsx +85 -0
  336. package/src/demo/components/layout/list/List.Item.module.scss +3 -0
  337. package/src/demo/components/layout/list/List.Item.tsx +23 -0
  338. package/src/demo/components/ui/action/Action.tsx +112 -0
  339. package/src/demo/components/ui/action/ActionDemo.module.scss +3 -0
  340. package/src/demo/components/ui/button/ButtonDemo.tsx +18 -0
  341. package/src/demo/components/ui/directionPad/Pad.tsx +40 -0
  342. package/src/demo/components/ui/icons/Icons.module.scss +4 -0
  343. package/src/demo/components/ui/icons/Icons.tsx +25 -0
  344. package/src/demo/componentsMap.ts +144 -0
  345. package/src/demo/utils/makeVariants.ts +13 -0
  346. package/src/global.scss +34 -13
  347. package/src/index.ts +11 -1
  348. package/src/pages/_app.tsx +7 -1
  349. package/src/pages/react-miui.tsx +12 -0
  350. package/src/types.ts +7 -0
  351. package/.postcssrc +0 -9
  352. package/src/pages/index.html +0 -14
package/esm/global.scss CHANGED
@@ -1,15 +1,18 @@
1
- // Font-size ratio: 1,6 (666?)
2
- // Border ratio: 2,6666
3
- // Dimensions ratio: 3
4
-
5
1
  // @TODO prefix variable names
6
2
  :root {
3
+ --ratio-dimensions: 3;
4
+ --ratio-border: 2.666666;
5
+ --ratio-font: 1.666666;
6
+
7
7
  --main-color: #008ad2; // used
8
8
  --main-color-alt: #006AA9;
9
9
 
10
10
  --active-bg: #d3d3d3;
11
11
  --inactive-bg: #d3d3d3; // used
12
12
 
13
+ --toggle-handle-bg: #e0e0e0;
14
+ --toggle-handle-border: #cdcdcd;
15
+
13
16
  --icon: #636363;
14
17
  --border: #d5d5d5;
15
18
  --button-border: #bababa;
@@ -18,17 +21,35 @@
18
21
  --header-bg: #efeff0;
19
22
  --header-text: #484848;
20
23
 
21
- --toolbar--border: #ababab;
22
- --toolbar--bg: #f8f8f8;
24
+ --toolbar-border: #ababab;
25
+ --toolbar-bg: #f8f8f8;
23
26
 
24
- --color1: #00aeeb;
25
- --color2: #9d6ee5;
26
- --color3: #00c293;
27
- --color4: #ff5290;
28
- --color5: #ff7259;
29
- --color6: #4083f7;
27
+ // Shades: https://maketintsandshades.com/#038bf4,ff7200,7357e8,3ec234,3ec234,ff388f,ea2700
28
+ --blue1: #038bf4;
29
+ --orange1: #ff7200;
30
+ --orange1-darker: #cc5b00;
31
+ --purple1: #7357e8;
32
+ --green1: #3ec234;
33
+ --green1-darker: #38af2f;
34
+ --pink1: #ff388f;
35
+ --red1: #ea2700;
36
+
37
+ --grey1: #737373;
38
+
39
+ --focus-color: #dcaf00;
30
40
  }
31
41
 
32
- *:focus { // @TODO take care of focus
42
+ *:focus {
33
43
  outline: none!important;
34
44
  }
45
+
46
+ *:focus-visible:focus-visible {
47
+ outline: none!important;
48
+ border-color: var(--focus-color);
49
+ background-color: var(--focus-bg-set);
50
+ }
51
+
52
+
53
+ body {
54
+ font-size: 15px;
55
+ }
package/esm/index.d.ts CHANGED
@@ -1,2 +1,9 @@
1
- export * from "./components/form/Checkbox";
1
+ export * from "./components/form/Checkbox.js";
2
+ export * from "./components/icons/Icon.js";
3
+ export * from "./components/layout/header/Header.js";
4
+ export * from "./components/layout/header/StickyHeader.js";
5
+ export * from "./components/layout/list/List.js";
6
+ export * from "./components/layout/list/Item.js";
7
+ export * from "./components/ui/button/Button.js";
8
+ export * from "./components/ui/directionPad/Pad.js";
2
9
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,4BAA4B,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,+BAA+B,CAAC;AAE9C,cAAc,4BAA4B,CAAC;AAE3C,cAAc,sCAAsC,CAAC;AACrD,cAAc,4CAA4C,CAAC;AAC3D,cAAc,kCAAkC,CAAC;AACjD,cAAc,kCAAkC,CAAC;AAEjD,cAAc,kCAAkC,CAAC;AACjD,cAAc,qCAAqC,CAAC"}
package/esm/index.js CHANGED
@@ -1,2 +1,9 @@
1
- export * from "./components/form/Checkbox";
1
+ export * from "./components/form/Checkbox.js";
2
+ export * from "./components/icons/Icon.js";
3
+ export * from "./components/layout/header/Header.js";
4
+ export * from "./components/layout/header/StickyHeader.js";
5
+ export * from "./components/layout/list/List.js";
6
+ export * from "./components/layout/list/Item.js";
7
+ export * from "./components/ui/button/Button.js";
8
+ export * from "./components/ui/directionPad/Pad.js";
2
9
  //# sourceMappingURL=index.js.map
package/esm/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,4BAA4B,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,+BAA+B,CAAC;AAE9C,cAAc,4BAA4B,CAAC;AAE3C,cAAc,sCAAsC,CAAC;AACrD,cAAc,4CAA4C,CAAC;AAC3D,cAAc,kCAAkC,CAAC;AACjD,cAAc,kCAAkC,CAAC;AAEjD,cAAc,kCAAkC,CAAC;AACjD,cAAc,qCAAqC,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"_app.d.ts","sourceRoot":"","sources":["../../src/pages/_app.tsx"],"names":[],"mappings":";AACA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;AAEzC,OAAO,gBAAgB,CAAC;AACxB,OAAO,qBAAqB,CAAC;AAE7B,QAAA,MAAM,KAAK,6BAA8B,QAAQ,gBAEhD,CAAC;AAEF,eAAe,KAAK,CAAC"}
1
+ {"version":3,"file":"_app.d.ts","sourceRoot":"","sources":["../../src/pages/_app.tsx"],"names":[],"mappings":";AAEA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;AAEzC,OAAO,gBAAgB,CAAC;AACxB,OAAO,qBAAqB,CAAC;AAE7B,QAAA,MAAM,KAAK,6BAA8B,QAAQ,gBAOhD,CAAC;AAEF,eAAe,KAAK,CAAC"}
package/esm/pages/_app.js CHANGED
@@ -1,6 +1,10 @@
1
1
  import React from "react";
2
+ import Head from "next/head";
2
3
  import "../global.scss";
3
4
  import "../demo-global.scss";
4
- const MyApp = ({ Component, pageProps }) => (React.createElement(Component, { ...pageProps }));
5
+ const MyApp = ({ Component, pageProps }) => (React.createElement(React.Fragment, null,
6
+ React.createElement(Head, null,
7
+ React.createElement("title", null, "MIUI in React")),
8
+ React.createElement(Component, { ...pageProps })));
5
9
  export default MyApp;
6
10
  //# sourceMappingURL=_app.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"_app.js","sourceRoot":"","sources":["../../src/pages/_app.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,OAAO,gBAAgB,CAAC;AACxB,OAAO,qBAAqB,CAAC;AAE7B,MAAM,KAAK,GAAG,CAAC,EAAE,SAAS,EAAE,SAAS,EAAY,EAAE,EAAE,CAAC,CAClD,oBAAC,SAAS,OAAK,SAAS,GAAI,CAC/B,CAAC;AAEF,eAAe,KAAK,CAAC"}
1
+ {"version":3,"file":"_app.js","sourceRoot":"","sources":["../../src/pages/_app.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,IAAI,MAAM,WAAW,CAAC;AAG7B,OAAO,gBAAgB,CAAC;AACxB,OAAO,qBAAqB,CAAC;AAE7B,MAAM,KAAK,GAAG,CAAC,EAAE,SAAS,EAAE,SAAS,EAAY,EAAE,EAAE,CAAC,CAClD;IACI,oBAAC,IAAI;QACD,mDAA4B,CACzB;IACP,oBAAC,SAAS,OAAK,SAAS,GAAI,CAC7B,CACN,CAAC;AAEF,eAAe,KAAK,CAAC"}
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ declare const ReactMiuiPage: () => JSX.Element;
3
+ export default ReactMiuiPage;
4
+ //# sourceMappingURL=react-miui.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"react-miui.d.ts","sourceRoot":"","sources":["../../src/pages/react-miui.tsx"],"names":[],"mappings":";AAEA,QAAA,MAAM,aAAa,mBAOlB,CAAC;AAEF,eAAe,aAAa,CAAC"}
@@ -0,0 +1,6 @@
1
+ import React from "react";
2
+ const ReactMiuiPage = () => {
3
+ return (React.createElement("div", null, "Hi. This is an example page to demonstrate application level routing."));
4
+ };
5
+ export default ReactMiuiPage;
6
+ //# sourceMappingURL=react-miui.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"react-miui.js","sourceRoot":"","sources":["../../src/pages/react-miui.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,MAAM,aAAa,GAAG,GAAG,EAAE;IAEvB,OAAO,CACH,yGAEM,CACT,CAAC;AACN,CAAC,CAAC;AAEF,eAAe,aAAa,CAAC"}
package/esm/types.d.ts ADDED
@@ -0,0 +1,4 @@
1
+ import type React from "react";
2
+ declare type AnyComponent = React.ComponentClass | React.FC | React.VFC;
3
+ export type { AnyComponent, };
4
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,aAAK,YAAY,GAAG,KAAK,CAAC,cAAc,GAAG,KAAK,CAAC,EAAE,GAAG,KAAK,CAAC,GAAG,CAAC;AAEhE,YAAY,EACR,YAAY,GACf,CAAC"}
package/esm/types.js ADDED
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":""}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "react-miui",
3
- "version": "0.0.1",
3
+ "version": "0.3.0",
4
4
  "author": "Jacek Nowacki",
5
5
  "license": "MIT",
6
6
  "scripts": {
@@ -14,7 +14,8 @@
14
14
  "lint:fix": "yarn lint --fix",
15
15
  "prepack": "yarn compile",
16
16
  "prepublishOnly": "yarn audit && yarn lint && yarn test && yarn docs",
17
- "start:dev": "next dev"
17
+ "start:dev": "next dev",
18
+ "deploy:dev": "next build && next export && netlify deploy --dir out"
18
19
  },
19
20
  "exports": {
20
21
  "./global.scss": "./src/global.scss",
@@ -33,7 +34,8 @@
33
34
  "@babel/core": "^7.12.10",
34
35
  "@babel/preset-env": "^7.12.11",
35
36
  "@babel/preset-typescript": "^7.12.7",
36
- "@dzek69/eslint-config-base": "^2.0.0",
37
+ "@dzek69/eslint-config-base": "^2.1.0",
38
+ "@dzek69/eslint-config-react": "^1.2.2",
37
39
  "@dzek69/eslint-config-typescript": "^0.4.0",
38
40
  "@types/jest": "^26.0.23",
39
41
  "@types/react": "^17.0.4",
@@ -42,14 +44,14 @@
42
44
  "@typescript-eslint/parser": "^4.11.1",
43
45
  "babel-plugin-module-extension": "^0.1.3",
44
46
  "babel-plugin-module-resolver": "^4.1.0",
45
- "eslint": "^7.14.0",
47
+ "eslint": "^7.32.0",
48
+ "eslint-plugin-react": "^7.24.0",
46
49
  "fast-glob": "^3.2.7",
47
50
  "fs-extra": "^9.0.1",
48
51
  "husky": "^4.3.0",
49
52
  "jest": "^27.0.6",
50
53
  "must": "^0.13.4",
51
- "next": "^11.1.0",
52
- "nodemon": "^2.0.6",
54
+ "next": "^11.1.2",
53
55
  "react": "^17.0.2",
54
56
  "react-dom": "^17.0.2",
55
57
  "react-use": "^17.2.4",
@@ -69,7 +71,7 @@
69
71
  }
70
72
  },
71
73
  "libraryTemplate": {
72
- "version": "3.3.1",
74
+ "version": "3.4.0",
73
75
  "language": "typescript",
74
76
  "fixDefaultForCommonJS": true,
75
77
  "jsx": true
@@ -3,24 +3,31 @@
3
3
  width: 0;
4
4
  height: 0;
5
5
  transform: scale(0);
6
+ margin: 0;
7
+ vertical-align: middle;
6
8
 
7
9
  + span {
8
10
  border-radius: 100px;
9
11
  background: var(--inactive-bg);
10
- width: 24px;
11
- height: 24px;
12
+ width: 18px;
13
+ height: 18px;
12
14
  display: inline-flex;
13
15
  justify-content: center;
14
16
  align-items: center;
17
+ vertical-align: middle;
15
18
 
16
19
  svg {
17
- width: 12px;
18
- height: 12px;
20
+ width: 9px;
21
+ height: 9px;
19
22
  fill: white;
20
23
  }
24
+
25
+ + span {
26
+ vertical-align: middle;
27
+ }
21
28
  }
22
29
 
23
- &:focus {
30
+ &:focus-visible {
24
31
  + span {
25
32
  box-shadow: 0 0 5px black;
26
33
  }
@@ -34,7 +41,7 @@
34
41
  }
35
42
 
36
43
  + span + span:not(:empty) {
37
- margin-left: 1em;
44
+ margin-left: 0.5em;
38
45
  }
39
46
  }
40
47
  }
@@ -0,0 +1,46 @@
1
+ .container {
2
+ --ratio-dimensions: 2.5;
3
+
4
+ display: inline-flex;
5
+ align-items: center;
6
+ border: 1px solid #ccc;
7
+ border-radius: 100px;
8
+ position: relative;
9
+ line-height: 0;
10
+ width: calc(110px / var(--ratio-dimensions));
11
+ height: calc(62px / var(--ratio-dimensions));
12
+ padding-left: calc(8px / var(--ratio-dimensions));
13
+ box-sizing: border-box;
14
+
15
+ input {
16
+ position: absolute;
17
+ width: 0;
18
+ height: 0;
19
+ overflow: hidden;
20
+ visibility: hidden;
21
+
22
+ &:not(:checked) + .toggle {
23
+ transform: translateX(0);
24
+ background: var(--toggle-handle-bg);
25
+ border-color: var(--toggle-handle-border);
26
+ }
27
+
28
+ &[data-undetermined=true] + .toggle {
29
+ transform: translateX(calc(24px / var(--ratio-dimensions)));
30
+ background: var(--toggle-handle-border);
31
+ border-color: var(--toggle-handle-border);
32
+ }
33
+ }
34
+ }
35
+
36
+ .toggle {
37
+ box-sizing: border-box;
38
+ border-radius: 100px;
39
+ display: inline-block;
40
+ width: calc(44px / var(--ratio-dimensions));
41
+ height: calc(44px / var(--ratio-dimensions));
42
+ border: calc(1px / var(--ratio-border)) solid var(--orange1-darker);
43
+ background: var(--orange1);
44
+ transition: transform 200ms, background-color 200ms, border-color 200ms;
45
+ transform: translateX(calc(48px / var(--ratio-dimensions)));
46
+ }
@@ -0,0 +1,33 @@
1
+ import type { ChangeEvent } from "react";
2
+ import React, { useCallback } from "react";
3
+
4
+ import styles from "./Toggle.module.scss";
5
+
6
+ interface Props {
7
+ onChange: (newState: boolean) => void;
8
+ state: boolean | null;
9
+ }
10
+
11
+ const Toggle: React.VFC<Props> = (props) => {
12
+ const handleChange = useCallback((e: ChangeEvent<HTMLInputElement>) => {
13
+ if (props.state == null) {
14
+ return;
15
+ }
16
+ props.onChange(e.target.checked);
17
+ }, [props.onChange, props.state]);
18
+
19
+ return (
20
+ <label className={styles.container}>
21
+ <input
22
+ type={"checkbox"}
23
+ checked={Boolean(props.state)}
24
+ data-undetermined={props.state == null}
25
+ readOnly={props.state == null}
26
+ onChange={handleChange}
27
+ />
28
+ <div className={styles.toggle} />
29
+ </label>
30
+ );
31
+ };
32
+
33
+ export { Toggle };
@@ -0,0 +1,15 @@
1
+ import React from "react";
2
+
3
+ interface Props {
4
+ className?: string;
5
+ }
6
+
7
+ const Back: React.VFC<Props> = (props) => {
8
+ return (
9
+ <svg width={"9"} height={"16"} viewBox={"0 0 9 16"} xmlns={"http://www.w3.org/2000/svg"} className={props.className}>
10
+ <path fill={"currentColor"} d={"M8.05.1L0 7.95l8.05 7.85v.05q.15.15.4.15t.4-.15q.15-.2.15-.4 0-.25-.15-.4V15H8.8L1.65 7.95l7.2-7Q9 .75 9 .55q0-.25-.2-.4Q8.65 0 8.4 0q-.2 0-.35.1"} />
11
+ </svg>
12
+ );
13
+ };
14
+
15
+ export { Back };
@@ -7,11 +7,14 @@ interface Props {
7
7
  const Checkmark: React.FC<Props> = (props) => {
8
8
  return (
9
9
  <svg
10
- xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 45.701 45.7"
10
+ xmlns={"http://www.w3.org/2000/svg"}
11
+ width={"16"}
12
+ height={"16"}
13
+ viewBox={"0 0 45.701 45.7"}
11
14
  className={props.className}
12
15
  >
13
16
  <path
14
- d="M20.687 38.332a5.308 5.308 0 01-7.505 0L1.554 26.704A5.306 5.306 0 119.059 19.2l6.928 6.927a1.344 1.344 0 001.896 0L36.642 7.368a5.308 5.308 0 017.505 7.504l-23.46 23.46z"
17
+ d={"M20.687 38.332a5.308 5.308 0 01-7.505 0L1.554 26.704A5.306 5.306 0 119.059 19.2l6.928 6.927a1.344 1.344 0 001.896 0L36.642 7.368a5.308 5.308 0 017.505 7.504l-23.46 23.46z"}
15
18
  />
16
19
  </svg>
17
20
 
@@ -0,0 +1,30 @@
1
+ import type { AnyComponent } from "../../types";
2
+
3
+ import React from "react";
4
+ import { Checkmark } from "./Checkmark";
5
+ import { Back } from "./Back";
6
+
7
+ enum ICON {
8
+ checkmark = "checkmark",
9
+ back = "back",
10
+ }
11
+
12
+ interface Props {
13
+ name: ICON;
14
+ className?: string;
15
+ }
16
+
17
+ const iconsMap = new Map<ICON, AnyComponent>([
18
+ [ICON.checkmark, Checkmark],
19
+ [ICON.back, Back],
20
+ ]);
21
+
22
+ const Icon: React.FC<Props> = ({ name: iconName, ...props }) => {
23
+ const C = iconsMap.get(iconName);
24
+ if (!C) {
25
+ throw new TypeError("Unknown icon: " + iconName);
26
+ }
27
+ return <C {...props} />;
28
+ };
29
+
30
+ export { Icon, ICON };
@@ -0,0 +1,89 @@
1
+ .header {
2
+ --border-color: var(--header-border);
3
+ --background-color: var(--header-bg);
4
+ background: var(--background-color);
5
+ display: flex;
6
+ align-items: center;
7
+ font-size: 15px;
8
+ font-weight: bold;
9
+ box-sizing: border-box;
10
+ color: var(--header-text);
11
+ }
12
+
13
+ .header--toolbar {
14
+ --border-color: var(--toolbar-border);
15
+ --background-color: var(--toolbar-bg);
16
+ }
17
+
18
+ .header--top, .header--bottom {
19
+ padding: 0 16.666px;
20
+ min-height: 44px;
21
+ }
22
+ .header--left, .header--right {
23
+ padding: 16.666px 0;
24
+ min-width: 44px;
25
+ flex-direction: column;
26
+
27
+ > .contents {
28
+ flex-direction: column;
29
+ align-items: center;
30
+ }
31
+ }
32
+
33
+ .header--top {
34
+ border-bottom: 0.37px solid var(--border-color);
35
+ }
36
+ .header--bottom {
37
+ border-top: 0.37px solid var(--border-color);
38
+ order: 2;
39
+ }
40
+ .header--left {
41
+ border-right: 0.37px solid var(--border-color);
42
+ }
43
+ .header--right {
44
+ border-left: 0.37px solid var(--border-color);
45
+ order: 2;
46
+ }
47
+
48
+ .contents {
49
+ flex: 1;
50
+ display: flex;
51
+ }
52
+
53
+ .header--center > .contents {
54
+ justify-content: center;
55
+ }
56
+
57
+ .header--top, .header--bottom {
58
+ .before {
59
+ margin-right: calc(50px / var(--ratio-dimensions));
60
+ }
61
+
62
+ .after {
63
+ margin-left: calc(50px / var(--ratio-dimensions));
64
+ }
65
+
66
+ .actions {
67
+ margin: calc(56px / var(--ratio-dimensions)) 0;
68
+ }
69
+ }
70
+
71
+ .header--left, .header--right {
72
+ .before {
73
+ margin-bottom: calc(50px / var(--ratio-dimensions));
74
+ flex-direction: column;
75
+ }
76
+
77
+ .after {
78
+ margin-top: calc(50px / var(--ratio-dimensions));
79
+ flex-direction: column;
80
+ }
81
+
82
+ .actions {
83
+ margin: 0 calc(56px / var(--ratio-dimensions));
84
+ }
85
+ }
86
+
87
+ .before, .after {
88
+ display: flex;
89
+ }
@@ -0,0 +1,65 @@
1
+ import React from "react";
2
+ import classnames from "classnames";
3
+ import type { ReactNode } from "react";
4
+
5
+ import styles from "./Header.module.scss";
6
+ import { Action } from "../../ui/action/Action";
7
+ import { EqualActions } from "../../ui/action/EqualActions";
8
+
9
+ interface Props {
10
+ center?: boolean;
11
+ variant?: "toolbar";
12
+ /**
13
+ * This indicates just how the borders are drawn and how content is aligned, not the actual position on the screen.
14
+ * To set up position on the screen you need to properly style parent element.
15
+ */
16
+ position?: "top" | "left" | "right" | "bottom"; // @TODO disallow left/right if not inside StickyHeader?
17
+ className?: string;
18
+ before?: ReactNode;
19
+ after?: ReactNode;
20
+ }
21
+
22
+ // eslint-disable-next-line max-statements
23
+ const Header: React.FC<Props> = (props) => {
24
+ const { center, children, variant, position = "top" } = props;
25
+
26
+ let justActions = false;
27
+ if (position === "top" || position === "bottom") {
28
+ const chld = React.Children.toArray(props.children);
29
+ justActions = chld.every(c => {
30
+ return c && typeof c === "object" && "type" in c && c.type === Action;
31
+ });
32
+ }
33
+
34
+ const cls = classnames(styles.header, {
35
+ [styles["header--center"]]: center,
36
+ [styles["header--toolbar"]]: variant === "toolbar",
37
+ }, styles[`header--${position}`], props.className);
38
+
39
+ let contents = children;
40
+ if (justActions) {
41
+ contents = <EqualActions className={styles.actions}>{contents}</EqualActions>;
42
+ }
43
+
44
+ let before: ReactNode;
45
+ if (props.before != null) {
46
+ before = <div className={styles.before}>{props.before}</div>;
47
+ }
48
+
49
+ let after: ReactNode;
50
+ if (props.after != null) {
51
+ after = <div className={styles.after}>{props.after}</div>;
52
+ }
53
+
54
+ return (
55
+ <div className={cls}>
56
+ {before}
57
+ <div className={styles.contents}>
58
+ {contents}
59
+ </div>
60
+ {after}
61
+ </div>
62
+ );
63
+ };
64
+
65
+ export { Header };
@@ -0,0 +1,22 @@
1
+ .btn, .a {
2
+ padding: 7px;
3
+ background: none;
4
+ border-radius: 666px;
5
+ display: inline-block;
6
+ border: calc(2px / var(--ratio-border)) solid transparent;
7
+ color: var(--header-text);
8
+
9
+ &:hover {
10
+ background: #00000022;
11
+ }
12
+ &:active {
13
+ background: #00000011;
14
+ color: currentColor;
15
+ }
16
+ }
17
+
18
+ .icon {
19
+ width: 16px;
20
+ height: 16px;
21
+ display: block;
22
+ }
@@ -0,0 +1,49 @@
1
+ import React from "react";
2
+ import type { ReactNode } from "react";
3
+
4
+ import type { ICON } from "../../icons/Icon";
5
+ import { Icon } from "../../icons/Icon";
6
+ import styles from "./HeaderIconAction.module.scss";
7
+
8
+ interface LinkProps { // @TODO extract? - same on list item
9
+ href: string;
10
+ }
11
+
12
+ interface Props {
13
+ icon?: ICON | Exclude<ReactNode, string>;
14
+ onClick?: () => void;
15
+ href?: string;
16
+ to?: string;
17
+ Link?: React.ComponentClass<LinkProps> | React.FC<LinkProps>;
18
+ label?: ReactNode;
19
+ // if className ever goes here make sure that `a` gets classnames merged
20
+ }
21
+
22
+ const HeaderIconAction: React.VFC<Props> = (props) => {
23
+ const { icon, label, href, to, Link, ...restProps } = props;
24
+
25
+ let content: ReactNode = icon;
26
+ if (typeof icon === "string") {
27
+ content = <Icon className={styles.icon} name={icon as ICON} />;
28
+ }
29
+
30
+ if (to) {
31
+ if (!Link) {
32
+ throw new TypeError("`to` prop given without `Link` component");
33
+ }
34
+
35
+ return <Link href={to} {...restProps}><a className={styles.a}>{content}</a></Link>;
36
+ }
37
+
38
+ if (href) {
39
+ return <a href={href} className={styles.a} {...restProps}>{content}</a>;
40
+ }
41
+
42
+ return (
43
+ <button className={styles.btn} onClick={props.onClick}>
44
+ {content}
45
+ </button>
46
+ );
47
+ };
48
+
49
+ export { HeaderIconAction };
@@ -0,0 +1,18 @@
1
+ .stickyHeader {
2
+ height: 100%;
3
+ display: flex;
4
+ flex-direction: column;
5
+
6
+ &__content {
7
+ flex: 1;
8
+ overflow: auto;
9
+
10
+ &--bottom, &--right {
11
+ order: 1;
12
+ }
13
+ }
14
+ }
15
+
16
+ .stickyHeader--left, .stickyHeader--right {
17
+ flex-direction: row;
18
+ }