page.js 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271
  1. "use client";
  2. import { debounce } from "lodash";
  3. import { useEffect, useState } from "react";
  4. import { Collapse, Loader } from "tiny-ui";
  5. import { WLEDClient } from "wled-client";
  6. import { Layout, Management, Notification } from "components";
  7. import config from "data/config.json";
  8. import defaults from "data/presets.json";
  9. export default function Home() {
  10. const [names, setNames] = useState(null);
  11. const [clients, setClients] = useState(null);
  12. const [connections, setConnections] = useState(null);
  13. useEffect(() => {
  14. let t = [];
  15. let c = [];
  16. let n = [];
  17. for (let client of Object.keys(config)) {
  18. c.push(client);
  19. n.push(config[client]);
  20. t.push(new WLEDClient(client));
  21. }
  22. setClients(c);
  23. setConnections(t);
  24. setNames(n);
  25. }, []);
  26. const handleDefaults = async (payload) => {
  27. if (payload?.clients) {
  28. Notification({
  29. type: "loading",
  30. title: "Default presets installing",
  31. description: `Sending data to ${payload?.clients?.join(", ")}`
  32. });
  33. for (let client of payload.clients) {
  34. let indx = clients.findIndex((o) => o === client);
  35. if (connections[indx]) {
  36. let wled = connections[indx];
  37. for (let n of Object.keys(defaults)) {
  38. if (n && defaults?.[n]) {
  39. await wled.savePreset(n, defaults?.[n]);
  40. }
  41. }
  42. await wled.reinit();
  43. }
  44. Notification({
  45. type: "success",
  46. title: "Default presets installed",
  47. description: `Default presets installed on ${payload?.clients?.join(
  48. ", "
  49. )}`
  50. });
  51. }
  52. }
  53. };
  54. const handleCopy = async (payload) => {
  55. if (payload?.clients && payload?.value) {
  56. Notification({
  57. type: "loading",
  58. title: "Copying presets",
  59. description: `Sending data to ${payload?.clients?.join(", ")}`
  60. });
  61. for (let client of payload.clients) {
  62. let indx = clients.findIndex((o) => o === client);
  63. if (connections[indx]) {
  64. let wled = connections[indx];
  65. for (let n of Object.keys(payload?.value)) {
  66. if (n && payload?.value?.[n]) {
  67. console.log("handleCopy", n, payload?.value[n]);
  68. await wled.savePreset(n, payload?.value[n]);
  69. }
  70. }
  71. await wled.reinit();
  72. }
  73. }
  74. Notification({
  75. type: "success",
  76. title: "Presets copied",
  77. description: `Presets ${Object.keys(payload?.value)?.join(
  78. ", "
  79. )} copied to ${payload?.clients?.join(", ")}`
  80. });
  81. }
  82. };
  83. const handleDelete = async (payload) => {
  84. if (payload?.clients && payload?.value) {
  85. Notification({
  86. type: "loading",
  87. title: "Deleting presets",
  88. description: `Sending delete requests to ${payload?.clients?.join(
  89. ", "
  90. )}`
  91. });
  92. for (let client of payload?.clients) {
  93. let indx = clients.findIndex((o) => o === client);
  94. if (connections[indx]) {
  95. let wled = connections[indx];
  96. for (let n of payload?.value) {
  97. await wled.deletePreset(n);
  98. }
  99. await wled.reinit();
  100. }
  101. }
  102. Notification({
  103. type: "success",
  104. title: "Deleted presets",
  105. description: `Presets ${Object.keys(payload?.value)?.join(
  106. ", "
  107. )} deleted from ${payload?.clients?.join(", ")}`
  108. });
  109. }
  110. };
  111. const handleSync = async (payload) => {
  112. if (payload?.clients) {
  113. Notification({
  114. type: "loading",
  115. title: "Sync update",
  116. description: `Sending sync updates to ${payload?.clients?.join(", ")}`
  117. });
  118. for (let client of payload?.clients) {
  119. let indx = clients.findIndex((o) => o === client);
  120. if (connections[indx]) {
  121. let wled = connections[indx];
  122. switch (payload?.value) {
  123. case "enable":
  124. await wled.enableUDPSync({ send: true, receive: false });
  125. break;
  126. case "disable":
  127. await wled.disableUDPSync();
  128. break;
  129. }
  130. await wled.reinit();
  131. }
  132. }
  133. Notification({
  134. type: "success",
  135. title: `Sync ${payload?.value}`,
  136. description: `Sync ${payload?.value} on ${payload?.clients?.join(", ")}`
  137. });
  138. }
  139. };
  140. const handlePower = async (payload) => {
  141. if (payload?.clients && payload?.value) {
  142. Notification({
  143. type: "loading",
  144. title: "Power updates",
  145. description: `Sending power updates to ${payload?.clients?.join(", ")}`
  146. });
  147. for (let client of payload?.clients) {
  148. let indx = clients.findIndex((o) => o === client);
  149. if (connections[indx]) {
  150. let wled = connections[indx];
  151. switch (payload?.value) {
  152. case "on":
  153. await wled.turnOn();
  154. await wled.reinit();
  155. break;
  156. case "off":
  157. await wled.turnOff();
  158. await wled.reinit();
  159. break;
  160. case "toggle":
  161. await wled.toggle();
  162. await wled.reinit();
  163. break;
  164. case "reboot":
  165. await wled.reboot();
  166. setTimeout(async () => {
  167. await wled.reinit(true);
  168. }, 3000);
  169. break;
  170. }
  171. }
  172. }
  173. Notification({
  174. type: "success",
  175. title: `Power ${payload?.value}`,
  176. description: `Power ${payload?.value} run on ${payload?.clients?.join(
  177. ", "
  178. )}`
  179. });
  180. }
  181. };
  182. const handleBrightness = async (payload) => {
  183. if (payload?.clients && payload?.value) {
  184. Notification({
  185. type: "loading",
  186. title: "Adjusting brightness",
  187. description: `Adjusting brightness on ${payload?.clients?.join(", ")}`
  188. });
  189. for (let client of payload?.clients) {
  190. let indx = clients.findIndex((o) => o === client);
  191. if (connections[indx]) {
  192. let wled = connections[indx];
  193. await wled.setBrightness(payload?.value);
  194. await wled.reinit();
  195. }
  196. }
  197. Notification({
  198. type: "success",
  199. title: `Brightness set`,
  200. description: `Brightness set to ${
  201. payload?.value
  202. } on ${payload?.clients?.join(", ")}`
  203. });
  204. }
  205. };
  206. const debounceHandleBrightness = debounce(handleBrightness, 500);
  207. const handlePreset = async (payload) => {
  208. if (payload?.clients && payload?.value) {
  209. Notification({
  210. type: "loading",
  211. title: "Setting preset",
  212. description: `Setting preset on ${payload?.clients?.join(", ")}`
  213. });
  214. for (let client of payload?.clients) {
  215. let indx = clients.findIndex((o) => o === client);
  216. if (connections[indx]) {
  217. let wled = connections[indx];
  218. await wled.setPreset(payload?.value);
  219. await wled.reinit();
  220. }
  221. }
  222. Notification({
  223. type: "success",
  224. title: `Preset set`,
  225. description: `Preset set to ${
  226. payload?.value
  227. } on ${payload?.clients?.join(", ")}`
  228. });
  229. }
  230. };
  231. return (
  232. <Layout page="home">
  233. {(connections && clients && (
  234. <Collapse bordered={false}>
  235. {clients?.map((o, i) => (
  236. <Management
  237. key={i + 1}
  238. itemKey={`${i + 1}`}
  239. clients={clients}
  240. client={o}
  241. clientName={names[i]}
  242. connection={connections[i]}
  243. onCopy={handleCopy}
  244. onDelete={handleDelete}
  245. onSync={handleSync}
  246. onPower={handlePower}
  247. onBrightness={debounceHandleBrightness}
  248. onPreset={handlePreset}
  249. onDefaults={handleDefaults}
  250. />
  251. ))}
  252. </Collapse>
  253. )) || <Loader size="lg" />}
  254. </Layout>
  255. );
  256. return;
  257. }