@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.
@@ -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,gBA8Q7B,CAAC;AAEF,eAAO,MAAM,uBAAuB,EAAE,QAAQ,CAC5C,WAAW,EACX,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAsBxB,CAAC"}
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,KAAqB,MAAM,OAAO,CAAC;AAK1C,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,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,qGAuGjC,CAAC"}
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.size,b=void 0===d?"small":d,p=e.hasCurrency,v=e.onChange,f=e.onPlusClick,N=e.onMinusClick,z=e.min,g=e.max,y=e.defaultValue,_=e.isLoading,x=void 0!==_&&_,C=(0,n.useTranslation(["Sale"]).t)("Sale:soldOut"),k="big"===b,E=s(c,"licklist-number-input-horizontal");return i.createElement("div",{className:E},i.createElement("button",{type:"button",onClick:function(){void 0!==z&&m>z&&N(m-1),void 0===z&&N(m-1)},className:["licklist-number-input-horizontal__btn-minus",k?"big-sizes-btn":"small-sizes-btn"].join(" "),disabled:o},i.createElement(l.default,{type:"minus",className:k?"big_icon":"small_icon"})),i.createElement("div",{className:["position-relative d-flex",o&&k&&"w-100"].join(" ")},p&&i.createElement("div",{className:"currency"},"£"),i.createElement(a.FormControl,{ref:t,onClick:function(e){return e.target.select()},type:o&&k?"text":"number",className:k?"big-sizes-input":"small-sizes-input",onChange:function(e){return v(Number(e.target.value))},value:o&&k&&!x?C:m,min:z,max:g,defaultValue:y,disabled:o})),i.createElement("button",{type:"button",onClick:function(){void 0!==g&&m<g&&f(m+1),void 0===g&&f(m+1)},className:["licklist-number-input-horizontal__btn-plus",k?"big-sizes-btn":"small-sizes-btn"].join(" "),disabled:o},i.createElement(l.default,{type:"plus",className:k?"big_icon":"small_icon"})))}));r.displayName="NumberInputHorizontal",exports.NumberInputHorizontal=r;
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
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@licklist/design",
3
- "version": "0.46.0",
3
+ "version": "0.47.0",
4
4
  "repository": {
5
5
  "type": "git",
6
6
  "url": "git+ssh://git@bitbucket.org/artelogicsoft/licklist_design.git"
@@ -126,7 +126,8 @@ export const DateAndRecurrenceInput = ({
126
126
  }
127
127
  }
128
128
 
129
- const availableTime = availableTimesFormRef?.current?.getValues()?.availableTimes || null;
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) => e.target.select();
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={hasBigSize ? "big-sizes-input" : "small-sizes-input"}
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