@seamapi/react 3.1.2 → 4.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/README.md +2 -2
- package/dist/elements.js +11198 -11349
- package/dist/elements.js.map +1 -1
- package/dist/index.css +8 -193
- package/dist/index.css.map +1 -1
- package/dist/index.min.css +1 -1
- package/dist/index.min.css.map +1 -1
- package/lib/seam/components/AccessCodeDetails/AccessCodeDetails.d.ts +1 -1
- package/lib/seam/components/AccessCodeDetails/AccessCodeDetails.js +3 -3
- package/lib/seam/components/AccessCodeDetails/AccessCodeDetails.js.map +1 -1
- package/lib/seam/components/AccessCodeTable/AccessCodeTable.d.ts +1 -1
- package/lib/seam/components/AccessCodeTable/AccessCodeTable.js +4 -4
- package/lib/seam/components/AccessCodeTable/AccessCodeTable.js.map +1 -1
- package/lib/seam/components/DeviceDetails/DeviceDetails.d.ts +1 -1
- package/lib/seam/components/DeviceDetails/DeviceDetails.js +1 -2
- package/lib/seam/components/DeviceDetails/DeviceDetails.js.map +1 -1
- package/lib/seam/components/DeviceDetails/LockDeviceDetails.d.ts +1 -1
- package/lib/seam/components/DeviceDetails/LockDeviceDetails.js +2 -2
- package/lib/seam/components/DeviceDetails/LockDeviceDetails.js.map +1 -1
- package/lib/seam/components/DeviceDetails/ThermostatDeviceDetails.d.ts +1 -1
- package/lib/seam/components/DeviceDetails/ThermostatDeviceDetails.js +2 -46
- package/lib/seam/components/DeviceDetails/ThermostatDeviceDetails.js.map +1 -1
- package/lib/seam/components/DeviceTable/DeviceTable.d.ts +1 -1
- package/lib/seam/components/DeviceTable/DeviceTable.js +2 -2
- package/lib/seam/components/DeviceTable/DeviceTable.js.map +1 -1
- package/lib/seam/components/common-props.d.ts +0 -1
- package/lib/seam/components/common-props.js.map +1 -1
- package/lib/seam/components/index.d.ts +0 -2
- package/lib/seam/components/index.js +0 -2
- package/lib/seam/components/index.js.map +1 -1
- package/lib/seam/index.d.ts +0 -2
- package/lib/seam/index.js +0 -2
- package/lib/seam/index.js.map +1 -1
- package/lib/seam/thermostats/thermostat-device.d.ts +0 -1
- package/lib/seam/thermostats/thermostat-device.js.map +1 -1
- package/lib/ui/thermostat/FanModeMenu.js +1 -0
- package/lib/ui/thermostat/FanModeMenu.js.map +1 -1
- package/lib/version.d.ts +1 -1
- package/lib/version.js +1 -1
- package/package.json +8 -8
- package/src/lib/element.tsx +0 -1
- package/src/lib/seam/components/AccessCodeDetails/AccessCodeDetails.tsx +0 -3
- package/src/lib/seam/components/AccessCodeTable/AccessCodeTable.tsx +0 -4
- package/src/lib/seam/components/DeviceDetails/DeviceDetails.tsx +0 -2
- package/src/lib/seam/components/DeviceDetails/LockDeviceDetails.tsx +0 -2
- package/src/lib/seam/components/DeviceDetails/ThermostatDeviceDetails.tsx +0 -144
- package/src/lib/seam/components/DeviceTable/DeviceTable.tsx +0 -2
- package/src/lib/seam/components/common-props.tsx +0 -1
- package/src/lib/seam/components/elements.ts +0 -2
- package/src/lib/seam/components/index.ts +0 -2
- package/src/lib/seam/index.ts +0 -2
- package/src/lib/seam/thermostats/thermostat-device.ts +0 -1
- package/src/lib/ui/thermostat/FanModeMenu.tsx +1 -0
- package/src/lib/version.ts +1 -1
- package/src/styles/_main.scss +0 -4
- package/src/styles/_thermostat.scss +0 -98
- package/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleCard.d.ts +0 -7
- package/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleCard.js +0 -43
- package/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleCard.js.map +0 -1
- package/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleDetails.d.ts +0 -7
- package/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleDetails.js +0 -55
- package/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleDetails.js.map +0 -1
- package/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleDeviceBar.d.ts +0 -5
- package/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleDeviceBar.js +0 -31
- package/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleDeviceBar.js.map +0 -1
- package/lib/seam/components/ClimateSettingScheduleDetails/dates.d.ts +0 -1
- package/lib/seam/components/ClimateSettingScheduleDetails/dates.js +0 -9
- package/lib/seam/components/ClimateSettingScheduleDetails/dates.js.map +0 -1
- package/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleRow.d.ts +0 -8
- package/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleRow.js +0 -10
- package/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleRow.js.map +0 -1
- package/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleRowDetails.d.ts +0 -5
- package/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleRowDetails.js +0 -28
- package/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleRowDetails.js.map +0 -1
- package/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleTable.d.ts +0 -14
- package/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleTable.js +0 -80
- package/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleTable.js.map +0 -1
- package/lib/seam/components/CreateClimateSettingScheduleForm/CreateClimateSettingScheduleForm.d.ts +0 -5
- package/lib/seam/components/CreateClimateSettingScheduleForm/CreateClimateSettingScheduleForm.js +0 -29
- package/lib/seam/components/CreateClimateSettingScheduleForm/CreateClimateSettingScheduleForm.js.map +0 -1
- package/lib/seam/thermostats/climate-setting-schedules/use-climate-setting-schedule.d.ts +0 -6
- package/lib/seam/thermostats/climate-setting-schedules/use-climate-setting-schedule.js +0 -16
- package/lib/seam/thermostats/climate-setting-schedules/use-climate-setting-schedule.js.map +0 -1
- package/lib/seam/thermostats/climate-setting-schedules/use-climate-setting-schedules.d.ts +0 -6
- package/lib/seam/thermostats/climate-setting-schedules/use-climate-setting-schedules.js +0 -28
- package/lib/seam/thermostats/climate-setting-schedules/use-climate-setting-schedules.js.map +0 -1
- package/lib/seam/thermostats/climate-setting-schedules/use-create-climate-setting-schedule.d.ts +0 -7
- package/lib/seam/thermostats/climate-setting-schedules/use-create-climate-setting-schedule.js +0 -25
- package/lib/seam/thermostats/climate-setting-schedules/use-create-climate-setting-schedule.js.map +0 -1
- package/lib/seam/thermostats/climate-setting-schedules/use-delete-climate-setting-schedule.d.ts +0 -6
- package/lib/seam/thermostats/climate-setting-schedules/use-delete-climate-setting-schedule.js +0 -27
- package/lib/seam/thermostats/climate-setting-schedules/use-delete-climate-setting-schedule.js.map +0 -1
- package/lib/seam/thermostats/climate-setting-schedules/use-update-climate-setting-schedule.d.ts +0 -6
- package/lib/seam/thermostats/climate-setting-schedules/use-update-climate-setting-schedule.js +0 -46
- package/lib/seam/thermostats/climate-setting-schedules/use-update-climate-setting-schedule.js.map +0 -1
- package/lib/seam/thermostats/use-update-thermostat.d.ts +0 -6
- package/lib/seam/thermostats/use-update-thermostat.js +0 -51
- package/lib/seam/thermostats/use-update-thermostat.js.map +0 -1
- package/lib/ui/ClimateSettingForm/ClimateSettingScheduleForm.d.ts +0 -32
- package/lib/ui/ClimateSettingForm/ClimateSettingScheduleForm.js +0 -85
- package/lib/ui/ClimateSettingForm/ClimateSettingScheduleForm.js.map +0 -1
- package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormClimateSetting.d.ts +0 -13
- package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormClimateSetting.js +0 -44
- package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormClimateSetting.js.map +0 -1
- package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormDefaultClimateSetting.d.ts +0 -10
- package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormDefaultClimateSetting.js +0 -24
- package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormDefaultClimateSetting.js.map +0 -1
- package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormDeviceSelect.d.ts +0 -10
- package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormDeviceSelect.js +0 -10
- package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormDeviceSelect.js.map +0 -1
- package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormNameAndSchedule.d.ts +0 -15
- package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormNameAndSchedule.js +0 -30
- package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormNameAndSchedule.js.map +0 -1
- package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormTimeZonePicker.d.ts +0 -9
- package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormTimeZonePicker.js +0 -16
- package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormTimeZonePicker.js.map +0 -1
- package/lib/ui/ClimateSettingForm/set-point-bounds.d.ts +0 -4
- package/lib/ui/ClimateSettingForm/set-point-bounds.js +0 -17
- package/lib/ui/ClimateSettingForm/set-point-bounds.js.map +0 -1
- package/src/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleCard.tsx +0 -107
- package/src/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleDetails.element.ts +0 -11
- package/src/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleDetails.tsx +0 -175
- package/src/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleDeviceBar.tsx +0 -72
- package/src/lib/seam/components/ClimateSettingScheduleDetails/dates.ts +0 -10
- package/src/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleRow.tsx +0 -35
- package/src/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleRowDetails.tsx +0 -60
- package/src/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleTable.element.ts +0 -17
- package/src/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleTable.tsx +0 -220
- package/src/lib/seam/components/CreateClimateSettingScheduleForm/CreateClimateSettingScheduleForm.element.ts +0 -9
- package/src/lib/seam/components/CreateClimateSettingScheduleForm/CreateClimateSettingScheduleForm.tsx +0 -56
- package/src/lib/seam/thermostats/climate-setting-schedules/use-climate-setting-schedule.ts +0 -34
- package/src/lib/seam/thermostats/climate-setting-schedules/use-climate-setting-schedules.ts +0 -53
- package/src/lib/seam/thermostats/climate-setting-schedules/use-create-climate-setting-schedule.ts +0 -53
- package/src/lib/seam/thermostats/climate-setting-schedules/use-delete-climate-setting-schedule.ts +0 -51
- package/src/lib/seam/thermostats/climate-setting-schedules/use-update-climate-setting-schedule.ts +0 -83
- package/src/lib/seam/thermostats/use-update-thermostat.ts +0 -90
- package/src/lib/ui/ClimateSettingForm/ClimateSettingScheduleForm.tsx +0 -189
- package/src/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormClimateSetting.tsx +0 -118
- package/src/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormDefaultClimateSetting.tsx +0 -79
- package/src/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormDeviceSelect.tsx +0 -36
- package/src/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormNameAndSchedule.tsx +0 -120
- package/src/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormTimeZonePicker.tsx +0 -43
- package/src/lib/ui/ClimateSettingForm/set-point-bounds.ts +0 -31
- package/src/styles/_climate-setting-schedule-details.scss +0 -44
- package/src/styles/_climate-setting-schedule-form.scss +0 -111
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
/// <reference types="react" />
|
|
2
|
-
import { type Control } from 'react-hook-form';
|
|
3
|
-
import type { ClimateSettingScheduleFormFields } from '../../../lib/ui/ClimateSettingForm/ClimateSettingScheduleForm.js';
|
|
4
|
-
interface ClimateSettingScheduleFormClimateSettingProps {
|
|
5
|
-
title: string;
|
|
6
|
-
control: Control<ClimateSettingScheduleFormFields>;
|
|
7
|
-
deviceId: string;
|
|
8
|
-
onBack: () => void;
|
|
9
|
-
onCancel: (() => void) | undefined;
|
|
10
|
-
onSave: () => void;
|
|
11
|
-
}
|
|
12
|
-
export declare function ClimateSettingScheduleFormClimateSetting({ title, control, deviceId, onBack, onCancel, onSave, }: ClimateSettingScheduleFormClimateSettingProps): JSX.Element;
|
|
13
|
-
export {};
|
|
@@ -1,44 +0,0 @@
|
|
|
1
|
-
import { Fragment as _Fragment, jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import { Controller } from 'react-hook-form';
|
|
3
|
-
import { useDevice } from '../../../lib/seam/devices/use-device.js';
|
|
4
|
-
import { isThermostatDevice } from '../../../lib/seam/thermostats/thermostat-device.js';
|
|
5
|
-
import { Button } from '../../../lib/ui/Button.js';
|
|
6
|
-
import { getSetPointBounds, } from '../../../lib/ui/ClimateSettingForm/set-point-bounds.js';
|
|
7
|
-
import { FormField } from '../../../lib/ui/FormField.js';
|
|
8
|
-
import { InputLabel } from '../../../lib/ui/InputLabel.js';
|
|
9
|
-
import { ContentHeader } from '../../../lib/ui/layout/ContentHeader.js';
|
|
10
|
-
import { ClimateSettingControlGroup } from '../../../lib/ui/thermostat/ClimateSettingControlGroup.js';
|
|
11
|
-
export function ClimateSettingScheduleFormClimateSetting({ title, control, deviceId, onBack, onCancel, onSave, }) {
|
|
12
|
-
const { device } = useDevice({
|
|
13
|
-
device_id: deviceId,
|
|
14
|
-
});
|
|
15
|
-
if (device == null)
|
|
16
|
-
return _jsx(_Fragment, {});
|
|
17
|
-
if (!isThermostatDevice(device))
|
|
18
|
-
return _jsx(_Fragment, {});
|
|
19
|
-
const setPointBounds = getSetPointBounds(device);
|
|
20
|
-
return (_jsxs(_Fragment, { children: [_jsx(ContentHeader, { title: title, onBack: onBack, subheading: device?.properties.name }), _jsxs("div", { className: 'seam-main', children: [_jsx("div", { className: 'seam-climate-setting-schedule-form-climate-setting', children: _jsxs("div", { className: 'seam-content', children: [_jsxs("div", { children: [_jsx(InputLabel, { children: t.climateSetting }), _jsx("span", { className: 'seam-label', children: t.climateSettingSubHeading })] }), _jsx(FormContent, { control: control, setPointBounds: setPointBounds })] }) }), _jsxs("div", { className: 'seam-actions', children: [_jsx(Button, { onClick: onCancel, children: t.cancel }), _jsx(Button, { variant: 'solid', onClick: onSave, children: t.save })] })] })] }));
|
|
21
|
-
}
|
|
22
|
-
function FormContent({ control, setPointBounds, }) {
|
|
23
|
-
return (_jsx(FormField, { children: _jsx(Controller, { name: 'climateSetting', control: control, render: ({ field: { value, onChange } }) => (_jsx(ClimateSettingControlGroup, { mode: value.hvacModeSetting, onModeChange: (mode) => {
|
|
24
|
-
onChange({ ...value, hvacModeSetting: mode });
|
|
25
|
-
}, coolValue: value.coolingSetPoint, heatValue: value.heatingSetPoint, ...setPointBounds, onCoolValueChange: (coolingSetPoint) => {
|
|
26
|
-
onChange({
|
|
27
|
-
...value,
|
|
28
|
-
coolingSetPoint,
|
|
29
|
-
});
|
|
30
|
-
}, onHeatValueChange: (heatingSetPoint) => {
|
|
31
|
-
onChange({
|
|
32
|
-
...value,
|
|
33
|
-
heatingSetPoint,
|
|
34
|
-
});
|
|
35
|
-
} })) }) }));
|
|
36
|
-
}
|
|
37
|
-
const t = {
|
|
38
|
-
climateSetting: 'Climate setting',
|
|
39
|
-
climateSettingSubHeading: 'Choose mode and adjust the climate',
|
|
40
|
-
cancel: 'Cancel',
|
|
41
|
-
save: 'Save',
|
|
42
|
-
next: 'Next',
|
|
43
|
-
};
|
|
44
|
-
//# sourceMappingURL=ClimateSettingScheduleFormClimateSetting.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ClimateSettingScheduleFormClimateSetting.js","sourceRoot":"","sources":["../../../src/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormClimateSetting.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
/// <reference types="react" />
|
|
2
|
-
interface ClimateSettingScheduleFormDefaultClimateSettingProps {
|
|
3
|
-
title: string;
|
|
4
|
-
deviceId: string;
|
|
5
|
-
onBack: () => void;
|
|
6
|
-
onCancel: (() => void) | undefined;
|
|
7
|
-
onSave: () => void;
|
|
8
|
-
}
|
|
9
|
-
export declare function ClimateSettingScheduleFormDefaultClimateSetting({ title, deviceId, onBack, onCancel, onSave, }: ClimateSettingScheduleFormDefaultClimateSettingProps): JSX.Element;
|
|
10
|
-
export {};
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
-
import { useState } from 'react';
|
|
3
|
-
import { useDevice } from '../../../lib/seam/devices/use-device.js';
|
|
4
|
-
import { Button } from '../../../lib/ui/Button.js';
|
|
5
|
-
import { InputLabel } from '../../../lib/ui/InputLabel.js';
|
|
6
|
-
import { ContentHeader } from '../../../lib/ui/layout/ContentHeader.js';
|
|
7
|
-
import { ClimateSettingControlGroup } from '../../../lib/ui/thermostat/ClimateSettingControlGroup.js';
|
|
8
|
-
export function ClimateSettingScheduleFormDefaultClimateSetting({ title, deviceId, onBack, onCancel, onSave, }) {
|
|
9
|
-
const { device } = useDevice({
|
|
10
|
-
device_id: deviceId,
|
|
11
|
-
});
|
|
12
|
-
const [mode, setMode] = useState('heat_cool');
|
|
13
|
-
const [heatValue, setHeatValue] = useState(70);
|
|
14
|
-
const [coolValue, setCoolValue] = useState(75);
|
|
15
|
-
return (_jsxs(_Fragment, { children: [_jsx(ContentHeader, { title: title, onBack: onBack, subheading: device?.properties.name }), _jsxs("div", { className: 'seam-main', children: [_jsx("div", { className: 'seam-climate-setting-schedule-form-default-climate-setting', children: _jsxs("div", { className: 'seam-content', children: [_jsx("div", { className: 'seam-default-climate-setting-message', children: _jsx("p", { children: t.defaultClimateMessage }) }), _jsxs("div", { className: 'seam-control-group-title', children: [_jsx(InputLabel, { children: t.defaultClimate }), _jsx("span", { className: 'seam-label', children: t.defautClimateSubHeading })] }), _jsx(ClimateSettingControlGroup, { mode: mode, onModeChange: setMode, heatValue: heatValue, onHeatValueChange: setHeatValue, coolValue: coolValue, onCoolValueChange: setCoolValue })] }) }), _jsxs("div", { className: 'seam-actions', children: [_jsx(Button, { onClick: onCancel, children: t.cancel }), _jsx(Button, { variant: 'solid', onClick: onSave, children: t.save })] })] })] }));
|
|
16
|
-
}
|
|
17
|
-
const t = {
|
|
18
|
-
defaultClimate: 'Default Climate',
|
|
19
|
-
defautClimateSubHeading: 'Choose the default mode and climate for this device',
|
|
20
|
-
defaultClimateMessage: 'This device doesn’t have a default climate set up yet. Choose the climate you’d like the device to fall back to after scheduled climates reach their ends.',
|
|
21
|
-
cancel: 'Cancel',
|
|
22
|
-
save: 'Save',
|
|
23
|
-
};
|
|
24
|
-
//# sourceMappingURL=ClimateSettingScheduleFormDefaultClimateSetting.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ClimateSettingScheduleFormDefaultClimateSetting.js","sourceRoot":"","sources":["../../../src/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormDefaultClimateSetting.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAEhC,OAAO,EAAE,SAAS,EAAE,MAAM,gCAAgC,CAAA;AAE1D,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAA;AACzC,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAA;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAA;AAC9D,OAAO,EAAE,0BAA0B,EAAE,MAAM,iDAAiD,CAAA;AAU5F,MAAM,UAAU,+CAA+C,CAAC,EAC9D,KAAK,EACL,QAAQ,EACR,MAAM,EACN,QAAQ,EACR,MAAM,GAC+C;IACrD,MAAM,EAAE,MAAM,EAAE,GAAG,SAAS,CAAC;QAC3B,SAAS,EAAE,QAAQ;KACpB,CAAC,CAAA;IAEF,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,QAAQ,CAAkB,WAAW,CAAC,CAAA;IAC9D,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAA;IAC9C,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAA;IAE9C,OAAO,CACL,8BACE,KAAC,aAAa,IACZ,KAAK,EAAE,KAAK,EACZ,MAAM,EAAE,MAAM,EACd,UAAU,EAAE,MAAM,EAAE,UAAU,CAAC,IAAI,GACnC,EACF,eAAK,SAAS,EAAC,WAAW,aACxB,cAAK,SAAS,EAAC,4DAA4D,YACzE,eAAK,SAAS,EAAC,cAAc,aAC3B,cAAK,SAAS,EAAC,sCAAsC,YACnD,sBAAI,CAAC,CAAC,qBAAqB,GAAK,GAC5B,EACN,eAAK,SAAS,EAAC,0BAA0B,aACvC,KAAC,UAAU,cAAE,CAAC,CAAC,cAAc,GAAc,EAC3C,eAAM,SAAS,EAAC,YAAY,YAAE,CAAC,CAAC,uBAAuB,GAAQ,IAC3D,EACN,KAAC,0BAA0B,IACzB,IAAI,EAAE,IAAI,EACV,YAAY,EAAE,OAAO,EACrB,SAAS,EAAE,SAAS,EACpB,iBAAiB,EAAE,YAAY,EAC/B,SAAS,EAAE,SAAS,EACpB,iBAAiB,EAAE,YAAY,GAC/B,IACE,GACF,EACN,eAAK,SAAS,EAAC,cAAc,aAC3B,KAAC,MAAM,IAAC,OAAO,EAAE,QAAQ,YAAG,CAAC,CAAC,MAAM,GAAU,EAC9C,KAAC,MAAM,IAAC,OAAO,EAAC,OAAO,EAAC,OAAO,EAAE,MAAM,YACpC,CAAC,CAAC,IAAI,GACA,IACL,IACF,IACL,CACJ,CAAA;AACH,CAAC;AAED,MAAM,CAAC,GAAG;IACR,cAAc,EAAE,iBAAiB;IACjC,uBAAuB,EACrB,qDAAqD;IACvD,qBAAqB,EACnB,4JAA4J;IAC9J,MAAM,EAAE,QAAQ;IAChB,IAAI,EAAE,MAAM;CACb,CAAA"}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
/// <reference types="react" />
|
|
2
|
-
import { type Control } from 'react-hook-form';
|
|
3
|
-
import type { ClimateSettingScheduleFormFields } from '../../../lib/ui/ClimateSettingForm/ClimateSettingScheduleForm.js';
|
|
4
|
-
interface ClimateSettingScheduleFormDeviceSelectProps {
|
|
5
|
-
title: string;
|
|
6
|
-
control: Control<ClimateSettingScheduleFormFields>;
|
|
7
|
-
onBack: (() => void) | undefined;
|
|
8
|
-
}
|
|
9
|
-
export declare function ClimateSettingScheduleFormDeviceSelect({ title, control, onBack, }: ClimateSettingScheduleFormDeviceSelectProps): JSX.Element;
|
|
10
|
-
export {};
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import { Controller } from 'react-hook-form';
|
|
3
|
-
import { ContentHeader } from '../../../lib/ui/layout/ContentHeader.js';
|
|
4
|
-
import { ThermostatSelect } from '../../../lib/ui/thermostat/ThermostatSelect.js';
|
|
5
|
-
export function ClimateSettingScheduleFormDeviceSelect({ title, control, onBack, }) {
|
|
6
|
-
return (_jsxs(_Fragment, { children: [_jsx(ContentHeader, { title: title, onBack: onBack }), _jsx("div", { className: 'seam-main', children: _jsx(Controller, { name: 'deviceId', control: control, render: ({ field: { onChange } }) => (_jsx(ThermostatSelect, { onSelect: (deviceId) => {
|
|
7
|
-
onChange(deviceId);
|
|
8
|
-
} })) }) })] }));
|
|
9
|
-
}
|
|
10
|
-
//# sourceMappingURL=ClimateSettingScheduleFormDeviceSelect.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ClimateSettingScheduleFormDeviceSelect.js","sourceRoot":"","sources":["../../../src/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormDeviceSelect.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAgB,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAG1D,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAA;AAC9D,OAAO,EAAE,gBAAgB,EAAE,MAAM,uCAAuC,CAAA;AAQxE,MAAM,UAAU,sCAAsC,CAAC,EACrD,KAAK,EACL,OAAO,EACP,MAAM,GACsC;IAC5C,OAAO,CACL,8BACE,KAAC,aAAa,IAAC,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,GAAI,EAC/C,cAAK,SAAS,EAAC,WAAW,YACxB,KAAC,UAAU,IACT,IAAI,EAAC,UAAU,EACf,OAAO,EAAE,OAAO,EAChB,MAAM,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,EAAE,CAAC,CACnC,KAAC,gBAAgB,IACf,QAAQ,EAAE,CAAC,QAAQ,EAAE,EAAE;4BACrB,QAAQ,CAAC,QAAQ,CAAC,CAAA;wBACpB,CAAC,GACD,CACH,GACD,GACE,IACL,CACJ,CAAA;AACH,CAAC"}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
/// <reference types="react" />
|
|
2
|
-
import { type Control } from 'react-hook-form';
|
|
3
|
-
import type { ClimateSettingScheduleFormFields } from '../../../lib/ui/ClimateSettingForm/ClimateSettingScheduleForm.js';
|
|
4
|
-
interface ClimateSettingScheduleFormNameAndScheduleProps {
|
|
5
|
-
title: string;
|
|
6
|
-
control: Control<ClimateSettingScheduleFormFields>;
|
|
7
|
-
deviceId: string;
|
|
8
|
-
timeZone: string;
|
|
9
|
-
onBack: () => void;
|
|
10
|
-
onCancel: (() => void) | undefined;
|
|
11
|
-
onNext: () => void;
|
|
12
|
-
onChangeTimeZone: () => void;
|
|
13
|
-
}
|
|
14
|
-
export declare function ClimateSettingScheduleFormNameAndSchedule({ title, control, deviceId, timeZone, onBack, onCancel, onNext, onChangeTimeZone, }: ClimateSettingScheduleFormNameAndScheduleProps): JSX.Element;
|
|
15
|
-
export {};
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
-
import { Controller } from 'react-hook-form';
|
|
3
|
-
import { formatTimeZone } from '../../../lib/dates.js';
|
|
4
|
-
import { ChevronRightIcon } from '../../../lib/icons/ChevronRight.js';
|
|
5
|
-
import { useDevice } from '../../../lib/seam/devices/use-device.js';
|
|
6
|
-
import { Button } from '../../../lib/ui/Button.js';
|
|
7
|
-
import { DateTimePicker } from '../../../lib/ui/DateTimePicker/DateTimePicker.js';
|
|
8
|
-
import { FormField } from '../../../lib/ui/FormField.js';
|
|
9
|
-
import { InputLabel } from '../../../lib/ui/InputLabel.js';
|
|
10
|
-
import { ContentHeader } from '../../../lib/ui/layout/ContentHeader.js';
|
|
11
|
-
import { TextField } from '../../../lib/ui/TextField/TextField.js';
|
|
12
|
-
export function ClimateSettingScheduleFormNameAndSchedule({ title, control, deviceId, timeZone, onBack, onCancel, onNext, onChangeTimeZone, }) {
|
|
13
|
-
const { device } = useDevice({
|
|
14
|
-
device_id: deviceId,
|
|
15
|
-
});
|
|
16
|
-
return (_jsxs(_Fragment, { children: [_jsx(ContentHeader, { title: title, onBack: onBack, subheading: device?.properties.name }), _jsxs("div", { className: 'seam-main', children: [_jsx("div", { className: 'seam-climate-setting-schedule-form-name-and-schedule', children: _jsxs("div", { className: 'seam-content', children: [_jsxs(FormField, { children: [_jsx(InputLabel, { children: t.nameInputLabel }), _jsx(Controller, { name: 'name', control: control, defaultValue: '', render: ({ field, fieldState: { invalid, error } }) => {
|
|
17
|
-
return (_jsx(TextField, { ...field, size: 'large', clearable: true, hasError: invalid, helperText: error?.message }));
|
|
18
|
-
} })] }), _jsxs(FormField, { children: [_jsx(InputLabel, { children: t.startTimeLabel }), _jsxs("div", { className: 'seam-time-zone', children: [_jsx("span", { className: 'seam-label', children: t.selectedTimeZoneLabel }), _jsxs("span", { className: 'seam-selected', onClick: onChangeTimeZone, children: [formatTimeZone(timeZone), _jsx(ChevronRightIcon, {})] })] }), _jsx(Controller, { name: 'startDate', control: control, defaultValue: '', render: ({ field }) => (_jsx(DateTimePicker, { ...field, size: 'large' })) })] }), _jsxs(FormField, { children: [_jsx(InputLabel, { children: t.endTimeLabel }), _jsx(Controller, { name: 'endDate', control: control, defaultValue: '', render: ({ field }) => (_jsx(DateTimePicker, { ...field, size: 'large' })) })] })] }) }), _jsxs("div", { className: 'seam-actions', children: [_jsx(Button, { onClick: onCancel, children: t.cancel }), _jsx(Button, { variant: 'solid', onClick: onNext, children: t.next })] })] })] }));
|
|
19
|
-
}
|
|
20
|
-
const t = {
|
|
21
|
-
nameInputLabel: 'Name the climate setting schedule',
|
|
22
|
-
startTimeLabel: 'Start time',
|
|
23
|
-
endTimeLabel: 'End time',
|
|
24
|
-
addNewClimateSettingSchedule: 'Add a climate setting schedule',
|
|
25
|
-
cancel: 'Cancel',
|
|
26
|
-
save: 'Save',
|
|
27
|
-
next: 'Next',
|
|
28
|
-
selectedTimeZoneLabel: 'All times in',
|
|
29
|
-
};
|
|
30
|
-
//# sourceMappingURL=ClimateSettingScheduleFormNameAndSchedule.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ClimateSettingScheduleFormNameAndSchedule.js","sourceRoot":"","sources":["../../../src/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormNameAndSchedule.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
/// <reference types="react" />
|
|
2
|
-
import { type Control } from 'react-hook-form';
|
|
3
|
-
import type { ClimateSettingScheduleFormFields } from '../../../lib/ui/ClimateSettingForm/ClimateSettingScheduleForm.js';
|
|
4
|
-
interface ClimateSettingScheduleFormTimeZonePickerProps {
|
|
5
|
-
control: Control<ClimateSettingScheduleFormFields>;
|
|
6
|
-
onClose: () => void;
|
|
7
|
-
}
|
|
8
|
-
export declare function ClimateSettingScheduleFormTimeZonePicker({ control, onClose, }: ClimateSettingScheduleFormTimeZonePickerProps): JSX.Element;
|
|
9
|
-
export {};
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import { useState } from 'react';
|
|
3
|
-
import { Controller } from 'react-hook-form';
|
|
4
|
-
import { ContentHeader } from '../../../lib/ui/layout/ContentHeader.js';
|
|
5
|
-
import { TimeZonePicker } from '../../../lib/ui/TimeZonePicker/TimeZonePicker.js';
|
|
6
|
-
export function ClimateSettingScheduleFormTimeZonePicker({ control, onClose, }) {
|
|
7
|
-
const [title, setTitle] = useState(t.titleAuto);
|
|
8
|
-
return (_jsxs(_Fragment, { children: [_jsx(ContentHeader, { title: title, onBack: onClose }), _jsx("div", { className: 'seam-main', children: _jsx(Controller, { name: 'timeZone', control: control, render: ({ field }) => (_jsx(TimeZonePicker, { ...field, onManualTimeZoneSelected: (manualTimeZoneSelected) => {
|
|
9
|
-
setTitle(manualTimeZoneSelected ? t.titleManual : t.titleAuto);
|
|
10
|
-
} })) }) })] }));
|
|
11
|
-
}
|
|
12
|
-
const t = {
|
|
13
|
-
titleAuto: 'Time Zone (automatic)',
|
|
14
|
-
titleManual: 'Time Zone (manual)',
|
|
15
|
-
};
|
|
16
|
-
//# sourceMappingURL=ClimateSettingScheduleFormTimeZonePicker.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ClimateSettingScheduleFormTimeZonePicker.js","sourceRoot":"","sources":["../../../src/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormTimeZonePicker.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAChC,OAAO,EAAgB,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAG1D,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAA;AAC9D,OAAO,EAAE,cAAc,EAAE,MAAM,yCAAyC,CAAA;AAOxE,MAAM,UAAU,wCAAwC,CAAC,EACvD,OAAO,EACP,OAAO,GACuC;IAC9C,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAA;IAE/C,OAAO,CACL,8BACE,KAAC,aAAa,IAAC,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,GAAI,EAChD,cAAK,SAAS,EAAC,WAAW,YACxB,KAAC,UAAU,IACT,IAAI,EAAC,UAAU,EACf,OAAO,EAAE,OAAO,EAChB,MAAM,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CACrB,KAAC,cAAc,OACT,KAAK,EACT,wBAAwB,EAAE,CAAC,sBAAsB,EAAE,EAAE;4BACnD,QAAQ,CAAC,sBAAsB,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAA;wBAChE,CAAC,GACD,CACH,GACD,GACE,IACL,CACJ,CAAA;AACH,CAAC;AAED,MAAM,CAAC,GAAG;IACR,SAAS,EAAE,uBAAuB;IAClC,WAAW,EAAE,oBAAoB;CAClC,CAAA"}
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import type { ThermostatDevice } from '../../../lib/seam/thermostats/thermostat-device.js';
|
|
2
|
-
import type { TemperatureControlGroupProps } from '../../../lib/ui/thermostat/TemperatureControlGroup.js';
|
|
3
|
-
export type SetPointBounds = Partial<Pick<TemperatureControlGroupProps, 'minCool' | 'maxCool' | 'minHeat' | 'maxHeat' | 'delta'>>;
|
|
4
|
-
export declare const getSetPointBounds: (device: ThermostatDevice) => SetPointBounds;
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
export const getSetPointBounds = (device) => {
|
|
2
|
-
const { properties } = device;
|
|
3
|
-
const setPointBounds = {};
|
|
4
|
-
if (properties.available_hvac_mode_settings.includes('cool')) {
|
|
5
|
-
setPointBounds.minCool = properties.min_cooling_set_point_fahrenheit;
|
|
6
|
-
setPointBounds.maxCool = properties.max_cooling_set_point_fahrenheit;
|
|
7
|
-
}
|
|
8
|
-
if (properties.available_hvac_mode_settings.includes('heat')) {
|
|
9
|
-
setPointBounds.minHeat = properties.min_heating_set_point_fahrenheit;
|
|
10
|
-
setPointBounds.maxHeat = properties.max_heating_set_point_fahrenheit;
|
|
11
|
-
}
|
|
12
|
-
if (properties.available_hvac_mode_settings.includes('heat_cool')) {
|
|
13
|
-
setPointBounds.delta = properties.min_heating_cooling_delta_fahrenheit;
|
|
14
|
-
}
|
|
15
|
-
return setPointBounds;
|
|
16
|
-
};
|
|
17
|
-
//# sourceMappingURL=set-point-bounds.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"set-point-bounds.js","sourceRoot":"","sources":["../../../src/lib/ui/ClimateSettingForm/set-point-bounds.ts"],"names":[],"mappings":"AAUA,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,MAAwB,EAAkB,EAAE;IAC5E,MAAM,EAAE,UAAU,EAAE,GAAG,MAAM,CAAA;IAE7B,MAAM,cAAc,GAAmB,EAAE,CAAA;IAEzC,IAAI,UAAU,CAAC,4BAA4B,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;QAC7D,cAAc,CAAC,OAAO,GAAG,UAAU,CAAC,gCAAgC,CAAA;QACpE,cAAc,CAAC,OAAO,GAAG,UAAU,CAAC,gCAAgC,CAAA;IACtE,CAAC;IAED,IAAI,UAAU,CAAC,4BAA4B,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;QAC7D,cAAc,CAAC,OAAO,GAAG,UAAU,CAAC,gCAAgC,CAAA;QACpE,cAAc,CAAC,OAAO,GAAG,UAAU,CAAC,gCAAgC,CAAA;IACtE,CAAC;IAED,IAAI,UAAU,CAAC,4BAA4B,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE,CAAC;QAClE,cAAc,CAAC,KAAK,GAAG,UAAU,CAAC,oCAAoC,CAAA;IACxE,CAAC;IAED,OAAO,cAAc,CAAA;AACvB,CAAC,CAAA"}
|
package/src/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleCard.tsx
DELETED
|
@@ -1,107 +0,0 @@
|
|
|
1
|
-
import type { ClimateSettingSchedule } from '@seamapi/types/connect'
|
|
2
|
-
import { DateTime } from 'luxon'
|
|
3
|
-
|
|
4
|
-
import { ClimateSettingScheduleIcon } from 'lib/icons/ClimateSettingSchedule.js'
|
|
5
|
-
import { ClimateSettingScheduleDeviceBar } from 'lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleDeviceBar.js'
|
|
6
|
-
import { useClimateSettingSchedule } from 'lib/seam/thermostats/climate-setting-schedules/use-climate-setting-schedule.js'
|
|
7
|
-
import { DotDivider } from 'lib/ui/layout/DotDivider.js'
|
|
8
|
-
import { ClimateSettingStatus } from 'lib/ui/thermostat/ClimateSettingStatus.js'
|
|
9
|
-
import { useNow } from 'lib/ui/use-now.js'
|
|
10
|
-
|
|
11
|
-
import { formatDateTime } from './dates.js'
|
|
12
|
-
|
|
13
|
-
interface ClimateSettingScheduleCardProps {
|
|
14
|
-
climateSettingScheduleId: string
|
|
15
|
-
onSelectDevice: (deviceId: string) => void
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
export function ClimateSettingScheduleCard({
|
|
19
|
-
climateSettingScheduleId,
|
|
20
|
-
onSelectDevice,
|
|
21
|
-
}: ClimateSettingScheduleCardProps): JSX.Element {
|
|
22
|
-
return (
|
|
23
|
-
<div className='seam-climate-setting-schedule-card'>
|
|
24
|
-
<Content
|
|
25
|
-
climateSettingScheduleId={climateSettingScheduleId}
|
|
26
|
-
onSelectDevice={onSelectDevice}
|
|
27
|
-
/>
|
|
28
|
-
</div>
|
|
29
|
-
)
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
function Content(props: {
|
|
33
|
-
climateSettingScheduleId: string
|
|
34
|
-
onSelectDevice: (deviceId: string) => void
|
|
35
|
-
}): JSX.Element | null {
|
|
36
|
-
const { climateSettingScheduleId, onSelectDevice } = props
|
|
37
|
-
|
|
38
|
-
const { climateSettingSchedule } = useClimateSettingSchedule({
|
|
39
|
-
climate_setting_schedule_id: climateSettingScheduleId,
|
|
40
|
-
})
|
|
41
|
-
|
|
42
|
-
if (climateSettingSchedule == null) {
|
|
43
|
-
return null
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
const name = climateSettingSchedule.name ?? t.fallbackName
|
|
47
|
-
|
|
48
|
-
return (
|
|
49
|
-
<div className='seam-climate-setting-schedule-content'>
|
|
50
|
-
<div className='seam-climate-setting-schedule-summary-container'>
|
|
51
|
-
<div className='seam-climate-setting-schedule-icon-block'>
|
|
52
|
-
<ClimateSettingScheduleIcon />
|
|
53
|
-
</div>
|
|
54
|
-
<div className='seam-climate-setting-schedule-summary'>
|
|
55
|
-
<h5 className='seam-climate-setting-schedule-heading'>{name}</h5>
|
|
56
|
-
<div className='seam-climate-setting-schedule-subheading'>
|
|
57
|
-
<ClimateSettingStatus climateSetting={climateSettingSchedule} />
|
|
58
|
-
<DotDivider />
|
|
59
|
-
<ClimateSettingScheduleTiming
|
|
60
|
-
climateSettingSchedule={climateSettingSchedule}
|
|
61
|
-
/>
|
|
62
|
-
</div>
|
|
63
|
-
</div>
|
|
64
|
-
</div>
|
|
65
|
-
<ClimateSettingScheduleDeviceBar
|
|
66
|
-
onSelectDevice={onSelectDevice}
|
|
67
|
-
deviceId={climateSettingSchedule.device_id}
|
|
68
|
-
/>
|
|
69
|
-
</div>
|
|
70
|
-
)
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
function ClimateSettingScheduleTiming(props: {
|
|
74
|
-
climateSettingSchedule: ClimateSettingSchedule
|
|
75
|
-
}): JSX.Element | null {
|
|
76
|
-
const { climateSettingSchedule } = props
|
|
77
|
-
|
|
78
|
-
const now = useNow()
|
|
79
|
-
|
|
80
|
-
if (now === null) return null
|
|
81
|
-
|
|
82
|
-
const startTime = DateTime.fromISO(climateSettingSchedule.schedule_starts_at)
|
|
83
|
-
const endTime = DateTime.fromISO(climateSettingSchedule.schedule_ends_at)
|
|
84
|
-
|
|
85
|
-
if (now < startTime)
|
|
86
|
-
return (
|
|
87
|
-
<span>
|
|
88
|
-
{t.starts} {formatDateTime(climateSettingSchedule.schedule_starts_at)}
|
|
89
|
-
</span>
|
|
90
|
-
)
|
|
91
|
-
|
|
92
|
-
if (startTime <= now && now <= endTime)
|
|
93
|
-
return (
|
|
94
|
-
<span>
|
|
95
|
-
{t.ends} {formatDateTime(climateSettingSchedule.schedule_starts_at)}
|
|
96
|
-
</span>
|
|
97
|
-
)
|
|
98
|
-
|
|
99
|
-
return <span>{t.expired}</span>
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
const t = {
|
|
103
|
-
starts: 'Starts',
|
|
104
|
-
ends: 'Ends',
|
|
105
|
-
expired: 'Expired',
|
|
106
|
-
fallbackName: 'Climate Setting Schedule',
|
|
107
|
-
}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import type { ElementProps } from 'lib/element.js'
|
|
2
|
-
|
|
3
|
-
import type { ClimateSettingScheduleDetailsProps } from './ClimateSettingScheduleDetails.js'
|
|
4
|
-
|
|
5
|
-
export const name = 'seam-climate-setting-schedule-details'
|
|
6
|
-
|
|
7
|
-
export const props: ElementProps<ClimateSettingScheduleDetailsProps> = {
|
|
8
|
-
climateSettingScheduleId: 'string',
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
export { ClimateSettingScheduleDetails as Component } from './ClimateSettingScheduleDetails.js'
|
package/src/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleDetails.tsx
DELETED
|
@@ -1,175 +0,0 @@
|
|
|
1
|
-
import classNames from 'classnames'
|
|
2
|
-
import { useState } from 'react'
|
|
3
|
-
|
|
4
|
-
import { ArrowRightIcon } from 'lib/icons/ArrowRight.js'
|
|
5
|
-
import { ClimateSettingScheduleCard } from 'lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleCard.js'
|
|
6
|
-
import {
|
|
7
|
-
type CommonProps,
|
|
8
|
-
withRequiredCommonProps,
|
|
9
|
-
} from 'lib/seam/components/common-props.js'
|
|
10
|
-
import { NestedDeviceDetails } from 'lib/seam/components/DeviceDetails/DeviceDetails.js'
|
|
11
|
-
import { useClimateSettingSchedule } from 'lib/seam/thermostats/climate-setting-schedules/use-climate-setting-schedule.js'
|
|
12
|
-
import { useUpdateClimateSettingSchedule } from 'lib/seam/thermostats/climate-setting-schedules/use-update-climate-setting-schedule.js'
|
|
13
|
-
import { useComponentTelemetry } from 'lib/telemetry/index.js'
|
|
14
|
-
import { ContentHeader } from 'lib/ui/layout/ContentHeader.js'
|
|
15
|
-
import { DetailRow } from 'lib/ui/layout/DetailRow.js'
|
|
16
|
-
import { DetailSection } from 'lib/ui/layout/DetailSection.js'
|
|
17
|
-
import { DetailSectionGroup } from 'lib/ui/layout/DetailSectionGroup.js'
|
|
18
|
-
import { Snackbar } from 'lib/ui/Snackbar/Snackbar.js'
|
|
19
|
-
import { Switch } from 'lib/ui/Switch/Switch.js'
|
|
20
|
-
import { ClimateSettingStatus } from 'lib/ui/thermostat/ClimateSettingStatus.js'
|
|
21
|
-
|
|
22
|
-
import { formatDateTime } from './dates.js'
|
|
23
|
-
|
|
24
|
-
export interface ClimateSettingScheduleDetailsProps extends CommonProps {
|
|
25
|
-
climateSettingScheduleId: string
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
export const NestedClimateSettingScheduleDetails = withRequiredCommonProps(
|
|
29
|
-
ClimateSettingScheduleDetails
|
|
30
|
-
)
|
|
31
|
-
|
|
32
|
-
export function ClimateSettingScheduleDetails({
|
|
33
|
-
climateSettingScheduleId,
|
|
34
|
-
disableLockUnlock = false,
|
|
35
|
-
disableDeleteAccessCode = false,
|
|
36
|
-
onBack,
|
|
37
|
-
className,
|
|
38
|
-
errorFilter = () => true,
|
|
39
|
-
warningFilter = () => true,
|
|
40
|
-
disableCreateAccessCode,
|
|
41
|
-
disableEditAccessCode,
|
|
42
|
-
disableResourceIds = false,
|
|
43
|
-
disableConnectedAccountInformation = false,
|
|
44
|
-
disableClimateSettingSchedules,
|
|
45
|
-
}: ClimateSettingScheduleDetailsProps): JSX.Element | null {
|
|
46
|
-
useComponentTelemetry('ClimateSettingScheduleDetails')
|
|
47
|
-
|
|
48
|
-
const { climateSettingSchedule } = useClimateSettingSchedule({
|
|
49
|
-
climate_setting_schedule_id: climateSettingScheduleId,
|
|
50
|
-
})
|
|
51
|
-
|
|
52
|
-
const { mutate, isSuccess, isError } = useUpdateClimateSettingSchedule()
|
|
53
|
-
|
|
54
|
-
const [selectedDeviceId, selectDevice] = useState<string | null>(null)
|
|
55
|
-
|
|
56
|
-
if (climateSettingSchedule == null) {
|
|
57
|
-
return null
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
const isManualOverrideAllowed =
|
|
61
|
-
climateSettingSchedule.manual_override_allowed ?? false
|
|
62
|
-
|
|
63
|
-
if (selectedDeviceId != null) {
|
|
64
|
-
return (
|
|
65
|
-
<NestedDeviceDetails
|
|
66
|
-
deviceId={selectedDeviceId}
|
|
67
|
-
errorFilter={errorFilter}
|
|
68
|
-
warningFilter={warningFilter}
|
|
69
|
-
disableLockUnlock={disableLockUnlock}
|
|
70
|
-
disableCreateAccessCode={disableCreateAccessCode}
|
|
71
|
-
disableEditAccessCode={disableEditAccessCode}
|
|
72
|
-
disableDeleteAccessCode={disableDeleteAccessCode}
|
|
73
|
-
disableResourceIds={disableResourceIds}
|
|
74
|
-
disableConnectedAccountInformation={disableConnectedAccountInformation}
|
|
75
|
-
disableClimateSettingSchedules={disableClimateSettingSchedules}
|
|
76
|
-
onBack={() => {
|
|
77
|
-
selectDevice(null)
|
|
78
|
-
}}
|
|
79
|
-
className={className}
|
|
80
|
-
/>
|
|
81
|
-
)
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
return (
|
|
85
|
-
<>
|
|
86
|
-
<div
|
|
87
|
-
className={classNames(
|
|
88
|
-
'seam-climate-setting-schedule-details',
|
|
89
|
-
className
|
|
90
|
-
)}
|
|
91
|
-
>
|
|
92
|
-
<ContentHeader title={t.climateSettingSchedule} onBack={onBack} />
|
|
93
|
-
<div className='seam-climate-setting-schedule-details-content'>
|
|
94
|
-
<ClimateSettingScheduleCard
|
|
95
|
-
climateSettingScheduleId={climateSettingScheduleId}
|
|
96
|
-
onSelectDevice={selectDevice}
|
|
97
|
-
/>
|
|
98
|
-
<div className='seam-default-setting-message-container'>
|
|
99
|
-
<span className='seam-default-setting-message'>
|
|
100
|
-
{t.defaultSettingMessagePart1}{' '}
|
|
101
|
-
<span className='seam-default-setting-text'>
|
|
102
|
-
{t.defaultSetting}
|
|
103
|
-
</span>{' '}
|
|
104
|
-
{t.defaultSettingMessagePart2}
|
|
105
|
-
</span>
|
|
106
|
-
</div>
|
|
107
|
-
<DetailSectionGroup>
|
|
108
|
-
<DetailSection>
|
|
109
|
-
<DetailRow label={t.startEndTime}>
|
|
110
|
-
<span className='seam-climate-setting-details-value seam-climate-setting-details-schedule-range'>
|
|
111
|
-
{formatDateTime(climateSettingSchedule.schedule_starts_at)}
|
|
112
|
-
<ArrowRightIcon />
|
|
113
|
-
{formatDateTime(climateSettingSchedule.schedule_ends_at)}
|
|
114
|
-
</span>
|
|
115
|
-
</DetailRow>
|
|
116
|
-
<DetailRow label={t.climateSetting}>
|
|
117
|
-
<ClimateSettingStatus
|
|
118
|
-
climateSetting={climateSettingSchedule}
|
|
119
|
-
iconPlacement='right'
|
|
120
|
-
/>
|
|
121
|
-
</DetailRow>
|
|
122
|
-
<DetailRow label={t.allowManualOverride}>
|
|
123
|
-
<span className='seam-climate-setting-details-value'>
|
|
124
|
-
<Switch
|
|
125
|
-
checked={isManualOverrideAllowed}
|
|
126
|
-
onChange={(checked) => {
|
|
127
|
-
mutate({
|
|
128
|
-
climate_setting_schedule_id:
|
|
129
|
-
climateSettingSchedule.climate_setting_schedule_id,
|
|
130
|
-
manual_override_allowed: checked,
|
|
131
|
-
})
|
|
132
|
-
}}
|
|
133
|
-
/>
|
|
134
|
-
</span>
|
|
135
|
-
</DetailRow>
|
|
136
|
-
</DetailSection>
|
|
137
|
-
<DetailSection>
|
|
138
|
-
<DetailRow label={t.creationDate}>
|
|
139
|
-
<div className='seam-creation-date'>
|
|
140
|
-
{formatDateTime(climateSettingSchedule.created_at)}
|
|
141
|
-
</div>
|
|
142
|
-
</DetailRow>
|
|
143
|
-
</DetailSection>
|
|
144
|
-
</DetailSectionGroup>
|
|
145
|
-
</div>
|
|
146
|
-
</div>
|
|
147
|
-
<Snackbar
|
|
148
|
-
message={t.manualOverrideSuccess}
|
|
149
|
-
variant='success'
|
|
150
|
-
visible={isSuccess}
|
|
151
|
-
automaticVisibility
|
|
152
|
-
/>
|
|
153
|
-
|
|
154
|
-
<Snackbar
|
|
155
|
-
message={t.manualOverrideError}
|
|
156
|
-
variant='error'
|
|
157
|
-
visible={isError}
|
|
158
|
-
automaticVisibility
|
|
159
|
-
/>
|
|
160
|
-
</>
|
|
161
|
-
)
|
|
162
|
-
}
|
|
163
|
-
|
|
164
|
-
const t = {
|
|
165
|
-
climateSettingSchedule: 'Climate setting schedule',
|
|
166
|
-
startEndTime: 'Start/End Time',
|
|
167
|
-
climateSetting: 'Climate setting',
|
|
168
|
-
allowManualOverride: 'Allow manual override',
|
|
169
|
-
creationDate: 'Creation date',
|
|
170
|
-
defaultSettingMessagePart1: 'Thermostat will return to its',
|
|
171
|
-
defaultSetting: 'default setting',
|
|
172
|
-
defaultSettingMessagePart2: 'at end time.',
|
|
173
|
-
manualOverrideSuccess: 'Successfully updated manual override!',
|
|
174
|
-
manualOverrideError: 'Error updating manual override. Please try again.',
|
|
175
|
-
}
|
package/src/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleDeviceBar.tsx
DELETED
|
@@ -1,72 +0,0 @@
|
|
|
1
|
-
import { ChevronWideIcon } from 'lib/icons/ChevronWide.js'
|
|
2
|
-
import { useDevice } from 'lib/seam/devices/use-device.js'
|
|
3
|
-
import {
|
|
4
|
-
isThermostatDevice,
|
|
5
|
-
type ThermostatDevice,
|
|
6
|
-
} from 'lib/seam/thermostats/thermostat-device.js'
|
|
7
|
-
import { DeviceImage } from 'lib/ui/device/DeviceImage.js'
|
|
8
|
-
import { ClimateSettingStatus } from 'lib/ui/thermostat/ClimateSettingStatus.js'
|
|
9
|
-
|
|
10
|
-
export function ClimateSettingScheduleDeviceBar({
|
|
11
|
-
deviceId,
|
|
12
|
-
onSelectDevice,
|
|
13
|
-
}: {
|
|
14
|
-
deviceId: string
|
|
15
|
-
onSelectDevice: (deviceId: string) => void
|
|
16
|
-
}): JSX.Element | null {
|
|
17
|
-
const { isPending, device } = useDevice({
|
|
18
|
-
device_id: deviceId,
|
|
19
|
-
})
|
|
20
|
-
|
|
21
|
-
if (isPending) {
|
|
22
|
-
return null
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
if (device == null) {
|
|
26
|
-
return null
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
if (!isThermostatDevice(device)) {
|
|
30
|
-
return null
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
return <Content device={device} onSelectDevice={onSelectDevice} />
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
function Content(props: {
|
|
37
|
-
device: ThermostatDevice
|
|
38
|
-
onSelectDevice: (deviceId: string) => void
|
|
39
|
-
}): JSX.Element {
|
|
40
|
-
const { device, onSelectDevice } = props
|
|
41
|
-
|
|
42
|
-
return (
|
|
43
|
-
<div
|
|
44
|
-
className='seam-climate-setting-schedule-device-bar'
|
|
45
|
-
onClick={() => {
|
|
46
|
-
onSelectDevice(device.device_id)
|
|
47
|
-
}}
|
|
48
|
-
>
|
|
49
|
-
<div className='seam-climate-setting-schedule-device-content'>
|
|
50
|
-
<div className='seam-device-image'>
|
|
51
|
-
<DeviceImage device={device} />
|
|
52
|
-
</div>
|
|
53
|
-
<div className='seam-climate-setting-schedule-device-details'>
|
|
54
|
-
<div className='seam-device-name'>{device.properties.name}</div>
|
|
55
|
-
<div className='seam-device-current-climate-setting'>
|
|
56
|
-
{t.currentClimate}:
|
|
57
|
-
<ClimateSettingStatus
|
|
58
|
-
climateSetting={device.properties.current_climate_setting}
|
|
59
|
-
/>
|
|
60
|
-
</div>
|
|
61
|
-
</div>
|
|
62
|
-
</div>
|
|
63
|
-
<div className='seam-climate-setting-schedule-device-chevron'>
|
|
64
|
-
<ChevronWideIcon />
|
|
65
|
-
</div>
|
|
66
|
-
</div>
|
|
67
|
-
)
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
const t = {
|
|
71
|
-
currentClimate: 'Current climate',
|
|
72
|
-
}
|