@seamapi/react 1.60.3 → 1.61.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/README.md +1 -1
- package/dist/elements.js +4112 -4027
- package/dist/elements.js.map +1 -1
- package/dist/index.css +64 -4
- package/dist/index.css.map +1 -1
- package/dist/index.min.css +1 -1
- package/dist/index.min.css.map +1 -1
- package/lib/icons/Search.js +2 -2
- package/lib/icons/Search.js.map +1 -1
- package/lib/seam/components/AccessCodeTable/AccessCodeTable.js +7 -2
- package/lib/seam/components/AccessCodeTable/AccessCodeTable.js.map +1 -1
- package/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleTable.js +4 -5
- package/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleTable.js.map +1 -1
- package/lib/seam/components/DeviceTable/DeviceTable.js +4 -5
- package/lib/seam/components/DeviceTable/DeviceTable.js.map +1 -1
- package/lib/seam/components/SupportedDeviceTable/ShowAllDevicesButton.js +1 -1
- package/lib/seam/components/SupportedDeviceTable/ShowAllDevicesButton.js.map +1 -1
- package/lib/ui/LoadingToast/LoadingToast.d.ts +9 -0
- package/lib/ui/LoadingToast/LoadingToast.js +34 -0
- package/lib/ui/LoadingToast/LoadingToast.js.map +1 -0
- package/lib/version.d.ts +1 -1
- package/lib/version.js +1 -1
- package/package.json +1 -1
- package/src/lib/icons/Search.tsx +7 -7
- package/src/lib/seam/components/AccessCodeTable/AccessCodeTable.tsx +14 -1
- package/src/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleTable.tsx +10 -5
- package/src/lib/seam/components/DeviceTable/DeviceTable.tsx +10 -5
- package/src/lib/seam/components/SupportedDeviceTable/ShowAllDevicesButton.tsx +1 -1
- package/src/lib/ui/LoadingToast/LoadingToast.tsx +62 -0
- package/src/lib/version.ts +1 -1
- package/src/styles/_inputs.scss +13 -1
- package/src/styles/_loading_toast.scss +59 -0
- package/src/styles/_main.scss +2 -0
- package/src/styles/_spinner.scss +1 -1
- package/src/styles/_supported-device-table.scss +2 -2
- package/src/styles/_tables.scss +9 -0
|
@@ -13,6 +13,7 @@ import { NestedCreateAccessCodeForm } from '../../../../lib/seam/components/Crea
|
|
|
13
13
|
import { NestedEditAccessCodeForm } from '../../../../lib/seam/components/EditAccessCodeForm/EditAccessCodeForm.js';
|
|
14
14
|
import { IconButton } from '../../../../lib/ui/IconButton.js';
|
|
15
15
|
import { ContentHeader } from '../../../../lib/ui/layout/ContentHeader.js';
|
|
16
|
+
import { LoadingToast } from '../../../../lib/ui/LoadingToast/LoadingToast.js';
|
|
16
17
|
import { EmptyPlaceholder } from '../../../../lib/ui/Table/EmptyPlaceholder.js';
|
|
17
18
|
import { TableBody } from '../../../../lib/ui/Table/TableBody.js';
|
|
18
19
|
import { TableHeader } from '../../../../lib/ui/Table/TableHeader.js';
|
|
@@ -32,7 +33,7 @@ const defaultAccessCodeFilter = (accessCode, searchInputValue) => {
|
|
|
32
33
|
};
|
|
33
34
|
export function AccessCodeTable({ deviceId, disableSearch = false, onAccessCodeClick = () => { }, preventDefaultOnAccessCodeClick = false, onBack, accessCodeFilter = defaultAccessCodeFilter, accessCodeComparator = compareByCreatedAtDesc, heading = t.accessCodes, title = t.accessCodes, className, disableCreateAccessCode = false, disableEditAccessCode = false, disableLockUnlock = false, disableDeleteAccessCode = false, }) {
|
|
34
35
|
useComponentTelemetry('AccessCodeTable');
|
|
35
|
-
const { accessCodes } = useAccessCodes({
|
|
36
|
+
const { accessCodes, isInitialLoading, isError, error } = useAccessCodes({
|
|
36
37
|
device_id: deviceId,
|
|
37
38
|
});
|
|
38
39
|
const [selectedViewAccessCodeId, setSelectedViewAccessCodeId] = useState(null);
|
|
@@ -70,7 +71,10 @@ export function AccessCodeTable({ deviceId, disableSearch = false, onAccessCodeC
|
|
|
70
71
|
if (addAccessCodeFormVisible) {
|
|
71
72
|
return (_jsx(NestedCreateAccessCodeForm, { deviceId: deviceId, disableLockUnlock: disableLockUnlock, disableCreateAccessCode: disableCreateAccessCode, disableEditAccessCode: disableEditAccessCode, disableDeleteAccessCode: disableDeleteAccessCode, onBack: toggleAddAccessCodeForm, className: className }));
|
|
72
73
|
}
|
|
73
|
-
|
|
74
|
+
if (isError) {
|
|
75
|
+
return _jsx("p", { className: className, children: error?.message });
|
|
76
|
+
}
|
|
77
|
+
return (_jsxs("div", { className: classNames('seam-table', className), children: [_jsx(ContentHeader, { onBack: onBack }), _jsxs(TableHeader, { children: [_jsxs("div", { className: 'seam-left', children: [title != null ? (_jsxs(TableTitle, { children: [heading ?? title ?? t.accessCodes, ' ', _jsxs(Caption, { children: ["(", filteredAccessCodes.length, ")"] })] })) : (_jsx("div", { className: 'seam-fragment' })), !disableCreateAccessCode && (_jsx(IconButton, { onClick: toggleAddAccessCodeForm, className: 'seam-add-button', children: _jsx(AddIcon, {}) }))] }), _jsx("div", { className: 'seam-table-header-loading-wrap', children: _jsx(LoadingToast, { isLoading: isInitialLoading, label: t.loading, top: -20 }) }), !disableSearch && (_jsx(SearchTextField, { value: searchInputValue, onChange: setSearchInputValue, disabled: (accessCodes?.length ?? 0) === 0 }))] }), _jsx(TableBody, { children: _jsx(Content, { accessCodes: filteredAccessCodes, onAccessCodeClick: handleAccessCodeClick, onAccessCodeEdit: handleAccessCodeEdit, disableEditAccessCode: disableEditAccessCode, disableDeleteAccessCode: disableDeleteAccessCode }) })] }));
|
|
74
78
|
}
|
|
75
79
|
function Content(props) {
|
|
76
80
|
const { accessCodes, onAccessCodeClick, onAccessCodeEdit, disableEditAccessCode, disableDeleteAccessCode, } = props;
|
|
@@ -98,5 +102,6 @@ function Content(props) {
|
|
|
98
102
|
const t = {
|
|
99
103
|
accessCodes: 'Access Codes',
|
|
100
104
|
noAccessCodesMessage: 'Sorry, no access codes were found',
|
|
105
|
+
loading: 'Loading access codes',
|
|
101
106
|
};
|
|
102
107
|
//# sourceMappingURL=AccessCodeTable.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AccessCodeTable.js","sourceRoot":"","sources":["../../../../src/lib/seam/components/AccessCodeTable/AccessCodeTable.tsx"],"names":[],"mappings":";AAAA,OAAO,UAAU,MAAM,YAAY,CAAA;AACnC,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAEtD,OAAO,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAA;AAE9D,OAAO,EAAE,sBAAsB,EAAE,MAAM,cAAc,CAAA;AACrD,OAAO,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAA;AAC1C,OAAO,EACL,cAAc,GAEf,MAAM,2CAA2C,CAAA;AAClD,OAAO,EAAE,uBAAuB,EAAE,MAAM,4DAA4D,CAAA;AACpG,OAAO,EAEL,mBAAmB,GACpB,MAAM,4DAA4D,CAAA;AACnE,OAAO,EAAE,aAAa,EAAE,MAAM,sDAAsD,CAAA;AACpF,OAAO,EAEL,uBAAuB,GACxB,MAAM,qCAAqC,CAAA;AAC5C,OAAO,EAAE,0BAA0B,EAAE,MAAM,kEAAkE,CAAA;AAC7G,OAAO,EAAE,wBAAwB,EAAE,MAAM,8DAA8D,CAAA;AACvG,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAA;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAA;AAC9D,OAAO,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAA;AACnE,OAAO,EAAE,SAAS,EAAE,MAAM,2BAA2B,CAAA;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAA;AACzD,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAA;AACvD,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAA;AACrE,OAAO,EAAE,OAAO,EAAE,MAAM,8BAA8B,CAAA;AACtD,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAA;AAEhD,MAAM,CAAC,MAAM,qBAAqB,GAAG,uBAAuB,CAAC,eAAe,CAAC,CAAA;AAwB7E,MAAM,uBAAuB,GAAG,CAC9B,UAAsB,EACtB,gBAAwB,EACf,EAAE;IACX,MAAM,KAAK,GAAG,gBAAgB,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAA;IACnD,IAAI,KAAK,KAAK,EAAE;QAAE,OAAO,IAAI,CAAA;IAC7B,MAAM,IAAI,GAAG,UAAU,CAAC,IAAI,IAAI,EAAE,CAAA;IAClC,MAAM,IAAI,GAAG,UAAU,CAAC,IAAI,IAAI,EAAE,CAAA;IAClC,OAAO,CACL,IAAI,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC;QACzC,IAAI,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,CAC1C,CAAA;AACH,CAAC,CAAA;AAED,MAAM,UAAU,eAAe,CAAC,EAC9B,QAAQ,EACR,aAAa,GAAG,KAAK,EACrB,iBAAiB,GAAG,GAAG,EAAE,GAAE,CAAC,EAC5B,+BAA+B,GAAG,KAAK,EACvC,MAAM,EACN,gBAAgB,GAAG,uBAAuB,EAC1C,oBAAoB,GAAG,sBAAsB,EAC7C,OAAO,GAAG,CAAC,CAAC,WAAW,EACvB,KAAK,GAAG,CAAC,CAAC,WAAW,EACrB,SAAS,EACT,uBAAuB,GAAG,KAAK,EAC/B,qBAAqB,GAAG,KAAK,EAC7B,iBAAiB,GAAG,KAAK,EACzB,uBAAuB,GAAG,KAAK,GACV;IACrB,qBAAqB,CAAC,iBAAiB,CAAC,CAAA;IAExC,MAAM,EAAE,WAAW,EAAE,GAAG,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"AccessCodeTable.js","sourceRoot":"","sources":["../../../../src/lib/seam/components/AccessCodeTable/AccessCodeTable.tsx"],"names":[],"mappings":"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"}
|
|
@@ -8,6 +8,7 @@ import { ClimateSettingScheduleRow } from '../../../../lib/seam/components/Clima
|
|
|
8
8
|
import { withRequiredCommonProps, } from '../../../../lib/seam/components/common-props.js';
|
|
9
9
|
import { useClimateSettingSchedules, } from '../../../../lib/seam/thermostats/climate-setting-schedules/use-climate-setting-schedules.js';
|
|
10
10
|
import { ContentHeader } from '../../../../lib/ui/layout/ContentHeader.js';
|
|
11
|
+
import { LoadingToast } from '../../../../lib/ui/LoadingToast/LoadingToast.js';
|
|
11
12
|
import { EmptyPlaceholder } from '../../../../lib/ui/Table/EmptyPlaceholder.js';
|
|
12
13
|
import { TableBody } from '../../../../lib/ui/Table/TableBody.js';
|
|
13
14
|
import { TableHeader } from '../../../../lib/ui/Table/TableHeader.js';
|
|
@@ -24,7 +25,7 @@ const defaultClimateSettingScheduleFilter = (climateSettingSchedule, searchInput
|
|
|
24
25
|
};
|
|
25
26
|
export function ClimateSettingScheduleTable({ deviceId, disableSearch = false, onClimateSettingScheduleClick = () => { }, preventDefaultOnClimateSettingScheduleClick = false, climateSettingScheduleFilter = defaultClimateSettingScheduleFilter, climateSettingScheduleComparator = compareByCreatedAtDesc, heading = t.climateSettingSchedules, disableLockUnlock = false, disableDeleteAccessCode = false, onBack, className, disableCreateAccessCode, disableEditAccessCode, }) {
|
|
26
27
|
useComponentTelemetry('ClimateSettingScheduleTable');
|
|
27
|
-
const { climateSettingSchedules,
|
|
28
|
+
const { climateSettingSchedules, isInitialLoading, isError, error } = useClimateSettingSchedules({
|
|
28
29
|
device_id: deviceId,
|
|
29
30
|
});
|
|
30
31
|
const [searchInputValue, setSearchInputValue] = useState('');
|
|
@@ -52,13 +53,10 @@ export function ClimateSettingScheduleTable({ deviceId, disableSearch = false, o
|
|
|
52
53
|
setSelectedViewClimateSettingScheduleId(null);
|
|
53
54
|
}, className: className }));
|
|
54
55
|
}
|
|
55
|
-
if (isLoading) {
|
|
56
|
-
return _jsx("p", { className: className, children: "..." });
|
|
57
|
-
}
|
|
58
56
|
if (isError) {
|
|
59
57
|
return _jsx("p", { className: className, children: error?.message });
|
|
60
58
|
}
|
|
61
|
-
return (_jsxs("div", { className: classNames('seam-table', className), children: [_jsx(ContentHeader, { onBack: onBack }), _jsxs(TableHeader, { children: [heading != null ? (_jsxs(TableTitle, { children: [heading ?? t.climateSettingSchedules, ' ', _jsxs(Caption, { children: ["(", filteredClimateSettingSchedules.length, ")"] })] })) : (_jsx("div", { className: 'seam-fragment' })), !disableSearch && (_jsx(SearchTextField, { value: searchInputValue, onChange: setSearchInputValue, disabled: (climateSettingSchedules?.length ?? 0) === 0 }))] }), _jsx(TableBody, { children: _jsx(Content, { climateSettingSchedules: filteredClimateSettingSchedules, onClimateSettingScheduleClick: handleClimateSettingScheduleClick }) })] }));
|
|
59
|
+
return (_jsxs("div", { className: classNames('seam-table', className), children: [_jsx(ContentHeader, { onBack: onBack }), _jsxs(TableHeader, { children: [heading != null ? (_jsxs(TableTitle, { children: [heading ?? t.climateSettingSchedules, ' ', _jsxs(Caption, { children: ["(", filteredClimateSettingSchedules.length, ")"] })] })) : (_jsx("div", { className: 'seam-fragment' })), _jsx("div", { className: 'seam-table-header-loading-wrap', children: _jsx(LoadingToast, { isLoading: isInitialLoading, label: t.loading, top: -20 }) }), !disableSearch && (_jsx(SearchTextField, { value: searchInputValue, onChange: setSearchInputValue, disabled: (climateSettingSchedules?.length ?? 0) === 0 }))] }), _jsx(TableBody, { children: _jsx(Content, { climateSettingSchedules: filteredClimateSettingSchedules, onClimateSettingScheduleClick: handleClimateSettingScheduleClick }) })] }));
|
|
62
60
|
}
|
|
63
61
|
function Content(props) {
|
|
64
62
|
const { climateSettingSchedules, onClimateSettingScheduleClick } = props;
|
|
@@ -72,5 +70,6 @@ function Content(props) {
|
|
|
72
70
|
const t = {
|
|
73
71
|
climateSettingSchedules: 'Climate setting schedules',
|
|
74
72
|
noClimateSettingSchedulesMessage: 'Sorry, no climate setting schedules were found',
|
|
73
|
+
loading: 'Loading schedules',
|
|
75
74
|
};
|
|
76
75
|
//# sourceMappingURL=ClimateSettingScheduleTable.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ClimateSettingScheduleTable.js","sourceRoot":"","sources":["../../../../src/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleTable.tsx"],"names":[],"mappings":";AAAA,OAAO,UAAU,MAAM,YAAY,CAAA;AACnC,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAGtD,OAAO,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAA;AAE9D,OAAO,EAAE,sBAAsB,EAAE,MAAM,cAAc,CAAA;AACrD,OAAO,EAAE,mCAAmC,EAAE,MAAM,oFAAoF,CAAA;AACxI,OAAO,EAAE,yBAAyB,EAAE,MAAM,8EAA8E,CAAA;AACxH,OAAO,EAEL,uBAAuB,GACxB,MAAM,qCAAqC,CAAA;AAC5C,OAAO,EACL,0BAA0B,GAE3B,MAAM,iFAAiF,CAAA;AACxF,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAA;AAC9D,OAAO,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAA;AACnE,OAAO,EAAE,SAAS,EAAE,MAAM,2BAA2B,CAAA;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAA;AACzD,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAA;AACvD,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAA;AACrE,OAAO,EAAE,OAAO,EAAE,MAAM,8BAA8B,CAAA;AAEtD,MAAM,CAAC,MAAM,iCAAiC,GAAG,uBAAuB,CACtE,2BAA2B,CAC5B,CAAA;AAkBD,MAAM,mCAAmC,GAAG,CAC1C,sBAA8C,EAC9C,gBAAwB,EACf,EAAE;IACX,MAAM,KAAK,GAAG,gBAAgB,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAA;IACnD,IAAI,KAAK,KAAK,EAAE;QAAE,OAAO,IAAI,CAAA;IAC7B,MAAM,IAAI,GAAG,sBAAsB,CAAC,IAAI,IAAI,EAAE,CAAA;IAC9C,OAAO,IAAI,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;AAClD,CAAC,CAAA;AAED,MAAM,UAAU,2BAA2B,CAAC,EAC1C,QAAQ,EACR,aAAa,GAAG,KAAK,EACrB,6BAA6B,GAAG,GAAG,EAAE,GAAE,CAAC,EACxC,2CAA2C,GAAG,KAAK,EACnD,4BAA4B,GAAG,mCAAmC,EAClE,gCAAgC,GAAG,sBAAsB,EACzD,OAAO,GAAG,CAAC,CAAC,uBAAuB,EACnC,iBAAiB,GAAG,KAAK,EACzB,uBAAuB,GAAG,KAAK,EAC/B,MAAM,EACN,SAAS,EACT,uBAAuB,EACvB,qBAAqB,GACY;IACjC,qBAAqB,CAAC,6BAA6B,CAAC,CAAA;IAEpD,MAAM,EAAE,uBAAuB,EAAE,
|
|
1
|
+
{"version":3,"file":"ClimateSettingScheduleTable.js","sourceRoot":"","sources":["../../../../src/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleTable.tsx"],"names":[],"mappings":"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"}
|
|
@@ -10,6 +10,7 @@ import { DeviceHealthBar, } from '../../../../lib/seam/components/DeviceTable/De
|
|
|
10
10
|
import { DeviceRow } from '../../../../lib/seam/components/DeviceTable/DeviceRow.js';
|
|
11
11
|
import { useDevices, } from '../../../../lib/seam/devices/use-devices.js';
|
|
12
12
|
import { ContentHeader } from '../../../../lib/ui/layout/ContentHeader.js';
|
|
13
|
+
import { LoadingToast } from '../../../../lib/ui/LoadingToast/LoadingToast.js';
|
|
13
14
|
import { EmptyPlaceholder } from '../../../../lib/ui/Table/EmptyPlaceholder.js';
|
|
14
15
|
import { TableBody } from '../../../../lib/ui/Table/TableBody.js';
|
|
15
16
|
import { TableHeader } from '../../../../lib/ui/Table/TableHeader.js';
|
|
@@ -25,7 +26,7 @@ export const defaultDeviceFilter = (device, searchInputValue) => {
|
|
|
25
26
|
export const NestedDeviceTable = withRequiredCommonProps(DeviceTable);
|
|
26
27
|
export function DeviceTable({ deviceIds, connectedAccountIds, disableSearch = false, onDeviceClick = () => { }, preventDefaultOnDeviceClick = false, deviceFilter = defaultDeviceFilter, deviceComparator = compareByCreatedAtDesc, heading = t.devices, title = t.devices, disableLockUnlock = false, disableCreateAccessCode = false, disableEditAccessCode = false, disableDeleteAccessCode = false, onBack, className, } = {}) {
|
|
27
28
|
useComponentTelemetry('DeviceTable');
|
|
28
|
-
const { devices,
|
|
29
|
+
const { devices, isInitialLoading, isError, error } = useDevices({
|
|
29
30
|
device_ids: deviceIds,
|
|
30
31
|
connected_account_ids: connectedAccountIds,
|
|
31
32
|
});
|
|
@@ -46,13 +47,10 @@ export function DeviceTable({ deviceIds, connectedAccountIds, disableSearch = fa
|
|
|
46
47
|
setSelectedDeviceId(null);
|
|
47
48
|
}, className: className }));
|
|
48
49
|
}
|
|
49
|
-
if (isLoading) {
|
|
50
|
-
return _jsx("p", { className: className, children: "..." });
|
|
51
|
-
}
|
|
52
50
|
if (isError) {
|
|
53
51
|
return _jsx("p", { className: className, children: error?.message });
|
|
54
52
|
}
|
|
55
|
-
return (_jsxs("div", { className: classNames('seam-device-table', className), children: [_jsx(ContentHeader, { onBack: onBack }), _jsxs(TableHeader, { children: [title != null ? (_jsxs(TableTitle, { children: [heading ?? title ?? t.devices, ' ', _jsxs(Caption, { children: ["(", filteredDevices.length, ")"] })] })) : (_jsx("div", { className: 'seam-fragment' })), !disableSearch && (_jsx(SearchTextField, { value: searchInputValue, onChange: setSearchInputValue, disabled: (devices?.length ?? 0) === 0 }))] }), _jsx(TableBody, { children: _jsx(Content, { devices: filteredDevices, onDeviceClick: handleDeviceClick }) })] }));
|
|
53
|
+
return (_jsxs("div", { className: classNames('seam-device-table', className), children: [_jsx(ContentHeader, { onBack: onBack }), _jsxs(TableHeader, { children: [title != null ? (_jsxs(TableTitle, { children: [heading ?? title ?? t.devices, ' ', _jsxs(Caption, { children: ["(", filteredDevices.length, ")"] })] })) : (_jsx("div", { className: 'seam-fragment' })), _jsx("div", { className: 'seam-table-header-loading-wrap', children: _jsx(LoadingToast, { isLoading: isInitialLoading, label: t.loading, top: -20 }) }), !disableSearch && (_jsx(SearchTextField, { value: searchInputValue, onChange: setSearchInputValue, disabled: (devices?.length ?? 0) === 0 }))] }), _jsx(TableBody, { children: _jsx(Content, { devices: filteredDevices, onDeviceClick: handleDeviceClick }) })] }));
|
|
56
54
|
}
|
|
57
55
|
function Content(props) {
|
|
58
56
|
const { devices, onDeviceClick } = props;
|
|
@@ -80,5 +78,6 @@ function Content(props) {
|
|
|
80
78
|
const t = {
|
|
81
79
|
devices: 'Devices',
|
|
82
80
|
noDevicesMessage: 'Sorry, no devices were found',
|
|
81
|
+
loading: 'Loading devices',
|
|
83
82
|
};
|
|
84
83
|
//# sourceMappingURL=DeviceTable.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DeviceTable.js","sourceRoot":"","sources":["../../../../src/lib/seam/components/DeviceTable/DeviceTable.tsx"],"names":[],"mappings":";AAAA,OAAO,UAAU,MAAM,YAAY,CAAA;AACnC,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AACtD,OAAO,EAAqB,YAAY,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAA;AAE7E,OAAO,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAA;AAE9D,OAAO,EAAE,sBAAsB,EAAE,MAAM,cAAc,CAAA;AACrD,OAAO,EAEL,uBAAuB,GACxB,MAAM,qCAAqC,CAAA;AAC5C,OAAO,EAAE,mBAAmB,EAAE,MAAM,oDAAoD,CAAA;AACxF,OAAO,EAGL,eAAe,GAChB,MAAM,oDAAoD,CAAA;AAC3D,OAAO,EAAE,SAAS,EAAE,MAAM,8CAA8C,CAAA;AACxE,OAAO,EACL,UAAU,GAEX,MAAM,iCAAiC,CAAA;AACxC,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAA;AAC9D,OAAO,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAA;AACnE,OAAO,EAAE,SAAS,EAAE,MAAM,2BAA2B,CAAA;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAA;AACzD,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAA;AACvD,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAA;AACrE,OAAO,EAAE,OAAO,EAAE,MAAM,8BAA8B,CAAA;AAmBtD,MAAM,CAAC,MAAM,mBAAmB,GAAG,CACjC,MAAoB,EACpB,gBAAwB,EACf,EAAE;IACX,MAAM,KAAK,GAAG,gBAAgB,CAAC,IAAI,EAAE,CAAA;IACrC,IAAI,KAAK,KAAK,EAAE;QAAE,OAAO,IAAI,CAAA;IAC7B,OAAO,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;AAC7D,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,iBAAiB,GAAG,uBAAuB,CAAC,WAAW,CAAC,CAAA;AAErE,MAAM,UAAU,WAAW,CAAC,EAC1B,SAAS,EACT,mBAAmB,EACnB,aAAa,GAAG,KAAK,EACrB,aAAa,GAAG,GAAG,EAAE,GAAE,CAAC,EACxB,2BAA2B,GAAG,KAAK,EACnC,YAAY,GAAG,mBAAmB,EAClC,gBAAgB,GAAG,sBAAsB,EACzC,OAAO,GAAG,CAAC,CAAC,OAAO,EACnB,KAAK,GAAG,CAAC,CAAC,OAAO,EACjB,iBAAiB,GAAG,KAAK,EACzB,uBAAuB,GAAG,KAAK,EAC/B,qBAAqB,GAAG,KAAK,EAC7B,uBAAuB,GAAG,KAAK,EAC/B,MAAM,EACN,SAAS,MACW,EAAE;IACtB,qBAAqB,CAAC,aAAa,CAAC,CAAA;IAEpC,MAAM,EAAE,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"DeviceTable.js","sourceRoot":"","sources":["../../../../src/lib/seam/components/DeviceTable/DeviceTable.tsx"],"names":[],"mappings":"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"}
|
|
@@ -9,6 +9,6 @@ export function ShowAllDevicesButton({ onClick, visible, expanded, totalDeviceCo
|
|
|
9
9
|
}
|
|
10
10
|
const t = {
|
|
11
11
|
showLess: 'Show less',
|
|
12
|
-
showAll: (count) => `See all ${count}
|
|
12
|
+
showAll: (count) => `See all ${count}`,
|
|
13
13
|
};
|
|
14
14
|
//# sourceMappingURL=ShowAllDevicesButton.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ShowAllDevicesButton.js","sourceRoot":"","sources":["../../../../src/lib/seam/components/SupportedDeviceTable/ShowAllDevicesButton.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAA;AAS5D,MAAM,UAAU,oBAAoB,CAAC,EACnC,OAAO,EACP,OAAO,EACP,QAAQ,EACR,gBAAgB,GACU;IAC1B,IAAI,CAAC,OAAO,EAAE;QACZ,OAAO,IAAI,CAAA;KACZ;IAED,MAAM,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAA;IAEjE,OAAO,CACL,kBAAQ,SAAS,EAAC,yBAAyB,EAAC,OAAO,EAAE,OAAO,aAC1D,KAAC,gBAAgB,KAAG,OAAE,KAAK,IACpB,CACV,CAAA;AACH,CAAC;AAED,MAAM,CAAC,GAAG;IACR,QAAQ,EAAE,WAAW;IACrB,OAAO,EAAE,CAAC,KAAa,EAAE,EAAE,CAAC,WAAW,KAAK,
|
|
1
|
+
{"version":3,"file":"ShowAllDevicesButton.js","sourceRoot":"","sources":["../../../../src/lib/seam/components/SupportedDeviceTable/ShowAllDevicesButton.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAA;AAS5D,MAAM,UAAU,oBAAoB,CAAC,EACnC,OAAO,EACP,OAAO,EACP,QAAQ,EACR,gBAAgB,GACU;IAC1B,IAAI,CAAC,OAAO,EAAE;QACZ,OAAO,IAAI,CAAA;KACZ;IAED,MAAM,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAA;IAEjE,OAAO,CACL,kBAAQ,SAAS,EAAC,yBAAyB,EAAC,OAAO,EAAE,OAAO,aAC1D,KAAC,gBAAgB,KAAG,OAAE,KAAK,IACpB,CACV,CAAA;AACH,CAAC;AAED,MAAM,CAAC,GAAG;IACR,QAAQ,EAAE,WAAW;IACrB,OAAO,EAAE,CAAC,KAAa,EAAE,EAAE,CAAC,WAAW,KAAK,EAAE;CAC/C,CAAA"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/// <reference types="react" resolution-mode="require"/>
|
|
2
|
+
interface LoadingToastProps {
|
|
3
|
+
isLoading: boolean;
|
|
4
|
+
label: string;
|
|
5
|
+
top?: string | number;
|
|
6
|
+
left?: string | number;
|
|
7
|
+
}
|
|
8
|
+
export declare function LoadingToast({ isLoading, label, top, left, }: LoadingToastProps): JSX.Element;
|
|
9
|
+
export {};
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { Fragment as _Fragment, jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import classNames from 'classnames';
|
|
3
|
+
import { useEffect, useState } from 'react';
|
|
4
|
+
import { CheckBlackIcon } from '../../../lib/icons/CheckBlack.js';
|
|
5
|
+
import { Spinner } from '../../../lib/ui/Spinner/Spinner.js';
|
|
6
|
+
export function LoadingToast({ isLoading = true, label, top, left, }) {
|
|
7
|
+
const [hidden, setHidden] = useState(false);
|
|
8
|
+
const [showToast, setShowToast] = useState(isLoading);
|
|
9
|
+
useEffect(() => {
|
|
10
|
+
if (!isLoading) {
|
|
11
|
+
const hideTimeout = globalThis.setTimeout(() => {
|
|
12
|
+
setHidden(true);
|
|
13
|
+
}, 1000);
|
|
14
|
+
const removeTimeout = globalThis.setTimeout(() => {
|
|
15
|
+
setShowToast(false);
|
|
16
|
+
}, 1500);
|
|
17
|
+
return () => {
|
|
18
|
+
globalThis.clearTimeout(hideTimeout);
|
|
19
|
+
globalThis.clearTimeout(removeTimeout);
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
setHidden(false);
|
|
23
|
+
setShowToast(true);
|
|
24
|
+
return () => {
|
|
25
|
+
// noop
|
|
26
|
+
};
|
|
27
|
+
}, [isLoading]);
|
|
28
|
+
if (!showToast)
|
|
29
|
+
return _jsx(_Fragment, {});
|
|
30
|
+
return (_jsxs("div", { className: classNames('seam-loading-toast', {
|
|
31
|
+
'seam-loading-toast-hide': hidden,
|
|
32
|
+
}), style: { top, left }, children: [_jsx("div", { className: 'seam-loading-toast-icon-wrap', children: isLoading ? _jsx(Spinner, { size: 'small' }) : _jsx(CheckBlackIcon, {}) }), _jsx("p", { className: 'seam-loading-toast-text', children: label })] }));
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=LoadingToast.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LoadingToast.js","sourceRoot":"","sources":["../../../src/lib/ui/LoadingToast/LoadingToast.tsx"],"names":[],"mappings":";AAAA,OAAO,UAAU,MAAM,YAAY,CAAA;AACnC,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAE3C,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAA;AACxD,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAA;AASnD,MAAM,UAAU,YAAY,CAAC,EAC3B,SAAS,GAAG,IAAI,EAChB,KAAK,EACL,GAAG,EACH,IAAI,GACc;IAClB,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IAC3C,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAC,SAAS,CAAC,CAAA;IAErD,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,SAAS,EAAE;YACd,MAAM,WAAW,GAAG,UAAU,CAAC,UAAU,CAAC,GAAG,EAAE;gBAC7C,SAAS,CAAC,IAAI,CAAC,CAAA;YACjB,CAAC,EAAE,IAAI,CAAC,CAAA;YAER,MAAM,aAAa,GAAG,UAAU,CAAC,UAAU,CAAC,GAAG,EAAE;gBAC/C,YAAY,CAAC,KAAK,CAAC,CAAA;YACrB,CAAC,EAAE,IAAI,CAAC,CAAA;YAER,OAAO,GAAG,EAAE;gBACV,UAAU,CAAC,YAAY,CAAC,WAAW,CAAC,CAAA;gBACpC,UAAU,CAAC,YAAY,CAAC,aAAa,CAAC,CAAA;YACxC,CAAC,CAAA;SACF;QAED,SAAS,CAAC,KAAK,CAAC,CAAA;QAChB,YAAY,CAAC,IAAI,CAAC,CAAA;QAElB,OAAO,GAAG,EAAE;YACV,OAAO;QACT,CAAC,CAAA;IACH,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAA;IAEf,IAAI,CAAC,SAAS;QAAE,OAAO,mBAAK,CAAA;IAE5B,OAAO,CACL,eACE,SAAS,EAAE,UAAU,CAAC,oBAAoB,EAAE;YAC1C,yBAAyB,EAAE,MAAM;SAClC,CAAC,EACF,KAAK,EAAE,EAAE,GAAG,EAAE,IAAI,EAAE,aAEpB,cAAK,SAAS,EAAC,8BAA8B,YAC1C,SAAS,CAAC,CAAC,CAAC,KAAC,OAAO,IAAC,IAAI,EAAC,OAAO,GAAG,CAAC,CAAC,CAAC,KAAC,cAAc,KAAG,GACtD,EACN,YAAG,SAAS,EAAC,yBAAyB,YAAE,KAAK,GAAK,IAC9C,CACP,CAAA;AACH,CAAC"}
|
package/lib/version.d.ts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
declare const seamapiReactVersion = "1.
|
|
1
|
+
declare const seamapiReactVersion = "1.61.0";
|
|
2
2
|
export default seamapiReactVersion;
|
package/lib/version.js
CHANGED
package/package.json
CHANGED
package/src/lib/icons/Search.tsx
CHANGED
|
@@ -7,15 +7,15 @@ export function SearchIcon(props: SVGProps<SVGSVGElement>): JSX.Element {
|
|
|
7
7
|
return (
|
|
8
8
|
<svg
|
|
9
9
|
xmlns='http://www.w3.org/2000/svg'
|
|
10
|
-
width={
|
|
11
|
-
height={
|
|
10
|
+
width={24}
|
|
11
|
+
height={25}
|
|
12
12
|
fill='none'
|
|
13
13
|
{...props}
|
|
14
14
|
>
|
|
15
15
|
<mask
|
|
16
16
|
id='search_svg__a'
|
|
17
|
-
width={
|
|
18
|
-
height={
|
|
17
|
+
width={24}
|
|
18
|
+
height={25}
|
|
19
19
|
x={0}
|
|
20
20
|
y={0}
|
|
21
21
|
maskUnits='userSpaceOnUse'
|
|
@@ -23,12 +23,12 @@ export function SearchIcon(props: SVGProps<SVGSVGElement>): JSX.Element {
|
|
|
23
23
|
maskType: 'alpha',
|
|
24
24
|
}}
|
|
25
25
|
>
|
|
26
|
-
<path fill='#D9D9D9' d='M0
|
|
26
|
+
<path fill='#D9D9D9' d='M0 .988h24v24H0z' />
|
|
27
27
|
</mask>
|
|
28
28
|
<g mask='url(#search_svg__a)'>
|
|
29
29
|
<path
|
|
30
|
-
fill='#
|
|
31
|
-
d='
|
|
30
|
+
fill='#232B3A'
|
|
31
|
+
d='m19.6 21.988-6.3-6.3a6.096 6.096 0 0 1-3.8 1.3c-1.817 0-3.354-.629-4.612-1.887C3.629 13.843 3 12.305 3 10.488c0-1.816.63-3.354 1.888-4.613C6.146 4.617 7.683 3.988 9.5 3.988c1.817 0 3.354.63 4.613 1.887C15.371 7.134 16 8.672 16 10.488a6.096 6.096 0 0 1-1.3 3.8l6.3 6.3-1.4 1.4Zm-10.1-7c1.25 0 2.313-.437 3.188-1.312S14 11.738 14 10.488c0-1.25-.437-2.312-1.312-3.188-.875-.874-1.938-1.312-3.188-1.312-1.25 0-2.313.438-3.188 1.312C5.437 8.176 5 9.238 5 10.488c0 1.25.437 2.313 1.312 3.188S8.25 14.988 9.5 14.988Z'
|
|
32
32
|
/>
|
|
33
33
|
</g>
|
|
34
34
|
</svg>
|
|
@@ -23,6 +23,7 @@ import { NestedCreateAccessCodeForm } from 'lib/seam/components/CreateAccessCode
|
|
|
23
23
|
import { NestedEditAccessCodeForm } from 'lib/seam/components/EditAccessCodeForm/EditAccessCodeForm.js'
|
|
24
24
|
import { IconButton } from 'lib/ui/IconButton.js'
|
|
25
25
|
import { ContentHeader } from 'lib/ui/layout/ContentHeader.js'
|
|
26
|
+
import { LoadingToast } from 'lib/ui/LoadingToast/LoadingToast.js'
|
|
26
27
|
import { EmptyPlaceholder } from 'lib/ui/Table/EmptyPlaceholder.js'
|
|
27
28
|
import { TableBody } from 'lib/ui/Table/TableBody.js'
|
|
28
29
|
import { TableHeader } from 'lib/ui/Table/TableHeader.js'
|
|
@@ -87,7 +88,7 @@ export function AccessCodeTable({
|
|
|
87
88
|
}: AccessCodeTableProps): JSX.Element {
|
|
88
89
|
useComponentTelemetry('AccessCodeTable')
|
|
89
90
|
|
|
90
|
-
const { accessCodes } = useAccessCodes({
|
|
91
|
+
const { accessCodes, isInitialLoading, isError, error } = useAccessCodes({
|
|
91
92
|
device_id: deviceId,
|
|
92
93
|
})
|
|
93
94
|
|
|
@@ -178,6 +179,10 @@ export function AccessCodeTable({
|
|
|
178
179
|
)
|
|
179
180
|
}
|
|
180
181
|
|
|
182
|
+
if (isError) {
|
|
183
|
+
return <p className={className}>{error?.message}</p>
|
|
184
|
+
}
|
|
185
|
+
|
|
181
186
|
return (
|
|
182
187
|
<div className={classNames('seam-table', className)}>
|
|
183
188
|
<ContentHeader onBack={onBack} />
|
|
@@ -200,6 +205,13 @@ export function AccessCodeTable({
|
|
|
200
205
|
</IconButton>
|
|
201
206
|
)}
|
|
202
207
|
</div>
|
|
208
|
+
<div className='seam-table-header-loading-wrap'>
|
|
209
|
+
<LoadingToast
|
|
210
|
+
isLoading={isInitialLoading}
|
|
211
|
+
label={t.loading}
|
|
212
|
+
top={-20}
|
|
213
|
+
/>
|
|
214
|
+
</div>
|
|
203
215
|
{!disableSearch && (
|
|
204
216
|
<SearchTextField
|
|
205
217
|
value={searchInputValue}
|
|
@@ -283,4 +295,5 @@ function Content(props: {
|
|
|
283
295
|
const t = {
|
|
284
296
|
accessCodes: 'Access Codes',
|
|
285
297
|
noAccessCodesMessage: 'Sorry, no access codes were found',
|
|
298
|
+
loading: 'Loading access codes',
|
|
286
299
|
}
|
|
@@ -16,6 +16,7 @@ import {
|
|
|
16
16
|
type UseClimateSettingSchedulesData,
|
|
17
17
|
} from 'lib/seam/thermostats/climate-setting-schedules/use-climate-setting-schedules.js'
|
|
18
18
|
import { ContentHeader } from 'lib/ui/layout/ContentHeader.js'
|
|
19
|
+
import { LoadingToast } from 'lib/ui/LoadingToast/LoadingToast.js'
|
|
19
20
|
import { EmptyPlaceholder } from 'lib/ui/Table/EmptyPlaceholder.js'
|
|
20
21
|
import { TableBody } from 'lib/ui/Table/TableBody.js'
|
|
21
22
|
import { TableHeader } from 'lib/ui/Table/TableHeader.js'
|
|
@@ -70,7 +71,7 @@ export function ClimateSettingScheduleTable({
|
|
|
70
71
|
}: ClimateSettingScheduleTableProps): JSX.Element {
|
|
71
72
|
useComponentTelemetry('ClimateSettingScheduleTable')
|
|
72
73
|
|
|
73
|
-
const { climateSettingSchedules,
|
|
74
|
+
const { climateSettingSchedules, isInitialLoading, isError, error } =
|
|
74
75
|
useClimateSettingSchedules({
|
|
75
76
|
device_id: deviceId,
|
|
76
77
|
})
|
|
@@ -125,10 +126,6 @@ export function ClimateSettingScheduleTable({
|
|
|
125
126
|
)
|
|
126
127
|
}
|
|
127
128
|
|
|
128
|
-
if (isLoading) {
|
|
129
|
-
return <p className={className}>...</p>
|
|
130
|
-
}
|
|
131
|
-
|
|
132
129
|
if (isError) {
|
|
133
130
|
return <p className={className}>{error?.message}</p>
|
|
134
131
|
}
|
|
@@ -145,6 +142,13 @@ export function ClimateSettingScheduleTable({
|
|
|
145
142
|
) : (
|
|
146
143
|
<div className='seam-fragment' />
|
|
147
144
|
)}
|
|
145
|
+
<div className='seam-table-header-loading-wrap'>
|
|
146
|
+
<LoadingToast
|
|
147
|
+
isLoading={isInitialLoading}
|
|
148
|
+
label={t.loading}
|
|
149
|
+
top={-20}
|
|
150
|
+
/>
|
|
151
|
+
</div>
|
|
148
152
|
{!disableSearch && (
|
|
149
153
|
<SearchTextField
|
|
150
154
|
value={searchInputValue}
|
|
@@ -194,4 +198,5 @@ const t = {
|
|
|
194
198
|
climateSettingSchedules: 'Climate setting schedules',
|
|
195
199
|
noClimateSettingSchedulesMessage:
|
|
196
200
|
'Sorry, no climate setting schedules were found',
|
|
201
|
+
loading: 'Loading schedules',
|
|
197
202
|
}
|
|
@@ -21,6 +21,7 @@ import {
|
|
|
21
21
|
type UseDevicesData,
|
|
22
22
|
} from 'lib/seam/devices/use-devices.js'
|
|
23
23
|
import { ContentHeader } from 'lib/ui/layout/ContentHeader.js'
|
|
24
|
+
import { LoadingToast } from 'lib/ui/LoadingToast/LoadingToast.js'
|
|
24
25
|
import { EmptyPlaceholder } from 'lib/ui/Table/EmptyPlaceholder.js'
|
|
25
26
|
import { TableBody } from 'lib/ui/Table/TableBody.js'
|
|
26
27
|
import { TableHeader } from 'lib/ui/Table/TableHeader.js'
|
|
@@ -75,7 +76,7 @@ export function DeviceTable({
|
|
|
75
76
|
}: DeviceTableProps = {}): JSX.Element {
|
|
76
77
|
useComponentTelemetry('DeviceTable')
|
|
77
78
|
|
|
78
|
-
const { devices,
|
|
79
|
+
const { devices, isInitialLoading, isError, error } = useDevices({
|
|
79
80
|
device_ids: deviceIds,
|
|
80
81
|
connected_account_ids: connectedAccountIds,
|
|
81
82
|
})
|
|
@@ -117,10 +118,6 @@ export function DeviceTable({
|
|
|
117
118
|
)
|
|
118
119
|
}
|
|
119
120
|
|
|
120
|
-
if (isLoading) {
|
|
121
|
-
return <p className={className}>...</p>
|
|
122
|
-
}
|
|
123
|
-
|
|
124
121
|
if (isError) {
|
|
125
122
|
return <p className={className}>{error?.message}</p>
|
|
126
123
|
}
|
|
@@ -137,6 +134,13 @@ export function DeviceTable({
|
|
|
137
134
|
) : (
|
|
138
135
|
<div className='seam-fragment' />
|
|
139
136
|
)}
|
|
137
|
+
<div className='seam-table-header-loading-wrap'>
|
|
138
|
+
<LoadingToast
|
|
139
|
+
isLoading={isInitialLoading}
|
|
140
|
+
label={t.loading}
|
|
141
|
+
top={-20}
|
|
142
|
+
/>
|
|
143
|
+
</div>
|
|
140
144
|
{!disableSearch && (
|
|
141
145
|
<SearchTextField
|
|
142
146
|
value={searchInputValue}
|
|
@@ -209,4 +213,5 @@ function Content(props: {
|
|
|
209
213
|
const t = {
|
|
210
214
|
devices: 'Devices',
|
|
211
215
|
noDevicesMessage: 'Sorry, no devices were found',
|
|
216
|
+
loading: 'Loading devices',
|
|
212
217
|
}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import classNames from 'classnames'
|
|
2
|
+
import { useEffect, useState } from 'react'
|
|
3
|
+
|
|
4
|
+
import { CheckBlackIcon } from 'lib/icons/CheckBlack.js'
|
|
5
|
+
import { Spinner } from 'lib/ui/Spinner/Spinner.js'
|
|
6
|
+
|
|
7
|
+
interface LoadingToastProps {
|
|
8
|
+
isLoading: boolean
|
|
9
|
+
label: string
|
|
10
|
+
top?: string | number
|
|
11
|
+
left?: string | number
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export function LoadingToast({
|
|
15
|
+
isLoading = true,
|
|
16
|
+
label,
|
|
17
|
+
top,
|
|
18
|
+
left,
|
|
19
|
+
}: LoadingToastProps): JSX.Element {
|
|
20
|
+
const [hidden, setHidden] = useState(false)
|
|
21
|
+
const [showToast, setShowToast] = useState(isLoading)
|
|
22
|
+
|
|
23
|
+
useEffect(() => {
|
|
24
|
+
if (!isLoading) {
|
|
25
|
+
const hideTimeout = globalThis.setTimeout(() => {
|
|
26
|
+
setHidden(true)
|
|
27
|
+
}, 1000)
|
|
28
|
+
|
|
29
|
+
const removeTimeout = globalThis.setTimeout(() => {
|
|
30
|
+
setShowToast(false)
|
|
31
|
+
}, 1500)
|
|
32
|
+
|
|
33
|
+
return () => {
|
|
34
|
+
globalThis.clearTimeout(hideTimeout)
|
|
35
|
+
globalThis.clearTimeout(removeTimeout)
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
setHidden(false)
|
|
40
|
+
setShowToast(true)
|
|
41
|
+
|
|
42
|
+
return () => {
|
|
43
|
+
// noop
|
|
44
|
+
}
|
|
45
|
+
}, [isLoading])
|
|
46
|
+
|
|
47
|
+
if (!showToast) return <></>
|
|
48
|
+
|
|
49
|
+
return (
|
|
50
|
+
<div
|
|
51
|
+
className={classNames('seam-loading-toast', {
|
|
52
|
+
'seam-loading-toast-hide': hidden,
|
|
53
|
+
})}
|
|
54
|
+
style={{ top, left }}
|
|
55
|
+
>
|
|
56
|
+
<div className='seam-loading-toast-icon-wrap'>
|
|
57
|
+
{isLoading ? <Spinner size='small' /> : <CheckBlackIcon />}
|
|
58
|
+
</div>
|
|
59
|
+
<p className='seam-loading-toast-text'>{label}</p>
|
|
60
|
+
</div>
|
|
61
|
+
)
|
|
62
|
+
}
|
package/src/lib/version.ts
CHANGED
package/src/styles/_inputs.scss
CHANGED
|
@@ -1,9 +1,20 @@
|
|
|
1
1
|
@use './colors';
|
|
2
2
|
@use './typography';
|
|
3
3
|
|
|
4
|
+
@mixin search-text-field {
|
|
5
|
+
.seam-search-text-field {
|
|
6
|
+
svg {
|
|
7
|
+
* {
|
|
8
|
+
fill: colors.$text-gray-2;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
|
|
4
14
|
@mixin text-field {
|
|
5
15
|
.seam-text-field {
|
|
6
16
|
> .seam-main {
|
|
17
|
+
background: colors.$white;
|
|
7
18
|
border: 1px solid colors.$text-gray-3;
|
|
8
19
|
border-radius: 8px;
|
|
9
20
|
display: flex;
|
|
@@ -24,6 +35,7 @@
|
|
|
24
35
|
border: 0;
|
|
25
36
|
width: 100%;
|
|
26
37
|
border-radius: 8px;
|
|
38
|
+
font-size: 16px;
|
|
27
39
|
|
|
28
40
|
@include typography.font-family;
|
|
29
41
|
|
|
@@ -92,7 +104,6 @@
|
|
|
92
104
|
|
|
93
105
|
> .seam-text-field-input {
|
|
94
106
|
height: 48px;
|
|
95
|
-
font-size: 16px;
|
|
96
107
|
}
|
|
97
108
|
}
|
|
98
109
|
}
|
|
@@ -111,4 +122,5 @@
|
|
|
111
122
|
|
|
112
123
|
@mixin all {
|
|
113
124
|
@include text-field;
|
|
125
|
+
@include search-text-field;
|
|
114
126
|
}
|