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.
- package/CHANGELOG.md +46 -0
- package/README.md +10 -1
- package/assets/back.svg +1 -0
- package/dist/components/form/Checkbox.module.scss +13 -6
- package/dist/components/form/Toggle.d.ts +8 -0
- package/dist/components/form/Toggle.d.ts.map +1 -0
- package/dist/components/form/Toggle.js +40 -0
- package/dist/components/form/Toggle.js.map +1 -0
- package/dist/components/form/Toggle.module.scss +46 -0
- package/dist/components/icons/Back.d.ts +7 -0
- package/dist/components/icons/Back.d.ts.map +1 -0
- package/dist/components/icons/Back.js +13 -0
- package/dist/components/icons/Back.js.map +1 -0
- package/dist/components/icons/Checkmark.d.ts.map +1 -1
- package/dist/components/icons/Checkmark.js.map +1 -1
- package/dist/components/icons/Icon.d.ts +12 -0
- package/dist/components/icons/Icon.d.ts.map +1 -0
- package/dist/components/icons/Icon.js +40 -0
- package/dist/components/icons/Icon.js.map +1 -0
- package/dist/components/layout/header/Header.d.ts +13 -0
- package/dist/components/layout/header/Header.d.ts.map +1 -0
- package/dist/components/layout/header/Header.js +43 -0
- package/dist/components/layout/header/Header.js.map +1 -0
- package/dist/components/layout/header/Header.module.scss +89 -0
- package/dist/components/layout/header/HeaderIconAction.d.ts +17 -0
- package/dist/components/layout/header/HeaderIconAction.d.ts.map +1 -0
- package/dist/components/layout/header/HeaderIconAction.js +40 -0
- package/dist/components/layout/header/HeaderIconAction.js.map +1 -0
- package/dist/components/layout/header/HeaderIconAction.module.scss +22 -0
- package/dist/components/layout/header/StickyHeader.d.ts +10 -0
- package/dist/components/layout/header/StickyHeader.d.ts.map +1 -0
- package/dist/components/layout/header/StickyHeader.js +34 -0
- package/dist/components/layout/header/StickyHeader.js.map +1 -0
- package/dist/components/layout/header/StickyHeader.module.scss +18 -0
- package/dist/components/layout/list/Item.d.ts +14 -0
- package/dist/components/layout/list/Item.d.ts.map +1 -0
- package/dist/components/layout/list/Item.js +50 -0
- package/dist/components/layout/list/Item.js.map +1 -0
- package/dist/components/layout/list/Item.module.scss +23 -0
- package/dist/components/layout/list/List.d.ts +4 -0
- package/dist/components/layout/list/List.d.ts.map +1 -0
- package/dist/components/layout/list/List.js +13 -0
- package/dist/components/layout/list/List.js.map +1 -0
- package/dist/components/layout/list/List.module.scss +4 -0
- package/dist/components/ui/action/Action.d.ts +17 -0
- package/dist/components/ui/action/Action.d.ts.map +1 -0
- package/dist/components/ui/action/Action.js +44 -0
- package/dist/components/ui/action/Action.js.map +1 -0
- package/dist/components/ui/action/Action.module.scss +26 -0
- package/dist/components/ui/action/EqualActions.d.ts +7 -0
- package/dist/components/ui/action/EqualActions.d.ts.map +1 -0
- package/dist/components/ui/action/EqualActions.js +23 -0
- package/dist/components/ui/action/EqualActions.js.map +1 -0
- package/dist/components/ui/action/EqualActions.module.scss +6 -0
- package/dist/components/ui/button/Button.d.ts +8 -0
- package/dist/components/ui/button/Button.d.ts.map +1 -0
- package/dist/components/ui/button/Button.js +20 -0
- package/dist/components/ui/button/Button.js.map +1 -0
- package/dist/components/ui/button/Button.module.scss +25 -0
- package/dist/components/ui/directionPad/Button.d.ts +7 -0
- package/dist/components/ui/directionPad/Button.d.ts.map +1 -0
- package/dist/components/ui/directionPad/Button.js +14 -0
- package/dist/components/ui/directionPad/Button.js.map +1 -0
- package/dist/components/ui/directionPad/Middle.d.ts +8 -0
- package/dist/components/ui/directionPad/Middle.d.ts.map +1 -0
- package/dist/components/ui/directionPad/Middle.js +13 -0
- package/dist/components/ui/directionPad/Middle.js.map +1 -0
- package/dist/components/ui/directionPad/Pad.d.ts +12 -0
- package/dist/components/ui/directionPad/Pad.d.ts.map +1 -0
- package/dist/components/ui/directionPad/Pad.js +23 -0
- package/dist/components/ui/directionPad/Pad.js.map +1 -0
- package/dist/components/ui/directionPad/Pad.module.scss +45 -0
- package/dist/demo/Demo.d.ts.map +1 -1
- package/dist/demo/Demo.js +2 -1
- package/dist/demo/Demo.js.map +1 -1
- package/dist/demo/Main.d.ts.map +1 -1
- package/dist/demo/Main.js +36 -8
- package/dist/demo/Main.js.map +1 -1
- package/dist/demo/Main.module.scss +13 -0
- package/dist/demo/Menu.d.ts +6 -1
- package/dist/demo/Menu.d.ts.map +1 -1
- package/dist/demo/Menu.js +20 -4
- package/dist/demo/Menu.js.map +1 -1
- package/dist/demo/Menu.module.scss +30 -8
- package/dist/demo/components/form/Checkbox.d.ts.map +1 -1
- package/dist/demo/components/form/Checkbox.js +3 -2
- package/dist/demo/components/form/Checkbox.js.map +1 -1
- package/dist/demo/components/form/Toggle.d.ts +4 -0
- package/dist/demo/components/form/Toggle.d.ts.map +1 -0
- package/dist/demo/components/form/Toggle.js +65 -0
- package/dist/demo/components/form/Toggle.js.map +1 -0
- package/dist/demo/components/form/Toggle.module.scss +5 -0
- package/dist/demo/components/layout/header/Header.d.ts +8 -0
- package/dist/demo/components/layout/header/Header.d.ts.map +1 -0
- package/dist/demo/components/layout/header/Header.js +60 -0
- package/dist/demo/components/layout/header/Header.js.map +1 -0
- package/dist/demo/components/layout/header/StickyHeader.d.ts +9 -0
- package/dist/demo/components/layout/header/StickyHeader.d.ts.map +1 -0
- package/dist/demo/components/layout/header/StickyHeader.js +73 -0
- package/dist/demo/components/layout/header/StickyHeader.js.map +1 -0
- package/dist/demo/components/layout/list/List.Item.d.ts +4 -0
- package/dist/demo/components/layout/list/List.Item.d.ts.map +1 -0
- package/dist/demo/components/layout/list/List.Item.js +42 -0
- package/dist/demo/components/layout/list/List.Item.js.map +1 -0
- package/dist/demo/components/layout/list/List.Item.module.scss +3 -0
- package/dist/demo/components/ui/action/Action.d.ts +8 -0
- package/dist/demo/components/ui/action/Action.d.ts.map +1 -0
- package/dist/demo/components/ui/action/Action.js +83 -0
- package/dist/demo/components/ui/action/Action.js.map +1 -0
- package/dist/demo/components/ui/action/ActionDemo.module.scss +3 -0
- package/dist/demo/components/ui/button/ButtonDemo.d.ts +4 -0
- package/dist/demo/components/ui/button/ButtonDemo.d.ts.map +1 -0
- package/dist/demo/components/ui/button/ButtonDemo.js +20 -0
- package/dist/demo/components/ui/button/ButtonDemo.js.map +1 -0
- package/dist/demo/components/ui/directionPad/Pad.d.ts +4 -0
- package/dist/demo/components/ui/directionPad/Pad.d.ts.map +1 -0
- package/dist/demo/components/ui/directionPad/Pad.js +49 -0
- package/dist/demo/components/ui/directionPad/Pad.js.map +1 -0
- package/dist/demo/components/ui/icons/Icons.d.ts +4 -0
- package/dist/demo/components/ui/icons/Icons.d.ts.map +1 -0
- package/dist/demo/components/ui/icons/Icons.js +20 -0
- package/dist/demo/components/ui/icons/Icons.js.map +1 -0
- package/dist/demo/components/ui/icons/Icons.module.scss +4 -0
- package/dist/demo/componentsMap.d.ts +13 -0
- package/dist/demo/componentsMap.d.ts.map +1 -0
- package/dist/demo/componentsMap.js +112 -0
- package/dist/demo/componentsMap.js.map +1 -0
- package/dist/demo/utils/makeVariants.d.ts +3 -0
- package/dist/demo/utils/makeVariants.d.ts.map +1 -0
- package/dist/demo/utils/makeVariants.js +14 -0
- package/dist/demo/utils/makeVariants.js.map +1 -0
- package/dist/global.scss +34 -13
- package/dist/index.d.ts +8 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +8 -1
- package/dist/index.js.map +1 -1
- package/dist/pages/_app.d.ts.map +1 -1
- package/dist/pages/_app.js +5 -1
- package/dist/pages/_app.js.map +1 -1
- package/dist/pages/react-miui.d.ts +4 -0
- package/dist/pages/react-miui.d.ts.map +1 -0
- package/dist/pages/react-miui.js +11 -0
- package/dist/pages/react-miui.js.map +1 -0
- package/dist/types.d.ts +4 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +3 -0
- package/dist/types.js.map +1 -0
- package/docs/assets/js/search.js +1 -1
- package/docs/assets/js/search.json +1 -1
- package/docs/enums/ICON.html +182 -0
- package/docs/index.html +38 -5
- package/docs/modules/StickyHeader.html +159 -0
- package/docs/modules.html +121 -5
- package/docs/pages/Tutorials/Test.html +6 -3
- package/esm/components/form/Checkbox.module.scss +13 -6
- package/esm/components/form/Toggle.d.ts +8 -0
- package/esm/components/form/Toggle.d.ts.map +1 -0
- package/esm/components/form/Toggle.js +15 -0
- package/esm/components/form/Toggle.js.map +1 -0
- package/esm/components/form/Toggle.module.scss +46 -0
- package/esm/components/icons/Back.d.ts +7 -0
- package/esm/components/icons/Back.d.ts.map +1 -0
- package/esm/components/icons/Back.js +7 -0
- package/esm/components/icons/Back.js.map +1 -0
- package/esm/components/icons/Checkmark.d.ts.map +1 -1
- package/esm/components/icons/Checkmark.js.map +1 -1
- package/esm/components/icons/Icon.d.ts +12 -0
- package/esm/components/icons/Icon.d.ts.map +1 -0
- package/esm/components/icons/Icon.js +21 -0
- package/esm/components/icons/Icon.js.map +1 -0
- package/esm/components/layout/header/Header.d.ts +13 -0
- package/esm/components/layout/header/Header.d.ts.map +1 -0
- package/esm/components/layout/header/Header.js +37 -0
- package/esm/components/layout/header/Header.js.map +1 -0
- package/esm/components/layout/header/Header.module.scss +89 -0
- package/esm/components/layout/header/HeaderIconAction.d.ts +17 -0
- package/esm/components/layout/header/HeaderIconAction.d.ts.map +1 -0
- package/esm/components/layout/header/HeaderIconAction.js +23 -0
- package/esm/components/layout/header/HeaderIconAction.js.map +1 -0
- package/esm/components/layout/header/HeaderIconAction.module.scss +22 -0
- package/esm/components/layout/header/StickyHeader.d.ts +10 -0
- package/esm/components/layout/header/StickyHeader.d.ts.map +1 -0
- package/esm/components/layout/header/StickyHeader.js +28 -0
- package/esm/components/layout/header/StickyHeader.js.map +1 -0
- package/esm/components/layout/header/StickyHeader.module.scss +18 -0
- package/esm/components/layout/list/Item.d.ts +14 -0
- package/esm/components/layout/list/Item.d.ts.map +1 -0
- package/esm/components/layout/list/Item.js +33 -0
- package/esm/components/layout/list/Item.js.map +1 -0
- package/esm/components/layout/list/Item.module.scss +23 -0
- package/esm/components/layout/list/List.d.ts +4 -0
- package/esm/components/layout/list/List.d.ts.map +1 -0
- package/esm/components/layout/list/List.js +7 -0
- package/esm/components/layout/list/List.js.map +1 -0
- package/esm/components/layout/list/List.module.scss +4 -0
- package/esm/components/ui/action/Action.d.ts +17 -0
- package/esm/components/ui/action/Action.d.ts.map +1 -0
- package/esm/components/ui/action/Action.js +27 -0
- package/esm/components/ui/action/Action.js.map +1 -0
- package/esm/components/ui/action/Action.module.scss +26 -0
- package/esm/components/ui/action/EqualActions.d.ts +7 -0
- package/esm/components/ui/action/EqualActions.d.ts.map +1 -0
- package/esm/components/ui/action/EqualActions.js +17 -0
- package/esm/components/ui/action/EqualActions.js.map +1 -0
- package/esm/components/ui/action/EqualActions.module.scss +6 -0
- package/esm/components/ui/button/Button.d.ts +8 -0
- package/esm/components/ui/button/Button.d.ts.map +1 -0
- package/esm/components/ui/button/Button.js +14 -0
- package/esm/components/ui/button/Button.js.map +1 -0
- package/esm/components/ui/button/Button.module.scss +25 -0
- package/esm/components/ui/directionPad/Button.d.ts +7 -0
- package/esm/components/ui/directionPad/Button.d.ts.map +1 -0
- package/esm/components/ui/directionPad/Button.js +8 -0
- package/esm/components/ui/directionPad/Button.js.map +1 -0
- package/esm/components/ui/directionPad/Middle.d.ts +8 -0
- package/esm/components/ui/directionPad/Middle.d.ts.map +1 -0
- package/esm/components/ui/directionPad/Middle.js +7 -0
- package/esm/components/ui/directionPad/Middle.js.map +1 -0
- package/esm/components/ui/directionPad/Pad.d.ts +12 -0
- package/esm/components/ui/directionPad/Pad.d.ts.map +1 -0
- package/esm/components/ui/directionPad/Pad.js +17 -0
- package/esm/components/ui/directionPad/Pad.js.map +1 -0
- package/esm/components/ui/directionPad/Pad.module.scss +45 -0
- package/esm/demo/Demo.d.ts.map +1 -1
- package/esm/demo/Demo.js +2 -1
- package/esm/demo/Demo.js.map +1 -1
- package/esm/demo/Main.d.ts.map +1 -1
- package/esm/demo/Main.js +37 -9
- package/esm/demo/Main.js.map +1 -1
- package/esm/demo/Main.module.scss +13 -0
- package/esm/demo/Menu.d.ts +6 -1
- package/esm/demo/Menu.d.ts.map +1 -1
- package/esm/demo/Menu.js +20 -4
- package/esm/demo/Menu.js.map +1 -1
- package/esm/demo/Menu.module.scss +30 -8
- package/esm/demo/components/form/Checkbox.d.ts.map +1 -1
- package/esm/demo/components/form/Checkbox.js +4 -3
- package/esm/demo/components/form/Checkbox.js.map +1 -1
- package/esm/demo/components/form/Toggle.d.ts +4 -0
- package/esm/demo/components/form/Toggle.d.ts.map +1 -0
- package/esm/demo/components/form/Toggle.js +40 -0
- package/esm/demo/components/form/Toggle.js.map +1 -0
- package/esm/demo/components/form/Toggle.module.scss +5 -0
- package/esm/demo/components/layout/header/Header.d.ts +8 -0
- package/esm/demo/components/layout/header/Header.d.ts.map +1 -0
- package/esm/demo/components/layout/header/Header.js +50 -0
- package/esm/demo/components/layout/header/Header.js.map +1 -0
- package/esm/demo/components/layout/header/StickyHeader.d.ts +9 -0
- package/esm/demo/components/layout/header/StickyHeader.d.ts.map +1 -0
- package/esm/demo/components/layout/header/StickyHeader.js +62 -0
- package/esm/demo/components/layout/header/StickyHeader.js.map +1 -0
- package/esm/demo/components/layout/list/List.Item.d.ts +4 -0
- package/esm/demo/components/layout/list/List.Item.d.ts.map +1 -0
- package/esm/demo/components/layout/list/List.Item.js +17 -0
- package/esm/demo/components/layout/list/List.Item.js.map +1 -0
- package/esm/demo/components/layout/list/List.Item.module.scss +3 -0
- package/esm/demo/components/ui/action/Action.d.ts +8 -0
- package/esm/demo/components/ui/action/Action.d.ts.map +1 -0
- package/esm/demo/components/ui/action/Action.js +73 -0
- package/esm/demo/components/ui/action/Action.js.map +1 -0
- package/esm/demo/components/ui/action/ActionDemo.module.scss +3 -0
- package/esm/demo/components/ui/button/ButtonDemo.d.ts +4 -0
- package/esm/demo/components/ui/button/ButtonDemo.d.ts.map +1 -0
- package/esm/demo/components/ui/button/ButtonDemo.js +14 -0
- package/esm/demo/components/ui/button/ButtonDemo.js.map +1 -0
- package/esm/demo/components/ui/directionPad/Pad.d.ts +4 -0
- package/esm/demo/components/ui/directionPad/Pad.d.ts.map +1 -0
- package/esm/demo/components/ui/directionPad/Pad.js +27 -0
- package/esm/demo/components/ui/directionPad/Pad.js.map +1 -0
- package/esm/demo/components/ui/icons/Icons.d.ts +4 -0
- package/esm/demo/components/ui/icons/Icons.d.ts.map +1 -0
- package/esm/demo/components/ui/icons/Icons.js +14 -0
- package/esm/demo/components/ui/icons/Icons.js.map +1 -0
- package/esm/demo/components/ui/icons/Icons.module.scss +4 -0
- package/esm/demo/componentsMap.d.ts +13 -0
- package/esm/demo/componentsMap.d.ts.map +1 -0
- package/esm/demo/componentsMap.js +109 -0
- package/esm/demo/componentsMap.js.map +1 -0
- package/esm/demo/utils/makeVariants.d.ts +3 -0
- package/esm/demo/utils/makeVariants.d.ts.map +1 -0
- package/esm/demo/utils/makeVariants.js +11 -0
- package/esm/demo/utils/makeVariants.js.map +1 -0
- package/esm/global.scss +34 -13
- package/esm/index.d.ts +8 -1
- package/esm/index.d.ts.map +1 -1
- package/esm/index.js +8 -1
- package/esm/index.js.map +1 -1
- package/esm/pages/_app.d.ts.map +1 -1
- package/esm/pages/_app.js +5 -1
- package/esm/pages/_app.js.map +1 -1
- package/esm/pages/react-miui.d.ts +4 -0
- package/esm/pages/react-miui.d.ts.map +1 -0
- package/esm/pages/react-miui.js +6 -0
- package/esm/pages/react-miui.js.map +1 -0
- package/esm/types.d.ts +4 -0
- package/esm/types.d.ts.map +1 -0
- package/esm/types.js +2 -0
- package/esm/types.js.map +1 -0
- package/package.json +9 -7
- package/src/components/form/Checkbox.module.scss +13 -6
- package/src/components/form/Toggle.module.scss +46 -0
- package/src/components/form/Toggle.tsx +33 -0
- package/src/components/icons/Back.tsx +15 -0
- package/src/components/icons/Checkmark.tsx +5 -2
- package/src/components/icons/Icon.tsx +30 -0
- package/src/components/layout/header/Header.module.scss +89 -0
- package/src/components/layout/header/Header.tsx +65 -0
- package/src/components/layout/header/HeaderIconAction.module.scss +22 -0
- package/src/components/layout/header/HeaderIconAction.tsx +49 -0
- package/src/components/layout/header/StickyHeader.module.scss +18 -0
- package/src/components/layout/header/StickyHeader.tsx +54 -0
- package/src/components/layout/list/Item.module.scss +23 -0
- package/src/components/layout/list/Item.tsx +50 -0
- package/src/components/layout/list/List.module.scss +4 -0
- package/src/components/layout/list/List.tsx +11 -0
- package/src/components/ui/action/Action.module.scss +26 -0
- package/src/components/ui/action/Action.tsx +58 -0
- package/src/components/ui/action/EqualActions.module.scss +6 -0
- package/src/components/ui/action/EqualActions.tsx +30 -0
- package/src/components/ui/button/Button.module.scss +25 -0
- package/src/components/ui/button/Button.tsx +25 -0
- package/src/components/ui/directionPad/Button.tsx +15 -0
- package/src/components/ui/directionPad/Middle.tsx +16 -0
- package/src/components/ui/directionPad/Pad.module.scss +45 -0
- package/src/components/ui/directionPad/Pad.tsx +35 -0
- package/src/demo/Demo.tsx +2 -1
- package/src/demo/Main.module.scss +13 -0
- package/src/demo/Main.tsx +53 -10
- package/src/demo/Menu.module.scss +30 -8
- package/src/demo/Menu.tsx +33 -7
- package/src/demo/components/form/Checkbox.tsx +7 -3
- package/src/demo/components/form/Toggle.module.scss +5 -0
- package/src/demo/components/form/Toggle.tsx +59 -0
- package/src/demo/components/layout/header/Header.tsx +119 -0
- package/src/demo/components/layout/header/StickyHeader.tsx +85 -0
- package/src/demo/components/layout/list/List.Item.module.scss +3 -0
- package/src/demo/components/layout/list/List.Item.tsx +23 -0
- package/src/demo/components/ui/action/Action.tsx +112 -0
- package/src/demo/components/ui/action/ActionDemo.module.scss +3 -0
- package/src/demo/components/ui/button/ButtonDemo.tsx +18 -0
- package/src/demo/components/ui/directionPad/Pad.tsx +40 -0
- package/src/demo/components/ui/icons/Icons.module.scss +4 -0
- package/src/demo/components/ui/icons/Icons.tsx +25 -0
- package/src/demo/componentsMap.ts +144 -0
- package/src/demo/utils/makeVariants.ts +13 -0
- package/src/global.scss +34 -13
- package/src/index.ts +11 -1
- package/src/pages/_app.tsx +7 -1
- package/src/pages/react-miui.tsx +12 -0
- package/src/types.ts +7 -0
- package/.postcssrc +0 -9
- 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
|
|
22
|
-
--toolbar
|
|
24
|
+
--toolbar-border: #ababab;
|
|
25
|
+
--toolbar-bg: #f8f8f8;
|
|
23
26
|
|
|
24
|
-
|
|
25
|
-
--
|
|
26
|
-
--
|
|
27
|
-
--
|
|
28
|
-
--
|
|
29
|
-
--
|
|
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 {
|
|
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
|
package/esm/index.d.ts.map
CHANGED
|
@@ -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"}
|
package/esm/pages/_app.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"_app.d.ts","sourceRoot":"","sources":["../../src/pages/_app.tsx"],"names":[],"mappings":";
|
|
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(
|
|
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
|
package/esm/pages/_app.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"_app.js","sourceRoot":"","sources":["../../src/pages/_app.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
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
package/esm/types.js.map
ADDED
|
@@ -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
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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:
|
|
11
|
-
height:
|
|
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:
|
|
18
|
-
height:
|
|
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:
|
|
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"
|
|
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
|
+
}
|