@mw-kit/mw-ui 0.3.4 → 1.0.3
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/.eslintignore +28 -0
- package/.eslintrc.js +35 -0
- package/.prettierignore +27 -0
- package/.prettierrc.json +10 -0
- package/.storybook/main.js +13 -0
- package/.storybook/preview.js +21 -0
- package/.travis.yml +4 -0
- package/.vscode/settings.json +3 -0
- package/README.md +46 -40
- package/bitbucket-pipelines.yml +69 -0
- package/docker-compose.yml +14 -0
- package/example/README.md +5 -0
- package/example/favicon.ico +0 -0
- package/example/index.html +46 -0
- package/example/manifest.json +15 -0
- package/example/package.json +43 -0
- package/example/public/favicon.ico +0 -0
- package/example/public/index.html +46 -0
- package/example/public/manifest.json +15 -0
- package/example/src/App.tsx +47 -0
- package/example/src/index.tsx +11 -0
- package/example/src/react-app-env.d.ts +1 -0
- package/example/src/setupTests.ts +5 -0
- package/example/tsconfig.json +30 -0
- package/example/yarn.lock +694 -0
- package/exec.sh +11 -0
- package/hooks/pre-push +3 -0
- package/package.json +102 -69
- package/public/favicon.ico +0 -0
- package/public/index.html +43 -0
- package/public/logo192.png +0 -0
- package/public/logo512.png +0 -0
- package/public/manifest.json +25 -0
- package/public/robots.txt +3 -0
- package/shell/autotag.sh +169 -0
- package/shell/bash.sh +3 -0
- package/shell/install.sh +9 -0
- package/shell/logs.sh +3 -0
- package/shell/npx.sh +3 -0
- package/shell/restart.sh +5 -0
- package/shell/start.sh +7 -0
- package/shell/stop.sh +3 -0
- package/shell/tags.sh +24 -0
- package/shell/yarn.sh +7 -0
- package/src/addons/Portal/index.ts +26 -0
- package/src/addons/Portal/interfaces.ts +5 -0
- package/src/assets/icons/close.svg +1 -0
- package/src/assets/icons/feather/activity.svg +1 -0
- package/src/assets/icons/feather/airplay.svg +1 -0
- package/src/assets/icons/feather/alert-circle.svg +1 -0
- package/src/assets/icons/feather/alert-octagon.svg +1 -0
- package/src/assets/icons/feather/alert-triangle.svg +1 -0
- package/src/assets/icons/feather/align-center.svg +1 -0
- package/src/assets/icons/feather/align-justify.svg +1 -0
- package/src/assets/icons/feather/align-left.svg +1 -0
- package/src/assets/icons/feather/align-right.svg +1 -0
- package/src/assets/icons/feather/anchor.svg +1 -0
- package/src/assets/icons/feather/aperture.svg +1 -0
- package/src/assets/icons/feather/archive.svg +1 -0
- package/src/assets/icons/feather/arrow-down-circle.svg +1 -0
- package/src/assets/icons/feather/arrow-down-left.svg +1 -0
- package/src/assets/icons/feather/arrow-down-right.svg +1 -0
- package/src/assets/icons/feather/arrow-down.svg +1 -0
- package/src/assets/icons/feather/arrow-left-circle.svg +1 -0
- package/src/assets/icons/feather/arrow-left.svg +1 -0
- package/src/assets/icons/feather/arrow-right-circle.svg +1 -0
- package/src/assets/icons/feather/arrow-right.svg +1 -0
- package/src/assets/icons/feather/arrow-up-circle.svg +1 -0
- package/src/assets/icons/feather/arrow-up-left.svg +1 -0
- package/src/assets/icons/feather/arrow-up-right.svg +1 -0
- package/src/assets/icons/feather/arrow-up.svg +1 -0
- package/src/assets/icons/feather/at-sign.svg +1 -0
- package/src/assets/icons/feather/award.svg +1 -0
- package/src/assets/icons/feather/bar-chart-2.svg +1 -0
- package/src/assets/icons/feather/bar-chart.svg +1 -0
- package/src/assets/icons/feather/battery-charging.svg +1 -0
- package/src/assets/icons/feather/battery.svg +1 -0
- package/src/assets/icons/feather/bell-off.svg +1 -0
- package/src/assets/icons/feather/bell.svg +1 -0
- package/src/assets/icons/feather/bluetooth.svg +1 -0
- package/src/assets/icons/feather/bold.svg +1 -0
- package/src/assets/icons/feather/book-open.svg +1 -0
- package/src/assets/icons/feather/book.svg +1 -0
- package/src/assets/icons/feather/bookmark.svg +1 -0
- package/src/assets/icons/feather/box.svg +1 -0
- package/src/assets/icons/feather/briefcase.svg +1 -0
- package/src/assets/icons/feather/calendar.svg +1 -0
- package/src/assets/icons/feather/camera-off.svg +1 -0
- package/src/assets/icons/feather/camera.svg +1 -0
- package/src/assets/icons/feather/cast.svg +1 -0
- package/src/assets/icons/feather/check-circle.svg +1 -0
- package/src/assets/icons/feather/check-square.svg +1 -0
- package/src/assets/icons/feather/check.svg +1 -0
- package/src/assets/icons/feather/chevron-down.svg +1 -0
- package/src/assets/icons/feather/chevron-left.svg +1 -0
- package/src/assets/icons/feather/chevron-right.svg +1 -0
- package/src/assets/icons/feather/chevron-up.svg +1 -0
- package/src/assets/icons/feather/chevrons-down.svg +1 -0
- package/src/assets/icons/feather/chevrons-left.svg +1 -0
- package/src/assets/icons/feather/chevrons-right.svg +1 -0
- package/src/assets/icons/feather/chevrons-up.svg +1 -0
- package/src/assets/icons/feather/chrome.svg +1 -0
- package/src/assets/icons/feather/circle.svg +1 -0
- package/src/assets/icons/feather/clipboard.svg +1 -0
- package/src/assets/icons/feather/clock.svg +1 -0
- package/src/assets/icons/feather/cloud-drizzle.svg +1 -0
- package/src/assets/icons/feather/cloud-lightning.svg +1 -0
- package/src/assets/icons/feather/cloud-off.svg +1 -0
- package/src/assets/icons/feather/cloud-rain.svg +1 -0
- package/src/assets/icons/feather/cloud-snow.svg +1 -0
- package/src/assets/icons/feather/cloud.svg +1 -0
- package/src/assets/icons/feather/code.svg +1 -0
- package/src/assets/icons/feather/codepen.svg +1 -0
- package/src/assets/icons/feather/codesandbox.svg +1 -0
- package/src/assets/icons/feather/coffee.svg +1 -0
- package/src/assets/icons/feather/columns.svg +1 -0
- package/src/assets/icons/feather/command.svg +1 -0
- package/src/assets/icons/feather/compass.svg +1 -0
- package/src/assets/icons/feather/copy.svg +1 -0
- package/src/assets/icons/feather/corner-down-left.svg +1 -0
- package/src/assets/icons/feather/corner-down-right.svg +1 -0
- package/src/assets/icons/feather/corner-left-down.svg +1 -0
- package/src/assets/icons/feather/corner-left-up.svg +1 -0
- package/src/assets/icons/feather/corner-right-down.svg +1 -0
- package/src/assets/icons/feather/corner-right-up.svg +1 -0
- package/src/assets/icons/feather/corner-up-left.svg +1 -0
- package/src/assets/icons/feather/corner-up-right.svg +1 -0
- package/src/assets/icons/feather/cpu.svg +1 -0
- package/src/assets/icons/feather/credit-card.svg +1 -0
- package/src/assets/icons/feather/crop.svg +1 -0
- package/src/assets/icons/feather/crosshair.svg +1 -0
- package/src/assets/icons/feather/database.svg +1 -0
- package/src/assets/icons/feather/delete.svg +1 -0
- package/src/assets/icons/feather/disc.svg +1 -0
- package/src/assets/icons/feather/divide-circle.svg +1 -0
- package/src/assets/icons/feather/divide-square.svg +1 -0
- package/src/assets/icons/feather/divide.svg +1 -0
- package/src/assets/icons/feather/dollar-sign.svg +1 -0
- package/src/assets/icons/feather/download-cloud.svg +1 -0
- package/src/assets/icons/feather/download.svg +1 -0
- package/src/assets/icons/feather/dribbble.svg +1 -0
- package/src/assets/icons/feather/droplet.svg +1 -0
- package/src/assets/icons/feather/edit-2.svg +1 -0
- package/src/assets/icons/feather/edit-3.svg +1 -0
- package/src/assets/icons/feather/edit.svg +1 -0
- package/src/assets/icons/feather/external-link.svg +1 -0
- package/src/assets/icons/feather/eye-off.svg +1 -0
- package/src/assets/icons/feather/eye.svg +1 -0
- package/src/assets/icons/feather/facebook.svg +1 -0
- package/src/assets/icons/feather/fast-forward.svg +1 -0
- package/src/assets/icons/feather/feather.svg +1 -0
- package/src/assets/icons/feather/figma.svg +1 -0
- package/src/assets/icons/feather/file-minus.svg +1 -0
- package/src/assets/icons/feather/file-plus.svg +1 -0
- package/src/assets/icons/feather/file-text.svg +1 -0
- package/src/assets/icons/feather/file.svg +1 -0
- package/src/assets/icons/feather/film.svg +1 -0
- package/src/assets/icons/feather/filter.svg +1 -0
- package/src/assets/icons/feather/flag.svg +1 -0
- package/src/assets/icons/feather/folder-minus.svg +1 -0
- package/src/assets/icons/feather/folder-plus.svg +1 -0
- package/src/assets/icons/feather/folder.svg +1 -0
- package/src/assets/icons/feather/framer.svg +1 -0
- package/src/assets/icons/feather/frown.svg +1 -0
- package/src/assets/icons/feather/gift.svg +1 -0
- package/src/assets/icons/feather/git-branch.svg +1 -0
- package/src/assets/icons/feather/git-commit.svg +1 -0
- package/src/assets/icons/feather/git-merge.svg +1 -0
- package/src/assets/icons/feather/git-pull-request.svg +1 -0
- package/src/assets/icons/feather/github.svg +1 -0
- package/src/assets/icons/feather/gitlab.svg +1 -0
- package/src/assets/icons/feather/globe.svg +1 -0
- package/src/assets/icons/feather/grid.svg +1 -0
- package/src/assets/icons/feather/hard-drive.svg +1 -0
- package/src/assets/icons/feather/hash.svg +1 -0
- package/src/assets/icons/feather/headphones.svg +1 -0
- package/src/assets/icons/feather/heart.svg +1 -0
- package/src/assets/icons/feather/help-circle.svg +1 -0
- package/src/assets/icons/feather/hexagon.svg +1 -0
- package/src/assets/icons/feather/home.svg +1 -0
- package/src/assets/icons/feather/image.svg +1 -0
- package/src/assets/icons/feather/inbox.svg +1 -0
- package/src/assets/icons/feather/index.ts +581 -0
- package/src/assets/icons/feather/info.svg +1 -0
- package/src/assets/icons/feather/instagram.svg +1 -0
- package/src/assets/icons/feather/italic.svg +1 -0
- package/src/assets/icons/feather/key.svg +1 -0
- package/src/assets/icons/feather/layers.svg +1 -0
- package/src/assets/icons/feather/layout.svg +1 -0
- package/src/assets/icons/feather/life-buoy.svg +1 -0
- package/src/assets/icons/feather/link-2.svg +1 -0
- package/src/assets/icons/feather/link.svg +1 -0
- package/src/assets/icons/feather/linkedin.svg +1 -0
- package/src/assets/icons/feather/list.svg +1 -0
- package/src/assets/icons/feather/loader.svg +1 -0
- package/src/assets/icons/feather/lock.svg +1 -0
- package/src/assets/icons/feather/log-in.svg +1 -0
- package/src/assets/icons/feather/log-out.svg +1 -0
- package/src/assets/icons/feather/mail.svg +1 -0
- package/src/assets/icons/feather/map-pin.svg +1 -0
- package/src/assets/icons/feather/map.svg +1 -0
- package/src/assets/icons/feather/maximize-2.svg +1 -0
- package/src/assets/icons/feather/maximize.svg +1 -0
- package/src/assets/icons/feather/meh.svg +1 -0
- package/src/assets/icons/feather/menu.svg +1 -0
- package/src/assets/icons/feather/message-circle.svg +1 -0
- package/src/assets/icons/feather/message-square.svg +1 -0
- package/src/assets/icons/feather/mic-off.svg +1 -0
- package/src/assets/icons/feather/mic.svg +1 -0
- package/src/assets/icons/feather/minimize-2.svg +1 -0
- package/src/assets/icons/feather/minimize.svg +1 -0
- package/src/assets/icons/feather/minus-circle.svg +1 -0
- package/src/assets/icons/feather/minus-square.svg +1 -0
- package/src/assets/icons/feather/minus.svg +1 -0
- package/src/assets/icons/feather/monitor.svg +1 -0
- package/src/assets/icons/feather/moon.svg +1 -0
- package/src/assets/icons/feather/more-horizontal.svg +1 -0
- package/src/assets/icons/feather/more-vertical.svg +1 -0
- package/src/assets/icons/feather/mouse-pointer.svg +1 -0
- package/src/assets/icons/feather/move.svg +1 -0
- package/src/assets/icons/feather/music.svg +1 -0
- package/src/assets/icons/feather/navigation-2.svg +1 -0
- package/src/assets/icons/feather/navigation.svg +1 -0
- package/src/assets/icons/feather/octagon.svg +1 -0
- package/src/assets/icons/feather/package.svg +1 -0
- package/src/assets/icons/feather/paperclip.svg +1 -0
- package/src/assets/icons/feather/pause-circle.svg +1 -0
- package/src/assets/icons/feather/pause.svg +1 -0
- package/src/assets/icons/feather/pen-tool.svg +1 -0
- package/src/assets/icons/feather/percent.svg +1 -0
- package/src/assets/icons/feather/phone-call.svg +1 -0
- package/src/assets/icons/feather/phone-forwarded.svg +1 -0
- package/src/assets/icons/feather/phone-incoming.svg +1 -0
- package/src/assets/icons/feather/phone-missed.svg +1 -0
- package/src/assets/icons/feather/phone-off.svg +1 -0
- package/src/assets/icons/feather/phone-outgoing.svg +1 -0
- package/src/assets/icons/feather/phone.svg +1 -0
- package/src/assets/icons/feather/pie-chart.svg +1 -0
- package/src/assets/icons/feather/play-circle.svg +1 -0
- package/src/assets/icons/feather/play.svg +1 -0
- package/src/assets/icons/feather/plus-circle.svg +1 -0
- package/src/assets/icons/feather/plus-square.svg +1 -0
- package/src/assets/icons/feather/plus.svg +1 -0
- package/src/assets/icons/feather/pocket.svg +1 -0
- package/src/assets/icons/feather/power.svg +1 -0
- package/src/assets/icons/feather/printer.svg +1 -0
- package/src/assets/icons/feather/radio.svg +1 -0
- package/src/assets/icons/feather/refresh-ccw.svg +1 -0
- package/src/assets/icons/feather/refresh-cw.svg +1 -0
- package/src/assets/icons/feather/repeat.svg +1 -0
- package/src/assets/icons/feather/rewind.svg +1 -0
- package/src/assets/icons/feather/rotate-ccw.svg +1 -0
- package/src/assets/icons/feather/rotate-cw.svg +1 -0
- package/src/assets/icons/feather/rss.svg +1 -0
- package/src/assets/icons/feather/save.svg +1 -0
- package/src/assets/icons/feather/scissors.svg +1 -0
- package/src/assets/icons/feather/search.svg +1 -0
- package/src/assets/icons/feather/send.svg +1 -0
- package/src/assets/icons/feather/server.svg +1 -0
- package/src/assets/icons/feather/settings.svg +1 -0
- package/src/assets/icons/feather/share-2.svg +1 -0
- package/src/assets/icons/feather/share.svg +1 -0
- package/src/assets/icons/feather/shield-off.svg +1 -0
- package/src/assets/icons/feather/shield.svg +1 -0
- package/src/assets/icons/feather/shopping-bag.svg +1 -0
- package/src/assets/icons/feather/shopping-cart.svg +1 -0
- package/src/assets/icons/feather/shuffle.svg +1 -0
- package/src/assets/icons/feather/sidebar.svg +1 -0
- package/src/assets/icons/feather/skip-back.svg +1 -0
- package/src/assets/icons/feather/skip-forward.svg +1 -0
- package/src/assets/icons/feather/slack.svg +1 -0
- package/src/assets/icons/feather/slash.svg +1 -0
- package/src/assets/icons/feather/sliders.svg +1 -0
- package/src/assets/icons/feather/smartphone.svg +1 -0
- package/src/assets/icons/feather/smile.svg +1 -0
- package/src/assets/icons/feather/speaker.svg +1 -0
- package/src/assets/icons/feather/square.svg +1 -0
- package/src/assets/icons/feather/star.svg +1 -0
- package/src/assets/icons/feather/stop-circle.svg +1 -0
- package/src/assets/icons/feather/sun.svg +1 -0
- package/src/assets/icons/feather/sunrise.svg +1 -0
- package/src/assets/icons/feather/sunset.svg +1 -0
- package/src/assets/icons/feather/table.svg +1 -0
- package/src/assets/icons/feather/tablet.svg +1 -0
- package/src/assets/icons/feather/tag.svg +1 -0
- package/src/assets/icons/feather/target.svg +1 -0
- package/src/assets/icons/feather/terminal.svg +1 -0
- package/src/assets/icons/feather/thermometer.svg +1 -0
- package/src/assets/icons/feather/thumbs-down.svg +1 -0
- package/src/assets/icons/feather/thumbs-up.svg +1 -0
- package/src/assets/icons/feather/toggle-left.svg +1 -0
- package/src/assets/icons/feather/toggle-right.svg +1 -0
- package/src/assets/icons/feather/tool.svg +1 -0
- package/src/assets/icons/feather/trash-2.svg +1 -0
- package/src/assets/icons/feather/trash.svg +1 -0
- package/src/assets/icons/feather/trello.svg +1 -0
- package/src/assets/icons/feather/trending-down.svg +1 -0
- package/src/assets/icons/feather/trending-up.svg +1 -0
- package/src/assets/icons/feather/triangle.svg +1 -0
- package/src/assets/icons/feather/truck.svg +1 -0
- package/src/assets/icons/feather/tv.svg +1 -0
- package/src/assets/icons/feather/twitch.svg +1 -0
- package/src/assets/icons/feather/twitter.svg +1 -0
- package/src/assets/icons/feather/type.svg +1 -0
- package/src/assets/icons/feather/umbrella.svg +1 -0
- package/src/assets/icons/feather/underline.svg +1 -0
- package/src/assets/icons/feather/unlock.svg +1 -0
- package/src/assets/icons/feather/upload-cloud.svg +1 -0
- package/src/assets/icons/feather/upload.svg +1 -0
- package/src/assets/icons/feather/user-check.svg +1 -0
- package/src/assets/icons/feather/user-minus.svg +1 -0
- package/src/assets/icons/feather/user-plus.svg +1 -0
- package/src/assets/icons/feather/user-x.svg +1 -0
- package/src/assets/icons/feather/user.svg +1 -0
- package/src/assets/icons/feather/users.svg +1 -0
- package/src/assets/icons/feather/video-off.svg +1 -0
- package/src/assets/icons/feather/video.svg +1 -0
- package/src/assets/icons/feather/voicemail.svg +1 -0
- package/src/assets/icons/feather/volume-1.svg +1 -0
- package/src/assets/icons/feather/volume-2.svg +1 -0
- package/src/assets/icons/feather/volume-x.svg +1 -0
- package/src/assets/icons/feather/volume.svg +1 -0
- package/src/assets/icons/feather/watch.svg +1 -0
- package/src/assets/icons/feather/wifi-off.svg +1 -0
- package/src/assets/icons/feather/wifi.svg +1 -0
- package/src/assets/icons/feather/wind.svg +1 -0
- package/src/assets/icons/feather/x-circle.svg +1 -0
- package/src/assets/icons/feather/x-octagon.svg +1 -0
- package/src/assets/icons/feather/x-square.svg +1 -0
- package/src/assets/icons/feather/x.svg +1 -0
- package/src/assets/icons/feather/youtube.svg +1 -0
- package/src/assets/icons/feather/zap-off.svg +1 -0
- package/src/assets/icons/feather/zap.svg +1 -0
- package/src/assets/icons/feather/zoom-in.svg +1 -0
- package/src/assets/icons/feather/zoom-out.svg +1 -0
- package/src/assets/icons/flags/flags.png +0 -0
- package/src/assets/icons/flags/index.ts +120 -0
- package/src/components/AbsoluteContainer/index.tsx +62 -0
- package/src/components/AbsoluteContainer/interfaces.ts +39 -0
- package/src/components/AbsoluteContainer/styles.ts +93 -0
- package/src/components/Button/constants.ts +17 -0
- package/src/components/Button/index.tsx +47 -0
- package/src/components/Button/interfaces.ts +33 -0
- package/src/components/Button/styles.ts +126 -0
- package/src/components/Button/theme.ts +8 -0
- package/src/components/Calendar/index.tsx +375 -0
- package/src/components/Calendar/interfaces.ts +21 -0
- package/src/components/Calendar/styles.ts +161 -0
- package/src/components/CalendarInterval/index.tsx +93 -0
- package/src/components/CalendarInterval/interfaces.ts +17 -0
- package/src/components/CalendarInterval/styles.ts +9 -0
- package/src/components/Card/index.tsx +9 -0
- package/src/components/Card/interfaces.ts +5 -0
- package/src/components/Card/styled.ts +60 -0
- package/src/components/Icon/index.tsx +66 -0
- package/src/components/Icon/interfaces.ts +42 -0
- package/src/components/Icon/styled.ts +64 -0
- package/src/components/Indicator/index.tsx +14 -0
- package/src/components/Indicator/interfaces.ts +6 -0
- package/src/components/Indicator/styles.ts +49 -0
- package/src/components/Input/components/Checkbox/index.tsx +35 -0
- package/src/components/Input/components/Checkbox/interfaces.ts +27 -0
- package/src/components/Input/components/Checkbox/styles.ts +168 -0
- package/src/components/Input/components/Date/functions.ts +1 -0
- package/src/components/Input/components/Date/index.tsx +188 -0
- package/src/components/Input/components/Date/interfaces.ts +10 -0
- package/src/components/Input/components/Date/styles.ts +5 -0
- package/src/components/Input/components/DatePicker/index.tsx +143 -0
- package/src/components/Input/components/DatePicker/interfaces.ts +21 -0
- package/src/components/Input/components/DatePicker/styles.ts +64 -0
- package/src/components/Input/components/Input/functions.ts +35 -0
- package/src/components/Input/components/Input/index.tsx +204 -0
- package/src/components/Input/components/Input/interfaces.ts +46 -0
- package/src/components/Input/components/Input/styles.ts +140 -0
- package/src/components/Input/components/Password/index.tsx +63 -0
- package/src/components/Input/components/Password/interfaces.ts +9 -0
- package/src/components/Input/components/Phone/countries.ts +107 -0
- package/src/components/Input/components/Phone/index.tsx +179 -0
- package/src/components/Input/components/Phone/interfaces.ts +47 -0
- package/src/components/Input/components/Phone/styles.ts +27 -0
- package/src/components/Input/components/RadioButton/index.tsx +28 -0
- package/src/components/Input/components/RadioButton/interfaces.ts +16 -0
- package/src/components/Input/components/RadioButton/styles.ts +96 -0
- package/src/components/Input/components/Range/index.tsx +186 -0
- package/src/components/Input/components/Range/interfaces.ts +37 -0
- package/src/components/Input/components/Range/styles.ts +218 -0
- package/src/components/Input/components/Select/context.ts +8 -0
- package/src/components/Input/components/Select/index.tsx +226 -0
- package/src/components/Input/components/Select/interfaces.ts +49 -0
- package/src/components/Input/components/Select/styles.ts +17 -0
- package/src/components/Input/components/Switch/index.tsx +28 -0
- package/src/components/Input/components/Switch/interfaces.ts +16 -0
- package/src/components/Input/components/Switch/styles.ts +100 -0
- package/src/components/Input/components/Time/index.tsx +152 -0
- package/src/components/Input/components/Time/interfaces.ts +6 -0
- package/src/components/Input/index.tsx +95 -0
- package/src/components/Loader/index.ts +55 -0
- package/src/components/Loader/interfaces.ts +8 -0
- package/src/components/Menu/index.tsx +139 -0
- package/src/components/Menu/interfaces.ts +63 -0
- package/src/components/Menu/styles.ts +79 -0
- package/src/components/Modal/component.tsx +114 -0
- package/src/components/Modal/contants.ts +15 -0
- package/src/components/Modal/index.ts +18 -0
- package/src/components/Modal/interfaces.ts +60 -0
- package/src/components/Modal/styles.ts +91 -0
- package/src/components/Modal/templates/Audit/index.tsx +45 -0
- package/src/components/Modal/templates/Audit/interfaces.ts +17 -0
- package/src/components/Modal/templates/Audit/styles.ts +5 -0
- package/src/components/Modal/templates/ConfirmDelete/index.tsx +47 -0
- package/src/components/Modal/templates/ConfirmDelete/interfaces.ts +16 -0
- package/src/components/Modal/templates/ConfirmDelete/styles.ts +5 -0
- package/src/components/Modal/templates/ConfirmEdit/index.tsx +51 -0
- package/src/components/Modal/templates/ConfirmEdit/interfaces.ts +18 -0
- package/src/components/Modal/templates/ConfirmEdit/styles.ts +5 -0
- package/src/components/Modal/templates/index.ts +3 -0
- package/src/components/Placeholder/components/Template1/index.tsx +27 -0
- package/src/components/Placeholder/components/Template1/styles.ts +68 -0
- package/src/components/Placeholder/components/Template10/index.tsx +29 -0
- package/src/components/Placeholder/components/Template10/styles.ts +79 -0
- package/src/components/Placeholder/components/Template2/index.tsx +25 -0
- package/src/components/Placeholder/components/Template2/styles.ts +43 -0
- package/src/components/Placeholder/components/Template3/index.tsx +18 -0
- package/src/components/Placeholder/components/Template3/styles.ts +15 -0
- package/src/components/Placeholder/components/Template4/index.tsx +20 -0
- package/src/components/Placeholder/components/Template4/styles.ts +50 -0
- package/src/components/Placeholder/components/Template5/index.tsx +40 -0
- package/src/components/Placeholder/components/Template5/styles.ts +64 -0
- package/src/components/Placeholder/components/Template6/index.tsx +33 -0
- package/src/components/Placeholder/components/Template6/styles.ts +63 -0
- package/src/components/Placeholder/components/Template7/index.tsx +23 -0
- package/src/components/Placeholder/components/Template7/styles.ts +73 -0
- package/src/components/Placeholder/components/Template8/index.tsx +30 -0
- package/src/components/Placeholder/components/Template8/styles.ts +66 -0
- package/src/components/Placeholder/components/Template9/index.tsx +20 -0
- package/src/components/Placeholder/components/Template9/styles.ts +74 -0
- package/src/components/Placeholder/index.tsx +56 -0
- package/src/components/Placeholder/interfaces.ts +21 -0
- package/src/components/Placeholder/styles.ts +35 -0
- package/src/components/ProgressBar/index.tsx +16 -0
- package/src/components/ProgressBar/interfaces.ts +4 -0
- package/src/components/ProgressBar/styles.ts +51 -0
- package/src/components/ScrollContainer/index.tsx +99 -0
- package/src/components/ScrollContainer/interfaces.ts +9 -0
- package/src/components/Tabs/index.tsx +55 -0
- package/src/components/Tabs/interfaces.ts +44 -0
- package/src/components/Tabs/styles.ts +65 -0
- package/src/components/TextArea/index.tsx +9 -0
- package/src/components/TextArea/interfaces.ts +10 -0
- package/src/components/TextArea/styles.ts +13 -0
- package/src/components/Toast/index.tsx +20 -0
- package/src/components/Toast/interfaces.ts +7 -0
- package/src/components/Toast/styles.ts +88 -0
- package/src/components/index.ts +17 -0
- package/src/components/theme.ts +7 -0
- package/src/functions/common.ts +3 -0
- package/src/functions/formatters.ts +170 -0
- package/src/functions/validators.ts +93 -0
- package/src/hooks/onClickOut.ts +28 -0
- package/src/index.ts +8 -0
- package/src/interfaces.ts +4 -0
- package/src/stories/components/Input/MwCheckbox/MwCheckBox.stories.tsx +20 -0
- package/src/stories/components/Input/MwCheckbox/argTypes.ts +82 -0
- package/src/stories/components/Input/MwDate/MwDate.stories.tsx +31 -0
- package/src/stories/components/Input/MwDate/argTypes.ts +74 -0
- package/src/stories/components/Input/MwDatePicker/MwDatePicker.stories.tsx +33 -0
- package/src/stories/components/Input/MwDatePicker/argTypes.ts +6 -0
- package/src/stories/components/Input/MwInput/MwInput.stories.tsx +21 -0
- package/src/stories/components/Input/MwInput/argTypes.ts +93 -0
- package/src/stories/components/Input/MwIntlTel/MwIntlTel.stories.tsx +31 -0
- package/src/stories/components/Input/MwIntlTel/argTypes.ts +67 -0
- package/src/stories/components/Input/MwPassword/MwPassword.stories.tsx +20 -0
- package/src/stories/components/Input/MwPassword/argTypes.ts +51 -0
- package/src/stories/components/Input/MwRadioButton/MwSwitch.stories.tsx +22 -0
- package/src/stories/components/Input/MwRadioButton/argtypes.ts +81 -0
- package/src/stories/components/Input/MwRange/MwRange.stories.tsx +33 -0
- package/src/stories/components/Input/MwRange/argTypes.ts +83 -0
- package/src/stories/components/Input/MwSelect/MwSelect.stories.tsx +20 -0
- package/src/stories/components/Input/MwSelect/argTypes.ts +133 -0
- package/src/stories/components/Input/MwSwitch/MwSwitch.stories.tsx +20 -0
- package/src/stories/components/Input/MwSwitch/argTypes.ts +73 -0
- package/src/stories/components/Input/MwTime/MwTime.stories.tsx +20 -0
- package/src/stories/components/Input/MwTime/argTypes.ts +88 -0
- package/src/stories/components/MwButton/MwButton.stories.tsx +19 -0
- package/src/stories/components/MwButton/argTypes.ts +81 -0
- package/src/stories/components/MwCalendar/MwCalendar.stories.tsx +39 -0
- package/src/stories/components/MwCalendar/argTypes.ts +15 -0
- package/src/stories/components/MwCalendarInterval/MwCalendarInterval.stories.tsx +39 -0
- package/src/stories/components/MwCalendarInterval/argTypes.ts +15 -0
- package/src/stories/components/MwCard/MwCard.stories.tsx +19 -0
- package/src/stories/components/MwCard/argTypes.ts +27 -0
- package/src/stories/components/MwIcon/MwIcon.stories.tsx +19 -0
- package/src/stories/components/MwIcon/argTypes.ts +48 -0
- package/src/stories/components/MwIndicator/MwIndicator.stories.tsx +19 -0
- package/src/stories/components/MwIndicator/argTypes.ts +38 -0
- package/src/stories/components/MwLoader/MwLoader.stories.tsx +19 -0
- package/src/stories/components/MwLoader/argTypes.ts +33 -0
- package/src/stories/components/MwModal/MwModal.stories.tsx +81 -0
- package/src/stories/components/MwModal/argTypes.ts +71 -0
- package/src/stories/components/MwPlaceholder/Template1/MwTemplate1.stories.tsx +23 -0
- package/src/stories/components/MwPlaceholder/Template1/argTypes.ts +22 -0
- package/src/stories/components/MwPlaceholder/Template10/MwTemplate1.stories.tsx +23 -0
- package/src/stories/components/MwPlaceholder/Template10/argTypes.ts +22 -0
- package/src/stories/components/MwPlaceholder/Template2/MwTemplate1.stories.tsx +23 -0
- package/src/stories/components/MwPlaceholder/Template2/argTypes.ts +22 -0
- package/src/stories/components/MwPlaceholder/Template3/MwTemplate1.stories.tsx +23 -0
- package/src/stories/components/MwPlaceholder/Template3/argTypes.ts +22 -0
- package/src/stories/components/MwPlaceholder/Template4/MwTemplate1.stories.tsx +23 -0
- package/src/stories/components/MwPlaceholder/Template4/argTypes.ts +22 -0
- package/src/stories/components/MwPlaceholder/Template5/MwTemplate1.stories.tsx +23 -0
- package/src/stories/components/MwPlaceholder/Template5/argTypes.ts +22 -0
- package/src/stories/components/MwPlaceholder/Template6/MwTemplate1.stories.tsx +23 -0
- package/src/stories/components/MwPlaceholder/Template6/argTypes.ts +22 -0
- package/src/stories/components/MwPlaceholder/Template7/MwTemplate1.stories.tsx +23 -0
- package/src/stories/components/MwPlaceholder/Template7/argTypes.ts +22 -0
- package/src/stories/components/MwPlaceholder/Template8/MwTemplate1.stories.tsx +23 -0
- package/src/stories/components/MwPlaceholder/Template8/argTypes.ts +22 -0
- package/src/stories/components/MwPlaceholder/Template9/MwTemplate1.stories.tsx +23 -0
- package/src/stories/components/MwPlaceholder/Template9/argTypes.ts +22 -0
- package/src/stories/components/MwProgressBar/MwIndicator.stories.tsx +19 -0
- package/src/stories/components/MwProgressBar/argTypes.ts +22 -0
- package/src/stories/components/MwTabs/MwTabs.stories.tsx +29 -0
- package/src/stories/components/MwTabs/argTypes.ts +78 -0
- package/src/stories/components/MwTextArea/MwTextArea.stories.tsx +19 -0
- package/src/stories/components/MwTextArea/argTypes.ts +29 -0
- package/src/stories/components/MwToast/MwIcon.stories.tsx +19 -0
- package/src/stories/components/MwToast/argTypes.ts +45 -0
- package/src/stories/examples/Introduction.stories.mdx +219 -0
- package/src/stories/examples/assets/code-brackets.svg +1 -0
- package/src/stories/examples/assets/colors.svg +1 -0
- package/src/stories/examples/assets/comments.svg +1 -0
- package/src/stories/examples/assets/direction.svg +1 -0
- package/src/stories/examples/assets/flow.svg +1 -0
- package/src/stories/examples/assets/plugin.svg +1 -0
- package/src/stories/examples/assets/repo.svg +1 -0
- package/src/stories/examples/assets/stackalt.svg +1 -0
- package/src/stories/interfaces.ts +17 -0
- package/src/styled.d.ts +9 -0
- package/src/theme/constants.ts +129 -0
- package/src/theme/globals.tsx +15 -0
- package/src/theme/index.tsx +68 -0
- package/src/theme/interfaces.ts +24 -0
- package/src/theme/useCssVars.ts +49 -0
- package/src/typings.d.ts +20 -0
- package/tsconfig.json +23 -0
- package/dist/index.d.ts +0 -6
- package/dist/index.js +0 -30
- package/dist/index.js.map +0 -1
- package/dist/index.modern.js +0 -11
- package/dist/index.modern.js.map +0 -1
|
@@ -0,0 +1,188 @@
|
|
|
1
|
+
import React, { useState } from 'react'
|
|
2
|
+
|
|
3
|
+
import {
|
|
4
|
+
dateToIsoString,
|
|
5
|
+
filterObject,
|
|
6
|
+
isoStringToDate,
|
|
7
|
+
} from '../../../../functions/formatters'
|
|
8
|
+
import useOnClickOut from '../../../../hooks/onClickOut'
|
|
9
|
+
|
|
10
|
+
import Calendar from '../../../Calendar'
|
|
11
|
+
import { IconProps } from '../../../Icon/interfaces'
|
|
12
|
+
|
|
13
|
+
import Input from '../Input'
|
|
14
|
+
import { InputProps } from '../Input/interfaces'
|
|
15
|
+
|
|
16
|
+
import { JSDate } from './functions'
|
|
17
|
+
import { DateProps } from './interfaces'
|
|
18
|
+
import * as S from './styles'
|
|
19
|
+
|
|
20
|
+
const isLeapYear = (year: number): boolean => {
|
|
21
|
+
if (year % 4 !== 0) return false
|
|
22
|
+
else if (year % 100 !== 0) return true
|
|
23
|
+
else if (year % 400 !== 0) return false
|
|
24
|
+
else return true
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
const mask = (v: string) => {
|
|
28
|
+
v = v.replace(/[^0-9\s]/g, '')
|
|
29
|
+
|
|
30
|
+
while (v.length > 0 && parseInt(v[0]) > 3) {
|
|
31
|
+
v = v.substring(1)
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
if (v.length > 1) {
|
|
35
|
+
if (v[0] === '3') {
|
|
36
|
+
while (v.length > 1 && parseInt(v[1]) > 1) {
|
|
37
|
+
v = v[0] + v.substring(2)
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
if (v.length > 2) {
|
|
43
|
+
while (v.length > 2 && parseInt(v[2]) > 1) {
|
|
44
|
+
v = v.substring(0, 2) + v.substring(3)
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
if (v.length > 3) {
|
|
49
|
+
if (v[2] === '1') {
|
|
50
|
+
while (v.length > 3 && parseInt(v[3]) > 2) {
|
|
51
|
+
v = v.substring(0, 3) + v.substring(4)
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
v = v.substring(0, 8)
|
|
57
|
+
|
|
58
|
+
const date = [v.substring(0, 2), v.substring(2, 4), v.substring(4)]
|
|
59
|
+
|
|
60
|
+
if (date[1] === '02') {
|
|
61
|
+
const d = parseInt(date[0])
|
|
62
|
+
|
|
63
|
+
if (date[2].length < 4 || isLeapYear(parseInt(date[2]))) {
|
|
64
|
+
// se for ano nao estiver setado, ou se for bissexto, o dia maximo de fevereiro deve ser 29
|
|
65
|
+
if (d > 29) {
|
|
66
|
+
date[0] = '29'
|
|
67
|
+
}
|
|
68
|
+
} else if (d > 28) {
|
|
69
|
+
// se for ano estiver setado e nao for bissexto, o dia maximo de fevereiro deve ser 28
|
|
70
|
+
date[0] = '28'
|
|
71
|
+
}
|
|
72
|
+
} else if (['04', '06', '09', '11'].includes(date[1]) && date[0] === '31') {
|
|
73
|
+
// meses com 30 dias
|
|
74
|
+
date[0] = '30'
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
v = date.join('')
|
|
78
|
+
|
|
79
|
+
if (v.length < 3) return v
|
|
80
|
+
else if (v.length < 5) return v.substring(0, 2) + '/' + v.substring(2)
|
|
81
|
+
else return v.substring(0, 2) + '/' + v.substring(2, 4) + '/' + v.substring(4)
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
const Date = React.forwardRef(
|
|
85
|
+
(props: DateProps, ref?: React.ForwardedRef<HTMLInputElement>) => {
|
|
86
|
+
const { picker, value, min, max } = props
|
|
87
|
+
|
|
88
|
+
const setValue = props.setValue || (() => {})
|
|
89
|
+
|
|
90
|
+
const [open, setOpen] = useState<boolean>(false)
|
|
91
|
+
|
|
92
|
+
const _onKeyDown = props.onKeyDown || (() => {})
|
|
93
|
+
|
|
94
|
+
const onKeyDown: React.KeyboardEventHandler<HTMLInputElement> = (event) => {
|
|
95
|
+
const target = event.target as HTMLInputElement
|
|
96
|
+
|
|
97
|
+
const todayDate = new JSDate()
|
|
98
|
+
|
|
99
|
+
const curD = todayDate.getDate()
|
|
100
|
+
const curM = todayDate.getMonth() + 1
|
|
101
|
+
const curY = todayDate.getFullYear()
|
|
102
|
+
|
|
103
|
+
const value = target.value.replace(/[^0-9\s]/g, '')
|
|
104
|
+
|
|
105
|
+
let tmp = value.substring(0, 2)
|
|
106
|
+
const d = tmp.length === 0 ? curD : parseInt(tmp.padEnd(2, '0'))
|
|
107
|
+
|
|
108
|
+
tmp = value.substring(2, 4)
|
|
109
|
+
const m = tmp.length === 0 ? curM : parseInt(tmp.padEnd(2, '0'))
|
|
110
|
+
|
|
111
|
+
tmp = value.substring(4, 8)
|
|
112
|
+
const y = tmp.length === 0 ? curY : parseInt(tmp.padEnd(2, '0'))
|
|
113
|
+
|
|
114
|
+
if (event.key === 'ArrowUp') {
|
|
115
|
+
const date = new JSDate(`${y}-${m}-${d} 00:00:00`)
|
|
116
|
+
date.setDate(date.getDate() + 1)
|
|
117
|
+
|
|
118
|
+
if (!max || date <= max) {
|
|
119
|
+
target.value = dateToIsoString(date)
|
|
120
|
+
}
|
|
121
|
+
} else if (event.key === 'ArrowDown') {
|
|
122
|
+
const date = new JSDate(`${y}-${m}-${d} 00:00:00`)
|
|
123
|
+
date.setDate(date.getDate() - 1)
|
|
124
|
+
|
|
125
|
+
if (!min || date >= min) {
|
|
126
|
+
target.value = dateToIsoString(date)
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
_onKeyDown(event)
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
const placeholder =
|
|
134
|
+
props.placeholder === undefined ? 'dd/mm/aaaa' : props.placeholder
|
|
135
|
+
|
|
136
|
+
const icon = picker
|
|
137
|
+
? {
|
|
138
|
+
icon: {
|
|
139
|
+
type: 'feather',
|
|
140
|
+
icon: 'calendar',
|
|
141
|
+
} as IconProps,
|
|
142
|
+
position: 'right' as 'right' | 'left',
|
|
143
|
+
onClick: () => setOpen((prev) => !prev),
|
|
144
|
+
}
|
|
145
|
+
: undefined
|
|
146
|
+
|
|
147
|
+
const inputProps = filterObject<DateProps, InputProps>(props, [
|
|
148
|
+
'picker',
|
|
149
|
+
'min',
|
|
150
|
+
'max',
|
|
151
|
+
])
|
|
152
|
+
|
|
153
|
+
return (
|
|
154
|
+
<S.RelativeContainer ref={useOnClickOut(() => setOpen(false))}>
|
|
155
|
+
<Input
|
|
156
|
+
{...inputProps}
|
|
157
|
+
type='text'
|
|
158
|
+
placeholder={placeholder}
|
|
159
|
+
mask={mask}
|
|
160
|
+
onKeyDown={onKeyDown}
|
|
161
|
+
icon={icon}
|
|
162
|
+
ref={ref}
|
|
163
|
+
/>
|
|
164
|
+
|
|
165
|
+
{open && (
|
|
166
|
+
<Calendar
|
|
167
|
+
initalValue={value ? isoStringToDate(value) : undefined}
|
|
168
|
+
onSubmit={{
|
|
169
|
+
onClick: (date) => {
|
|
170
|
+
if (!date) return
|
|
171
|
+
const newValue = dateToIsoString(date)
|
|
172
|
+
setValue(newValue)
|
|
173
|
+
setOpen(false)
|
|
174
|
+
},
|
|
175
|
+
}}
|
|
176
|
+
min={min}
|
|
177
|
+
max={max}
|
|
178
|
+
references={{ bottom: '35px' }}
|
|
179
|
+
/>
|
|
180
|
+
)}
|
|
181
|
+
</S.RelativeContainer>
|
|
182
|
+
)
|
|
183
|
+
},
|
|
184
|
+
)
|
|
185
|
+
|
|
186
|
+
Date.displayName = 'Date'
|
|
187
|
+
|
|
188
|
+
export default Date
|
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
import React, { useEffect, useState } from 'react'
|
|
2
|
+
import {
|
|
3
|
+
dateToIsoString,
|
|
4
|
+
filterObject,
|
|
5
|
+
isoStringToDate,
|
|
6
|
+
} from '../../../../functions/formatters'
|
|
7
|
+
import useOnClickOut from '../../../../hooks/onClickOut'
|
|
8
|
+
import Calendar from '../../../Calendar'
|
|
9
|
+
import Icon from '../../../Icon'
|
|
10
|
+
import { IconProps } from '../../../Icon/interfaces'
|
|
11
|
+
import Input from '../Input'
|
|
12
|
+
import { InputProps } from '../Input/interfaces'
|
|
13
|
+
import { DatePickerProps } from './interfaces'
|
|
14
|
+
import * as S from './styles'
|
|
15
|
+
|
|
16
|
+
const DatePicker = React.forwardRef(
|
|
17
|
+
(props: DatePickerProps, ref?: React.ForwardedRef<HTMLInputElement>) => {
|
|
18
|
+
const { picker, value, setValue, min, max } = props
|
|
19
|
+
|
|
20
|
+
const disabled = props.disabled || props.loading
|
|
21
|
+
|
|
22
|
+
const today = dateToIsoString(new Date())
|
|
23
|
+
|
|
24
|
+
const [open, setOpen] = useState<boolean>(false)
|
|
25
|
+
|
|
26
|
+
useEffect(() => {
|
|
27
|
+
const date = isoStringToDate(value)
|
|
28
|
+
if (!date) {
|
|
29
|
+
setValue(dateToIsoString(new Date()))
|
|
30
|
+
}
|
|
31
|
+
}, [value])
|
|
32
|
+
|
|
33
|
+
const onAdd = () => {
|
|
34
|
+
const date = isoStringToDate(value) || new Date()
|
|
35
|
+
date.setDate(date.getDate() + 1)
|
|
36
|
+
if (max && date > max) return
|
|
37
|
+
setValue(dateToIsoString(date))
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
const onSub = () => {
|
|
41
|
+
const date = isoStringToDate(value) || new Date()
|
|
42
|
+
date.setDate(date.getDate() - 1)
|
|
43
|
+
if (min && date < min) return
|
|
44
|
+
setValue(dateToIsoString(date))
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
const icon = picker
|
|
48
|
+
? {
|
|
49
|
+
icon: {
|
|
50
|
+
type: 'feather',
|
|
51
|
+
icon: 'calendar',
|
|
52
|
+
width: '24px',
|
|
53
|
+
} as IconProps,
|
|
54
|
+
position: 'right' as 'right' | 'left',
|
|
55
|
+
onClick: () => setOpen((prev) => !prev),
|
|
56
|
+
}
|
|
57
|
+
: undefined
|
|
58
|
+
|
|
59
|
+
const inputProps = filterObject<DatePickerProps, InputProps>(props, [
|
|
60
|
+
'picker',
|
|
61
|
+
'min',
|
|
62
|
+
'max',
|
|
63
|
+
])
|
|
64
|
+
|
|
65
|
+
return (
|
|
66
|
+
<S.RelativeContainer ref={useOnClickOut(() => setOpen(false))}>
|
|
67
|
+
<Input {...inputProps} type='text' icon={icon} ref={ref} htmlDisabled />
|
|
68
|
+
|
|
69
|
+
<S.Container
|
|
70
|
+
iconWidth={picker ? '24px' : '0px'}
|
|
71
|
+
invalid={props.invalid ? 1 : 0}
|
|
72
|
+
disabled={props.disabled ? 1 : 0}
|
|
73
|
+
>
|
|
74
|
+
<S.Button
|
|
75
|
+
type='button'
|
|
76
|
+
onClick={disabled ? undefined : onSub}
|
|
77
|
+
disabled={
|
|
78
|
+
disabled ||
|
|
79
|
+
(() => {
|
|
80
|
+
if (!min) return undefined
|
|
81
|
+
const v = isoStringToDate(value)
|
|
82
|
+
if (!v) return undefined
|
|
83
|
+
|
|
84
|
+
return v <= min
|
|
85
|
+
})()
|
|
86
|
+
}
|
|
87
|
+
>
|
|
88
|
+
<Icon
|
|
89
|
+
type='feather'
|
|
90
|
+
icon='chevron_left'
|
|
91
|
+
color={props.invalid ? 'warningRed' : 'grey'}
|
|
92
|
+
strokeWidth='3px'
|
|
93
|
+
/>
|
|
94
|
+
</S.Button>
|
|
95
|
+
|
|
96
|
+
<div>{today === value ? 'Hoje' : value}</div>
|
|
97
|
+
|
|
98
|
+
<S.Button
|
|
99
|
+
type='button'
|
|
100
|
+
onClick={disabled ? undefined : onAdd}
|
|
101
|
+
disabled={
|
|
102
|
+
disabled ||
|
|
103
|
+
(() => {
|
|
104
|
+
if (!max) return undefined
|
|
105
|
+
const v = isoStringToDate(value)
|
|
106
|
+
if (!v) return undefined
|
|
107
|
+
|
|
108
|
+
return v >= max
|
|
109
|
+
})()
|
|
110
|
+
}
|
|
111
|
+
>
|
|
112
|
+
<Icon
|
|
113
|
+
type='feather'
|
|
114
|
+
icon='chevron_right'
|
|
115
|
+
color={props.invalid ? 'warningRed' : 'grey'}
|
|
116
|
+
strokeWidth='3px'
|
|
117
|
+
/>
|
|
118
|
+
</S.Button>
|
|
119
|
+
</S.Container>
|
|
120
|
+
|
|
121
|
+
{open && (
|
|
122
|
+
<Calendar
|
|
123
|
+
initalValue={value ? isoStringToDate(value) : undefined}
|
|
124
|
+
onSubmit={{
|
|
125
|
+
onClick: (date) => {
|
|
126
|
+
if (!date) return
|
|
127
|
+
setValue(dateToIsoString(date))
|
|
128
|
+
setOpen(false)
|
|
129
|
+
},
|
|
130
|
+
}}
|
|
131
|
+
min={min}
|
|
132
|
+
max={max}
|
|
133
|
+
references={{ bottom: '35px' }}
|
|
134
|
+
/>
|
|
135
|
+
)}
|
|
136
|
+
</S.RelativeContainer>
|
|
137
|
+
)
|
|
138
|
+
},
|
|
139
|
+
)
|
|
140
|
+
|
|
141
|
+
DatePicker.displayName = 'DatePicker'
|
|
142
|
+
|
|
143
|
+
export default DatePicker
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { InputProps } from '../Input/interfaces'
|
|
2
|
+
|
|
3
|
+
export interface DatePickerProps
|
|
4
|
+
extends Omit<
|
|
5
|
+
InputProps,
|
|
6
|
+
| 'type'
|
|
7
|
+
| 'mask'
|
|
8
|
+
| 'icon'
|
|
9
|
+
| 'htmlDisabled'
|
|
10
|
+
| 'clearable'
|
|
11
|
+
| 'onPressEnter'
|
|
12
|
+
| 'min'
|
|
13
|
+
| 'max'
|
|
14
|
+
> {
|
|
15
|
+
type: 'datepicker'
|
|
16
|
+
picker?: boolean
|
|
17
|
+
value: string
|
|
18
|
+
setValue: (value: string) => void
|
|
19
|
+
max?: Date
|
|
20
|
+
min?: Date
|
|
21
|
+
}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import React from 'react'
|
|
2
|
+
import styled, { css } from 'styled-components'
|
|
3
|
+
|
|
4
|
+
export const RelativeContainer = styled.div`
|
|
5
|
+
position: relative;
|
|
6
|
+
|
|
7
|
+
input {
|
|
8
|
+
color: transparent;
|
|
9
|
+
}
|
|
10
|
+
`
|
|
11
|
+
|
|
12
|
+
interface ContainerProps extends React.HTMLAttributes<HTMLDivElement> {
|
|
13
|
+
iconWidth: string
|
|
14
|
+
invalid: 1 | 0
|
|
15
|
+
disabled: 1 | 0
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
export const Container = styled.div<ContainerProps>`
|
|
19
|
+
position: absolute;
|
|
20
|
+
bottom: 1px;
|
|
21
|
+
left: 1px;
|
|
22
|
+
width: calc(100% - 2px - ${({ iconWidth, theme }) => `${iconWidth} - ${theme.spacings.s3}`});
|
|
23
|
+
height: 33px;
|
|
24
|
+
display: flex;
|
|
25
|
+
justify-content: space-between;
|
|
26
|
+
align-items: center;
|
|
27
|
+
padding: ${({ theme }) =>
|
|
28
|
+
`${theme.spacings.s2} 0 ${theme.spacings.s2} ${theme.spacings.s3}`};
|
|
29
|
+
border-radius: 4px;
|
|
30
|
+
|
|
31
|
+
${({ invalid, theme }) => {
|
|
32
|
+
if (!invalid) return
|
|
33
|
+
|
|
34
|
+
return css`
|
|
35
|
+
color: ${theme.colors.warningRed};
|
|
36
|
+
`
|
|
37
|
+
}}
|
|
38
|
+
|
|
39
|
+
${({ disabled }) => {
|
|
40
|
+
if (!disabled) return
|
|
41
|
+
|
|
42
|
+
return css`
|
|
43
|
+
opacity: 0.5;
|
|
44
|
+
`
|
|
45
|
+
}}
|
|
46
|
+
`
|
|
47
|
+
|
|
48
|
+
export const Button = styled.button`
|
|
49
|
+
display: flex;
|
|
50
|
+
background-color: transparent;
|
|
51
|
+
border: none;
|
|
52
|
+
padding: 0;
|
|
53
|
+
box-shadow: none;
|
|
54
|
+
|
|
55
|
+
${({ onClick }) => {
|
|
56
|
+
if (!onClick) return
|
|
57
|
+
|
|
58
|
+
return css`
|
|
59
|
+
:not(:disabled) {
|
|
60
|
+
cursor: pointer;
|
|
61
|
+
}
|
|
62
|
+
`
|
|
63
|
+
}};
|
|
64
|
+
`
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { Mask, MaskFunction, MaskReplace, MaskReplaceArray } from './interfaces'
|
|
2
|
+
|
|
3
|
+
const isMaskFunction = (value?: Mask): value is MaskFunction => {
|
|
4
|
+
return typeof value === 'function'
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
const isMaskReplace = (value?: Mask): value is MaskReplace => {
|
|
8
|
+
return Array.isArray(value) && value[0] instanceof RegExp
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
const isMaskReplaceArray = (value?: Mask): value is MaskReplaceArray => {
|
|
12
|
+
return Array.isArray(value) && Array.isArray(value[0])
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
export const getMask = (mask?: Mask): MaskFunction => {
|
|
16
|
+
if (isMaskFunction(mask)) {
|
|
17
|
+
return mask
|
|
18
|
+
} else if (isMaskReplace(mask)) {
|
|
19
|
+
const [find, replace] = mask
|
|
20
|
+
return (value: string) => value.replace(find, replace)
|
|
21
|
+
} else if (isMaskReplaceArray(mask)) {
|
|
22
|
+
return (value: string) => {
|
|
23
|
+
let newValue = value
|
|
24
|
+
|
|
25
|
+
mask.forEach((e) => {
|
|
26
|
+
const [find, replace] = e
|
|
27
|
+
newValue = newValue.replace(find, replace)
|
|
28
|
+
})
|
|
29
|
+
|
|
30
|
+
return newValue
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
return (value: string) => value
|
|
35
|
+
}
|
|
@@ -0,0 +1,204 @@
|
|
|
1
|
+
import React from 'react'
|
|
2
|
+
|
|
3
|
+
import MwIcon from '../../../Icon'
|
|
4
|
+
|
|
5
|
+
import { filterObject } from '../../../../functions/formatters'
|
|
6
|
+
import { IconProps } from '../../../Icon/interfaces'
|
|
7
|
+
import Loader from '../../../Loader'
|
|
8
|
+
import { getMask } from './functions'
|
|
9
|
+
|
|
10
|
+
import { InputProps, StyledInputProps } from './interfaces'
|
|
11
|
+
import * as S from './styles'
|
|
12
|
+
|
|
13
|
+
const Input = React.forwardRef(
|
|
14
|
+
(props: InputProps, ref: React.ForwardedRef<HTMLInputElement>) => {
|
|
15
|
+
const {
|
|
16
|
+
label,
|
|
17
|
+
required,
|
|
18
|
+
invalid,
|
|
19
|
+
disabled,
|
|
20
|
+
loading,
|
|
21
|
+
clearable,
|
|
22
|
+
onPressEnter,
|
|
23
|
+
htmlDisabled,
|
|
24
|
+
width,
|
|
25
|
+
} = {
|
|
26
|
+
...props,
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
const mask = getMask(props.mask)
|
|
30
|
+
|
|
31
|
+
const intInvalid = invalid === undefined ? undefined : invalid ? 1 : 0
|
|
32
|
+
const intRequired = required === undefined ? undefined : required ? 1 : 0
|
|
33
|
+
const intDisabled = disabled === undefined ? undefined : disabled ? 1 : 0
|
|
34
|
+
|
|
35
|
+
let position
|
|
36
|
+
let iconWidth
|
|
37
|
+
let iconSubmit
|
|
38
|
+
let iconOnClick
|
|
39
|
+
let icon: IconProps | undefined
|
|
40
|
+
|
|
41
|
+
if (props.icon) {
|
|
42
|
+
icon = { ...props.icon.icon }
|
|
43
|
+
|
|
44
|
+
position = props.icon.position || 'right'
|
|
45
|
+
|
|
46
|
+
if (intInvalid) icon.color = 'warningRed'
|
|
47
|
+
|
|
48
|
+
iconWidth = icon.width
|
|
49
|
+
iconSubmit = props.icon.submit
|
|
50
|
+
iconOnClick = props.icon.onClick
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
const inputProps = filterObject<InputProps, StyledInputProps>(
|
|
54
|
+
props,
|
|
55
|
+
[
|
|
56
|
+
'label',
|
|
57
|
+
'invalid',
|
|
58
|
+
'required',
|
|
59
|
+
'icon',
|
|
60
|
+
'mask',
|
|
61
|
+
'loading',
|
|
62
|
+
'clearable',
|
|
63
|
+
'setValue',
|
|
64
|
+
'onPressEnter',
|
|
65
|
+
'htmlDisabled',
|
|
66
|
+
'width',
|
|
67
|
+
],
|
|
68
|
+
{
|
|
69
|
+
invalid: intInvalid,
|
|
70
|
+
type: 'text',
|
|
71
|
+
},
|
|
72
|
+
)
|
|
73
|
+
|
|
74
|
+
const onChange = inputProps.onChange || (() => {})
|
|
75
|
+
const setValue = props.setValue || (() => {})
|
|
76
|
+
|
|
77
|
+
inputProps.onChange = (event) => {
|
|
78
|
+
event.target.value = mask(event.target.value)
|
|
79
|
+
onChange(event)
|
|
80
|
+
setValue(event.target.value)
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
if (inputProps.onKeyDown || onPressEnter) {
|
|
84
|
+
const onKeyDown = inputProps.onKeyDown || (() => {})
|
|
85
|
+
|
|
86
|
+
const _onPressEnter = onPressEnter
|
|
87
|
+
? (event: React.KeyboardEvent<HTMLInputElement>) => {
|
|
88
|
+
event.preventDefault()
|
|
89
|
+
onPressEnter(event)
|
|
90
|
+
}
|
|
91
|
+
: () => {}
|
|
92
|
+
|
|
93
|
+
inputProps.onKeyDown = (event) => {
|
|
94
|
+
const target = event.target as HTMLInputElement
|
|
95
|
+
const v = target.value
|
|
96
|
+
|
|
97
|
+
onKeyDown(event)
|
|
98
|
+
|
|
99
|
+
if (v !== target.value) setValue(target.value)
|
|
100
|
+
|
|
101
|
+
if (event.key === 'Enter') {
|
|
102
|
+
_onPressEnter(event)
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
if (inputProps.onKeyUp) {
|
|
108
|
+
const onKeyUp = inputProps.onKeyUp
|
|
109
|
+
|
|
110
|
+
inputProps.onKeyUp = (event) => {
|
|
111
|
+
const target = event.target as HTMLInputElement
|
|
112
|
+
const v = target.value
|
|
113
|
+
|
|
114
|
+
onKeyUp(event)
|
|
115
|
+
|
|
116
|
+
if (v !== target.value) setValue(target.value)
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
if (inputProps.onKeyDownCapture) {
|
|
121
|
+
const onKeyDownCapture = inputProps.onKeyDownCapture
|
|
122
|
+
|
|
123
|
+
inputProps.onKeyDownCapture = (event) => {
|
|
124
|
+
const target = event.target as HTMLInputElement
|
|
125
|
+
const v = target.value
|
|
126
|
+
|
|
127
|
+
onKeyDownCapture(event)
|
|
128
|
+
|
|
129
|
+
if (v !== target.value) setValue(target.value)
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
if (inputProps.onKeyUpCapture) {
|
|
134
|
+
const onKeyUpCapture = inputProps.onKeyUpCapture
|
|
135
|
+
|
|
136
|
+
inputProps.onKeyUpCapture = (event) => {
|
|
137
|
+
const target = event.target as HTMLInputElement
|
|
138
|
+
const v = target.value
|
|
139
|
+
|
|
140
|
+
onKeyUpCapture(event)
|
|
141
|
+
|
|
142
|
+
if (v !== target.value) setValue(target.value)
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
if (loading) {
|
|
147
|
+
position = position || 'left'
|
|
148
|
+
icon = {
|
|
149
|
+
type: 'jsx',
|
|
150
|
+
icon: <Loader size='14px' />,
|
|
151
|
+
width: '14px',
|
|
152
|
+
}
|
|
153
|
+
inputProps.disabled = true
|
|
154
|
+
} else if (clearable) {
|
|
155
|
+
position = position || 'right'
|
|
156
|
+
|
|
157
|
+
iconOnClick =
|
|
158
|
+
typeof clearable === 'function' ? clearable : () => setValue('')
|
|
159
|
+
|
|
160
|
+
icon = {
|
|
161
|
+
type: 'feather',
|
|
162
|
+
icon: 'x',
|
|
163
|
+
width: '14px',
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
const iconProps = position
|
|
168
|
+
? {
|
|
169
|
+
position: position as 'left' | 'right',
|
|
170
|
+
width: iconWidth || '24px',
|
|
171
|
+
}
|
|
172
|
+
: undefined
|
|
173
|
+
|
|
174
|
+
if (htmlDisabled) inputProps.disabled = true
|
|
175
|
+
|
|
176
|
+
return (
|
|
177
|
+
<S.Label
|
|
178
|
+
required={intRequired}
|
|
179
|
+
disabled={intDisabled}
|
|
180
|
+
invalid={intInvalid}
|
|
181
|
+
icon={iconProps}
|
|
182
|
+
width={width}
|
|
183
|
+
>
|
|
184
|
+
<div>{label}</div>
|
|
185
|
+
|
|
186
|
+
<S.Input {...inputProps} ref={ref} />
|
|
187
|
+
|
|
188
|
+
{icon && (
|
|
189
|
+
<S.IconContainer
|
|
190
|
+
type={iconSubmit ? 'submit' : 'button'}
|
|
191
|
+
onClick={iconOnClick}
|
|
192
|
+
disabled={props.disabled}
|
|
193
|
+
>
|
|
194
|
+
<MwIcon {...icon} />
|
|
195
|
+
</S.IconContainer>
|
|
196
|
+
)}
|
|
197
|
+
</S.Label>
|
|
198
|
+
)
|
|
199
|
+
},
|
|
200
|
+
)
|
|
201
|
+
|
|
202
|
+
Input.displayName = 'Input'
|
|
203
|
+
|
|
204
|
+
export default Input
|