@nordicsemiconductor/pc-nrfconnect-shared 164.0.0 → 166.0.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/Changelog.md +30 -0
- package/nrfutil/modules.ts +8 -0
- package/nrfutil/sandbox.ts +24 -0
- package/package.json +1 -1
- package/src/InlineInput/InlineInput.tsx +3 -1
- package/src/InlineInput/NumberInlineInput.tsx +25 -2
- package/src/InlineInput/number-inline-input.scss +4 -2
- package/src/NumberInput/NumberInput.tsx +7 -1
- package/src/Slider/Slider.tsx +21 -7
- package/src/Slider/percentage.ts +13 -7
- package/src/Slider/range.ts +2 -15
- package/typings/generated/nrfutil/modules.d.ts.map +1 -1
- package/typings/generated/nrfutil/sandbox.d.ts +2 -0
- package/typings/generated/nrfutil/sandbox.d.ts.map +1 -1
- package/typings/generated/src/InlineInput/InlineInput.d.ts +1 -0
- package/typings/generated/src/InlineInput/InlineInput.d.ts.map +1 -1
- package/typings/generated/src/InlineInput/NumberInlineInput.d.ts +3 -1
- package/typings/generated/src/InlineInput/NumberInlineInput.d.ts.map +1 -1
- package/typings/generated/src/NumberInput/NumberInput.d.ts +3 -1
- package/typings/generated/src/NumberInput/NumberInput.d.ts.map +1 -1
- package/typings/generated/src/Slider/Slider.d.ts.map +1 -1
- package/typings/generated/src/Slider/percentage.d.ts.map +1 -1
- package/typings/generated/src/Slider/range.d.ts +1 -1
- package/typings/generated/src/Slider/range.d.ts.map +1 -1
package/Changelog.md
CHANGED
|
@@ -7,6 +7,36 @@ This project does _not_ adhere to
|
|
|
7
7
|
[Semantic Versioning](https://semver.org/spec/v2.0.0.html) but contrary to it
|
|
8
8
|
every new version is a new major version.
|
|
9
9
|
|
|
10
|
+
## 166.0.0 - 2024-03-05
|
|
11
|
+
|
|
12
|
+
### Added
|
|
13
|
+
|
|
14
|
+
- `Slider` now supports unsorted range values
|
|
15
|
+
- `NumberInlineInput` now supports unsorted range values
|
|
16
|
+
- `InlineInput` supports optional `minSize` property
|
|
17
|
+
- `NumberInlineInput` supports optional `minSize` and `preAllocateSize`
|
|
18
|
+
properties
|
|
19
|
+
- `NumberInput` supports optional `inputMinSize` and `preAllocateInputSize`
|
|
20
|
+
properties
|
|
21
|
+
|
|
22
|
+
### Changed
|
|
23
|
+
|
|
24
|
+
- `NumberInlineInput` will pre-allocate input min width depending on the range
|
|
25
|
+
unless `minSize` property is provided or `preAllocateSize` is set to false
|
|
26
|
+
- `NumberInput` will pre-allocate input min input field width depending on the
|
|
27
|
+
range unless `inputMinSize` property is provided or `preAllocateInputSize`
|
|
28
|
+
is set to false
|
|
29
|
+
|
|
30
|
+
### Fixed
|
|
31
|
+
|
|
32
|
+
- `NumberInput` unit is not aligned when label consumes multi line
|
|
33
|
+
|
|
34
|
+
## 165.0.0 - 2024-03-05
|
|
35
|
+
|
|
36
|
+
### Added
|
|
37
|
+
|
|
38
|
+
- Auto update nrfutil core for sandboxes
|
|
39
|
+
|
|
10
40
|
## 164.0.0 - 2024-03-05
|
|
11
41
|
|
|
12
42
|
### Fixed
|
package/nrfutil/modules.ts
CHANGED
|
@@ -27,6 +27,14 @@ const logModuleVersions = (module: string, moduleSandbox: NrfutilSandbox) => {
|
|
|
27
27
|
);
|
|
28
28
|
});
|
|
29
29
|
}
|
|
30
|
+
|
|
31
|
+
moduleSandbox.getCoreVersion().then(moduleVersion => {
|
|
32
|
+
getNrfutilLogger()?.info(
|
|
33
|
+
`Using nrfutil-${module} core version: ${describeVersion(
|
|
34
|
+
moduleVersion.version
|
|
35
|
+
)}`
|
|
36
|
+
);
|
|
37
|
+
});
|
|
30
38
|
};
|
|
31
39
|
|
|
32
40
|
const forwardLogging = (moduleSandbox: NrfutilSandbox) => {
|
package/nrfutil/sandbox.ts
CHANGED
|
@@ -149,6 +149,16 @@ export class NrfutilSandbox {
|
|
|
149
149
|
throw new Error('Unexpected result');
|
|
150
150
|
};
|
|
151
151
|
|
|
152
|
+
public getCoreVersion = async () => {
|
|
153
|
+
const results = await this.spawnNrfutil<ModuleVersion>('--version', []);
|
|
154
|
+
|
|
155
|
+
if (results.info.length === 1) {
|
|
156
|
+
return results.info[0];
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
throw new Error('Unexpected result');
|
|
160
|
+
};
|
|
161
|
+
|
|
152
162
|
public isSandboxInstalled = async () => {
|
|
153
163
|
if (
|
|
154
164
|
fs.existsSync(
|
|
@@ -192,6 +202,17 @@ export class NrfutilSandbox {
|
|
|
192
202
|
}
|
|
193
203
|
};
|
|
194
204
|
|
|
205
|
+
public updateNrfUtilCore = async (
|
|
206
|
+
onProgress?: (progress: Progress, task?: Task) => void
|
|
207
|
+
) => {
|
|
208
|
+
try {
|
|
209
|
+
await this.spawnNrfutil('self-upgrade', [], onProgress);
|
|
210
|
+
} catch (error) {
|
|
211
|
+
// User might not have internet hance fail silently
|
|
212
|
+
getNrfutilLogger()?.error(`Error while updated nrfutil core`);
|
|
213
|
+
}
|
|
214
|
+
};
|
|
215
|
+
|
|
195
216
|
public getNrfutilExePath = () => path.join(this.baseDir, 'nrfutil');
|
|
196
217
|
|
|
197
218
|
public spawnNrfutilSubcommand = <Result>(
|
|
@@ -725,6 +746,9 @@ export default async (
|
|
|
725
746
|
|
|
726
747
|
if (!result) {
|
|
727
748
|
await sandbox.prepareSandbox(onProgress);
|
|
749
|
+
} else {
|
|
750
|
+
// update nrfutil core
|
|
751
|
+
await sandbox.updateNrfUtilCore(onProgress);
|
|
728
752
|
}
|
|
729
753
|
|
|
730
754
|
onProgress?.(convertNrfutilProgress({ progressPercentage: 100 }));
|
package/package.json
CHANGED
|
@@ -61,6 +61,7 @@ interface Props {
|
|
|
61
61
|
textAlignLeft?: boolean;
|
|
62
62
|
onValidityChanged?: (validity: boolean) => void;
|
|
63
63
|
preventDefaultInvalidStyle?: boolean;
|
|
64
|
+
minSize?: number;
|
|
64
65
|
}
|
|
65
66
|
|
|
66
67
|
const InlineInput = React.forwardRef<HTMLInputElement, Props>(
|
|
@@ -78,6 +79,7 @@ const InlineInput = React.forwardRef<HTMLInputElement, Props>(
|
|
|
78
79
|
textAlignLeft = false,
|
|
79
80
|
onValidityChanged,
|
|
80
81
|
preventDefaultInvalidStyle,
|
|
82
|
+
minSize,
|
|
81
83
|
},
|
|
82
84
|
ref
|
|
83
85
|
) => {
|
|
@@ -174,7 +176,7 @@ const InlineInput = React.forwardRef<HTMLInputElement, Props>(
|
|
|
174
176
|
className
|
|
175
177
|
)}
|
|
176
178
|
size={
|
|
177
|
-
Math.max(1, internalValue.length) +
|
|
179
|
+
Math.max(minSize ?? 1, internalValue.length) +
|
|
178
180
|
(process.platform === 'darwin' ? 2 : 0)
|
|
179
181
|
}
|
|
180
182
|
disabled={disabled}
|
|
@@ -12,7 +12,7 @@ import {
|
|
|
12
12
|
isValues,
|
|
13
13
|
Range,
|
|
14
14
|
RangeOrValues,
|
|
15
|
-
|
|
15
|
+
useValidatedRange,
|
|
16
16
|
Values,
|
|
17
17
|
} from '../Slider/range';
|
|
18
18
|
import InlineInput from './InlineInput';
|
|
@@ -30,6 +30,8 @@ interface NumberInlineInput {
|
|
|
30
30
|
textAlignLeft?: boolean;
|
|
31
31
|
onValidityChanged?: (validity: boolean) => void;
|
|
32
32
|
preventDefaultInvalidStyle?: boolean;
|
|
33
|
+
minSize?: number;
|
|
34
|
+
preAllocateSize?: boolean;
|
|
33
35
|
}
|
|
34
36
|
|
|
35
37
|
const isInValues = (value: number, values: Values) => values.includes(value);
|
|
@@ -106,8 +108,10 @@ export default ({
|
|
|
106
108
|
textAlignLeft,
|
|
107
109
|
onValidityChanged,
|
|
108
110
|
preventDefaultInvalidStyle,
|
|
111
|
+
minSize,
|
|
112
|
+
preAllocateSize = true,
|
|
109
113
|
}: NumberInlineInput) => {
|
|
110
|
-
|
|
114
|
+
useValidatedRange(range);
|
|
111
115
|
|
|
112
116
|
return (
|
|
113
117
|
<InlineInput
|
|
@@ -143,6 +147,25 @@ export default ({
|
|
|
143
147
|
}}
|
|
144
148
|
onValidityChanged={onValidityChanged}
|
|
145
149
|
preventDefaultInvalidStyle={preventDefaultInvalidStyle}
|
|
150
|
+
minSize={
|
|
151
|
+
preAllocateSize
|
|
152
|
+
? minSize ??
|
|
153
|
+
Math.max(
|
|
154
|
+
...(isValues(range)
|
|
155
|
+
? range.map(v =>
|
|
156
|
+
Number.isFinite(v)
|
|
157
|
+
? handleInfinityToString(v)
|
|
158
|
+
: v.toString()
|
|
159
|
+
)
|
|
160
|
+
: [range.min, range.max].map(v =>
|
|
161
|
+
Number.isFinite(v)
|
|
162
|
+
? v.toFixed(range.decimals)
|
|
163
|
+
: handleInfinityToString(v)
|
|
164
|
+
)
|
|
165
|
+
).map(v => v.length)
|
|
166
|
+
)
|
|
167
|
+
: undefined
|
|
168
|
+
}
|
|
146
169
|
/>
|
|
147
170
|
);
|
|
148
171
|
};
|
|
@@ -4,12 +4,14 @@
|
|
|
4
4
|
* SPDX-License-Identifier: LicenseRef-Nordic-4-Clause
|
|
5
5
|
*/
|
|
6
6
|
|
|
7
|
-
@import
|
|
7
|
+
@import '../variables';
|
|
8
8
|
|
|
9
9
|
.number-inline-input {
|
|
10
10
|
text-align: center;
|
|
11
11
|
border-bottom-color: $gray-200;
|
|
12
12
|
font-size: 14px;
|
|
13
13
|
|
|
14
|
-
&:focus {
|
|
14
|
+
&:focus {
|
|
15
|
+
background-color: $white;
|
|
16
|
+
}
|
|
15
17
|
}
|
|
@@ -72,6 +72,8 @@ export default <T,>({
|
|
|
72
72
|
unit,
|
|
73
73
|
showSlider = false,
|
|
74
74
|
minWidth = false,
|
|
75
|
+
inputMinSize,
|
|
76
|
+
preAllocateInputSize,
|
|
75
77
|
}: {
|
|
76
78
|
range: RangeOrValues;
|
|
77
79
|
value: number;
|
|
@@ -84,6 +86,8 @@ export default <T,>({
|
|
|
84
86
|
showSlider?: boolean;
|
|
85
87
|
unit?: React.ReactNode | DropdownUnit<T>;
|
|
86
88
|
minWidth?: boolean;
|
|
89
|
+
inputMinSize?: number;
|
|
90
|
+
preAllocateInputSize?: boolean;
|
|
87
91
|
}) => (
|
|
88
92
|
<div
|
|
89
93
|
className={`tw-flex tw-flex-col tw-gap-1 tw-text-xs ${classNames(
|
|
@@ -98,13 +102,15 @@ export default <T,>({
|
|
|
98
102
|
title={title}
|
|
99
103
|
>
|
|
100
104
|
{label}
|
|
101
|
-
<div className="tw-flex tw-flex-row">
|
|
105
|
+
<div className="tw-flex tw-flex-row tw-items-center">
|
|
102
106
|
<NumberInlineInput
|
|
103
107
|
value={value}
|
|
104
108
|
range={range}
|
|
105
109
|
onChange={onChange}
|
|
106
110
|
onChangeComplete={onChangeComplete}
|
|
107
111
|
disabled={disabled}
|
|
112
|
+
minSize={inputMinSize}
|
|
113
|
+
preAllocateSize={preAllocateInputSize}
|
|
108
114
|
/>
|
|
109
115
|
{isDropdownUnit(unit) ? (
|
|
110
116
|
<Dropdown
|
package/src/Slider/Slider.tsx
CHANGED
|
@@ -11,7 +11,7 @@ import classNames from '../utils/classNames';
|
|
|
11
11
|
import Bar from './Bar';
|
|
12
12
|
import Handle from './Handle';
|
|
13
13
|
import { toPercentage } from './percentage';
|
|
14
|
-
import {
|
|
14
|
+
import { isValues, RangeOrValues, useValidatedRange } from './range';
|
|
15
15
|
import Ticks from './Ticks';
|
|
16
16
|
|
|
17
17
|
import './slider.scss';
|
|
@@ -52,14 +52,26 @@ const Slider: FC<Props> = ({
|
|
|
52
52
|
onChangeComplete,
|
|
53
53
|
}) => {
|
|
54
54
|
useValidatedArraySizes(values, onChange);
|
|
55
|
-
|
|
55
|
+
useValidatedRange(rangeOrValues);
|
|
56
56
|
|
|
57
57
|
const { width, ref } = useResizeDetector();
|
|
58
58
|
|
|
59
|
-
const
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
59
|
+
const explicitValues = isValues(rangeOrValues);
|
|
60
|
+
if (explicitValues) {
|
|
61
|
+
// we can just work with te indexes
|
|
62
|
+
values = values.map(v => rangeOrValues.indexOf(v));
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
const valueRange = explicitValues
|
|
66
|
+
? {
|
|
67
|
+
min: values.length === 1 ? 0 : Math.min(...values),
|
|
68
|
+
max: Math.max(...values),
|
|
69
|
+
}
|
|
70
|
+
: {
|
|
71
|
+
min:
|
|
72
|
+
values.length === 1 ? rangeOrValues.min : Math.min(...values),
|
|
73
|
+
max: Math.max(...values),
|
|
74
|
+
};
|
|
63
75
|
|
|
64
76
|
return (
|
|
65
77
|
<div
|
|
@@ -79,7 +91,9 @@ const Slider: FC<Props> = ({
|
|
|
79
91
|
value={value}
|
|
80
92
|
range={rangeOrValues}
|
|
81
93
|
disabled={disabled}
|
|
82
|
-
onChange={
|
|
94
|
+
onChange={v => {
|
|
95
|
+
onChange[index](explicitValues ? rangeOrValues[v] : v);
|
|
96
|
+
}}
|
|
83
97
|
onChangeComplete={onChangeComplete}
|
|
84
98
|
sliderWidth={width}
|
|
85
99
|
/>
|
package/src/Slider/percentage.ts
CHANGED
|
@@ -13,6 +13,12 @@ export const constrainedToPercentage = (percentage: number) => {
|
|
|
13
13
|
};
|
|
14
14
|
|
|
15
15
|
export const toPercentage = (value: number, rangeOrValues: RangeOrValues) => {
|
|
16
|
+
if (isValues(rangeOrValues)) {
|
|
17
|
+
const max = rangeOrValues.length;
|
|
18
|
+
|
|
19
|
+
// value is an index in the case of explicit values
|
|
20
|
+
return (value * 100) / max;
|
|
21
|
+
}
|
|
16
22
|
const min = getMin(rangeOrValues);
|
|
17
23
|
const max = getMax(rangeOrValues);
|
|
18
24
|
|
|
@@ -29,11 +35,10 @@ export const fromPercentage = (
|
|
|
29
35
|
const max = getMax(rangeOrValues);
|
|
30
36
|
|
|
31
37
|
if (isValues(rangeOrValues)) {
|
|
32
|
-
const
|
|
33
|
-
const
|
|
34
|
-
const computedValue = (value * (max - min)) / 100 + min;
|
|
38
|
+
const noOfIndexes = rangeOrValues.length - 1;
|
|
39
|
+
const computedValue = (value / 100) * noOfIndexes;
|
|
35
40
|
|
|
36
|
-
const lastValueIndex =
|
|
41
|
+
const lastValueIndex = lastValue;
|
|
37
42
|
const closestPrevIndex = lastValueIndex === 0 ? 0 : lastValueIndex - 1;
|
|
38
43
|
const closestNextIndex =
|
|
39
44
|
lastValueIndex === noOfIndexes ? noOfIndexes : lastValueIndex + 1;
|
|
@@ -42,17 +47,18 @@ export const fromPercentage = (
|
|
|
42
47
|
|
|
43
48
|
if (directionForward) {
|
|
44
49
|
closestIndex =
|
|
45
|
-
|
|
50
|
+
closestNextIndex > computedValue
|
|
46
51
|
? lastValueIndex
|
|
47
52
|
: closestNextIndex;
|
|
48
53
|
} else {
|
|
49
54
|
closestIndex =
|
|
50
|
-
|
|
55
|
+
closestPrevIndex < computedValue
|
|
51
56
|
? lastValueIndex
|
|
52
57
|
: closestPrevIndex;
|
|
53
58
|
}
|
|
54
59
|
|
|
55
|
-
|
|
60
|
+
console.log(computedValue, closestIndex);
|
|
61
|
+
return closestIndex;
|
|
56
62
|
}
|
|
57
63
|
|
|
58
64
|
const range = rangeOrValues;
|
package/src/Slider/range.ts
CHANGED
|
@@ -39,17 +39,6 @@ const assert = (expectedToBeTrue: boolean, warning: string) => {
|
|
|
39
39
|
}
|
|
40
40
|
};
|
|
41
41
|
|
|
42
|
-
const validateValues = (values: Values) => {
|
|
43
|
-
for (let i = 0; i < values.length - 1; i += 1) {
|
|
44
|
-
assert(
|
|
45
|
-
values[i] < values[i + 1],
|
|
46
|
-
`The values of the range must be sorted correctly, but ${
|
|
47
|
-
values[i]
|
|
48
|
-
} is larger then ${values[i + 1]} in ${values}`
|
|
49
|
-
);
|
|
50
|
-
}
|
|
51
|
-
};
|
|
52
|
-
|
|
53
42
|
const validateRange = (range: Range) => {
|
|
54
43
|
assert(
|
|
55
44
|
!(`explicitRange` in range),
|
|
@@ -81,11 +70,9 @@ const validateRange = (range: Range) => {
|
|
|
81
70
|
}
|
|
82
71
|
};
|
|
83
72
|
|
|
84
|
-
export const
|
|
73
|
+
export const useValidatedRange = (rangeOrValues: RangeOrValues) => {
|
|
85
74
|
useEffect(() => {
|
|
86
|
-
if (isValues(rangeOrValues)) {
|
|
87
|
-
validateValues(rangeOrValues);
|
|
88
|
-
} else {
|
|
75
|
+
if (!isValues(rangeOrValues)) {
|
|
89
76
|
validateRange(rangeOrValues);
|
|
90
77
|
}
|
|
91
78
|
}, [rangeOrValues]);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"modules.d.ts","sourceRoot":"","sources":["../../../nrfutil/modules.ts"],"names":[],"mappings":"AAYA,OAAgB,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AACpD,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"modules.d.ts","sourceRoot":"","sources":["../../../nrfutil/modules.ts"],"names":[],"mappings":"AAYA,OAAgB,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AACpD,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AA4G1C,eAAO,MAAM,SAAS,WAAY,MAAM,6CAMvC,CAAC;AAEF,eAAO,MAAM,mBAAmB,WAAY,MAAM,YACZ,CAAC;AASvC,eAAO,MAAM,WAAW,UAAiB,QAAQ,kBAIhD,CAAC;AAEF,eAAO,MAAM,iBAAiB,YAAmB,OAAO,kBAIvD,CAAC;AAEF,eAAO,MAAM,oBAAoB,yDAK5B,CAAC"}
|
|
@@ -22,8 +22,10 @@ export declare class NrfutilSandbox {
|
|
|
22
22
|
constructor(baseDir: string, module: string, version: string);
|
|
23
23
|
private processLoggingData;
|
|
24
24
|
getModuleVersion: () => Promise<ModuleVersion>;
|
|
25
|
+
getCoreVersion: () => Promise<ModuleVersion>;
|
|
25
26
|
isSandboxInstalled: () => Promise<boolean>;
|
|
26
27
|
prepareSandbox: (onProgress?: ((progress: Progress, task?: Task) => void) | undefined) => Promise<void>;
|
|
28
|
+
updateNrfUtilCore: (onProgress?: ((progress: Progress, task?: Task) => void) | undefined) => Promise<void>;
|
|
27
29
|
getNrfutilExePath: () => string;
|
|
28
30
|
spawnNrfutilSubcommand: <Result>(command: string, args: string[], onProgress?: ((progress: Progress, task?: Task) => void) | undefined, onTaskBegin?: ((taskBegin: TaskBegin) => void) | undefined, onTaskEnd?: ((taskEnd: TaskEnd<Result>) => void) | undefined, controller?: AbortController, editEnv?: ((env: NodeJS.ProcessEnv) => NodeJS.ProcessEnv) | undefined) => Promise<{
|
|
29
31
|
taskEnd: TaskEnd<Result>[];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sandbox.d.ts","sourceRoot":"","sources":["../../../nrfutil/sandbox.ts"],"names":[],"mappings":";AAiBA,OAAO,EACH,cAAc,EACd,QAAQ,EACR,UAAU,EACV,aAAa,EAGb,QAAQ,EACR,IAAI,EACJ,SAAS,EACT,OAAO,EACV,MAAM,gBAAgB,CAAC;AAcxB,QAAA,MAAM,UAAU,YAAa,MAAM,UAAU,MAAM,WAAW,MAAM;;;;;;;;;;;CAqBnE,CAAC;AAiDF,qBAAa,cAAc;IACvB,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,iBAAiB,EAAE,CAAC,CAAC,OAAO,EAAE,UAAU,EAAE,GAAG,CAAC,EAAE,MAAM,KAAK,IAAI,CAAC,EAAE,CAAM;IACxE,QAAQ,EAAE,QAAQ,CAAmC;IACrD,GAAG,EAAE,UAAU,CAAC,OAAO,UAAU,CAAC,CAAC;gBAEvB,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM;IAQ5D,OAAO,CAAC,kBAAkB,CASxB;IAEK,gBAAgB,+BAUrB;IAEK,kBAAkB,yBAmBvB;IAEK,cAAc,4BACO,QAAQ,SAAS,IAAI,KAAK,IAAI,gCAmBxD;IAEK,iBAAiB,eAA4C;IAE7D,sBAAsB,oBAChB,MAAM,QACT,MAAM,EAAE,2BACU,QAAQ,SAAS,IAAI,KAAK,IAAI,0CAC5B,SAAS,KAAK,IAAI,0DACF,IAAI,4BACjC,eAAe,mBACZ,OAAO,UAAU,KAAK,OAAO,UAAU;;;OAUrD;IAEN,OAAO,CAAC,mBAAmB,CAsBrB;IAEN,OAAO,CAAC,YAAY,CAmFlB;IAEK,YAAY,YACN,MAAM,QACT,MAAM,EAAE,iBACC,MAAM,QAAQ,MAAM,KAAK,MAAM,GAAG,SAAS,qBACvC,MAAM,QAAQ,MAAM,KAAK,IAAI,eACnC,eAAe,kBACb,OAAO,UAAU,KAAK,OAAO,UAAU,mBAqEnD;IAEA,qBAAqB,oBACf,MAAM,QACT,MAAM,EAAE,2BACU,QAAQ,SAAS,IAAI,KAAK,IAAI,0CAC5B,SAAS,KAAK,IAAI,0DACF,IAAI,4BACjC,eAAe,mBACZ,OAAO,UAAU,KAAK,OAAO,UAAU;;;OAUrD;IAEN,OAAO,CAAC,kBAAkB,CAmFxB;IAEK,WAAW,YACL,MAAM,QACT,MAAM,EAAE,iBACC,MAAM,QAAQ,MAAM,KAAK,IAAI,qBACzB,MAAM,QAAQ,MAAM,KAAK,IAAI,eACnC,eAAe,kBACb,OAAO,UAAU,KAAK,OAAO,UAAU,mBA0DnD;IAEA,yBAAyB,oBACnB,MAAM,QACT,MAAM,EAAE,uDAEE,OAAO,UAAU,KAAK,OAAO,UAAU;yBA4ClC,MAAM,IAAI;;qCAKE,KAAK,KAAK,IAAI,qBA7Cf,KAAK,KAAK,IAAI;MAoDhD;IAEK,8BAA8B,eACxB,MAAM,2BACS,QAAQ,SAAS,IAAI,KAAK,IAAI,4BACzC,eAAe,SACtB,MAAM,EAAE,sCAahB;IAEK,kCAAkC,sBAC5B,MAAM,2BACS,QAAQ,SAAS,IAAI,KAAK,IAAI,4BACzC,eAAe,SACtB,MAAM,EAAE,gBAehB;IAEK,+BAA+B,sBACzB,MAAM,eACF,eAAe,SACtB,MAAM,EAAE,gBAehB;IAEK,SAAS,sBACO,UAAU,QAAQ,MAAM,KAAK,IAAI,
|
|
1
|
+
{"version":3,"file":"sandbox.d.ts","sourceRoot":"","sources":["../../../nrfutil/sandbox.ts"],"names":[],"mappings":";AAiBA,OAAO,EACH,cAAc,EACd,QAAQ,EACR,UAAU,EACV,aAAa,EAGb,QAAQ,EACR,IAAI,EACJ,SAAS,EACT,OAAO,EACV,MAAM,gBAAgB,CAAC;AAcxB,QAAA,MAAM,UAAU,YAAa,MAAM,UAAU,MAAM,WAAW,MAAM;;;;;;;;;;;CAqBnE,CAAC;AAiDF,qBAAa,cAAc;IACvB,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,iBAAiB,EAAE,CAAC,CAAC,OAAO,EAAE,UAAU,EAAE,GAAG,CAAC,EAAE,MAAM,KAAK,IAAI,CAAC,EAAE,CAAM;IACxE,QAAQ,EAAE,QAAQ,CAAmC;IACrD,GAAG,EAAE,UAAU,CAAC,OAAO,UAAU,CAAC,CAAC;gBAEvB,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM;IAQ5D,OAAO,CAAC,kBAAkB,CASxB;IAEK,gBAAgB,+BAUrB;IAEK,cAAc,+BAQnB;IAEK,kBAAkB,yBAmBvB;IAEK,cAAc,4BACO,QAAQ,SAAS,IAAI,KAAK,IAAI,gCAmBxD;IAEK,iBAAiB,4BACI,QAAQ,SAAS,IAAI,KAAK,IAAI,gCAQxD;IAEK,iBAAiB,eAA4C;IAE7D,sBAAsB,oBAChB,MAAM,QACT,MAAM,EAAE,2BACU,QAAQ,SAAS,IAAI,KAAK,IAAI,0CAC5B,SAAS,KAAK,IAAI,0DACF,IAAI,4BACjC,eAAe,mBACZ,OAAO,UAAU,KAAK,OAAO,UAAU;;;OAUrD;IAEN,OAAO,CAAC,mBAAmB,CAsBrB;IAEN,OAAO,CAAC,YAAY,CAmFlB;IAEK,YAAY,YACN,MAAM,QACT,MAAM,EAAE,iBACC,MAAM,QAAQ,MAAM,KAAK,MAAM,GAAG,SAAS,qBACvC,MAAM,QAAQ,MAAM,KAAK,IAAI,eACnC,eAAe,kBACb,OAAO,UAAU,KAAK,OAAO,UAAU,mBAqEnD;IAEA,qBAAqB,oBACf,MAAM,QACT,MAAM,EAAE,2BACU,QAAQ,SAAS,IAAI,KAAK,IAAI,0CAC5B,SAAS,KAAK,IAAI,0DACF,IAAI,4BACjC,eAAe,mBACZ,OAAO,UAAU,KAAK,OAAO,UAAU;;;OAUrD;IAEN,OAAO,CAAC,kBAAkB,CAmFxB;IAEK,WAAW,YACL,MAAM,QACT,MAAM,EAAE,iBACC,MAAM,QAAQ,MAAM,KAAK,IAAI,qBACzB,MAAM,QAAQ,MAAM,KAAK,IAAI,eACnC,eAAe,kBACb,OAAO,UAAU,KAAK,OAAO,UAAU,mBA0DnD;IAEA,yBAAyB,oBACnB,MAAM,QACT,MAAM,EAAE,uDAEE,OAAO,UAAU,KAAK,OAAO,UAAU;yBA4ClC,MAAM,IAAI;;qCAKE,KAAK,KAAK,IAAI,qBA7Cf,KAAK,KAAK,IAAI;MAoDhD;IAEK,8BAA8B,eACxB,MAAM,2BACS,QAAQ,SAAS,IAAI,KAAK,IAAI,4BACzC,eAAe,SACtB,MAAM,EAAE,sCAahB;IAEK,kCAAkC,sBAC5B,MAAM,2BACS,QAAQ,SAAS,IAAI,KAAK,IAAI,4BACzC,eAAe,SACtB,MAAM,EAAE,gBAehB;IAEK,+BAA+B,sBACzB,MAAM,eACF,eAAe,SACtB,MAAM,EAAE,gBAehB;IAEK,SAAS,sBACO,UAAU,QAAQ,MAAM,KAAK,IAAI,sBAvlB1B,UAAU,QAAQ,MAAM,KAAK,IAAI,IAgmB7D;IAEK,WAAW,UAAW,QAAQ,UAEnC;CACL;kCAGY,MAAM,UACP,MAAM,YACJ,MAAM,2BACQ,QAAQ,SAAS,IAAI,KAAK,IAAI;AAJ1D,wBAwBE"}
|
|
@@ -14,6 +14,7 @@ interface Props {
|
|
|
14
14
|
textAlignLeft?: boolean;
|
|
15
15
|
onValidityChanged?: (validity: boolean) => void;
|
|
16
16
|
preventDefaultInvalidStyle?: boolean;
|
|
17
|
+
minSize?: number;
|
|
17
18
|
}
|
|
18
19
|
declare const InlineInput: React.ForwardRefExoticComponent<Props & React.RefAttributes<HTMLInputElement>>;
|
|
19
20
|
export default InlineInput;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"InlineInput.d.ts","sourceRoot":"","sources":["../../../../src/InlineInput/InlineInput.tsx"],"names":[],"mappings":"AAMA,OAAO,KAAsC,MAAM,OAAO,CAAC;AAI3D,OAAO,qBAAqB,CAAC;AA0B7B,eAAO,MAAM,sCAAsC,wDAEf,IAAI,MAUvC,CAAC;AAEF,UAAU,KAAK;IACX,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,OAAO,CAAC;IACrC,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAClC,gBAAgB,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAC3C,yBAAyB,CAAC,EAAE,MAAM,MAAM,CAAC;IACzC,yBAAyB,CAAC,EAAE,MAAM,MAAM,CAAC;IACzC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,iBAAiB,CAAC,EAAE,CAAC,QAAQ,EAAE,OAAO,KAAK,IAAI,CAAC;IAChD,0BAA0B,CAAC,EAAE,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"InlineInput.d.ts","sourceRoot":"","sources":["../../../../src/InlineInput/InlineInput.tsx"],"names":[],"mappings":"AAMA,OAAO,KAAsC,MAAM,OAAO,CAAC;AAI3D,OAAO,qBAAqB,CAAC;AA0B7B,eAAO,MAAM,sCAAsC,wDAEf,IAAI,MAUvC,CAAC;AAEF,UAAU,KAAK;IACX,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,OAAO,CAAC;IACrC,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAClC,gBAAgB,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAC3C,yBAAyB,CAAC,EAAE,MAAM,MAAM,CAAC;IACzC,yBAAyB,CAAC,EAAE,MAAM,MAAM,CAAC;IACzC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,iBAAiB,CAAC,EAAE,CAAC,QAAQ,EAAE,OAAO,KAAK,IAAI,CAAC;IAChD,0BAA0B,CAAC,EAAE,OAAO,CAAC;IACrC,OAAO,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,QAAA,MAAM,WAAW,gFAgIhB,CAAC;AAEF,eAAe,WAAW,CAAC"}
|
|
@@ -12,7 +12,9 @@ interface NumberInlineInput {
|
|
|
12
12
|
textAlignLeft?: boolean;
|
|
13
13
|
onValidityChanged?: (validity: boolean) => void;
|
|
14
14
|
preventDefaultInvalidStyle?: boolean;
|
|
15
|
+
minSize?: number;
|
|
16
|
+
preAllocateSize?: boolean;
|
|
15
17
|
}
|
|
16
|
-
declare const _default: ({ disabled, value, range, className, title, onChange, onChangeComplete, textAlignLeft, onValidityChanged, preventDefaultInvalidStyle, }: NumberInlineInput) => JSX.Element;
|
|
18
|
+
declare const _default: ({ disabled, value, range, className, title, onChange, onChangeComplete, textAlignLeft, onValidityChanged, preventDefaultInvalidStyle, minSize, preAllocateSize, }: NumberInlineInput) => JSX.Element;
|
|
17
19
|
export default _default;
|
|
18
20
|
//# sourceMappingURL=NumberInlineInput.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NumberInlineInput.d.ts","sourceRoot":"","sources":["../../../../src/InlineInput/NumberInlineInput.tsx"],"names":[],"mappings":";AASA,OAAO,EAIH,aAAa,EAGhB,MAAM,iBAAiB,CAAC;AAGzB,OAAO,4BAA4B,CAAC;AAEpC,UAAU,iBAAiB;IACvB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,aAAa,CAAC;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAClC,gBAAgB,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAC3C,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,iBAAiB,CAAC,EAAE,CAAC,QAAQ,EAAE,OAAO,KAAK,IAAI,CAAC;IAChD,0BAA0B,CAAC,EAAE,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"NumberInlineInput.d.ts","sourceRoot":"","sources":["../../../../src/InlineInput/NumberInlineInput.tsx"],"names":[],"mappings":";AASA,OAAO,EAIH,aAAa,EAGhB,MAAM,iBAAiB,CAAC;AAGzB,OAAO,4BAA4B,CAAC;AAEpC,UAAU,iBAAiB;IACvB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,aAAa,CAAC;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAClC,gBAAgB,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAC3C,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,iBAAiB,CAAC,EAAE,CAAC,QAAQ,EAAE,OAAO,KAAK,IAAI,CAAC;IAChD,0BAA0B,CAAC,EAAE,OAAO,CAAC;IACrC,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,eAAe,CAAC,EAAE,OAAO,CAAC;CAC7B;4LA8EE,iBAAiB;AAbpB,wBAuEE"}
|
|
@@ -6,7 +6,7 @@ interface DropdownUnit<T> {
|
|
|
6
6
|
items: DropdownItem<T>[];
|
|
7
7
|
onUnitChange: (unit: DropdownItem<T>) => void;
|
|
8
8
|
}
|
|
9
|
-
declare const _default: <T>({ range, value, onChange, onChangeComplete, className, disabled, label, title, unit, showSlider, minWidth, }: {
|
|
9
|
+
declare const _default: <T>({ range, value, onChange, onChangeComplete, className, disabled, label, title, unit, showSlider, minWidth, inputMinSize, preAllocateInputSize, }: {
|
|
10
10
|
range: RangeOrValues;
|
|
11
11
|
value: number;
|
|
12
12
|
onChange: (value: number) => void;
|
|
@@ -18,6 +18,8 @@ declare const _default: <T>({ range, value, onChange, onChangeComplete, classNam
|
|
|
18
18
|
showSlider?: boolean | undefined;
|
|
19
19
|
unit?: React.ReactNode | DropdownUnit<T>;
|
|
20
20
|
minWidth?: boolean | undefined;
|
|
21
|
+
inputMinSize?: number | undefined;
|
|
22
|
+
preAllocateInputSize?: boolean | undefined;
|
|
21
23
|
}) => JSX.Element;
|
|
22
24
|
export default _default;
|
|
23
25
|
//# sourceMappingURL=NumberInput.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NumberInput.d.ts","sourceRoot":"","sources":["../../../../src/NumberInput/NumberInput.tsx"],"names":[],"mappings":"AAMA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAiB,EAAE,KAAK,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAEnE,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAsChD,UAAU,YAAY,CAAC,CAAC;IACpB,YAAY,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC;IAC9B,KAAK,EAAE,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC;IACzB,YAAY,EAAE,CAAC,IAAI,EAAE,YAAY,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC;CACjD;;
|
|
1
|
+
{"version":3,"file":"NumberInput.d.ts","sourceRoot":"","sources":["../../../../src/NumberInput/NumberInput.tsx"],"names":[],"mappings":"AAMA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAiB,EAAE,KAAK,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAEnE,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAsChD,UAAU,YAAY,CAAC,CAAC;IACpB,YAAY,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC;IAC9B,KAAK,EAAE,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC;IACzB,YAAY,EAAE,CAAC,IAAI,EAAE,YAAY,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC;CACjD;;WAyBU,aAAa;WACb,MAAM;sBACK,MAAM,KAAK,IAAI;gCACN,MAAM,KAAK,IAAI;;;WAGnC,MAAM,SAAS;;;;;;;;AArB1B,wBA6EE"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Slider.d.ts","sourceRoot":"","sources":["../../../../src/Slider/Slider.tsx"],"names":[],"mappings":"AAMA,OAAc,EAAE,EAAE,EAAa,MAAM,OAAO,CAAC;AAO7C,OAAO,
|
|
1
|
+
{"version":3,"file":"Slider.d.ts","sourceRoot":"","sources":["../../../../src/Slider/Slider.tsx"],"names":[],"mappings":"AAMA,OAAc,EAAE,EAAE,EAAa,MAAM,OAAO,CAAC;AAO7C,OAAO,EAAY,aAAa,EAAqB,MAAM,SAAS,CAAC;AAGrE,OAAO,eAAe,CAAC;AAgBvB,MAAM,WAAW,KAAK;IAClB,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,MAAM,EAAE,SAAS,MAAM,EAAE,CAAC;IAC1B,KAAK,EAAE,aAAa,CAAC;IACrB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,MAAM,KAAK,IAAI,CAAC,EAAE,CAAC;IAClC,gBAAgB,CAAC,EAAE,MAAM,IAAI,CAAC;CACjC;AAED,QAAA,MAAM,MAAM,EAAE,EAAE,CAAC,KAAK,CA2DrB,CAAC;AAEF,eAAe,MAAM,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"percentage.d.ts","sourceRoot":"","sources":["../../../../src/Slider/percentage.ts"],"names":[],"mappings":"AAMA,OAAO,EAA4B,aAAa,EAAE,MAAM,SAAS,CAAC;AAElE,eAAO,MAAM,uBAAuB,eAAgB,MAAM,WAIzD,CAAC;AAEF,eAAO,MAAM,YAAY,UAAW,MAAM,iBAAiB,aAAa,
|
|
1
|
+
{"version":3,"file":"percentage.d.ts","sourceRoot":"","sources":["../../../../src/Slider/percentage.ts"],"names":[],"mappings":"AAMA,OAAO,EAA4B,aAAa,EAAE,MAAM,SAAS,CAAC;AAElE,eAAO,MAAM,uBAAuB,eAAgB,MAAM,WAIzD,CAAC;AAEF,eAAO,MAAM,YAAY,UAAW,MAAM,iBAAiB,aAAa,WAWvE,CAAC;AAEF,eAAO,MAAM,cAAc,cACZ,MAAM,SACV,MAAM,iBACE,aAAa,oBACV,OAAO,WAyC5B,CAAC"}
|
|
@@ -10,5 +10,5 @@ export declare const isValues: (rangeOrValues: RangeOrValues) => rangeOrValues i
|
|
|
10
10
|
export declare const getMin: (rangeOrValues: RangeOrValues) => number;
|
|
11
11
|
export declare const getMax: (rangeOrValues: RangeOrValues) => number;
|
|
12
12
|
export declare const getStep: (range: Range) => number;
|
|
13
|
-
export declare const
|
|
13
|
+
export declare const useValidatedRange: (rangeOrValues: RangeOrValues) => void;
|
|
14
14
|
//# sourceMappingURL=range.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"range.d.ts","sourceRoot":"","sources":["../../../../src/Slider/range.ts"],"names":[],"mappings":"AAUA,MAAM,MAAM,MAAM,GAAG,SAAS,MAAM,EAAE,CAAC;AACvC,MAAM,MAAM,KAAK,GAAG;IAChB,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;IACZ,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,IAAI,CAAC,EAAE,MAAM,CAAC;CACjB,CAAC;AAEF,MAAM,MAAM,aAAa,GAAG,KAAK,GAAG,MAAM,CAAC;AAE3C,eAAO,MAAM,QAAQ,kBACF,aAAa,4BAC0B,CAAC;AAE3D,eAAO,MAAM,MAAM,kBAAmB,aAAa,WACe,CAAC;AAEnE,eAAO,MAAM,MAAM,kBAAmB,aAAa,WAGxB,CAAC;AAE5B,eAAO,MAAM,OAAO,UAAW,KAAK,WAC8B,CAAC;
|
|
1
|
+
{"version":3,"file":"range.d.ts","sourceRoot":"","sources":["../../../../src/Slider/range.ts"],"names":[],"mappings":"AAUA,MAAM,MAAM,MAAM,GAAG,SAAS,MAAM,EAAE,CAAC;AACvC,MAAM,MAAM,KAAK,GAAG;IAChB,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;IACZ,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,IAAI,CAAC,EAAE,MAAM,CAAC;CACjB,CAAC;AAEF,MAAM,MAAM,aAAa,GAAG,KAAK,GAAG,MAAM,CAAC;AAE3C,eAAO,MAAM,QAAQ,kBACF,aAAa,4BAC0B,CAAC;AAE3D,eAAO,MAAM,MAAM,kBAAmB,aAAa,WACe,CAAC;AAEnE,eAAO,MAAM,MAAM,kBAAmB,aAAa,WAGxB,CAAC;AAE5B,eAAO,MAAM,OAAO,UAAW,KAAK,WAC8B,CAAC;AAuCnE,eAAO,MAAM,iBAAiB,kBAAmB,aAAa,SAM7D,CAAC"}
|