sveltekit-ui 1.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 (487) hide show
  1. package/README.md +23 -0
  2. package/dist/Components/Alert/index.svelte +88 -0
  3. package/dist/Components/Alert/index.svelte.js +101 -0
  4. package/dist/Components/ArrowToggle/index.svelte +62 -0
  5. package/dist/Components/Attachment/index.svelte +69 -0
  6. package/dist/Components/Attachment/index.svelte.js +119 -0
  7. package/dist/Components/Audio/index.svelte +193 -0
  8. package/dist/Components/Audio/index.svelte.js +463 -0
  9. package/dist/Components/AudioEditor/index.svelte +253 -0
  10. package/dist/Components/AudioEditor/index.svelte.js +973 -0
  11. package/dist/Components/AudioEditor/samples/alloy-voice-sample.mp3 +0 -0
  12. package/dist/Components/AudioEditor/samples/echo-voice-sample.mp3 +0 -0
  13. package/dist/Components/AudioEditor/samples/fable-voice-sample.mp3 +0 -0
  14. package/dist/Components/AudioEditor/samples/nova-voice-sample.mp3 +0 -0
  15. package/dist/Components/AudioEditor/samples/onyx-voice-sample.mp3 +0 -0
  16. package/dist/Components/AudioEditor/samples/shimmer-voice-sample.mp3 +0 -0
  17. package/dist/Components/AuthCodeInput/index.svelte +85 -0
  18. package/dist/Components/AuthCodeInput/index.svelte.js +95 -0
  19. package/dist/Components/Breadcrumbs/index.svelte +27 -0
  20. package/dist/Components/Breadcrumbs/index.svelte.js +88 -0
  21. package/dist/Components/Button/index.svelte +721 -0
  22. package/dist/Components/Button/index.svelte.js +375 -0
  23. package/dist/Components/Chart/Klines/index.svelte +87 -0
  24. package/dist/Components/Chart/index.svelte +226 -0
  25. package/dist/Components/Chart/index.svelte.js +1084 -0
  26. package/dist/Components/ChartInput/DisplayNav/Klines/index.svelte +150 -0
  27. package/dist/Components/ChartInput/DisplayNav/Lines/index.svelte +45 -0
  28. package/dist/Components/ChartInput/DisplayNav/index.svelte +297 -0
  29. package/dist/Components/ChartInput/EditPanel/index.svelte +155 -0
  30. package/dist/Components/ChartInput/index.svelte +21 -0
  31. package/dist/Components/ChartInput/index.svelte.js +671 -0
  32. package/dist/Components/Checkbox/index.svelte +411 -0
  33. package/dist/Components/Checkbox/index.svelte.js +178 -0
  34. package/dist/Components/Code/index.svelte +23 -0
  35. package/dist/Components/Code/index.svelte.js +34 -0
  36. package/dist/Components/Color/index.svelte +51 -0
  37. package/dist/Components/Color/index.svelte.js +31 -0
  38. package/dist/Components/ColorInput/ChromaPicker/index.svelte +50 -0
  39. package/dist/Components/ColorInput/ColorPalette/index.svelte +62 -0
  40. package/dist/Components/ColorInput/OpacityPicker/index.svelte +68 -0
  41. package/dist/Components/ColorInput/ShowcasePicker/index.svelte +136 -0
  42. package/dist/Components/ColorInput/index.svelte +70 -0
  43. package/dist/Components/ColorInput/index.svelte.js +383 -0
  44. package/dist/Components/ConditionsInput/index.svelte +46 -0
  45. package/dist/Components/ConditionsInput/index.svelte.js +201 -0
  46. package/dist/Components/Confetti/index.svelte +98 -0
  47. package/dist/Components/Confetti/index.svelte.js +94 -0
  48. package/dist/Components/Content/index.svelte +471 -0
  49. package/dist/Components/Content/index.svelte.js +903 -0
  50. package/dist/Components/ContentInput/AttributesInput/CustomConfig/Audio/index.svelte +31 -0
  51. package/dist/Components/ContentInput/AttributesInput/CustomConfig/Audio/index.svelte.js +258 -0
  52. package/dist/Components/ContentInput/AttributesInput/CustomConfig/AudioAdvanced/index.svelte +31 -0
  53. package/dist/Components/ContentInput/AttributesInput/CustomConfig/AudioAdvanced/index.svelte.js +258 -0
  54. package/dist/Components/ContentInput/AttributesInput/CustomConfig/Dropdown/index.svelte +58 -0
  55. package/dist/Components/ContentInput/AttributesInput/CustomConfig/Dropdown/index.svelte.js +210 -0
  56. package/dist/Components/ContentInput/AttributesInput/CustomConfig/Image/index.svelte +28 -0
  57. package/dist/Components/ContentInput/AttributesInput/CustomConfig/Image/index.svelte.js +224 -0
  58. package/dist/Components/ContentInput/AttributesInput/CustomConfig/Number/index.svelte +44 -0
  59. package/dist/Components/ContentInput/AttributesInput/CustomConfig/Number/index.svelte.js +273 -0
  60. package/dist/Components/ContentInput/AttributesInput/CustomConfig/Qr/index.svelte +41 -0
  61. package/dist/Components/ContentInput/AttributesInput/CustomConfig/Qr/index.svelte.js +203 -0
  62. package/dist/Components/ContentInput/AttributesInput/CustomConfig/Slider/index.svelte +19 -0
  63. package/dist/Components/ContentInput/AttributesInput/CustomConfig/Slider/index.svelte.js +119 -0
  64. package/dist/Components/ContentInput/AttributesInput/CustomConfig/TableAdvanced/index.svelte +60 -0
  65. package/dist/Components/ContentInput/AttributesInput/CustomConfig/TableAdvanced/index.svelte.js +546 -0
  66. package/dist/Components/ContentInput/AttributesInput/CustomConfig/Tag/index.svelte +47 -0
  67. package/dist/Components/ContentInput/AttributesInput/CustomConfig/Tag/index.svelte.js +185 -0
  68. package/dist/Components/ContentInput/AttributesInput/CustomConfig/TextInput/index.svelte +35 -0
  69. package/dist/Components/ContentInput/AttributesInput/CustomConfig/TextInput/index.svelte.js +224 -0
  70. package/dist/Components/ContentInput/AttributesInput/CustomConfig/TimeInput/index.svelte +20 -0
  71. package/dist/Components/ContentInput/AttributesInput/CustomConfig/TimeInput/index.svelte.js +87 -0
  72. package/dist/Components/ContentInput/AttributesInput/DefinedTypeInput/index.svelte +25 -0
  73. package/dist/Components/ContentInput/AttributesInput/DefinedTypeInput/index.svelte.js +101 -0
  74. package/dist/Components/ContentInput/AttributesInput/index.svelte +338 -0
  75. package/dist/Components/ContentInput/AttributesInput/index.svelte.js +1446 -0
  76. package/dist/Components/ContentInput/ContentPanelBuilder/AddElement/index.svelte +64 -0
  77. package/dist/Components/ContentInput/ContentPanelBuilder/AddElement/index.svelte.js +97 -0
  78. package/dist/Components/ContentInput/ContentPanelBuilder/ElementList/index.svelte +122 -0
  79. package/dist/Components/ContentInput/ContentPanelBuilder/index.svelte +41 -0
  80. package/dist/Components/ContentInput/index.svelte +50 -0
  81. package/dist/Components/ContentInput/index.svelte.js +1066 -0
  82. package/dist/Components/CronInput/index.svelte +78 -0
  83. package/dist/Components/CronInput/index.svelte.js +199 -0
  84. package/dist/Components/DataTypeInput/index.svelte +174 -0
  85. package/dist/Components/DataTypeInput/index.svelte.js +568 -0
  86. package/dist/Components/Dropdown/index.svelte +116 -0
  87. package/dist/Components/Dropdown/index.svelte.js +403 -0
  88. package/dist/Components/EmailAddress/index.svelte +22 -0
  89. package/dist/Components/EmailAddress/index.svelte.js +45 -0
  90. package/dist/Components/ErrorX/index.svelte +58 -0
  91. package/dist/Components/Eye/index.svelte +57 -0
  92. package/dist/Components/FileInput/index.svelte +146 -0
  93. package/dist/Components/FileInput/index.svelte.js +226 -0
  94. package/dist/Components/FunctionInput/Node/helpers/DefinedTargetInput/index.svelte +110 -0
  95. package/dist/Components/FunctionInput/Node/helpers/Field/index.svelte +109 -0
  96. package/dist/Components/FunctionInput/Node/helpers/Field/index.svelte.js +208 -0
  97. package/dist/Components/FunctionInput/Node/helpers/InlineDropArea/index.svelte +97 -0
  98. package/dist/Components/FunctionInput/Node/helpers/InlineDropArea/index.svelte.js +105 -0
  99. package/dist/Components/FunctionInput/Node/helpers/ObjectInput/index.svelte +198 -0
  100. package/dist/Components/FunctionInput/Node/helpers/StackArea/index.svelte +169 -0
  101. package/dist/Components/FunctionInput/Node/helpers/StackArea/index.svelte.js +152 -0
  102. package/dist/Components/FunctionInput/Node/index.svelte +144 -0
  103. package/dist/Components/FunctionInput/Node/index.svelte.js +130 -0
  104. package/dist/Components/FunctionInput/index.svelte +356 -0
  105. package/dist/Components/FunctionInput/index.svelte.js +1215 -0
  106. package/dist/Components/Hamburger/index.svelte +99 -0
  107. package/dist/Components/HorizScrollBox/index.svelte +145 -0
  108. package/dist/Components/Icon/index.svelte +412 -0
  109. package/dist/Components/Icon/index.svelte.js +117 -0
  110. package/dist/Components/IconInput/index.svelte +77 -0
  111. package/dist/Components/IconInput/index.svelte.js +260 -0
  112. package/dist/Components/Image/index.svelte +121 -0
  113. package/dist/Components/Image/index.svelte.js +114 -0
  114. package/dist/Components/ImageEditor/Image/CropBox/index.svelte +165 -0
  115. package/dist/Components/ImageEditor/Image/index.svelte +104 -0
  116. package/dist/Components/ImageEditor/Panels/AI/index.svelte +36 -0
  117. package/dist/Components/ImageEditor/Panels/Crop/index.svelte +96 -0
  118. package/dist/Components/ImageEditor/Panels/File/QualityPicker/index.svelte +124 -0
  119. package/dist/Components/ImageEditor/Panels/File/index.svelte +74 -0
  120. package/dist/Components/ImageEditor/Panels/Filters/index.svelte +46 -0
  121. package/dist/Components/ImageEditor/Panels/Resize/index.svelte +58 -0
  122. package/dist/Components/ImageEditor/index.svelte +91 -0
  123. package/dist/Components/ImageEditor/index.svelte.js +1907 -0
  124. package/dist/Components/ImageSlider/index.svelte +124 -0
  125. package/dist/Components/ImageSlider/index.svelte.js +99 -0
  126. package/dist/Components/InfoBox/index.svelte +89 -0
  127. package/dist/Components/Json/Nested/index.svelte +157 -0
  128. package/dist/Components/Json/index.svelte +60 -0
  129. package/dist/Components/Json/index.svelte.js +594 -0
  130. package/dist/Components/LabeledItem/index.svelte +102 -0
  131. package/dist/Components/Layout/NavBar/FullNav/index.svelte +53 -0
  132. package/dist/Components/Layout/NavBar/NavGuts/index.svelte +87 -0
  133. package/dist/Components/Layout/NavBar/index.svelte +72 -0
  134. package/dist/Components/Layout/index.svelte +149 -0
  135. package/dist/Components/Layout/index.svelte.js +362 -0
  136. package/dist/Components/Link/index.svelte +46 -0
  137. package/dist/Components/Link/index.svelte.js +126 -0
  138. package/dist/Components/LoadingSuccessDiv/index.svelte +51 -0
  139. package/dist/Components/LoadingWheel/index.svelte +38 -0
  140. package/dist/Components/Location/index.svelte +85 -0
  141. package/dist/Components/Location/index.svelte.js +292 -0
  142. package/dist/Components/LocationInput/index.svelte +200 -0
  143. package/dist/Components/LocationInput/index.svelte.js +950 -0
  144. package/dist/Components/Number/index.svelte +47 -0
  145. package/dist/Components/Number/index.svelte.js +151 -0
  146. package/dist/Components/PhoneCountryCode/index.svelte +7 -0
  147. package/dist/Components/PhoneCountryCode/index.svelte.js +260 -0
  148. package/dist/Components/PhoneNumber/index.svelte +22 -0
  149. package/dist/Components/PhoneNumber/index.svelte.js +41 -0
  150. package/dist/Components/Popover/index.svelte +396 -0
  151. package/dist/Components/Popover/index.svelte.js +319 -0
  152. package/dist/Components/Qr/index.svelte +60 -0
  153. package/dist/Components/Qr/index.svelte.js +295 -0
  154. package/dist/Components/Slider/index.svelte +231 -0
  155. package/dist/Components/Slider/index.svelte.js +468 -0
  156. package/dist/Components/Spacer/index.svelte +41 -0
  157. package/dist/Components/StoragePicker/DisplayFile/index.svelte +15 -0
  158. package/dist/Components/StoragePicker/index.svelte +192 -0
  159. package/dist/Components/StoragePicker/index.svelte.js +593 -0
  160. package/dist/Components/SuccessCheck/index.svelte +56 -0
  161. package/dist/Components/TableAdvanced/ColumnInput/index.svelte +110 -0
  162. package/dist/Components/TableAdvanced/ColumnInput/index.svelte.js +494 -0
  163. package/dist/Components/TableAdvanced/FilterInput/index.svelte +54 -0
  164. package/dist/Components/TableAdvanced/FilterInput/index.svelte.js +247 -0
  165. package/dist/Components/TableAdvanced/Pagination/index.svelte +43 -0
  166. package/dist/Components/TableAdvanced/Pagination/index.svelte.js +97 -0
  167. package/dist/Components/TableAdvanced/SortByInput/index.svelte +79 -0
  168. package/dist/Components/TableAdvanced/SortByInput/index.svelte.js +191 -0
  169. package/dist/Components/TableAdvanced/index.svelte +268 -0
  170. package/dist/Components/TableAdvanced/index.svelte.js +1422 -0
  171. package/dist/Components/Tag/index.svelte +45 -0
  172. package/dist/Components/Tag/index.svelte.js +76 -0
  173. package/dist/Components/TextArrayInput/index.svelte +108 -0
  174. package/dist/Components/TextArrayInput/index.svelte.js +239 -0
  175. package/dist/Components/TextInput/PasswordTooltip/index.svelte +89 -0
  176. package/dist/Components/TextInput/index.svelte +223 -0
  177. package/dist/Components/TextInput/index.svelte.js +434 -0
  178. package/dist/Components/Time/index.svelte +7 -0
  179. package/dist/Components/Time/index.svelte.js +38 -0
  180. package/dist/Components/TimeInput/NumberToggler/index.svelte +34 -0
  181. package/dist/Components/TimeInput/NumberToggler/index.svelte.js +79 -0
  182. package/dist/Components/TimeInput/index.js +699 -0
  183. package/dist/Components/TimeInput/index.svelte +211 -0
  184. package/dist/Components/TimeInput/index.svelte.js +638 -0
  185. package/dist/Components/Tooltip/index.svelte +143 -0
  186. package/dist/Components/TransparentBackground/index.svelte +153 -0
  187. package/dist/Components/TypingDots/index.svelte +84 -0
  188. package/dist/Components/VariablePathInput/index.svelte +109 -0
  189. package/dist/Components/VariablePathInput/index.svelte.js +250 -0
  190. package/dist/Components/VideoTBD/index.svelte +100 -0
  191. package/dist/Components/XFollow/index.svelte +42 -0
  192. package/dist/Components/XPost/index.svelte +52 -0
  193. package/dist/Components/XPost/index.svelte.js +64 -0
  194. package/dist/Components/YoutubeVideo/index.svelte +73 -0
  195. package/dist/Components/YoutubeVideo/index.svelte.js +54 -0
  196. package/dist/actions/draggable.js +49 -0
  197. package/dist/actions/intersection_observer.js +24 -0
  198. package/dist/actions/no_spaces.js +33 -0
  199. package/dist/actions/numbers_only.js +26 -0
  200. package/dist/actions/scroll_y.js +28 -0
  201. package/dist/actions/stop_scroll_propagation_y.js +42 -0
  202. package/dist/actions/swipe_handler.js +295 -0
  203. package/dist/client/astc_formatting/index.js +1167 -0
  204. package/dist/client/docs/index.js +7612 -0
  205. package/dist/client/index.js +729 -0
  206. package/dist/client/types/index.js +4681 -0
  207. package/dist/index.js +161 -0
  208. package/dist/style.css +682 -0
  209. package/package.json +44 -0
  210. package/src/app.html +17 -0
  211. package/src/hooks.server.js +7 -0
  212. package/src/lib/Components/Alert/index.svelte +88 -0
  213. package/src/lib/Components/Alert/index.svelte.js +101 -0
  214. package/src/lib/Components/ArrowToggle/index.svelte +62 -0
  215. package/src/lib/Components/Attachment/index.svelte +69 -0
  216. package/src/lib/Components/Attachment/index.svelte.js +119 -0
  217. package/src/lib/Components/Audio/index.svelte +193 -0
  218. package/src/lib/Components/Audio/index.svelte.js +463 -0
  219. package/src/lib/Components/AudioEditor/index.svelte +253 -0
  220. package/src/lib/Components/AudioEditor/index.svelte.js +973 -0
  221. package/src/lib/Components/AudioEditor/samples/alloy-voice-sample.mp3 +0 -0
  222. package/src/lib/Components/AudioEditor/samples/echo-voice-sample.mp3 +0 -0
  223. package/src/lib/Components/AudioEditor/samples/fable-voice-sample.mp3 +0 -0
  224. package/src/lib/Components/AudioEditor/samples/nova-voice-sample.mp3 +0 -0
  225. package/src/lib/Components/AudioEditor/samples/onyx-voice-sample.mp3 +0 -0
  226. package/src/lib/Components/AudioEditor/samples/shimmer-voice-sample.mp3 +0 -0
  227. package/src/lib/Components/AuthCodeInput/index.svelte +85 -0
  228. package/src/lib/Components/AuthCodeInput/index.svelte.js +95 -0
  229. package/src/lib/Components/Breadcrumbs/index.svelte +27 -0
  230. package/src/lib/Components/Breadcrumbs/index.svelte.js +88 -0
  231. package/src/lib/Components/Button/index.svelte +721 -0
  232. package/src/lib/Components/Button/index.svelte.js +375 -0
  233. package/src/lib/Components/Chart/Klines/index.svelte +87 -0
  234. package/src/lib/Components/Chart/index.svelte +226 -0
  235. package/src/lib/Components/Chart/index.svelte.js +1084 -0
  236. package/src/lib/Components/ChartInput/DisplayNav/Klines/index.svelte +150 -0
  237. package/src/lib/Components/ChartInput/DisplayNav/Lines/index.svelte +45 -0
  238. package/src/lib/Components/ChartInput/DisplayNav/index.svelte +297 -0
  239. package/src/lib/Components/ChartInput/EditPanel/index.svelte +155 -0
  240. package/src/lib/Components/ChartInput/index.svelte +21 -0
  241. package/src/lib/Components/ChartInput/index.svelte.js +671 -0
  242. package/src/lib/Components/Checkbox/index.svelte +411 -0
  243. package/src/lib/Components/Checkbox/index.svelte.js +178 -0
  244. package/src/lib/Components/Code/index.svelte +23 -0
  245. package/src/lib/Components/Code/index.svelte.js +34 -0
  246. package/src/lib/Components/Color/index.svelte +51 -0
  247. package/src/lib/Components/Color/index.svelte.js +31 -0
  248. package/src/lib/Components/ColorInput/ChromaPicker/index.svelte +50 -0
  249. package/src/lib/Components/ColorInput/ColorPalette/index.svelte +62 -0
  250. package/src/lib/Components/ColorInput/OpacityPicker/index.svelte +68 -0
  251. package/src/lib/Components/ColorInput/ShowcasePicker/index.svelte +136 -0
  252. package/src/lib/Components/ColorInput/index.svelte +70 -0
  253. package/src/lib/Components/ColorInput/index.svelte.js +383 -0
  254. package/src/lib/Components/ConditionsInput/index.svelte +46 -0
  255. package/src/lib/Components/ConditionsInput/index.svelte.js +201 -0
  256. package/src/lib/Components/Confetti/index.svelte +98 -0
  257. package/src/lib/Components/Confetti/index.svelte.js +94 -0
  258. package/src/lib/Components/Content/index.svelte +471 -0
  259. package/src/lib/Components/Content/index.svelte.js +903 -0
  260. package/src/lib/Components/ContentInput/AttributesInput/CustomConfig/Audio/index.svelte +31 -0
  261. package/src/lib/Components/ContentInput/AttributesInput/CustomConfig/Audio/index.svelte.js +258 -0
  262. package/src/lib/Components/ContentInput/AttributesInput/CustomConfig/AudioAdvanced/index.svelte +31 -0
  263. package/src/lib/Components/ContentInput/AttributesInput/CustomConfig/AudioAdvanced/index.svelte.js +258 -0
  264. package/src/lib/Components/ContentInput/AttributesInput/CustomConfig/Dropdown/index.svelte +58 -0
  265. package/src/lib/Components/ContentInput/AttributesInput/CustomConfig/Dropdown/index.svelte.js +210 -0
  266. package/src/lib/Components/ContentInput/AttributesInput/CustomConfig/Image/index.svelte +28 -0
  267. package/src/lib/Components/ContentInput/AttributesInput/CustomConfig/Image/index.svelte.js +224 -0
  268. package/src/lib/Components/ContentInput/AttributesInput/CustomConfig/Number/index.svelte +44 -0
  269. package/src/lib/Components/ContentInput/AttributesInput/CustomConfig/Number/index.svelte.js +273 -0
  270. package/src/lib/Components/ContentInput/AttributesInput/CustomConfig/Qr/index.svelte +41 -0
  271. package/src/lib/Components/ContentInput/AttributesInput/CustomConfig/Qr/index.svelte.js +203 -0
  272. package/src/lib/Components/ContentInput/AttributesInput/CustomConfig/Slider/index.svelte +19 -0
  273. package/src/lib/Components/ContentInput/AttributesInput/CustomConfig/Slider/index.svelte.js +119 -0
  274. package/src/lib/Components/ContentInput/AttributesInput/CustomConfig/TableAdvanced/index.svelte +60 -0
  275. package/src/lib/Components/ContentInput/AttributesInput/CustomConfig/TableAdvanced/index.svelte.js +546 -0
  276. package/src/lib/Components/ContentInput/AttributesInput/CustomConfig/Tag/index.svelte +47 -0
  277. package/src/lib/Components/ContentInput/AttributesInput/CustomConfig/Tag/index.svelte.js +185 -0
  278. package/src/lib/Components/ContentInput/AttributesInput/CustomConfig/TextInput/index.svelte +35 -0
  279. package/src/lib/Components/ContentInput/AttributesInput/CustomConfig/TextInput/index.svelte.js +224 -0
  280. package/src/lib/Components/ContentInput/AttributesInput/CustomConfig/TimeInput/index.svelte +20 -0
  281. package/src/lib/Components/ContentInput/AttributesInput/CustomConfig/TimeInput/index.svelte.js +87 -0
  282. package/src/lib/Components/ContentInput/AttributesInput/DefinedTypeInput/index.svelte +25 -0
  283. package/src/lib/Components/ContentInput/AttributesInput/DefinedTypeInput/index.svelte.js +101 -0
  284. package/src/lib/Components/ContentInput/AttributesInput/index.svelte +338 -0
  285. package/src/lib/Components/ContentInput/AttributesInput/index.svelte.js +1446 -0
  286. package/src/lib/Components/ContentInput/ContentPanelBuilder/AddElement/index.svelte +64 -0
  287. package/src/lib/Components/ContentInput/ContentPanelBuilder/AddElement/index.svelte.js +97 -0
  288. package/src/lib/Components/ContentInput/ContentPanelBuilder/ElementList/index.svelte +122 -0
  289. package/src/lib/Components/ContentInput/ContentPanelBuilder/index.svelte +41 -0
  290. package/src/lib/Components/ContentInput/index.svelte +50 -0
  291. package/src/lib/Components/ContentInput/index.svelte.js +1066 -0
  292. package/src/lib/Components/CronInput/index.svelte +78 -0
  293. package/src/lib/Components/CronInput/index.svelte.js +199 -0
  294. package/src/lib/Components/DataTypeInput/index.svelte +174 -0
  295. package/src/lib/Components/DataTypeInput/index.svelte.js +568 -0
  296. package/src/lib/Components/Dropdown/index.svelte +116 -0
  297. package/src/lib/Components/Dropdown/index.svelte.js +403 -0
  298. package/src/lib/Components/EmailAddress/index.svelte +22 -0
  299. package/src/lib/Components/EmailAddress/index.svelte.js +45 -0
  300. package/src/lib/Components/ErrorX/index.svelte +58 -0
  301. package/src/lib/Components/Eye/index.svelte +57 -0
  302. package/src/lib/Components/FileInput/index.svelte +146 -0
  303. package/src/lib/Components/FileInput/index.svelte.js +226 -0
  304. package/src/lib/Components/FunctionInput/Node/helpers/DefinedTargetInput/index.svelte +110 -0
  305. package/src/lib/Components/FunctionInput/Node/helpers/Field/index.svelte +109 -0
  306. package/src/lib/Components/FunctionInput/Node/helpers/Field/index.svelte.js +208 -0
  307. package/src/lib/Components/FunctionInput/Node/helpers/InlineDropArea/index.svelte +97 -0
  308. package/src/lib/Components/FunctionInput/Node/helpers/InlineDropArea/index.svelte.js +105 -0
  309. package/src/lib/Components/FunctionInput/Node/helpers/ObjectInput/index.svelte +198 -0
  310. package/src/lib/Components/FunctionInput/Node/helpers/StackArea/index.svelte +169 -0
  311. package/src/lib/Components/FunctionInput/Node/helpers/StackArea/index.svelte.js +152 -0
  312. package/src/lib/Components/FunctionInput/Node/index.svelte +144 -0
  313. package/src/lib/Components/FunctionInput/Node/index.svelte.js +130 -0
  314. package/src/lib/Components/FunctionInput/index.svelte +356 -0
  315. package/src/lib/Components/FunctionInput/index.svelte.js +1215 -0
  316. package/src/lib/Components/Hamburger/index.svelte +99 -0
  317. package/src/lib/Components/HorizScrollBox/index.svelte +145 -0
  318. package/src/lib/Components/Icon/index.svelte +412 -0
  319. package/src/lib/Components/Icon/index.svelte.js +117 -0
  320. package/src/lib/Components/IconInput/index.svelte +77 -0
  321. package/src/lib/Components/IconInput/index.svelte.js +260 -0
  322. package/src/lib/Components/Image/index.svelte +121 -0
  323. package/src/lib/Components/Image/index.svelte.js +114 -0
  324. package/src/lib/Components/ImageEditor/Image/CropBox/index.svelte +165 -0
  325. package/src/lib/Components/ImageEditor/Image/index.svelte +104 -0
  326. package/src/lib/Components/ImageEditor/Panels/AI/index.svelte +36 -0
  327. package/src/lib/Components/ImageEditor/Panels/Crop/index.svelte +96 -0
  328. package/src/lib/Components/ImageEditor/Panels/File/QualityPicker/index.svelte +124 -0
  329. package/src/lib/Components/ImageEditor/Panels/File/index.svelte +74 -0
  330. package/src/lib/Components/ImageEditor/Panels/Filters/index.svelte +46 -0
  331. package/src/lib/Components/ImageEditor/Panels/Resize/index.svelte +58 -0
  332. package/src/lib/Components/ImageEditor/index.svelte +91 -0
  333. package/src/lib/Components/ImageEditor/index.svelte.js +1907 -0
  334. package/src/lib/Components/ImageSlider/index.svelte +124 -0
  335. package/src/lib/Components/ImageSlider/index.svelte.js +99 -0
  336. package/src/lib/Components/InfoBox/index.svelte +89 -0
  337. package/src/lib/Components/Json/Nested/index.svelte +157 -0
  338. package/src/lib/Components/Json/index.svelte +60 -0
  339. package/src/lib/Components/Json/index.svelte.js +594 -0
  340. package/src/lib/Components/LabeledItem/index.svelte +102 -0
  341. package/src/lib/Components/Layout/NavBar/FullNav/index.svelte +53 -0
  342. package/src/lib/Components/Layout/NavBar/NavGuts/index.svelte +87 -0
  343. package/src/lib/Components/Layout/NavBar/index.svelte +72 -0
  344. package/src/lib/Components/Layout/index.svelte +149 -0
  345. package/src/lib/Components/Layout/index.svelte.js +362 -0
  346. package/src/lib/Components/Link/index.svelte +46 -0
  347. package/src/lib/Components/Link/index.svelte.js +126 -0
  348. package/src/lib/Components/LoadingSuccessDiv/index.svelte +51 -0
  349. package/src/lib/Components/LoadingWheel/index.svelte +38 -0
  350. package/src/lib/Components/Location/index.svelte +85 -0
  351. package/src/lib/Components/Location/index.svelte.js +292 -0
  352. package/src/lib/Components/LocationInput/index.svelte +200 -0
  353. package/src/lib/Components/LocationInput/index.svelte.js +950 -0
  354. package/src/lib/Components/Number/index.svelte +47 -0
  355. package/src/lib/Components/Number/index.svelte.js +151 -0
  356. package/src/lib/Components/PhoneCountryCode/index.svelte +7 -0
  357. package/src/lib/Components/PhoneCountryCode/index.svelte.js +260 -0
  358. package/src/lib/Components/PhoneNumber/index.svelte +22 -0
  359. package/src/lib/Components/PhoneNumber/index.svelte.js +41 -0
  360. package/src/lib/Components/Popover/index.svelte +396 -0
  361. package/src/lib/Components/Popover/index.svelte.js +319 -0
  362. package/src/lib/Components/Qr/index.svelte +60 -0
  363. package/src/lib/Components/Qr/index.svelte.js +295 -0
  364. package/src/lib/Components/Slider/index.svelte +231 -0
  365. package/src/lib/Components/Slider/index.svelte.js +468 -0
  366. package/src/lib/Components/Spacer/index.svelte +41 -0
  367. package/src/lib/Components/StoragePicker/DisplayFile/index.svelte +15 -0
  368. package/src/lib/Components/StoragePicker/index.svelte +192 -0
  369. package/src/lib/Components/StoragePicker/index.svelte.js +593 -0
  370. package/src/lib/Components/SuccessCheck/index.svelte +56 -0
  371. package/src/lib/Components/TableAdvanced/ColumnInput/index.svelte +110 -0
  372. package/src/lib/Components/TableAdvanced/ColumnInput/index.svelte.js +494 -0
  373. package/src/lib/Components/TableAdvanced/FilterInput/index.svelte +54 -0
  374. package/src/lib/Components/TableAdvanced/FilterInput/index.svelte.js +247 -0
  375. package/src/lib/Components/TableAdvanced/Pagination/index.svelte +43 -0
  376. package/src/lib/Components/TableAdvanced/Pagination/index.svelte.js +97 -0
  377. package/src/lib/Components/TableAdvanced/SortByInput/index.svelte +79 -0
  378. package/src/lib/Components/TableAdvanced/SortByInput/index.svelte.js +191 -0
  379. package/src/lib/Components/TableAdvanced/index.svelte +268 -0
  380. package/src/lib/Components/TableAdvanced/index.svelte.js +1422 -0
  381. package/src/lib/Components/Tag/index.svelte +45 -0
  382. package/src/lib/Components/Tag/index.svelte.js +76 -0
  383. package/src/lib/Components/TextArrayInput/index.svelte +108 -0
  384. package/src/lib/Components/TextArrayInput/index.svelte.js +239 -0
  385. package/src/lib/Components/TextInput/PasswordTooltip/index.svelte +89 -0
  386. package/src/lib/Components/TextInput/index.svelte +223 -0
  387. package/src/lib/Components/TextInput/index.svelte.js +434 -0
  388. package/src/lib/Components/Time/index.svelte +7 -0
  389. package/src/lib/Components/Time/index.svelte.js +38 -0
  390. package/src/lib/Components/TimeInput/NumberToggler/index.svelte +34 -0
  391. package/src/lib/Components/TimeInput/NumberToggler/index.svelte.js +79 -0
  392. package/src/lib/Components/TimeInput/index.js +699 -0
  393. package/src/lib/Components/TimeInput/index.svelte +211 -0
  394. package/src/lib/Components/TimeInput/index.svelte.js +638 -0
  395. package/src/lib/Components/Tooltip/index.svelte +143 -0
  396. package/src/lib/Components/TransparentBackground/index.svelte +153 -0
  397. package/src/lib/Components/TypingDots/index.svelte +84 -0
  398. package/src/lib/Components/VariablePathInput/index.svelte +109 -0
  399. package/src/lib/Components/VariablePathInput/index.svelte.js +250 -0
  400. package/src/lib/Components/VideoTBD/index.svelte +100 -0
  401. package/src/lib/Components/XFollow/index.svelte +42 -0
  402. package/src/lib/Components/XPost/index.svelte +52 -0
  403. package/src/lib/Components/XPost/index.svelte.js +64 -0
  404. package/src/lib/Components/YoutubeVideo/index.svelte +73 -0
  405. package/src/lib/Components/YoutubeVideo/index.svelte.js +54 -0
  406. package/src/lib/actions/draggable.js +49 -0
  407. package/src/lib/actions/intersection_observer.js +24 -0
  408. package/src/lib/actions/no_spaces.js +33 -0
  409. package/src/lib/actions/numbers_only.js +26 -0
  410. package/src/lib/actions/scroll_y.js +28 -0
  411. package/src/lib/actions/stop_scroll_propagation_y.js +42 -0
  412. package/src/lib/actions/swipe_handler.js +295 -0
  413. package/src/lib/client/astc_formatting/index.js +1167 -0
  414. package/src/lib/client/docs/index.js +7612 -0
  415. package/src/lib/client/index.js +729 -0
  416. package/src/lib/client/types/index.js +4681 -0
  417. package/src/lib/index.js +161 -0
  418. package/src/lib/style.css +682 -0
  419. package/src/notlib/assets/static/Logo/index.svelte +27 -0
  420. package/src/routes/+layout.js +8 -0
  421. package/src/routes/+layout.svelte +176 -0
  422. package/src/routes/+page.svelte +83 -0
  423. package/src/routes/[component]/+page.svelte +167 -0
  424. package/src/routes/[component]/Showcase/Alert/index.svelte +26 -0
  425. package/src/routes/[component]/Showcase/Audio/index.svelte +86 -0
  426. package/src/routes/[component]/Showcase/AudioEditor/index.svelte +93 -0
  427. package/src/routes/[component]/Showcase/AuthCodeInput/index.svelte +13 -0
  428. package/src/routes/[component]/Showcase/Breadcrumbs/index.svelte +44 -0
  429. package/src/routes/[component]/Showcase/Button/index.svelte +350 -0
  430. package/src/routes/[component]/Showcase/Chart/index.svelte +11117 -0
  431. package/src/routes/[component]/Showcase/Checkbox/index.svelte +52 -0
  432. package/src/routes/[component]/Showcase/Code/index.svelte +13 -0
  433. package/src/routes/[component]/Showcase/Color/index.svelte +28 -0
  434. package/src/routes/[component]/Showcase/ColorInput/index.svelte +35 -0
  435. package/src/routes/[component]/Showcase/ConditionsInput/index.svelte +18 -0
  436. package/src/routes/[component]/Showcase/Confetti/index.svelte +22 -0
  437. package/src/routes/[component]/Showcase/Content/index.svelte +144 -0
  438. package/src/routes/[component]/Showcase/ContentInput/index.svelte +358 -0
  439. package/src/routes/[component]/Showcase/CronInput/index.svelte +30 -0
  440. package/src/routes/[component]/Showcase/DocsDefinition/index.svelte +155 -0
  441. package/src/routes/[component]/Showcase/Dropdown/index.svelte +88 -0
  442. package/src/routes/[component]/Showcase/FileInput/index.svelte +40 -0
  443. package/src/routes/[component]/Showcase/FunctionInput/index.svelte +77 -0
  444. package/src/routes/[component]/Showcase/Icon/index.svelte +120 -0
  445. package/src/routes/[component]/Showcase/IconInput/index.svelte +15 -0
  446. package/src/routes/[component]/Showcase/Image/index.svelte +119 -0
  447. package/src/routes/[component]/Showcase/ImageEditor/index.svelte +89 -0
  448. package/src/routes/[component]/Showcase/ImageSlider/index.svelte +26 -0
  449. package/src/routes/[component]/Showcase/InfoBox/index.svelte +44 -0
  450. package/src/routes/[component]/Showcase/Json/index.svelte +80 -0
  451. package/src/routes/[component]/Showcase/LabeledItem/index.svelte +18 -0
  452. package/src/routes/[component]/Showcase/Link/index.svelte +15 -0
  453. package/src/routes/[component]/Showcase/LoadingWheel/index.svelte +10 -0
  454. package/src/routes/[component]/Showcase/Location/index.svelte +422 -0
  455. package/src/routes/[component]/Showcase/LocationInput/index.svelte +121 -0
  456. package/src/routes/[component]/Showcase/Number/index.svelte +55 -0
  457. package/src/routes/[component]/Showcase/Popover/index.svelte +225 -0
  458. package/src/routes/[component]/Showcase/Qr/index.svelte +77 -0
  459. package/src/routes/[component]/Showcase/Slider/index.svelte +92 -0
  460. package/src/routes/[component]/Showcase/Spacer/index.svelte +27 -0
  461. package/src/routes/[component]/Showcase/StoragePicker/index.svelte +139 -0
  462. package/src/routes/[component]/Showcase/TableAdvanced/index.svelte +888 -0
  463. package/src/routes/[component]/Showcase/Tag/index.svelte +27 -0
  464. package/src/routes/[component]/Showcase/TextArrayInput/index.svelte +23 -0
  465. package/src/routes/[component]/Showcase/TextInput/index.svelte +95 -0
  466. package/src/routes/[component]/Showcase/Time/index.svelte +43 -0
  467. package/src/routes/[component]/Showcase/TimeInput/index.svelte +100 -0
  468. package/src/routes/[component]/Showcase/Tooltip/index.svelte +37 -0
  469. package/src/routes/[component]/Showcase/TransparentBackground/index.svelte +26 -0
  470. package/src/routes/[component]/Showcase/XFollow/index.svelte +7 -0
  471. package/src/routes/[component]/Showcase/XPost/index.svelte +24 -0
  472. package/src/routes/[component]/Showcase/YoutubeVideo/index.svelte +17 -0
  473. package/src/routes/test/+page.svelte +53 -0
  474. package/static/apple-touch-icon.png +0 -0
  475. package/static/browserconfig.xml +9 -0
  476. package/static/favicon-96x96.png +0 -0
  477. package/static/favicon-inactive.svg +4 -0
  478. package/static/favicon.svg +14 -0
  479. package/static/fonts/ProximaVara.woff2 +0 -0
  480. package/static/fonts/Quicksand-VariableFont.woff2 +0 -0
  481. package/static/fonts/RobotoSerif-VariableFont.woff2 +0 -0
  482. package/static/icon.png +0 -0
  483. package/static/site.webmanifest +21 -0
  484. package/static/web-app-manifest-192x192.png +0 -0
  485. package/static/web-app-manifest-512x512.png +0 -0
  486. package/svelte.config.js +12 -0
  487. package/vite.config.js +6 -0
@@ -0,0 +1,250 @@
1
+ import { create_popover_manager } from "../Popover/index.svelte.js"
2
+ import { create_button_manager } from "../Button/index.svelte.js"
3
+ import { create_text_input_manager } from "../TextInput/index.svelte.js"
4
+ import { create_icon_manager } from "../Icon/index.svelte.js"
5
+ import { create_checkbox_manager } from "../Checkbox/index.svelte.js"
6
+ import { deep_copy, set_closurable, get_data_type_at_path } from "../../client/index.js"
7
+
8
+ export function create_variable_path_input_manager(config) {
9
+ let val = $state(null)
10
+ let is_popover = $state(true)
11
+ let popover_manager = $state(null)
12
+ let popover_toggle_button_manager = $state(null)
13
+ let small_popover_toggle_button_manager = $state(null)
14
+ let set_null_button_manager = $state(null)
15
+ let set_root_path_button_manager = $state(null)
16
+ let is_dynamic_path_item_checkbox_manager = $state(null)
17
+ let next_path_variable_path_input_manager = $state(null)
18
+ let finish_button_manager = $state(null)
19
+ let next_path_options = $state(null)
20
+ let val_prepped = $state(null)
21
+ let arrow_icon_manager = $state(null)
22
+
23
+ let is_allow_dynamic_path_item = $derived(set_closurable(config?.is_allow_dynamic_path_item, true))
24
+ let variables_data_type = $derived(set_closurable(config?.variables_data_type, null))
25
+ let full_data_type = $derived({
26
+ name: "Object",
27
+ type: "object_literal",
28
+ properties: {
29
+ variables: variables_data_type,
30
+ loops: { type: "loop" },
31
+ },
32
+ })
33
+ // if data_type changes dynamically set_next_path_options also needs updated
34
+ let data_type_at_path = $derived(get_data_type_at_path(val, full_data_type))
35
+
36
+ function set_val_prepped() {
37
+ let val_prepped_loc = []
38
+ if (Array.isArray(val)) {
39
+ for (let i = 0; i < val.length; i++) {
40
+ val_prepped_loc.push({
41
+ ...val[i],
42
+ remove_path_button_manager: create_button_manager({
43
+ type: "outlined",
44
+ support_icon: "x",
45
+ text: Array.isArray(val?.[i]) ? `[${val?.[i]}]` : String(val?.[i]),
46
+ on_click: () => {
47
+ val = val.slice(0, i)
48
+ set_val_prepped()
49
+ set_next_path_options()
50
+ },
51
+ }),
52
+ })
53
+ }
54
+ }
55
+ val_prepped = val_prepped_loc
56
+ }
57
+
58
+ function add_path_item(input) {
59
+ if (!Array.isArray(val)) {
60
+ val = [input]
61
+ } else {
62
+ val = [...val, input]
63
+ }
64
+ is_dynamic_path_item_checkbox_manager.set_val(false)
65
+ next_path_variable_path_input_manager?.init()
66
+ set_next_path_options()
67
+ }
68
+
69
+ function set_next_path_options() {
70
+ let next_path_options_loc = null
71
+ if (data_type_at_path?.type == "loop") {
72
+ let number_input_manager = create_text_input_manager({
73
+ type: "number",
74
+ val: 0,
75
+ mt: 0.5,
76
+ mb: 0.5,
77
+ })
78
+ next_path_options_loc = {
79
+ type: "loop",
80
+ number_input_manager: number_input_manager,
81
+ add_path_item_button_manager: create_button_manager({
82
+ type: "outlined",
83
+ is_compressed: true,
84
+ text: "Add Path Item",
85
+ on_click: () => add_path_item(number_input_manager?.val),
86
+ }),
87
+ }
88
+ } else if (data_type_at_path?.type == "object_literal") {
89
+ let options_loc = $state([])
90
+ for (let [key, property] of Object.entries(data_type_at_path?.properties)) {
91
+ let option_button_manager = create_button_manager({
92
+ type: "outlined",
93
+ is_compressed: true,
94
+ text: `${key}: (${property?.type})`,
95
+ on_click: () => add_path_item(key),
96
+ })
97
+ options_loc.push({
98
+ option_button_manager: option_button_manager,
99
+ })
100
+ }
101
+ next_path_options_loc = {
102
+ type: "object_literal",
103
+ options: options_loc,
104
+ }
105
+ }
106
+ next_path_options = next_path_options_loc
107
+ set_val_prepped()
108
+ }
109
+
110
+ function finish() {
111
+ popover_manager.close()
112
+ if (typeof config?.on_finish == "function") {
113
+ config?.on_finish(val)
114
+ }
115
+ }
116
+
117
+ function set_val(input) {
118
+ val = input
119
+ set_val_prepped()
120
+ set_next_path_options()
121
+ }
122
+
123
+ function init(config) {
124
+ val = config?.val ?? null
125
+ popover_manager = create_popover_manager({
126
+ min_width: 320,
127
+ target_width: 400,
128
+ min_height: 320,
129
+ target_height: 400,
130
+ type: "center",
131
+ header: "Variable Path Input",
132
+ anchor_id: () => `button_${popover_toggle_button_manager?.id}`,
133
+ })
134
+ popover_toggle_button_manager = create_button_manager({
135
+ type: "outlined",
136
+ is_compressed: true,
137
+ text: "Select Variable Path",
138
+ popover_target: () => `popover_${popover_manager?.id}`,
139
+ })
140
+ small_popover_toggle_button_manager = create_button_manager({
141
+ type: "soft",
142
+ support_icon: "edit",
143
+ is_uniform: true,
144
+ icon_size: 1.6,
145
+ min_height: 2,
146
+ border_radius: 0.5,
147
+ c: 16,
148
+ popover_target: () => `popover_${popover_manager?.id}`,
149
+ })
150
+ set_null_button_manager = create_button_manager({
151
+ type: "outlined",
152
+ is_compressed: true,
153
+ text: "Set Null",
154
+ on_click: () => {
155
+ val = null
156
+ set_val_prepped()
157
+ set_next_path_options()
158
+ },
159
+ })
160
+ set_root_path_button_manager = create_button_manager({
161
+ type: "outlined",
162
+ is_compressed: true,
163
+ text: `Set Root Path (${data_type_at_path?.type})`,
164
+ on_click: () => {
165
+ val = []
166
+ set_val_prepped()
167
+ set_next_path_options()
168
+ },
169
+ })
170
+ is_dynamic_path_item_checkbox_manager = create_checkbox_manager({
171
+ type: "toggle",
172
+ label: "Is Dynamic Path Item",
173
+ val: false,
174
+ on_change: (input) => {
175
+ if (input) {
176
+ next_path_variable_path_input_manager = create_variable_path_input_manager({
177
+ is_popover: false,
178
+ is_allow_dynamic_path_item: false,
179
+ variables_data_type: () => variables_data_type,
180
+ on_finish: (input) => add_path_item(input),
181
+ })
182
+ }
183
+ },
184
+ })
185
+ finish_button_manager = create_button_manager({
186
+ text: "Finish",
187
+ on_click: () => finish(),
188
+ })
189
+ arrow_icon_manager = create_icon_manager({
190
+ icon_id: "arrow",
191
+ deg: 90,
192
+ size: 1.2,
193
+ color: "var(--g11-t)",
194
+ })
195
+ set_val_prepped()
196
+ set_next_path_options()
197
+ }
198
+
199
+ init(config)
200
+
201
+ return {
202
+ get val() {
203
+ return val
204
+ },
205
+ get val_prepped() {
206
+ return val_prepped
207
+ },
208
+ get is_popover() {
209
+ return is_popover
210
+ },
211
+ get data_type_at_path() {
212
+ return data_type_at_path
213
+ },
214
+ get popover_manager() {
215
+ return popover_manager
216
+ },
217
+ get popover_toggle_button_manager() {
218
+ return popover_toggle_button_manager
219
+ },
220
+ get small_popover_toggle_button_manager() {
221
+ return small_popover_toggle_button_manager
222
+ },
223
+ get next_path_options() {
224
+ return next_path_options
225
+ },
226
+ get set_null_button_manager() {
227
+ return set_null_button_manager
228
+ },
229
+ get set_root_path_button_manager() {
230
+ return set_root_path_button_manager
231
+ },
232
+ get is_allow_dynamic_path_item() {
233
+ return is_allow_dynamic_path_item
234
+ },
235
+ get is_dynamic_path_item_checkbox_manager() {
236
+ return is_dynamic_path_item_checkbox_manager
237
+ },
238
+ get next_path_variable_path_input_manager() {
239
+ return next_path_variable_path_input_manager
240
+ },
241
+ get finish_button_manager() {
242
+ return finish_button_manager
243
+ },
244
+ get arrow_icon_manager() {
245
+ return arrow_icon_manager
246
+ },
247
+ set_val,
248
+ init,
249
+ }
250
+ }
@@ -0,0 +1,100 @@
1
+ <script>
2
+ import { create_unique_id } from "../../client/index.js"
3
+ import { onMount } from "svelte"
4
+
5
+ function create_video_manager(config) {
6
+ const id = create_unique_id(null, 20)
7
+ let step = $state(null)
8
+
9
+ function draw() {
10
+ let video_el = document?.querySelector(`#video_${id}`)
11
+ let canvas_el = document?.querySelector(`#canvas_${id}`)
12
+ if (video_el && canvas_el) {
13
+ let ctx = canvas_el.getContext("2d")
14
+ ctx.filter = "blur(1px)"
15
+ ctx.drawImage(video_el, 0, 0, canvas_el.width, canvas_el.height)
16
+ }
17
+ }
18
+
19
+ function draw_loop() {
20
+ draw()
21
+ step = window.requestAnimationFrame(draw_loop)
22
+ }
23
+
24
+ function draw_pause() {
25
+ window.cancelAnimationFrame(step)
26
+ step = undefined
27
+ }
28
+
29
+ return {
30
+ id,
31
+ draw,
32
+ draw_loop,
33
+ draw_pause,
34
+ }
35
+ }
36
+
37
+ let manager = $state(null)
38
+ onMount(() => {
39
+ manager = create_video_manager()
40
+ })
41
+ </script>
42
+
43
+ <section class="wrapper">
44
+ <video
45
+ id={`video_${manager?.id}`}
46
+ controls
47
+ muted
48
+ class="video"
49
+ src="http://commondatastorage.googleapis.com/gtv-videos-bucket/sample/BigBuckBunny.mp4"
50
+ onpause={(e) => manager?.draw_pause(e)}
51
+ onended={(e) => manager?.draw_pause(e)}
52
+ onplay={(e) => manager?.draw_loop(e)}
53
+ onseeked={(e) => manager?.draw(e)}
54
+ onloadeddata={(e) => manager?.draw(e)}
55
+ ></video>
56
+ <canvas width="10" height="6" aria-hidden="true" class="canvas" id={`canvas_${manager?.id}`}></canvas>
57
+ </section>
58
+
59
+ <style>
60
+ *,
61
+ *::before,
62
+ *::after {
63
+ box-sizing: border-box;
64
+ }
65
+
66
+ .video,
67
+ .canvas {
68
+ display: block;
69
+ width: 100%;
70
+ height: auto;
71
+ margin: 0;
72
+ }
73
+
74
+ .wrapper {
75
+ position: relative;
76
+ box-shadow: inset 0 0 4rem 4.5rem var(--color-background);
77
+ max-width: 1600px;
78
+ margin: 0 auto;
79
+ }
80
+
81
+ .canvas {
82
+ position: absolute;
83
+ top: 0;
84
+ left: 0;
85
+ z-index: -1;
86
+ width: 100%;
87
+ height: 100%;
88
+ opacity: 0.4;
89
+ }
90
+
91
+ .video {
92
+ padding: 7rem;
93
+ }
94
+
95
+ @media (prefers-reduced-motion: reduce) {
96
+ .canvas {
97
+ display: none !important;
98
+ }
99
+ }
100
+ </style>
@@ -0,0 +1,42 @@
1
+ <script>
2
+ let { x_handle, size = 4 } = $props()
3
+ </script>
4
+
5
+ <a
6
+ href="https://x.com/{x_handle}"
7
+ role="button"
8
+ tabindex="0"
9
+ class="button_container"
10
+ target="_blank"
11
+ data-show-count="false"
12
+ style="min-height: {size}rem; border-radius: {size}rem; padding: {size / 3}rem {size / 2}rem;
13
+ font-size: {size / 1.8}rem;"
14
+ >
15
+ <svg fill="none" height={size * 5} width={size * 5} xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 1227"
16
+ ><path
17
+ d="M714.163 519.284 1160.89 0h-105.86L667.137 450.887 357.328 0H0l468.492 681.821L0 1226.37h105.866l409.625-476.152 327.181 476.152H1200L714.137 519.284h.026ZM569.165 687.828l-47.468-67.894-377.686-540.24h162.604l304.797 435.991 47.468 67.894 396.2 566.721H892.476L569.165 687.854v-.026Z"
18
+ fill="var(--g24-t)"
19
+ /></svg
20
+ >
21
+ @{x_handle}
22
+ </a>
23
+
24
+ <style>
25
+ .button_container {
26
+ display: flex;
27
+ width: fit-content;
28
+ gap: 0.8rem;
29
+ align-items: center;
30
+ background-color: var(--g1-t);
31
+ color: var(--g24-t);
32
+ text-decoration: none;
33
+ font-weight: 600;
34
+ box-shadow: 0px 0.5rem 1rem var(--g15-t);
35
+ transition: all 0.3s ease 0s;
36
+ }
37
+ .button_container:hover {
38
+ background-color: var(--g4-t);
39
+ box-shadow: 0px 0.3rem 2rem var(--g15-t);
40
+ transform: translateY(-0.2rem);
41
+ }
42
+ </style>
@@ -0,0 +1,52 @@
1
+ <script>
2
+ import LoadingWheel from "../LoadingWheel/index.svelte"
3
+
4
+ let { manager } = $props()
5
+
6
+ $effect(() => {
7
+ if (typeof manager?.load_script == "function") {
8
+ manager?.load_script()
9
+ }
10
+ })
11
+ </script>
12
+
13
+ <div id={manager?.selector_id}>
14
+ {#if manager?.is_loading}
15
+ <div
16
+ style="width: 100%; height: 30rem; display: grid; place-items: center; background-color: var(--shadow2-t); border-radius: 1rem;"
17
+ >
18
+ <LoadingWheel size={8} />
19
+ <p>Loading post</p>
20
+ </div>
21
+ {/if}
22
+ {#if manager?.error_message}
23
+ <div class="failed_to_load_box">
24
+ <p>{manager?.error_message}</p>
25
+ <a href="https://x.com/status/{manager?.post_id}">https://x.com/status/{manager?.post_id}</a>
26
+ </div>
27
+ {/if}
28
+ <div class="x_post_container">
29
+ <div id={`x_post_${manager?.id}`} class:is_hidden={!!manager?.error_message}></div>
30
+ </div>
31
+ </div>
32
+
33
+ <style>
34
+ .failed_to_load_box {
35
+ margin: 1rem 0;
36
+ background-color: oklch(var(--l8-t) var(--c16) var(--h3) / var(--o3));
37
+ border-radius: 1rem;
38
+ padding: 1rem;
39
+ }
40
+ .failed_to_load_box p {
41
+ color: oklch(var(--l3-t) var(--c16) var(--h3));
42
+ }
43
+ .is_hidden {
44
+ max-width: 0;
45
+ max-height: 0;
46
+ overflow: hidden;
47
+ }
48
+ .x_post_container {
49
+ max-width: 100% !important;
50
+ overflow-x: scroll;
51
+ }
52
+ </style>
@@ -0,0 +1,64 @@
1
+ import { create_unique_id } from "../../client/index.js"
2
+
3
+ export function create_x_post_manager(config) {
4
+ const id = create_unique_id(null, 20)
5
+
6
+ let is_loading = $state(false)
7
+ let is_script_loaded = $state(false)
8
+ let error_message = $state("")
9
+
10
+ let is_dark_theme = $derived(config?.is_dark_theme)
11
+ let theme = $derived(config?.is_dark_theme ? "dark" : "light")
12
+
13
+ function load_script() {
14
+ error_message = null
15
+ if (!is_script_loaded) {
16
+ const script = document.createElement("script")
17
+ script.src = "https://platform.twitter.com/widgets.js"
18
+ script.charset = "utf-8"
19
+ script.async = true
20
+ script.onload = () => {
21
+ is_script_loaded = true
22
+ render_x_post()
23
+ }
24
+ document.head.appendChild(script)
25
+ }
26
+ }
27
+
28
+ async function render_x_post() {
29
+ try {
30
+ error_message = ""
31
+ is_loading = true
32
+ let container_el = document?.querySelector(`#x_post_${id}`)
33
+ if (config?.post_id && is_script_loaded && window.twttr && container_el) {
34
+ const create_embed_res = await twttr.widgets.createTweet(config?.post_id, container_el, {
35
+ theme: theme,
36
+ dnt: true,
37
+ })
38
+ if (create_embed_res) {
39
+ error_message = ""
40
+ } else {
41
+ error_message = "Post not found or failed to load."
42
+ }
43
+ }
44
+ } catch {
45
+ error_message = "Post not found or failed to load."
46
+ } finally {
47
+ is_loading = false
48
+ }
49
+ }
50
+
51
+ return {
52
+ id,
53
+ get post_id() {
54
+ return config?.post_id
55
+ },
56
+ get is_dark_theme() {
57
+ return is_dark_theme
58
+ },
59
+ get theme() {
60
+ return theme
61
+ },
62
+ load_script,
63
+ }
64
+ }
@@ -0,0 +1,73 @@
1
+ <script>
2
+ import LoadingWheel from "../LoadingWheel/index.svelte"
3
+ import { onMount } from "svelte"
4
+
5
+ let { manager } = $props()
6
+
7
+ onMount(() => {
8
+ if (typeof manager?.render_video == "function") {
9
+ manager?.render_video()
10
+ }
11
+ })
12
+ </script>
13
+
14
+ <svelte:window onresize={() => manager.resize_video()} />
15
+
16
+ <div id={manager?.selector_id}>
17
+ {#if manager?.is_loading}
18
+ <div
19
+ style="width: 100%; height: 30rem; display: grid; place-items: center; background-color: var(--shadow2-t); border-radius: 1rem; margin-top: 2rem;"
20
+ >
21
+ <LoadingWheel size={8} />
22
+ <p>Loading Youtube Video</p>
23
+ </div>
24
+ {/if}
25
+ {#if manager?.error_message}
26
+ <div class="failed_to_load_box">
27
+ <p>{manager?.error_message}</p>
28
+ <a href="https://youtu.be/{manager?.video_id}">https://youtu.be/{manager?.video_id}</a>
29
+ </div>
30
+ {/if}
31
+ <div class="video_container">
32
+ <div class="video_inner_container">
33
+ <iframe
34
+ class:is_hidden={!!manager?.error_message}
35
+ style="position: absolute; top: 0; left: 0; width: 100%; height: 100%;"
36
+ src="https://www.youtube.com/embed/{manager?.video_id}?rel=0"
37
+ title="YouTube video player"
38
+ frameborder="0"
39
+ allow="clipboard-write; encrypted-media; gyroscope; web-share"
40
+ allowfullscreen
41
+ ></iframe>
42
+ </div>
43
+ </div>
44
+ </div>
45
+
46
+ <style>
47
+ .video_container {
48
+ position: relative;
49
+ width: 100%;
50
+ overflow: hidden;
51
+ margin-top: 2rem;
52
+ }
53
+ .video_inner_container {
54
+ position: relative;
55
+ padding-bottom: 56.25%;
56
+ height: 0;
57
+ overflow: hidden;
58
+ }
59
+ .failed_to_load_box {
60
+ margin: 1rem 0;
61
+ background-color: oklch(var(--l8-t) var(--c16) var(--h3) / var(--o3));
62
+ border-radius: 1rem;
63
+ padding: 1rem;
64
+ }
65
+ .failed_to_load_box p {
66
+ color: oklch(var(--l3-t) var(--c16) var(--h3));
67
+ }
68
+ .is_hidden {
69
+ max-width: 0;
70
+ max-height: 0;
71
+ overflow: hidden;
72
+ }
73
+ </style>
@@ -0,0 +1,54 @@
1
+ import { create_unique_id } from "../../client/index.js"
2
+
3
+ export function create_youtube_video_manager(config) {
4
+ let id = create_unique_id(null, 20)
5
+ let theme = $derived(config?.is_dark_theme ? "dark" : "light")
6
+
7
+ let is_loading = $state(false)
8
+ let error_message = $state("")
9
+
10
+ async function render_video() {
11
+ error_message = ""
12
+ is_loading = true
13
+ if (config?.video_id) {
14
+ var img = new Image()
15
+ img.src = "http://img.youtube.com/vi/" + config?.video_id + "/mqdefault.jpg"
16
+ img.onload = function () {
17
+ if (this.width === 120) {
18
+ error_message = "YouTube video not found or failed to load."
19
+ } else {
20
+ error_message = ""
21
+ resize_video()
22
+ }
23
+ }
24
+ } else {
25
+ error_message = "YouTube video not found or failed to load."
26
+ }
27
+ is_loading = false
28
+ }
29
+
30
+ function resize_video() {
31
+ const video_container = document?.querySelector(".video_container")
32
+ const max_width = video_container.clientWidth
33
+ const max_height = 15 * 16 // 20rem * 16px
34
+ const aspect_ratio = 16 / 9
35
+ const height = Math.min(max_width / aspect_ratio, max_height)
36
+ const width = height * aspect_ratio
37
+ if (video_container.style.height > height) {
38
+ video_container.style.height = `${height}px`
39
+ video_container.style.width = `${width}px`
40
+ }
41
+ }
42
+
43
+ return {
44
+ id,
45
+ get video_id() {
46
+ return config?.video_id
47
+ },
48
+ get theme() {
49
+ return theme
50
+ },
51
+ render_video,
52
+ resize_video,
53
+ }
54
+ }
@@ -0,0 +1,49 @@
1
+ export default function draggable(node) {
2
+ let is_dragging = false
3
+ let left
4
+ let top
5
+
6
+ function handle_pointerdown(e) {
7
+ is_dragging = true
8
+ top = JSON.parse(node.style.top.replace(/[^\d.-]/g, ""))
9
+ left = JSON.parse(node.style.left.replace(/[^\d.-]/g, ""))
10
+ }
11
+
12
+ function handle_pointerup(e) {
13
+ is_dragging = false
14
+ }
15
+
16
+ function handle_pointermove(e) {
17
+ if (is_dragging) {
18
+ left += e.movementX
19
+ top += e.movementY
20
+ node.style.top = `${top}px`
21
+ node.style.left = `${left}px`
22
+ node.dispatchEvent(
23
+ new CustomEvent("drag", { detail: { top: top, left: left } })
24
+ )
25
+ }
26
+ }
27
+
28
+ node.style.position = "absolute"
29
+ node.style.cursor = "move"
30
+ node.style.userSelect = "none"
31
+ node.style["touch-action"] = "none"
32
+ node.style["-webkit-touch-callout"] = "none"
33
+ node.style["-ms-touch-action"] = "none"
34
+ node.style["-moz-user-select"] = "none"
35
+ node.style["-webkit-user-select"] = "none"
36
+ node.style["-ms-user-select"] = "none"
37
+
38
+ node.addEventListener("pointerdown", handle_pointerdown)
39
+ window.addEventListener("pointerup", handle_pointerup)
40
+ window.addEventListener("pointermove", handle_pointermove)
41
+
42
+ return {
43
+ destroy() {
44
+ node.removeEventListener("pointerdown", handle_pointerdown)
45
+ window.removeEventListener("pointerup", handle_pointerup)
46
+ window.removeEventListener("pointermove", handle_pointermove)
47
+ },
48
+ }
49
+ }