@wangxinowo/vue-datepicker-next 1.0.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/README.md +104 -0
- package/dist/vue-datepicker-next.min.css +3560 -0
- package/dist/vue-datepicker-next.min.js +11 -0
- package/package.json +84 -0
- package/src/components/_util/BaseMixin.js +40 -0
- package/src/components/_util/ContainerRender.jsx +98 -0
- package/src/components/_util/FormDecoratorDirective.js +10 -0
- package/src/components/_util/KeyCode.js +521 -0
- package/src/components/_util/Portal.js +51 -0
- package/src/components/_util/PortalWrapper.js +156 -0
- package/src/components/_util/StateMixin.js +10 -0
- package/src/components/_util/__tests__/easings.test.js +13 -0
- package/src/components/_util/__tests__/scrollTo.test.js +56 -0
- package/src/components/_util/antDirective.js +13 -0
- package/src/components/_util/antInputDirective.js +73 -0
- package/src/components/_util/callMoment.js +4 -0
- package/src/components/_util/colors.js +17 -0
- package/src/components/_util/createChainedFunction.js +22 -0
- package/src/components/_util/css-animation/Event.js +130 -0
- package/src/components/_util/css-animation/index.js +184 -0
- package/src/components/_util/easings.js +8 -0
- package/src/components/_util/env.js +14 -0
- package/src/components/_util/getLocale.js +30 -0
- package/src/components/_util/getRequestAnimationFrame.js +46 -0
- package/src/components/_util/getScroll.js +17 -0
- package/src/components/_util/getScrollBarSize.js +38 -0
- package/src/components/_util/getTransitionProps.js +34 -0
- package/src/components/_util/interopDefault.js +4 -0
- package/src/components/_util/isCssAnimationSupported.js +24 -0
- package/src/components/_util/isFlexSupported.js +12 -0
- package/src/components/_util/isNumeric.js +4 -0
- package/src/components/_util/isValid.js +4 -0
- package/src/components/_util/moment-util.js +75 -0
- package/src/components/_util/openAnimation.js +67 -0
- package/src/components/_util/portalDirective.js +24 -0
- package/src/components/_util/props-util.js +335 -0
- package/src/components/_util/proxyComponent.jsx +58 -0
- package/src/components/_util/raf.js +32 -0
- package/src/components/_util/requestAnimationTimeout.js +23 -0
- package/src/components/_util/responsiveObserve.js +94 -0
- package/src/components/_util/scrollTo.js +37 -0
- package/src/components/_util/setStyle.js +25 -0
- package/src/components/_util/store/PropTypes.js +7 -0
- package/src/components/_util/store/Provider.jsx +15 -0
- package/src/components/_util/store/connect.jsx +106 -0
- package/src/components/_util/store/create.js +30 -0
- package/src/components/_util/store/index.js +5 -0
- package/src/components/_util/styleChecker.js +13 -0
- package/src/components/_util/switchScrollingEffect.js +20 -0
- package/src/components/_util/throttleByAnimationFrame.js +45 -0
- package/src/components/_util/transButton.jsx +81 -0
- package/src/components/_util/triggerEvent.js +8 -0
- package/src/components/_util/type.js +4 -0
- package/src/components/_util/vnode.js +147 -0
- package/src/components/_util/vue-types/index.js +263 -0
- package/src/components/_util/vue-types/utils.js +200 -0
- package/src/components/_util/warning.js +7 -0
- package/src/components/_util/wave.jsx +169 -0
- package/src/components/base/index.js +9 -0
- package/src/components/base/style/index.js +2 -0
- package/src/components/button/__tests__/__snapshots__/demo.test.js.snap +103 -0
- package/src/components/button/__tests__/__snapshots__/index.test.js.snap +43 -0
- package/src/components/button/__tests__/demo.test.js +3 -0
- package/src/components/button/__tests__/index.test.js +239 -0
- package/src/components/button/button-group.jsx +52 -0
- package/src/components/button/button.jsx +186 -0
- package/src/components/button/buttonTypes.js +13 -0
- package/src/components/button/index.js +14 -0
- package/src/components/button/style/index.js +2 -0
- package/src/components/button/style/index.less +224 -0
- package/src/components/button/style/mixin.less +357 -0
- package/src/components/calendar/locale/en_US.js +2 -0
- package/src/components/config-provider/__tests__/index.test.js +44 -0
- package/src/components/config-provider/configConsumerProps.jsx +9 -0
- package/src/components/config-provider/index.jsx +91 -0
- package/src/components/config-provider/renderEmpty.jsx +42 -0
- package/src/components/config-provider/style/index.js +1 -0
- package/src/components/config-provider/style/index.less +2 -0
- package/src/components/date-picker/InputIcon.js +20 -0
- package/src/components/date-picker/PresetPanel.jsx +102 -0
- package/src/components/date-picker/RangePicker.jsx +1010 -0
- package/src/components/date-picker/WeekPicker.jsx +235 -0
- package/src/components/date-picker/__tests__/DatePicker.test.js +189 -0
- package/src/components/date-picker/__tests__/MonthPicker.test.js +29 -0
- package/src/components/date-picker/__tests__/RangePicker.test.js +417 -0
- package/src/components/date-picker/__tests__/WeekPicker.test.js +24 -0
- package/src/components/date-picker/__tests__/__snapshots__/DatePicker.test.js.snap +3 -0
- package/src/components/date-picker/__tests__/__snapshots__/RangePicker.test.js.snap +695 -0
- package/src/components/date-picker/__tests__/__snapshots__/WeekPicker.test.js.snap +3 -0
- package/src/components/date-picker/__tests__/__snapshots__/demo.test.js.snap +49 -0
- package/src/components/date-picker/__tests__/__snapshots__/other.test.js.snap +240 -0
- package/src/components/date-picker/__tests__/demo.test.js +3 -0
- package/src/components/date-picker/__tests__/mount.test.js +11 -0
- package/src/components/date-picker/__tests__/other.test.js +88 -0
- package/src/components/date-picker/__tests__/showTime.test.js +234 -0
- package/src/components/date-picker/__tests__/utils.js +34 -0
- package/src/components/date-picker/createPicker.js +273 -0
- package/src/components/date-picker/generate/dayjs.js +438 -0
- package/src/components/date-picker/generate/index.js +125 -0
- package/src/components/date-picker/generate/moment.js +357 -0
- package/src/components/date-picker/index.js +37 -0
- package/src/components/date-picker/interface.js +172 -0
- package/src/components/date-picker/locale/ar_EG.js +23 -0
- package/src/components/date-picker/locale/bg_BG.js +19 -0
- package/src/components/date-picker/locale/ca_ES.js +19 -0
- package/src/components/date-picker/locale/cs_CZ.js +19 -0
- package/src/components/date-picker/locale/da_DK.js +19 -0
- package/src/components/date-picker/locale/de_DE.js +19 -0
- package/src/components/date-picker/locale/el_GR.js +19 -0
- package/src/components/date-picker/locale/en_GB.js +19 -0
- package/src/components/date-picker/locale/en_US.js +19 -0
- package/src/components/date-picker/locale/es_ES.js +19 -0
- package/src/components/date-picker/locale/et_EE.js +19 -0
- package/src/components/date-picker/locale/example.json +39 -0
- package/src/components/date-picker/locale/fa_IR.js +19 -0
- package/src/components/date-picker/locale/fi_FI.js +19 -0
- package/src/components/date-picker/locale/fr_BE.js +19 -0
- package/src/components/date-picker/locale/fr_FR.js +19 -0
- package/src/components/date-picker/locale/ga_IE.js +19 -0
- package/src/components/date-picker/locale/he_IL.js +19 -0
- package/src/components/date-picker/locale/hi_IN.js +19 -0
- package/src/components/date-picker/locale/hr_HR.js +19 -0
- package/src/components/date-picker/locale/hu_HU.js +19 -0
- package/src/components/date-picker/locale/id_ID.js +19 -0
- package/src/components/date-picker/locale/is_IS.js +19 -0
- package/src/components/date-picker/locale/it_IT.js +19 -0
- package/src/components/date-picker/locale/ja_JP.js +18 -0
- package/src/components/date-picker/locale/kn_IN.js +19 -0
- package/src/components/date-picker/locale/ko_KR.js +19 -0
- package/src/components/date-picker/locale/ku_IQ.js +18 -0
- package/src/components/date-picker/locale/lv_LV.js +19 -0
- package/src/components/date-picker/locale/mk_MK.js +19 -0
- package/src/components/date-picker/locale/mn_MN.js +19 -0
- package/src/components/date-picker/locale/ms_MY.js +19 -0
- package/src/components/date-picker/locale/nb_NO.js +19 -0
- package/src/components/date-picker/locale/nl_BE.js +19 -0
- package/src/components/date-picker/locale/nl_NL.js +19 -0
- package/src/components/date-picker/locale/pl_PL.js +19 -0
- package/src/components/date-picker/locale/pt_BR.js +19 -0
- package/src/components/date-picker/locale/pt_PT.js +46 -0
- package/src/components/date-picker/locale/ro_RO.js +19 -0
- package/src/components/date-picker/locale/ru_RU.js +22 -0
- package/src/components/date-picker/locale/sk_SK.js +19 -0
- package/src/components/date-picker/locale/sl_SI.js +43 -0
- package/src/components/date-picker/locale/sr_RS.js +19 -0
- package/src/components/date-picker/locale/sv_SE.js +18 -0
- package/src/components/date-picker/locale/ta_IN.js +20 -0
- package/src/components/date-picker/locale/th_TH.js +19 -0
- package/src/components/date-picker/locale/tr_TR.js +19 -0
- package/src/components/date-picker/locale/uk_UA.js +18 -0
- package/src/components/date-picker/locale/vi_VN.js +19 -0
- package/src/components/date-picker/locale/zh_CN.js +21 -0
- package/src/components/date-picker/locale/zh_TW.js +20 -0
- package/src/components/date-picker/statusUtils.js +53 -0
- package/src/components/date-picker/style/Calendar.less +402 -0
- package/src/components/date-picker/style/DecadePanel.less +81 -0
- package/src/components/date-picker/style/MonthPanel.less +86 -0
- package/src/components/date-picker/style/MonthPicker.less +11 -0
- package/src/components/date-picker/style/Picker.less +113 -0
- package/src/components/date-picker/style/RangePicker.less +327 -0
- package/src/components/date-picker/style/TimePicker.less +151 -0
- package/src/components/date-picker/style/WeekPicker.less +21 -0
- package/src/components/date-picker/style/YearPanel.less +93 -0
- package/src/components/date-picker/style/index.js +8 -0
- package/src/components/date-picker/style/index.less +20 -0
- package/src/components/date-picker/style/presets.less +69 -0
- package/src/components/date-picker/style/status.less +94 -0
- package/src/components/date-picker/style/transitions.less +176 -0
- package/src/components/date-picker/utils.js +209 -0
- package/src/components/date-picker/wrapPicker.js +258 -0
- package/src/components/empty/__tests__/__snapshots__/demo.test.js.snap +195 -0
- package/src/components/empty/__tests__/demo.test.js +3 -0
- package/src/components/empty/__tests__/index.test.js +25 -0
- package/src/components/empty/empty.jsx +47 -0
- package/src/components/empty/index.jsx +78 -0
- package/src/components/empty/simple.jsx +20 -0
- package/src/components/empty/style/index.js +2 -0
- package/src/components/empty/style/index.less +52 -0
- package/src/components/icon/IconFont.jsx +52 -0
- package/src/components/icon/__tests__/__snapshots__/demo.test.js.snap +671 -0
- package/src/components/icon/__tests__/__snapshots__/index.test.js.snap +77 -0
- package/src/components/icon/__tests__/demo.test.js +3 -0
- package/src/components/icon/__tests__/index.test.js +236 -0
- package/src/components/icon/index.js +185 -0
- package/src/components/icon/style/index.js +2 -0
- package/src/components/icon/style/index.less +4 -0
- package/src/components/icon/twoTonePrimaryColor.js +12 -0
- package/src/components/icon/utils.js +77 -0
- package/src/components/input/ClearableLabeledInput.jsx +182 -0
- package/src/components/input/Group.jsx +41 -0
- package/src/components/input/Input.jsx +240 -0
- package/src/components/input/Password.jsx +117 -0
- package/src/components/input/ResizableTextArea.jsx +158 -0
- package/src/components/input/Search.jsx +185 -0
- package/src/components/input/TextArea.jsx +131 -0
- package/src/components/input/__tests__/Search.test.js +134 -0
- package/src/components/input/__tests__/__snapshots__/Search.test.js.snap +5 -0
- package/src/components/input/__tests__/__snapshots__/demo.test.js.snap +86 -0
- package/src/components/input/__tests__/__snapshots__/index.test.js.snap +9 -0
- package/src/components/input/__tests__/demo.test.js +3 -0
- package/src/components/input/__tests__/index.test.js +124 -0
- package/src/components/input/calculateNodeHeight.js +151 -0
- package/src/components/input/index.js +27 -0
- package/src/components/input/inputProps.js +36 -0
- package/src/components/input/style/index.js +5 -0
- package/src/components/input/style/index.less +52 -0
- package/src/components/input/style/mixin.less +453 -0
- package/src/components/input/style/search-input.less +34 -0
- package/src/components/locale/ar_EG.js +43 -0
- package/src/components/locale/bg_BG.js +43 -0
- package/src/components/locale/ca_ES.js +41 -0
- package/src/components/locale/cs_CZ.js +41 -0
- package/src/components/locale/da_DK.js +43 -0
- package/src/components/locale/de_DE.js +43 -0
- package/src/components/locale/default.js +62 -0
- package/src/components/locale/el_GR.js +43 -0
- package/src/components/locale/en_GB.js +43 -0
- package/src/components/locale/en_US.js +3 -0
- package/src/components/locale/es_ES.js +59 -0
- package/src/components/locale/et_EE.js +43 -0
- package/src/components/locale/fa_IR.js +43 -0
- package/src/components/locale/fi_FI.js +44 -0
- package/src/components/locale/fr_BE.js +47 -0
- package/src/components/locale/fr_FR.js +47 -0
- package/src/components/locale/ga_IE.js +43 -0
- package/src/components/locale/he_IL.js +43 -0
- package/src/components/locale/hi_IN.js +51 -0
- package/src/components/locale/hr_HR.js +57 -0
- package/src/components/locale/hu_HU.js +44 -0
- package/src/components/locale/hy_AM.js +109 -0
- package/src/components/locale/id_ID.js +45 -0
- package/src/components/locale/is_IS.js +43 -0
- package/src/components/locale/it_IT.js +56 -0
- package/src/components/locale/ja_JP.js +43 -0
- package/src/components/locale/kn_IN.js +51 -0
- package/src/components/locale/ko_KR.js +43 -0
- package/src/components/locale/ku_IQ.js +43 -0
- package/src/components/locale/lv_LV.js +43 -0
- package/src/components/locale/mk_MK.js +58 -0
- package/src/components/locale/mn_MN.js +43 -0
- package/src/components/locale/ms_MY.js +63 -0
- package/src/components/locale/nb_NO.js +43 -0
- package/src/components/locale/ne_NP.js +44 -0
- package/src/components/locale/nl_BE.js +43 -0
- package/src/components/locale/nl_NL.js +62 -0
- package/src/components/locale/pl_PL.js +43 -0
- package/src/components/locale/pt_BR.js +49 -0
- package/src/components/locale/pt_PT.js +44 -0
- package/src/components/locale/ro_RO.js +62 -0
- package/src/components/locale/ru_RU.js +53 -0
- package/src/components/locale/sk_SK.js +62 -0
- package/src/components/locale/sl_SI.js +43 -0
- package/src/components/locale/sr_RS.js +43 -0
- package/src/components/locale/sv_SE.js +47 -0
- package/src/components/locale/ta_IN.js +63 -0
- package/src/components/locale/th_TH.js +62 -0
- package/src/components/locale/tr_TR.js +57 -0
- package/src/components/locale/uk_UA.js +43 -0
- package/src/components/locale/vi_VN.js +43 -0
- package/src/components/locale/zh_CN.js +62 -0
- package/src/components/locale/zh_TW.js +49 -0
- package/src/components/locale-provider/LocaleReceiver.jsx +43 -0
- package/src/components/locale-provider/__tests__/__snapshots__/demo.test.js.snap +434 -0
- package/src/components/locale-provider/__tests__/__snapshots__/index.test.js.snap +22618 -0
- package/src/components/locale-provider/__tests__/demo.test.js +3 -0
- package/src/components/locale-provider/__tests__/index.test.js +271 -0
- package/src/components/locale-provider/ar_EG.js +3 -0
- package/src/components/locale-provider/bg_BG.js +3 -0
- package/src/components/locale-provider/ca_ES.js +3 -0
- package/src/components/locale-provider/cs_CZ.js +3 -0
- package/src/components/locale-provider/da_DK.js +3 -0
- package/src/components/locale-provider/de_DE.js +3 -0
- package/src/components/locale-provider/default.js +3 -0
- package/src/components/locale-provider/el_GR.js +3 -0
- package/src/components/locale-provider/en_GB.js +3 -0
- package/src/components/locale-provider/en_US.js +3 -0
- package/src/components/locale-provider/es_ES.js +3 -0
- package/src/components/locale-provider/et_EE.js +3 -0
- package/src/components/locale-provider/fa_IR.js +3 -0
- package/src/components/locale-provider/fi_FI.js +3 -0
- package/src/components/locale-provider/fr_BE.js +3 -0
- package/src/components/locale-provider/fr_FR.js +3 -0
- package/src/components/locale-provider/ga_IE.js +3 -0
- package/src/components/locale-provider/he_IL.js +3 -0
- package/src/components/locale-provider/hi_IN.js +3 -0
- package/src/components/locale-provider/hr_HR.js +3 -0
- package/src/components/locale-provider/hu_HU.js +3 -0
- package/src/components/locale-provider/hy_AM.js +3 -0
- package/src/components/locale-provider/id_ID.js +3 -0
- package/src/components/locale-provider/index.jsx +82 -0
- package/src/components/locale-provider/is_IS.js +3 -0
- package/src/components/locale-provider/it_IT.js +3 -0
- package/src/components/locale-provider/ja_JP.js +3 -0
- package/src/components/locale-provider/kn_IN.js +3 -0
- package/src/components/locale-provider/ko_KR.js +3 -0
- package/src/components/locale-provider/ku_IQ.js +3 -0
- package/src/components/locale-provider/lv_LV.js +3 -0
- package/src/components/locale-provider/mk_MK.js +3 -0
- package/src/components/locale-provider/mn_MN.js +3 -0
- package/src/components/locale-provider/ms_MY.js +3 -0
- package/src/components/locale-provider/nb_NO.js +3 -0
- package/src/components/locale-provider/ne-NP.js +3 -0
- package/src/components/locale-provider/ne_NP.js +3 -0
- package/src/components/locale-provider/nl_BE.js +3 -0
- package/src/components/locale-provider/nl_NL.js +3 -0
- package/src/components/locale-provider/pl_PL.js +3 -0
- package/src/components/locale-provider/pt_BR.js +3 -0
- package/src/components/locale-provider/pt_PT.js +3 -0
- package/src/components/locale-provider/ro_RO.js +3 -0
- package/src/components/locale-provider/ru_RU.js +3 -0
- package/src/components/locale-provider/sk_SK.js +3 -0
- package/src/components/locale-provider/sl_SI.js +3 -0
- package/src/components/locale-provider/sr_RS.js +3 -0
- package/src/components/locale-provider/style/index.js +1 -0
- package/src/components/locale-provider/style/index.less +2 -0
- package/src/components/locale-provider/sv_SE.js +3 -0
- package/src/components/locale-provider/ta_IN.js +62 -0
- package/src/components/locale-provider/th_TH.js +3 -0
- package/src/components/locale-provider/tr_TR.js +3 -0
- package/src/components/locale-provider/uk_UA.js +3 -0
- package/src/components/locale-provider/vi_VN.js +3 -0
- package/src/components/locale-provider/zh_CN.js +3 -0
- package/src/components/locale-provider/zh_TW.js +3 -0
- package/src/components/style/color/bezierEasing.less +110 -0
- package/src/components/style/color/colorPalette.less +75 -0
- package/src/components/style/color/colors.less +149 -0
- package/src/components/style/color/tinyColor.less +1184 -0
- package/src/components/style/core/base.less +510 -0
- package/src/components/style/core/iconfont.less +19 -0
- package/src/components/style/core/index.less +4 -0
- package/src/components/style/core/motion/fade.less +31 -0
- package/src/components/style/core/motion/move.less +120 -0
- package/src/components/style/core/motion/other.less +45 -0
- package/src/components/style/core/motion/slide.less +120 -0
- package/src/components/style/core/motion/swing.less +34 -0
- package/src/components/style/core/motion/zoom.less +162 -0
- package/src/components/style/core/motion.less +20 -0
- package/src/components/style/index.js +1 -0
- package/src/components/style/index.less +2 -0
- package/src/components/style/index.tsx +1 -0
- package/src/components/style/mixins/clearfix.less +13 -0
- package/src/components/style/mixins/compatibility.less +22 -0
- package/src/components/style/mixins/iconfont.less +43 -0
- package/src/components/style/mixins/index.less +10 -0
- package/src/components/style/mixins/motion.less +35 -0
- package/src/components/style/mixins/operation-unit.less +18 -0
- package/src/components/style/mixins/reset.less +13 -0
- package/src/components/style/mixins/size.less +10 -0
- package/src/components/style/mixins/typography.less +49 -0
- package/src/components/style/themes/default.less +701 -0
- package/src/components/style/themes/index.less +1 -0
- package/src/components/style/v2-compatible-reset.js +1 -0
- package/src/components/style/v2-compatible-reset.less +51 -0
- package/src/components/style/v2-compatible-reset.tsx +1 -0
- package/src/components/tag/CheckableTag.jsx +43 -0
- package/src/components/tag/Tag.jsx +145 -0
- package/src/components/tag/__tests__/__snapshots__/demo.test.js.snap +92 -0
- package/src/components/tag/__tests__/__snapshots__/index.test.js.snap +13 -0
- package/src/components/tag/__tests__/demo.test.js +3 -0
- package/src/components/tag/__tests__/index.test.js +82 -0
- package/src/components/tag/index.js +14 -0
- package/src/components/tag/style/index.js +2 -0
- package/src/components/tag/style/index.less +106 -0
- package/src/components/time-picker/__tests__/__snapshots__/demo.test.js.snap +39 -0
- package/src/components/time-picker/__tests__/__snapshots__/index.test.js.snap +5 -0
- package/src/components/time-picker/__tests__/demo.test.js +3 -0
- package/src/components/time-picker/__tests__/index.test.js +55 -0
- package/src/components/time-picker/index.jsx +267 -0
- package/src/components/time-picker/locale/ar_EG.js +5 -0
- package/src/components/time-picker/locale/bg_BG.js +5 -0
- package/src/components/time-picker/locale/ca_ES.js +5 -0
- package/src/components/time-picker/locale/cs_CZ.js +5 -0
- package/src/components/time-picker/locale/da_DK.js +5 -0
- package/src/components/time-picker/locale/de_DE.js +5 -0
- package/src/components/time-picker/locale/el_GR.js +5 -0
- package/src/components/time-picker/locale/en_GB.js +5 -0
- package/src/components/time-picker/locale/en_US.js +5 -0
- package/src/components/time-picker/locale/es_ES.js +5 -0
- package/src/components/time-picker/locale/et_EE.js +5 -0
- package/src/components/time-picker/locale/fa_IR.js +5 -0
- package/src/components/time-picker/locale/fi_FI.js +5 -0
- package/src/components/time-picker/locale/fr_BE.js +5 -0
- package/src/components/time-picker/locale/fr_FR.js +5 -0
- package/src/components/time-picker/locale/ga_IE.js +5 -0
- package/src/components/time-picker/locale/he_IL.js +5 -0
- package/src/components/time-picker/locale/hi_IN.js +5 -0
- package/src/components/time-picker/locale/hr_HR.js +5 -0
- package/src/components/time-picker/locale/hu_HU.js +5 -0
- package/src/components/time-picker/locale/id_ID.js +5 -0
- package/src/components/time-picker/locale/is_IS.js +5 -0
- package/src/components/time-picker/locale/it_IT.js +5 -0
- package/src/components/time-picker/locale/ja_JP.js +5 -0
- package/src/components/time-picker/locale/kn_IN.js +5 -0
- package/src/components/time-picker/locale/ko_KR.js +5 -0
- package/src/components/time-picker/locale/ku_IQ.js +5 -0
- package/src/components/time-picker/locale/lv_LV.js +5 -0
- package/src/components/time-picker/locale/mk_MK.js +5 -0
- package/src/components/time-picker/locale/mn_MN.js +5 -0
- package/src/components/time-picker/locale/ms_MY.js +5 -0
- package/src/components/time-picker/locale/nb_NO.js +5 -0
- package/src/components/time-picker/locale/nl_BE.js +5 -0
- package/src/components/time-picker/locale/nl_NL.js +5 -0
- package/src/components/time-picker/locale/pl_PL.js +5 -0
- package/src/components/time-picker/locale/pt_BR.js +5 -0
- package/src/components/time-picker/locale/pt_PT.js +5 -0
- package/src/components/time-picker/locale/ro_RO.js +5 -0
- package/src/components/time-picker/locale/ru_RU.js +8 -0
- package/src/components/time-picker/locale/sk_SK.js +5 -0
- package/src/components/time-picker/locale/sl_SI.js +5 -0
- package/src/components/time-picker/locale/sr_RS.js +5 -0
- package/src/components/time-picker/locale/sv_SE.js +5 -0
- package/src/components/time-picker/locale/ta_IN.js +5 -0
- package/src/components/time-picker/locale/th_TH.js +5 -0
- package/src/components/time-picker/locale/tr_TR.js +5 -0
- package/src/components/time-picker/locale/uk_UA.js +5 -0
- package/src/components/time-picker/locale/vi_VN.js +5 -0
- package/src/components/time-picker/locale/zh_CN.js +5 -0
- package/src/components/time-picker/locale/zh_TW.js +5 -0
- package/src/components/time-picker/style/index.js +2 -0
- package/src/components/time-picker/style/index.less +246 -0
- package/src/components/tooltip/Tooltip.jsx +219 -0
- package/src/components/tooltip/__tests__/__snapshots__/demo.test.js.snap +20 -0
- package/src/components/tooltip/__tests__/demo.test.js +3 -0
- package/src/components/tooltip/__tests__/tooltip.test.js +204 -0
- package/src/components/tooltip/abstractTooltipProps.js +34 -0
- package/src/components/tooltip/index.js +10 -0
- package/src/components/tooltip/placements.js +96 -0
- package/src/components/tooltip/style/index.js +2 -0
- package/src/components/tooltip/style/index.less +187 -0
- package/src/components/vc-align/Align.jsx +149 -0
- package/src/components/vc-align/index.js +3 -0
- package/src/components/vc-align/util.js +52 -0
- package/src/components/vc-calendar/assets/common/Calendar.less +106 -0
- package/src/components/vc-calendar/assets/common/FullCalendar.less +91 -0
- package/src/components/vc-calendar/assets/common/Picker.less +10 -0
- package/src/components/vc-calendar/assets/common/RangeCalendar.less +131 -0
- package/src/components/vc-calendar/assets/common/index.less +16 -0
- package/src/components/vc-calendar/assets/index/Calendar.less +301 -0
- package/src/components/vc-calendar/assets/index/DecadePanel.less +122 -0
- package/src/components/vc-calendar/assets/index/Input.less +23 -0
- package/src/components/vc-calendar/assets/index/MonthPanel.less +143 -0
- package/src/components/vc-calendar/assets/index/Picker.less +110 -0
- package/src/components/vc-calendar/assets/index/Time.less +6 -0
- package/src/components/vc-calendar/assets/index/TimePanel.less +72 -0
- package/src/components/vc-calendar/assets/index/YearPanel.less +136 -0
- package/src/components/vc-calendar/assets/index.less +10 -0
- package/src/components/vc-calendar/index.js +8 -0
- package/src/components/vc-calendar/src/Calendar.jsx +390 -0
- package/src/components/vc-calendar/src/FullCalendar.jsx +166 -0
- package/src/components/vc-calendar/src/MonthCalendar.jsx +125 -0
- package/src/components/vc-calendar/src/Picker.jsx +244 -0
- package/src/components/vc-calendar/src/RangeCalendar.jsx +1031 -0
- package/src/components/vc-calendar/src/calendar/CalendarFooter.jsx +86 -0
- package/src/components/vc-calendar/src/calendar/CalendarHeader.jsx +264 -0
- package/src/components/vc-calendar/src/calendar/OkButton.jsx +18 -0
- package/src/components/vc-calendar/src/calendar/TimePickerButton.jsx +22 -0
- package/src/components/vc-calendar/src/calendar/TodayButton.jsx +33 -0
- package/src/components/vc-calendar/src/date/DateConstants.js +4 -0
- package/src/components/vc-calendar/src/date/DateInput.jsx +226 -0
- package/src/components/vc-calendar/src/date/DateTBody.jsx +261 -0
- package/src/components/vc-calendar/src/date/DateTHead.jsx +49 -0
- package/src/components/vc-calendar/src/date/DateTable.jsx +20 -0
- package/src/components/vc-calendar/src/decade/DecadePanel.jsx +131 -0
- package/src/components/vc-calendar/src/full-calendar/CalendarHeader.jsx +134 -0
- package/src/components/vc-calendar/src/index.js +3 -0
- package/src/components/vc-calendar/src/locale/ar_EG.js +27 -0
- package/src/components/vc-calendar/src/locale/bg_BG.js +27 -0
- package/src/components/vc-calendar/src/locale/ca_ES.js +27 -0
- package/src/components/vc-calendar/src/locale/cs_CZ.js +27 -0
- package/src/components/vc-calendar/src/locale/da_DK.js +27 -0
- package/src/components/vc-calendar/src/locale/de_DE.js +27 -0
- package/src/components/vc-calendar/src/locale/el_GR.js +27 -0
- package/src/components/vc-calendar/src/locale/en_GB.js +27 -0
- package/src/components/vc-calendar/src/locale/en_US.js +28 -0
- package/src/components/vc-calendar/src/locale/es_ES.js +27 -0
- package/src/components/vc-calendar/src/locale/et_EE.js +27 -0
- package/src/components/vc-calendar/src/locale/fa_IR.js +27 -0
- package/src/components/vc-calendar/src/locale/fi_FI.js +27 -0
- package/src/components/vc-calendar/src/locale/fr_BE.js +27 -0
- package/src/components/vc-calendar/src/locale/fr_FR.js +27 -0
- package/src/components/vc-calendar/src/locale/ga_IE.js +28 -0
- package/src/components/vc-calendar/src/locale/he_IL.js +28 -0
- package/src/components/vc-calendar/src/locale/hi_IN.js +28 -0
- package/src/components/vc-calendar/src/locale/hr_HR.js +28 -0
- package/src/components/vc-calendar/src/locale/hu_HU.js +27 -0
- package/src/components/vc-calendar/src/locale/id_ID.js +28 -0
- package/src/components/vc-calendar/src/locale/is_IS.js +27 -0
- package/src/components/vc-calendar/src/locale/it_IT.js +27 -0
- package/src/components/vc-calendar/src/locale/ja_JP.js +26 -0
- package/src/components/vc-calendar/src/locale/kn_IN.js +28 -0
- package/src/components/vc-calendar/src/locale/ko_KR.js +27 -0
- package/src/components/vc-calendar/src/locale/ku_IQ.js +27 -0
- package/src/components/vc-calendar/src/locale/lv_LV.js +27 -0
- package/src/components/vc-calendar/src/locale/mk_MK.js +27 -0
- package/src/components/vc-calendar/src/locale/mm_MM.js +28 -0
- package/src/components/vc-calendar/src/locale/mn_MN.js +28 -0
- package/src/components/vc-calendar/src/locale/ms_MY.js +27 -0
- package/src/components/vc-calendar/src/locale/nb_NO.js +27 -0
- package/src/components/vc-calendar/src/locale/nl_BE.js +27 -0
- package/src/components/vc-calendar/src/locale/nl_NL.js +27 -0
- package/src/components/vc-calendar/src/locale/pl_PL.js +27 -0
- package/src/components/vc-calendar/src/locale/pt_BR.js +27 -0
- package/src/components/vc-calendar/src/locale/pt_PT.js +27 -0
- package/src/components/vc-calendar/src/locale/ro_RO.js +28 -0
- package/src/components/vc-calendar/src/locale/ru_RU.js +27 -0
- package/src/components/vc-calendar/src/locale/sk_SK.js +28 -0
- package/src/components/vc-calendar/src/locale/sl_SI.js +27 -0
- package/src/components/vc-calendar/src/locale/sr_RS.js +27 -0
- package/src/components/vc-calendar/src/locale/sv_SE.js +27 -0
- package/src/components/vc-calendar/src/locale/ta_IN.js +28 -0
- package/src/components/vc-calendar/src/locale/th_TH.js +27 -0
- package/src/components/vc-calendar/src/locale/tr_TR.js +27 -0
- package/src/components/vc-calendar/src/locale/ug_CN.js +26 -0
- package/src/components/vc-calendar/src/locale/uk_UA.js +27 -0
- package/src/components/vc-calendar/src/locale/vi_VN.js +28 -0
- package/src/components/vc-calendar/src/locale/zh_CN.js +27 -0
- package/src/components/vc-calendar/src/locale/zh_TW.js +26 -0
- package/src/components/vc-calendar/src/mixin/CalendarMixin.js +122 -0
- package/src/components/vc-calendar/src/mixin/CommonMixin.js +26 -0
- package/src/components/vc-calendar/src/month/MonthPanel.jsx +123 -0
- package/src/components/vc-calendar/src/month/MonthTable.jsx +138 -0
- package/src/components/vc-calendar/src/picker/placements.js +35 -0
- package/src/components/vc-calendar/src/range-calendar/CalendarPart.jsx +171 -0
- package/src/components/vc-calendar/src/util/index.js +113 -0
- package/src/components/vc-calendar/src/util/toTime.js +15 -0
- package/src/components/vc-calendar/src/year/YearPanel.jsx +167 -0
- package/src/components/vc-pagination/locale/en_US.js +15 -0
- package/src/components/vc-select/DropdownMenu.jsx +216 -0
- package/src/components/vc-select/OptGroup.jsx +8 -0
- package/src/components/vc-select/Option.jsx +11 -0
- package/src/components/vc-select/PropTypes.js +59 -0
- package/src/components/vc-select/Select.jsx +1716 -0
- package/src/components/vc-select/SelectTrigger.jsx +259 -0
- package/src/components/vc-select/assets/index.less +541 -0
- package/src/components/vc-select/index.js +11 -0
- package/src/components/vc-select/util.js +223 -0
- package/src/components/vc-time-picker/Combobox.jsx +214 -0
- package/src/components/vc-time-picker/Header.jsx +187 -0
- package/src/components/vc-time-picker/Panel.jsx +225 -0
- package/src/components/vc-time-picker/Select.jsx +140 -0
- package/src/components/vc-time-picker/TimePicker.jsx +386 -0
- package/src/components/vc-time-picker/assets/index/Header.less +22 -0
- package/src/components/vc-time-picker/assets/index/Panel.less +29 -0
- package/src/components/vc-time-picker/assets/index/Picker.less +25 -0
- package/src/components/vc-time-picker/assets/index/Select.less +62 -0
- package/src/components/vc-time-picker/assets/index.less +44 -0
- package/src/components/vc-time-picker/index.js +2 -0
- package/src/components/vc-time-picker/placements.js +35 -0
- package/src/components/vc-tooltip/Content.jsx +23 -0
- package/src/components/vc-tooltip/Tooltip.jsx +106 -0
- package/src/components/vc-tooltip/assets/boostrap/anim.less +61 -0
- package/src/components/vc-tooltip/assets/bootstrap.less +171 -0
- package/src/components/vc-tooltip/assets/bootstrap_white.less +190 -0
- package/src/components/vc-tooltip/index.js +4 -0
- package/src/components/vc-tooltip/placements.js +83 -0
- package/src/components/vc-trigger/LazyRenderBox.jsx +22 -0
- package/src/components/vc-trigger/Popup.jsx +336 -0
- package/src/components/vc-trigger/PopupInner.jsx +25 -0
- package/src/components/vc-trigger/Trigger.jsx +663 -0
- package/src/components/vc-trigger/assets/index.less +72 -0
- package/src/components/vc-trigger/assets/mask.less +65 -0
- package/src/components/vc-trigger/index.js +3 -0
- package/src/components/vc-trigger/index.md +160 -0
- package/src/components/vc-trigger/t.js +665 -0
- package/src/components/vc-trigger/utils.js +27 -0
- package/src/components/vc-util/Dom/addEventListener.js +5 -0
- package/src/components/vc-util/Dom/class.js +28 -0
- package/src/components/vc-util/Dom/contains.js +11 -0
- package/src/components/vc-util/warning.js +38 -0
- package/src/index.js +44 -0
- package/types/index.d.ts +112 -0
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
export default {
|
|
2
|
+
today: 'Hôm nay',
|
|
3
|
+
now: 'Bây giờ',
|
|
4
|
+
backToToday: 'Trở về hôm nay',
|
|
5
|
+
ok: 'Ok',
|
|
6
|
+
clear: 'Xóa',
|
|
7
|
+
month: 'Tháng',
|
|
8
|
+
year: 'Năm',
|
|
9
|
+
timeSelect: 'Chọn thời gian',
|
|
10
|
+
dateSelect: 'Chọn ngày',
|
|
11
|
+
weekSelect: 'Chọn tuần',
|
|
12
|
+
monthSelect: 'Chọn tháng',
|
|
13
|
+
yearSelect: 'Chọn năm',
|
|
14
|
+
decadeSelect: 'Chọn thập kỷ',
|
|
15
|
+
yearFormat: 'YYYY',
|
|
16
|
+
dateFormat: 'D/M/YYYY',
|
|
17
|
+
dayFormat: 'D',
|
|
18
|
+
dateTimeFormat: 'D/M/YYYY HH:mm:ss',
|
|
19
|
+
monthBeforeYear: true,
|
|
20
|
+
previousMonth: 'Tháng trước (PageUp)',
|
|
21
|
+
nextMonth: 'Tháng sau (PageDown)',
|
|
22
|
+
previousYear: 'Năm trước (Control + left)',
|
|
23
|
+
nextYear: 'Năm sau (Control + right)',
|
|
24
|
+
previousDecade: 'Thập kỷ trước',
|
|
25
|
+
nextDecade: 'Thập kỷ sau',
|
|
26
|
+
previousCentury: 'Thế kỷ trước',
|
|
27
|
+
nextCentury: 'Thế kỷ sau',
|
|
28
|
+
};
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
export default {
|
|
2
|
+
today: '今天',
|
|
3
|
+
now: '此刻',
|
|
4
|
+
backToToday: '返回今天',
|
|
5
|
+
ok: '确定',
|
|
6
|
+
timeSelect: '选择时间',
|
|
7
|
+
dateSelect: '选择日期',
|
|
8
|
+
weekSelect: '选择周',
|
|
9
|
+
clear: '清除',
|
|
10
|
+
month: '月',
|
|
11
|
+
year: '年',
|
|
12
|
+
previousMonth: '上个月 (翻页上键)',
|
|
13
|
+
nextMonth: '下个月 (翻页下键)',
|
|
14
|
+
monthSelect: '选择月份',
|
|
15
|
+
yearSelect: '选择年份',
|
|
16
|
+
decadeSelect: '选择年代',
|
|
17
|
+
yearFormat: 'YYYY年',
|
|
18
|
+
dayFormat: 'D日',
|
|
19
|
+
dateFormat: 'YYYY年M月D日',
|
|
20
|
+
dateTimeFormat: 'YYYY年M月D日 HH时mm分ss秒',
|
|
21
|
+
previousYear: '上一年 (Control键加左方向键)',
|
|
22
|
+
nextYear: '下一年 (Control键加右方向键)',
|
|
23
|
+
previousDecade: '上一年代',
|
|
24
|
+
nextDecade: '下一年代',
|
|
25
|
+
previousCentury: '上一世纪',
|
|
26
|
+
nextCentury: '下一世纪',
|
|
27
|
+
};
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export default {
|
|
2
|
+
today: '今天',
|
|
3
|
+
now: '此刻',
|
|
4
|
+
backToToday: '返回今天',
|
|
5
|
+
ok: '確定',
|
|
6
|
+
timeSelect: '選擇時間',
|
|
7
|
+
dateSelect: '選擇日期',
|
|
8
|
+
clear: '清除',
|
|
9
|
+
month: '月',
|
|
10
|
+
year: '年',
|
|
11
|
+
previousMonth: '上個月 (翻頁上鍵)',
|
|
12
|
+
nextMonth: '下個月 (翻頁下鍵)',
|
|
13
|
+
monthSelect: '選擇月份',
|
|
14
|
+
yearSelect: '選擇年份',
|
|
15
|
+
decadeSelect: '選擇年代',
|
|
16
|
+
yearFormat: 'YYYY年',
|
|
17
|
+
dayFormat: 'D日',
|
|
18
|
+
dateFormat: 'YYYY年M月D日',
|
|
19
|
+
dateTimeFormat: 'YYYY年M月D日 HH時mm分ss秒',
|
|
20
|
+
previousYear: '上一年 (Control鍵加左方向鍵)',
|
|
21
|
+
nextYear: '下一年 (Control鍵加右方向鍵)',
|
|
22
|
+
previousDecade: '上一年代',
|
|
23
|
+
nextDecade: '下一年代',
|
|
24
|
+
previousCentury: '上一世紀',
|
|
25
|
+
nextCentury: '下一世紀',
|
|
26
|
+
};
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
import PropTypes from '../../../_util/vue-types';
|
|
2
|
+
import BaseMixin from '../../../_util/BaseMixin';
|
|
3
|
+
import { hasProp } from '../../../_util/props-util';
|
|
4
|
+
import moment from 'moment';
|
|
5
|
+
import { isAllowedDate, getTodayTime } from '../util/index';
|
|
6
|
+
function noop() {}
|
|
7
|
+
|
|
8
|
+
export function getNowByCurrentStateValue(value) {
|
|
9
|
+
let ret;
|
|
10
|
+
if (value) {
|
|
11
|
+
ret = getTodayTime(value);
|
|
12
|
+
} else {
|
|
13
|
+
ret = moment();
|
|
14
|
+
}
|
|
15
|
+
return ret;
|
|
16
|
+
}
|
|
17
|
+
function isMoment(value) {
|
|
18
|
+
if (Array.isArray(value)) {
|
|
19
|
+
return (
|
|
20
|
+
value.length === 0 || value.findIndex(val => val === undefined || moment.isMoment(val)) !== -1
|
|
21
|
+
);
|
|
22
|
+
} else {
|
|
23
|
+
return value === undefined || moment.isMoment(value);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
const MomentType = PropTypes.custom(isMoment);
|
|
27
|
+
const CalendarMixin = {
|
|
28
|
+
mixins: [BaseMixin],
|
|
29
|
+
name: 'CalendarMixinWrapper',
|
|
30
|
+
props: {
|
|
31
|
+
value: MomentType,
|
|
32
|
+
defaultValue: MomentType,
|
|
33
|
+
},
|
|
34
|
+
|
|
35
|
+
data() {
|
|
36
|
+
const props = this.$props;
|
|
37
|
+
const sValue = props.value || props.defaultValue || getNowByCurrentStateValue();
|
|
38
|
+
return {
|
|
39
|
+
sValue,
|
|
40
|
+
sSelectedValue: props.selectedValue || props.defaultSelectedValue,
|
|
41
|
+
};
|
|
42
|
+
},
|
|
43
|
+
watch: {
|
|
44
|
+
value(val) {
|
|
45
|
+
const sValue = val || this.defaultValue || getNowByCurrentStateValue(this.sValue);
|
|
46
|
+
this.setState({
|
|
47
|
+
sValue,
|
|
48
|
+
});
|
|
49
|
+
},
|
|
50
|
+
selectedValue(val) {
|
|
51
|
+
this.setState({
|
|
52
|
+
sSelectedValue: val,
|
|
53
|
+
});
|
|
54
|
+
},
|
|
55
|
+
},
|
|
56
|
+
methods: {
|
|
57
|
+
onSelect(value, cause) {
|
|
58
|
+
if (value) {
|
|
59
|
+
this.setValue(value);
|
|
60
|
+
}
|
|
61
|
+
this.setSelectedValue(value, cause);
|
|
62
|
+
},
|
|
63
|
+
|
|
64
|
+
renderRoot(newProps) {
|
|
65
|
+
const props = this.$props;
|
|
66
|
+
const prefixCls = props.prefixCls;
|
|
67
|
+
|
|
68
|
+
const className = {
|
|
69
|
+
[prefixCls]: 1,
|
|
70
|
+
[`${prefixCls}-hidden`]: !props.visible,
|
|
71
|
+
// [props.className]: !!props.className,
|
|
72
|
+
[newProps.class]: !!newProps.class,
|
|
73
|
+
};
|
|
74
|
+
return (
|
|
75
|
+
<div
|
|
76
|
+
ref="rootInstance"
|
|
77
|
+
class={className}
|
|
78
|
+
tabIndex="0"
|
|
79
|
+
onKeydown={this.onKeyDown || noop}
|
|
80
|
+
onBlur={this.onBlur || noop}
|
|
81
|
+
>
|
|
82
|
+
{newProps.children}
|
|
83
|
+
</div>
|
|
84
|
+
);
|
|
85
|
+
},
|
|
86
|
+
|
|
87
|
+
setSelectedValue(selectedValue, cause) {
|
|
88
|
+
// if (this.isAllowedDate(selectedValue)) {
|
|
89
|
+
if (!hasProp(this, 'selectedValue')) {
|
|
90
|
+
this.setState({
|
|
91
|
+
sSelectedValue: selectedValue,
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
this.__emit('select', selectedValue, cause);
|
|
95
|
+
// }
|
|
96
|
+
},
|
|
97
|
+
|
|
98
|
+
setValue(value) {
|
|
99
|
+
const originalValue = this.sValue;
|
|
100
|
+
if (!hasProp(this, 'value')) {
|
|
101
|
+
this.setState({
|
|
102
|
+
sValue: value,
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
if (
|
|
106
|
+
(originalValue && value && !originalValue.isSame(value)) ||
|
|
107
|
+
(!originalValue && value) ||
|
|
108
|
+
(originalValue && !value)
|
|
109
|
+
) {
|
|
110
|
+
this.__emit('change', value);
|
|
111
|
+
}
|
|
112
|
+
},
|
|
113
|
+
|
|
114
|
+
isAllowedDate(value) {
|
|
115
|
+
const disabledDate = this.disabledDate;
|
|
116
|
+
const disabledTime = this.disabledTime;
|
|
117
|
+
return isAllowedDate(value, disabledDate, disabledTime);
|
|
118
|
+
},
|
|
119
|
+
},
|
|
120
|
+
};
|
|
121
|
+
|
|
122
|
+
export default CalendarMixin;
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export default {
|
|
2
|
+
methods: {
|
|
3
|
+
getFormat() {
|
|
4
|
+
let { format } = this;
|
|
5
|
+
const { locale, timePicker } = this;
|
|
6
|
+
if (!format) {
|
|
7
|
+
if (timePicker) {
|
|
8
|
+
format = locale.dateTimeFormat;
|
|
9
|
+
} else {
|
|
10
|
+
format = locale.dateFormat;
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
return format;
|
|
14
|
+
},
|
|
15
|
+
focus() {
|
|
16
|
+
if (this.focusElement) {
|
|
17
|
+
this.focusElement.focus();
|
|
18
|
+
} else if (this.$refs.rootInstance) {
|
|
19
|
+
this.$refs.rootInstance.focus();
|
|
20
|
+
}
|
|
21
|
+
},
|
|
22
|
+
saveFocusElement(focusElement) {
|
|
23
|
+
this.focusElement = focusElement;
|
|
24
|
+
},
|
|
25
|
+
},
|
|
26
|
+
};
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
import PropTypes from '../../../_util/vue-types';
|
|
2
|
+
import BaseMixin from '../../../_util/BaseMixin';
|
|
3
|
+
import { hasProp, getListeners } from '../../../_util/props-util';
|
|
4
|
+
import MonthTable from './MonthTable';
|
|
5
|
+
|
|
6
|
+
function goYear(direction) {
|
|
7
|
+
this.changeYear(direction);
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
function noop() {}
|
|
11
|
+
|
|
12
|
+
const MonthPanel = {
|
|
13
|
+
name: 'MonthPanel',
|
|
14
|
+
mixins: [BaseMixin],
|
|
15
|
+
props: {
|
|
16
|
+
value: PropTypes.any,
|
|
17
|
+
defaultValue: PropTypes.any,
|
|
18
|
+
selectedValue: PropTypes.any,
|
|
19
|
+
cellRender: PropTypes.any,
|
|
20
|
+
contentRender: PropTypes.any,
|
|
21
|
+
locale: PropTypes.any,
|
|
22
|
+
rootPrefixCls: PropTypes.string,
|
|
23
|
+
// onChange: PropTypes.func,
|
|
24
|
+
disabledDate: PropTypes.func,
|
|
25
|
+
// onSelect: PropTypes.func,
|
|
26
|
+
renderFooter: PropTypes.func,
|
|
27
|
+
changeYear: PropTypes.func.def(noop),
|
|
28
|
+
},
|
|
29
|
+
|
|
30
|
+
data() {
|
|
31
|
+
const { value, defaultValue } = this;
|
|
32
|
+
// bind methods
|
|
33
|
+
this.nextYear = goYear.bind(this, 1);
|
|
34
|
+
this.previousYear = goYear.bind(this, -1);
|
|
35
|
+
return {
|
|
36
|
+
sValue: value || defaultValue,
|
|
37
|
+
};
|
|
38
|
+
},
|
|
39
|
+
watch: {
|
|
40
|
+
value(val) {
|
|
41
|
+
this.setState({
|
|
42
|
+
sValue: val,
|
|
43
|
+
});
|
|
44
|
+
},
|
|
45
|
+
},
|
|
46
|
+
methods: {
|
|
47
|
+
setAndSelectValue(value) {
|
|
48
|
+
this.setValue(value);
|
|
49
|
+
this.__emit('select', value);
|
|
50
|
+
},
|
|
51
|
+
|
|
52
|
+
setValue(value) {
|
|
53
|
+
if (hasProp(this, 'value')) {
|
|
54
|
+
this.setState({
|
|
55
|
+
sValue: value,
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
},
|
|
59
|
+
},
|
|
60
|
+
|
|
61
|
+
render() {
|
|
62
|
+
const {
|
|
63
|
+
sValue,
|
|
64
|
+
cellRender,
|
|
65
|
+
contentRender,
|
|
66
|
+
locale,
|
|
67
|
+
rootPrefixCls,
|
|
68
|
+
disabledDate,
|
|
69
|
+
renderFooter,
|
|
70
|
+
selectedValue,
|
|
71
|
+
} = this;
|
|
72
|
+
const year = sValue.year();
|
|
73
|
+
const prefixCls = `${rootPrefixCls}-month-panel`;
|
|
74
|
+
|
|
75
|
+
const footer = renderFooter && renderFooter('month');
|
|
76
|
+
return (
|
|
77
|
+
<div class={prefixCls}>
|
|
78
|
+
<div>
|
|
79
|
+
<div class={`${prefixCls}-header`}>
|
|
80
|
+
<a
|
|
81
|
+
class={`${prefixCls}-prev-year-btn`}
|
|
82
|
+
role="button"
|
|
83
|
+
onClick={this.previousYear}
|
|
84
|
+
title={locale.previousYear}
|
|
85
|
+
/>
|
|
86
|
+
|
|
87
|
+
<a
|
|
88
|
+
class={`${prefixCls}-year-select`}
|
|
89
|
+
role="button"
|
|
90
|
+
onClick={getListeners(this).yearPanelShow || noop}
|
|
91
|
+
title={locale.yearSelect}
|
|
92
|
+
>
|
|
93
|
+
<span class={`${prefixCls}-year-select-content`}>{year}</span>
|
|
94
|
+
<span class={`${prefixCls}-year-select-arrow`}>x</span>
|
|
95
|
+
</a>
|
|
96
|
+
|
|
97
|
+
<a
|
|
98
|
+
class={`${prefixCls}-next-year-btn`}
|
|
99
|
+
role="button"
|
|
100
|
+
onClick={this.nextYear}
|
|
101
|
+
title={locale.nextYear}
|
|
102
|
+
/>
|
|
103
|
+
</div>
|
|
104
|
+
<div class={`${prefixCls}-body`}>
|
|
105
|
+
<MonthTable
|
|
106
|
+
disabledDate={disabledDate}
|
|
107
|
+
onSelect={this.setAndSelectValue}
|
|
108
|
+
locale={locale}
|
|
109
|
+
value={sValue}
|
|
110
|
+
selectedValue={selectedValue}
|
|
111
|
+
cellRender={cellRender}
|
|
112
|
+
contentRender={contentRender}
|
|
113
|
+
prefixCls={prefixCls}
|
|
114
|
+
/>
|
|
115
|
+
</div>
|
|
116
|
+
{footer && <div class={`${prefixCls}-footer`}>{footer}</div>}
|
|
117
|
+
</div>
|
|
118
|
+
</div>
|
|
119
|
+
);
|
|
120
|
+
},
|
|
121
|
+
};
|
|
122
|
+
|
|
123
|
+
export default MonthPanel;
|
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
import PropTypes from '../../../_util/vue-types';
|
|
2
|
+
import BaseMixin from '../../../_util/BaseMixin';
|
|
3
|
+
import { getTodayTime, getMonthName } from '../util/index';
|
|
4
|
+
|
|
5
|
+
const ROW = 4;
|
|
6
|
+
const COL = 3;
|
|
7
|
+
|
|
8
|
+
function noop() {}
|
|
9
|
+
|
|
10
|
+
const MonthTable = {
|
|
11
|
+
name: 'MonthTable',
|
|
12
|
+
mixins: [BaseMixin],
|
|
13
|
+
props: {
|
|
14
|
+
cellRender: PropTypes.func,
|
|
15
|
+
prefixCls: PropTypes.string,
|
|
16
|
+
value: PropTypes.object,
|
|
17
|
+
selectedValue: PropTypes.object,
|
|
18
|
+
locale: PropTypes.any,
|
|
19
|
+
contentRender: PropTypes.any,
|
|
20
|
+
disabledDate: PropTypes.func,
|
|
21
|
+
},
|
|
22
|
+
data() {
|
|
23
|
+
return {
|
|
24
|
+
sValue: this.value,
|
|
25
|
+
};
|
|
26
|
+
},
|
|
27
|
+
watch: {
|
|
28
|
+
value(val) {
|
|
29
|
+
this.setState({
|
|
30
|
+
sValue: val,
|
|
31
|
+
});
|
|
32
|
+
},
|
|
33
|
+
},
|
|
34
|
+
methods: {
|
|
35
|
+
setAndSelectValue(value) {
|
|
36
|
+
this.setState({
|
|
37
|
+
sValue: value,
|
|
38
|
+
});
|
|
39
|
+
this.__emit('select', value);
|
|
40
|
+
},
|
|
41
|
+
chooseMonth(month) {
|
|
42
|
+
const next = this.sValue.clone();
|
|
43
|
+
next.month(month);
|
|
44
|
+
this.setAndSelectValue(next);
|
|
45
|
+
},
|
|
46
|
+
months() {
|
|
47
|
+
const value = this.sValue;
|
|
48
|
+
const current = value.clone();
|
|
49
|
+
const months = [];
|
|
50
|
+
let index = 0;
|
|
51
|
+
for (let rowIndex = 0; rowIndex < ROW; rowIndex++) {
|
|
52
|
+
months[rowIndex] = [];
|
|
53
|
+
for (let colIndex = 0; colIndex < COL; colIndex++) {
|
|
54
|
+
current.month(index);
|
|
55
|
+
const content = getMonthName(current);
|
|
56
|
+
months[rowIndex][colIndex] = {
|
|
57
|
+
value: index,
|
|
58
|
+
content,
|
|
59
|
+
title: content,
|
|
60
|
+
};
|
|
61
|
+
index++;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
return months;
|
|
65
|
+
},
|
|
66
|
+
},
|
|
67
|
+
|
|
68
|
+
render() {
|
|
69
|
+
const props = this.$props;
|
|
70
|
+
const value = this.sValue;
|
|
71
|
+
const { selectedValue } = props;
|
|
72
|
+
const today = getTodayTime(value);
|
|
73
|
+
const months = this.months();
|
|
74
|
+
const { prefixCls, locale, contentRender, cellRender, disabledDate } = props;
|
|
75
|
+
|
|
76
|
+
// 只有当 selectedValue 存在且与当前面板年份相同时,才显示选中状态
|
|
77
|
+
const hasSelectedValue = selectedValue && selectedValue.year() === value.year();
|
|
78
|
+
const selectedMonth = hasSelectedValue ? selectedValue.month() : -1;
|
|
79
|
+
|
|
80
|
+
const monthsEls = months.map((month, index) => {
|
|
81
|
+
const tds = month.map(monthData => {
|
|
82
|
+
let disabled = false;
|
|
83
|
+
if (disabledDate) {
|
|
84
|
+
const testValue = value.clone();
|
|
85
|
+
testValue.month(monthData.value);
|
|
86
|
+
disabled = disabledDate(testValue);
|
|
87
|
+
}
|
|
88
|
+
const classNameMap = {
|
|
89
|
+
[`${prefixCls}-cell`]: 1,
|
|
90
|
+
[`${prefixCls}-cell-disabled`]: disabled,
|
|
91
|
+
[`${prefixCls}-selected-cell`]: monthData.value === selectedMonth,
|
|
92
|
+
[`${prefixCls}-current-cell`]:
|
|
93
|
+
today.year() === value.year() && monthData.value === today.month(),
|
|
94
|
+
};
|
|
95
|
+
let cellEl;
|
|
96
|
+
if (cellRender) {
|
|
97
|
+
const currentValue = value.clone();
|
|
98
|
+
currentValue.month(monthData.value);
|
|
99
|
+
cellEl = cellRender(currentValue, locale);
|
|
100
|
+
} else {
|
|
101
|
+
let content;
|
|
102
|
+
if (contentRender) {
|
|
103
|
+
const currentValue = value.clone();
|
|
104
|
+
currentValue.month(monthData.value);
|
|
105
|
+
content = contentRender(currentValue, locale);
|
|
106
|
+
} else {
|
|
107
|
+
content = monthData.content;
|
|
108
|
+
}
|
|
109
|
+
cellEl = <a class={`${prefixCls}-month`}>{content}</a>;
|
|
110
|
+
}
|
|
111
|
+
return (
|
|
112
|
+
<td
|
|
113
|
+
role="gridcell"
|
|
114
|
+
key={monthData.value}
|
|
115
|
+
onClick={disabled ? noop : () => this.chooseMonth(monthData.value)}
|
|
116
|
+
title={monthData.title}
|
|
117
|
+
class={classNameMap}
|
|
118
|
+
>
|
|
119
|
+
{cellEl}
|
|
120
|
+
</td>
|
|
121
|
+
);
|
|
122
|
+
});
|
|
123
|
+
return (
|
|
124
|
+
<tr key={index} role="row">
|
|
125
|
+
{tds}
|
|
126
|
+
</tr>
|
|
127
|
+
);
|
|
128
|
+
});
|
|
129
|
+
|
|
130
|
+
return (
|
|
131
|
+
<table class={`${prefixCls}-table`} cellSpacing="0" role="grid">
|
|
132
|
+
<tbody class={`${prefixCls}-tbody`}>{monthsEls}</tbody>
|
|
133
|
+
</table>
|
|
134
|
+
);
|
|
135
|
+
},
|
|
136
|
+
};
|
|
137
|
+
|
|
138
|
+
export default MonthTable;
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
const autoAdjustOverflow = {
|
|
2
|
+
adjustX: 1,
|
|
3
|
+
adjustY: 1,
|
|
4
|
+
};
|
|
5
|
+
|
|
6
|
+
const targetOffset = [0, 0];
|
|
7
|
+
|
|
8
|
+
const placements = {
|
|
9
|
+
bottomLeft: {
|
|
10
|
+
points: ['tl', 'bl'],
|
|
11
|
+
overflow: autoAdjustOverflow,
|
|
12
|
+
offset: [0, 4],
|
|
13
|
+
targetOffset,
|
|
14
|
+
},
|
|
15
|
+
bottomRight: {
|
|
16
|
+
points: ['tr', 'br'],
|
|
17
|
+
overflow: autoAdjustOverflow,
|
|
18
|
+
offset: [0, 4],
|
|
19
|
+
targetOffset,
|
|
20
|
+
},
|
|
21
|
+
topRight: {
|
|
22
|
+
points: ['br', 'tr'],
|
|
23
|
+
overflow: autoAdjustOverflow,
|
|
24
|
+
offset: [0, -4],
|
|
25
|
+
targetOffset,
|
|
26
|
+
},
|
|
27
|
+
topLeft: {
|
|
28
|
+
points: ['bl', 'tl'],
|
|
29
|
+
overflow: autoAdjustOverflow,
|
|
30
|
+
offset: [0, -4],
|
|
31
|
+
targetOffset,
|
|
32
|
+
},
|
|
33
|
+
};
|
|
34
|
+
|
|
35
|
+
export default placements;
|
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
import PropTypes from '../../../_util/vue-types';
|
|
2
|
+
import BaseMixin from '../../../_util/BaseMixin';
|
|
3
|
+
import { getOptionProps, getComponentFromProp, getListeners } from '../../../_util/props-util';
|
|
4
|
+
import { cloneElement } from '../../../_util/vnode';
|
|
5
|
+
import CalendarHeader from '../calendar/CalendarHeader';
|
|
6
|
+
import DateTable from '../date/DateTable';
|
|
7
|
+
import DateInput from '../date/DateInput';
|
|
8
|
+
import { getTimeConfig } from '../util/index';
|
|
9
|
+
function noop() {}
|
|
10
|
+
const CalendarPart = {
|
|
11
|
+
mixins: [BaseMixin],
|
|
12
|
+
props: {
|
|
13
|
+
prefixCls: PropTypes.string,
|
|
14
|
+
value: PropTypes.any,
|
|
15
|
+
hoverValue: PropTypes.any,
|
|
16
|
+
selectedValue: PropTypes.any,
|
|
17
|
+
direction: PropTypes.any,
|
|
18
|
+
locale: PropTypes.any,
|
|
19
|
+
showDateInput: PropTypes.bool,
|
|
20
|
+
showTimePicker: PropTypes.bool,
|
|
21
|
+
showWeekNumber: PropTypes.bool,
|
|
22
|
+
format: PropTypes.any,
|
|
23
|
+
placeholder: PropTypes.any,
|
|
24
|
+
disabledDate: PropTypes.any,
|
|
25
|
+
timePicker: PropTypes.any,
|
|
26
|
+
disabledTime: PropTypes.any,
|
|
27
|
+
disabledMonth: PropTypes.any,
|
|
28
|
+
mode: PropTypes.any,
|
|
29
|
+
// onInputSelect: PropTypes.func,
|
|
30
|
+
timePickerDisabledTime: PropTypes.object,
|
|
31
|
+
enableNext: PropTypes.any,
|
|
32
|
+
enablePrev: PropTypes.any,
|
|
33
|
+
clearIcon: PropTypes.any,
|
|
34
|
+
dateRender: PropTypes.func,
|
|
35
|
+
inputMode: PropTypes.string,
|
|
36
|
+
inputReadOnly: PropTypes.bool,
|
|
37
|
+
},
|
|
38
|
+
render() {
|
|
39
|
+
const { $props: props } = this;
|
|
40
|
+
const {
|
|
41
|
+
prefixCls,
|
|
42
|
+
value,
|
|
43
|
+
hoverValue,
|
|
44
|
+
selectedValue,
|
|
45
|
+
mode,
|
|
46
|
+
direction,
|
|
47
|
+
locale,
|
|
48
|
+
format,
|
|
49
|
+
placeholder,
|
|
50
|
+
disabledDate,
|
|
51
|
+
timePicker,
|
|
52
|
+
disabledTime,
|
|
53
|
+
timePickerDisabledTime,
|
|
54
|
+
showTimePicker,
|
|
55
|
+
enablePrev,
|
|
56
|
+
enableNext,
|
|
57
|
+
disabledMonth,
|
|
58
|
+
showDateInput,
|
|
59
|
+
dateRender,
|
|
60
|
+
showWeekNumber,
|
|
61
|
+
showClear,
|
|
62
|
+
inputMode,
|
|
63
|
+
inputReadOnly,
|
|
64
|
+
} = props;
|
|
65
|
+
const clearIcon = getComponentFromProp(this, 'clearIcon');
|
|
66
|
+
const {
|
|
67
|
+
inputChange = noop,
|
|
68
|
+
inputSelect = noop,
|
|
69
|
+
valueChange = noop,
|
|
70
|
+
panelChange = noop,
|
|
71
|
+
select = noop,
|
|
72
|
+
dayHover = noop,
|
|
73
|
+
} = getListeners(this);
|
|
74
|
+
const shouldShowTimePicker = showTimePicker && timePicker;
|
|
75
|
+
const disabledTimeConfig =
|
|
76
|
+
shouldShowTimePicker && disabledTime ? getTimeConfig(selectedValue, disabledTime) : null;
|
|
77
|
+
const rangeClassName = `${prefixCls}-range`;
|
|
78
|
+
const newProps = {
|
|
79
|
+
locale,
|
|
80
|
+
value,
|
|
81
|
+
prefixCls,
|
|
82
|
+
showTimePicker,
|
|
83
|
+
};
|
|
84
|
+
const index = direction === 'left' ? 0 : 1;
|
|
85
|
+
let timePickerEle = null;
|
|
86
|
+
if (shouldShowTimePicker) {
|
|
87
|
+
const timePickerProps = getOptionProps(timePicker);
|
|
88
|
+
timePickerEle = cloneElement(timePicker, {
|
|
89
|
+
props: {
|
|
90
|
+
showHour: true,
|
|
91
|
+
showMinute: true,
|
|
92
|
+
showSecond: true,
|
|
93
|
+
...timePickerProps,
|
|
94
|
+
...disabledTimeConfig,
|
|
95
|
+
...timePickerDisabledTime,
|
|
96
|
+
defaultOpenValue: value,
|
|
97
|
+
value: selectedValue[index],
|
|
98
|
+
},
|
|
99
|
+
on: {
|
|
100
|
+
change: inputChange,
|
|
101
|
+
},
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
const dateInputElement = showDateInput && (
|
|
106
|
+
<DateInput
|
|
107
|
+
format={format}
|
|
108
|
+
locale={locale}
|
|
109
|
+
prefixCls={prefixCls}
|
|
110
|
+
timePicker={timePicker}
|
|
111
|
+
disabledDate={disabledDate}
|
|
112
|
+
placeholder={placeholder}
|
|
113
|
+
disabledTime={disabledTime}
|
|
114
|
+
value={value}
|
|
115
|
+
showClear={showClear || false}
|
|
116
|
+
selectedValue={selectedValue[index]}
|
|
117
|
+
onChange={inputChange}
|
|
118
|
+
onSelect={inputSelect}
|
|
119
|
+
clearIcon={clearIcon}
|
|
120
|
+
inputMode={inputMode}
|
|
121
|
+
inputReadOnly={inputReadOnly}
|
|
122
|
+
/>
|
|
123
|
+
);
|
|
124
|
+
const headerProps = {
|
|
125
|
+
props: {
|
|
126
|
+
...newProps,
|
|
127
|
+
mode,
|
|
128
|
+
enableNext,
|
|
129
|
+
enablePrev,
|
|
130
|
+
disabledMonth,
|
|
131
|
+
selectedValue: selectedValue[index],
|
|
132
|
+
},
|
|
133
|
+
on: {
|
|
134
|
+
valueChange,
|
|
135
|
+
panelChange,
|
|
136
|
+
},
|
|
137
|
+
};
|
|
138
|
+
const tableProps = {
|
|
139
|
+
props: {
|
|
140
|
+
...newProps,
|
|
141
|
+
hoverValue,
|
|
142
|
+
selectedValue,
|
|
143
|
+
dateRender,
|
|
144
|
+
disabledDate,
|
|
145
|
+
showWeekNumber,
|
|
146
|
+
},
|
|
147
|
+
on: {
|
|
148
|
+
select,
|
|
149
|
+
dayHover,
|
|
150
|
+
},
|
|
151
|
+
};
|
|
152
|
+
return (
|
|
153
|
+
<div class={`${rangeClassName}-part ${rangeClassName}-${direction}`}>
|
|
154
|
+
{dateInputElement}
|
|
155
|
+
<div style={{ outline: 'none' }}>
|
|
156
|
+
<CalendarHeader {...headerProps} />
|
|
157
|
+
{showTimePicker ? (
|
|
158
|
+
<div class={`${prefixCls}-time-picker`}>
|
|
159
|
+
<div class={`${prefixCls}-time-picker-panel`}>{timePickerEle}</div>
|
|
160
|
+
</div>
|
|
161
|
+
) : null}
|
|
162
|
+
<div class={`${prefixCls}-body`}>
|
|
163
|
+
<DateTable {...tableProps} />
|
|
164
|
+
</div>
|
|
165
|
+
</div>
|
|
166
|
+
</div>
|
|
167
|
+
);
|
|
168
|
+
},
|
|
169
|
+
};
|
|
170
|
+
|
|
171
|
+
export default CalendarPart;
|