@linzjs/lui 24.1.2 → 24.3.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/lui.esm.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import * as React from 'react';
2
- import React__default, { forwardRef as forwardRef$1, useState, useRef, useCallback, useEffect, useContext, Fragment, useLayoutEffect, createContext, useMemo, Component, cloneElement, useId as useId$1, useInsertionEffect as useInsertionEffect$1, Children, isValidElement, createElement, useImperativeHandle, useReducer } from 'react';
2
+ import React__default, { forwardRef as forwardRef$1, useState, useRef, useCallback, useEffect, useContext, createContext, Fragment, useLayoutEffect, useMemo, Component, cloneElement, useId as useId$1, useInsertionEffect as useInsertionEffect$1, Children, isValidElement, createElement, useImperativeHandle, useReducer } from 'react';
3
3
  import { Menu as Menu$2, ControlledMenu, applyStatics, MenuItem, SubMenu, MenuDivider, MenuHeader, useMenuState, FocusableItem } from '@szhsin/react-menu';
4
4
  import lottie from 'lottie-web/build/player/lottie_light';
5
5
  import crypto$1 from 'crypto';
@@ -6989,6 +6989,113 @@ var DateInput = forwardRef$1(function (props, ref) {
6989
6989
  } })));
6990
6990
  });
6991
6991
 
6992
+ // eslint-disable-next-line no-control-regex
6993
+ var LinzInvalidCharMatcher = /([^\u0000-\u017f])/gu;
6994
+ var LinzFreeTextValidator = function (value, invalidCharMatcher, maxReportedChars) {
6995
+ if (invalidCharMatcher === void 0) { invalidCharMatcher = LinzInvalidCharMatcher; }
6996
+ if (maxReportedChars === void 0) { maxReportedChars = 10; }
6997
+ if (!value) {
6998
+ return undefined;
6999
+ }
7000
+ var matchedItems = value.match(invalidCharMatcher);
7001
+ if (matchedItems === null) {
7002
+ return undefined;
7003
+ }
7004
+ var invalidCharacters = Array.from(new Set(matchedItems)).slice(0, maxReportedChars);
7005
+ return "Invalid character".concat(invalidCharacters.length === 1 ? '' : 's', " ").concat(invalidCharacters.join(', '));
7006
+ };
7007
+
7008
+ function CreateLinzFreeTextFilter(removeInvalidChars) {
7009
+ if (removeInvalidChars === void 0) { removeInvalidChars = true; }
7010
+ return function (value) {
7011
+ if (!value) {
7012
+ return '';
7013
+ }
7014
+ var strLength = value.length;
7015
+ if (!strLength) {
7016
+ return '';
7017
+ }
7018
+ return Array.prototype.flatMap
7019
+ .call(value, function (char) {
7020
+ // Supported character range
7021
+ if (char.match(LinzInvalidCharMatcher) === null) {
7022
+ return char;
7023
+ }
7024
+ var charCode = char.charCodeAt(0);
7025
+ // Silent conversion characters
7026
+ // why: https://toitutewhenua.atlassian.net/wiki/spaces/STEP/pages/124322198/Minimum+Text+Validation#Silent-conversion-characters
7027
+ switch (charCode) {
7028
+ case 0x2018:
7029
+ case 0x2019:
7030
+ return "'";
7031
+ case 0x201c:
7032
+ case 0x201d:
7033
+ return '"';
7034
+ case 0x2022:
7035
+ return '*';
7036
+ case 0x2013:
7037
+ case 0x2014:
7038
+ return '-';
7039
+ }
7040
+ return removeInvalidChars ? '' : char;
7041
+ })
7042
+ .join('');
7043
+ };
7044
+ }
7045
+ /**
7046
+ * Default LINZ free text filter function.
7047
+ * Silently converts some invalid characters with supported alternatives.
7048
+ * Removes all other invalid characters.
7049
+ */
7050
+ var LinzFreeTextFilter = CreateLinzFreeTextFilter(true);
7051
+ /**
7052
+ * LINZ free text filter function that leaves invalid characters intact.
7053
+ * Silently converts some invalid characters with supported alternatives.
7054
+ * Leaves all other invalid characters as is.
7055
+ * Should be paired with LinzFreeTextValidator to warn users about invalid characters.
7056
+ */
7057
+ var LinzFreeTextFilterConvertOnly = CreateLinzFreeTextFilter(false);
7058
+
7059
+ var LuiFilterCharactersContext = createContext({
7060
+ filterCharacters: function (input) {
7061
+ // Default implementation: return input as is.
7062
+ return input;
7063
+ },
7064
+ filterInputEvent: function () {
7065
+ // Default implementation: do nothing.
7066
+ return;
7067
+ }
7068
+ });
7069
+ function useFilterCharacters() {
7070
+ return useContext(LuiFilterCharactersContext);
7071
+ }
7072
+ var LuiFilterCharactersProvider = function (_a) {
7073
+ var children = _a.children, filterFunction = _a.filterFunction;
7074
+ var filterCharacters = useCallback(function (input) {
7075
+ if (input === undefined) {
7076
+ return input;
7077
+ }
7078
+ var filter = typeof filterFunction === 'function'
7079
+ ? filterFunction
7080
+ : LinzFreeTextFilter;
7081
+ return filter(input);
7082
+ }, [filterFunction]);
7083
+ var filterInputEvent = useCallback(function (event) {
7084
+ var value = event.target.value;
7085
+ var filteredValue = filterCharacters(value);
7086
+ if (filteredValue !== value) {
7087
+ var caretPosition = event.target.selectionStart;
7088
+ event.target.value = filteredValue;
7089
+ if (caretPosition !== null) {
7090
+ var positionOffset = value.length - filteredValue.length;
7091
+ var newCaretPosition = Math.max(caretPosition - positionOffset, 0);
7092
+ event.target.setSelectionRange(newCaretPosition, newCaretPosition);
7093
+ }
7094
+ }
7095
+ }, [filterFunction]);
7096
+ return (React__default.createElement(LuiFilterCharactersContext.Provider, { value: { filterCharacters: filterCharacters, filterInputEvent: filterInputEvent } }, children));
7097
+ };
7098
+
6992
7099
  function useGenerateOrDefaultId(idFromProps) {
6993
7100
  var id = useState(idFromProps ? idFromProps : v4())[0];
6994
7101
  return id;
@@ -6997,6 +7104,7 @@ var BareInput = forwardRef$1(function (props, ref) { return React__default.creat
6997
7104
  var LuiTextInput = forwardRef$1(function (props, ref) {
6998
7105
  var _a, _b, _c;
6999
7106
  var id = useGenerateOrDefaultId((_a = props.inputProps) === null || _a === void 0 ? void 0 : _a.id);
7107
+ var filterInputEvent = useFilterCharacters().filterInputEvent;
7000
7108
  var LuiInput = ((_b = props.inputProps) === null || _b === void 0 ? void 0 : _b.type) === 'date' ? DateInput : BareInput;
7001
7109
  return (React__default.createElement("div", { className: clsx$1('LuiTextInput', props.error && 'hasError', props.warning && 'hasWarning', props.className) },
7002
7110
  React__default.createElement("label", { className: 'LuiTextInput-label', htmlFor: id },
@@ -7004,7 +7112,15 @@ var LuiTextInput = forwardRef$1(function (props, ref) {
7004
7112
  React__default.createElement("span", { className: 'LuiTextInput-label-text ' +
7005
7113
  clsx$1(props.hideLabel ? 'LuiScreenReadersOnly' : '') }, props.label),
7006
7114
  React__default.createElement("span", { className: "LuiTextInput-inputWrapper" },
7007
- React__default.createElement(LuiInput, __assign({ ref: ref, className: clsx$1('LuiTextInput-input', props.showPadlockIcon ? 'LuiTextInput-padlock-icon ' : '', props.size ? "LuiTextInput-".concat(props.size) : ''), min: ((_c = props.inputProps) === null || _c === void 0 ? void 0 : _c.type) === 'date' ? undefined : '0', value: props.value, onChange: props.onChange }, props.inputProps, { id: id })),
7115
+ React__default.createElement(LuiInput, __assign({ ref: ref, className: clsx$1('LuiTextInput-input', props.showPadlockIcon ? 'LuiTextInput-padlock-icon ' : '', props.size ? "LuiTextInput-".concat(props.size) : ''), min: ((_c = props.inputProps) === null || _c === void 0 ? void 0 : _c.type) === 'date' ? undefined : '0', value: props.value, onChange: function (event) {
7116
+ var _a;
7117
+ if (((_a = props.inputProps) === null || _a === void 0 ? void 0 : _a.type) !== 'date') {
7118
+ filterInputEvent(event);
7119
+ }
7120
+ if (props.onChange) {
7121
+ props.onChange(event);
7122
+ }
7123
+ } }, props.inputProps, { id: id })),
7008
7124
  props.icon),
7009
7125
  props.error && (React__default.createElement("span", { className: "LuiTextInput-error" },
7010
7126
  React__default.createElement(LuiIcon, { alt: "error", name: "ic_error", className: "LuiTextInput-error-icon", size: "sm", status: "error" }),
@@ -7149,13 +7265,22 @@ var LuiSelectInput = function (props) {
7149
7265
  var LuiTextAreaInput = React__default.forwardRef(function (props, ref) {
7150
7266
  var _a, _b;
7151
7267
  var id = useGenerateOrDefaultId((_a = props.inputProps) === null || _a === void 0 ? void 0 : _a.id);
7268
+ var filterInputEvent = useFilterCharacters().filterInputEvent;
7152
7269
  var rows = props.rows !== undefined ? props.rows : 5;
7153
7270
  return (React__default.createElement("div", { className: clsx$1('LuiTextAreaInput', ((_b = props.inputProps) === null || _b === void 0 ? void 0 : _b.disabled) ? 'isDisabled' : '', props.error ? 'hasError' : '', props.warning ? 'hasWarning' : '') },
7154
7271
  React__default.createElement("label", { htmlFor: id },
7155
7272
  props.mandatory && (React__default.createElement("span", { className: "LuiTextAreaInput-mandatory" }, "*")),
7156
7273
  React__default.createElement("span", { className: "LuiTextAreaInput-label" }, props.label),
7157
7274
  React__default.createElement("div", { className: "LuiTextAreaInput-wrapper" },
7158
- React__default.createElement("textarea", __assign({ id: id, value: props.value, onChange: props.onChange, ref: ref, rows: rows }, props.inputProps)))),
7275
+ React__default.createElement("textarea", __assign({ id: id, value: props.value, onChange: function (event) {
7276
+ var _a;
7277
+ if (((_a = props.inputProps) === null || _a === void 0 ? void 0 : _a.type) !== 'date') {
7278
+ filterInputEvent(event);
7279
+ }
7280
+ if (props.onChange) {
7281
+ props.onChange(event);
7282
+ }
7283
+ }, ref: ref, rows: rows }, props.inputProps)))),
7159
7284
  props.error && (React__default.createElement("span", { className: "LuiTextAreaInput-error" },
7160
7285
  React__default.createElement(LuiIcon, { alt: "error", name: "ic_error", className: "LuiTextAreaInput-error-icon", size: "sm", status: "error" }),
7161
7286
  props.error)),
@@ -15734,6 +15859,14 @@ var logo = 'data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idX
15734
15859
 
15735
15860
  var motif = 'data:image/svg+xml;base64,<?xml version="1.0" encoding="utf-8"?>
<!-- Generator: Adobe Illustrator 25.2.3, SVG Export Plug-In . SVG Version: 6.00 Build 0)  -->
<svg version="1.1" id="Layer_2" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
	 width="113.4px" height="102.6px" viewBox="0 0 113.4 102.6" style="enable-background:new 0 0 113.4 102.6;" xml:space="preserve"
>
<style type="text/css">
	.st0{fill:#FFFFFF;}
	.st1{fill:url(#SVGID_1_);}
	.st2{fill:url(#SVGID_2_);}
	.st3{fill:url(#SVGID_3_);}
	.st4{fill:url(#SVGID_4_);}
	.st5{fill:url(#SVGID_5_);}
	.st6{opacity:0.4;fill:url(#SVGID_6_);enable-background:new    ;}
</style>
	<g>
	<path class="st0" d="M112.9,21.6c-0.7-1.4-2.3-2.4-3.8-2.6l-1.7-0.1c0.1-0.1,0.3-0.4,0.3-0.6c1.4-2.3,0.7-5.2-1.6-6.7
		c-0.7-0.4-1.4-0.6-2.1-0.7h-0.3h-0.1h-0.1h-0.3H103l-2.4-0.3c0.1-2.6-1.8-4.8-4.5-5h-1h-0.1C85.9,5,77,4.5,68.1,4.5
		c-2,0-5.1,0-7.1,0.1l-0.3-0.4c-0.4-0.7-0.9-1.3-1.3-1.8c-0.6-0.6-1.1-1.1-1.8-1.6C56.7,0.3,56,0,55,0h-0.1h-1l0,0H53l0,0
		c-3.5,0.1-7.1,0.3-10.6,0.6h-0.3c-3.3,0.3-6.2,0.6-8.9,0.9c-1.1,0.1-2.1,0.7-3,1.4c-4.5,4.5-9.1,11.3-13.6,20.3v0.1
		c-0.1,0.1-0.1,0.4-0.3,0.6c-1.7,3.3-3.3,6.8-4.8,10.6c0,0,0,0,0,0.1l-0.3,0.7c-1.4,3.4-2.8,7-4.1,10.5V46l-0.1,0.4l-0.1,0.3v0.1
		c-1.3,3.5-2.4,7-3.3,10.4v0.1l-0.1,0.4v0.1V58C2.1,62.4,1,66.5,0.2,70.2l0,0v0.1l0,0v0.3l-0.1,0.4c-0.6,2.7,1.3,5.1,3.8,5.7
		c0.3,0,0.6,0.1,0.9,0.1h0.1c-0.1,0.6-0.3,1.3-0.4,1.8v0.1l-0.1,0.9c-0.4,2.6,1.3,5.1,3.8,5.7c0.3,0,0.7,0.1,1,0.1h0.1
		c-0.1,0.7-0.3,1.3-0.4,1.8v0.1v0.1l0,0V88v0.1v0.3c-0.6,2.6,1.1,5.2,3.7,5.7c0.3,0,0.6,0.1,0.7,0.1h0.1c-0.1,0.6-0.3,1-0.3,1.6
		c-0.6,2.7,1.3,5.1,3.8,5.7c0.3,0,0.6,0.1,0.9,0.1c0.3,0,0.4,0,0.7,0c9.5-1.3,19.2-1.8,28.8-1.7c12.6,0,25.3,0.9,37.9,2.4
		c0.1,0,0.4,0,0.6,0c2.4,0,4.4-1.7,4.8-4.1c3.4-22.4,10.9-53.1,22-71.8C113.6,24.8,113.6,23.1,112.9,21.6z"/>

		<linearGradient id="SVGID_1_" gradientUnits="userSpaceOnUse" x1="40.257" y1="963.9195" x2="104.5195" y2="1028.1926" gradientTransform="matrix(1 0 0 1 0 -926.1102)">
		<stop  offset="0" style="stop-color:#73C8E1"/>
			<stop  offset="1" style="stop-color:#007199"/>
	</linearGradient>
		<path class="st1" d="M108.6,24.1c-22.1-1.8-43-1.4-57.9,0.4C37,38.7,22.5,73.6,17.8,97.5c15.7-2.4,41.9-2.8,68.1,0.4
		C89.2,75.9,96.9,44,108.6,24.1z"/>

		<linearGradient id="SVGID_2_" gradientUnits="userSpaceOnUse" x1="35.328" y1="956.0861" x2="98.91" y2="1019.6682" gradientTransform="matrix(1 0 0 1 0 -926.1102)">
		<stop  offset="0" style="stop-color:#75CBC7"/>
			<stop  offset="1" style="stop-color:#008782"/>
	</linearGradient>
		<path class="st2" d="M103.1,16c-22.1-1.8-42.8-1.4-57.9,0.4C31.3,30.6,18,65.7,13.2,89.5c15.9-2.4,39.4-3.1,65-0.7
		C82.2,64,90.6,37,103.1,16z"/>
		<path class="st0" d="M13,89.9l0.1-0.9c17.4-2.6,41.4-2.8,64.4-0.7c4.8-27.7,13.6-53.3,25-72.4l0.9,0.1c-11.3,19-20.3,45.1-25,72.8
		l-0.1,0.4H78C54.9,87.1,30.6,87.4,13,89.9z"/>

		<linearGradient id="SVGID_3_" gradientUnits="userSpaceOnUse" x1="30.0719" y1="949.9825" x2="91.0784" y2="1010.9786" gradientTransform="matrix(1 0 0 1 0 -926.1102)">
		<stop  offset="0" style="stop-color:#9DD19A"/>
			<stop  offset="0.5" style="stop-color:#06A24A"/>
	</linearGradient>
		<path class="st3" d="M71.2,48l2.3-6.2l10.8-12.3c0.4-0.1,0.9-0.1,1.3-0.1c2.8-6.4,6-12.6,9.5-18.6c-21.3-1.8-41.1-1.4-55.6,0.4
		C26.2,24.5,13.2,58,8.6,80.6c8.2-1.1,16.5-1.8,24.7-2c-0.6-0.3-0.1-2.3-0.1-2.3c0.6-2.4,2.3-4.3,4.5-6.2c2.3-2,1.3-3.3,3.1-4
		c3.8-1.7,7.5-3.8,10.9-6.2c4.3-3.1,5.8-14,6-13.3c0.1,0.7,1.7,0.4,1.7,1.1c0,0.6,0.4,1.8,0.7,2c0.3,0,1.6-3.3,4.5-3.3
		c1.8,0.1,3.5,0.7,5,2c0.1,0,1.3-0.1,1.3-0.1L71.2,48z"/>
		<path class="st0" d="M85.2,30.6l-0.7-0.4l0.6-1.1c2.7-6.4,5.8-12.5,9.4-18.4h0.9c-3.5,6-6.8,12.2-9.6,18.7L85.2,30.6z"/>
		<path class="st0" d="M57.7,9.2c-0.3,0.1,0.1,0.3,0.7,1c0.9,1,1.4,2,1.8,3.3c0,0.6-0.7,0.3,0.1,1.3c0.9,1,3.5,5,3.8,5.7
		s0.9,0.6,0.9,0.1s0.4,0.3,0.6,0.7c0,0.3-0.3,0.1-0.3,0.3c0,0.1,0.9,1.3,1.6,3.1c0.9,2.1,1.6,3.3,1.3,5.2c-0.1,2-0.6,5-2.1,5.8
		c-1.6,0.9-2.8,1-2.7,2.4c0.1,1.4,1.7,1.6,2.8,2.4s2.8,0.4,3.4,2c0.6,1.4-0.1,4.1-1.1,5.2s-1.4,1.7-0.9,2.1c0.6,0.4,0.9,0.4,1.3,0.3
		c0.4-0.1,0.9,0.1,0.9,0.7c0,0.6,0.3,0.7,2-0.3s2.4-3.1,3.7-4.8c1.1-1.6,2.1-3.1,3-5c0.1-0.3,0.1-0.4-0.4-0.7
		c-0.6-0.1-0.9-0.9-0.6-1.4c0,0,0-0.1,0.1-0.1c0.7-1.3,1.7-1.6,3-1.8c0.6-0.1,1.1-0.1,1.7,0c0.4,0.4,0.1,1.3,0.4,1s0.6-0.7,0.7-1
		c0-0.1,0-0.1-0.1-0.3c-0.1-0.1-0.6-0.4-0.1-1.3c0.4-1.1,1.8-0.9,2.1-2.8c0.4-2,1.6-3.3,1-4s-1.8-0.4-2.8-0.1c-1,0.4-2.1,2.4-3.5,2
		c-1.3-0.4-4.5-1.4-5.1-2.3c-0.7-1.7-1.1-3.3-1.4-5.1c-0.1-1.1-1-0.7-1.4-1.4c-0.4-0.6-0.7,0.4-0.6,1.4c0.1,1.1,1.1,2.1,0.6,2.6
		c-0.7,0.4-1.1-1.6-2.1-2c-1-0.4-1.4-1-1.1-2.8c0.1-2-1.7-2.3-1.4-3.3s0.6-2.1-1.7-3.7c-2.3-1.6-3.7-1-4.5-1.7
		c-0.9-0.9-1.4-1.3-1.6-2c-0.1-0.9,0.6-1-0.6-0.7C58.1,9.2,58,9.1,57.7,9.2z"/>
		<path class="st0" d="M64.4,53.6c0.4-0.4,0.7-1,1-1.7c0.1-0.4-1-0.3-1-1.1c0-0.9,0.6-1.7,0.6-2.1c0-0.3-0.3-0.1-0.4-0.1
		s-0.4-0.1-0.4-0.3c-0.1-0.4-0.6-0.6-1.6-0.1c-1,0.4-1.8,1.4-2.1,1.4c-0.3,0-0.7-1.4-0.7-2c0-0.7-1.7-0.4-1.6-1.1
		c0-0.3,0.1-0.6,0.3-0.9c0-0.1,0.1-0.1,0-0.3c-1.3-0.1-2.3,1.1-2.8,1.7c-0.6,0.6,0.9,2.8-0.7,4.1c-1.6,1.3-2.1,0.9-2.3,1.6
		c-0.4,3-2,5.8-4.5,7.5c-4.3,3.3-6.5,5.2-8.2,6.1c-1.7,0.7-2.1,3.1-4.3,5.1c-2.1,2-3.5,6.4-2.4,7.5c0.9,0.9,2.1,1.1,3.3,0.7
		c0.6-0.1,1.3,0.1,1.7,0.6c0.3,0.4,1.4-0.1,2,0.4c1,0.6,2.1,0.9,3.3,0.7c1.4-0.1,4.1-1.3,6.2-4.8c2.3-3.5,1.8-6.5,2.4-7.8
		c0.7-1.7,2-3.1,3.7-3.7c1.8-0.6,2.1-0.7,2.8-0.4s2,0.6,1.8-0.7c-0.1-1.3-1.7-0.7-1.7-1.7s-0.3-1.6,0.9-2.1c1.1-0.4,1.8-2.1,2.6-3.4
		C62.7,55.3,63.5,54.9,64.4,53.6z"/>

		<linearGradient id="SVGID_4_" gradientUnits="userSpaceOnUse" x1="16.8592" y1="952.0137" x2="62.9255" y2="998.0905" gradientTransform="matrix(1 0 0 1 0 -926.1102)">
		<stop  offset="0" style="stop-color:#9DD19A"/>
			<stop  offset="1" style="stop-color:#06A24A"/>
	</linearGradient>
		<path class="st4" d="M69.5,42.6c-0.1-0.3-0.3-0.4-0.4-0.6c-0.1-0.1-0.3-0.3-0.4-0.3c-0.7-0.4-1.7-0.4-2.6-1c-1.1-0.9-2.7-1-2.8-2.4
		c-0.1-1.4,1.1-1.7,2.7-2.4c1.6-0.9,2-3.7,2.1-5.8c0.1-2-0.6-3.3-1.3-5.2c-0.7-1.8-1.6-2.8-1.6-3.1s0.3,0,0.3-0.3
		c-0.1-0.4-0.6-1-0.6-0.7s-0.4,0.6-0.9-0.1c-0.4-0.7-3.1-4.7-3.8-5.7c-0.7-1-0.1-0.7-0.1-1.3c-0.4-1.1-1-2.3-1.8-3.3
		c-0.1-0.3-0.4-0.6-0.7-0.7l0,0c-0.1,0-0.1,0,0,0c-0.1-0.1-0.1-0.1-0.1-0.3c-0.6-1.3-1.4-2.6-2.3-3.7c-0.1-0.1-0.3-0.3-0.6-0.4
		C47.1,5.4,39.1,6,33.2,6.7C20.7,19.4,8.6,50.2,4.2,71.8c6.4-0.9,20-2,29.2-2.1h1.1h1.3h1.4c0.9-1.3,1.4-2.4,2.4-2.8
		c1.7-0.7,4.1-2.8,8.2-6.1c2.4-1.8,4.1-4.5,4.5-7.5c0.1-0.6,0.7-0.3,2.3-1.6c1.6-1.3,0.1-3.5,0.7-4.1c0.6-0.6,1.6-2,2.8-1.7
		c0.1,0,0,0.1,0,0.3C58.1,46.4,58,46.7,58,47c0,0.9,1.6,0.6,1.6,1.1c0,0.7,0.4,2,0.7,2c0.3,0,1.1-1,2.1-1.4l0.3-0.1l0,0
		c0.1,0,0.3-0.1,0.4-0.1l0,0c1,0,1.8,0.3,2.7,0.6c0.4,0.3,0.7,0.6,1,1c0-0.4,0.4-0.9,1-1.7C69.2,46.7,70,44,69.5,42.6z"/>
		<path class="st0" d="M33,78.3c-8.1,0.3-16,0.9-24.1,2l-0.1,0.9c8.2-1.1,16.5-1.7,24.8-2L33.4,79C33.2,78.9,33,78.6,33,78.3z"/>
		<path class="st0" d="M37.6,69.2h-1.4h-1.3h-1.1c-9.2,0.3-22.8,1.3-29.2,2.1v0.1v0.3l-0.1,0.6c6.2-0.9,20.1-2,29.5-2.1H35h1.8
		c0.1-0.1,0.3-0.4,0.4-0.6l0,0L37.6,69.2L37.6,69.2z"/>
		<path class="st0" d="M38.5,81.7c-0.9-0.3-0.4,0.4-0.4,1c0,0.6-0.3,0.6-0.4,1c-0.1,0.6-0.4,1-0.1,1.3c0.1,0.3,0.3,0.3,0.7-0.1
		c0.4-0.4,0.4-0.4,1-0.4c0.6,0,0.9-0.1,0.9-1C40,82.6,39.3,81.9,38.5,81.7z"/>

		<linearGradient id="SVGID_5_" gradientUnits="userSpaceOnUse" x1="22.8121" y1="942.3104" x2="47.9287" y2="988.5548" gradientTransform="matrix(1 0 0 1 0 -926.1102)">
		<stop  offset="0" style="stop-color:#FFFFFF;stop-opacity:0.9"/>
			<stop  offset="1" style="stop-color:#FFFFFF;stop-opacity:0.1"/>
	</linearGradient>
		<path class="st5" d="M13,70.6h0.7c1-4.1,2-8.1,3.1-11.8c3-0.1,6.4-0.4,10.1-0.6c-1.1,3.7-2.1,7.5-3.1,11.6h0.7
		c1-4.1,2-7.9,3.1-11.5c3.3-0.1,6.7-0.3,10.1-0.3c-1.1,3.5-2.1,7.4-3.1,11.5h0.3h0.3c1-4,2-7.8,3.1-11.5c3.4,0,6.8,0,10.1,0
		C48.1,59,47.8,60,47.5,61c0.1-0.1,0.4-0.3,0.6-0.4l0.3-0.3c0.1-0.7,0.4-1.4,0.6-2.1h1.4c0.1-0.1,0.3-0.4,0.4-0.6H49
		c1.1-3.7,2.3-7.2,3.4-10.5l3.1,0.1c0.1-0.1,0.3-0.4,0.6-0.6c-1.1,0-2.3-0.1-3.4-0.1c1.4-3.7,2.7-7.2,4.1-10.5
		c2.8,0,5.5,0.1,8.2,0.3c0.3-0.1,0.6-0.3,0.9-0.4c0.1,0,0.1-0.1,0.3-0.1c-2.8-0.1-6-0.3-8.9-0.4c1.7-3.8,3.4-7.4,5-10.5
		c1.6,0,3.1,0.1,4.7,0.1l-0.1-0.3l-0.1-0.3c-1.4,0-2.7-0.1-4.3-0.1c0.7-1.1,1.3-2.4,1.8-3.4c-0.1-0.1-0.1-0.1-0.3-0.3l-0.1-0.3
		c-0.7,1.3-1.4,2.6-2.1,4c-3.4,0-6.8,0-10.1,0c2.1-4.3,4.3-7.7,6.1-10.5H60v-0.1c0-0.1,0-0.3-0.1-0.4H58c0.3-0.6,0.7-1,1-1.6
		c-0.1-0.1-0.3-0.4-0.4-0.6c-0.4,0.7-0.9,1.3-1.4,2.1c-3.4,0-6.8,0.1-9.9,0.3c1.8-3,4-5.7,6.2-8.4h-0.9c-2.3,2.6-4.3,5.4-6.1,8.2
		c-3.7,0.1-7.1,0.3-9.9,0.6c1.8-3,4-5.7,6.2-8.4H42c-2.3,2.7-4.3,5.4-6.1,8.4c-4.5,0.3-7.8,0.6-9.1,0.7c-0.1,0.1-0.3,0.4-0.4,0.7
		c0.6,0,4-0.3,9.1-0.7c-1.8,2.8-3.8,6.2-6.1,10.5c-4.5,0.3-7.8,0.6-8.9,0.7l-0.3,0.7c0.7,0,4.1-0.3,8.9-0.7c-1.6,3.1-3.3,6.5-5,10.4
		c-4.3,0.3-7.5,0.6-8.8,0.7L15,37.5c1.1-0.1,4.4-0.4,8.8-0.7c-1.4,3.3-2.8,6.7-4.1,10.5c-4.1,0.3-7.4,0.4-8.4,0.6L11,48.4
		c0.7,0,4-0.3,8.8-0.7c-1.1,3.3-2.3,6.8-3.4,10.5c-4.4,0.3-7.7,0.6-8.7,0.6c0,0.1-0.1,0.4-0.1,0.6c0.7,0,4-0.3,8.7-0.7
		C15,62.6,14,66.4,13,70.6z M37.8,57.3c-3.5,0-7,0.1-10.1,0.3c1.1-3.7,2.3-7.1,3.4-10.5c3.3-0.1,6.7-0.3,10.1-0.3
		C40.1,50.1,39,53.6,37.8,57.3z M45.6,35.7c-1.4,3.3-2.7,6.7-4.1,10.5c-3.5,0-7,0.1-10.1,0.3c1.4-3.7,2.7-7.2,4.3-10.5
		C38.7,35.9,42.1,35.9,45.6,35.7z M35.9,35.5c1.7-3.8,3.4-7.4,5-10.5c3.1-0.1,6.5-0.3,10.1-0.3c-1.6,3.1-3.3,6.5-5,10.5
		C42.4,35.2,39,35.3,35.9,35.5z M48.6,57.3c-3.4,0-6.8,0-10.1,0c1.1-3.7,2.3-7.2,3.4-10.5c3.4,0,6.8,0,10.1,0
		C50.9,50.1,49.8,53.6,48.6,57.3z M52.3,46.2c-3.4,0-6.8,0-10.1,0c1.4-3.7,2.7-7.2,4.1-10.5c3.4,0,6.7,0,10.1,0
		C55,39,53.7,42.6,52.3,46.2z M61.5,24.7c-1.6,3.1-3.3,6.5-5,10.5c-3.4,0-6.8,0-10.1,0c1.7-3.8,3.4-7.4,5-10.5
		C54.9,24.7,58.3,24.7,61.5,24.7L61.5,24.7z M47.2,14c3.1-0.1,6.5-0.3,9.9-0.3c-1.8,2.8-3.8,6.2-6,10.5c-3.4,0-6.8,0.1-10.1,0.3
		C43.2,20.3,45.4,16.7,47.2,14z M36.4,14.6c2.8-0.1,6.2-0.4,9.9-0.6c-1.8,2.8-3.8,6.2-6.1,10.5c-3.7,0.1-7.1,0.3-10.1,0.6
		C32.6,20.9,34.6,17.3,36.4,14.6z M30,25.5c3-0.1,6.4-0.4,10.1-0.6c-1.6,3.1-3.3,6.5-5,10.5c-3.7,0.1-7.1,0.3-10.1,0.6
		C26.8,32.2,28.3,28.7,30,25.5z M24.8,36.6c3-0.1,6.4-0.4,10.1-0.6c-1.4,3.3-2.7,6.7-4.1,10.5c-3.7,0.1-7.2,0.3-10.1,0.6
		C22,43.3,23.4,39.9,24.8,36.6z M20.4,47.7c3-0.1,6.4-0.4,10.1-0.6c-1.1,3.3-2.3,6.8-3.4,10.4c-3.7,0.1-7.2,0.3-10.1,0.6
		C18.1,54.5,19.3,50.9,20.4,47.7z"/>

		<linearGradient id="SVGID_6_" gradientUnits="userSpaceOnUse" x1="61.5799" y1="968.431" x2="65.3909" y2="975.4666" gradientTransform="matrix(1 0 0 1 0 -926.1102)">
		<stop  offset="0" style="stop-color:#FFF799;stop-opacity:0.9"/>
			<stop  offset="1" style="stop-color:#FFF8A3;stop-opacity:0.1"/>
	</linearGradient>
		<path class="st6" d="M63.7,46.7c0.7-2.1,1.6-4.3,2.4-6.2c-0.1-0.1-0.3-0.3-0.6-0.3c-0.9,2.1-1.7,4.3-2.4,6.4
		c-1.6-0.1-3.1-0.1-4.8-0.3c0,0.4,0.4,0.6,0.9,0.7c1.3,0,2.6,0.1,3.7,0.1l-0.4,1.1h0.1c0.1-0.1,0.4-0.1,0.7-0.1l0.3-0.7
		c1.7,0.1,3.3,0.3,5,0.4c0.1-0.1,0.3-0.4,0.4-0.6C67.1,47,65.4,46.8,63.7,46.7z"/>
</g>
</svg>';
15736
15861
 
15862
+ function useDeprecatedWarning(componentName) {
15863
+ useEffect(function () {
15864
+ if (window.location.hostname.includes('localhost')) {
15865
+ console.warn("".concat(componentName, " will be deprecated in future versions of Lui. Please see the 'Current Deprecations' page in Lui docs."));
15866
+ }
15867
+ }, []);
15868
+ }
15869
+
15737
15870
  /**
15738
15871
  * A hook which allows you to register a handler when the escape key is pressed
15739
15872
  *
@@ -15760,11 +15893,21 @@ var useEscapeFunction = function (onEscape, trigger, elRef) {
15760
15893
  * A hook which allows handling of click event anywhere on the page.
15761
15894
  * Provides a way of handling clicks done inside or outside the element bound to the returned react ref.
15762
15895
  *
15896
+ * @deprecated
15897
+ * This hook is deprecated. It's no longer supported and will be removed in future version.
15898
+ *
15899
+ * For click inside element handling, consider attaching an `onClick` handler directly onto the element.
15900
+ *
15901
+ * For click outside element handling, consider using the `useClickedOutsideElement` hook instead.
15902
+ *
15903
+ * For click anywhere (both inside and outside) handling, consider attaching an `onClick` handler directly onto the document.
15904
+ *
15763
15905
  * @param onClickInsideArg handler for mouse clicks inside the element
15764
15906
  * @param onClickOutsideArg handler for mouse clicks outside the element
15765
15907
  * @return a react ref which can be bound to an html element
15766
15908
  */
15767
15909
  var usePageClickFunction = function (onClickInsideArg, onClickOutsideArg) {
15910
+ useDeprecatedWarning('usePageClickFunction');
15768
15911
  var elementRef = useRef(null);
15769
15912
  var onClickInside = useCallback(onClickInsideArg, [onClickInsideArg]);
15770
15913
  var onClickOutside = useCallback(onClickOutsideArg, [onClickOutsideArg]);
@@ -15829,14 +15972,6 @@ var buildHideClassDict = function (_a) {
15829
15972
  };
15830
15973
  };
15831
15974
 
15832
- function useDeprecatedWarning(componentName) {
15833
- useEffect(function () {
15834
- if (window.location.hostname.includes('localhost')) {
15835
- console.warn("".concat(componentName, " will be deprecated in future versions of Lui. Please see the 'Current Deprecations' page in Lui docs."));
15836
- }
15837
- }, []);
15838
- }
15839
-
15840
15975
  /**
15841
15976
  * @deprecated: this is replaced by LuiHeaderV2
15842
15977
  */
@@ -18623,10 +18758,18 @@ var LuiSearchInput = function (props) {
18623
18758
  }, [typedValue]);
18624
18759
  var cancelIcon = typedValue !== '' ? (React__default.createElement(LuiIcon, { alt: "clear", name: "ic_cancel_clear", size: "md", className: 'LuiSearchInput-iconPosition', spanProps: {
18625
18760
  onClick: function () {
18626
- var _a;
18761
+ var _a, _b, _c;
18762
+ var canClearInternally = (_a = props.isClearable) !== null && _a !== void 0 ? _a : true;
18763
+ if (!canClearInternally) {
18764
+ // Parent (e.g. unsaved-changes flow) will decide when
18765
+ // input gets cleared. We only signal the intent.
18766
+ (_b = props.onClearCallback) === null || _b === void 0 ? void 0 : _b.call(props);
18767
+ return;
18768
+ }
18769
+ // Default behaviour: clear input + results, and notify parent
18627
18770
  setInputValue('');
18628
- (_a = props.onClearCallback) === null || _a === void 0 ? void 0 : _a.call(props);
18629
18771
  setResults([]);
18772
+ (_c = props.onClearCallback) === null || _c === void 0 ? void 0 : _c.call(props);
18630
18773
  }
18631
18774
  } })) : null;
18632
18775
  var searchIcon = props.externalSearch ? (React__default.createElement(LuiIcon, { className: "LuiSearchInput-startIconPosition ".concat(typedValue ? 'LuiSearchInput-startIconPosition-enabled' : ''), name: "ic_create", size: "md", alt: "edit", spanProps: { onClick: function () { var _a; return (_a = inputRef.current) === null || _a === void 0 ? void 0 : _a.focus(); } } })) : (React__default.createElement(LuiIcon, { className: 'LuiSearchInput-startIconPosition', name: "ic_search", size: "md", alt: "search", spanProps: { onClick: function () { var _a; return (_a = inputRef.current) === null || _a === void 0 ? void 0 : _a.focus(); } } }));
@@ -41288,5 +41431,5 @@ var DrawerGlobal = forwardRef$1(function (props, ref) {
41288
41431
  return (React__default.createElement(Drawer, __assign({}, props, { ref: ref, isOpen: isOpen, onRequestClose: onRequestClose })));
41289
41432
  });
41290
41433
 
41291
- export { CheckboxItemRenderer, ColorBucket, ColorInput, ColorInputGroup, ColorPalette, Drawer, DrawerGlobal, DrawerGlobalContext, DrawerGlobalProvider, LuiAccordicard, LuiAccordicardStatic, LuiAccordion, LuiAlertModal, LuiAlertModalButtons, LuiAlertModalV2, LuiAppFooterSml, LuiAutoExpandTextAreaInput, LuiBadge, LuiBanner, LuiBannerContent, LuiBannerV2, LuiBearingInput, LuiButton, LuiButtonGroup, LuiCheckboxInput, LuiCloseableHeaderMenuContext, LuiCloseableHeaderMenuContextV2, LuiCloseableHeaderMenuItem, LuiCloseableHeaderMenuItemV2, LuiComboSelect, LuiControlledMenu, LuiCounter, LuiDateInput, LuiDrawerMenu, LuiDrawerMenuDivider, LuiDrawerMenuDividerV2, LuiDrawerMenuOption, LuiDrawerMenuOptionV2, LuiDrawerMenuOptions, LuiDrawerMenuOptionsV2, LuiDrawerMenuSection, LuiDrawerMenuSectionV2, LuiDrawerMenuV2, LuiDropdownMenu, LuiDropdownMenuV2, LuiDropdownMenuV2DropContent, LuiErrorIllustration, LuiErrorPage, LuiErrorPanel, LuiExpandableBanner, LuiFileInputBox, LuiFilterContainer, LuiFilterMenu, LuiFooter, LuiFormSectionHeader, LuiHeader, LuiHeaderMenuItem, LuiHeaderMenuItemV2, LuiHeaderV2, LuiIcon, LuiListBox, LuiLoadingSpinner, LuiMenu, LuiMenuCloseButton, LuiMenuCloseButtonV2, LuiMessagingContextProvider, LuiMiniSpinner, LuiModal, LuiModalV2, LuiMoneyInput, LuiMultiSwitch, LuiMultiSwitchYesNo, LuiPagination, LuiPassiveSearchInput, LuiProgressBar, LuiRadioInput, LuiResizableLayout, LuiSearchBox, LuiSearchInput, LuiSelectDataMenu, LuiSelectInput, LuiSelectMenu, LuiSelectMenuDivider, LuiSelectMenuHeader, LuiSelectMenuItem, LuiSelectMenuItemSwitch, LuiSelectSubMenuItem, LuiShadow, LuiSideMenu, LuiSideMenuItem, LuiSidePanel, LuiSidePanelProvider, LuiSideToolbar, LuiSplitButton, LuiSplitButtonMenuItem, LuiSplitButtonPosition, LuiStaticMessage, LuiStatusSpinner, LuiSwitchButton, LuiTab, LuiTabs, LuiTabsContext, LuiTabsGroup, LuiTabsPanel, LuiTabsPanelSwitch, LuiTextAreaInput, LuiTextInput, LuiToastMessage, LuiTooltip, LuiUpdatesSplashModal, RadioItemRenderer, SplitPanelState, Splitter, ToolbarButton, ToolbarDirection, ToolbarItem, ToolbarItemSeparator, breakpointQuery, breakpoints, defaultColours, isChromatic, useClickedOutsideElement, useDrawerGlobalContext, useEscapeFunction, useLuiCloseableHeaderMenuContextV2, useMediaQuery, usePageClickFunction, useShowLUIMessage, useSplitterRef, useToast };
41434
+ export { CheckboxItemRenderer, ColorBucket, ColorInput, ColorInputGroup, ColorPalette, Drawer, DrawerGlobal, DrawerGlobalContext, DrawerGlobalProvider, LinzFreeTextFilter, LinzFreeTextFilterConvertOnly, LinzFreeTextValidator, LuiAccordicard, LuiAccordicardStatic, LuiAccordion, LuiAlertModal, LuiAlertModalButtons, LuiAlertModalV2, LuiAppFooterSml, LuiAutoExpandTextAreaInput, LuiBadge, LuiBanner, LuiBannerContent, LuiBannerV2, LuiBearingInput, LuiButton, LuiButtonGroup, LuiCheckboxInput, LuiCloseableHeaderMenuContext, LuiCloseableHeaderMenuContextV2, LuiCloseableHeaderMenuItem, LuiCloseableHeaderMenuItemV2, LuiComboSelect, LuiControlledMenu, LuiCounter, LuiDateInput, LuiDrawerMenu, LuiDrawerMenuDivider, LuiDrawerMenuDividerV2, LuiDrawerMenuOption, LuiDrawerMenuOptionV2, LuiDrawerMenuOptions, LuiDrawerMenuOptionsV2, LuiDrawerMenuSection, LuiDrawerMenuSectionV2, LuiDrawerMenuV2, LuiDropdownMenu, LuiDropdownMenuV2, LuiDropdownMenuV2DropContent, LuiErrorIllustration, LuiErrorPage, LuiErrorPanel, LuiExpandableBanner, LuiFileInputBox, LuiFilterCharactersProvider, LuiFilterContainer, LuiFilterMenu, LuiFooter, LuiFormSectionHeader, LuiHeader, LuiHeaderMenuItem, LuiHeaderMenuItemV2, LuiHeaderV2, LuiIcon, LuiListBox, LuiLoadingSpinner, LuiMenu, LuiMenuCloseButton, LuiMenuCloseButtonV2, LuiMessagingContextProvider, LuiMiniSpinner, LuiModal, LuiModalV2, LuiMoneyInput, LuiMultiSwitch, LuiMultiSwitchYesNo, LuiPagination, LuiPassiveSearchInput, LuiProgressBar, LuiRadioInput, LuiResizableLayout, LuiSearchBox, LuiSearchInput, LuiSelectDataMenu, LuiSelectInput, LuiSelectMenu, LuiSelectMenuDivider, LuiSelectMenuHeader, LuiSelectMenuItem, LuiSelectMenuItemSwitch, LuiSelectSubMenuItem, LuiShadow, LuiSideMenu, LuiSideMenuItem, LuiSidePanel, LuiSidePanelProvider, LuiSideToolbar, LuiSplitButton, LuiSplitButtonMenuItem, LuiSplitButtonPosition, LuiStaticMessage, LuiStatusSpinner, LuiSwitchButton, LuiTab, LuiTabs, LuiTabsContext, LuiTabsGroup, LuiTabsPanel, LuiTabsPanelSwitch, LuiTextAreaInput, LuiTextInput, LuiToastMessage, LuiTooltip, LuiUpdatesSplashModal, RadioItemRenderer, SplitPanelState, Splitter, ToolbarButton, ToolbarDirection, ToolbarItem, ToolbarItemSeparator, breakpointQuery, breakpoints, defaultColours, isChromatic, useClickedOutsideElement, useDrawerGlobalContext, useEscapeFunction, useFilterCharacters, useLuiCloseableHeaderMenuContextV2, useMediaQuery, usePageClickFunction, useShowLUIMessage, useSplitterRef, useToast };
41292
41435
  //# sourceMappingURL=lui.esm.js.map