@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.
Files changed (145) hide show
  1. package/README.md +2 -2
  2. package/dist/elements.js +11198 -11349
  3. package/dist/elements.js.map +1 -1
  4. package/dist/index.css +8 -193
  5. package/dist/index.css.map +1 -1
  6. package/dist/index.min.css +1 -1
  7. package/dist/index.min.css.map +1 -1
  8. package/lib/seam/components/AccessCodeDetails/AccessCodeDetails.d.ts +1 -1
  9. package/lib/seam/components/AccessCodeDetails/AccessCodeDetails.js +3 -3
  10. package/lib/seam/components/AccessCodeDetails/AccessCodeDetails.js.map +1 -1
  11. package/lib/seam/components/AccessCodeTable/AccessCodeTable.d.ts +1 -1
  12. package/lib/seam/components/AccessCodeTable/AccessCodeTable.js +4 -4
  13. package/lib/seam/components/AccessCodeTable/AccessCodeTable.js.map +1 -1
  14. package/lib/seam/components/DeviceDetails/DeviceDetails.d.ts +1 -1
  15. package/lib/seam/components/DeviceDetails/DeviceDetails.js +1 -2
  16. package/lib/seam/components/DeviceDetails/DeviceDetails.js.map +1 -1
  17. package/lib/seam/components/DeviceDetails/LockDeviceDetails.d.ts +1 -1
  18. package/lib/seam/components/DeviceDetails/LockDeviceDetails.js +2 -2
  19. package/lib/seam/components/DeviceDetails/LockDeviceDetails.js.map +1 -1
  20. package/lib/seam/components/DeviceDetails/ThermostatDeviceDetails.d.ts +1 -1
  21. package/lib/seam/components/DeviceDetails/ThermostatDeviceDetails.js +2 -46
  22. package/lib/seam/components/DeviceDetails/ThermostatDeviceDetails.js.map +1 -1
  23. package/lib/seam/components/DeviceTable/DeviceTable.d.ts +1 -1
  24. package/lib/seam/components/DeviceTable/DeviceTable.js +2 -2
  25. package/lib/seam/components/DeviceTable/DeviceTable.js.map +1 -1
  26. package/lib/seam/components/common-props.d.ts +0 -1
  27. package/lib/seam/components/common-props.js.map +1 -1
  28. package/lib/seam/components/index.d.ts +0 -2
  29. package/lib/seam/components/index.js +0 -2
  30. package/lib/seam/components/index.js.map +1 -1
  31. package/lib/seam/index.d.ts +0 -2
  32. package/lib/seam/index.js +0 -2
  33. package/lib/seam/index.js.map +1 -1
  34. package/lib/seam/thermostats/thermostat-device.d.ts +0 -1
  35. package/lib/seam/thermostats/thermostat-device.js.map +1 -1
  36. package/lib/ui/thermostat/FanModeMenu.js +1 -0
  37. package/lib/ui/thermostat/FanModeMenu.js.map +1 -1
  38. package/lib/version.d.ts +1 -1
  39. package/lib/version.js +1 -1
  40. package/package.json +8 -8
  41. package/src/lib/element.tsx +0 -1
  42. package/src/lib/seam/components/AccessCodeDetails/AccessCodeDetails.tsx +0 -3
  43. package/src/lib/seam/components/AccessCodeTable/AccessCodeTable.tsx +0 -4
  44. package/src/lib/seam/components/DeviceDetails/DeviceDetails.tsx +0 -2
  45. package/src/lib/seam/components/DeviceDetails/LockDeviceDetails.tsx +0 -2
  46. package/src/lib/seam/components/DeviceDetails/ThermostatDeviceDetails.tsx +0 -144
  47. package/src/lib/seam/components/DeviceTable/DeviceTable.tsx +0 -2
  48. package/src/lib/seam/components/common-props.tsx +0 -1
  49. package/src/lib/seam/components/elements.ts +0 -2
  50. package/src/lib/seam/components/index.ts +0 -2
  51. package/src/lib/seam/index.ts +0 -2
  52. package/src/lib/seam/thermostats/thermostat-device.ts +0 -1
  53. package/src/lib/ui/thermostat/FanModeMenu.tsx +1 -0
  54. package/src/lib/version.ts +1 -1
  55. package/src/styles/_main.scss +0 -4
  56. package/src/styles/_thermostat.scss +0 -98
  57. package/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleCard.d.ts +0 -7
  58. package/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleCard.js +0 -43
  59. package/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleCard.js.map +0 -1
  60. package/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleDetails.d.ts +0 -7
  61. package/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleDetails.js +0 -55
  62. package/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleDetails.js.map +0 -1
  63. package/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleDeviceBar.d.ts +0 -5
  64. package/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleDeviceBar.js +0 -31
  65. package/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleDeviceBar.js.map +0 -1
  66. package/lib/seam/components/ClimateSettingScheduleDetails/dates.d.ts +0 -1
  67. package/lib/seam/components/ClimateSettingScheduleDetails/dates.js +0 -9
  68. package/lib/seam/components/ClimateSettingScheduleDetails/dates.js.map +0 -1
  69. package/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleRow.d.ts +0 -8
  70. package/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleRow.js +0 -10
  71. package/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleRow.js.map +0 -1
  72. package/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleRowDetails.d.ts +0 -5
  73. package/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleRowDetails.js +0 -28
  74. package/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleRowDetails.js.map +0 -1
  75. package/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleTable.d.ts +0 -14
  76. package/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleTable.js +0 -80
  77. package/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleTable.js.map +0 -1
  78. package/lib/seam/components/CreateClimateSettingScheduleForm/CreateClimateSettingScheduleForm.d.ts +0 -5
  79. package/lib/seam/components/CreateClimateSettingScheduleForm/CreateClimateSettingScheduleForm.js +0 -29
  80. package/lib/seam/components/CreateClimateSettingScheduleForm/CreateClimateSettingScheduleForm.js.map +0 -1
  81. package/lib/seam/thermostats/climate-setting-schedules/use-climate-setting-schedule.d.ts +0 -6
  82. package/lib/seam/thermostats/climate-setting-schedules/use-climate-setting-schedule.js +0 -16
  83. package/lib/seam/thermostats/climate-setting-schedules/use-climate-setting-schedule.js.map +0 -1
  84. package/lib/seam/thermostats/climate-setting-schedules/use-climate-setting-schedules.d.ts +0 -6
  85. package/lib/seam/thermostats/climate-setting-schedules/use-climate-setting-schedules.js +0 -28
  86. package/lib/seam/thermostats/climate-setting-schedules/use-climate-setting-schedules.js.map +0 -1
  87. package/lib/seam/thermostats/climate-setting-schedules/use-create-climate-setting-schedule.d.ts +0 -7
  88. package/lib/seam/thermostats/climate-setting-schedules/use-create-climate-setting-schedule.js +0 -25
  89. package/lib/seam/thermostats/climate-setting-schedules/use-create-climate-setting-schedule.js.map +0 -1
  90. package/lib/seam/thermostats/climate-setting-schedules/use-delete-climate-setting-schedule.d.ts +0 -6
  91. package/lib/seam/thermostats/climate-setting-schedules/use-delete-climate-setting-schedule.js +0 -27
  92. package/lib/seam/thermostats/climate-setting-schedules/use-delete-climate-setting-schedule.js.map +0 -1
  93. package/lib/seam/thermostats/climate-setting-schedules/use-update-climate-setting-schedule.d.ts +0 -6
  94. package/lib/seam/thermostats/climate-setting-schedules/use-update-climate-setting-schedule.js +0 -46
  95. package/lib/seam/thermostats/climate-setting-schedules/use-update-climate-setting-schedule.js.map +0 -1
  96. package/lib/seam/thermostats/use-update-thermostat.d.ts +0 -6
  97. package/lib/seam/thermostats/use-update-thermostat.js +0 -51
  98. package/lib/seam/thermostats/use-update-thermostat.js.map +0 -1
  99. package/lib/ui/ClimateSettingForm/ClimateSettingScheduleForm.d.ts +0 -32
  100. package/lib/ui/ClimateSettingForm/ClimateSettingScheduleForm.js +0 -85
  101. package/lib/ui/ClimateSettingForm/ClimateSettingScheduleForm.js.map +0 -1
  102. package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormClimateSetting.d.ts +0 -13
  103. package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormClimateSetting.js +0 -44
  104. package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormClimateSetting.js.map +0 -1
  105. package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormDefaultClimateSetting.d.ts +0 -10
  106. package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormDefaultClimateSetting.js +0 -24
  107. package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormDefaultClimateSetting.js.map +0 -1
  108. package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormDeviceSelect.d.ts +0 -10
  109. package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormDeviceSelect.js +0 -10
  110. package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormDeviceSelect.js.map +0 -1
  111. package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormNameAndSchedule.d.ts +0 -15
  112. package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormNameAndSchedule.js +0 -30
  113. package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormNameAndSchedule.js.map +0 -1
  114. package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormTimeZonePicker.d.ts +0 -9
  115. package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormTimeZonePicker.js +0 -16
  116. package/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormTimeZonePicker.js.map +0 -1
  117. package/lib/ui/ClimateSettingForm/set-point-bounds.d.ts +0 -4
  118. package/lib/ui/ClimateSettingForm/set-point-bounds.js +0 -17
  119. package/lib/ui/ClimateSettingForm/set-point-bounds.js.map +0 -1
  120. package/src/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleCard.tsx +0 -107
  121. package/src/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleDetails.element.ts +0 -11
  122. package/src/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleDetails.tsx +0 -175
  123. package/src/lib/seam/components/ClimateSettingScheduleDetails/ClimateSettingScheduleDeviceBar.tsx +0 -72
  124. package/src/lib/seam/components/ClimateSettingScheduleDetails/dates.ts +0 -10
  125. package/src/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleRow.tsx +0 -35
  126. package/src/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleRowDetails.tsx +0 -60
  127. package/src/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleTable.element.ts +0 -17
  128. package/src/lib/seam/components/ClimateSettingScheduleTable/ClimateSettingScheduleTable.tsx +0 -220
  129. package/src/lib/seam/components/CreateClimateSettingScheduleForm/CreateClimateSettingScheduleForm.element.ts +0 -9
  130. package/src/lib/seam/components/CreateClimateSettingScheduleForm/CreateClimateSettingScheduleForm.tsx +0 -56
  131. package/src/lib/seam/thermostats/climate-setting-schedules/use-climate-setting-schedule.ts +0 -34
  132. package/src/lib/seam/thermostats/climate-setting-schedules/use-climate-setting-schedules.ts +0 -53
  133. package/src/lib/seam/thermostats/climate-setting-schedules/use-create-climate-setting-schedule.ts +0 -53
  134. package/src/lib/seam/thermostats/climate-setting-schedules/use-delete-climate-setting-schedule.ts +0 -51
  135. package/src/lib/seam/thermostats/climate-setting-schedules/use-update-climate-setting-schedule.ts +0 -83
  136. package/src/lib/seam/thermostats/use-update-thermostat.ts +0 -90
  137. package/src/lib/ui/ClimateSettingForm/ClimateSettingScheduleForm.tsx +0 -189
  138. package/src/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormClimateSetting.tsx +0 -118
  139. package/src/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormDefaultClimateSetting.tsx +0 -79
  140. package/src/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormDeviceSelect.tsx +0 -36
  141. package/src/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormNameAndSchedule.tsx +0 -120
  142. package/src/lib/ui/ClimateSettingForm/ClimateSettingScheduleFormTimeZonePicker.tsx +0 -43
  143. package/src/lib/ui/ClimateSettingForm/set-point-bounds.ts +0 -31
  144. package/src/styles/_climate-setting-schedule-details.scss +0 -44
  145. 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":";AAAA,OAAO,EAAgB,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAE1D,OAAO,EAAE,SAAS,EAAE,MAAM,gCAAgC,CAAA;AAC1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,2CAA2C,CAAA;AAC9E,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAA;AAEzC,OAAO,EACL,iBAAiB,GAElB,MAAM,+CAA+C,CAAA;AACtD,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAA;AAC/C,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAA;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAA;AAC9D,OAAO,EAAE,0BAA0B,EAAE,MAAM,iDAAiD,CAAA;AAW5F,MAAM,UAAU,wCAAwC,CAAC,EACvD,KAAK,EACL,OAAO,EACP,QAAQ,EACR,MAAM,EACN,QAAQ,EACR,MAAM,GACwC;IAC9C,MAAM,EAAE,MAAM,EAAE,GAAG,SAAS,CAAC;QAC3B,SAAS,EAAE,QAAQ;KACpB,CAAC,CAAA;IAEF,IAAI,MAAM,IAAI,IAAI;QAAE,OAAO,mBAAK,CAAA;IAChC,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC;QAAE,OAAO,mBAAK,CAAA;IAE7C,MAAM,cAAc,GAAG,iBAAiB,CAAC,MAAM,CAAC,CAAA;IAEhD,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,oDAAoD,YACjE,eAAK,SAAS,EAAC,cAAc,aAC3B,0BACE,KAAC,UAAU,cAAE,CAAC,CAAC,cAAc,GAAc,EAC3C,eAAM,SAAS,EAAC,YAAY,YAAE,CAAC,CAAC,wBAAwB,GAAQ,IAC5D,EACN,KAAC,WAAW,IAAC,OAAO,EAAE,OAAO,EAAE,cAAc,EAAE,cAAc,GAAI,IAC7D,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;AAOD,SAAS,WAAW,CAAC,EACnB,OAAO,EACP,cAAc,GACG;IACjB,OAAO,CACL,KAAC,SAAS,cACR,KAAC,UAAU,IACT,IAAI,EAAC,gBAAgB,EACrB,OAAO,EAAE,OAAO,EAChB,MAAM,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,EAAE,EAAE,EAAE,CAAC,CAC1C,KAAC,0BAA0B,IACzB,IAAI,EAAE,KAAK,CAAC,eAAe,EAC3B,YAAY,EAAE,CAAC,IAAI,EAAE,EAAE;oBACrB,QAAQ,CAAC,EAAE,GAAG,KAAK,EAAE,eAAe,EAAE,IAAI,EAAE,CAAC,CAAA;gBAC/C,CAAC,EACD,SAAS,EAAE,KAAK,CAAC,eAAe,EAChC,SAAS,EAAE,KAAK,CAAC,eAAe,KAC5B,cAAc,EAClB,iBAAiB,EAAE,CAAC,eAAe,EAAE,EAAE;oBACrC,QAAQ,CAAC;wBACP,GAAG,KAAK;wBACR,eAAe;qBAChB,CAAC,CAAA;gBACJ,CAAC,EACD,iBAAiB,EAAE,CAAC,eAAe,EAAE,EAAE;oBACrC,QAAQ,CAAC;wBACP,GAAG,KAAK;wBACR,eAAe;qBAChB,CAAC,CAAA;gBACJ,CAAC,GACD,CACH,GACD,GACQ,CACb,CAAA;AACH,CAAC;AAED,MAAM,CAAC,GAAG;IACR,cAAc,EAAE,iBAAiB;IACjC,wBAAwB,EAAE,oCAAoC;IAC9D,MAAM,EAAE,QAAQ;IAChB,IAAI,EAAE,MAAM;IACZ,IAAI,EAAE,MAAM;CACb,CAAA"}
@@ -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":";AAAA,OAAO,EAAgB,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAE1D,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAA;AAC7C,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAA;AAC5D,OAAO,EAAE,SAAS,EAAE,MAAM,gCAAgC,CAAA;AAC1D,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAA;AAEzC,OAAO,EAAE,cAAc,EAAE,MAAM,yCAAyC,CAAA;AACxE,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAA;AAC/C,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAA;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAA;AAC9D,OAAO,EAAE,SAAS,EAAE,MAAM,+BAA+B,CAAA;AAazD,MAAM,UAAU,yCAAyC,CAAC,EACxD,KAAK,EACL,OAAO,EACP,QAAQ,EACR,QAAQ,EACR,MAAM,EACN,QAAQ,EACR,MAAM,EACN,gBAAgB,GAC+B;IAC/C,MAAM,EAAE,MAAM,EAAE,GAAG,SAAS,CAAC;QAC3B,SAAS,EAAE,QAAQ;KACpB,CAAC,CAAA;IAEF,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,sDAAsD,YACnE,eAAK,SAAS,EAAC,cAAc,aAC3B,MAAC,SAAS,eACR,KAAC,UAAU,cAAE,CAAC,CAAC,cAAc,GAAc,EAC3C,KAAC,UAAU,IACT,IAAI,EAAC,MAAM,EACX,OAAO,EAAE,OAAO,EAChB,YAAY,EAAC,EAAE,EACf,MAAM,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE,EAAE,EAAE;gDACpD,OAAO,CACL,KAAC,SAAS,OACJ,KAAK,EACT,IAAI,EAAC,OAAO,EACZ,SAAS,QACT,QAAQ,EAAE,OAAO,EACjB,UAAU,EAAE,KAAK,EAAE,OAAO,GAC1B,CACH,CAAA;4CACH,CAAC,GACD,IACQ,EAEZ,MAAC,SAAS,eACR,KAAC,UAAU,cAAE,CAAC,CAAC,cAAc,GAAc,EAC3C,eAAK,SAAS,EAAC,gBAAgB,aAC7B,eAAM,SAAS,EAAC,YAAY,YAAE,CAAC,CAAC,qBAAqB,GAAQ,EAC7D,gBAAM,SAAS,EAAC,eAAe,EAAC,OAAO,EAAE,gBAAgB,aACtD,cAAc,CAAC,QAAQ,CAAC,EACzB,KAAC,gBAAgB,KAAG,IACf,IACH,EACN,KAAC,UAAU,IACT,IAAI,EAAC,WAAW,EAChB,OAAO,EAAE,OAAO,EAChB,YAAY,EAAC,EAAE,EACf,MAAM,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CACrB,KAAC,cAAc,OAAK,KAAK,EAAE,IAAI,EAAC,OAAO,GAAG,CAC3C,GACD,IACQ,EACZ,MAAC,SAAS,eACR,KAAC,UAAU,cAAE,CAAC,CAAC,YAAY,GAAc,EACzC,KAAC,UAAU,IACT,IAAI,EAAC,SAAS,EACd,OAAO,EAAE,OAAO,EAChB,YAAY,EAAC,EAAE,EACf,MAAM,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CACrB,KAAC,cAAc,OAAK,KAAK,EAAE,IAAI,EAAC,OAAO,GAAG,CAC3C,GACD,IACQ,IACR,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,mCAAmC;IACnD,cAAc,EAAE,YAAY;IAC5B,YAAY,EAAE,UAAU;IACxB,4BAA4B,EAAE,gCAAgC;IAC9D,MAAM,EAAE,QAAQ;IAChB,IAAI,EAAE,MAAM;IACZ,IAAI,EAAE,MAAM;IACZ,qBAAqB,EAAE,cAAc;CACtC,CAAA"}
@@ -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"}
@@ -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'
@@ -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
- }
@@ -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
- }
@@ -1,10 +0,0 @@
1
- import { DateTime } from 'luxon'
2
-
3
- export const formatDateTime = (date: string): string =>
4
- DateTime.fromISO(date).toLocaleString({
5
- month: 'short',
6
- day: 'numeric',
7
- hour: 'numeric',
8
- minute: '2-digit',
9
- timeZoneName: 'short',
10
- })