@licklist/design 0.46.0 → 0.47.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/product-set/control/DateAndRecurrenceInput.d.ts.map +1 -1
- package/dist/sales/manual-booking/number-input-horizontal/NumberInputHorizontal.d.ts +3 -1
- package/dist/sales/manual-booking/number-input-horizontal/NumberInputHorizontal.d.ts.map +1 -1
- package/dist/sales/manual-booking/number-input-horizontal/NumberInputHorizontal.js +1 -1
- package/package.json +1 -1
- package/src/product-set/control/DateAndRecurrenceInput.tsx +2 -1
- package/src/sales/manual-booking/number-input-horizontal/NumberInputHorizontal.stories.tsx +48 -0
- package/src/sales/manual-booking/number-input-horizontal/NumberInputHorizontal.tsx +17 -4
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DateAndRecurrenceInput.d.ts","sourceRoot":"","sources":["../../../src/product-set/control/DateAndRecurrenceInput.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAO1C,OAAO,EAAE,QAAQ,EAAE,MAAM,4DAA4D,CAAC;AACtF,OAAO,EAAE,oBAAoB,EAAE,MAAM,uEAAuE,CAAC;AAuB7G,MAAM,WAAW,4BAA4B;IAC3C,eAAe,CAAC,EAAE,OAAO,CAAC,oBAAoB,CAAC,EAAE,CAAC;CACnD;AAED,UAAU,2BAA2B;IACnC,qBAAqB,CAAC,EAAE,OAAO,CAAC;IAChC,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC;IACvB,4BAA4B,EAAE,OAAO,CAAC;IACtC,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB;AAED,eAAO,MAAM,sBAAsB,mFAKhC,2BAA2B,
|
|
1
|
+
{"version":3,"file":"DateAndRecurrenceInput.d.ts","sourceRoot":"","sources":["../../../src/product-set/control/DateAndRecurrenceInput.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAO1C,OAAO,EAAE,QAAQ,EAAE,MAAM,4DAA4D,CAAC;AACtF,OAAO,EAAE,oBAAoB,EAAE,MAAM,uEAAuE,CAAC;AAuB7G,MAAM,WAAW,4BAA4B;IAC3C,eAAe,CAAC,EAAE,OAAO,CAAC,oBAAoB,CAAC,EAAE,CAAC;CACnD;AAED,UAAU,2BAA2B;IACnC,qBAAqB,CAAC,EAAE,OAAO,CAAC;IAChC,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC;IACvB,4BAA4B,EAAE,OAAO,CAAC;IACtC,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB;AAED,eAAO,MAAM,sBAAsB,mFAKhC,2BAA2B,gBA+Q7B,CAAC;AAEF,eAAO,MAAM,uBAAuB,EAAE,QAAQ,CAC5C,WAAW,EACX,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAsBxB,CAAC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import React from "react";
|
|
1
|
+
import React, { SyntheticEvent } from "react";
|
|
2
2
|
type Sizes = "big" | "small";
|
|
3
3
|
interface NumberInputHorizontalProps {
|
|
4
4
|
disabled?: boolean;
|
|
@@ -7,6 +7,8 @@ interface NumberInputHorizontalProps {
|
|
|
7
7
|
onChange: (value: number) => void;
|
|
8
8
|
onPlusClick: (value: number) => void;
|
|
9
9
|
onMinusClick: (value: number) => void;
|
|
10
|
+
onSelect?: (e: SyntheticEvent) => void;
|
|
11
|
+
step?: number;
|
|
10
12
|
min?: number;
|
|
11
13
|
max?: number;
|
|
12
14
|
size?: Sizes;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NumberInputHorizontal.d.ts","sourceRoot":"","sources":["../../../../src/sales/manual-booking/number-input-horizontal/NumberInputHorizontal.tsx"],"names":[],"mappings":"AACA,OAAO,
|
|
1
|
+
{"version":3,"file":"NumberInputHorizontal.d.ts","sourceRoot":"","sources":["../../../../src/sales/manual-booking/number-input-horizontal/NumberInputHorizontal.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,EAAE,cAAc,EAAc,MAAM,OAAO,CAAC;AAK1D,KAAK,KAAK,GAAG,KAAK,GAAG,OAAO,CAAC;AAE7B,UAAU,0BAA0B;IAClC,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAClC,WAAW,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACrC,YAAY,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACtC,QAAQ,CAAC,EAAE,CAAC,CAAC,EAAE,cAAc,KAAK,IAAI,CAAC;IACvC,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,KAAK,CAAC;IACb,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB;AAED,eAAO,MAAM,qBAAqB,qGAkHjC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";function e(e){return e&&"object"==typeof e&&"default"in e?e.default:e}Object.defineProperty(exports,"__esModule",{value:!0});var t=require("react"),i=e(t),n=require("react-i18next"),a=require("react-bootstrap"),l=require("../../../static/Icon.js"),s=e(require("clsx"));require("../../../static/index.js");var r=t.forwardRef((function(e,t){var r=e.disabled,o=void 0!==r&&r,u=e.className,c=void 0===u?"":u,m=e.value,d=e.
|
|
1
|
+
"use strict";function e(e){return e&&"object"==typeof e&&"default"in e?e.default:e}Object.defineProperty(exports,"__esModule",{value:!0});var t=require("react"),i=e(t),n=require("react-i18next"),a=require("react-bootstrap"),l=require("../../../static/Icon.js"),s=e(require("clsx"));require("../../../static/index.js");var r=t.forwardRef((function(e,t){var r=e.disabled,o=void 0!==r&&r,u=e.className,c=void 0===u?"":u,m=e.value,d=e.step,b=e.size,p=void 0===b?"small":b,v=e.hasCurrency,f=e.onChange,N=e.onPlusClick,z=e.onMinusClick,g=e.onSelect,y=e.min,_=e.max,x=e.defaultValue,C=e.isLoading,k=void 0!==C&&C,E=(0,n.useTranslation(["Sale"]).t)("Sale:soldOut"),j="big"===p,h=s(c,"licklist-number-input-horizontal");return i.createElement("div",{className:h},i.createElement("button",{type:"button",onClick:function(){void 0!==y&&m>y&&z(m-1),void 0===y&&z(m-1)},className:["licklist-number-input-horizontal__btn-minus",j?"big-sizes-btn":"small-sizes-btn"].join(" "),disabled:o},i.createElement(l.default,{type:"minus",className:j?"big_icon":"small_icon"})),i.createElement("div",{className:["position-relative d-flex",o&&j&&"w-100"].join(" ")},v&&i.createElement("div",{className:"currency"},"£"),i.createElement(a.FormControl,{ref:t,onClick:function(e){g&&g(e),e.target.select()},type:o&&j?"text":"number",className:s(j?"big-sizes-input":"small-sizes-input",o&&"border-0"),onChange:function(e){return f(Number(e.target.value))},value:o&&j&&!k?E:m,min:y,max:_,step:d,defaultValue:x,disabled:o&&!g})),i.createElement("button",{type:"button",onClick:function(){void 0!==_&&m<_&&N(m+1),void 0===_&&N(m+1)},className:["licklist-number-input-horizontal__btn-plus",j?"big-sizes-btn":"small-sizes-btn"].join(" "),disabled:o},i.createElement(l.default,{type:"plus",className:j?"big_icon":"small_icon"})))}));r.displayName="NumberInputHorizontal",exports.NumberInputHorizontal=r;
|
package/package.json
CHANGED
|
@@ -126,7 +126,8 @@ export const DateAndRecurrenceInput = ({
|
|
|
126
126
|
}
|
|
127
127
|
}
|
|
128
128
|
|
|
129
|
-
const availableTime =
|
|
129
|
+
const availableTime =
|
|
130
|
+
availableTimesFormRef?.current?.getValues()?.availableTimes || null;
|
|
130
131
|
|
|
131
132
|
const values = {
|
|
132
133
|
rrule: next.rrule,
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import React, { useRef, useState } from "react";
|
|
2
|
+
import { Meta, Story } from "@storybook/react";
|
|
3
|
+
import { NumberInputHorizontal } from "./NumberInputHorizontal";
|
|
4
|
+
|
|
5
|
+
export default {
|
|
6
|
+
title: "Manual Booking/NumberInputHorizontal",
|
|
7
|
+
} as Meta;
|
|
8
|
+
|
|
9
|
+
export const Default: Story<any> = (args) => {
|
|
10
|
+
const ref = useRef(null);
|
|
11
|
+
const [value, setValue] = useState(0);
|
|
12
|
+
const [isDisabled, setDisabled] = useState(true);
|
|
13
|
+
|
|
14
|
+
const onPriceClick = (e) => {
|
|
15
|
+
if (!isDisabled) {
|
|
16
|
+
return;
|
|
17
|
+
}
|
|
18
|
+
console.log("click");
|
|
19
|
+
setDisabled(false);
|
|
20
|
+
};
|
|
21
|
+
|
|
22
|
+
return (
|
|
23
|
+
<div
|
|
24
|
+
role="button"
|
|
25
|
+
tabIndex={0}
|
|
26
|
+
onClick={onPriceClick}
|
|
27
|
+
onKeyDown={onPriceClick}
|
|
28
|
+
style={{ height: "250px", width: "370px" }}
|
|
29
|
+
>
|
|
30
|
+
<NumberInputHorizontal
|
|
31
|
+
ref={ref}
|
|
32
|
+
hasCurrency
|
|
33
|
+
onSelect={onPriceClick}
|
|
34
|
+
onChange={(val) => {
|
|
35
|
+
setValue(val);
|
|
36
|
+
}}
|
|
37
|
+
onMinusClick={() => {
|
|
38
|
+
setValue(value - 1 || 0);
|
|
39
|
+
}}
|
|
40
|
+
onPlusClick={() => {
|
|
41
|
+
setValue((value ?? 0) + 1);
|
|
42
|
+
}}
|
|
43
|
+
value={value}
|
|
44
|
+
disabled={isDisabled}
|
|
45
|
+
/>
|
|
46
|
+
</div>
|
|
47
|
+
);
|
|
48
|
+
};
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import clsx from "clsx";
|
|
2
|
-
import React, { forwardRef } from "react";
|
|
2
|
+
import React, { SyntheticEvent, forwardRef } from "react";
|
|
3
3
|
import { FormControl } from "react-bootstrap";
|
|
4
4
|
import { useTranslation } from "react-i18next";
|
|
5
5
|
import { Icon } from "../../../static";
|
|
@@ -13,6 +13,8 @@ interface NumberInputHorizontalProps {
|
|
|
13
13
|
onChange: (value: number) => void;
|
|
14
14
|
onPlusClick: (value: number) => void;
|
|
15
15
|
onMinusClick: (value: number) => void;
|
|
16
|
+
onSelect?: (e: SyntheticEvent) => void;
|
|
17
|
+
step?: number;
|
|
16
18
|
min?: number;
|
|
17
19
|
max?: number;
|
|
18
20
|
size?: Sizes;
|
|
@@ -30,11 +32,13 @@ export const NumberInputHorizontal = forwardRef<
|
|
|
30
32
|
disabled = false,
|
|
31
33
|
className = "",
|
|
32
34
|
value,
|
|
35
|
+
step,
|
|
33
36
|
size = "small",
|
|
34
37
|
hasCurrency,
|
|
35
38
|
onChange,
|
|
36
39
|
onPlusClick,
|
|
37
40
|
onMinusClick,
|
|
41
|
+
onSelect,
|
|
38
42
|
min,
|
|
39
43
|
max,
|
|
40
44
|
defaultValue,
|
|
@@ -54,7 +58,12 @@ export const NumberInputHorizontal = forwardRef<
|
|
|
54
58
|
}
|
|
55
59
|
};
|
|
56
60
|
|
|
57
|
-
const onClick = (e) =>
|
|
61
|
+
const onClick = (e) => {
|
|
62
|
+
if (onSelect) {
|
|
63
|
+
onSelect(e);
|
|
64
|
+
}
|
|
65
|
+
e.target.select();
|
|
66
|
+
};
|
|
58
67
|
|
|
59
68
|
const handleArrowDownClick = () => {
|
|
60
69
|
if (min !== undefined && value > min) {
|
|
@@ -98,13 +107,17 @@ export const NumberInputHorizontal = forwardRef<
|
|
|
98
107
|
ref={ref}
|
|
99
108
|
onClick={onClick}
|
|
100
109
|
type={disabled && hasBigSize ? "text" : "number"}
|
|
101
|
-
className={
|
|
110
|
+
className={clsx(
|
|
111
|
+
hasBigSize ? "big-sizes-input" : "small-sizes-input",
|
|
112
|
+
disabled && "border-0"
|
|
113
|
+
)}
|
|
102
114
|
onChange={(e) => onChange(Number(e.target.value))}
|
|
103
115
|
value={disabled && hasBigSize && !isLoading ? soldOut : value}
|
|
104
116
|
min={min}
|
|
105
117
|
max={max}
|
|
118
|
+
step={step}
|
|
106
119
|
defaultValue={defaultValue}
|
|
107
|
-
disabled={disabled}
|
|
120
|
+
disabled={disabled && !onSelect}
|
|
108
121
|
/>
|
|
109
122
|
</div>
|
|
110
123
|
<button
|