@balena/ui-shared-components 12.4.3-build-renovate-virtua-b0089dfef7b3a0021271231ae9081a1192fe5043-1 → 12.4.3-build-remove-unused-icon-0c7a4fdc638b14b9a2ed9f241b4bb710ea768ad6-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.
- package/dist/components/CollapsedList/index.js +4 -3
- package/dist/components/DownloadImageDialog/ImageForm.js +6 -7
- package/dist/components/DownloadImageDialog/OsTypeSelector.js +3 -2
- package/dist/components/DownloadImageDialog/VariantSelector.js +3 -2
- package/dist/components/DownloadImageDialog/index.js +4 -3
- package/dist/components/DropDownButton/index.js +4 -3
- package/dist/components/Form/Widgets/PasswordWidget.js +3 -2
- package/dist/components/RJST/components/Widget/Formats/HashWidget.js +1 -2
- package/package.json +3 -4
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
2
|
import { Avatar, Box, Button, Collapse, Typography } from '@mui/material';
|
|
3
3
|
import { useMemo, useState } from 'react';
|
|
4
|
-
import
|
|
5
|
-
import
|
|
4
|
+
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
|
|
5
|
+
import { faCaretDown } from '@fortawesome/free-solid-svg-icons/faCaretDown';
|
|
6
|
+
import { faCaretUp } from '@fortawesome/free-solid-svg-icons/faCaretUp';
|
|
6
7
|
/**
|
|
7
8
|
* This will collapse a long list and allow to expand it by clicking the "expand" button.
|
|
8
9
|
*/
|
|
@@ -21,5 +22,5 @@ export const CollapsedList = ({ list, collapseItems = 3, }) => {
|
|
|
21
22
|
}
|
|
22
23
|
return (_jsxs(Box, { display: "flex", flexDirection: "column", justifyContent: "center", children: [_jsx(Collapse, { in: showMore, collapsedSize: collapseItems * 33, children: listItems }), list.length > collapseItems && (_jsxs(Button, { onClick: () => {
|
|
23
24
|
setShowMore(!showMore);
|
|
24
|
-
}, children: [showMore ? 'Less' : 'More', showMore ? _jsx(
|
|
25
|
+
}, children: [showMore ? 'Less' : 'More', showMore ? (_jsx(FontAwesomeIcon, { icon: faCaretUp })) : (_jsx(FontAwesomeIcon, { icon: faCaretDown }))] }))] }));
|
|
25
26
|
};
|
|
@@ -1,17 +1,15 @@
|
|
|
1
1
|
import { __rest } from "tslib";
|
|
2
2
|
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
3
3
|
import { Avatar, Box, Checkbox, Chip, Divider, FormControl, FormControlLabel, FormLabel, InputAdornment, Radio, RadioGroup, TextField, Tooltip, Typography, IconButton, Autocomplete, Stack, Accordion, AccordionSummary, AccordionDetails, accordionSummaryClasses, } from '@mui/material';
|
|
4
|
-
import HelpIcon from '@mui/icons-material/Help';
|
|
5
4
|
import { memo, useCallback, useEffect, useMemo, useState } from 'react';
|
|
6
5
|
import { getPreferredVersionOpts, transformVersions } from './version';
|
|
7
6
|
import { OsTypeSelector } from './OsTypeSelector';
|
|
8
7
|
import { VariantSelector } from './VariantSelector';
|
|
9
|
-
import
|
|
8
|
+
import { faFileLines } from '@fortawesome/free-solid-svg-icons/faFileLines';
|
|
10
9
|
import { MUILinkWithTracking } from '../MUILinkWithTracking';
|
|
11
|
-
import { Visibility, VisibilityOff } from '@mui/icons-material';
|
|
12
10
|
import { FALLBACK_LOGO_UNKNOWN_DEVICE } from './utils';
|
|
13
11
|
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
|
|
14
|
-
import { faChevronRight, faTriangleExclamation, } from '@fortawesome/free-solid-svg-icons';
|
|
12
|
+
import { faChevronRight, faEye, faEyeSlash, faQuestionCircle, faTriangleExclamation, } from '@fortawesome/free-solid-svg-icons';
|
|
15
13
|
import { Callout } from '../Callout';
|
|
16
14
|
import { token } from '../../utils/token';
|
|
17
15
|
const POLL_INTERVAL_DOCS = 'https://www.balena.io/docs/reference/supervisor/bandwidth-reduction/#side-effects--warnings';
|
|
@@ -120,7 +118,7 @@ export const ImageForm = memo(function ImageForm({ compatibleDeviceTypes, osVers
|
|
|
120
118
|
}, renderInput: (_a) => {
|
|
121
119
|
var _b;
|
|
122
120
|
var { InputProps } = _a, params = __rest(_a, ["InputProps"]);
|
|
123
|
-
return (_jsx(TextField, Object.assign({}, params, { label: _jsxs(Stack, { direction: "row", alignItems: "center", gap: 1, children: ["Device type", _jsx(Tooltip, { title: "Applications can support any devices that share the same architecture as their default device type.", children: _jsx(
|
|
121
|
+
return (_jsx(TextField, Object.assign({}, params, { label: _jsxs(Stack, { direction: "row", alignItems: "center", gap: 1, children: ["Device type", _jsx(Tooltip, { title: "Applications can support any devices that share the same architecture as their default device type.", children: _jsx(FontAwesomeIcon, { icon: faQuestionCircle, color: "info", fontSize: "1rem" }) })] }), slotProps: {
|
|
124
122
|
input: Object.assign(Object.assign({}, InputProps), { startAdornment: (_jsx(Avatar, { variant: "square", src: (_b = model.deviceType.logo) !== null && _b !== void 0 ? _b : FALLBACK_LOGO_UNKNOWN_DEVICE, sx: { mr: 3, width: '20px', height: '20px' } })) }),
|
|
125
123
|
} })));
|
|
126
124
|
}, onChange: (_event, value) => {
|
|
@@ -167,7 +165,7 @@ export const ImageForm = memo(function ImageForm({ compatibleDeviceTypes, osVers
|
|
|
167
165
|
setShowPassword((show) => !show);
|
|
168
166
|
}, onMouseDown: (event) => {
|
|
169
167
|
event.preventDefault();
|
|
170
|
-
}, edge: "end", children: showPassword ? _jsx(
|
|
168
|
+
}, edge: "end", children: showPassword ? (_jsx(FontAwesomeIcon, { icon: faEyeSlash })) : (_jsx(FontAwesomeIcon, { icon: faEye })) }) })),
|
|
171
169
|
},
|
|
172
170
|
}, onChange: (event) => {
|
|
173
171
|
onChange({ wifiKey: event.target.value });
|
|
@@ -194,7 +192,8 @@ export const ImageForm = memo(function ImageForm({ compatibleDeviceTypes, osVers
|
|
|
194
192
|
display: 'flex',
|
|
195
193
|
alignItems: 'center',
|
|
196
194
|
height: '1.5rem',
|
|
197
|
-
|
|
195
|
+
gap: 1,
|
|
196
|
+
}, children: _jsx(FontAwesomeIcon, { icon: faFileLines, fontSize: "1.15rem" }) })] }) }), _jsx(TextField, { name: "provisioningKeyName", value: (_a = model.provisioningKeyName) !== null && _a !== void 0 ? _a : '', slotProps: {
|
|
198
197
|
htmlInput: {
|
|
199
198
|
name: 'provisioningKeyName',
|
|
200
199
|
autoComplete: 'provisioningKeyName-auto-complete',
|
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
2
|
import { Box, InputLabel, MenuItem, Select, Tooltip, Typography, Stack, } from '@mui/material';
|
|
3
3
|
import { getOsTypeName } from './utils';
|
|
4
|
-
import ArticleIcon from '@mui/icons-material/Article';
|
|
5
4
|
import { MUILinkWithTracking } from '../MUILinkWithTracking';
|
|
6
5
|
import { OsTypesEnum } from './models';
|
|
7
6
|
import { Chip } from '../Chip';
|
|
7
|
+
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
|
|
8
|
+
import { faFileLines } from '@fortawesome/free-solid-svg-icons';
|
|
8
9
|
const OsTypeOption = ({ osType }) => {
|
|
9
10
|
if (!osType) {
|
|
10
11
|
return _jsx(Typography, { variant: "body1", children: "Select OS type..." });
|
|
@@ -30,7 +31,7 @@ export const OsTypeSelector = ({ supportedOsTypes, hasEsrVersions, selectedOsTyp
|
|
|
30
31
|
};
|
|
31
32
|
});
|
|
32
33
|
const selectedOsType = selectOsTypes.find((osType) => osType.slug === selectedOsTypeSlug && osType.supportedForDeviceType);
|
|
33
|
-
return (_jsxs(Stack, { flex: 1, children: [_jsx(Stack, { direction: "row", alignItems: "center", gap: 1, children: _jsxs(InputLabel, { id: "newAppApplicationType-label", sx: { display: 'flex', alignItems: 'center', gap: 1 }, children: ["OS type", _jsx(MUILinkWithTracking, { sx: { height: 12 }, href: "https://www.balena.io/docs/reference/OS/extended-support-release", children: _jsx(
|
|
34
|
+
return (_jsxs(Stack, { flex: 1, children: [_jsx(Stack, { direction: "row", alignItems: "center", gap: 1, children: _jsxs(InputLabel, { id: "newAppApplicationType-label", sx: { display: 'flex', alignItems: 'center', gap: 1 }, children: ["OS type", _jsx(MUILinkWithTracking, { sx: { height: 12 }, href: "https://www.balena.io/docs/reference/OS/extended-support-release", children: _jsx(FontAwesomeIcon, { icon: faFileLines, fontSize: "1rem" }) })] }) }), _jsx(Select, { id: "newAppApplicationType", fullWidth: true, disabled: supportedOsTypes.length === 0, value: (_a = selectedOsType === null || selectedOsType === void 0 ? void 0 : selectedOsType.slug) !== null && _a !== void 0 ? _a : OsTypesEnum.DEFAULT, renderValue: (selected) => (_jsx(Box, { display: "flex", width: "100%", children: _jsx(OsTypeOption, { osType: selectOsTypes.find((osType) => selected === osType.slug) }) })), onChange: (event) => {
|
|
34
35
|
const osType = selectOsTypes.find((os) => os.slug === event.target.value);
|
|
35
36
|
if (!osType.disabled) {
|
|
36
37
|
onSelectedOsTypeChange(osType.slug);
|
|
@@ -2,12 +2,13 @@ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-run
|
|
|
2
2
|
import { FormControl, FormControlLabel, FormLabel, Radio, RadioGroup, Stack, Tooltip, Typography, } from '@mui/material';
|
|
3
3
|
import { MUILinkWithTracking } from '../MUILinkWithTracking';
|
|
4
4
|
import { getOsVariantDisplayText } from './utils';
|
|
5
|
-
import { Lightbulb } from '@mui/icons-material';
|
|
6
5
|
import { token } from '../../utils/token';
|
|
7
6
|
import { Callout } from '../Callout';
|
|
7
|
+
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
|
|
8
|
+
import { faLightbulb } from '@fortawesome/free-solid-svg-icons';
|
|
8
9
|
const variantInfo = (selected) => ({
|
|
9
10
|
dev: {
|
|
10
|
-
title: (_jsxs(Stack, { gap: 1, direction: "row", alignItems: "center", children: [_jsx(Typography, { children: getOsVariantDisplayText('dev') }), _jsxs(Typography, { variant: "bodySm", color: token('color.text.accent'), alignItems: "center", display: "flex", children: [_jsx(
|
|
11
|
+
title: (_jsxs(Stack, { gap: 1, direction: "row", alignItems: "center", children: [_jsx(Typography, { children: getOsVariantDisplayText('dev') }), _jsxs(Typography, { variant: "bodySm", color: token('color.text.accent'), alignItems: "center", display: "flex", children: [_jsx(FontAwesomeIcon, { icon: faLightbulb, width: 14, height: 14 }), "Recommended for first time users"] })] })),
|
|
11
12
|
description: (_jsxs(Stack, { gap: 1, children: [_jsxs(Typography, { children: ["Development images should be used when you are developing an application and want to use the fast", ' ', _jsx(MUILinkWithTracking, { href: "https://balena.io/docs/development/local-mode/", children: "local mode" }), ' ', "workflow."] }), selected === 'dev' && (_jsxs(Callout, { severity: "warning", size: "sm", children: ["This variant should never be used in production for security reasons.", ' ', _jsx(MUILinkWithTracking, { href: "https://docs.balena.io/reference/OS/overview/#development-vs-production-mode", children: "Learn more" }), "."] }))] })),
|
|
12
13
|
},
|
|
13
14
|
prod: {
|
|
@@ -5,7 +5,6 @@ import { FALLBACK_LOGO_UNKNOWN_DEVICE, isUrlAccessible, stripVersionBuild, } fro
|
|
|
5
5
|
import { ImageForm } from './ImageForm';
|
|
6
6
|
import { ApplicationInstructions } from './ApplicationInstructions';
|
|
7
7
|
import { DropDownButton } from '../DropDownButton';
|
|
8
|
-
import DownloadIcon from '@mui/icons-material/Download';
|
|
9
8
|
import pickBy from 'lodash/pickBy';
|
|
10
9
|
import debounce from 'lodash/debounce';
|
|
11
10
|
import isEmpty from 'lodash/isEmpty';
|
|
@@ -15,6 +14,8 @@ import { enqueueSnackbar } from 'notistack';
|
|
|
15
14
|
import { DialogWithCloseButton } from '../DialogWithCloseButton';
|
|
16
15
|
import { Callout } from '../Callout';
|
|
17
16
|
import { Spinner } from '../Spinner';
|
|
17
|
+
import { faDownload } from '@fortawesome/free-solid-svg-icons';
|
|
18
|
+
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
|
|
18
19
|
const etcherLogoBase64 = '';
|
|
19
20
|
const ETCHER_OPEN_IMAGE_URL = 'https://www.balena.io/etcher/open-image-url';
|
|
20
21
|
export var ActionType;
|
|
@@ -150,7 +151,7 @@ export const DownloadImageDialog = ({ open, applicationId, releaseId, compatible
|
|
|
150
151
|
onDownloadStart === null || onDownloadStart === void 0 ? void 0 : onDownloadStart(formModel, ActionType.downloadOs);
|
|
151
152
|
formElement.current.submit();
|
|
152
153
|
}),
|
|
153
|
-
children: (_jsxs(_Fragment, { children: [_jsx(
|
|
154
|
+
children: (_jsxs(_Fragment, { children: [_jsx(FontAwesomeIcon, { icon: faDownload }), " Download balenaOS", ' ', formModel.version && downloadSize ? ` (~${downloadSize})` : ''] })),
|
|
154
155
|
},
|
|
155
156
|
];
|
|
156
157
|
if (downloadConfig) {
|
|
@@ -164,7 +165,7 @@ export const DownloadImageDialog = ({ open, applicationId, releaseId, compatible
|
|
|
164
165
|
onDownloadStart === null || onDownloadStart === void 0 ? void 0 : onDownloadStart(formModel, ActionType.downloadConfigFile);
|
|
165
166
|
await downloadConfig(formModel);
|
|
166
167
|
},
|
|
167
|
-
children: (_jsxs(_Fragment, { children: [_jsx(
|
|
168
|
+
children: (_jsxs(_Fragment, { children: [_jsx(FontAwesomeIcon, { icon: faDownload }), " Download configuration file only"] })),
|
|
168
169
|
});
|
|
169
170
|
}
|
|
170
171
|
return dropDownButtonActions;
|
|
@@ -6,8 +6,9 @@ import { ButtonWithTracking } from '../ButtonWithTracking';
|
|
|
6
6
|
import { useAnalyticsContext } from '../../contexts/AnalyticsContext';
|
|
7
7
|
import groupBy from 'lodash/groupBy';
|
|
8
8
|
import flatMap from 'lodash/flatMap';
|
|
9
|
-
import { KeyboardArrowDown, KeyboardArrowUp, ArrowDropDown, ArrowDropUp, } from '@mui/icons-material';
|
|
10
9
|
import { Tooltip } from '../Tooltip';
|
|
10
|
+
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
|
|
11
|
+
import { faCaretDown, faCaretUp, faChevronDown, faChevronUp, } from '@fortawesome/free-solid-svg-icons';
|
|
11
12
|
/**
|
|
12
13
|
* This component implements a Dropdown button using MUI (This can be removed as soon as MUI implements it. Check
|
|
13
14
|
* progress: https://mui.com/material-ui/discover-more/roadmap/#new-components)
|
|
@@ -49,9 +50,9 @@ export const DropDownButton = (_a) => {
|
|
|
49
50
|
};
|
|
50
51
|
return (_jsxs(_Fragment, { children: [children ? (_jsx(Button, Object.assign({ "aria-controls": anchorEl ? 'dropdown' : undefined, "aria-expanded": anchorEl ? 'true' : undefined, onClick: (event) => {
|
|
51
52
|
setAnchorEl(event.currentTarget);
|
|
52
|
-
}, endIcon: anchorEl ? _jsx(
|
|
53
|
+
}, endIcon: anchorEl ? (_jsx(FontAwesomeIcon, { icon: faChevronUp })) : (_jsx(FontAwesomeIcon, { icon: faChevronDown })) }, buttonProps, { children: children }))) : (_jsxs(ButtonGroup, Object.assign({ variant: "contained", disableElevation: true }, buttonProps, { children: [_jsx(ButtonWithTracking, { onClick: handleClick, eventName: memoizedItems[selectedIndex].eventName, eventProperties: memoizedItems[selectedIndex].eventProperties, tooltip: memoizedItems[selectedIndex].tooltip, children: memoizedItems[selectedIndex].children }), _jsx(Button, { onClick: handleToggle,
|
|
53
54
|
// It doesn't look good without it, hence the addition.
|
|
54
|
-
sx: (theme) => ({ pl: 2, pr: `calc(${theme.spacing(2)} + 2px)` }), children: anchorEl ? _jsx(
|
|
55
|
+
sx: (theme) => ({ pl: 2, pr: `calc(${theme.spacing(2)} + 2px)` }), children: anchorEl ? (_jsx(FontAwesomeIcon, { icon: faCaretUp })) : (_jsx(FontAwesomeIcon, { icon: faCaretDown })) })] }))), _jsx(Menu, { anchorEl: anchorEl, open: !!anchorEl, onClose: () => {
|
|
55
56
|
setAnchorEl(null);
|
|
56
57
|
}, children: memoizedItems.map((item, index) => (_jsx(MenuItemWithTracking, Object.assign({}, item, { onClick: (event) => {
|
|
57
58
|
handleMenuItemClick(event, index);
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
2
|
import { FormControl, IconButton, InputAdornment, TextField, } from '@mui/material';
|
|
3
3
|
import { Suspense, lazy, useState } from 'react';
|
|
4
|
-
import {
|
|
4
|
+
import { faEye, faEyeSlash } from '@fortawesome/free-solid-svg-icons';
|
|
5
|
+
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
|
|
5
6
|
const PasswordStrength = lazy(async () => {
|
|
6
7
|
const importedModule = await import('../PasswordStrength');
|
|
7
8
|
return {
|
|
@@ -27,6 +28,6 @@ export const PasswordWidget = ({ id, label, value, disabled, name, placeholder,
|
|
|
27
28
|
setShowPassword((show) => !show);
|
|
28
29
|
}, onMouseDown: (event) => {
|
|
29
30
|
event.preventDefault();
|
|
30
|
-
}, edge: "end", children: showPassword ? _jsx(
|
|
31
|
+
}, edge: "end", children: showPassword ? (_jsx(FontAwesomeIcon, { icon: faEyeSlash })) : (_jsx(FontAwesomeIcon, { icon: faEye })) }) })),
|
|
31
32
|
} }), options.showPasswordStrengthMeter && (_jsx(Suspense, { fallback: null, children: _jsx(PasswordStrength, { password: value }) }))] }));
|
|
32
33
|
};
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
-
import { Code } from '@mui/icons-material';
|
|
3
2
|
import { Copy } from '../../../../Copy';
|
|
4
3
|
import { JsonTypes, truncateHash, widgetFactory } from '../utils';
|
|
5
4
|
export const HashWidget = widgetFactory('Hash', {}, [JsonTypes.string])(({ value, }) => {
|
|
6
|
-
return
|
|
5
|
+
return _jsx(Copy, { copy: value, children: truncateHash(value) });
|
|
7
6
|
});
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@balena/ui-shared-components",
|
|
3
|
-
"version": "12.4.3-build-
|
|
3
|
+
"version": "12.4.3-build-remove-unused-icon-0c7a4fdc638b14b9a2ed9f241b4bb710ea768ad6-1",
|
|
4
4
|
"main": "./dist/index.js",
|
|
5
5
|
"sideEffects": false,
|
|
6
6
|
"files": [
|
|
@@ -17,7 +17,6 @@
|
|
|
17
17
|
"@emotion/styled": "^11.10.6",
|
|
18
18
|
"@fortawesome/free-solid-svg-icons": "^6.5.1",
|
|
19
19
|
"@fortawesome/react-fontawesome": "^0.2.0",
|
|
20
|
-
"@mui/icons-material": "^6.3.1",
|
|
21
20
|
"@mui/lab": "6.0.0-beta.24",
|
|
22
21
|
"@mui/material": "^6.3.1",
|
|
23
22
|
"@mui/styled-engine-sc": "^6.3.1",
|
|
@@ -51,7 +50,7 @@
|
|
|
51
50
|
"rimraf": "^6.0.0",
|
|
52
51
|
"ts-jest": "^29.2.5",
|
|
53
52
|
"typescript": "^5.8.2",
|
|
54
|
-
"virtua": "^0.
|
|
53
|
+
"virtua": "^0.37.3",
|
|
55
54
|
"zxcvbn": "^4.4.2"
|
|
56
55
|
},
|
|
57
56
|
"devDependencies": {
|
|
@@ -133,7 +132,7 @@
|
|
|
133
132
|
},
|
|
134
133
|
"homepage": "https://github.com/balena-io/ui-shared-components#readme",
|
|
135
134
|
"versionist": {
|
|
136
|
-
"publishedAt": "2025-
|
|
135
|
+
"publishedAt": "2025-06-02T13:20:28.789Z"
|
|
137
136
|
},
|
|
138
137
|
"overrides": {
|
|
139
138
|
"storybook": "$storybook"
|