@cruk/cruk-react-components 3.0.0 → 3.1.1

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.
@@ -13,10 +13,11 @@ declare const _default: {
13
13
  isValidVisible?: boolean | undefined;
14
14
  isInvalidVisible?: boolean | undefined;
15
15
  label?: string | undefined;
16
+ hintText?: string | undefined;
16
17
  onAddressError?: ((error: Error) => void) | undefined;
17
18
  onBlur?: ((e: React.FocusEvent<HTMLInputElement, Element>) => void) | undefined;
18
19
  ref?: React.Ref<HTMLInputElement> | undefined;
19
- }, "label" | "apiKey" | "countries" | "errorMessage" | "hasError" | "isValid" | "isValidVisible" | "isInvalidVisible" | "onAddressError" | "onAddressSelected" | keyof React.InputHTMLAttributes<HTMLInputElement>> & React.RefAttributes<HTMLInputElement>>;
20
+ }, "label" | "apiKey" | "countries" | "errorMessage" | "hasError" | "isValid" | "isValidVisible" | "isInvalidVisible" | "hintText" | "onAddressError" | "onAddressSelected" | keyof React.InputHTMLAttributes<HTMLInputElement>> & React.RefAttributes<HTMLInputElement>>;
20
21
  args: {
21
22
  disabled: boolean;
22
23
  errorMessage: string;
@@ -26,6 +27,8 @@ declare const _default: {
26
27
  isValid: boolean;
27
28
  isValidVisible: boolean;
28
29
  isInvalidVisible: boolean;
30
+ apiKey: string;
31
+ onAddressSelected: (address: unknown) => void;
29
32
  };
30
33
  tags: string[];
31
34
  };
@@ -19,6 +19,8 @@ export type AddressLookupProps = InputHTMLAttributes<HTMLInputElement> & {
19
19
  isInvalidVisible?: boolean;
20
20
  /** label text */
21
21
  label?: string;
22
+ /** hint text text */
23
+ hintText?: string;
22
24
  /** callback function which is passed the error */
23
25
  onAddressError?: (error: Error) => void;
24
26
  /** onBlur handler */
@@ -51,11 +53,13 @@ declare const AddressLookup: React.ForwardRefExoticComponent<Pick<React.InputHTM
51
53
  isInvalidVisible?: boolean | undefined;
52
54
  /** label text */
53
55
  label?: string | undefined;
56
+ /** hint text text */
57
+ hintText?: string | undefined;
54
58
  /** callback function which is passed the error */
55
59
  onAddressError?: ((error: Error) => void) | undefined;
56
60
  /** onBlur handler */
57
61
  onBlur?: ((e: FocusEvent<HTMLInputElement>) => void) | undefined;
58
62
  /** attach a DOM reference variable to your component */
59
63
  ref?: React.Ref<HTMLInputElement> | undefined;
60
- }, "apiKey" | "countries" | "errorMessage" | "hasError" | "isValid" | "isValidVisible" | "isInvalidVisible" | "label" | "onAddressError" | "onAddressSelected" | keyof React.InputHTMLAttributes<HTMLInputElement>> & React.RefAttributes<HTMLInputElement>>;
64
+ }, "apiKey" | "countries" | "errorMessage" | "hasError" | "isValid" | "isValidVisible" | "isInvalidVisible" | "label" | "hintText" | "onAddressError" | "onAddressSelected" | keyof React.InputHTMLAttributes<HTMLInputElement>> & React.RefAttributes<HTMLInputElement>>;
61
65
  export default AddressLookup;
@@ -1,2 +1,2 @@
1
- var I="# Address lookup

This component creates a combobox for a user to type in a post code or partial address and be presented with a of verified addresses.

We use Loqate (formerly Addressy and Postcode Anywhere) API v3, we have looked at v4 but it is more expensive without many benefits for our use case.

You will need a Loqate api key, the examples below use "MG17-ZD93-FF33-KF13" our development key.

This component is generally only used for country codes including "GBR", "GGY", "IMN", "JEY". An example of this behavior is included bellow.

### Try it out

```.jsx
function () {
  const [validated, setValidated] = React.useState(false);
  const [line1, setLine1] = React.useState('');
  const [line2, setLine2] = React.useState('');
  const [line3, setLine3] = React.useState('');
  const [city, setCity] = React.useState('');
  const [postalCode, setPostalCode] = React.useState('');
  const [country, setCountry] = React.useState('GBR');

  const handleAddressSelected = (address) => {
    setValidated(true);
    setLine1(address.Line1);
    setLine2(address.Line2);
    setLine3(address.Line3);
    setCity(address.City);
    setPostalCode(address.PostalCode);
  }

  return (
    <>
      <Box>
        <AddressLookup
          apiKey="MG17-ZD93-FF33-KF13"
          onAddressSelected={(address) => alert(JSON.stringify(address, null, 2))}
          onChange={(e) => console.log('value', e.target.value)}
          onBlur={(e) => console.log('blur')}
        />
      </Box>

      <fieldset>
        <legend>Your Address</legend>
        <p>
          Example wired up to a simple form, with controlled inputs. For production use we recommend using using Formic and Yup for form management and validation
        </p>
        <Box>
          <Select
            label="Country"
            required
            value={country}
            onChange={(e) => setCountry(e.target.value)
          }>
            <option value="GBR">United Kingdom</option>
            <option value="ALA">Afghanistan</option>
            <option value="ALB">Albania</option>
            <option value="DZA">Algeria</option>
            {/* ... */}
            <option value="GGY">Guernsey</option>
          </Select>
        </Box>
        <Box>
          {["GBR", "GGY", "IMN", "JEY"].includes(country) ? (
            <AddressLookup
              apiKey="MG17-ZD93-FF33-KF13"
              countries={[country]}
              onAddressSelected={handleAddressSelected}
              onChange={(e) => {
                setValidated(false);
                setLine1(e.target.value)}
              }
              value={line1}
            />
          ) : (
            <TextField
              onChange={e => {
                setValidated(false);
                setLine2(e.target.value);
              }}
              required
              label="Home address"
              value={line1}
            />
          )}
        </Box>
        <Box>
          <TextField
            onChange={e => {
              setValidated(false);
              setLine2(e.target.value);
            }}
            label="Address line 2"
            value={line2}
          />
        </Box>
        <Box>
          <TextField
            onChange={e => {
              setValidated(false);
              setLine3(e.target.value);
            }}
            label="Address line 3"
            value={line3}
          />
        </Box>
        <Box>
          <TextField
            onChange={e => {
              setValidated(false);
              setCity(e.target.value);
            }}
            label="City"
            value={city}
            required
          />
        <Box>
        </Box>
          <TextField
            onChange={e => {
              setValidated(false);
              setPostalCode(e.target.value);
            }}
            label="Postcode"
            value={postalCode}
            required
          />
        </Box>
        <pre>{JSON.stringify({validated}, null, 2)}</pre>
      </fieldset>
    </>
  );
}
```

## Props

| Name              | Type     |                                         Options                                          | Default                   | Description                                                                                                                      |
| :---------------- | :------- | :--------------------------------------------------------------------------------------: | :------------------------ | :------------------------------------------------------------------------------------------------------------------------------- |
| apiKey            | String   |                                                                                          |                           | Loqate API key                                                                                                                   |
| countries         | String[] | A comma separated list of ISO 2 or 3 character country codes to limit the search within. |                           | See https://www.loqate.com/resources/support/apis/Capture/Interactive/Find/1.1/ - CRUK typically uses "GBR", "GGY", "IMN", "JEY" |
| error             | String   |                                                                                          |                           | Error message text                                                                                                               |
| hasError          | Boolean  |                                                                                          | false                     | If true, use error styling for the input                                                                                         |
| isValid           | Boolean  |                                                                                          | true                      | used with isValidVisible to show valid indicator                                                                                 |
| isValidVisible    | Boolean  |                                                                                          | false                     | show valid indicator when isValid is true or no error exists                                                                     |
| label             | String   |                                      "Home address"                                      |                           | Label text for field                                                                                                             |
| onAddressError    | Function |                                                                                          | err => console.error(err) | Handler for if there is an error thrown back by Loqate                                                                           |
| onAddressSelected | Function |                                                                                          |                           | Returns address object                                                                                                           |
| onChange          | Function |                                                                                          |                           | Callback function called on input change                                                                                         |

## Accessibility

- Responds to keyboard events
- Informs screen reader users of the presence of results returned from search
";export{I as default};
1
+ var g="# Address lookup

This component creates a combobox for a user to type in a post code or partial address and be presented with a of verified addresses.

We use Loqate (formerly Addressy and Postcode Anywhere) API v3, we have looked at v4 but it is more expensive without many benefits for our use case.

You will need a Loqate api key, the examples below use "MG17-ZD93-FF33-KF13" our development key.

This component is generally only used for country codes including "GBR", "GGY", "IMN", "JEY". An example of this behavior is included bellow.

### Try it out

```.jsx
function () {
  const [validated, setValidated] = React.useState(false);
  const [line1, setLine1] = React.useState('');
  const [line2, setLine2] = React.useState('');
  const [line3, setLine3] = React.useState('');
  const [city, setCity] = React.useState('');
  const [postalCode, setPostalCode] = React.useState('');
  const [country, setCountry] = React.useState('GBR');

  const handleAddressSelected = (address) => {
    setValidated(true);
    setLine1(address.Line1);
    setLine2(address.Line2);
    setLine3(address.Line3);
    setCity(address.City);
    setPostalCode(address.PostalCode);
  }

  return (
    <>
      <Box>
        <AddressLookup
          apiKey="MG17-ZD93-FF33-KF13"
          onAddressSelected={(address) => alert(JSON.stringify(address, null, 2))}
          onChange={(e) => console.log('value', e.target.value)}
          onBlur={(e) => console.log('blur')}
        />
      </Box>

      <fieldset>
        <legend>Your Address</legend>
        <p>
          Example wired up to a simple form, with controlled inputs. For production use we recommend using using Formic and Yup for form management and validation
        </p>
        <Box>
          <Select
            label="Country"
            required
            value={country}
            onChange={(e) => setCountry(e.target.value)
          }>
            <option value="GBR">United Kingdom</option>
            <option value="ALA">Afghanistan</option>
            <option value="ALB">Albania</option>
            <option value="DZA">Algeria</option>
            {/* ... */}
            <option value="GGY">Guernsey</option>
          </Select>
        </Box>
        <Box>
          {["GBR", "GGY", "IMN", "JEY"].includes(country) ? (
            <AddressLookup
              apiKey="MG17-ZD93-FF33-KF13"
              countries={[country]}
              onAddressSelected={handleAddressSelected}
              onChange={(e) => {
                setValidated(false);
                setLine1(e.target.value)}
              }
              value={line1}
            />
          ) : (
            <TextField
              onChange={e => {
                setValidated(false);
                setLine2(e.target.value);
              }}
              required
              label="Home address"
              value={line1}
            />
          )}
        </Box>
        <Box>
          <TextField
            onChange={e => {
              setValidated(false);
              setLine2(e.target.value);
            }}
            label="Address line 2"
            value={line2}
          />
        </Box>
        <Box>
          <TextField
            onChange={e => {
              setValidated(false);
              setLine3(e.target.value);
            }}
            label="Address line 3"
            value={line3}
          />
        </Box>
        <Box>
          <TextField
            onChange={e => {
              setValidated(false);
              setCity(e.target.value);
            }}
            label="City"
            value={city}
            required
          />
        <Box>
        </Box>
          <TextField
            onChange={e => {
              setValidated(false);
              setPostalCode(e.target.value);
            }}
            label="Postcode"
            value={postalCode}
            required
          />
        </Box>
        <pre>{JSON.stringify({validated}, null, 2)}</pre>
      </fieldset>
    </>
  );
}
```

## Props

| Name              | Type     |                                         Options                                          | Default                                 | Description                                                                                                                      |
| :---------------- | :------- | :--------------------------------------------------------------------------------------: | :-------------------------------------- | :------------------------------------------------------------------------------------------------------------------------------- |
| apiKey            | String   |                                                                                          |                                         | Loqate API key                                                                                                                   |
| countries         | String[] | A comma separated list of ISO 2 or 3 character country codes to limit the search within. |                                         | See https://www.loqate.com/resources/support/apis/Capture/Interactive/Find/1.1/ - CRUK typically uses "GBR", "GGY", "IMN", "JEY" |
| error             | String   |                                                                                          |                                         | Error message text                                                                                                               |
| hasError          | Boolean  |                                                                                          | false                                   | If true, use error styling for the input                                                                                         |
| isValid           | Boolean  |                                                                                          | true                                    | used with isValidVisible to show valid indicator                                                                                 |
| isValidVisible    | Boolean  |                                                                                          | false                                   | show valid indicator when isValid is true or no error exists                                                                     |
| label             | String   |                                                                                          | "Home address"                          | Label text for field                                                                                                             |
| hintText          | String   |                                                                                          | "Start typing your address or postcode" | Hint text for field                                                                                                              |
| onAddressError    | Function |                                                                                          | err => console.error(err)               | Handler for if there is an error thrown back by Loqate                                                                           |
| onAddressSelected | Function |                                                                                          |                                         | Returns address object                                                                                                           |
| onChange          | Function |                                                                                          |                                         | Callback function called on input change                                                                                         |

## Accessibility

- Responds to keyboard events
- Informs screen reader users of the presence of results returned from search
";export{g as default};
2
2
  //# sourceMappingURL=README.md.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"README.md.js","sources":["../../../../../src/components/AddressLookup/README.md"],"sourcesContent":["export default \"# Address lookup

This component creates a combobox for a user to type in a post code or partial address and be presented with a of verified addresses.

We use Loqate (formerly Addressy and Postcode Anywhere) API v3, we have looked at v4 but it is more expensive without many benefits for our use case.

You will need a Loqate api key, the examples below use "MG17-ZD93-FF33-KF13" our development key.

This component is generally only used for country codes including "GBR", "GGY", "IMN", "JEY". An example of this behavior is included bellow.

### Try it out

```.jsx
function () {
  const [validated, setValidated] = React.useState(false);
  const [line1, setLine1] = React.useState('');
  const [line2, setLine2] = React.useState('');
  const [line3, setLine3] = React.useState('');
  const [city, setCity] = React.useState('');
  const [postalCode, setPostalCode] = React.useState('');
  const [country, setCountry] = React.useState('GBR');

  const handleAddressSelected = (address) => {
    setValidated(true);
    setLine1(address.Line1);
    setLine2(address.Line2);
    setLine3(address.Line3);
    setCity(address.City);
    setPostalCode(address.PostalCode);
  }

  return (
    <>
      <Box>
        <AddressLookup
          apiKey="MG17-ZD93-FF33-KF13"
          onAddressSelected={(address) => alert(JSON.stringify(address, null, 2))}
          onChange={(e) => console.log('value', e.target.value)}
          onBlur={(e) => console.log('blur')}
        />
      </Box>

      <fieldset>
        <legend>Your Address</legend>
        <p>
          Example wired up to a simple form, with controlled inputs. For production use we recommend using using Formic and Yup for form management and validation
        </p>
        <Box>
          <Select
            label="Country"
            required
            value={country}
            onChange={(e) => setCountry(e.target.value)
          }>
            <option value="GBR">United Kingdom</option>
            <option value="ALA">Afghanistan</option>
            <option value="ALB">Albania</option>
            <option value="DZA">Algeria</option>
            {/* ... */}
            <option value="GGY">Guernsey</option>
          </Select>
        </Box>
        <Box>
          {["GBR", "GGY", "IMN", "JEY"].includes(country) ? (
            <AddressLookup
              apiKey="MG17-ZD93-FF33-KF13"
              countries={[country]}
              onAddressSelected={handleAddressSelected}
              onChange={(e) => {
                setValidated(false);
                setLine1(e.target.value)}
              }
              value={line1}
            />
          ) : (
            <TextField
              onChange={e => {
                setValidated(false);
                setLine2(e.target.value);
              }}
              required
              label="Home address"
              value={line1}
            />
          )}
        </Box>
        <Box>
          <TextField
            onChange={e => {
              setValidated(false);
              setLine2(e.target.value);
            }}
            label="Address line 2"
            value={line2}
          />
        </Box>
        <Box>
          <TextField
            onChange={e => {
              setValidated(false);
              setLine3(e.target.value);
            }}
            label="Address line 3"
            value={line3}
          />
        </Box>
        <Box>
          <TextField
            onChange={e => {
              setValidated(false);
              setCity(e.target.value);
            }}
            label="City"
            value={city}
            required
          />
        <Box>
        </Box>
          <TextField
            onChange={e => {
              setValidated(false);
              setPostalCode(e.target.value);
            }}
            label="Postcode"
            value={postalCode}
            required
          />
        </Box>
        <pre>{JSON.stringify({validated}, null, 2)}</pre>
      </fieldset>
    </>
  );
}
```

## Props

| Name              | Type     |                                         Options                                          | Default                   | Description                                                                                                                      |
| :---------------- | :------- | :--------------------------------------------------------------------------------------: | :------------------------ | :------------------------------------------------------------------------------------------------------------------------------- |
| apiKey            | String   |                                                                                          |                           | Loqate API key                                                                                                                   |
| countries         | String[] | A comma separated list of ISO 2 or 3 character country codes to limit the search within. |                           | See https://www.loqate.com/resources/support/apis/Capture/Interactive/Find/1.1/ - CRUK typically uses "GBR", "GGY", "IMN", "JEY" |
| error             | String   |                                                                                          |                           | Error message text                                                                                                               |
| hasError          | Boolean  |                                                                                          | false                     | If true, use error styling for the input                                                                                         |
| isValid           | Boolean  |                                                                                          | true                      | used with isValidVisible to show valid indicator                                                                                 |
| isValidVisible    | Boolean  |                                                                                          | false                     | show valid indicator when isValid is true or no error exists                                                                     |
| label             | String   |                                      "Home address"                                      |                           | Label text for field                                                                                                             |
| onAddressError    | Function |                                                                                          | err => console.error(err) | Handler for if there is an error thrown back by Loqate                                                                           |
| onAddressSelected | Function |                                                                                          |                           | Returns address object                                                                                                           |
| onChange          | Function |                                                                                          |                           | Callback function called on input change                                                                                         |

## Accessibility

- Responds to keyboard events
- Informs screen reader users of the presence of results returned from search
\""],"names":["README"],"mappings":"AAAA,IAAeA,EAAA"}
1
+ {"version":3,"file":"README.md.js","sources":["../../../../../src/components/AddressLookup/README.md"],"sourcesContent":["export default \"# Address lookup

This component creates a combobox for a user to type in a post code or partial address and be presented with a of verified addresses.

We use Loqate (formerly Addressy and Postcode Anywhere) API v3, we have looked at v4 but it is more expensive without many benefits for our use case.

You will need a Loqate api key, the examples below use "MG17-ZD93-FF33-KF13" our development key.

This component is generally only used for country codes including "GBR", "GGY", "IMN", "JEY". An example of this behavior is included bellow.

### Try it out

```.jsx
function () {
  const [validated, setValidated] = React.useState(false);
  const [line1, setLine1] = React.useState('');
  const [line2, setLine2] = React.useState('');
  const [line3, setLine3] = React.useState('');
  const [city, setCity] = React.useState('');
  const [postalCode, setPostalCode] = React.useState('');
  const [country, setCountry] = React.useState('GBR');

  const handleAddressSelected = (address) => {
    setValidated(true);
    setLine1(address.Line1);
    setLine2(address.Line2);
    setLine3(address.Line3);
    setCity(address.City);
    setPostalCode(address.PostalCode);
  }

  return (
    <>
      <Box>
        <AddressLookup
          apiKey="MG17-ZD93-FF33-KF13"
          onAddressSelected={(address) => alert(JSON.stringify(address, null, 2))}
          onChange={(e) => console.log('value', e.target.value)}
          onBlur={(e) => console.log('blur')}
        />
      </Box>

      <fieldset>
        <legend>Your Address</legend>
        <p>
          Example wired up to a simple form, with controlled inputs. For production use we recommend using using Formic and Yup for form management and validation
        </p>
        <Box>
          <Select
            label="Country"
            required
            value={country}
            onChange={(e) => setCountry(e.target.value)
          }>
            <option value="GBR">United Kingdom</option>
            <option value="ALA">Afghanistan</option>
            <option value="ALB">Albania</option>
            <option value="DZA">Algeria</option>
            {/* ... */}
            <option value="GGY">Guernsey</option>
          </Select>
        </Box>
        <Box>
          {["GBR", "GGY", "IMN", "JEY"].includes(country) ? (
            <AddressLookup
              apiKey="MG17-ZD93-FF33-KF13"
              countries={[country]}
              onAddressSelected={handleAddressSelected}
              onChange={(e) => {
                setValidated(false);
                setLine1(e.target.value)}
              }
              value={line1}
            />
          ) : (
            <TextField
              onChange={e => {
                setValidated(false);
                setLine2(e.target.value);
              }}
              required
              label="Home address"
              value={line1}
            />
          )}
        </Box>
        <Box>
          <TextField
            onChange={e => {
              setValidated(false);
              setLine2(e.target.value);
            }}
            label="Address line 2"
            value={line2}
          />
        </Box>
        <Box>
          <TextField
            onChange={e => {
              setValidated(false);
              setLine3(e.target.value);
            }}
            label="Address line 3"
            value={line3}
          />
        </Box>
        <Box>
          <TextField
            onChange={e => {
              setValidated(false);
              setCity(e.target.value);
            }}
            label="City"
            value={city}
            required
          />
        <Box>
        </Box>
          <TextField
            onChange={e => {
              setValidated(false);
              setPostalCode(e.target.value);
            }}
            label="Postcode"
            value={postalCode}
            required
          />
        </Box>
        <pre>{JSON.stringify({validated}, null, 2)}</pre>
      </fieldset>
    </>
  );
}
```

## Props

| Name              | Type     |                                         Options                                          | Default                                 | Description                                                                                                                      |
| :---------------- | :------- | :--------------------------------------------------------------------------------------: | :-------------------------------------- | :------------------------------------------------------------------------------------------------------------------------------- |
| apiKey            | String   |                                                                                          |                                         | Loqate API key                                                                                                                   |
| countries         | String[] | A comma separated list of ISO 2 or 3 character country codes to limit the search within. |                                         | See https://www.loqate.com/resources/support/apis/Capture/Interactive/Find/1.1/ - CRUK typically uses "GBR", "GGY", "IMN", "JEY" |
| error             | String   |                                                                                          |                                         | Error message text                                                                                                               |
| hasError          | Boolean  |                                                                                          | false                                   | If true, use error styling for the input                                                                                         |
| isValid           | Boolean  |                                                                                          | true                                    | used with isValidVisible to show valid indicator                                                                                 |
| isValidVisible    | Boolean  |                                                                                          | false                                   | show valid indicator when isValid is true or no error exists                                                                     |
| label             | String   |                                                                                          | "Home address"                          | Label text for field                                                                                                             |
| hintText          | String   |                                                                                          | "Start typing your address or postcode" | Hint text for field                                                                                                              |
| onAddressError    | Function |                                                                                          | err => console.error(err)               | Handler for if there is an error thrown back by Loqate                                                                           |
| onAddressSelected | Function |                                                                                          |                                         | Returns address object                                                                                                           |
| onChange          | Function |                                                                                          |                                         | Callback function called on input change                                                                                         |

## Accessibility

- Responds to keyboard events
- Informs screen reader users of the presence of results returned from search
\""],"names":["README"],"mappings":"AAAA,IAAeA,EAAA"}
@@ -1,2 +1,2 @@
1
- import{__rest as e,__assign as t}from"../../../_virtual/_tslib.js";import n,{forwardRef as r,useState as o,useRef as s,useCallback as a,useEffect as i}from"react";import{useTheme as c}from"styled-components";import{faChevronRight as l}from"../../../node_modules/@fortawesome/free-solid-svg-icons/index.mjs.js";import{useKey as d}from"../../hooks/useKey.js";import u from"../../utils/debounce.js";import{Text as m}from"../Text/index.js";import f from"../TextField/index.js";import p from"../IconFa/index.js";import h from"../../themes/cruk.js";import{ScreenReaderOnly as g,ListWrapper as v,List as y,ListItem as E}from"./styles.js";var w=r((function(r,w){var b=r.apiKey,j=r.countries,I=r.errorMessage,x=r.hasError,T=r.isValid,V=r.isValidVisible,k=r.isInvalidVisible,A=r.label,C=r.onAddressError,K=void 0===C?function(e){}:C,D=r.onAddressSelected,F=r.onChange,S=r.onBlur,_=e(r,["apiKey","countries","errorMessage","hasError","isValid","isValidVisible","isInvalidVisible","label","onAddressError","onAddressSelected","onChange","onBlur"]),M=o([]),B=M[0],L=M[1],H=o(-1),O=H[0],U=H[1],q=s(null),R=c(),W=t(t({},h),R),z=function(){U(-1),L([])},G=a(u(500,(function(e){return J(e)})),[]),J=function(e,t){if(void 0===t&&(t=""),0===e.length)return L([]);var n="".concat("https://api.addressy.com/Capture/Interactive/Find/v1.1/json3.ws","?Key=").concat(b,"&Text=").concat(e,"&Container=").concat(t);return void 0!==j&&(n="".concat(n,"&Countries=").concat(j.join(","))),fetch(n).then((function(e){if(!e.ok)throw new Error("Something went wrong please try again");return e.json()})).then((function(e){if(e.Items[0].Error)throw new Error("Something went wrong please try again");return L(e.Items||[]),null})).catch((function(e){return K(e)})),null},N=function(e){fetch("".concat("https://api.addressy.com/Capture/Interactive/Retrieve/v1/json3.ws","?Key=").concat(b,"&Id=").concat(e)).then((function(e){if(!e.ok)throw new Error("Something went wrong please try again");return e.json()})).then((function(e){return z(),D(e.Items[0]),null})).catch((function(e){return K(e)}))},P=function(e){return"Address"===e.Type?N(e.Id):(J(e.Text,e.Id),null)},Q=function(e){q.current&&e.target instanceof HTMLElement&&!q.current.contains(e.target)&&z()};return i((function(){return document.addEventListener("mousedown",Q),function(){document.removeEventListener("mousedown",Q)}})),d((function(){z()}),{detectKeys:["Escape","Tab"]},[]),n.createElement(n.Fragment,null,n.createElement(f,t({"aria-activedescendant":B.length?"addressOptions-".concat(O):"","aria-owns":"found_addresses","aria-autocomplete":"both","aria-expanded":B.length?"true":"false",autoComplete:"off",hasError:x||!!I,errorMessage:I,hintText:"Start typing your address or postcode",isValid:T,isValidVisible:V,isInvalidVisible:k,label:null!=A?A:"Home address",ref:w,required:!0,role:"combobox",type:"search"},_,{onKeyDown:function(e){"Enter"===e.key&&B[O]?(e.preventDefault(),"Address"===B[O].Type&&N(B[O].Id),J(B[O].Text,B[O].Id),U(-1)):"ArrowUp"===e.key?(e.preventDefault(),O<=-1&&U(B.length-1),U(O-1)):"ArrowDown"===e.key?(e.preventDefault(),O+1>=B.length&&U(0),U(O+1)):U(-1)},onChange:function(e){G(e.target.value),F&&F(e)},onBlur:function(e){var t=!!B.length;S&&!t&&S(e)}})),!!B.length&&n.createElement(n.Fragment,null,n.createElement(g,{role:"status","aria-live":"assertive"},!!B.length&&"We have found ".concat(B.length," result").concat(1!==B.length?"s":""," matching your search. Use up and down arrow keys to navigate")),n.createElement(v,{ref:q},n.createElement(y,{"aria-label":"found addresses",id:"found_addresses",role:"listbox",theme:W},B.map((function(e,t){return n.createElement(E,{tabIndex:0,id:"addressOptions-".concat(t),isActive:t===O,key:e.Id,onClick:function(){P(e)},onKeyDown:function(t){"Enter"===t.key&&P(e)},role:"option","data-hj-suppress":!0,theme:W},n.createElement(m,{as:"span","data-hj-suppress":!0},e.Text," ",e.Description),"Address"!==e.Type&&n.createElement(n.Fragment,null,n.createElement(g,null,"press enter for these addresses"),n.createElement(p,{faIcon:l})))}))))))}));export{w as default};
1
+ import{__rest as e,__assign as t}from"../../../_virtual/_tslib.js";import n,{forwardRef as r,useState as o,useRef as s,useCallback as a,useEffect as i}from"react";import{useTheme as l}from"styled-components";import{faChevronRight as c}from"../../../node_modules/@fortawesome/free-solid-svg-icons/index.mjs.js";import{useKey as d}from"../../hooks/useKey.js";import u from"../../utils/debounce.js";import{removeCommasFromObjectStringValues as m}from"../../utils/Helper.js";import{Text as f}from"../Text/index.js";import p from"../TextField/index.js";import h from"../IconFa/index.js";import g from"../../themes/cruk.js";import{ScreenReaderOnly as v,ListWrapper as y,List as E,ListItem as w}from"./styles.js";var b=r((function(r,b){var j=r.apiKey,x=r.countries,I=r.errorMessage,T=r.hasError,V=r.isValid,k=r.isValidVisible,A=r.isInvalidVisible,C=r.label,K=r.hintText,D=r.onAddressError,F=void 0===D?function(e){}:D,S=r.onAddressSelected,_=r.onChange,M=r.onBlur,B=e(r,["apiKey","countries","errorMessage","hasError","isValid","isValidVisible","isInvalidVisible","label","hintText","onAddressError","onAddressSelected","onChange","onBlur"]),H=o([]),L=H[0],O=H[1],U=o(-1),q=U[0],R=U[1],W=s(null),z=l(),G=t(t({},g),z),J=function(){R(-1),O([])},N=a(u(500,(function(e){return P(e)})),[]),P=function(e,t){if(void 0===t&&(t=""),0===e.length)return O([]);var n="".concat("https://api.addressy.com/Capture/Interactive/Find/v1.1/json3.ws","?Key=").concat(j,"&Text=").concat(e,"&Container=").concat(t);return void 0!==x&&(n="".concat(n,"&Countries=").concat(x.join(","))),fetch(n).then((function(e){if(!e.ok)throw new Error("Something went wrong please try again");return e.json()})).then((function(e){if(e.Items[0].Error)throw new Error("Something went wrong please try again");return O(e.Items||[]),null})).catch((function(e){return F(e)})),null},Q=function(e){fetch("".concat("https://api.addressy.com/Capture/Interactive/Retrieve/v1/json3.ws","?Key=").concat(j,"&Id=").concat(e)).then((function(e){if(!e.ok)throw new Error("Something went wrong please try again");return e.json()})).then((function(e){var t=e.Items[0],n=m(t);return S(n),J(),null})).catch((function(e){return F(e)}))},X=function(e){return"Address"===e.Type?Q(e.Id):(P(e.Text,e.Id),null)},Y=function(e){W.current&&e.target instanceof HTMLElement&&!W.current.contains(e.target)&&J()};return i((function(){return document.addEventListener("mousedown",Y),function(){document.removeEventListener("mousedown",Y)}})),d((function(){J()}),{detectKeys:["Escape","Tab"]},[]),n.createElement(n.Fragment,null,n.createElement(p,t({"aria-activedescendant":L.length?"addressOptions-".concat(q):"","aria-owns":"found_addresses","aria-autocomplete":"both","aria-expanded":L.length?"true":"false",autoComplete:"off",hasError:T||!!I,errorMessage:I,hintText:null!=K?K:"Start typing your address or postcode",isValid:V,isValidVisible:k,isInvalidVisible:A,label:null!=C?C:"Home address",ref:b,required:!0,role:"combobox",type:"search"},B,{onKeyDown:function(e){"Enter"===e.key&&L[q]?(e.preventDefault(),"Address"===L[q].Type&&Q(L[q].Id),P(L[q].Text,L[q].Id),R(-1)):"ArrowUp"===e.key?(e.preventDefault(),q<=-1&&R(L.length-1),R(q-1)):"ArrowDown"===e.key?(e.preventDefault(),q+1>=L.length&&R(0),R(q+1)):R(-1)},onChange:function(e){N(e.target.value),_&&_(e)},onBlur:function(e){var t=!!L.length;M&&!t&&M(e)}})),!!L.length&&n.createElement(n.Fragment,null,n.createElement(v,{role:"status","aria-live":"assertive"},!!L.length&&"We have found ".concat(L.length," result").concat(1!==L.length?"s":""," matching your search. Use up and down arrow keys to navigate")),n.createElement(y,{ref:W},n.createElement(E,{"aria-label":"found addresses",id:"found_addresses",role:"listbox",theme:G},L.map((function(e,t){return n.createElement(w,{tabIndex:0,id:"addressOptions-".concat(t),isActive:t===q,key:e.Id,onClick:function(){X(e)},onKeyDown:function(t){"Enter"===t.key&&X(e)},role:"option","data-hj-suppress":!0,theme:G},n.createElement(f,{as:"span","data-hj-suppress":!0},e.Text," ",e.Description),"Address"!==e.Type&&n.createElement(n.Fragment,null,n.createElement(v,null,"press enter for these addresses"),n.createElement(h,{faIcon:c})))}))))))}));export{b as default};
2
2
  //# sourceMappingURL=index.js.map
@@ -1,2 +1,2 @@
1
- import{__assign as e}from"../../../_virtual/_tslib.js";import t,{useState as l}from"react";import{useTheme as n,ThemeProvider as o}from"styled-components";import i from"../../hooks/useScrollPosition.js";import r from"../../themes/cruk.js";import{StyledHeader as m,HeaderStickyPlaceHolder as a,HeaderStickyContainer as c,SkipToMain as s,HeaderMainContent as u,StyledLink as f,LogoWrapper as g,Logo as E,Tagline as S,ChildWrapper as k,ChildInner as p}from"./styles.js";var d=function(d){var y=d.isSticky,h=d.siteSlogan,j=d.logoAltText,v=d.logoImageSrc,C=d.logoLinkTitle,w=d.logoLinkUrl,x=d.fullWidth,A=d.children,L=l(!1),P=L[0],T=L[1],U="undefined"!=typeof window,W=n(),_=e(e({},r),W);return i((function(e){var t=e.currPos,l=!!U&&t.y>240;l!==P&&T(l)}),[P],null,!0,50),t.createElement(o,{theme:_},t.createElement(m,null,t.createElement(a,null,t.createElement(c,{"data-cy":"header-sticky-container",isSmall:P,isSticky:y},t.createElement(s,{className:"skip-main",href:"#main"},"Skip to main content"),t.createElement(u,{fullWidth:x},t.createElement(f,{href:null!=w?w:_.siteConfig.logoUrl,title:null!=C?C:"Home"},t.createElement(g,{isSmall:P,isSticky:y},t.createElement(E,{src:null!=v?v:_.siteConfig.logoSrc,alt:null!=j?j:_.siteConfig.logoAlt}))),h?t.createElement(S,{isSmall:P,isSticky:y},h):null,t.createElement(k,null,t.createElement(p,null,A)))))))};export{d as Header,d as default};
1
+ import{__assign as e}from"../../../_virtual/_tslib.js";import t,{useState as l}from"react";import{useTheme as o,ThemeProvider as n}from"styled-components";import r from"../../hooks/useScrollPosition.js";import i from"../../themes/cruk.js";import{StyledHeader as m,HeaderStickyPlaceHolder as a,HeaderStickyContainer as c,SkipToMain as s,HeaderMainContent as u,StyledLink as f,LogoWrapper as g,Logo as E,Tagline as S,ChildWrapper as d,ChildInner as k}from"./styles.js";var p=function(p){var y=p.isSticky,h=p.siteSlogan,j=p.logoAltText,v=p.logoImageSrc,C=p.logoLinkTitle,w=p.logoLinkUrl,x=p.fullWidth,A=p.children,L=l(!1),P=L[0],T=L[1],U="undefined"!=typeof window,W=o(),_=e(e({},i),W);return r((function(e){var t=e.currPos,l=!!U&&t.y>240;l!==P&&T(l)}),[P],null,!0,50),t.createElement(n,{theme:_},t.createElement(m,null,t.createElement(a,null,t.createElement(c,{"data-cy":"header-sticky-container",isSmall:P,isSticky:y},t.createElement(s,{href:"#main"},"Skip to main content"),t.createElement(u,{fullWidth:x},t.createElement(f,{href:null!=w?w:_.siteConfig.logoUrl,title:null!=C?C:"Home"},t.createElement(g,{isSmall:P,isSticky:y},t.createElement(E,{src:null!=v?v:_.siteConfig.logoSrc,alt:null!=j?j:_.siteConfig.logoAlt}))),h?t.createElement(S,{isSmall:P,isSticky:y},h):null,t.createElement(d,null,t.createElement(k,null,A)))))))};export{p as Header,p as default};
2
2
  //# sourceMappingURL=index.js.map
@@ -1,2 +1,2 @@
1
- import{__rest as e,__assign as r}from"../../../_virtual/_tslib.js";import t from"react";import{useTheme as l,ThemeProvider as n}from"styled-components";import{Text as i}from"../Text/index.js";import m from"../../themes/cruk.js";import{Label as a,LabelText as o}from"./styles.js";var u=function(u){var d=u.label,s=u.hintText,c=u.required,p=u.hideRequiredInLabel,f=void 0!==p&&p,h=u.children,b=e(u,["label","hintText","required","hideRequiredInLabel","children"]),q=l(),x=r(r({},m),q),E=!s||"string"!=typeof s&&"number"!=typeof s?s:t.createElement(i,null,s);return t.createElement(n,{theme:x},d?t.createElement(a,r({},b),t.createElement(o,{hasHintText:!!s},d," ",c&&!f&&t.createElement("span",null,"(required)")),E,h):t.createElement(t.Fragment,null,h))};u.defaultProps={required:!1};export{u as LabelWrapper,u as default};
1
+ import{__rest as e,__assign as t}from"../../../_virtual/_tslib.js";import r from"react";import{useTheme as l,ThemeProvider as n}from"styled-components";import{Text as i}from"../Text/index.js";import m from"../../themes/cruk.js";import{Label as a,LabelText as o}from"./styles.js";var u=function(u){var d=u.label,s=u.hintText,c=u.required,p=u.hideRequiredInLabel,f=void 0!==p&&p,h=u.children,b=e(u,["label","hintText","required","hideRequiredInLabel","children"]),q=l(),x=t(t({},m),q),E=s&&("string"==typeof s&&s.length||"number"==typeof s)?r.createElement(i,null,s):s;return r.createElement(n,{theme:x},d?r.createElement(a,t({},b),r.createElement(o,{hasHintText:!!s},d," ",c&&!f&&r.createElement("span",null,"(required)")),E,h):r.createElement(r.Fragment,null,h))};u.defaultProps={required:!1};export{u as LabelWrapper,u as default};
2
2
  //# sourceMappingURL=index.js.map
@@ -1,2 +1,2 @@
1
- var r="undefined"!=typeof window,t=function(r,t){var a=r/t*100;return a===Number.POSITIVE_INFINITY||Number.isNaN(a)?0:Math.floor(a<1?Math.ceil(a):Math.floor(a))},a=function(r){if(!r)return"";var t=r.toString().split(".");return"".concat(t[0].replace(/\B(?=(\d{3})+(?!\d))/g,",")).concat(t[1]?".".concat(t[1]):"")},e=function(r){var t=Number.parseFloat((Math.round(100*r)/100).toString()).toFixed(2);return Number.isNaN(parseFloat(t))||Number.isNaN(r)?"0":a(t)};export{t as calculatePercentRounded,e as formatMoneyWithCommas,r as isBrowser,a as numberWithCommas};
1
+ import{__assign as r}from"../../_virtual/_tslib.js";var t="undefined"!=typeof window,e=function(r,t){var e=r/t*100;return e===Number.POSITIVE_INFINITY||Number.isNaN(e)?0:Math.floor(e<1?Math.ceil(e):Math.floor(e))},n=function(r){if(!r)return"";var t=r.toString().split(".");return"".concat(t[0].replace(/\B(?=(\d{3})+(?!\d))/g,",")).concat(t[1]?".".concat(t[1]):"")},o=function(r){var t=Number.parseFloat((Math.round(100*r)/100).toString()).toFixed(2);return Number.isNaN(parseFloat(t))||Number.isNaN(r)?"0":n(t)},a=function(t){return Object.entries(t).reduce((function(t,e){var n,o=e[0],a=e[1],i="string"==typeof a?a.replace(/,/g,""):a;return r(r({},t),((n={})[o]=i,n))}),{})};export{e as calculatePercentRounded,o as formatMoneyWithCommas,t as isBrowser,n as numberWithCommas,a as removeCommasFromObjectStringValues};
2
2
  //# sourceMappingURL=Helper.js.map
@@ -4,3 +4,4 @@ export declare const formatMoney: (value: number) => string;
4
4
  export declare const numberWithCommas: (n?: number | string) => string;
5
5
  export declare const formatMoneyWithCommas: (value: number) => string;
6
6
  export declare const camelize: (str: string) => string;
7
+ export declare const removeCommasFromObjectStringValues: <T>(object: T) => T;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@cruk/cruk-react-components",
3
- "version": "3.0.0",
3
+ "version": "3.1.1",
4
4
  "description": "React components implementing CRUK, SU2C & Bowelbabe designs",
5
5
  "license": "UNLICENSED",
6
6
  "publishConfig": {
@@ -119,7 +119,7 @@
119
119
  "prop-types": "^15.8.1",
120
120
  "react": "^16.12.0",
121
121
  "react-dom": "^16.12.0",
122
- "react-live": "^3.1.1",
122
+ "react-live": "^4.1.2",
123
123
  "rollup": "^2.7.2",
124
124
  "rollup-plugin-terser": "^7.0.0",
125
125
  "rollup-plugin-typescript2": "^0.34.0",