blue-chestnut-solar-expert 0.0.68 → 0.0.69

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 (329) hide show
  1. package/dist/cjs/app-globals-I24yU8do.js +10 -0
  2. package/dist/cjs/app-globals-I24yU8do.js.map +1 -0
  3. package/dist/cjs/basedecoder-CQuzfSgz.js +116 -0
  4. package/dist/cjs/basedecoder-CQuzfSgz.js.map +1 -0
  5. package/dist/cjs/deflate-AzGzQSW2.js +17 -0
  6. package/dist/cjs/deflate-AzGzQSW2.js.map +1 -0
  7. package/dist/cjs/eraser-icon_19.cjs.entry.js +31 -0
  8. package/dist/cjs/eraser-icon_19.cjs.entry.js.map +1 -0
  9. package/dist/cjs/index-HgRXF6kp.js +1470 -0
  10. package/dist/cjs/index-HgRXF6kp.js.map +1 -0
  11. package/dist/cjs/index.cjs.js +7 -0
  12. package/dist/cjs/index.cjs.js.map +1 -0
  13. package/dist/cjs/jpeg-Bx3bTm32.js +904 -0
  14. package/dist/cjs/jpeg-Bx3bTm32.js.map +1 -0
  15. package/dist/cjs/lerc-Bdx5y-yw.js +4427 -0
  16. package/dist/cjs/lerc-Bdx5y-yw.js.map +1 -0
  17. package/dist/cjs/loader.cjs.js +18 -0
  18. package/dist/cjs/loader.cjs.js.map +1 -0
  19. package/dist/cjs/loading-widget.cjs.entry.js +22 -0
  20. package/dist/{stencil-library/polygon-information.entry.esm.js.map → cjs/loading-widget.cjs.entry.js.map} +1 -1
  21. package/dist/cjs/loading-widget.entry.cjs.js.map +1 -0
  22. package/dist/cjs/lzw-BmFug486.js +140 -0
  23. package/dist/cjs/lzw-BmFug486.js.map +1 -0
  24. package/dist/cjs/packbits-CYx9fB0v.js +35 -0
  25. package/dist/cjs/packbits-CYx9fB0v.js.map +1 -0
  26. package/dist/cjs/pako.esm-0mKI6Jik.js +3243 -0
  27. package/dist/cjs/pako.esm-0mKI6Jik.js.map +1 -0
  28. package/dist/cjs/raw-DC82yoyr.js +16 -0
  29. package/dist/cjs/raw-DC82yoyr.js.map +1 -0
  30. package/dist/cjs/stencil-library.cjs.js +30 -0
  31. package/dist/cjs/stencil-library.cjs.js.map +1 -0
  32. package/dist/cjs/webimage-Dc0t2xAB.js +49 -0
  33. package/dist/cjs/webimage-Dc0t2xAB.js.map +1 -0
  34. package/dist/collection/collection-manifest.json +31 -0
  35. package/dist/collection/components/icons/eraser.js +64 -0
  36. package/dist/collection/components/icons/eraser.js.map +1 -0
  37. package/dist/collection/components/icons/house.js +64 -0
  38. package/dist/collection/components/icons/house.js.map +1 -0
  39. package/dist/collection/components/icons/icon.js +108 -0
  40. package/dist/collection/components/icons/icon.js.map +1 -0
  41. package/dist/collection/components/icons/marker.js +64 -0
  42. package/dist/collection/components/icons/marker.js.map +1 -0
  43. package/dist/collection/components/icons/move.js +64 -0
  44. package/dist/collection/components/icons/move.js.map +1 -0
  45. package/dist/collection/components/icons/octagonMinus.js +64 -0
  46. package/dist/collection/components/icons/octagonMinus.js.map +1 -0
  47. package/dist/collection/components/icons/search.js +64 -0
  48. package/dist/collection/components/icons/search.js.map +1 -0
  49. package/dist/collection/components/icons/settings.js +64 -0
  50. package/dist/collection/components/icons/settings.js.map +1 -0
  51. package/dist/collection/components/icons/undo.js +64 -0
  52. package/dist/collection/components/icons/undo.js.map +1 -0
  53. package/dist/collection/components/map-draw/map-draw.js +824 -0
  54. package/dist/collection/components/map-draw/map-draw.js.map +1 -0
  55. package/dist/collection/components/map-draw/map-selector.js +246 -0
  56. package/dist/collection/components/map-draw/map-selector.js.map +1 -0
  57. package/dist/collection/components/map-draw/polygon-buttons.js +86 -0
  58. package/dist/collection/components/map-draw/polygon-buttons.js.map +1 -0
  59. package/dist/collection/components/map-draw/polygon-information.js +211 -0
  60. package/dist/collection/components/map-draw/polygon-information.js.map +1 -0
  61. package/dist/collection/components/map-draw/tool-box.js +108 -0
  62. package/dist/collection/components/map-draw/tool-box.js.map +1 -0
  63. package/dist/collection/components/map-draw/tutorial-component.js +219 -0
  64. package/dist/collection/components/map-draw/tutorial-component.js.map +1 -0
  65. package/dist/collection/components/settings/settings.js +127 -0
  66. package/dist/collection/components/settings/settings.js.map +1 -0
  67. package/dist/collection/components/solar-expert/solar-expert.js +241 -0
  68. package/dist/collection/components/solar-expert/solar-expert.js.map +1 -0
  69. package/dist/collection/components/solar-system-form/solar-system-form.js +617 -0
  70. package/dist/collection/components/solar-system-form/solar-system-form.js.map +1 -0
  71. package/dist/collection/components/widgets/loading-widget.js +18 -0
  72. package/dist/collection/components/widgets/loading-widget.js.map +1 -0
  73. package/dist/collection/components/widgets/toast-notification.js +133 -0
  74. package/dist/collection/components/widgets/toast-notification.js.map +1 -0
  75. package/dist/{stencil-library/config-CWfV1nKn.js → collection/config.js} +4 -10
  76. package/dist/collection/config.js.map +1 -0
  77. package/dist/collection/constants.js +90 -0
  78. package/dist/collection/constants.js.map +1 -0
  79. package/dist/collection/index.js +2 -0
  80. package/dist/collection/index.js.map +1 -0
  81. package/dist/collection/output.css +1126 -0
  82. package/dist/collection/store.js +43 -0
  83. package/dist/collection/store.js.map +1 -0
  84. package/dist/collection/types/lang.js +2 -0
  85. package/dist/collection/types/lang.js.map +1 -0
  86. package/dist/collection/types/shapes.js +2 -0
  87. package/dist/collection/types/shapes.js.map +1 -0
  88. package/dist/collection/utils/api.js +94 -0
  89. package/dist/collection/utils/api.js.map +1 -0
  90. package/dist/collection/utils/images.js +2 -0
  91. package/dist/collection/utils/images.js.map +1 -0
  92. package/dist/collection/utils/lang/english.js +164 -0
  93. package/dist/collection/utils/lang/english.js.map +1 -0
  94. package/dist/collection/utils/lang/general.js +30 -0
  95. package/dist/collection/utils/lang/general.js.map +1 -0
  96. package/dist/collection/utils/lang/german.js +164 -0
  97. package/dist/collection/utils/lang/german.js.map +1 -0
  98. package/dist/collection/utils/lang/spanish.js +164 -0
  99. package/dist/collection/utils/lang/spanish.js.map +1 -0
  100. package/dist/{stencil-library/tools-BNYKV5H5.js → collection/utils/render/tools.js} +8 -14
  101. package/dist/collection/utils/render/tools.js.map +1 -0
  102. package/dist/collection/utils/solar.js +135 -0
  103. package/dist/collection/utils/solar.js.map +1 -0
  104. package/dist/collection/utils/theme.js +97 -0
  105. package/dist/collection/utils/theme.js.map +1 -0
  106. package/dist/{stencil-library/utils-BCUZxI9u.js → collection/utils/utils.js} +3 -9
  107. package/dist/collection/utils/utils.js.map +1 -0
  108. package/dist/components/eraser-icon.js +11 -0
  109. package/dist/components/eraser-icon.js.map +1 -0
  110. package/dist/components/house-icon.js +11 -0
  111. package/dist/components/house-icon.js.map +1 -0
  112. package/dist/components/icon-selector.js +11 -0
  113. package/dist/components/icon-selector.js.map +1 -0
  114. package/dist/components/index.js +1269 -0
  115. package/dist/components/index.js.map +1 -0
  116. package/dist/components/loading-widget.js +38 -0
  117. package/dist/{stencil-library/marker-icon.entry.esm.js.map → components/loading-widget.js.map} +1 -1
  118. package/dist/components/map-draw.js +11 -0
  119. package/dist/components/map-draw.js.map +1 -0
  120. package/dist/components/map-selector.js +11 -0
  121. package/dist/components/map-selector.js.map +1 -0
  122. package/dist/components/marker-icon.js +11 -0
  123. package/dist/components/marker-icon.js.map +1 -0
  124. package/dist/components/move-icon.js +11 -0
  125. package/dist/components/move-icon.js.map +1 -0
  126. package/dist/components/octagon-minus-icon.js +11 -0
  127. package/dist/components/octagon-minus-icon.js.map +1 -0
  128. package/dist/{stencil-library/polygon-buttons.entry.js → components/p-26DHwbCE.js} +29 -10
  129. package/dist/{stencil-library/solar-expert.entry.js.map → components/p-26DHwbCE.js.map} +1 -1
  130. package/dist/components/p-B54Ul0nf.js +15 -0
  131. package/dist/components/p-B54Ul0nf.js.map +1 -0
  132. package/dist/components/p-B5WTRCh8.js +3241 -0
  133. package/dist/components/p-B5WTRCh8.js.map +1 -0
  134. package/dist/{stencil-library/jpeg-Dd5nnHR5.js → components/p-BGoSj_DR.js} +3 -11
  135. package/dist/components/p-BGoSj_DR.js.map +1 -0
  136. package/dist/{stencil-library/octagon-minus-icon.entry.js → components/p-BJLO76Yi.js} +27 -9
  137. package/dist/components/p-BJLO76Yi.js.map +1 -0
  138. package/dist/components/p-BOe-Z8rz.js +16323 -0
  139. package/dist/components/p-BOe-Z8rz.js.map +1 -0
  140. package/dist/{stencil-library/map-selector.entry.js → components/p-Bduzzygj.js} +453 -12
  141. package/dist/components/p-Bduzzygj.js.map +1 -0
  142. package/dist/{stencil-library/packbits-X3R_utTs.js → components/p-ByX6QP-E.js} +3 -9
  143. package/dist/components/p-ByX6QP-E.js.map +1 -0
  144. package/dist/{stencil-library/solar-system-form.entry.js → components/p-C3ZXE525.js} +382 -80
  145. package/dist/components/p-C3ZXE525.js.map +1 -0
  146. package/dist/{stencil-library/icon-selector.entry.js → components/p-C5QieOat.js} +76 -9
  147. package/dist/components/p-C5QieOat.js.map +1 -0
  148. package/dist/{stencil-library/eraser-icon.entry.js → components/p-CL74Q4VR.js} +27 -9
  149. package/dist/components/p-CL74Q4VR.js.map +1 -0
  150. package/dist/{stencil-library/webimage-CBrfoxHM.js → components/p-Cgchl6bA.js} +3 -9
  151. package/dist/components/p-Cgchl6bA.js.map +1 -0
  152. package/dist/{stencil-library/tool-box.entry.js → components/p-Cx7fffWb.js} +135 -11
  153. package/dist/components/p-Cx7fffWb.js.map +1 -0
  154. package/dist/{stencil-library/tutorial-component.entry.js → components/p-D2AHNjbG.js} +35 -10
  155. package/dist/{stencil-library/toast-notification.entry.esm.js.map → components/p-D2AHNjbG.js.map} +1 -1
  156. package/dist/{stencil-library/house-icon.entry.js → components/p-D8w3bTPO.js} +27 -9
  157. package/dist/components/p-D8w3bTPO.js.map +1 -0
  158. package/dist/{stencil-library/search-icon.entry.js → components/p-DBwr8xSB.js} +27 -9
  159. package/dist/components/p-DBwr8xSB.js.map +1 -0
  160. package/dist/{stencil-library/lerc-7W4E8EBs.js → components/p-DLWzgdrw.js} +1981 -27
  161. package/dist/components/p-DLWzgdrw.js.map +1 -0
  162. package/dist/{stencil-library/settings-icon.entry.js → components/p-DTXeHbuh.js} +27 -9
  163. package/dist/{stencil-library/octagon-minus-icon.entry.esm.js.map → components/p-DTXeHbuh.js.map} +1 -1
  164. package/dist/{stencil-library/settings-modal.entry.js → components/p-Ddk3b30j.js} +30 -12
  165. package/dist/{stencil-library/polygon-buttons.entry.esm.js.map → components/p-Ddk3b30j.js.map} +1 -1
  166. package/dist/{stencil-library/store-CcqrFuBK.js → components/p-DfzSejIb.js} +3 -3
  167. package/dist/components/p-DfzSejIb.js.map +1 -0
  168. package/dist/{stencil-library/move-icon.entry.js → components/p-FdEV2qPo.js} +27 -9
  169. package/dist/components/p-FdEV2qPo.js.map +1 -0
  170. package/dist/{stencil-library/polygon-information.entry.js → components/p-OxUYjaAL.js} +68 -11
  171. package/dist/components/p-OxUYjaAL.js.map +1 -0
  172. package/dist/{stencil-library/toast-notification.entry.js → components/p-P28NBglk.js} +30 -9
  173. package/dist/{stencil-library/loading-widget.entry.js.map → components/p-P28NBglk.js.map} +1 -1
  174. package/dist/{stencil-library/marker-icon.entry.js → components/p-Umz6nJIv.js} +27 -9
  175. package/dist/components/p-Umz6nJIv.js.map +1 -0
  176. package/dist/components/p-WmcSqXD8.js +14 -0
  177. package/dist/components/p-WmcSqXD8.js.map +1 -0
  178. package/dist/components/p-j-vOrhhh.js +114 -0
  179. package/dist/components/p-j-vOrhhh.js.map +1 -0
  180. package/dist/{stencil-library/lzw--P4c0ZHH.js → components/p-q8auDIJ2.js} +4 -10
  181. package/dist/components/p-q8auDIJ2.js.map +1 -0
  182. package/dist/{stencil-library/undo-icon.entry.js → components/p-waOPoUcA.js} +27 -9
  183. package/dist/components/p-waOPoUcA.js.map +1 -0
  184. package/dist/components/polygon-buttons.js +11 -0
  185. package/dist/components/polygon-buttons.js.map +1 -0
  186. package/dist/components/polygon-information.js +11 -0
  187. package/dist/components/polygon-information.js.map +1 -0
  188. package/dist/components/search-icon.js +11 -0
  189. package/dist/components/search-icon.js.map +1 -0
  190. package/dist/components/settings-icon.js +11 -0
  191. package/dist/components/settings-icon.js.map +1 -0
  192. package/dist/components/settings-modal.js +11 -0
  193. package/dist/components/settings-modal.js.map +1 -0
  194. package/dist/{stencil-library/solar-expert.entry.js → components/solar-expert.js} +149 -13
  195. package/dist/components/solar-expert.js.map +1 -0
  196. package/dist/components/solar-system-form.js +11 -0
  197. package/dist/components/solar-system-form.js.map +1 -0
  198. package/dist/components/toast-notification.js +11 -0
  199. package/dist/components/toast-notification.js.map +1 -0
  200. package/dist/components/tool-box.js +11 -0
  201. package/dist/components/tool-box.js.map +1 -0
  202. package/dist/components/tutorial-component.js +11 -0
  203. package/dist/components/tutorial-component.js.map +1 -0
  204. package/dist/components/undo-icon.js +11 -0
  205. package/dist/components/undo-icon.js.map +1 -0
  206. package/dist/esm/basedecoder-j-vOrhhh.js +114 -0
  207. package/dist/esm/basedecoder-j-vOrhhh.js.map +1 -0
  208. package/dist/esm/deflate-DHgPf9CO.js +15 -0
  209. package/dist/{stencil-library/deflate-0Vdd6-55.js.map → esm/deflate-DHgPf9CO.js.map} +1 -1
  210. package/dist/esm/eraser-icon_19.entry.js +7 -0
  211. package/dist/esm/eraser-icon_19.entry.js.map +1 -0
  212. package/dist/esm/index-C2JRBB5c.js +1458 -0
  213. package/dist/esm/index-C2JRBB5c.js.map +1 -0
  214. package/dist/esm/index.js +5 -0
  215. package/dist/esm/index.js.map +1 -0
  216. package/dist/esm/jpeg-CJLm1GkA.js +902 -0
  217. package/dist/esm/jpeg-CJLm1GkA.js.map +1 -0
  218. package/dist/esm/lerc-DF5Lrv5A.js +4424 -0
  219. package/dist/esm/lerc-DF5Lrv5A.js.map +1 -0
  220. package/dist/esm/loader.js +16 -0
  221. package/dist/esm/loader.js.map +1 -0
  222. package/dist/{stencil-library → esm}/loading-widget.entry.js +2 -2
  223. package/dist/esm/loading-widget.entry.js.map +1 -0
  224. package/dist/esm/lzw-DaOzWJUD.js +138 -0
  225. package/dist/esm/lzw-DaOzWJUD.js.map +1 -0
  226. package/dist/esm/packbits-CZPyx9kx.js +33 -0
  227. package/dist/esm/packbits-CZPyx9kx.js.map +1 -0
  228. package/dist/esm/pako.esm-B5WTRCh8.js +3241 -0
  229. package/dist/{stencil-library/pako.esm-CPorU236.js.map → esm/pako.esm-B5WTRCh8.js.map} +1 -1
  230. package/dist/esm/raw-pqeeWc2_.js +14 -0
  231. package/dist/esm/raw-pqeeWc2_.js.map +1 -0
  232. package/dist/esm/stencil-library.js +26 -0
  233. package/dist/esm/stencil-library.js.map +1 -0
  234. package/dist/esm/webimage-BiHardhv.js +47 -0
  235. package/dist/{stencil-library/webimage-CBrfoxHM.js.map → esm/webimage-BiHardhv.js.map} +1 -1
  236. package/dist/index.cjs.js +1 -0
  237. package/dist/index.js +1 -0
  238. package/dist/stencil-library/index.esm.js +1 -13
  239. package/dist/stencil-library/index.esm.js.map +1 -1
  240. package/dist/stencil-library/{search-icon.entry.js.map → p-9b4e52c3.entry.js} +2 -1
  241. package/dist/stencil-library/p-9b4e52c3.entry.js.map +1 -0
  242. package/dist/stencil-library/p-B54Ul0nf.js +2 -0
  243. package/dist/stencil-library/p-B54Ul0nf.js.map +1 -0
  244. package/dist/stencil-library/p-B5WTRCh8.js +2 -0
  245. package/dist/stencil-library/p-B5WTRCh8.js.map +1 -0
  246. package/dist/stencil-library/p-BGoSj_DR.js +2 -0
  247. package/dist/stencil-library/p-BGoSj_DR.js.map +1 -0
  248. package/dist/stencil-library/p-ByX6QP-E.js +2 -0
  249. package/dist/stencil-library/p-ByX6QP-E.js.map +1 -0
  250. package/dist/stencil-library/p-C2JRBB5c.js +3 -0
  251. package/dist/stencil-library/p-C2JRBB5c.js.map +1 -0
  252. package/dist/stencil-library/p-CX8V3eiN.js +2 -0
  253. package/dist/stencil-library/p-CX8V3eiN.js.map +1 -0
  254. package/dist/stencil-library/p-Cgchl6bA.js +2 -0
  255. package/dist/stencil-library/p-Cgchl6bA.js.map +1 -0
  256. package/dist/stencil-library/p-CymYGBJH.js +2 -0
  257. package/dist/stencil-library/p-CymYGBJH.js.map +1 -0
  258. package/dist/stencil-library/p-DHgjDQwz.js +10 -0
  259. package/dist/stencil-library/p-DHgjDQwz.js.map +1 -0
  260. package/dist/stencil-library/p-WmcSqXD8.js +2 -0
  261. package/dist/stencil-library/p-WmcSqXD8.js.map +1 -0
  262. package/dist/stencil-library/p-ba64c5e4.entry.js +2 -0
  263. package/dist/stencil-library/p-ba64c5e4.entry.js.map +1 -0
  264. package/dist/stencil-library/p-j-vOrhhh.js +2 -0
  265. package/dist/stencil-library/p-j-vOrhhh.js.map +1 -0
  266. package/dist/stencil-library/p-q8auDIJ2.js +2 -0
  267. package/dist/stencil-library/p-q8auDIJ2.js.map +1 -0
  268. package/dist/stencil-library/stencil-library.esm.js +1 -52
  269. package/dist/stencil-library/stencil-library.esm.js.map +1 -1
  270. package/dist/types/components/solar-system-form/solar-system-form.d.ts +1 -0
  271. package/dist/types/components.d.ts +2 -0
  272. package/dist/types/utils/api.d.ts +1 -0
  273. package/package.json +1 -1
  274. package/dist/stencil-library/config-CWfV1nKn.js.map +0 -1
  275. package/dist/stencil-library/constants-hboFofU4.js +0 -1522
  276. package/dist/stencil-library/constants-hboFofU4.js.map +0 -1
  277. package/dist/stencil-library/decoder-DNOvLSaS.js +0 -39
  278. package/dist/stencil-library/decoder-DNOvLSaS.js.map +0 -1
  279. package/dist/stencil-library/deflate-0Vdd6-55.js +0 -21
  280. package/dist/stencil-library/eraser-icon.entry.esm.js.map +0 -1
  281. package/dist/stencil-library/eraser-icon.entry.js.map +0 -1
  282. package/dist/stencil-library/house-icon.entry.esm.js.map +0 -1
  283. package/dist/stencil-library/house-icon.entry.js.map +0 -1
  284. package/dist/stencil-library/icon-selector.entry.esm.js.map +0 -1
  285. package/dist/stencil-library/icon-selector.entry.js.map +0 -1
  286. package/dist/stencil-library/index-CChkgM3J.js +0 -414
  287. package/dist/stencil-library/index-CChkgM3J.js.map +0 -1
  288. package/dist/stencil-library/index-ICfDNUMe.js +0 -4172
  289. package/dist/stencil-library/index-ICfDNUMe.js.map +0 -1
  290. package/dist/stencil-library/jpeg-Dd5nnHR5.js.map +0 -1
  291. package/dist/stencil-library/lerc-7W4E8EBs.js.map +0 -1
  292. package/dist/stencil-library/lzw--P4c0ZHH.js.map +0 -1
  293. package/dist/stencil-library/map-draw-Cx9WZoKH.js +0 -25567
  294. package/dist/stencil-library/map-draw-Cx9WZoKH.js.map +0 -1
  295. package/dist/stencil-library/map-draw.entry.esm.js.map +0 -1
  296. package/dist/stencil-library/map-draw.entry.js +0 -12
  297. package/dist/stencil-library/map-draw.entry.js.map +0 -1
  298. package/dist/stencil-library/map-selector.entry.esm.js.map +0 -1
  299. package/dist/stencil-library/map-selector.entry.js.map +0 -1
  300. package/dist/stencil-library/marker-icon.entry.js.map +0 -1
  301. package/dist/stencil-library/move-icon.entry.esm.js.map +0 -1
  302. package/dist/stencil-library/move-icon.entry.js.map +0 -1
  303. package/dist/stencil-library/octagon-minus-icon.entry.js.map +0 -1
  304. package/dist/stencil-library/packbits-X3R_utTs.js.map +0 -1
  305. package/dist/stencil-library/pako.esm-CPorU236.js +0 -6881
  306. package/dist/stencil-library/polygon-buttons.entry.js.map +0 -1
  307. package/dist/stencil-library/polygon-information.entry.js.map +0 -1
  308. package/dist/stencil-library/raw-BxukYehy.js +0 -20
  309. package/dist/stencil-library/raw-BxukYehy.js.map +0 -1
  310. package/dist/stencil-library/search-icon.entry.esm.js.map +0 -1
  311. package/dist/stencil-library/settings-icon.entry.esm.js.map +0 -1
  312. package/dist/stencil-library/settings-icon.entry.js.map +0 -1
  313. package/dist/stencil-library/settings-modal.entry.esm.js.map +0 -1
  314. package/dist/stencil-library/settings-modal.entry.js.map +0 -1
  315. package/dist/stencil-library/solar-expert.entry.esm.js.map +0 -1
  316. package/dist/stencil-library/solar-system-form.entry.esm.js.map +0 -1
  317. package/dist/stencil-library/solar-system-form.entry.js.map +0 -1
  318. package/dist/stencil-library/store-CcqrFuBK.js.map +0 -1
  319. package/dist/stencil-library/toast-notification.entry.js.map +0 -1
  320. package/dist/stencil-library/tool-box.entry.esm.js.map +0 -1
  321. package/dist/stencil-library/tool-box.entry.js.map +0 -1
  322. package/dist/stencil-library/tools-BNYKV5H5.js.map +0 -1
  323. package/dist/stencil-library/tutorial-component.entry.esm.js.map +0 -1
  324. package/dist/stencil-library/tutorial-component.entry.js.map +0 -1
  325. package/dist/stencil-library/undo-icon.entry.esm.js.map +0 -1
  326. package/dist/stencil-library/undo-icon.entry.js.map +0 -1
  327. package/dist/stencil-library/utils-BCUZxI9u.js.map +0 -1
  328. /package/dist/{stencil-library → esm}/app-globals-CX8V3eiN.js +0 -0
  329. /package/dist/{stencil-library → esm}/app-globals-CX8V3eiN.js.map +0 -0
@@ -0,0 +1,127 @@
1
+ import { h } from "@stencil/core";
2
+ import { state } from "../../store";
3
+ import { getLanguageStrings } from "../../utils/lang/general";
4
+ export class SettingsModal {
5
+ settings;
6
+ tempSettings;
7
+ close;
8
+ save;
9
+ componentWillLoad() {
10
+ this.tempSettings = { ...this.settings };
11
+ }
12
+ handleClose = () => {
13
+ if (JSON.stringify(this.tempSettings) !== JSON.stringify(this.settings)) {
14
+ if (confirm("Are you sure you want to close without saving your changes?")) {
15
+ this.close.emit();
16
+ }
17
+ }
18
+ else {
19
+ this.close.emit();
20
+ }
21
+ };
22
+ handleSave = () => {
23
+ this.save.emit(this.tempSettings);
24
+ this.close.emit();
25
+ };
26
+ handleInputChange = (key, value) => {
27
+ this.tempSettings = {
28
+ ...this.tempSettings,
29
+ [key]: value,
30
+ };
31
+ };
32
+ render() {
33
+ const t = getLanguageStrings(state.settings.language);
34
+ return (h("div", { key: '0e3c77d79dee06a39d41ea8e54808ae7d2dfbc20', class: "fixed inset-0 bg-black bg-opacity-50 flex items-center justify-center z-50" }, h("div", { key: '89bb78aa78d726b26167672f28e9092291fe50a6', class: "bg-primary rounded-4xl p-6 w-full max-w-md" }, h("div", { key: '7a627d2cb08cd2fe4ed2d972c970593ebad902b4', class: "flex justify-between items-center mb-6" }, h("h2", { key: '1e0b97819493f28da6e7347e66d9dd91085bfde9', class: "text-xl font-semibold" }, "Settings"), h("button", { key: 'cdaca129254e415958d35ab25104562fe2742982', class: "p-2 hover:bg-hover rounded-full transition-colors", onClick: this.handleClose }, h("svg", { key: '9d45841f50089683c0e27c7cf87b0cc9f9c6b08f', xmlns: "http://www.w3.org/2000/svg", width: "24", height: "24", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", "stroke-width": "2", "stroke-linecap": "round", "stroke-linejoin": "round" }, h("line", { key: '52a7f53b7ee2fd1428708a7082f4b8ad82337cf2', x1: "18", y1: "6", x2: "6", y2: "18" }), h("line", { key: 'b3d0a74200fbca9bc2bc64ab7f0daa8cb63e8e8f', x1: "6", y1: "6", x2: "18", y2: "18" })))), h("div", { key: 'b632724625ef74b606b70586c0eab14f81ca6539', class: "space-y-4" }, h("div", { key: '5a15f11410211da1e5b1765d3b8254d9cb57331e' }, h("h3", { key: '5739e208a3f4656667b615cfe34e973ce57a3d8c', class: "text-sm font-medium text-text-muted mb-1" }, "Debug Information"), h("p", { key: 'e9351c9800425f2d2e3d8e9d262e75b9a55e5e6f', class: "text-sm text-text-muted mb-1" }, "state: ", JSON.stringify(state, null, 2)), h("p", { key: 'efd907bfe97e4372de78effde2529f9e6dce1de9', class: "text-sm text-text-muted mb-1" }, navigator.userAgent), h("p", { key: '2c1f03415528788ac4a122c9c4330d64642436a0', class: "text-sm text-text-muted mb-1" }, navigator.userAgent.indexOf("Safari")), h("p", { key: 'a5a2d0b3cd81f81fbf8efeef400e9ba4ed49be91', class: "text-sm text-text-muted mb-1" }, "maxTouchPoints: ", navigator.maxTouchPoints), h("p", { key: '84b20c7d094cc4fbadf79b35ff5070b71ef95a2b', class: "text-sm text-text-muted mb-1" }, "iPhone: ", navigator.userAgent.indexOf("iPhone")), h("p", { key: '0291e3fa7c2d5f3537d8be9cd22a3ae17c7e3996', class: "text-sm text-text-muted mb-1" }, "Mac OS: ", navigator.userAgent.indexOf("Mac OS"))), h("div", { key: '6e9d555787ee2460a3e5a7044c5583862fbbdb37' }, h("label", { key: '666b69e114688801fe718200e94f330b4f66bb4a', class: "block text-sm font-medium text-text-muted mb-1" }, t.settings.language), h("select", { key: 'b0dc0f28d16c983cadb33a0ed44a921ba7e2a765', class: "w-full bg-muted rounded-4xl p-2", onInput: (e) => this.handleInputChange("language", e.target
35
+ .value) }, h("option", { key: '997a1f570e1a477d515817b692950921b33df0d0', value: "en", selected: this.tempSettings.language ===
36
+ "en" }, "English"), h("option", { key: 'aef384455e1f8880602fdcd77a36ec6a1e49d4e2', value: "es", selected: this.tempSettings.language ===
37
+ "es" }, "Espa\u00F1ol"), h("option", { key: 'af08a8d991f69d1903b6cb198a3429eea4f1d95e', value: "de", selected: this.tempSettings.language ===
38
+ "de" }, "Deutsch"))), h("div", { key: '896ea8e61e6a4dec8c534bc42f71c4437b058c24' }, h("label", { key: '4d7c46a60f2f67ef8249f86f7762835b48ef4da3', class: "block text-sm font-medium text-text-muted mb-1" }, t.settings.rowSpacing), h("input", { key: 'abb0c8b9929745c8e066ceca3eca12f9de3c5496', type: "number", class: "w-full bg-muted rounded-4xl p-2", value: this.tempSettings.rowSpacing, onInput: (e) => this.handleInputChange("rowSpacing", parseFloat(e.target
39
+ .value)) })), h("div", { key: 'f671fce6864d0e187c0f814af1611c427e261c98' }, h("label", { key: '6859ffb44db1516c7e7cd5820c188814fcc34443', class: "block text-sm font-medium text-text-muted mb-1" }, t.settings.columnSpacing), h("input", { key: 'c9ebe64451106e9a45e13f909e4f26e571d83f82', type: "number", class: "w-full bg-muted rounded-4xl p-2", value: this.tempSettings.columnSpacing, onInput: (e) => this.handleInputChange("columnSpacing", parseFloat(e.target
40
+ .value)) })), h("div", { key: 'bb2454aeeaf6f924e59829d321210939de94ca5a' }, h("label", { key: '5929ad97adbf3048cba137de29e24c4cf13e13bc', class: "block text-sm font-medium text-text-muted mb-1" }, t.settings.borderInset), h("input", { key: '064deb239020bc56fbd810de4438b5e3418c16d6', type: "number", class: "w-full bg-muted rounded-4xl p-2", value: this.tempSettings.borderInset, onInput: (e) => this.handleInputChange("borderInset", parseFloat(e.target
41
+ .value)) }))), h("div", { key: 'e9397a36adde815afea3b1855ad9d7cf422a6cf7', class: "flex justify-end gap-4 mt-6" }, h("button", { key: '25a764283801fabf1cb42ac7e3cc36a53ecdc1d8', class: "px-4 py-2 bg-surface rounded-4xl hover:bg-surface-hover transition-colors", onClick: this.handleClose }, "Cancel"), h("button", { key: '74ed7467fe3476f6fa4b82d56aba6f29350a7b87', class: "px-4 py-2 bg-secondary text-muted rounded-4xl hover:bg-text-secondary transition-colors", onClick: this.handleSave }, "Save Changes")))));
42
+ }
43
+ static get is() { return "settings-modal"; }
44
+ static get originalStyleUrls() {
45
+ return {
46
+ "$": ["../../output.css"]
47
+ };
48
+ }
49
+ static get styleUrls() {
50
+ return {
51
+ "$": ["../../output.css"]
52
+ };
53
+ }
54
+ static get properties() {
55
+ return {
56
+ "settings": {
57
+ "type": "unknown",
58
+ "attribute": "settings",
59
+ "mutable": false,
60
+ "complexType": {
61
+ "original": "Settings",
62
+ "resolved": "Settings",
63
+ "references": {
64
+ "Settings": {
65
+ "location": "import",
66
+ "path": "../../store",
67
+ "id": "src/store.ts::Settings"
68
+ }
69
+ }
70
+ },
71
+ "required": false,
72
+ "optional": false,
73
+ "docs": {
74
+ "tags": [],
75
+ "text": ""
76
+ },
77
+ "getter": false,
78
+ "setter": false
79
+ }
80
+ };
81
+ }
82
+ static get states() {
83
+ return {
84
+ "tempSettings": {}
85
+ };
86
+ }
87
+ static get events() {
88
+ return [{
89
+ "method": "close",
90
+ "name": "close",
91
+ "bubbles": true,
92
+ "cancelable": true,
93
+ "composed": true,
94
+ "docs": {
95
+ "tags": [],
96
+ "text": ""
97
+ },
98
+ "complexType": {
99
+ "original": "void",
100
+ "resolved": "void",
101
+ "references": {}
102
+ }
103
+ }, {
104
+ "method": "save",
105
+ "name": "save",
106
+ "bubbles": true,
107
+ "cancelable": true,
108
+ "composed": true,
109
+ "docs": {
110
+ "tags": [],
111
+ "text": ""
112
+ },
113
+ "complexType": {
114
+ "original": "Settings",
115
+ "resolved": "Settings",
116
+ "references": {
117
+ "Settings": {
118
+ "location": "import",
119
+ "path": "../../store",
120
+ "id": "src/store.ts::Settings"
121
+ }
122
+ }
123
+ }
124
+ }];
125
+ }
126
+ }
127
+ //# sourceMappingURL=settings.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"settings.js","sourceRoot":"","sources":["../../../src/components/settings/settings.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Event, EventEmitter, h, Prop, State } from \"@stencil/core\";\r\nimport { Settings, state } from \"../../store\";\r\nimport { getLanguageStrings } from \"../../utils/lang/general\";\r\nimport { Language } from \"../../types/lang\";\r\n\r\n@Component({\r\n tag: \"settings-modal\",\r\n styleUrl: \"../../output.css\",\r\n shadow: false,\r\n})\r\nexport class SettingsModal {\r\n @Prop()\r\n settings: Settings;\r\n\r\n @State()\r\n private tempSettings: Settings;\r\n\r\n @Event()\r\n close: EventEmitter<void>;\r\n\r\n @Event()\r\n save: EventEmitter<Settings>;\r\n\r\n componentWillLoad() {\r\n this.tempSettings = { ...this.settings };\r\n }\r\n\r\n private handleClose = () => {\r\n if (\r\n JSON.stringify(this.tempSettings) !== JSON.stringify(this.settings)\r\n ) {\r\n if (\r\n confirm(\r\n \"Are you sure you want to close without saving your changes?\",\r\n )\r\n ) {\r\n this.close.emit();\r\n }\r\n } else {\r\n this.close.emit();\r\n }\r\n };\r\n\r\n private handleSave = () => {\r\n this.save.emit(this.tempSettings);\r\n this.close.emit();\r\n };\r\n\r\n private handleInputChange = (\r\n key: keyof Settings,\r\n value: number | Language,\r\n ) => {\r\n this.tempSettings = {\r\n ...this.tempSettings,\r\n [key]: value,\r\n };\r\n };\r\n\r\n render() {\r\n const t = getLanguageStrings(state.settings.language);\r\n return (\r\n <div class=\"fixed inset-0 bg-black bg-opacity-50 flex items-center justify-center z-50\">\r\n <div class=\"bg-primary rounded-4xl p-6 w-full max-w-md\">\r\n <div class=\"flex justify-between items-center mb-6\">\r\n <h2 class=\"text-xl font-semibold\">Settings</h2>\r\n <button\r\n class=\"p-2 hover:bg-hover rounded-full transition-colors\"\r\n onClick={this.handleClose}\r\n >\r\n <svg\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n width=\"24\"\r\n height=\"24\"\r\n viewBox=\"0 0 24 24\"\r\n fill=\"none\"\r\n stroke=\"currentColor\"\r\n stroke-width=\"2\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\"\r\n >\r\n <line x1=\"18\" y1=\"6\" x2=\"6\" y2=\"18\" />\r\n <line x1=\"6\" y1=\"6\" x2=\"18\" y2=\"18\" />\r\n </svg>\r\n </button>\r\n </div>\r\n\r\n <div class=\"space-y-4\">\r\n <div>\r\n <h3 class=\"text-sm font-medium text-text-muted mb-1\">\r\n Debug Information\r\n </h3>\r\n <p class=\"text-sm text-text-muted mb-1\">\r\n state: {JSON.stringify(state, null, 2)}\r\n </p>\r\n <p class=\"text-sm text-text-muted mb-1\">\r\n {navigator.userAgent}\r\n </p>\r\n <p class=\"text-sm text-text-muted mb-1\">\r\n {navigator.userAgent.indexOf(\"Safari\")}\r\n </p>\r\n <p class=\"text-sm text-text-muted mb-1\">\r\n maxTouchPoints: {navigator.maxTouchPoints}\r\n </p>\r\n <p class=\"text-sm text-text-muted mb-1\">\r\n iPhone: {navigator.userAgent.indexOf(\"iPhone\")}\r\n </p>\r\n <p class=\"text-sm text-text-muted mb-1\">\r\n Mac OS: {navigator.userAgent.indexOf(\"Mac OS\")}\r\n </p>\r\n </div>\r\n <div>\r\n <label class=\"block text-sm font-medium text-text-muted mb-1\">\r\n {t.settings.language}\r\n </label>\r\n <select\r\n class=\"w-full bg-muted rounded-4xl p-2\"\r\n onInput={(e) =>\r\n this.handleInputChange(\r\n \"language\",\r\n (e.target as HTMLSelectElement)\r\n .value as Language,\r\n )}\r\n >\r\n <option\r\n value=\"en\"\r\n selected={this.tempSettings.language ===\r\n \"en\"}\r\n >\r\n English\r\n </option>\r\n <option\r\n value=\"es\"\r\n selected={this.tempSettings.language ===\r\n \"es\"}\r\n >\r\n Español\r\n </option>\r\n <option\r\n value=\"de\"\r\n selected={this.tempSettings.language ===\r\n \"de\"}\r\n >\r\n Deutsch\r\n </option>\r\n </select>\r\n </div>\r\n\r\n <div>\r\n <label class=\"block text-sm font-medium text-text-muted mb-1\">\r\n {t.settings.rowSpacing}\r\n </label>\r\n <input\r\n type=\"number\"\r\n class=\"w-full bg-muted rounded-4xl p-2\"\r\n value={this.tempSettings.rowSpacing}\r\n onInput={(e) =>\r\n this.handleInputChange(\r\n \"rowSpacing\",\r\n parseFloat(\r\n (e.target as HTMLInputElement)\r\n .value,\r\n ),\r\n )}\r\n />\r\n </div>\r\n\r\n <div>\r\n <label class=\"block text-sm font-medium text-text-muted mb-1\">\r\n {t.settings.columnSpacing}\r\n </label>\r\n <input\r\n type=\"number\"\r\n class=\"w-full bg-muted rounded-4xl p-2\"\r\n value={this.tempSettings.columnSpacing}\r\n onInput={(e) =>\r\n this.handleInputChange(\r\n \"columnSpacing\",\r\n parseFloat(\r\n (e.target as HTMLInputElement)\r\n .value,\r\n ),\r\n )}\r\n />\r\n </div>\r\n\r\n <div>\r\n <label class=\"block text-sm font-medium text-text-muted mb-1\">\r\n {t.settings.borderInset}\r\n </label>\r\n <input\r\n type=\"number\"\r\n class=\"w-full bg-muted rounded-4xl p-2\"\r\n value={this.tempSettings.borderInset}\r\n onInput={(e) =>\r\n this.handleInputChange(\r\n \"borderInset\",\r\n parseFloat(\r\n (e.target as HTMLInputElement)\r\n .value,\r\n ),\r\n )}\r\n />\r\n </div>\r\n </div>\r\n\r\n <div class=\"flex justify-end gap-4 mt-6\">\r\n <button\r\n class=\"px-4 py-2 bg-surface rounded-4xl hover:bg-surface-hover transition-colors\"\r\n onClick={this.handleClose}\r\n >\r\n Cancel\r\n </button>\r\n <button\r\n class=\"px-4 py-2 bg-secondary text-muted rounded-4xl hover:bg-text-secondary transition-colors\"\r\n onClick={this.handleSave}\r\n >\r\n Save Changes\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n }\r\n}\r\n"]}
@@ -0,0 +1,241 @@
1
+ import { Env, h } from "@stencil/core";
2
+ import { Loader } from "@googlemaps/js-api-loader";
3
+ import { getLanguageStrings } from "../../utils/lang/general";
4
+ import { onChange, state } from "../../store";
5
+ import { DEFAULT_COLOR_SCHEME } from "../../config";
6
+ import { applyThemeGlobally, applyThemeToElement } from "../../utils/theme";
7
+ export class SolarExpert {
8
+ el;
9
+ apiKey = Env.GOOGLE_MAPS_API_KEY;
10
+ language = "en";
11
+ colorScheme = null;
12
+ // {
13
+ // primary: "hsl(0 0% 100%)",
14
+ // secondary: "hsl(0 0% 100%)",
15
+ // tertiary: "hsl(0 0% 100%)",
16
+ // muted: "hsl(0 0% 100%)",
17
+ // error: "hsl(0 0% 100%)",
18
+ // // secondary: "hsl(180 100% 25%)",
19
+ // // tertiary: "hsl(24 100% 18%)",
20
+ // // muted: "hsl(0 0% 85%)",
21
+ // // error: "hsl(240 75% 29%)",
22
+ // primaryForeground: "hsl(0 0% 100%)",
23
+ // secondaryForeground: "hsl(0 0% 100%)",
24
+ // tertiaryForeground: "hsl(0 0% 100%)",
25
+ // mutedForeground: "hsl(0 0% 100%)",
26
+ // errorForeground: "hsl(0 0% 100%)",
27
+ // surface: "hsl(0 0% 100%)",
28
+ // surfaceHover: "hsl(0 0% 100%)",
29
+ // surfaceActive: "hsl(0 0% 100%)",
30
+ // // Text colors
31
+ // textMuted: "hsl(0 0% 100%)",
32
+ // textSecondary: "hsl(0 0% 100%)",
33
+ // textPlaceholder: "hsl(0 0% 100%)",
34
+ // // Border colors
35
+ // border: "hsl(0 0% 100%)",
36
+ // borderLight: "hsl(0 0% 100%)",
37
+ // // Status colors
38
+ // success: "hsl(0 0% 100%)",
39
+ // info: "hsl(0 0% 100%)",
40
+ // // Interactive colors
41
+ // hover: "hsl(0 0% 100%)",
42
+ // hoverDark: "hsl(0 0% 100%)",
43
+ // overlay: "hsl(0 0% 100%)",
44
+ // tooltip: "hsl(0 0% 100%)",
45
+ // };
46
+ latitude = 40.581614;
47
+ longitude = -4.128423;
48
+ isLoaded = false;
49
+ autocomplete = null;
50
+ place = null;
51
+ showMapSelector = false;
52
+ inputElement;
53
+ componentWillLoad() {
54
+ state.isMobile =
55
+ /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i
56
+ .test(navigator.userAgent) || window.innerWidth < 768;
57
+ this.loadGoogleMapsScript();
58
+ onChange("latitude", () => {
59
+ if (this.showMapSelector) {
60
+ this.showMapSelector = false;
61
+ this.scrollToMapDraw();
62
+ }
63
+ });
64
+ state.settings.language = this.language;
65
+ const isIPhone = navigator.userAgent.indexOf("iPhone") != -1;
66
+ const isMac = navigator.userAgent.indexOf("Mac OS") != -1;
67
+ state.isIOS = isIPhone || isMac;
68
+ if (!this.colorScheme) {
69
+ applyThemeToElement(this.el, DEFAULT_COLOR_SCHEME);
70
+ applyThemeGlobally(DEFAULT_COLOR_SCHEME);
71
+ }
72
+ this.applyTheme();
73
+ }
74
+ colorSchemeChanged() {
75
+ this.applyTheme();
76
+ }
77
+ applyTheme() {
78
+ if (this.colorScheme) {
79
+ // Apply theme globally for non-shadow components
80
+ applyThemeGlobally(this.colorScheme);
81
+ // Apply theme to this component's Shadow DOM host element
82
+ applyThemeToElement(this.el, this.colorScheme);
83
+ }
84
+ }
85
+ async loadGoogleMapsScript() {
86
+ try {
87
+ const loader = new Loader({
88
+ apiKey: this.apiKey,
89
+ libraries: ["places", "maps", "marker"],
90
+ });
91
+ const places = await loader.importLibrary("places");
92
+ this.isLoaded = true;
93
+ this.initializeAutocomplete(places);
94
+ }
95
+ catch (error) {
96
+ console.error("Error loading Google Maps: ", error);
97
+ }
98
+ }
99
+ initializeAutocomplete(places) {
100
+ if (!this.inputElement || !this.isLoaded)
101
+ return;
102
+ this.autocomplete = new places.Autocomplete(this.inputElement);
103
+ this.autocomplete.addListener("place_changed", () => {
104
+ state.latitude = null;
105
+ state.longitude = null;
106
+ const place = this.autocomplete?.getPlace();
107
+ this.latitude = place?.geometry?.location?.lat() ?? 0;
108
+ this.longitude = place?.geometry?.location?.lng() ?? 0;
109
+ state.latitude = this.latitude;
110
+ state.longitude = this.longitude;
111
+ state.location = place?.name ?? null;
112
+ this.scrollToMapDraw();
113
+ });
114
+ }
115
+ scrollToMapDraw() {
116
+ const mapDrawElement = this.el.querySelector("map-draw");
117
+ if (mapDrawElement) {
118
+ mapDrawElement.scrollIntoView({ behavior: "smooth" });
119
+ }
120
+ }
121
+ handleChooseOnMap() {
122
+ this.showMapSelector = true;
123
+ }
124
+ render() {
125
+ const t = getLanguageStrings(this.language);
126
+ return (h("div", { key: '7ccb47dff2e8984ef657012dc04d3b14a8b15349', class: "flex flex-col w-full h-full p-3 m-auto", id: "solar-calculator" }, this.showMapSelector
127
+ ? (h("map-selector", { "api-key": this.apiKey, language: this.language }))
128
+ : (h(h.Fragment, null, h("div", { class: "pb-2 flex flex-col sm:flex-row gap-2 sm:gap-4 items-stretch w-full" }, h("div", { class: "relative flex-1 sm:flex-3" }, h("div", { class: "absolute left-3 top-0 h-full flex items-center text-muted-foreground pointer-events-none" }, h("search-icon", null)), h("input", { ref: (el) => this.inputElement = el, type: "text", placeholder: t.solarExpert
129
+ .searchPlaceholder, class: "w-full pl-10 pr-4 py-2 border border-border rounded-4xl focus:ring-secondary bg-muted text-muted-foreground h-full" })), h("button", { onClick: () => this.handleChooseOnMap(), class: "flex-1 pl-4 pr-4 py-2 border border-border bg-muted rounded-4xl focus:ring-secondary hover:bg-surface-hover" }, t.mapSelector.chooseOnMap)), (state.latitude === null ||
130
+ state.longitude === null) && (h("div", { class: "w-full pb-2" }, h("p", { class: "text-text-muted text-center flex items-center justify-center rounded-4xl px-4 py-2 w-full" }, t.mapDraw.noAddressSelected))), h("map-draw", { apiKey: this.apiKey })))));
131
+ }
132
+ static get is() { return "solar-expert"; }
133
+ static get originalStyleUrls() {
134
+ return {
135
+ "$": ["../../output.css"]
136
+ };
137
+ }
138
+ static get styleUrls() {
139
+ return {
140
+ "$": ["../../output.css"]
141
+ };
142
+ }
143
+ static get assetsDirs() { return ["assets"]; }
144
+ static get properties() {
145
+ return {
146
+ "apiKey": {
147
+ "type": "string",
148
+ "attribute": "api-key",
149
+ "mutable": false,
150
+ "complexType": {
151
+ "original": "string",
152
+ "resolved": "string",
153
+ "references": {}
154
+ },
155
+ "required": false,
156
+ "optional": false,
157
+ "docs": {
158
+ "tags": [],
159
+ "text": ""
160
+ },
161
+ "getter": false,
162
+ "setter": false,
163
+ "reflect": false,
164
+ "defaultValue": "Env.GOOGLE_MAPS_API_KEY"
165
+ },
166
+ "language": {
167
+ "type": "string",
168
+ "attribute": "language",
169
+ "mutable": false,
170
+ "complexType": {
171
+ "original": "Language",
172
+ "resolved": "\"de\" | \"en\" | \"es\"",
173
+ "references": {
174
+ "Language": {
175
+ "location": "import",
176
+ "path": "../../types/lang",
177
+ "id": "src/types/lang.ts::Language"
178
+ }
179
+ }
180
+ },
181
+ "required": false,
182
+ "optional": false,
183
+ "docs": {
184
+ "tags": [],
185
+ "text": ""
186
+ },
187
+ "getter": false,
188
+ "setter": false,
189
+ "reflect": false,
190
+ "defaultValue": "\"en\""
191
+ },
192
+ "colorScheme": {
193
+ "type": "unknown",
194
+ "attribute": "color-scheme",
195
+ "mutable": false,
196
+ "complexType": {
197
+ "original": "Partial<ColorScheme> | null",
198
+ "resolved": "{ primary?: string; primaryForeground?: string; secondary?: string; secondaryForeground?: string; tertiary?: string; tertiaryForeground?: string; muted?: string; mutedForeground?: string; error?: string; errorForeground?: string; surface?: string; surfaceHover?: string; surfaceActive?: string; textMuted?: string; textSecondary?: string; textPlaceholder?: string; border?: string; borderLight?: string; success?: string; info?: string; hover?: string; hoverDark?: string; overlay?: string; tooltip?: string; }",
199
+ "references": {
200
+ "Partial": {
201
+ "location": "global",
202
+ "id": "global::Partial"
203
+ },
204
+ "ColorScheme": {
205
+ "location": "import",
206
+ "path": "../../config",
207
+ "id": "src/config.ts::ColorScheme"
208
+ }
209
+ }
210
+ },
211
+ "required": false,
212
+ "optional": false,
213
+ "docs": {
214
+ "tags": [],
215
+ "text": ""
216
+ },
217
+ "getter": false,
218
+ "setter": false,
219
+ "defaultValue": "null"
220
+ }
221
+ };
222
+ }
223
+ static get states() {
224
+ return {
225
+ "latitude": {},
226
+ "longitude": {},
227
+ "isLoaded": {},
228
+ "autocomplete": {},
229
+ "place": {},
230
+ "showMapSelector": {}
231
+ };
232
+ }
233
+ static get elementRef() { return "el"; }
234
+ static get watchers() {
235
+ return [{
236
+ "propName": "colorScheme",
237
+ "methodName": "colorSchemeChanged"
238
+ }];
239
+ }
240
+ }
241
+ //# sourceMappingURL=solar-expert.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"solar-expert.js","sourceRoot":"","sources":["../../../src/components/solar-expert/solar-expert.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Element, Env, h, Prop, State, Watch } from \"@stencil/core\";\r\nimport { Loader } from \"@googlemaps/js-api-loader\";\r\nimport { Language } from \"../../types/lang\";\r\nimport { getLanguageStrings } from \"../../utils/lang/general\";\r\nimport { onChange, state } from \"../../store\";\r\nimport { ColorScheme, DEFAULT_COLOR_SCHEME } from \"../../config\";\r\nimport { applyThemeGlobally, applyThemeToElement } from \"../../utils/theme\";\r\n\r\n@Component({\r\n tag: \"solar-expert\",\r\n shadow: false,\r\n styleUrl: \"../../output.css\",\r\n assetsDirs: [\"assets\"],\r\n})\r\nexport class SolarExpert {\r\n @Element()\r\n el!: HTMLElement;\r\n\r\n @Prop()\r\n apiKey: string = Env.GOOGLE_MAPS_API_KEY;\r\n @Prop()\r\n language: Language = \"en\";\r\n @Prop()\r\n colorScheme: Partial<ColorScheme> | null = null;\r\n // {\r\n // primary: \"hsl(0 0% 100%)\",\r\n // secondary: \"hsl(0 0% 100%)\",\r\n // tertiary: \"hsl(0 0% 100%)\",\r\n // muted: \"hsl(0 0% 100%)\",\r\n // error: \"hsl(0 0% 100%)\",\r\n // // secondary: \"hsl(180 100% 25%)\",\r\n // // tertiary: \"hsl(24 100% 18%)\",\r\n // // muted: \"hsl(0 0% 85%)\",\r\n // // error: \"hsl(240 75% 29%)\",\r\n // primaryForeground: \"hsl(0 0% 100%)\",\r\n // secondaryForeground: \"hsl(0 0% 100%)\",\r\n // tertiaryForeground: \"hsl(0 0% 100%)\",\r\n // mutedForeground: \"hsl(0 0% 100%)\",\r\n // errorForeground: \"hsl(0 0% 100%)\",\r\n // surface: \"hsl(0 0% 100%)\",\r\n // surfaceHover: \"hsl(0 0% 100%)\",\r\n // surfaceActive: \"hsl(0 0% 100%)\",\r\n // // Text colors\r\n // textMuted: \"hsl(0 0% 100%)\",\r\n // textSecondary: \"hsl(0 0% 100%)\",\r\n // textPlaceholder: \"hsl(0 0% 100%)\",\r\n // // Border colors\r\n // border: \"hsl(0 0% 100%)\",\r\n // borderLight: \"hsl(0 0% 100%)\",\r\n // // Status colors\r\n // success: \"hsl(0 0% 100%)\",\r\n // info: \"hsl(0 0% 100%)\",\r\n // // Interactive colors\r\n // hover: \"hsl(0 0% 100%)\",\r\n // hoverDark: \"hsl(0 0% 100%)\",\r\n // overlay: \"hsl(0 0% 100%)\",\r\n // tooltip: \"hsl(0 0% 100%)\",\r\n // };\r\n\r\n @State()\r\n latitude: number | null = 40.581614;\r\n @State()\r\n longitude: number | null = -4.128423;\r\n @State()\r\n isLoaded: boolean = false;\r\n @State()\r\n autocomplete: google.maps.places.Autocomplete | null = null;\r\n @State()\r\n place: google.maps.places.PlaceResult | null = null;\r\n @State()\r\n showMapSelector: boolean = false;\r\n\r\n private inputElement?: HTMLInputElement;\r\n\r\n componentWillLoad() {\r\n state.isMobile =\r\n /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i\r\n .test(navigator.userAgent) || window.innerWidth < 768;\r\n this.loadGoogleMapsScript();\r\n onChange(\"latitude\", () => {\r\n if (this.showMapSelector) {\r\n this.showMapSelector = false;\r\n this.scrollToMapDraw();\r\n }\r\n });\r\n state.settings.language = this.language;\r\n\r\n const isIPhone = navigator.userAgent.indexOf(\"iPhone\") != -1;\r\n const isMac = navigator.userAgent.indexOf(\"Mac OS\") != -1;\r\n\r\n state.isIOS = isIPhone || isMac;\r\n if (!this.colorScheme) {\r\n applyThemeToElement(this.el, DEFAULT_COLOR_SCHEME);\r\n applyThemeGlobally(DEFAULT_COLOR_SCHEME);\r\n }\r\n this.applyTheme();\r\n }\r\n\r\n @Watch(\"colorScheme\")\r\n colorSchemeChanged() {\r\n this.applyTheme();\r\n }\r\n\r\n private applyTheme() {\r\n if (this.colorScheme) {\r\n // Apply theme globally for non-shadow components\r\n applyThemeGlobally(this.colorScheme);\r\n // Apply theme to this component's Shadow DOM host element\r\n applyThemeToElement(this.el, this.colorScheme);\r\n }\r\n }\r\n\r\n private async loadGoogleMapsScript() {\r\n try {\r\n const loader = new Loader({\r\n apiKey: this.apiKey,\r\n libraries: [\"places\", \"maps\", \"marker\"],\r\n });\r\n\r\n const places = await loader.importLibrary(\"places\");\r\n this.isLoaded = true;\r\n this.initializeAutocomplete(places);\r\n } catch (error) {\r\n console.error(\"Error loading Google Maps: \", error);\r\n }\r\n }\r\n\r\n private initializeAutocomplete(\r\n places: google.maps.PlacesLibrary,\r\n ) {\r\n if (!this.inputElement || !this.isLoaded) return;\r\n this.autocomplete = new places.Autocomplete(this.inputElement);\r\n\r\n this.autocomplete.addListener(\"place_changed\", () => {\r\n state.latitude = null;\r\n state.longitude = null;\r\n const place = this.autocomplete?.getPlace();\r\n this.latitude = place?.geometry?.location?.lat() ?? 0;\r\n this.longitude = place?.geometry?.location?.lng() ?? 0;\r\n state.latitude = this.latitude;\r\n state.longitude = this.longitude;\r\n state.location = place?.name ?? null;\r\n\r\n this.scrollToMapDraw();\r\n });\r\n }\r\n\r\n private scrollToMapDraw() {\r\n const mapDrawElement = this.el.querySelector(\"map-draw\");\r\n if (mapDrawElement) {\r\n mapDrawElement.scrollIntoView({ behavior: \"smooth\" });\r\n }\r\n }\r\n\r\n private handleChooseOnMap() {\r\n this.showMapSelector = true;\r\n }\r\n\r\n render() {\r\n const t = getLanguageStrings(this.language);\r\n return (\r\n <div\r\n class=\"flex flex-col w-full h-full p-3 m-auto\"\r\n id=\"solar-calculator\"\r\n >\r\n {this.showMapSelector\r\n ? (\r\n <map-selector\r\n api-key={this.apiKey}\r\n language={this.language}\r\n />\r\n )\r\n : (\r\n <>\r\n <div class=\"pb-2 flex flex-col sm:flex-row gap-2 sm:gap-4 items-stretch w-full\">\r\n <div class=\"relative flex-1 sm:flex-3\">\r\n <div class=\"absolute left-3 top-0 h-full flex items-center text-muted-foreground pointer-events-none\">\r\n <search-icon />\r\n </div>\r\n <input\r\n ref={(el) => this.inputElement = el}\r\n type=\"text\"\r\n placeholder={t.solarExpert\r\n .searchPlaceholder}\r\n class=\"w-full pl-10 pr-4 py-2 border border-border rounded-4xl focus:ring-secondary bg-muted text-muted-foreground h-full\"\r\n />\r\n </div>\r\n <button\r\n onClick={() => this.handleChooseOnMap()}\r\n class=\"flex-1 pl-4 pr-4 py-2 border border-border bg-muted rounded-4xl focus:ring-secondary hover:bg-surface-hover\"\r\n >\r\n {t.mapSelector.chooseOnMap}\r\n </button>\r\n </div>\r\n {(state.latitude === null ||\r\n state.longitude === null) && (\r\n <div class=\"w-full pb-2\">\r\n <p class=\"text-text-muted text-center flex items-center justify-center rounded-4xl px-4 py-2 w-full\">\r\n {t.mapDraw.noAddressSelected}\r\n </p>\r\n </div>\r\n )}\r\n <map-draw\r\n apiKey={this.apiKey}\r\n />\r\n </>\r\n )}\r\n </div>\r\n );\r\n }\r\n}\r\n"]}