amis 1.8.0-beta.1 → 1.8.0-beta.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (207) hide show
  1. package/lib/SchemaRenderer.js +19 -3
  2. package/lib/SchemaRenderer.js.map +2 -2
  3. package/lib/WithRootStore.d.ts +18 -0
  4. package/lib/WithStore.js +2 -1
  5. package/lib/WithStore.js.map +2 -2
  6. package/lib/actions/CmptAction.js +14 -3
  7. package/lib/actions/CmptAction.js.map +2 -2
  8. package/lib/components/AssociatedSelection.js +9 -2
  9. package/lib/components/AssociatedSelection.js.map +2 -2
  10. package/lib/components/BarCode.js +1 -1
  11. package/lib/components/BarCode.js.map +2 -2
  12. package/lib/components/Checkbox.d.ts +24 -23
  13. package/lib/components/Checkbox.js +6 -2
  14. package/lib/components/Checkbox.js.map +2 -2
  15. package/lib/components/DatePicker.js +16 -5
  16. package/lib/components/DatePicker.js.map +2 -2
  17. package/lib/components/DateRangePicker.d.ts +94 -84
  18. package/lib/components/DateRangePicker.js +259 -7
  19. package/lib/components/DateRangePicker.js.map +2 -2
  20. package/lib/components/MonthRangePicker.d.ts +84 -84
  21. package/lib/components/Radios.d.ts +22 -22
  22. package/lib/components/Radios.js +3 -5
  23. package/lib/components/Radios.js.map +2 -2
  24. package/lib/components/Range.d.ts +2 -2
  25. package/lib/components/Range.js +24 -11
  26. package/lib/components/Range.js.map +2 -2
  27. package/lib/components/Steps.d.ts +6 -0
  28. package/lib/components/Steps.js +13 -9
  29. package/lib/components/Steps.js.map +2 -2
  30. package/lib/components/calendar/Calendar.js +2 -14
  31. package/lib/components/calendar/Calendar.js.map +2 -2
  32. package/lib/components/calendar/YearsView.js +3 -3
  33. package/lib/components/calendar/YearsView.js.map +2 -2
  34. package/lib/factory.d.ts +4 -0
  35. package/lib/factory.js +9 -0
  36. package/lib/factory.js.map +2 -2
  37. package/lib/index.js +1 -1
  38. package/lib/locale/de-DE.js +13 -0
  39. package/lib/locale/de-DE.js.map +2 -2
  40. package/lib/locale/en-US.js +13 -0
  41. package/lib/locale/en-US.js.map +2 -2
  42. package/lib/locale/zh-CN.js +13 -0
  43. package/lib/locale/zh-CN.js.map +2 -2
  44. package/lib/renderers/Action.d.ts +2 -0
  45. package/lib/renderers/Action.js +23 -5
  46. package/lib/renderers/Action.js.map +2 -2
  47. package/lib/renderers/CRUD.d.ts +8 -0
  48. package/lib/renderers/CRUD.js +11 -4
  49. package/lib/renderers/CRUD.js.map +2 -2
  50. package/lib/renderers/Carousel.d.ts +1 -0
  51. package/lib/renderers/Carousel.js +13 -1
  52. package/lib/renderers/Carousel.js.map +2 -2
  53. package/lib/renderers/Form/Checkbox.d.ts +5 -2
  54. package/lib/renderers/Form/Checkbox.js +2 -2
  55. package/lib/renderers/Form/Checkbox.js.map +2 -2
  56. package/lib/renderers/Form/Checkboxes.d.ts +7 -2
  57. package/lib/renderers/Form/Checkboxes.js +101 -12
  58. package/lib/renderers/Form/Checkboxes.js.map +2 -2
  59. package/lib/renderers/Form/Combo.js +3 -2
  60. package/lib/renderers/Form/Combo.js.map +2 -2
  61. package/lib/renderers/Form/InputCity.d.ts +3 -0
  62. package/lib/renderers/Form/InputCity.js +44 -2
  63. package/lib/renderers/Form/InputCity.js.map +2 -2
  64. package/lib/renderers/Form/InputDateRange.d.ts +5 -0
  65. package/lib/renderers/Form/InputDateRange.js.map +2 -2
  66. package/lib/renderers/Form/InputFile.js +6 -3
  67. package/lib/renderers/Form/InputFile.js.map +2 -2
  68. package/lib/renderers/Form/InputImage.js +6 -3
  69. package/lib/renderers/Form/InputImage.js.map +2 -2
  70. package/lib/renderers/Form/InputRange.js +13 -14
  71. package/lib/renderers/Form/InputRange.js.map +2 -2
  72. package/lib/renderers/Form/Item.d.ts +11 -6
  73. package/lib/renderers/Form/Item.js +3 -1
  74. package/lib/renderers/Form/Item.js.map +2 -2
  75. package/lib/renderers/Form/index.d.ts +1 -0
  76. package/lib/renderers/Form/index.js +1 -1
  77. package/lib/renderers/Form/index.js.map +2 -2
  78. package/lib/renderers/Form/wrapControl.d.ts +9 -0
  79. package/lib/renderers/Form/wrapControl.js +1 -1
  80. package/lib/renderers/Form/wrapControl.js.map +2 -2
  81. package/lib/renderers/Nav.js +2 -2
  82. package/lib/renderers/Nav.js.map +2 -2
  83. package/lib/renderers/Steps.d.ts +8 -0
  84. package/lib/renderers/Steps.js +2 -2
  85. package/lib/renderers/Steps.js.map +2 -2
  86. package/lib/renderers/Table/index.d.ts +1 -0
  87. package/lib/renderers/Table/index.js +10 -5
  88. package/lib/renderers/Table/index.js.map +2 -2
  89. package/lib/renderers/Tabs.d.ts +4 -0
  90. package/lib/renderers/Tabs.js +22 -6
  91. package/lib/renderers/Tabs.js.map +2 -2
  92. package/lib/renderers/Wizard.d.ts +6 -3
  93. package/lib/renderers/Wizard.js +257 -152
  94. package/lib/renderers/Wizard.js.map +2 -2
  95. package/lib/store/crud.d.ts +1 -0
  96. package/lib/store/crud.js +33 -7
  97. package/lib/store/crud.js.map +2 -2
  98. package/lib/store/formItem.js +1 -1
  99. package/lib/store/formItem.js.map +2 -2
  100. package/lib/store/index.d.ts +5 -0
  101. package/lib/store/index.js +14 -0
  102. package/lib/store/index.js.map +2 -2
  103. package/lib/store/table.js +2 -2
  104. package/lib/store/table.js.map +2 -2
  105. package/lib/themes/ang-ie11.css +278 -17
  106. package/lib/themes/ang.css +286 -17
  107. package/lib/themes/ang.css.map +1 -1
  108. package/lib/themes/antd-ie11.css +278 -17
  109. package/lib/themes/antd.css +286 -17
  110. package/lib/themes/antd.css.map +1 -1
  111. package/lib/themes/cxd-ie11.css +278 -17
  112. package/lib/themes/cxd.css +286 -17
  113. package/lib/themes/cxd.css.map +1 -1
  114. package/lib/themes/dark-ie11.css +278 -17
  115. package/lib/themes/dark.css +286 -17
  116. package/lib/themes/dark.css.map +1 -1
  117. package/lib/themes/default-ie11.css +278 -17
  118. package/lib/themes/default.css +286 -17
  119. package/lib/themes/default.css.map +1 -1
  120. package/lib/types.d.ts +1 -1
  121. package/lib/types.js.map +1 -1
  122. package/lib/utils/columnsSplit.d.ts +1 -0
  123. package/lib/utils/columnsSplit.js +40 -0
  124. package/lib/utils/columnsSplit.js.map +13 -0
  125. package/lib/utils/debug.d.ts +1 -1
  126. package/lib/utils/debug.js +16 -22
  127. package/lib/utils/debug.js.map +2 -2
  128. package/package.json +1 -1
  129. package/schema.json +237 -29
  130. package/scss/_properties.scss +10 -1
  131. package/scss/components/_barcode.scss +1 -1
  132. package/scss/components/_carousel.scss +1 -0
  133. package/scss/components/_debug.scss +3 -3
  134. package/scss/components/_steps.scss +199 -8
  135. package/scss/components/form/_checks.scss +122 -1
  136. package/scss/components/form/_date.scss +2 -1
  137. package/scss/components/form/_editor.scss +2 -1
  138. package/scss/components/form/_form.scss +16 -0
  139. package/sdk/ang-ie11.css +335 -18
  140. package/sdk/ang.css +343 -18
  141. package/sdk/antd-ie11.css +335 -18
  142. package/sdk/antd.css +343 -18
  143. package/sdk/barcode.js +51 -51
  144. package/sdk/charts.js +14 -14
  145. package/sdk/codemirror.js +7 -7
  146. package/sdk/color-picker.js +65 -65
  147. package/sdk/cropperjs.js +2 -2
  148. package/sdk/cxd-ie11.css +335 -18
  149. package/sdk/cxd.css +343 -18
  150. package/sdk/dark-ie11.css +335 -18
  151. package/sdk/dark.css +343 -18
  152. package/sdk/exceljs.js +1 -1
  153. package/sdk/locale/de-DE.js +13 -0
  154. package/sdk/markdown.js +69 -69
  155. package/sdk/papaparse.js +1 -1
  156. package/sdk/renderers/Form/CityDB.js +1 -1
  157. package/sdk/rest.js +17 -17
  158. package/sdk/rich-text.js +62 -62
  159. package/sdk/sdk-ie11.css +335 -18
  160. package/sdk/sdk.css +343 -18
  161. package/sdk/sdk.js +1289 -1287
  162. package/sdk/thirds/hls.js/hls.js +1 -1
  163. package/sdk/thirds/mpegts.js/mpegts.js +1 -1
  164. package/sdk/tinymce.js +57 -57
  165. package/src/SchemaRenderer.tsx +32 -14
  166. package/src/WithStore.tsx +3 -1
  167. package/src/actions/CmptAction.ts +18 -0
  168. package/src/components/AssociatedSelection.tsx +9 -3
  169. package/src/components/BarCode.tsx +2 -2
  170. package/src/components/Checkbox.tsx +11 -5
  171. package/src/components/DatePicker.tsx +21 -4
  172. package/src/components/DateRangePicker.tsx +295 -6
  173. package/src/components/Radios.tsx +6 -17
  174. package/src/components/Range.tsx +26 -12
  175. package/src/components/Steps.tsx +28 -27
  176. package/src/components/calendar/Calendar.tsx +2 -15
  177. package/src/components/calendar/YearsView.tsx +3 -4
  178. package/src/factory.tsx +16 -0
  179. package/src/locale/de-DE.ts +13 -0
  180. package/src/locale/en-US.ts +13 -0
  181. package/src/locale/zh-CN.ts +13 -0
  182. package/src/renderers/Action.tsx +22 -1
  183. package/src/renderers/CRUD.tsx +22 -4
  184. package/src/renderers/Carousel.tsx +8 -0
  185. package/src/renderers/Form/Checkbox.tsx +11 -2
  186. package/src/renderers/Form/Checkboxes.tsx +106 -23
  187. package/src/renderers/Form/Combo.tsx +2 -3
  188. package/src/renderers/Form/InputCity.tsx +33 -4
  189. package/src/renderers/Form/InputDateRange.tsx +8 -1
  190. package/src/renderers/Form/InputFile.tsx +7 -3
  191. package/src/renderers/Form/InputImage.tsx +7 -3
  192. package/src/renderers/Form/InputRange.tsx +18 -16
  193. package/src/renderers/Form/Item.tsx +1 -0
  194. package/src/renderers/Form/index.tsx +2 -1
  195. package/src/renderers/Form/wrapControl.tsx +1 -1
  196. package/src/renderers/Nav.tsx +1 -1
  197. package/src/renderers/Steps.tsx +14 -0
  198. package/src/renderers/Table/index.tsx +15 -4
  199. package/src/renderers/Tabs.tsx +75 -28
  200. package/src/renderers/Wizard.tsx +154 -93
  201. package/src/store/crud.ts +40 -5
  202. package/src/store/formItem.ts +1 -2
  203. package/src/store/index.ts +20 -0
  204. package/src/store/table.ts +2 -2
  205. package/src/types.ts +3 -1
  206. package/src/utils/columnsSplit.tsx +57 -0
  207. package/src/utils/debug.tsx +17 -24
@@ -12,10 +12,10 @@ interface CheckboxProps {
12
12
  labelClassName?: string;
13
13
  className?: string;
14
14
  onChange?: (value: any, shift?: boolean) => void;
15
- value?: any;
15
+ value?: boolean | string | number;
16
16
  inline?: boolean;
17
- trueValue?: any;
18
- falseValue?: any;
17
+ trueValue?: boolean | string | number;
18
+ falseValue?: boolean | string | number;
19
19
  disabled?: boolean;
20
20
  readOnly?: boolean;
21
21
  checked?: boolean;
@@ -24,6 +24,7 @@ interface CheckboxProps {
24
24
  classPrefix: string;
25
25
  classnames: ClassNamesFn;
26
26
  partial?: boolean;
27
+ optionType?: 'default' | 'button';
27
28
  }
28
29
  export declare class Checkbox extends React.Component<CheckboxProps, any> {
29
30
  static defaultProps: Pick<CheckboxProps, 'trueValue' | 'falseValue' | 'type'>;
@@ -31,12 +32,12 @@ export declare class Checkbox extends React.Component<CheckboxProps, any> {
31
32
  render(): JSX.Element;
32
33
  }
33
34
  declare const _default: {
34
- new (props: (Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps) | Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>): {
35
+ new (props: (Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial" | "optionType"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps) | Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial" | "optionType"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>): {
35
36
  render(): JSX.Element;
36
37
  context: any;
37
- setState<K extends never>(state: {} | ((prevState: Readonly<{}>, props: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>) => {} | Pick<{}, K> | null) | Pick<{}, K> | null, callback?: (() => void) | undefined): void;
38
+ setState<K extends never>(state: {} | ((prevState: Readonly<{}>, props: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial" | "optionType"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>) => {} | Pick<{}, K> | null) | Pick<{}, K> | null, callback?: (() => void) | undefined): void;
38
39
  forceUpdate(callback?: (() => void) | undefined): void;
39
- readonly props: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps> & Readonly<{
40
+ readonly props: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial" | "optionType"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps> & Readonly<{
40
41
  children?: React.ReactNode;
41
42
  }>;
42
43
  state: Readonly<{}>;
@@ -44,24 +45,24 @@ declare const _default: {
44
45
  [key: string]: React.ReactInstance;
45
46
  };
46
47
  componentDidMount?(): void;
47
- shouldComponentUpdate?(nextProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, nextState: Readonly<{}>, nextContext: any): boolean;
48
+ shouldComponentUpdate?(nextProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial" | "optionType"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, nextState: Readonly<{}>, nextContext: any): boolean;
48
49
  componentWillUnmount?(): void;
49
50
  componentDidCatch?(error: Error, errorInfo: React.ErrorInfo): void;
50
- getSnapshotBeforeUpdate?(prevProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, prevState: Readonly<{}>): any;
51
- componentDidUpdate?(prevProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, prevState: Readonly<{}>, snapshot?: any): void;
51
+ getSnapshotBeforeUpdate?(prevProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial" | "optionType"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, prevState: Readonly<{}>): any;
52
+ componentDidUpdate?(prevProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial" | "optionType"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, prevState: Readonly<{}>, snapshot?: any): void;
52
53
  componentWillMount?(): void;
53
54
  UNSAFE_componentWillMount?(): void;
54
- componentWillReceiveProps?(nextProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, nextContext: any): void;
55
- UNSAFE_componentWillReceiveProps?(nextProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, nextContext: any): void;
56
- componentWillUpdate?(nextProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, nextState: Readonly<{}>, nextContext: any): void;
57
- UNSAFE_componentWillUpdate?(nextProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, nextState: Readonly<{}>, nextContext: any): void;
55
+ componentWillReceiveProps?(nextProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial" | "optionType"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, nextContext: any): void;
56
+ UNSAFE_componentWillReceiveProps?(nextProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial" | "optionType"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, nextContext: any): void;
57
+ componentWillUpdate?(nextProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial" | "optionType"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, nextState: Readonly<{}>, nextContext: any): void;
58
+ UNSAFE_componentWillUpdate?(nextProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial" | "optionType"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, nextState: Readonly<{}>, nextContext: any): void;
58
59
  };
59
- new (props: Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps, context: any): {
60
+ new (props: Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial" | "optionType"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps, context: any): {
60
61
  render(): JSX.Element;
61
62
  context: any;
62
- setState<K extends never>(state: {} | ((prevState: Readonly<{}>, props: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>) => {} | Pick<{}, K> | null) | Pick<{}, K> | null, callback?: (() => void) | undefined): void;
63
+ setState<K extends never>(state: {} | ((prevState: Readonly<{}>, props: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial" | "optionType"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>) => {} | Pick<{}, K> | null) | Pick<{}, K> | null, callback?: (() => void) | undefined): void;
63
64
  forceUpdate(callback?: (() => void) | undefined): void;
64
- readonly props: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps> & Readonly<{
65
+ readonly props: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial" | "optionType"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps> & Readonly<{
65
66
  children?: React.ReactNode;
66
67
  }>;
67
68
  state: Readonly<{}>;
@@ -69,17 +70,17 @@ declare const _default: {
69
70
  [key: string]: React.ReactInstance;
70
71
  };
71
72
  componentDidMount?(): void;
72
- shouldComponentUpdate?(nextProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, nextState: Readonly<{}>, nextContext: any): boolean;
73
+ shouldComponentUpdate?(nextProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial" | "optionType"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, nextState: Readonly<{}>, nextContext: any): boolean;
73
74
  componentWillUnmount?(): void;
74
75
  componentDidCatch?(error: Error, errorInfo: React.ErrorInfo): void;
75
- getSnapshotBeforeUpdate?(prevProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, prevState: Readonly<{}>): any;
76
- componentDidUpdate?(prevProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, prevState: Readonly<{}>, snapshot?: any): void;
76
+ getSnapshotBeforeUpdate?(prevProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial" | "optionType"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, prevState: Readonly<{}>): any;
77
+ componentDidUpdate?(prevProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial" | "optionType"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, prevState: Readonly<{}>, snapshot?: any): void;
77
78
  componentWillMount?(): void;
78
79
  UNSAFE_componentWillMount?(): void;
79
- componentWillReceiveProps?(nextProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, nextContext: any): void;
80
- UNSAFE_componentWillReceiveProps?(nextProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, nextContext: any): void;
81
- componentWillUpdate?(nextProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, nextState: Readonly<{}>, nextContext: any): void;
82
- UNSAFE_componentWillUpdate?(nextProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, nextState: Readonly<{}>, nextContext: any): void;
80
+ componentWillReceiveProps?(nextProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial" | "optionType"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, nextContext: any): void;
81
+ UNSAFE_componentWillReceiveProps?(nextProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial" | "optionType"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, nextContext: any): void;
82
+ componentWillUpdate?(nextProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial" | "optionType"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, nextState: Readonly<{}>, nextContext: any): void;
83
+ UNSAFE_componentWillUpdate?(nextProps: Readonly<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "label" | "value" | "description" | "disabled" | "checked" | "name" | "size" | "inline" | "readOnly" | "onChange" | "labelClassName" | "partial" | "optionType"> & Partial<Pick<Omit<CheckboxProps, keyof import("../theme").ThemeProps>, "type" | "trueValue" | "falseValue">> & Partial<Pick<Pick<CheckboxProps, "type" | "trueValue" | "falseValue">, never>> & import("../theme").ThemeOutterProps>, nextState: Readonly<{}>, nextContext: any): void;
83
84
  };
84
85
  displayName: string;
85
86
  contextType: React.Context<string>;
@@ -24,11 +24,15 @@ var Checkbox = /** @class */ (function (_super) {
24
24
  };
25
25
  Checkbox.prototype.render = function () {
26
26
  var _a;
27
- var _b = this.props, size = _b.size, className = _b.className, cx = _b.classnames, value = _b.value, label = _b.label, partial = _b.partial, trueValue = _b.trueValue, children = _b.children, disabled = _b.disabled, description = _b.description, readOnly = _b.readOnly, checked = _b.checked, type = _b.type, name = _b.name, labelClassName = _b.labelClassName;
27
+ var _b = this.props, size = _b.size, className = _b.className, cx = _b.classnames, value = _b.value, label = _b.label, partial = _b.partial, trueValue = _b.trueValue, children = _b.children, disabled = _b.disabled, description = _b.description, readOnly = _b.readOnly, checked = _b.checked, type = _b.type, name = _b.name, labelClassName = _b.labelClassName, optionType = _b.optionType;
28
28
  return (react_1.default.createElement("label", { className: cx("Checkbox Checkbox--".concat(type), className, (_a = {
29
- 'Checkbox--full': !partial
29
+ 'Checkbox--full': !partial,
30
+ 'Checkbox--partial': partial
30
31
  },
31
32
  _a["Checkbox--".concat(size)] = size,
33
+ _a['Checkbox--button'] = optionType === 'button',
34
+ _a['Checkbox--button--checked'] = optionType === 'button' && checked,
35
+ _a['Checkbox--button--disabled--unchecked'] = disabled && !checked,
32
36
  _a)) },
33
37
  react_1.default.createElement("input", { type: type, checked: typeof checked !== 'undefined'
34
38
  ? checked
@@ -6,8 +6,8 @@
6
6
  "/src/components/Checkbox.tsx"
7
7
  ],
8
8
  "names": [],
9
- "mappings": ";AAAA;;;GAGG;;;;AAEH,6DAA0B;AAC1B,kCAAiD;AACjD,0CAAyC;AAEzC,IAAM,YAAY,GAAG,UAAC,CAAM,IAAK,OAAA,CAAC,CAAC,eAAe,EAAE,EAAnB,CAAmB,CAAC;AAuBrD;IAA8B,yCAAmC;IAAjE;;IA2EA,CAAC;IAhEC,8BAAW,GAAX,UAAY,CAAyB;QAC7B,IAAA,KAAoC,IAAI,CAAC,KAAK,EAA7C,SAAS,eAAA,EAAE,UAAU,gBAAA,EAAE,QAAQ,cAAc,CAAC;QAErD,IAAI,CAAC,QAAQ,EAAE;YACb,OAAO;SACR;QAED,QAAQ,CACN,CAAC,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,UAAU,EAC/C,CAAC,CAAC,WAA0B,CAAC,QAAQ,CACvC,CAAC;IACJ,CAAC;IAED,yBAAM,GAAN;;QACM,IAAA,KAgBA,IAAI,CAAC,KAAK,EAfZ,IAAI,UAAA,EACJ,SAAS,eAAA,EACG,EAAE,gBAAA,EACd,KAAK,WAAA,EACL,KAAK,WAAA,EACL,OAAO,aAAA,EACP,SAAS,eAAA,EACT,QAAQ,cAAA,EACR,QAAQ,cAAA,EACR,WAAW,iBAAA,EACX,QAAQ,cAAA,EACR,OAAO,aAAA,EACP,IAAI,UAAA,EACJ,IAAI,UAAA,EACJ,cAAc,oBACF,CAAC;QAEf,OAAO,CACL,yCACE,SAAS,EAAE,EAAE,CAAC,6BAAsB,IAAI,CAAE,EAAE,SAAS;oBACnD,gBAAgB,EAAE,CAAC,OAAO;;gBAC1B,GAAC,oBAAa,IAAI,CAAE,IAAG,IAAI;oBAC3B;YAEF,yCACE,IAAI,EAAE,IAAI,EACV,OAAO,EACL,OAAO,OAAO,KAAK,WAAW;oBAC5B,CAAC,CAAC,OAAO;oBACT,CAAC,CAAC,OAAO,KAAK,KAAK,WAAW;wBAC9B,CAAC,CAAC,KAAK;wBACP,CAAC,CAAC,KAAK,IAAI,SAAS,EAExB,QAAQ,EAAE,IAAI,CAAC,WAAW,EAC1B,OAAO,EACL,YAAY,CAAC,oCAAoC;kBAEnD,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,IAAI,EAAE,IAAI,GACV;YACF,wCAAK;YACL,wCAAM,SAAS,EAAE,EAAE,CAAC,cAAc,CAAC,IAAG,QAAQ,IAAI,KAAK,CAAQ;YAC9D,WAAW,CAAC,CAAC,CAAC,CACb,uCAAK,SAAS,EAAE,EAAE,CAAC,eAAe,CAAC,IAAG,WAAW,CAAO,CACzD,CAAC,CAAC,CAAC,IAAI,CACF,CACT,CAAC;IACJ,CAAC;;IAzEM,qBAAY,GAGf;QACF,SAAS,EAAE,IAAI;QACf,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE,UAAU;KACjB,CAAC;IAGF;QADC,iBAAQ;;0EACM,eAAK,oBAAL,eAAK,CAAC,WAAW;;+CAW/B;IAqDH,eAAC;CAAA,AA3ED,CAA8B,eAAK,CAAC,SAAS,GA2E5C;AA3EY,4BAAQ;AA6ErB,kBAAe,IAAA,iBAAS,EAAC,QAAQ,CAAC,CAAC",
9
+ "mappings": ";AAAA;;;GAGG;;;;AAEH,6DAA0B;AAC1B,kCAAiD;AACjD,0CAAyC;AAEzC,IAAM,YAAY,GAAG,UAAC,CAAM,IAAK,OAAA,CAAC,CAAC,eAAe,EAAE,EAAnB,CAAmB,CAAC;AAwBrD;IAA8B,yCAAmC;IAAjE;;IAgFA,CAAC;IArEC,8BAAW,GAAX,UAAY,CAAyB;QAC7B,IAAA,KAAoC,IAAI,CAAC,KAAK,EAA7C,SAAS,eAAA,EAAE,UAAU,gBAAA,EAAE,QAAQ,cAAc,CAAC;QAErD,IAAI,CAAC,QAAQ,EAAE;YACb,OAAO;SACR;QAED,QAAQ,CACN,CAAC,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,UAAU,EAC/C,CAAC,CAAC,WAA0B,CAAC,QAAQ,CACvC,CAAC;IACJ,CAAC;IAED,yBAAM,GAAN;;QACM,IAAA,KAiBA,IAAI,CAAC,KAAK,EAhBZ,IAAI,UAAA,EACJ,SAAS,eAAA,EACG,EAAE,gBAAA,EACd,KAAK,WAAA,EACL,KAAK,WAAA,EACL,OAAO,aAAA,EACP,SAAS,eAAA,EACT,QAAQ,cAAA,EACR,QAAQ,cAAA,EACR,WAAW,iBAAA,EACX,QAAQ,cAAA,EACR,OAAO,aAAA,EACP,IAAI,UAAA,EACJ,IAAI,UAAA,EACJ,cAAc,oBAAA,EACd,UAAU,gBACE,CAAC;QAEf,OAAO,CACL,yCACE,SAAS,EAAE,EAAE,CAAC,6BAAsB,IAAI,CAAE,EAAE,SAAS;oBACnD,gBAAgB,EAAE,CAAC,OAAO;oBAC1B,mBAAmB,EAAE,OAAO;;gBAC5B,GAAC,oBAAa,IAAI,CAAE,IAAG,IAAI;gBAC3B,sBAAkB,GAAE,UAAU,KAAK,QAAQ;gBAC3C,+BAA2B,GAAE,UAAU,KAAK,QAAQ,IAAI,OAAO;gBAC/D,2CAAuC,GAAE,QAAQ,IAAI,CAAC,OAAO;oBAC7D;YAEF,yCACE,IAAI,EAAE,IAAI,EACV,OAAO,EACL,OAAO,OAAO,KAAK,WAAW;oBAC5B,CAAC,CAAC,OAAO;oBACT,CAAC,CAAC,OAAO,KAAK,KAAK,WAAW;wBAC9B,CAAC,CAAC,KAAK;wBACP,CAAC,CAAC,KAAK,IAAI,SAAS,EAExB,QAAQ,EAAE,IAAI,CAAC,WAAW,EAC1B,OAAO,EACL,YAAY,CAAC,oCAAoC;kBAEnD,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,IAAI,EAAE,IAAI,GACV;YACF,wCAAK;YACL,wCAAM,SAAS,EAAE,EAAE,CAAC,cAAc,CAAC,IAAG,QAAQ,IAAI,KAAK,CAAQ;YAC9D,WAAW,CAAC,CAAC,CAAC,CACb,uCAAK,SAAS,EAAE,EAAE,CAAC,eAAe,CAAC,IAAG,WAAW,CAAO,CACzD,CAAC,CAAC,CAAC,IAAI,CACF,CACT,CAAC;IACJ,CAAC;;IA9EM,qBAAY,GAGf;QACF,SAAS,EAAE,IAAI;QACf,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE,UAAU;KACjB,CAAC;IAGF;QADC,iBAAQ;;0EACM,eAAK,oBAAL,eAAK,CAAC,WAAW;;+CAW/B;IA0DH,eAAC;CAAA,AAhFD,CAA8B,eAAK,CAAC,SAAS,GAgF5C;AAhFY,4BAAQ;AAkFrB,kBAAe,IAAA,iBAAS,EAAC,QAAQ,CAAC,CAAC",
10
10
  "sourcesContent": [
11
- "/**\n * @file Checkbox\n * @author fex\n */\n\nimport React from 'react';\nimport {ClassNamesFn, themeable} from '../theme';\nimport {autobind} from '../utils/helper';\n\nconst preventEvent = (e: any) => e.stopPropagation();\n\ninterface CheckboxProps {\n type: 'checkbox' | 'radio';\n size?: 'sm' | 'lg' | 'small' | 'large';\n label?: string;\n labelClassName?: string;\n className?: string;\n onChange?: (value: any, shift?: boolean) => void;\n value?: any;\n inline?: boolean;\n trueValue?: any;\n falseValue?: any;\n disabled?: boolean;\n readOnly?: boolean;\n checked?: boolean;\n name?: string;\n description?: string;\n classPrefix: string;\n classnames: ClassNamesFn;\n partial?: boolean;\n}\n\nexport class Checkbox extends React.Component<CheckboxProps, any> {\n static defaultProps: Pick<\n CheckboxProps,\n 'trueValue' | 'falseValue' | 'type'\n > = {\n trueValue: true,\n falseValue: false,\n type: 'checkbox'\n };\n\n @autobind\n handleCheck(e: React.ChangeEvent<any>) {\n const {trueValue, falseValue, onChange} = this.props;\n\n if (!onChange) {\n return;\n }\n\n onChange(\n e.currentTarget.checked ? trueValue : falseValue,\n (e.nativeEvent as MouseEvent).shiftKey\n );\n }\n\n render() {\n let {\n size,\n className,\n classnames: cx,\n value,\n label,\n partial,\n trueValue,\n children,\n disabled,\n description,\n readOnly,\n checked,\n type,\n name,\n labelClassName\n } = this.props;\n\n return (\n <label\n className={cx(`Checkbox Checkbox--${type}`, className, {\n 'Checkbox--full': !partial,\n [`Checkbox--${size}`]: size\n })}\n >\n <input\n type={type}\n checked={\n typeof checked !== 'undefined'\n ? checked\n : typeof value === 'undefined'\n ? value\n : value == trueValue\n }\n onChange={this.handleCheck}\n onClick={\n preventEvent // 当点击 i 的时候,这个地方也会触发 click,很奇怪,干脆禁掉\n }\n disabled={disabled}\n readOnly={readOnly}\n name={name}\n />\n <i />\n <span className={cx(labelClassName)}>{children || label}</span>\n {description ? (\n <div className={cx('Checkbox-desc')}>{description}</div>\n ) : null}\n </label>\n );\n }\n}\n\nexport default themeable(Checkbox);\n"
11
+ "/**\n * @file Checkbox\n * @author fex\n */\n\nimport React from 'react';\nimport {ClassNamesFn, themeable} from '../theme';\nimport {autobind} from '../utils/helper';\n\nconst preventEvent = (e: any) => e.stopPropagation();\n\ninterface CheckboxProps {\n type: 'checkbox' | 'radio';\n size?: 'sm' | 'lg' | 'small' | 'large';\n label?: string;\n labelClassName?: string;\n className?: string;\n onChange?: (value: any, shift?: boolean) => void;\n value?: boolean | string | number;\n inline?: boolean;\n trueValue?: boolean | string | number;\n falseValue?: boolean | string | number;\n disabled?: boolean;\n readOnly?: boolean;\n checked?: boolean;\n name?: string;\n description?: string;\n classPrefix: string;\n classnames: ClassNamesFn;\n partial?: boolean;\n optionType?: 'default' | 'button';\n}\n\nexport class Checkbox extends React.Component<CheckboxProps, any> {\n static defaultProps: Pick<\n CheckboxProps,\n 'trueValue' | 'falseValue' | 'type'\n > = {\n trueValue: true,\n falseValue: false,\n type: 'checkbox'\n };\n\n @autobind\n handleCheck(e: React.ChangeEvent<any>) {\n const {trueValue, falseValue, onChange} = this.props;\n\n if (!onChange) {\n return;\n }\n\n onChange(\n e.currentTarget.checked ? trueValue : falseValue,\n (e.nativeEvent as MouseEvent).shiftKey\n );\n }\n\n render() {\n let {\n size,\n className,\n classnames: cx,\n value,\n label,\n partial,\n trueValue,\n children,\n disabled,\n description,\n readOnly,\n checked,\n type,\n name,\n labelClassName,\n optionType\n } = this.props;\n\n return (\n <label\n className={cx(`Checkbox Checkbox--${type}`, className, {\n 'Checkbox--full': !partial,\n 'Checkbox--partial': partial,\n [`Checkbox--${size}`]: size,\n 'Checkbox--button': optionType === 'button',\n 'Checkbox--button--checked': optionType === 'button' && checked,\n 'Checkbox--button--disabled--unchecked': disabled && !checked\n })}\n >\n <input\n type={type}\n checked={\n typeof checked !== 'undefined'\n ? checked\n : typeof value === 'undefined'\n ? value\n : value == trueValue\n }\n onChange={this.handleCheck}\n onClick={\n preventEvent // 当点击 i 的时候,这个地方也会触发 click,很奇怪,干脆禁掉\n }\n disabled={disabled}\n readOnly={readOnly}\n name={name}\n />\n <i />\n <span className={cx(labelClassName)}>{children || label}</span>\n {description ? (\n <div className={cx('Checkbox-desc')}>{description}</div>\n ) : null}\n </label>\n );\n }\n}\n\nexport default themeable(Checkbox);\n"
12
12
  ]
13
13
  }
@@ -246,11 +246,22 @@ var DatePicker = /** @class */ (function (_super) {
246
246
  return _this;
247
247
  }
248
248
  DatePicker.prototype.componentDidUpdate = function (prevProps) {
249
+ var _a;
249
250
  var props = this.props;
250
- if (prevProps.value !== props.value) {
251
- this.setState({
251
+ var prevValue = prevProps.value;
252
+ if (prevValue !== props.value) {
253
+ var newState = {
252
254
  value: normalizeValue(props.value, props.format)
253
- });
255
+ };
256
+ // 相对值和公式是 didUpdate 的时候才更新
257
+ if (typeof prevValue === 'string' &&
258
+ (prevValue.startsWith('+') ||
259
+ prevValue.startsWith('-') ||
260
+ prevValue.startsWith('$'))) {
261
+ newState.inputValue =
262
+ ((_a = normalizeValue(this.props.value, this.props.format)) === null || _a === void 0 ? void 0 : _a.format(this.props.inputFormat)) || '';
263
+ }
264
+ this.setState(newState);
254
265
  }
255
266
  };
256
267
  DatePicker.prototype.focus = function () {
@@ -453,12 +464,12 @@ var DatePicker = /** @class */ (function (_super) {
453
464
  }
454
465
  return (react_1.default.createElement("div", { tabIndex: 0, onKeyPress: this.handleKeyPress, onFocus: this.handleFocus, onBlur: this.handleBlur, className: cx("DatePicker", (_a = {
455
466
  'is-disabled': disabled,
456
- 'is-focused': this.state.isFocused
467
+ 'is-focused': !disabled && this.state.isFocused
457
468
  },
458
469
  _a["DatePicker--border".concat((0, helper_1.ucFirst)(borderMode))] = borderMode,
459
470
  _a['is-mobile'] = useMobileUI && (0, helper_1.isMobile)(),
460
471
  _a), className), ref: this.domRef, onClick: this.handleClick },
461
- react_1.default.createElement(Input_1.default, { onChange: this.inputChange, ref: this.inputRef, placeholder: __(placeholder), autoComplete: "off", value: this.state.inputValue }),
472
+ react_1.default.createElement(Input_1.default, { className: cx('DatePicker-input'), onChange: this.inputChange, ref: this.inputRef, placeholder: __(placeholder), autoComplete: "off", value: this.state.inputValue, disabled: disabled }),
462
473
  clearable && !disabled && normalizeValue(value, format) ? (react_1.default.createElement("a", { className: cx("DatePicker-clear"), onClick: this.clearValue },
463
474
  react_1.default.createElement(icons_1.Icon, { icon: "input-clear", className: "icon" }))) : null,
464
475
  react_1.default.createElement("a", { className: cx("DatePicker-toggler") },
@@ -6,8 +6,8 @@
6
6
  "/src/components/DatePicker.tsx"
7
7
  ],
8
8
  "names": [],
9
- "mappings": "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",
9
+ "mappings": "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",
10
10
  "sourcesContent": [
11
- "/**\n * @file DatePicker\n * @description 时间选择器组件\n * @author fex\n */\n\nimport React from 'react';\nimport moment from 'moment';\nimport 'moment/locale/zh-cn';\nimport {Icon} from './icons';\nimport PopOver from './PopOver';\nimport PopUp from './PopUp';\nimport Overlay from './Overlay';\nimport {ClassNamesFn, themeable, ThemeProps} from '../theme';\nimport {PlainObject} from '../types';\nimport Calendar from './calendar/Calendar';\nimport {localeable, LocaleProps, TranslateFn} from '../locale';\nimport {isMobile, ucFirst} from '../utils/helper';\nimport CalendarMobile from './CalendarMobile';\nimport Input from './Input';\n\nconst availableShortcuts: {[propName: string]: any} = {\n now: {\n label: 'Date.now',\n date: (now: moment.Moment) => {\n return now;\n }\n },\n today: {\n label: 'Date.today',\n date: (now: moment.Moment) => {\n return now.startOf('day');\n }\n },\n\n yesterday: {\n label: 'Date.yesterday',\n date: (now: moment.Moment) => {\n return now.add(-1, 'days').startOf('day');\n }\n },\n\n thisweek: {\n label: 'Date.monday',\n date: (now: moment.Moment) => {\n return now.startOf('week').startOf('day');\n }\n },\n\n thismonth: {\n label: 'Date.startOfMonth',\n date: (now: moment.Moment) => {\n return now.startOf('month');\n }\n },\n\n prevmonth: {\n label: 'Date.startOfLastMonth',\n date: (now: moment.Moment) => {\n return now.startOf('month').add(-1, 'month');\n }\n },\n\n prevquarter: {\n label: 'Date.startOfLastQuarter',\n date: (now: moment.Moment) => {\n return now.startOf('quarter').add(-1, 'quarter');\n }\n },\n\n thisquarter: {\n label: 'Date.startOfQuarter',\n date: (now: moment.Moment) => {\n return now.startOf('quarter');\n }\n },\n\n tomorrow: {\n label: 'Date.tomorrow',\n date: (now: moment.Moment) => {\n return now.add(1, 'days').startOf('day');\n }\n },\n\n endofthisweek: {\n label: 'Date.endOfWeek',\n date: (now: moment.Moment) => {\n return now.endOf('week');\n }\n },\n\n endofthismonth: {\n label: 'Date.endOfMonth',\n date: (now: moment.Moment) => {\n return now.endOf('month');\n }\n },\n\n endoflastmonth: {\n label: 'Date.endOfLastMonth',\n date: (now: moment.Moment) => {\n return now.add(-1, 'month').endOf('month');\n }\n }\n};\n\nconst advancedShortcuts = [\n {\n regexp: /^(\\d+)hoursago$/,\n resolve: (__: TranslateFn, _: string, hours: string) => {\n return {\n label: __('Date.hoursago', {hours}),\n date: (now: moment.Moment) => {\n return now.subtract(hours, 'hours');\n }\n };\n }\n },\n {\n regexp: /^(\\d+)hourslater$/,\n resolve: (__: TranslateFn, _: string, hours: string) => {\n return {\n label: __('Date.hourslater', {hours}),\n date: (now: moment.Moment) => {\n return now.add(hours, 'hours');\n }\n };\n }\n },\n {\n regexp: /^(\\d+)daysago$/,\n resolve: (__: TranslateFn, _: string, days: string) => {\n return {\n label: __('Date.daysago', {days}),\n date: (now: moment.Moment) => {\n return now.subtract(days, 'days');\n }\n };\n }\n },\n {\n regexp: /^(\\d+)dayslater$/,\n resolve: (__: TranslateFn, _: string, days: string) => {\n return {\n label: __('Date.dayslater', {days}),\n date: (now: moment.Moment) => {\n return now.add(days, 'days');\n }\n };\n }\n },\n {\n regexp: /^(\\d+)weeksago$/,\n resolve: (__: TranslateFn, _: string, weeks: string) => {\n return {\n label: __('Date.weeksago', {weeks}),\n date: (now: moment.Moment) => {\n return now.subtract(weeks, 'weeks');\n }\n };\n }\n },\n {\n regexp: /^(\\d+)weekslater$/,\n resolve: (__: TranslateFn, _: string, weeks: string) => {\n return {\n label: __('Date.weekslater', {weeks}),\n date: (now: moment.Moment) => {\n return now.add(weeks, 'weeks');\n }\n };\n }\n },\n {\n regexp: /^(\\d+)monthsago$/,\n resolve: (__: TranslateFn, _: string, months: string) => {\n return {\n label: __('Date.monthsago', {months}),\n date: (now: moment.Moment) => {\n return now.subtract(months, 'months');\n }\n };\n }\n },\n {\n regexp: /^(\\d+)monthslater$/,\n resolve: (__: TranslateFn, _: string, months: string) => {\n return {\n label: __('Date.monthslater', {months}),\n date: (now: moment.Moment) => {\n return now.add(months, 'months');\n }\n };\n }\n },\n {\n regexp: /^(\\d+)quartersago$/,\n resolve: (__: TranslateFn, _: string, quarters: string) => {\n return {\n label: __('Date.quartersago', {quarters}),\n date: (now: moment.Moment) => {\n return now.subtract(quarters, 'quarters');\n }\n };\n }\n },\n {\n regexp: /^(\\d+)quarterslater$/,\n resolve: (__: TranslateFn, _: string, quarters: string) => {\n return {\n label: __('Date.quarterslater', {quarters}),\n date: (now: moment.Moment) => {\n return now.add(quarters, 'quarters');\n }\n };\n }\n }\n];\n\nexport type ShortCutDate = {\n label: string;\n date: moment.Moment;\n};\n\nexport type ShortCutDateRange = {\n label: string;\n startDate?: moment.Moment;\n endDate?: moment.Moment;\n};\n\nexport type ShortCuts =\n | {\n label: string;\n value: string;\n }\n | ShortCutDate\n | ShortCutDateRange;\n\nexport interface DateProps extends LocaleProps, ThemeProps {\n viewMode: 'years' | 'months' | 'days' | 'time' | 'quarters';\n className?: string;\n popoverClassName?: string;\n placeholder?: string;\n inputFormat?: string;\n timeFormat?: string;\n format?: string;\n closeOnSelect: boolean;\n disabled?: boolean;\n minDate?: moment.Moment;\n maxDate?: moment.Moment;\n clearable?: boolean;\n defaultValue?: any;\n utc?: boolean;\n onChange: (value: any) => void;\n value?: any;\n shortcuts: string | Array<ShortCuts>;\n overlayPlacement: string;\n // minTime?: moment.Moment;\n // maxTime?: moment.Moment;\n dateFormat?: string;\n timeConstraints?: {\n hours?: {\n min: number;\n max: number;\n step: number;\n };\n minutes?: {\n min: number;\n max: number;\n step: number;\n };\n seconds: {\n min: number;\n max: number;\n step: number;\n };\n };\n popOverContainer?: any;\n\n borderMode?: 'full' | 'half' | 'none';\n // 是否为内嵌模式,如果开启就不是 picker 了,直接页面点选。\n embed?: boolean;\n schedules?: Array<{\n startTime: Date;\n endTime: Date;\n content: any;\n className?: string;\n }>;\n scheduleClassNames?: Array<string>;\n largeMode?: boolean;\n onScheduleClick?: (scheduleData: any) => void;\n useMobileUI?: boolean;\n // 在移动端日期展示有多种形式,一种是picker 滑动选择,一种是日历展开选择,mobileCalendarMode为calendar表示日历展开选择\n mobileCalendarMode?: 'picker' | 'calendar';\n\n // 下面那个千万不要写,写了就会导致 keyof DateProps 得到的结果是 string | number;\n // [propName: string]: any;\n onFocus?: Function;\n onBlur?: Function;\n}\n\nexport interface DatePickerState {\n isOpened: boolean;\n isFocused: boolean;\n value: moment.Moment | undefined;\n inputValue: string | undefined; // 手动输入的值\n}\n\nfunction normalizeValue(value: any, format?: string) {\n if (!value || value === '0') {\n return undefined;\n }\n const v = moment(value, format, true);\n return v.isValid() ? v : undefined;\n}\n\nexport class DatePicker extends React.Component<DateProps, DatePickerState> {\n static defaultProps = {\n viewMode: 'days' as 'years' | 'months' | 'days' | 'time',\n shortcuts: '',\n closeOnSelect: true,\n overlayPlacement: 'auto',\n scheduleClassNames: [\n 'bg-warning',\n 'bg-danger',\n 'bg-success',\n 'bg-info',\n 'bg-secondary'\n ]\n };\n state: DatePickerState = {\n isOpened: false,\n isFocused: false,\n value: normalizeValue(this.props.value, this.props.format),\n inputValue:\n normalizeValue(this.props.value, this.props.format)?.format(\n this.props.inputFormat\n ) || ''\n };\n constructor(props: DateProps) {\n super(props);\n this.inputRef = React.createRef();\n this.handleChange = this.handleChange.bind(this);\n this.selectRannge = this.selectRannge.bind(this);\n this.checkIsValidDate = this.checkIsValidDate.bind(this);\n this.open = this.open.bind(this);\n this.close = this.close.bind(this);\n this.handleFocus = this.handleFocus.bind(this);\n this.handleBlur = this.handleBlur.bind(this);\n this.clearValue = this.clearValue.bind(this);\n this.handleClick = this.handleClick.bind(this);\n this.handleKeyPress = this.handleKeyPress.bind(this);\n this.getParent = this.getParent.bind(this);\n this.getTarget = this.getTarget.bind(this);\n this.handlePopOverClick = this.handlePopOverClick.bind(this);\n this.renderShortCuts = this.renderShortCuts.bind(this);\n this.inputChange = this.inputChange.bind(this);\n }\n\n dom: HTMLDivElement;\n\n inputRef: React.RefObject<HTMLInputElement>;\n\n componentDidUpdate(prevProps: DateProps) {\n const props = this.props;\n\n if (prevProps.value !== props.value) {\n this.setState({\n value: normalizeValue(props.value, props.format)\n });\n }\n }\n\n focus() {\n if (!this.dom) {\n return;\n }\n\n this.dom.focus();\n }\n\n handleFocus(e: React.SyntheticEvent<HTMLDivElement>) {\n this.setState({\n isFocused: true\n });\n const {onFocus} = this.props;\n onFocus && onFocus(e);\n }\n\n handleBlur(e: React.SyntheticEvent<HTMLDivElement>) {\n this.setState({\n isFocused: false\n });\n const {onBlur} = this.props;\n onBlur && onBlur(e);\n }\n\n handleKeyPress(e: React.KeyboardEvent) {\n if (e.key === ' ') {\n this.handleClick();\n e.preventDefault();\n }\n }\n\n handleClick() {\n this.state.isOpened ? this.close() : this.open();\n }\n\n handlePopOverClick(e: React.MouseEvent<any>) {\n e.stopPropagation();\n e.preventDefault();\n }\n\n open(fn?: () => void) {\n if (this.props.disabled) {\n return;\n }\n this.setState(\n {\n isOpened: true\n },\n fn\n );\n const input = this.inputRef.current;\n input && input.focus();\n }\n\n close() {\n this.setState({\n isOpened: false\n });\n }\n\n clearValue(e: React.MouseEvent<any>) {\n e.preventDefault();\n e.stopPropagation();\n const onChange = this.props.onChange;\n onChange('');\n this.setState({inputValue: ''});\n }\n\n handleChange(value: moment.Moment) {\n const {\n onChange,\n format,\n minDate,\n maxDate,\n dateFormat,\n inputFormat,\n timeFormat,\n closeOnSelect,\n utc,\n viewMode\n } = this.props;\n\n if (!moment.isMoment(value)) {\n return;\n }\n\n if (minDate && value && value.isBefore(minDate, 'second')) {\n value = minDate;\n } else if (maxDate && value && value.isAfter(maxDate, 'second')) {\n value = maxDate;\n }\n\n onChange(utc ? moment.utc(value).format(format) : value.format(format));\n\n if (closeOnSelect && dateFormat && !timeFormat) {\n this.close();\n }\n\n this.setState({\n inputValue: utc\n ? moment.utc(value).format(inputFormat)\n : value.format(inputFormat)\n });\n }\n\n // 手动输入日期\n inputChange(e: React.ChangeEvent<HTMLInputElement>) {\n const {onChange, inputFormat, format, utc} = this.props;\n const value = e.currentTarget.value;\n this.setState({inputValue: value});\n if (value === '') {\n onChange('');\n } else {\n const newDate = moment(value, inputFormat);\n const dateValue = utc\n ? moment.utc(newDate).format(format)\n : newDate.format(format);\n // 小于 0 的日期丢弃\n if (!dateValue.startsWith('-')) {\n onChange(dateValue);\n }\n }\n }\n\n selectRannge(item: any) {\n const {closeOnSelect} = this.props;\n const now = moment();\n this.handleChange(item.date(now));\n\n closeOnSelect && this.close();\n }\n\n checkIsValidDate(currentDate: moment.Moment) {\n const {minDate, maxDate} = this.props;\n\n if (minDate && currentDate.isBefore(minDate, 'day')) {\n return false;\n } else if (maxDate && currentDate.isAfter(maxDate, 'day')) {\n return false;\n }\n\n return true;\n }\n\n getTarget() {\n return this.dom;\n }\n\n getParent() {\n return this.dom;\n }\n\n domRef = (ref: HTMLDivElement) => {\n this.dom = ref;\n };\n\n getAvailableShortcuts(key: string) {\n if (availableShortcuts[key]) {\n return availableShortcuts[key];\n }\n\n const __ = this.props.translate;\n\n for (let i = 0, len = advancedShortcuts.length; i < len; i++) {\n let item = advancedShortcuts[i];\n const m = item.regexp.exec(key);\n\n if (m) {\n return item.resolve.apply(item, [__, ...m]);\n }\n }\n\n return null;\n }\n\n renderShortCuts(shortcuts: string | Array<ShortCuts>) {\n if (!shortcuts) {\n return null;\n }\n const {classPrefix: ns, classnames: cx} = this.props;\n let shortcutArr: Array<string | ShortCuts>;\n if (typeof shortcuts === 'string') {\n shortcutArr = shortcuts.split(',');\n } else {\n shortcutArr = shortcuts;\n }\n\n const __ = this.props.translate;\n return (\n <ul className={cx(`DatePicker-shortcuts`)}>\n {shortcutArr.map(item => {\n if (!item) {\n return null;\n }\n let shortcut: PlainObject = {};\n if (typeof item === 'string') {\n shortcut = this.getAvailableShortcuts(item);\n shortcut.key = item;\n } else if ((item as ShortCutDate).date) {\n shortcut = {\n ...item,\n date: () => (item as ShortCutDate).date\n };\n }\n return (\n <li\n className={cx(`DatePicker-shortcut`)}\n onClick={() => this.selectRannge(shortcut)}\n key={shortcut.key || shortcut.label}\n >\n <a>{__(shortcut.label)}</a>\n </li>\n );\n })}\n </ul>\n );\n }\n\n render() {\n const {\n classPrefix: ns,\n classnames: cx,\n className,\n popoverClassName,\n value,\n placeholder,\n disabled,\n inputFormat,\n dateFormat,\n timeFormat,\n viewMode,\n timeConstraints,\n popOverContainer,\n clearable,\n shortcuts,\n utc,\n overlayPlacement,\n locale,\n format,\n borderMode,\n embed,\n minDate,\n useMobileUI,\n maxDate,\n schedules,\n largeMode,\n scheduleClassNames,\n onScheduleClick,\n mobileCalendarMode\n } = this.props;\n\n const __ = this.props.translate;\n const isOpened = this.state.isOpened;\n let date: moment.Moment | undefined = this.state.value;\n\n const calendarMobile = (\n <CalendarMobile\n isDatePicker={true}\n timeFormat={timeFormat}\n inputFormat={inputFormat}\n startDate={date}\n defaultDate={date}\n minDate={minDate}\n maxDate={maxDate}\n dateFormat={dateFormat}\n embed={embed}\n viewMode={viewMode}\n close={this.close}\n confirm={this.handleChange}\n footerExtra={this.renderShortCuts(shortcuts)}\n showViewMode={\n viewMode === 'quarters' || viewMode === 'months' ? 'years' : 'months'\n }\n timeConstraints={timeConstraints}\n />\n );\n const CalendarMobileTitle = (\n <div className={`${ns}CalendarMobile-title`}>\n {__('Calendar.datepicker')}\n </div>\n );\n const useCalendarMobile =\n useMobileUI &&\n isMobile() &&\n ['days', 'months', 'quarters'].indexOf(viewMode) > -1;\n\n if (embed) {\n let schedulesData: DateProps['schedules'] = undefined;\n if (schedules && Array.isArray(schedules)) {\n // 设置日程颜色\n let index = 0;\n schedulesData = schedules.map((schedule: any) => {\n let className = schedule.className;\n if (!className && scheduleClassNames) {\n className = scheduleClassNames[index];\n index++;\n if (index >= scheduleClassNames.length) {\n index = 0;\n }\n }\n return {\n ...schedule,\n className\n };\n });\n }\n return (\n <div\n className={cx(\n `DateCalendar`,\n {\n 'is-disabled': disabled,\n 'ScheduleCalendar': schedulesData,\n 'ScheduleCalendar-large': largeMode\n },\n className\n )}\n >\n <Calendar\n value={date}\n onChange={this.handleChange}\n requiredConfirm={false}\n dateFormat={dateFormat}\n timeFormat={timeFormat}\n isValidDate={this.checkIsValidDate}\n viewMode={viewMode}\n timeConstraints={timeConstraints}\n input={false}\n onClose={this.close}\n locale={locale}\n minDate={minDate}\n maxDate={maxDate}\n // utc={utc}\n schedules={schedulesData}\n largeMode={largeMode}\n onScheduleClick={onScheduleClick}\n embed={embed}\n useMobileUI={useMobileUI}\n />\n </div>\n );\n }\n\n return (\n <div\n tabIndex={0}\n onKeyPress={this.handleKeyPress}\n onFocus={this.handleFocus}\n onBlur={this.handleBlur}\n className={cx(\n `DatePicker`,\n {\n 'is-disabled': disabled,\n 'is-focused': this.state.isFocused,\n [`DatePicker--border${ucFirst(borderMode)}`]: borderMode,\n 'is-mobile': useMobileUI && isMobile()\n },\n className\n )}\n ref={this.domRef}\n onClick={this.handleClick}\n >\n <Input\n onChange={this.inputChange}\n ref={this.inputRef}\n placeholder={__(placeholder)}\n autoComplete=\"off\"\n value={this.state.inputValue}\n />\n\n {clearable && !disabled && normalizeValue(value, format) ? (\n <a className={cx(`DatePicker-clear`)} onClick={this.clearValue}>\n <Icon icon=\"input-clear\" className=\"icon\" />\n </a>\n ) : null}\n\n <a className={cx(`DatePicker-toggler`)}>\n <Icon icon=\"clock\" className=\"icon\" />\n </a>\n\n {!(useMobileUI && isMobile()) && isOpened ? (\n <Overlay\n target={this.getTarget}\n container={popOverContainer || this.getParent}\n rootClose={false}\n placement={overlayPlacement}\n show\n >\n <PopOver\n classPrefix={ns}\n className={cx(`DatePicker-popover`, popoverClassName)}\n onHide={this.close}\n overlay\n onClick={this.handlePopOverClick}\n >\n {this.renderShortCuts(shortcuts)}\n\n <Calendar\n value={date}\n onChange={this.handleChange}\n requiredConfirm={!!(dateFormat && timeFormat)}\n dateFormat={dateFormat}\n inputFormat={inputFormat}\n timeFormat={timeFormat}\n isValidDate={this.checkIsValidDate}\n viewMode={viewMode}\n timeConstraints={timeConstraints}\n input={false}\n onClose={this.close}\n locale={locale}\n minDate={minDate}\n maxDate={maxDate}\n useMobileUI={useMobileUI}\n // utc={utc}\n />\n </PopOver>\n </Overlay>\n ) : null}\n {useMobileUI && isMobile() ? (\n mobileCalendarMode === 'calendar' && useCalendarMobile ? (\n <PopUp\n isShow={isOpened}\n className={cx(`${ns}CalendarMobile-pop`)}\n onHide={this.close}\n header={CalendarMobileTitle}\n >\n {calendarMobile}\n </PopUp>\n ) : (\n <PopUp\n className={cx(`${ns}DatePicker-popup DatePicker-mobile`)}\n container={popOverContainer}\n isShow={isOpened}\n showClose={false}\n onHide={this.handleClick}\n >\n <Calendar\n value={date}\n onChange={this.handleChange}\n requiredConfirm={!!(dateFormat && timeFormat)}\n dateFormat={dateFormat}\n inputFormat={inputFormat}\n timeFormat={timeFormat}\n isValidDate={this.checkIsValidDate}\n viewMode={viewMode}\n timeConstraints={timeConstraints}\n input={false}\n onClose={this.close}\n locale={locale}\n minDate={minDate}\n maxDate={maxDate}\n useMobileUI={useMobileUI}\n // utc={utc}\n />\n </PopUp>\n )\n ) : null}\n </div>\n );\n }\n}\n\nexport default themeable(localeable(DatePicker));\n"
11
+ "/**\n * @file DatePicker\n * @description 时间选择器组件\n * @author fex\n */\n\nimport React from 'react';\nimport moment from 'moment';\nimport 'moment/locale/zh-cn';\nimport {Icon} from './icons';\nimport PopOver from './PopOver';\nimport PopUp from './PopUp';\nimport Overlay from './Overlay';\nimport {ClassNamesFn, themeable, ThemeProps} from '../theme';\nimport {PlainObject} from '../types';\nimport Calendar from './calendar/Calendar';\nimport {localeable, LocaleProps, TranslateFn} from '../locale';\nimport {isMobile, ucFirst} from '../utils/helper';\nimport CalendarMobile from './CalendarMobile';\nimport Input from './Input';\n\nconst availableShortcuts: {[propName: string]: any} = {\n now: {\n label: 'Date.now',\n date: (now: moment.Moment) => {\n return now;\n }\n },\n today: {\n label: 'Date.today',\n date: (now: moment.Moment) => {\n return now.startOf('day');\n }\n },\n\n yesterday: {\n label: 'Date.yesterday',\n date: (now: moment.Moment) => {\n return now.add(-1, 'days').startOf('day');\n }\n },\n\n thisweek: {\n label: 'Date.monday',\n date: (now: moment.Moment) => {\n return now.startOf('week').startOf('day');\n }\n },\n\n thismonth: {\n label: 'Date.startOfMonth',\n date: (now: moment.Moment) => {\n return now.startOf('month');\n }\n },\n\n prevmonth: {\n label: 'Date.startOfLastMonth',\n date: (now: moment.Moment) => {\n return now.startOf('month').add(-1, 'month');\n }\n },\n\n prevquarter: {\n label: 'Date.startOfLastQuarter',\n date: (now: moment.Moment) => {\n return now.startOf('quarter').add(-1, 'quarter');\n }\n },\n\n thisquarter: {\n label: 'Date.startOfQuarter',\n date: (now: moment.Moment) => {\n return now.startOf('quarter');\n }\n },\n\n tomorrow: {\n label: 'Date.tomorrow',\n date: (now: moment.Moment) => {\n return now.add(1, 'days').startOf('day');\n }\n },\n\n endofthisweek: {\n label: 'Date.endOfWeek',\n date: (now: moment.Moment) => {\n return now.endOf('week');\n }\n },\n\n endofthismonth: {\n label: 'Date.endOfMonth',\n date: (now: moment.Moment) => {\n return now.endOf('month');\n }\n },\n\n endoflastmonth: {\n label: 'Date.endOfLastMonth',\n date: (now: moment.Moment) => {\n return now.add(-1, 'month').endOf('month');\n }\n }\n};\n\nconst advancedShortcuts = [\n {\n regexp: /^(\\d+)hoursago$/,\n resolve: (__: TranslateFn, _: string, hours: string) => {\n return {\n label: __('Date.hoursago', {hours}),\n date: (now: moment.Moment) => {\n return now.subtract(hours, 'hours');\n }\n };\n }\n },\n {\n regexp: /^(\\d+)hourslater$/,\n resolve: (__: TranslateFn, _: string, hours: string) => {\n return {\n label: __('Date.hourslater', {hours}),\n date: (now: moment.Moment) => {\n return now.add(hours, 'hours');\n }\n };\n }\n },\n {\n regexp: /^(\\d+)daysago$/,\n resolve: (__: TranslateFn, _: string, days: string) => {\n return {\n label: __('Date.daysago', {days}),\n date: (now: moment.Moment) => {\n return now.subtract(days, 'days');\n }\n };\n }\n },\n {\n regexp: /^(\\d+)dayslater$/,\n resolve: (__: TranslateFn, _: string, days: string) => {\n return {\n label: __('Date.dayslater', {days}),\n date: (now: moment.Moment) => {\n return now.add(days, 'days');\n }\n };\n }\n },\n {\n regexp: /^(\\d+)weeksago$/,\n resolve: (__: TranslateFn, _: string, weeks: string) => {\n return {\n label: __('Date.weeksago', {weeks}),\n date: (now: moment.Moment) => {\n return now.subtract(weeks, 'weeks');\n }\n };\n }\n },\n {\n regexp: /^(\\d+)weekslater$/,\n resolve: (__: TranslateFn, _: string, weeks: string) => {\n return {\n label: __('Date.weekslater', {weeks}),\n date: (now: moment.Moment) => {\n return now.add(weeks, 'weeks');\n }\n };\n }\n },\n {\n regexp: /^(\\d+)monthsago$/,\n resolve: (__: TranslateFn, _: string, months: string) => {\n return {\n label: __('Date.monthsago', {months}),\n date: (now: moment.Moment) => {\n return now.subtract(months, 'months');\n }\n };\n }\n },\n {\n regexp: /^(\\d+)monthslater$/,\n resolve: (__: TranslateFn, _: string, months: string) => {\n return {\n label: __('Date.monthslater', {months}),\n date: (now: moment.Moment) => {\n return now.add(months, 'months');\n }\n };\n }\n },\n {\n regexp: /^(\\d+)quartersago$/,\n resolve: (__: TranslateFn, _: string, quarters: string) => {\n return {\n label: __('Date.quartersago', {quarters}),\n date: (now: moment.Moment) => {\n return now.subtract(quarters, 'quarters');\n }\n };\n }\n },\n {\n regexp: /^(\\d+)quarterslater$/,\n resolve: (__: TranslateFn, _: string, quarters: string) => {\n return {\n label: __('Date.quarterslater', {quarters}),\n date: (now: moment.Moment) => {\n return now.add(quarters, 'quarters');\n }\n };\n }\n }\n];\n\nexport type ShortCutDate = {\n label: string;\n date: moment.Moment;\n};\n\nexport type ShortCutDateRange = {\n label: string;\n startDate?: moment.Moment;\n endDate?: moment.Moment;\n};\n\nexport type ShortCuts =\n | {\n label: string;\n value: string;\n }\n | ShortCutDate\n | ShortCutDateRange;\n\nexport interface DateProps extends LocaleProps, ThemeProps {\n viewMode: 'years' | 'months' | 'days' | 'time' | 'quarters';\n className?: string;\n popoverClassName?: string;\n placeholder?: string;\n inputFormat?: string;\n timeFormat?: string;\n format?: string;\n closeOnSelect: boolean;\n disabled?: boolean;\n minDate?: moment.Moment;\n maxDate?: moment.Moment;\n clearable?: boolean;\n defaultValue?: any;\n utc?: boolean;\n onChange: (value: any) => void;\n value?: any;\n shortcuts: string | Array<ShortCuts>;\n overlayPlacement: string;\n // minTime?: moment.Moment;\n // maxTime?: moment.Moment;\n dateFormat?: string;\n timeConstraints?: {\n hours?: {\n min: number;\n max: number;\n step: number;\n };\n minutes?: {\n min: number;\n max: number;\n step: number;\n };\n seconds: {\n min: number;\n max: number;\n step: number;\n };\n };\n popOverContainer?: any;\n\n borderMode?: 'full' | 'half' | 'none';\n // 是否为内嵌模式,如果开启就不是 picker 了,直接页面点选。\n embed?: boolean;\n schedules?: Array<{\n startTime: Date;\n endTime: Date;\n content: any;\n className?: string;\n }>;\n scheduleClassNames?: Array<string>;\n largeMode?: boolean;\n onScheduleClick?: (scheduleData: any) => void;\n useMobileUI?: boolean;\n // 在移动端日期展示有多种形式,一种是picker 滑动选择,一种是日历展开选择,mobileCalendarMode为calendar表示日历展开选择\n mobileCalendarMode?: 'picker' | 'calendar';\n\n // 下面那个千万不要写,写了就会导致 keyof DateProps 得到的结果是 string | number;\n // [propName: string]: any;\n onFocus?: Function;\n onBlur?: Function;\n}\n\nexport interface DatePickerState {\n isOpened: boolean;\n isFocused: boolean;\n value: moment.Moment | undefined;\n inputValue: string | undefined; // 手动输入的值\n}\n\nfunction normalizeValue(value: any, format?: string) {\n if (!value || value === '0') {\n return undefined;\n }\n const v = moment(value, format, true);\n return v.isValid() ? v : undefined;\n}\n\nexport class DatePicker extends React.Component<DateProps, DatePickerState> {\n static defaultProps = {\n viewMode: 'days' as 'years' | 'months' | 'days' | 'time',\n shortcuts: '',\n closeOnSelect: true,\n overlayPlacement: 'auto',\n scheduleClassNames: [\n 'bg-warning',\n 'bg-danger',\n 'bg-success',\n 'bg-info',\n 'bg-secondary'\n ]\n };\n state: DatePickerState = {\n isOpened: false,\n isFocused: false,\n value: normalizeValue(this.props.value, this.props.format),\n inputValue:\n normalizeValue(this.props.value, this.props.format)?.format(\n this.props.inputFormat\n ) || ''\n };\n constructor(props: DateProps) {\n super(props);\n this.inputRef = React.createRef();\n this.handleChange = this.handleChange.bind(this);\n this.selectRannge = this.selectRannge.bind(this);\n this.checkIsValidDate = this.checkIsValidDate.bind(this);\n this.open = this.open.bind(this);\n this.close = this.close.bind(this);\n this.handleFocus = this.handleFocus.bind(this);\n this.handleBlur = this.handleBlur.bind(this);\n this.clearValue = this.clearValue.bind(this);\n this.handleClick = this.handleClick.bind(this);\n this.handleKeyPress = this.handleKeyPress.bind(this);\n this.getParent = this.getParent.bind(this);\n this.getTarget = this.getTarget.bind(this);\n this.handlePopOverClick = this.handlePopOverClick.bind(this);\n this.renderShortCuts = this.renderShortCuts.bind(this);\n this.inputChange = this.inputChange.bind(this);\n }\n\n dom: HTMLDivElement;\n\n inputRef: React.RefObject<HTMLInputElement>;\n\n componentDidUpdate(prevProps: DateProps) {\n const props = this.props;\n\n const prevValue = prevProps.value;\n\n if (prevValue !== props.value) {\n const newState: any = {\n value: normalizeValue(props.value, props.format)\n };\n // 相对值和公式是 didUpdate 的时候才更新\n if (\n typeof prevValue === 'string' &&\n (prevValue.startsWith('+') ||\n prevValue.startsWith('-') ||\n prevValue.startsWith('$'))\n ) {\n newState.inputValue =\n normalizeValue(this.props.value, this.props.format)?.format(\n this.props.inputFormat\n ) || '';\n }\n this.setState(newState);\n }\n }\n\n focus() {\n if (!this.dom) {\n return;\n }\n\n this.dom.focus();\n }\n\n handleFocus(e: React.SyntheticEvent<HTMLDivElement>) {\n this.setState({\n isFocused: true\n });\n const {onFocus} = this.props;\n onFocus && onFocus(e);\n }\n\n handleBlur(e: React.SyntheticEvent<HTMLDivElement>) {\n this.setState({\n isFocused: false\n });\n const {onBlur} = this.props;\n onBlur && onBlur(e);\n }\n\n handleKeyPress(e: React.KeyboardEvent) {\n if (e.key === ' ') {\n this.handleClick();\n e.preventDefault();\n }\n }\n\n handleClick() {\n this.state.isOpened ? this.close() : this.open();\n }\n\n handlePopOverClick(e: React.MouseEvent<any>) {\n e.stopPropagation();\n e.preventDefault();\n }\n\n open(fn?: () => void) {\n if (this.props.disabled) {\n return;\n }\n this.setState(\n {\n isOpened: true\n },\n fn\n );\n const input = this.inputRef.current;\n input && input.focus();\n }\n\n close() {\n this.setState({\n isOpened: false\n });\n }\n\n clearValue(e: React.MouseEvent<any>) {\n e.preventDefault();\n e.stopPropagation();\n const onChange = this.props.onChange;\n onChange('');\n this.setState({inputValue: ''});\n }\n\n handleChange(value: moment.Moment) {\n const {\n onChange,\n format,\n minDate,\n maxDate,\n dateFormat,\n inputFormat,\n timeFormat,\n closeOnSelect,\n utc,\n viewMode\n } = this.props;\n\n if (!moment.isMoment(value)) {\n return;\n }\n\n if (minDate && value && value.isBefore(minDate, 'second')) {\n value = minDate;\n } else if (maxDate && value && value.isAfter(maxDate, 'second')) {\n value = maxDate;\n }\n\n onChange(utc ? moment.utc(value).format(format) : value.format(format));\n\n if (closeOnSelect && dateFormat && !timeFormat) {\n this.close();\n }\n\n this.setState({\n inputValue: utc\n ? moment.utc(value).format(inputFormat)\n : value.format(inputFormat)\n });\n }\n\n // 手动输入日期\n inputChange(e: React.ChangeEvent<HTMLInputElement>) {\n const {onChange, inputFormat, format, utc} = this.props;\n const value = e.currentTarget.value;\n this.setState({inputValue: value});\n if (value === '') {\n onChange('');\n } else {\n const newDate = moment(value, inputFormat);\n const dateValue = utc\n ? moment.utc(newDate).format(format)\n : newDate.format(format);\n // 小于 0 的日期丢弃\n if (!dateValue.startsWith('-')) {\n onChange(dateValue);\n }\n }\n }\n\n selectRannge(item: any) {\n const {closeOnSelect} = this.props;\n const now = moment();\n this.handleChange(item.date(now));\n\n closeOnSelect && this.close();\n }\n\n checkIsValidDate(currentDate: moment.Moment) {\n const {minDate, maxDate} = this.props;\n\n if (minDate && currentDate.isBefore(minDate, 'day')) {\n return false;\n } else if (maxDate && currentDate.isAfter(maxDate, 'day')) {\n return false;\n }\n\n return true;\n }\n\n getTarget() {\n return this.dom;\n }\n\n getParent() {\n return this.dom;\n }\n\n domRef = (ref: HTMLDivElement) => {\n this.dom = ref;\n };\n\n getAvailableShortcuts(key: string) {\n if (availableShortcuts[key]) {\n return availableShortcuts[key];\n }\n\n const __ = this.props.translate;\n\n for (let i = 0, len = advancedShortcuts.length; i < len; i++) {\n let item = advancedShortcuts[i];\n const m = item.regexp.exec(key);\n\n if (m) {\n return item.resolve.apply(item, [__, ...m]);\n }\n }\n\n return null;\n }\n\n renderShortCuts(shortcuts: string | Array<ShortCuts>) {\n if (!shortcuts) {\n return null;\n }\n const {classPrefix: ns, classnames: cx} = this.props;\n let shortcutArr: Array<string | ShortCuts>;\n if (typeof shortcuts === 'string') {\n shortcutArr = shortcuts.split(',');\n } else {\n shortcutArr = shortcuts;\n }\n\n const __ = this.props.translate;\n return (\n <ul className={cx(`DatePicker-shortcuts`)}>\n {shortcutArr.map(item => {\n if (!item) {\n return null;\n }\n let shortcut: PlainObject = {};\n if (typeof item === 'string') {\n shortcut = this.getAvailableShortcuts(item);\n shortcut.key = item;\n } else if ((item as ShortCutDate).date) {\n shortcut = {\n ...item,\n date: () => (item as ShortCutDate).date\n };\n }\n return (\n <li\n className={cx(`DatePicker-shortcut`)}\n onClick={() => this.selectRannge(shortcut)}\n key={shortcut.key || shortcut.label}\n >\n <a>{__(shortcut.label)}</a>\n </li>\n );\n })}\n </ul>\n );\n }\n\n render() {\n const {\n classPrefix: ns,\n classnames: cx,\n className,\n popoverClassName,\n value,\n placeholder,\n disabled,\n inputFormat,\n dateFormat,\n timeFormat,\n viewMode,\n timeConstraints,\n popOverContainer,\n clearable,\n shortcuts,\n utc,\n overlayPlacement,\n locale,\n format,\n borderMode,\n embed,\n minDate,\n useMobileUI,\n maxDate,\n schedules,\n largeMode,\n scheduleClassNames,\n onScheduleClick,\n mobileCalendarMode\n } = this.props;\n\n const __ = this.props.translate;\n const isOpened = this.state.isOpened;\n let date: moment.Moment | undefined = this.state.value;\n\n const calendarMobile = (\n <CalendarMobile\n isDatePicker={true}\n timeFormat={timeFormat}\n inputFormat={inputFormat}\n startDate={date}\n defaultDate={date}\n minDate={minDate}\n maxDate={maxDate}\n dateFormat={dateFormat}\n embed={embed}\n viewMode={viewMode}\n close={this.close}\n confirm={this.handleChange}\n footerExtra={this.renderShortCuts(shortcuts)}\n showViewMode={\n viewMode === 'quarters' || viewMode === 'months' ? 'years' : 'months'\n }\n timeConstraints={timeConstraints}\n />\n );\n const CalendarMobileTitle = (\n <div className={`${ns}CalendarMobile-title`}>\n {__('Calendar.datepicker')}\n </div>\n );\n const useCalendarMobile =\n useMobileUI &&\n isMobile() &&\n ['days', 'months', 'quarters'].indexOf(viewMode) > -1;\n\n if (embed) {\n let schedulesData: DateProps['schedules'] = undefined;\n if (schedules && Array.isArray(schedules)) {\n // 设置日程颜色\n let index = 0;\n schedulesData = schedules.map((schedule: any) => {\n let className = schedule.className;\n if (!className && scheduleClassNames) {\n className = scheduleClassNames[index];\n index++;\n if (index >= scheduleClassNames.length) {\n index = 0;\n }\n }\n return {\n ...schedule,\n className\n };\n });\n }\n return (\n <div\n className={cx(\n `DateCalendar`,\n {\n 'is-disabled': disabled,\n 'ScheduleCalendar': schedulesData,\n 'ScheduleCalendar-large': largeMode\n },\n className\n )}\n >\n <Calendar\n value={date}\n onChange={this.handleChange}\n requiredConfirm={false}\n dateFormat={dateFormat}\n timeFormat={timeFormat}\n isValidDate={this.checkIsValidDate}\n viewMode={viewMode}\n timeConstraints={timeConstraints}\n input={false}\n onClose={this.close}\n locale={locale}\n minDate={minDate}\n maxDate={maxDate}\n // utc={utc}\n schedules={schedulesData}\n largeMode={largeMode}\n onScheduleClick={onScheduleClick}\n embed={embed}\n useMobileUI={useMobileUI}\n />\n </div>\n );\n }\n\n return (\n <div\n tabIndex={0}\n onKeyPress={this.handleKeyPress}\n onFocus={this.handleFocus}\n onBlur={this.handleBlur}\n className={cx(\n `DatePicker`,\n {\n 'is-disabled': disabled,\n 'is-focused': !disabled && this.state.isFocused,\n [`DatePicker--border${ucFirst(borderMode)}`]: borderMode,\n 'is-mobile': useMobileUI && isMobile()\n },\n className\n )}\n ref={this.domRef}\n onClick={this.handleClick}\n >\n <Input\n className={cx('DatePicker-input')}\n onChange={this.inputChange}\n ref={this.inputRef}\n placeholder={__(placeholder)}\n autoComplete=\"off\"\n value={this.state.inputValue}\n disabled={disabled}\n />\n\n {clearable && !disabled && normalizeValue(value, format) ? (\n <a className={cx(`DatePicker-clear`)} onClick={this.clearValue}>\n <Icon icon=\"input-clear\" className=\"icon\" />\n </a>\n ) : null}\n\n <a className={cx(`DatePicker-toggler`)}>\n <Icon icon=\"clock\" className=\"icon\" />\n </a>\n\n {!(useMobileUI && isMobile()) && isOpened ? (\n <Overlay\n target={this.getTarget}\n container={popOverContainer || this.getParent}\n rootClose={false}\n placement={overlayPlacement}\n show\n >\n <PopOver\n classPrefix={ns}\n className={cx(`DatePicker-popover`, popoverClassName)}\n onHide={this.close}\n overlay\n onClick={this.handlePopOverClick}\n >\n {this.renderShortCuts(shortcuts)}\n\n <Calendar\n value={date}\n onChange={this.handleChange}\n requiredConfirm={!!(dateFormat && timeFormat)}\n dateFormat={dateFormat}\n inputFormat={inputFormat}\n timeFormat={timeFormat}\n isValidDate={this.checkIsValidDate}\n viewMode={viewMode}\n timeConstraints={timeConstraints}\n input={false}\n onClose={this.close}\n locale={locale}\n minDate={minDate}\n maxDate={maxDate}\n useMobileUI={useMobileUI}\n // utc={utc}\n />\n </PopOver>\n </Overlay>\n ) : null}\n {useMobileUI && isMobile() ? (\n mobileCalendarMode === 'calendar' && useCalendarMobile ? (\n <PopUp\n isShow={isOpened}\n className={cx(`${ns}CalendarMobile-pop`)}\n onHide={this.close}\n header={CalendarMobileTitle}\n >\n {calendarMobile}\n </PopUp>\n ) : (\n <PopUp\n className={cx(`${ns}DatePicker-popup DatePicker-mobile`)}\n container={popOverContainer}\n isShow={isOpened}\n showClose={false}\n onHide={this.handleClick}\n >\n <Calendar\n value={date}\n onChange={this.handleChange}\n requiredConfirm={!!(dateFormat && timeFormat)}\n dateFormat={dateFormat}\n inputFormat={inputFormat}\n timeFormat={timeFormat}\n isValidDate={this.checkIsValidDate}\n viewMode={viewMode}\n timeConstraints={timeConstraints}\n input={false}\n onClose={this.close}\n locale={locale}\n minDate={minDate}\n maxDate={maxDate}\n useMobileUI={useMobileUI}\n // utc={utc}\n />\n </PopUp>\n )\n ) : null}\n </div>\n );\n }\n}\n\nexport default themeable(localeable(DatePicker));\n"
12
12
  ]
13
13
  }