@activecollab/components 1.0.388 → 1.0.390

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 (38) hide show
  1. package/dist/cjs/components/EditableContent/EditableContent.js +2 -2
  2. package/dist/cjs/components/EditableContent/EditableContent.js.map +1 -1
  3. package/dist/cjs/components/EditableHours/EditableHours.js +56 -19
  4. package/dist/cjs/components/EditableHours/EditableHours.js.map +1 -1
  5. package/dist/cjs/components/Input/InputHours.js +35 -17
  6. package/dist/cjs/components/Input/InputHours.js.map +1 -1
  7. package/dist/cjs/{components/HoursWrapper/HoursWrapper.js → hooks/useInputHours.js} +45 -76
  8. package/dist/cjs/hooks/useInputHours.js.map +1 -0
  9. package/dist/esm/components/EditableContent/EditableContent.d.ts.map +1 -1
  10. package/dist/esm/components/EditableContent/EditableContent.js +2 -2
  11. package/dist/esm/components/EditableContent/EditableContent.js.map +1 -1
  12. package/dist/esm/components/EditableHours/EditableHours.d.ts +2 -10
  13. package/dist/esm/components/EditableHours/EditableHours.d.ts.map +1 -1
  14. package/dist/esm/components/EditableHours/EditableHours.js +58 -21
  15. package/dist/esm/components/EditableHours/EditableHours.js.map +1 -1
  16. package/dist/esm/components/Input/InputHours.d.ts +2 -2
  17. package/dist/esm/components/Input/InputHours.d.ts.map +1 -1
  18. package/dist/esm/components/Input/InputHours.js +35 -17
  19. package/dist/esm/components/Input/InputHours.js.map +1 -1
  20. package/dist/esm/hooks/useInputHours.d.ts +27 -0
  21. package/dist/esm/hooks/useInputHours.d.ts.map +1 -0
  22. package/dist/esm/{components/HoursWrapper/HoursWrapper.js → hooks/useInputHours.js} +41 -68
  23. package/dist/esm/hooks/useInputHours.js.map +1 -0
  24. package/dist/index.js +263 -230
  25. package/dist/index.js.map +1 -1
  26. package/dist/index.min.js +1 -1
  27. package/dist/index.min.js.map +1 -1
  28. package/package.json +1 -1
  29. package/dist/cjs/components/HoursWrapper/HoursWrapper.js.map +0 -1
  30. package/dist/cjs/components/HoursWrapper/index.js +0 -17
  31. package/dist/cjs/components/HoursWrapper/index.js.map +0 -1
  32. package/dist/esm/components/HoursWrapper/HoursWrapper.d.ts +0 -9
  33. package/dist/esm/components/HoursWrapper/HoursWrapper.d.ts.map +0 -1
  34. package/dist/esm/components/HoursWrapper/HoursWrapper.js.map +0 -1
  35. package/dist/esm/components/HoursWrapper/index.d.ts +0 -2
  36. package/dist/esm/components/HoursWrapper/index.d.ts.map +0 -1
  37. package/dist/esm/components/HoursWrapper/index.js +0 -2
  38. package/dist/esm/components/HoursWrapper/index.js.map +0 -1
@@ -1,14 +1,13 @@
1
1
  import _extends from "@babel/runtime/helpers/esm/extends";
2
2
  import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
3
- var _excluded = ["value", "onCancel", "onSave", "allowEmptyValue", "withLeadingZero", "validation", "incrementOnlySelected", "minuteIncrement", "className", "inputProps"];
3
+ var _excluded = ["value", "onCancel", "onSave", "allowEmptyValue", "withLeadingZero", "validation", "incrementOnlySelected", "minuteIncrement", "className", "onEnterKeyPress", "inputProps", "onClick"];
4
4
  import { EditableContent } from "../EditableContent";
5
- import React, { useRef } from "react";
5
+ import React, { useEffect, useRef } from "react";
6
6
  import useForkRef from "../../utils/useForkRef";
7
- import classNames from "classnames";
8
- import { validateTimeInput } from "../../utils";
9
- import { HoursWrapper } from "../HoursWrapper";
7
+ import { decimalToHours, validateTimeInput } from "../../utils";
8
+ import { useInputHours } from "../../hooks/useInputHours";
10
9
  export var EditableHours = /*#__PURE__*/React.forwardRef(function (_ref, ref) {
11
- var value = _ref.value,
10
+ var defaultValue = _ref.value,
12
11
  onCancel = _ref.onCancel,
13
12
  onSave = _ref.onSave,
14
13
  allowEmptyValue = _ref.allowEmptyValue,
@@ -21,26 +20,64 @@ export var EditableHours = /*#__PURE__*/React.forwardRef(function (_ref, ref) {
21
20
  _ref$minuteIncrement = _ref.minuteIncrement,
22
21
  minuteIncrement = _ref$minuteIncrement === void 0 ? 1 : _ref$minuteIncrement,
23
22
  className = _ref.className,
24
- inputProps = _ref.inputProps,
23
+ externalEnterKeyPress = _ref.onEnterKeyPress,
24
+ externalInputProps = _ref.inputProps,
25
+ externalOnClick = _ref.onClick,
25
26
  rest = _objectWithoutPropertiesLoose(_ref, _excluded);
26
27
  var inputRef = useRef(null);
27
28
  var handleRef = useForkRef(ref, inputRef);
28
- return /*#__PURE__*/React.createElement(HoursWrapper, {
29
- value: value,
30
- onCancel: onCancel,
31
- onSave: onSave,
32
- incrementOnlySelected: incrementOnlySelected,
33
- minuteIncrement: minuteIncrement,
34
- allowEmptyValue: allowEmptyValue,
35
- withLeadingZero: withLeadingZero,
36
- validation: validation
37
- }, /*#__PURE__*/React.createElement(EditableContent, _extends({
29
+ var _useInputHours = useInputHours({
30
+ value: defaultValue,
31
+ withLeadingZero: withLeadingZero,
32
+ onSave: onSave,
33
+ validation: validation,
34
+ allowEmptyValue: allowEmptyValue,
35
+ onCancel: onCancel,
36
+ minuteIncrement: minuteIncrement,
37
+ incrementOnlySelected: incrementOnlySelected,
38
+ onEnterKeyPress: externalEnterKeyPress,
39
+ onClick: externalOnClick
40
+ }, inputRef),
41
+ inputProps = _useInputHours.inputProps,
42
+ setCurrentValue = _useInputHours.setCurrentValue,
43
+ setPrevValue = _useInputHours.setPrevValue;
44
+ var value = inputProps.value,
45
+ onBlur = inputProps.onBlur,
46
+ onKeyDown = inputProps.onKeyDown,
47
+ onChange = inputProps.onChange,
48
+ onClick = inputProps.onClick,
49
+ onDoubleClick = inputProps.onDoubleClick;
50
+ useEffect(function () {
51
+ var _value;
52
+ if (defaultValue !== undefined) {
53
+ _value = decimalToHours(defaultValue, withLeadingZero);
54
+ }
55
+ setCurrentValue(function (prevState) {
56
+ if (prevState !== _value) {
57
+ return _value;
58
+ }
59
+ return prevState;
60
+ });
61
+ setPrevValue(function (prevState) {
62
+ if (prevState !== _value) {
63
+ return _value;
64
+ }
65
+ return prevState;
66
+ });
67
+ }, [defaultValue, setCurrentValue, setPrevValue, withLeadingZero]);
68
+ return /*#__PURE__*/React.createElement(EditableContent, _extends({
38
69
  ref: handleRef,
39
- inputProps: _extends({}, inputProps, {
40
- type: "text",
41
- className: classNames("c-input", className)
70
+ className: className,
71
+ inputProps: _extends({}, externalInputProps, {
72
+ value: value,
73
+ onBlur: onBlur,
74
+ onKeyDown: onKeyDown,
75
+ onChange: onChange,
76
+ onClick: onClick,
77
+ onDoubleClick: onDoubleClick,
78
+ type: "text"
42
79
  })
43
- }, rest)));
80
+ }, rest));
44
81
  });
45
82
  EditableHours.displayName = "EditableHours";
46
83
  //# sourceMappingURL=EditableHours.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"EditableHours.js","names":["EditableContent","React","useRef","useForkRef","classNames","validateTimeInput","HoursWrapper","EditableHours","forwardRef","ref","value","onCancel","onSave","allowEmptyValue","withLeadingZero","validation","incrementOnlySelected","minuteIncrement","className","inputProps","rest","inputRef","handleRef","type","displayName"],"sources":["../../../../src/components/EditableHours/EditableHours.tsx"],"sourcesContent":["import { EditableContent, EditableContentInterface } from \"../EditableContent\";\nimport React, { useRef } from \"react\";\nimport useForkRef from \"../../utils/useForkRef\";\nimport classNames from \"classnames\";\nimport { validateTimeInput } from \"../../utils\";\nimport { HoursWrapper } from \"../HoursWrapper\";\n\nexport interface EditableHoursProps extends EditableContentInterface {\n value?: number | string;\n onSave?: (e: Event) => void;\n onCancel?: (e: Event) => void;\n onEnterKeyPress?: () => void;\n withLeadingZero?: boolean;\n incrementOnlySelected?: boolean;\n validation?: (value: string, withLeadingZero: boolean) => boolean;\n allowEmptyValue?: boolean;\n minuteIncrement?: number;\n className?: string;\n}\nexport const EditableHours = React.forwardRef<\n HTMLDivElement,\n EditableHoursProps\n>(\n (\n {\n value,\n onCancel,\n onSave,\n allowEmptyValue,\n withLeadingZero = true,\n validation = validateTimeInput,\n incrementOnlySelected = false,\n minuteIncrement = 1,\n className,\n inputProps,\n ...rest\n },\n ref\n ) => {\n const inputRef = useRef<HTMLInputElement>(null);\n const handleRef = useForkRef(ref, inputRef);\n\n return (\n <HoursWrapper\n value={value}\n onCancel={onCancel}\n onSave={onSave}\n incrementOnlySelected={incrementOnlySelected}\n minuteIncrement={minuteIncrement}\n allowEmptyValue={allowEmptyValue}\n withLeadingZero={withLeadingZero}\n validation={validation}\n >\n <EditableContent\n ref={handleRef}\n inputProps={{\n ...inputProps,\n type: \"text\",\n className: classNames(\"c-input\", className),\n }}\n {...rest}\n />\n </HoursWrapper>\n );\n }\n);\n\nEditableHours.displayName = \"EditableHours\";\n"],"mappings":";;;AAAA,SAASA,eAAe,QAAkC,oBAAoB;AAC9E,OAAOC,KAAK,IAAIC,MAAM,QAAQ,OAAO;AACrC,OAAOC,UAAU,MAAM,wBAAwB;AAC/C,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,iBAAiB,QAAQ,aAAa;AAC/C,SAASC,YAAY,QAAQ,iBAAiB;AAc9C,OAAO,IAAMC,aAAa,gBAAGN,KAAK,CAACO,UAAU,CAI3C,gBAcEC,GAAG,EACA;EAAA,IAbDC,KAAK,QAALA,KAAK;IACLC,QAAQ,QAARA,QAAQ;IACRC,MAAM,QAANA,MAAM;IACNC,eAAe,QAAfA,eAAe;IAAA,4BACfC,eAAe;IAAfA,eAAe,qCAAG,IAAI;IAAA,uBACtBC,UAAU;IAAVA,UAAU,gCAAGV,iBAAiB;IAAA,6BAC9BW,qBAAqB;IAArBA,qBAAqB,sCAAG,KAAK;IAAA,4BAC7BC,eAAe;IAAfA,eAAe,qCAAG,CAAC;IACnBC,SAAS,QAATA,SAAS;IACTC,UAAU,QAAVA,UAAU;IACPC,IAAI;EAIT,IAAMC,QAAQ,GAAGnB,MAAM,CAAmB,IAAI,CAAC;EAC/C,IAAMoB,SAAS,GAAGnB,UAAU,CAACM,GAAG,EAAEY,QAAQ,CAAC;EAE3C,oBACE,oBAAC,YAAY;IACX,KAAK,EAAEX,KAAM;IACb,QAAQ,EAAEC,QAAS;IACnB,MAAM,EAAEC,MAAO;IACf,qBAAqB,EAAEI,qBAAsB;IAC7C,eAAe,EAAEC,eAAgB;IACjC,eAAe,EAAEJ,eAAgB;IACjC,eAAe,EAAEC,eAAgB;IACjC,UAAU,EAAEC;EAAW,gBAEvB,oBAAC,eAAe;IACd,GAAG,EAAEO,SAAU;IACf,UAAU,eACLH,UAAU;MACbI,IAAI,EAAE,MAAM;MACZL,SAAS,EAAEd,UAAU,CAAC,SAAS,EAAEc,SAAS;IAAC;EAC3C,GACEE,IAAI,EACR,CACW;AAEnB,CAAC,CACF;AAEDb,aAAa,CAACiB,WAAW,GAAG,eAAe"}
1
+ {"version":3,"file":"EditableHours.js","names":["EditableContent","React","useEffect","useRef","useForkRef","decimalToHours","validateTimeInput","useInputHours","EditableHours","forwardRef","ref","defaultValue","value","onCancel","onSave","allowEmptyValue","withLeadingZero","validation","incrementOnlySelected","minuteIncrement","className","externalEnterKeyPress","onEnterKeyPress","externalInputProps","inputProps","externalOnClick","onClick","rest","inputRef","handleRef","setCurrentValue","setPrevValue","onBlur","onKeyDown","onChange","onDoubleClick","_value","undefined","prevState","type","displayName"],"sources":["../../../../src/components/EditableHours/EditableHours.tsx"],"sourcesContent":["import { EditableContent, EditableContentInterface } from \"../EditableContent\";\nimport React, { useEffect, useRef } from \"react\";\nimport useForkRef from \"../../utils/useForkRef\";\nimport { decimalToHours, validateTimeInput } from \"../../utils\";\nimport { IInputHours, useInputHours } from \"../../hooks/useInputHours\";\n\nexport interface EditableHoursProps\n extends EditableContentInterface,\n Omit<IInputHours, \"onChange\"> {\n className?: string;\n}\nexport const EditableHours = React.forwardRef<\n HTMLDivElement,\n EditableHoursProps\n>(\n (\n {\n value: defaultValue,\n onCancel,\n onSave,\n allowEmptyValue,\n withLeadingZero = true,\n validation = validateTimeInput,\n incrementOnlySelected = false,\n minuteIncrement = 1,\n className,\n onEnterKeyPress: externalEnterKeyPress,\n inputProps: externalInputProps,\n onClick: externalOnClick,\n ...rest\n },\n ref\n ) => {\n const inputRef = useRef<HTMLInputElement>(null);\n const handleRef = useForkRef(ref, inputRef);\n\n const { inputProps, setCurrentValue, setPrevValue } = useInputHours(\n {\n value: defaultValue,\n withLeadingZero,\n onSave,\n validation,\n allowEmptyValue,\n onCancel,\n minuteIncrement,\n incrementOnlySelected,\n onEnterKeyPress: externalEnterKeyPress,\n onClick: externalOnClick,\n },\n inputRef\n );\n\n const { value, onBlur, onKeyDown, onChange, onClick, onDoubleClick } =\n inputProps;\n\n useEffect(() => {\n let _value;\n if (defaultValue !== undefined) {\n _value = decimalToHours(defaultValue, withLeadingZero);\n }\n setCurrentValue((prevState) => {\n if (prevState !== _value) {\n return _value;\n }\n return prevState;\n });\n setPrevValue((prevState) => {\n if (prevState !== _value) {\n return _value;\n }\n return prevState;\n });\n }, [defaultValue, setCurrentValue, setPrevValue, withLeadingZero]);\n\n return (\n <EditableContent\n ref={handleRef}\n className={className}\n inputProps={{\n ...externalInputProps,\n value,\n onBlur,\n onKeyDown,\n onChange,\n onClick,\n onDoubleClick,\n type: \"text\",\n }}\n {...rest}\n />\n );\n }\n);\n\nEditableHours.displayName = \"EditableHours\";\n"],"mappings":"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"}
@@ -1,7 +1,7 @@
1
1
  import React from "react";
2
2
  import type { InputProps } from "./Input";
3
- import type { EditableHoursProps } from "../EditableHours";
4
- export interface InputHoursProps extends Omit<EditableHoursProps, "weight" | "variant">, Omit<InputProps, "value"> {
3
+ import { IInputHours } from "../../hooks/useInputHours";
4
+ export interface InputHoursProps extends Omit<InputProps, "value" | "onChange">, IInputHours {
5
5
  }
6
6
  export declare const InputHours: React.ForwardRefExoticComponent<InputHoursProps & React.RefAttributes<HTMLInputElement>>;
7
7
  //# sourceMappingURL=InputHours.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"InputHours.d.ts","sourceRoot":"","sources":["../../../../src/components/Input/InputHours.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAiB,MAAM,OAAO,CAAC;AAKtC,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAC1C,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAC;AAE3D,MAAM,WAAW,eACf,SAAQ,IAAI,CAAC,kBAAkB,EAAE,QAAQ,GAAG,SAAS,CAAC,EACpD,IAAI,CAAC,UAAU,EAAE,OAAO,CAAC;CAAG;AAEhC,eAAO,MAAM,UAAU,0FAyCtB,CAAC"}
1
+ {"version":3,"file":"InputHours.d.ts","sourceRoot":"","sources":["../../../../src/components/Input/InputHours.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAiB,MAAM,OAAO,CAAC;AAItC,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAC1C,OAAO,EAAE,WAAW,EAAiB,MAAM,2BAA2B,CAAC;AAEvE,MAAM,WAAW,eACf,SAAQ,IAAI,CAAC,UAAU,EAAE,OAAO,GAAG,UAAU,CAAC,EAC5C,WAAW;CAAG;AAElB,eAAO,MAAM,UAAU,0FAyDtB,CAAC"}
@@ -1,16 +1,16 @@
1
1
  import _extends from "@babel/runtime/helpers/esm/extends";
2
2
  import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
3
- var _excluded = ["value", "onCancel", "onSave", "onEnterKeyPress", "allowEmptyValue", "withLeadingZero", "validation", "incrementOnlySelected", "minuteIncrement", "className"];
3
+ var _excluded = ["value", "onCancel", "onSave", "onEnterKeyPress", "allowEmptyValue", "withLeadingZero", "validation", "incrementOnlySelected", "minuteIncrement", "className", "onChange", "onClick"];
4
4
  import React, { useRef } from "react";
5
5
  import useForkRef from "../../utils/useForkRef";
6
6
  import { validateTimeInput } from "../../utils";
7
7
  import { Input } from "./Input";
8
- import { HoursWrapper } from "../HoursWrapper";
8
+ import { useInputHours } from "../../hooks/useInputHours";
9
9
  export var InputHours = /*#__PURE__*/React.forwardRef(function (_ref, ref) {
10
- var value = _ref.value,
10
+ var defaultValue = _ref.value,
11
11
  onCancel = _ref.onCancel,
12
12
  onSave = _ref.onSave,
13
- onEnterKeyPress = _ref.onEnterKeyPress,
13
+ externalEnterKeyPress = _ref.onEnterKeyPress,
14
14
  allowEmptyValue = _ref.allowEmptyValue,
15
15
  _ref$withLeadingZero = _ref.withLeadingZero,
16
16
  withLeadingZero = _ref$withLeadingZero === void 0 ? true : _ref$withLeadingZero,
@@ -21,24 +21,42 @@ export var InputHours = /*#__PURE__*/React.forwardRef(function (_ref, ref) {
21
21
  _ref$minuteIncrement = _ref.minuteIncrement,
22
22
  minuteIncrement = _ref$minuteIncrement === void 0 ? 1 : _ref$minuteIncrement,
23
23
  className = _ref.className,
24
+ externalOnChange = _ref.onChange,
25
+ externalOnClick = _ref.onClick,
24
26
  rest = _objectWithoutPropertiesLoose(_ref, _excluded);
25
27
  var inputRef = useRef(null);
26
28
  var handleRef = useForkRef(ref, inputRef);
27
- return /*#__PURE__*/React.createElement(HoursWrapper, {
29
+ var _useInputHours = useInputHours({
30
+ value: defaultValue,
31
+ withLeadingZero: withLeadingZero,
32
+ onSave: onSave,
33
+ validation: validation,
34
+ allowEmptyValue: allowEmptyValue,
35
+ onCancel: onCancel,
36
+ minuteIncrement: minuteIncrement,
37
+ incrementOnlySelected: incrementOnlySelected,
38
+ onEnterKeyPress: externalEnterKeyPress,
39
+ onChange: externalOnChange,
40
+ onClick: externalOnClick
41
+ }, inputRef),
42
+ inputProps = _useInputHours.inputProps;
43
+ var value = inputProps.value,
44
+ onBlur = inputProps.onBlur,
45
+ onKeyDown = inputProps.onKeyDown,
46
+ onChange = inputProps.onChange,
47
+ onClick = inputProps.onClick,
48
+ onDoubleClick = inputProps.onDoubleClick;
49
+ return /*#__PURE__*/React.createElement(Input, _extends({}, rest, {
50
+ className: className,
51
+ placeholder: withLeadingZero ? "00:00" : "0:00",
28
52
  value: value,
29
- onCancel: onCancel,
30
- onSave: onSave,
31
- onEnterKeyPress: onEnterKeyPress,
32
- incrementOnlySelected: incrementOnlySelected,
33
- minuteIncrement: minuteIncrement,
34
- allowEmptyValue: allowEmptyValue,
35
- withLeadingZero: withLeadingZero,
36
- validation: validation,
53
+ onBlur: onBlur,
54
+ onKeyDown: onKeyDown,
55
+ onChange: onChange,
56
+ onClick: onClick,
57
+ onDoubleClick: onDoubleClick,
37
58
  ref: handleRef
38
- }, /*#__PURE__*/React.createElement(Input, _extends({
39
- className: className,
40
- placeholder: withLeadingZero ? "00:00" : "0:00"
41
- }, rest)));
59
+ }));
42
60
  });
43
61
  InputHours.displayName = "InputHours";
44
62
  //# sourceMappingURL=InputHours.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"InputHours.js","names":["React","useRef","useForkRef","validateTimeInput","Input","HoursWrapper","InputHours","forwardRef","ref","value","onCancel","onSave","onEnterKeyPress","allowEmptyValue","withLeadingZero","validation","incrementOnlySelected","minuteIncrement","className","rest","inputRef","handleRef","displayName"],"sources":["../../../../src/components/Input/InputHours.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport useForkRef from \"../../utils/useForkRef\";\nimport { validateTimeInput } from \"../../utils\";\nimport { Input } from \"./Input\";\nimport { HoursWrapper } from \"../HoursWrapper\";\nimport type { InputProps } from \"./Input\";\nimport type { EditableHoursProps } from \"../EditableHours\";\n\nexport interface InputHoursProps\n extends Omit<EditableHoursProps, \"weight\" | \"variant\">,\n Omit<InputProps, \"value\"> {}\n\nexport const InputHours = React.forwardRef<HTMLInputElement, InputHoursProps>(\n (\n {\n value,\n onCancel,\n onSave,\n onEnterKeyPress,\n allowEmptyValue,\n withLeadingZero = true,\n validation = validateTimeInput,\n incrementOnlySelected = false,\n minuteIncrement = 1,\n className,\n ...rest\n },\n ref\n ) => {\n const inputRef = useRef<HTMLInputElement>(null);\n const handleRef = useForkRef(ref, inputRef);\n\n return (\n <HoursWrapper\n value={value}\n onCancel={onCancel}\n onSave={onSave}\n onEnterKeyPress={onEnterKeyPress}\n incrementOnlySelected={incrementOnlySelected}\n minuteIncrement={minuteIncrement}\n allowEmptyValue={allowEmptyValue}\n withLeadingZero={withLeadingZero}\n validation={validation}\n ref={handleRef}\n >\n <Input\n className={className}\n placeholder={withLeadingZero ? \"00:00\" : \"0:00\"}\n {...rest}\n />\n </HoursWrapper>\n );\n }\n);\n\nInputHours.displayName = \"InputHours\";\n"],"mappings":";;;AAAA,OAAOA,KAAK,IAAIC,MAAM,QAAQ,OAAO;AACrC,OAAOC,UAAU,MAAM,wBAAwB;AAC/C,SAASC,iBAAiB,QAAQ,aAAa;AAC/C,SAASC,KAAK,QAAQ,SAAS;AAC/B,SAASC,YAAY,QAAQ,iBAAiB;AAQ9C,OAAO,IAAMC,UAAU,gBAAGN,KAAK,CAACO,UAAU,CACxC,gBAcEC,GAAG,EACA;EAAA,IAbDC,KAAK,QAALA,KAAK;IACLC,QAAQ,QAARA,QAAQ;IACRC,MAAM,QAANA,MAAM;IACNC,eAAe,QAAfA,eAAe;IACfC,eAAe,QAAfA,eAAe;IAAA,4BACfC,eAAe;IAAfA,eAAe,qCAAG,IAAI;IAAA,uBACtBC,UAAU;IAAVA,UAAU,gCAAGZ,iBAAiB;IAAA,6BAC9Ba,qBAAqB;IAArBA,qBAAqB,sCAAG,KAAK;IAAA,4BAC7BC,eAAe;IAAfA,eAAe,qCAAG,CAAC;IACnBC,SAAS,QAATA,SAAS;IACNC,IAAI;EAIT,IAAMC,QAAQ,GAAGnB,MAAM,CAAmB,IAAI,CAAC;EAC/C,IAAMoB,SAAS,GAAGnB,UAAU,CAACM,GAAG,EAAEY,QAAQ,CAAC;EAE3C,oBACE,oBAAC,YAAY;IACX,KAAK,EAAEX,KAAM;IACb,QAAQ,EAAEC,QAAS;IACnB,MAAM,EAAEC,MAAO;IACf,eAAe,EAAEC,eAAgB;IACjC,qBAAqB,EAAEI,qBAAsB;IAC7C,eAAe,EAAEC,eAAgB;IACjC,eAAe,EAAEJ,eAAgB;IACjC,eAAe,EAAEC,eAAgB;IACjC,UAAU,EAAEC,UAAW;IACvB,GAAG,EAAEM;EAAU,gBAEf,oBAAC,KAAK;IACJ,SAAS,EAAEH,SAAU;IACrB,WAAW,EAAEJ,eAAe,GAAG,OAAO,GAAG;EAAO,GAC5CK,IAAI,EACR,CACW;AAEnB,CAAC,CACF;AAEDb,UAAU,CAACgB,WAAW,GAAG,YAAY"}
1
+ {"version":3,"file":"InputHours.js","names":["React","useRef","useForkRef","validateTimeInput","Input","useInputHours","InputHours","forwardRef","ref","defaultValue","value","onCancel","onSave","externalEnterKeyPress","onEnterKeyPress","allowEmptyValue","withLeadingZero","validation","incrementOnlySelected","minuteIncrement","className","externalOnChange","onChange","externalOnClick","onClick","rest","inputRef","handleRef","inputProps","onBlur","onKeyDown","onDoubleClick","displayName"],"sources":["../../../../src/components/Input/InputHours.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport useForkRef from \"../../utils/useForkRef\";\nimport { validateTimeInput } from \"../../utils\";\nimport { Input } from \"./Input\";\nimport type { InputProps } from \"./Input\";\nimport { IInputHours, useInputHours } from \"../../hooks/useInputHours\";\n\nexport interface InputHoursProps\n extends Omit<InputProps, \"value\" | \"onChange\">,\n IInputHours {}\n\nexport const InputHours = React.forwardRef<HTMLInputElement, InputHoursProps>(\n (\n {\n value: defaultValue,\n onCancel,\n onSave,\n onEnterKeyPress: externalEnterKeyPress,\n allowEmptyValue,\n withLeadingZero = true,\n validation = validateTimeInput,\n incrementOnlySelected = false,\n minuteIncrement = 1,\n className,\n onChange: externalOnChange,\n onClick: externalOnClick,\n ...rest\n },\n ref\n ) => {\n const inputRef = useRef<HTMLInputElement>(null);\n const handleRef = useForkRef(ref, inputRef);\n\n const { inputProps } = useInputHours(\n {\n value: defaultValue,\n withLeadingZero,\n onSave,\n validation,\n allowEmptyValue,\n onCancel,\n minuteIncrement,\n incrementOnlySelected,\n onEnterKeyPress: externalEnterKeyPress,\n onChange: externalOnChange,\n onClick: externalOnClick,\n },\n inputRef\n );\n\n const { value, onBlur, onKeyDown, onChange, onClick, onDoubleClick } =\n inputProps;\n\n return (\n <Input\n {...rest}\n className={className}\n placeholder={withLeadingZero ? \"00:00\" : \"0:00\"}\n value={value}\n onBlur={onBlur}\n onKeyDown={onKeyDown}\n onChange={onChange}\n onClick={onClick}\n onDoubleClick={onDoubleClick}\n ref={handleRef}\n />\n );\n }\n);\n\nInputHours.displayName = \"InputHours\";\n"],"mappings":";;;AAAA,OAAOA,KAAK,IAAIC,MAAM,QAAQ,OAAO;AACrC,OAAOC,UAAU,MAAM,wBAAwB;AAC/C,SAASC,iBAAiB,QAAQ,aAAa;AAC/C,SAASC,KAAK,QAAQ,SAAS;AAE/B,SAAsBC,aAAa,QAAQ,2BAA2B;AAMtE,OAAO,IAAMC,UAAU,gBAAGN,KAAK,CAACO,UAAU,CACxC,gBAgBEC,GAAG,EACA;EAAA,IAfMC,YAAY,QAAnBC,KAAK;IACLC,QAAQ,QAARA,QAAQ;IACRC,MAAM,QAANA,MAAM;IACWC,qBAAqB,QAAtCC,eAAe;IACfC,eAAe,QAAfA,eAAe;IAAA,4BACfC,eAAe;IAAfA,eAAe,qCAAG,IAAI;IAAA,uBACtBC,UAAU;IAAVA,UAAU,gCAAGd,iBAAiB;IAAA,6BAC9Be,qBAAqB;IAArBA,qBAAqB,sCAAG,KAAK;IAAA,4BAC7BC,eAAe;IAAfA,eAAe,qCAAG,CAAC;IACnBC,SAAS,QAATA,SAAS;IACCC,gBAAgB,QAA1BC,QAAQ;IACCC,eAAe,QAAxBC,OAAO;IACJC,IAAI;EAIT,IAAMC,QAAQ,GAAGzB,MAAM,CAAmB,IAAI,CAAC;EAC/C,IAAM0B,SAAS,GAAGzB,UAAU,CAACM,GAAG,EAAEkB,QAAQ,CAAC;EAE3C,qBAAuBrB,aAAa,CAClC;MACEK,KAAK,EAAED,YAAY;MACnBO,eAAe,EAAfA,eAAe;MACfJ,MAAM,EAANA,MAAM;MACNK,UAAU,EAAVA,UAAU;MACVF,eAAe,EAAfA,eAAe;MACfJ,QAAQ,EAARA,QAAQ;MACRQ,eAAe,EAAfA,eAAe;MACfD,qBAAqB,EAArBA,qBAAqB;MACrBJ,eAAe,EAAED,qBAAqB;MACtCS,QAAQ,EAAED,gBAAgB;MAC1BG,OAAO,EAAED;IACX,CAAC,EACDG,QAAQ,CACT;IAfOE,UAAU,kBAAVA,UAAU;EAiBlB,IAAQlB,KAAK,GACXkB,UAAU,CADJlB,KAAK;IAAEmB,MAAM,GACnBD,UAAU,CADGC,MAAM;IAAEC,SAAS,GAC9BF,UAAU,CADWE,SAAS;IAAER,QAAQ,GACxCM,UAAU,CADsBN,QAAQ;IAAEE,OAAO,GACjDI,UAAU,CADgCJ,OAAO;IAAEO,aAAa,GAChEH,UAAU,CADyCG,aAAa;EAGlE,oBACE,oBAAC,KAAK,eACAN,IAAI;IACR,SAAS,EAAEL,SAAU;IACrB,WAAW,EAAEJ,eAAe,GAAG,OAAO,GAAG,MAAO;IAChD,KAAK,EAAEN,KAAM;IACb,MAAM,EAAEmB,MAAO;IACf,SAAS,EAAEC,SAAU;IACrB,QAAQ,EAAER,QAAS;IACnB,OAAO,EAAEE,OAAQ;IACjB,aAAa,EAAEO,aAAc;IAC7B,GAAG,EAAEJ;EAAU,GACf;AAEN,CAAC,CACF;AAEDrB,UAAU,CAAC0B,WAAW,GAAG,YAAY"}
@@ -0,0 +1,27 @@
1
+ import { RefObject, MouseEvent } from "react";
2
+ export interface IInputHours {
3
+ value?: string | number;
4
+ withLeadingZero?: boolean;
5
+ onSave?: (e: Event) => void;
6
+ validation?: (...args: any[]) => boolean;
7
+ allowEmptyValue?: boolean;
8
+ onCancel?: (e: Event) => void;
9
+ minuteIncrement?: number;
10
+ incrementOnlySelected?: boolean;
11
+ onEnterKeyPress?: (val: string) => void;
12
+ onChange?: (val: string) => void;
13
+ onClick?: (event: MouseEvent<HTMLInputElement>) => void;
14
+ }
15
+ export declare const useInputHours: ({ value, withLeadingZero, onSave, validation, allowEmptyValue, onCancel, minuteIncrement, incrementOnlySelected, onEnterKeyPress, onChange, onClick, }: IInputHours, inputRef: RefObject<HTMLInputElement | null>) => {
16
+ inputProps: {
17
+ value: string;
18
+ onBlur: (e: any) => void;
19
+ onKeyDown: (e: any) => void;
20
+ onChange: (e: any) => void;
21
+ onClick: (e: any) => void;
22
+ onDoubleClick: () => void;
23
+ };
24
+ setCurrentValue: import("react").Dispatch<import("react").SetStateAction<string>>;
25
+ setPrevValue: import("react").Dispatch<import("react").SetStateAction<string>>;
26
+ };
27
+ //# sourceMappingURL=useInputHours.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useInputHours.d.ts","sourceRoot":"","sources":["../../../src/hooks/useInputHours.tsx"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EAKT,UAAU,EACX,MAAM,OAAO,CAAC;AAIf,MAAM,WAAW,WAAW;IAC1B,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACxB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,MAAM,CAAC,EAAE,CAAC,CAAC,EAAE,KAAK,KAAK,IAAI,CAAC;IAC5B,UAAU,CAAC,EAAE,CAAC,GAAG,IAAI,OAAA,KAAK,OAAO,CAAC;IAClC,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,QAAQ,CAAC,EAAE,CAAC,CAAC,EAAE,KAAK,KAAK,IAAI,CAAC;IAC9B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,qBAAqB,CAAC,EAAE,OAAO,CAAC;IAChC,eAAe,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,IAAI,CAAC;IACxC,QAAQ,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,IAAI,CAAC;IACjC,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,UAAU,CAAC,gBAAgB,CAAC,KAAK,IAAI,CAAC;CACzD;AAED,eAAO,MAAM,aAAa,2JAarB,WAAW,YACJ,UAAU,gBAAgB,GAAG,IAAI,CAAC;;;;;;;;;;;CA8Q7C,CAAC"}
@@ -1,29 +1,20 @@
1
- import _extends from "@babel/runtime/helpers/esm/extends";
2
- import React, { useCallback, useEffect, useRef, useState } from "react";
3
- import { decimalToHours } from "../../utils/timeUtils";
4
- import useForkRef from "../../utils/useForkRef";
5
- import { validateTimeInput } from "../../utils";
6
- import { EditableContent } from "../EditableContent";
7
-
8
- // eslint-disable-next-line @typescript-eslint/no-empty-interface
9
-
10
- export var HoursWrapper = /*#__PURE__*/React.forwardRef(function (_ref, ref) {
11
- var children = _ref.children,
12
- value = _ref.value,
13
- onCancel = _ref.onCancel,
1
+ import { useCallback, useMemo, useRef, useState } from "react";
2
+ import { decimalToHours } from "../utils";
3
+ import { validateTimeInput } from "../utils";
4
+ export var useInputHours = function useInputHours(_ref, inputRef) {
5
+ var value = _ref.value,
6
+ withLeadingZero = _ref.withLeadingZero,
14
7
  onSave = _ref.onSave,
15
- onEnterKeyPress = _ref.onEnterKeyPress,
16
- allowEmptyValue = _ref.allowEmptyValue,
17
- _ref$withLeadingZero = _ref.withLeadingZero,
18
- withLeadingZero = _ref$withLeadingZero === void 0 ? true : _ref$withLeadingZero,
19
8
  _ref$validation = _ref.validation,
20
9
  validation = _ref$validation === void 0 ? validateTimeInput : _ref$validation,
21
- _ref$incrementOnlySel = _ref.incrementOnlySelected,
22
- incrementOnlySelected = _ref$incrementOnlySel === void 0 ? false : _ref$incrementOnlySel,
10
+ allowEmptyValue = _ref.allowEmptyValue,
11
+ onCancel = _ref.onCancel,
23
12
  _ref$minuteIncrement = _ref.minuteIncrement,
24
- minuteIncrement = _ref$minuteIncrement === void 0 ? 1 : _ref$minuteIncrement;
25
- var inputRef = useRef(null);
26
- var handleRef = useForkRef(ref, inputRef);
13
+ minuteIncrement = _ref$minuteIncrement === void 0 ? 1 : _ref$minuteIncrement,
14
+ incrementOnlySelected = _ref.incrementOnlySelected,
15
+ onEnterKeyPress = _ref.onEnterKeyPress,
16
+ onChange = _ref.onChange,
17
+ onClick = _ref.onClick;
27
18
  var _useState = useState(function () {
28
19
  return decimalToHours(value, withLeadingZero);
29
20
  }),
@@ -35,17 +26,6 @@ export var HoursWrapper = /*#__PURE__*/React.forwardRef(function (_ref, ref) {
35
26
  prevValue = _useState2[0],
36
27
  setPrevValue = _useState2[1];
37
28
  var escapeRef = useRef(false);
38
- useEffect(function () {
39
- var _value;
40
- if (value !== undefined) {
41
- _value = decimalToHours(value, withLeadingZero);
42
- }
43
- if (currentValue !== _value) {
44
- setCurrentValue(_value);
45
- setPrevValue(_value);
46
- }
47
- // eslint-disable-next-line react-hooks/exhaustive-deps
48
- }, [value]);
49
29
  var handleBlur = useCallback(function (e) {
50
30
  if (escapeRef.current) {
51
31
  setCurrentValue(prevValue);
@@ -124,11 +104,11 @@ export var HoursWrapper = /*#__PURE__*/React.forwardRef(function (_ref, ref) {
124
104
  }
125
105
  }
126
106
  }
127
- }, [currentValue, incrementOnlySelected, minuteIncrement, validation, withLeadingZero]);
107
+ }, [currentValue, incrementOnlySelected, inputRef, minuteIncrement, validation, withLeadingZero]);
128
108
  var handleKeyDown = useCallback(function (e) {
129
109
  if (e.key === "Enter") {
130
110
  e.target.blur();
131
- onEnterKeyPress && onEnterKeyPress();
111
+ if (typeof onEnterKeyPress === "function") onEnterKeyPress(e.target.value);
132
112
  }
133
113
  if (e.key === "ArrowLeft") {
134
114
  return;
@@ -197,11 +177,12 @@ export var HoursWrapper = /*#__PURE__*/React.forwardRef(function (_ref, ref) {
197
177
  return;
198
178
  }
199
179
  }
200
- }, [handleIncrementDecrement, onCancel, onEnterKeyPress, validation, withLeadingZero]);
180
+ }, [handleIncrementDecrement, inputRef, onCancel, onEnterKeyPress, validation, withLeadingZero]);
201
181
  var handleChange = useCallback(function (e) {
202
182
  setCurrentValue(e.target.value);
203
- }, []);
204
- var handleClick = function handleClick() {
183
+ if (onChange) onChange(e.target.value);
184
+ }, [onChange]);
185
+ var handleClick = useCallback(function (e) {
205
186
  var _inputRef$current5;
206
187
  var selectionStart = (_inputRef$current5 = inputRef.current) == null ? void 0 : _inputRef$current5.selectionStart;
207
188
  if (inputRef.current && currentValue && currentValue.length > 0 && typeof selectionStart === "number") {
@@ -214,38 +195,30 @@ export var HoursWrapper = /*#__PURE__*/React.forwardRef(function (_ref, ref) {
214
195
  (_inputRef$current7 = inputRef.current) == null ? void 0 : _inputRef$current7.setSelectionRange(dotsIndex + 1, currentValue.length);
215
196
  }
216
197
  }
217
- };
218
- var handleDoubleClick = function handleDoubleClick() {
198
+ if (typeof onClick === "function") {
199
+ onClick(e);
200
+ }
201
+ }, [currentValue, inputRef, onClick]);
202
+ var handleDoubleClick = useCallback(function () {
219
203
  if (inputRef.current) {
220
204
  var _inputRef$current8;
221
205
  (_inputRef$current8 = inputRef.current) == null ? void 0 : _inputRef$current8.select();
222
206
  }
207
+ }, [inputRef]);
208
+ var inputProps = useMemo(function () {
209
+ return {
210
+ value: currentValue,
211
+ onBlur: handleBlur,
212
+ onKeyDown: handleKeyDown,
213
+ onChange: handleChange,
214
+ onClick: handleClick,
215
+ onDoubleClick: handleDoubleClick
216
+ };
217
+ }, [currentValue, handleBlur, handleChange, handleClick, handleDoubleClick, handleKeyDown]);
218
+ return {
219
+ inputProps: inputProps,
220
+ setCurrentValue: setCurrentValue,
221
+ setPrevValue: setPrevValue
223
222
  };
224
- var inputProps = {
225
- value: currentValue,
226
- onBlur: handleBlur,
227
- onKeyDown: handleKeyDown,
228
- onChange: handleChange,
229
- onClick: handleClick,
230
- onDoubleClick: handleDoubleClick,
231
- onEnterKeyPress: onEnterKeyPress
232
- };
233
- if (!children) {
234
- console.error("No children provided!");
235
- return null;
236
- }
237
- return /*#__PURE__*/React.createElement(React.Fragment, null, React.Children.map(children, function (child) {
238
- var el = child;
239
- if (el && el.type === EditableContent) {
240
- return /*#__PURE__*/React.cloneElement(child, {
241
- ref: handleRef,
242
- inputProps: inputProps
243
- });
244
- }
245
- return /*#__PURE__*/React.cloneElement(child, _extends({
246
- ref: handleRef
247
- }, inputProps));
248
- }));
249
- });
250
- HoursWrapper.displayName = "HoursWrapper";
251
- //# sourceMappingURL=HoursWrapper.js.map
223
+ };
224
+ //# sourceMappingURL=useInputHours.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useInputHours.js","names":["useCallback","useMemo","useRef","useState","decimalToHours","validateTimeInput","useInputHours","inputRef","value","withLeadingZero","onSave","validation","allowEmptyValue","onCancel","minuteIncrement","incrementOnlySelected","onEnterKeyPress","onChange","onClick","currentValue","setCurrentValue","prevValue","setPrevValue","escapeRef","handleBlur","e","current","target","trim","length","_value","handleIncrementDecrement","increment","selectionStart","dotsIndex","indexOf","split","map","Number","hours","minutes","newHours","newMinutes","newMinutesString","newHoursString","newValue","requestAnimationFrame","newDotsIndex","isHoursSelected","newSelectionStart","selectionEnd","setSelectionRange","handleKeyDown","key","blur","metaKey","ctrlKey","select","input","start","end","shiftKey","isMinutesSelected","preventDefault","substring","handleChange","handleClick","handleDoubleClick","inputProps","onBlur","onKeyDown","onDoubleClick"],"sources":["../../../src/hooks/useInputHours.tsx"],"sourcesContent":["import {\n RefObject,\n useCallback,\n useMemo,\n useRef,\n useState,\n MouseEvent,\n} from \"react\";\nimport { decimalToHours } from \"../utils\";\nimport { validateTimeInput } from \"../utils\";\n\nexport interface IInputHours {\n value?: string | number;\n withLeadingZero?: boolean;\n onSave?: (e: Event) => void;\n validation?: (...args) => boolean;\n allowEmptyValue?: boolean;\n onCancel?: (e: Event) => void;\n minuteIncrement?: number;\n incrementOnlySelected?: boolean;\n onEnterKeyPress?: (val: string) => void;\n onChange?: (val: string) => void;\n onClick?: (event: MouseEvent<HTMLInputElement>) => void;\n}\n\nexport const useInputHours = (\n {\n value,\n withLeadingZero,\n onSave,\n validation = validateTimeInput,\n allowEmptyValue,\n onCancel,\n minuteIncrement = 1,\n incrementOnlySelected,\n onEnterKeyPress,\n onChange,\n onClick,\n }: IInputHours,\n inputRef: RefObject<HTMLInputElement | null>\n) => {\n const [currentValue, setCurrentValue] = useState(() =>\n decimalToHours(value, withLeadingZero)\n );\n const [prevValue, setPrevValue] = useState(() =>\n decimalToHours(value, withLeadingZero)\n );\n\n const escapeRef = useRef(false);\n\n const handleBlur = useCallback(\n (e) => {\n if (escapeRef.current) {\n setCurrentValue(prevValue);\n } else {\n if (e.target.value.trim().length > 0 && prevValue !== e.target.value) {\n const _value = decimalToHours(e.target.value, withLeadingZero);\n setPrevValue(_value);\n setCurrentValue(_value);\n typeof onSave === \"function\" && onSave(e);\n } else {\n if (!allowEmptyValue) {\n setCurrentValue(prevValue);\n typeof onCancel === \"function\" && onCancel(e);\n } else {\n if (typeof onSave === \"function\" && prevValue !== e.target.value) {\n onSave(e);\n } else {\n typeof onCancel === \"function\" && onCancel(e);\n }\n }\n }\n }\n },\n [allowEmptyValue, onCancel, onSave, prevValue, withLeadingZero]\n );\n\n const handleIncrementDecrement = useCallback(\n (increment: boolean) => {\n if (inputRef.current) {\n const selectionStart = inputRef.current.selectionStart;\n if (selectionStart !== null) {\n const dotsIndex = currentValue.indexOf(\":\");\n const [hours, minutes] = currentValue.split(\":\").map(Number);\n let newHours = hours;\n let newMinutes = minutes;\n\n if (selectionStart < dotsIndex) {\n if (increment) {\n newHours += 1;\n } else {\n newHours -= 1;\n if (newHours < 0) newHours = 0;\n }\n } else if (selectionStart > dotsIndex) {\n if (increment) {\n newMinutes += minuteIncrement;\n if (newMinutes > 59) {\n newMinutes = 0;\n if (!incrementOnlySelected) newHours += 1;\n }\n } else {\n if (newMinutes >= minuteIncrement || newMinutes === 0) {\n newMinutes -= minuteIncrement;\n if (newMinutes < 0 && newHours > 0) {\n newMinutes = 60 - minuteIncrement;\n if (!incrementOnlySelected) newHours -= 1;\n }\n if (newHours < 0) {\n newHours = 0;\n }\n } else {\n newMinutes = 0;\n }\n }\n }\n\n const newMinutesString =\n newMinutes < 10 ? `0${newMinutes}` : newMinutes;\n const newHoursString =\n withLeadingZero && newHours < 10 ? `0${newHours}` : newHours;\n const newValue = `${newHoursString}:${newMinutesString}`;\n\n if (validation(newValue, withLeadingZero)) {\n setCurrentValue(newValue);\n\n requestAnimationFrame(() => {\n const newDotsIndex = newValue.indexOf(\":\");\n const isHoursSelected = selectionStart < newDotsIndex;\n const newSelectionStart = isHoursSelected ? 0 : newDotsIndex + 1;\n const selectionEnd = isHoursSelected\n ? newDotsIndex\n : newValue.length;\n inputRef.current?.setSelectionRange(\n newSelectionStart,\n selectionEnd\n );\n });\n }\n }\n }\n },\n [\n currentValue,\n incrementOnlySelected,\n inputRef,\n minuteIncrement,\n validation,\n withLeadingZero,\n ]\n );\n\n const handleKeyDown = useCallback(\n (e) => {\n if (e.key === \"Enter\") {\n e.target.blur();\n if (typeof onEnterKeyPress === \"function\")\n onEnterKeyPress(e.target.value);\n }\n if (e.key === \"ArrowLeft\") {\n return;\n }\n if (e.key === \"ArrowRight\") {\n return;\n }\n if (e.key === \"Escape\") {\n escapeRef.current = true;\n e.target.blur();\n typeof onCancel === \"function\" && onCancel(e);\n escapeRef.current = false;\n }\n if (e.key === \"Backspace\") {\n return;\n }\n if ((e.metaKey || e.ctrlKey) && e.key === \"a\") {\n inputRef.current?.select();\n return;\n }\n const input = e.target;\n const start = input.selectionStart;\n const end = input.selectionEnd;\n const currentValue = input.value;\n if (e.key === \"Tab\") {\n if (start !== end) {\n if (e.shiftKey) {\n const newDotsIndex = currentValue.indexOf(\":\");\n const isMinutesSelected = start > newDotsIndex;\n if (isMinutesSelected) {\n e.preventDefault();\n inputRef.current?.setSelectionRange(0, newDotsIndex);\n }\n } else {\n const newDotsIndex = currentValue.indexOf(\":\");\n const isHoursSelected = start < newDotsIndex;\n if (isHoursSelected) {\n e.preventDefault();\n inputRef.current?.setSelectionRange(\n newDotsIndex + 1,\n currentValue.length\n );\n }\n }\n }\n return;\n }\n\n if (start !== end) {\n if (e.key === \"ArrowUp\") {\n handleIncrementDecrement(true);\n return;\n }\n if (e.key === \"ArrowDown\") {\n handleIncrementDecrement(false);\n return;\n }\n const newValue =\n currentValue.substring(0, start) +\n e.key +\n currentValue.substring(end);\n if (!validation(newValue, withLeadingZero)) {\n e.preventDefault();\n return;\n }\n } else {\n const newValue =\n currentValue.substring(0, start) +\n e.key +\n currentValue.substring(end);\n\n if (!validation(newValue, withLeadingZero)) {\n e.preventDefault();\n return;\n }\n }\n },\n [\n handleIncrementDecrement,\n inputRef,\n onCancel,\n onEnterKeyPress,\n validation,\n withLeadingZero,\n ]\n );\n\n const handleChange = useCallback(\n (e) => {\n setCurrentValue(e.target.value);\n if (onChange) onChange(e.target.value);\n },\n [onChange]\n );\n\n const handleClick = useCallback(\n (e) => {\n const selectionStart = inputRef.current?.selectionStart;\n if (\n inputRef.current &&\n currentValue &&\n currentValue.length > 0 &&\n typeof selectionStart === \"number\"\n ) {\n const dotsIndex = currentValue.indexOf(\":\");\n if (selectionStart < dotsIndex) {\n inputRef.current?.setSelectionRange(0, dotsIndex);\n } else if (selectionStart >= dotsIndex) {\n inputRef.current?.setSelectionRange(\n dotsIndex + 1,\n currentValue.length\n );\n }\n }\n\n if (typeof onClick === \"function\") {\n onClick(e);\n }\n },\n [currentValue, inputRef, onClick]\n );\n\n const handleDoubleClick = useCallback(() => {\n if (inputRef.current) {\n inputRef.current?.select();\n }\n }, [inputRef]);\n\n const inputProps = useMemo(() => {\n return {\n value: currentValue,\n onBlur: handleBlur,\n onKeyDown: handleKeyDown,\n onChange: handleChange,\n onClick: handleClick,\n onDoubleClick: handleDoubleClick,\n };\n }, [\n currentValue,\n handleBlur,\n handleChange,\n handleClick,\n handleDoubleClick,\n handleKeyDown,\n ]);\n\n return {\n inputProps,\n setCurrentValue,\n setPrevValue,\n };\n};\n"],"mappings":"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"}