@edgedev/create-edge-app 1.0.41 → 1.0.43

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 (366) hide show
  1. package/.env.dev +1 -0
  2. package/.vscode/settings.json +1 -1
  3. package/app.vue +72 -21
  4. package/assets/css/tailwind.css +78 -0
  5. package/bin/cli.js +1 -1
  6. package/components/subToolbar.vue +4 -13
  7. package/components/ui/accordion/Accordion.vue +19 -0
  8. package/components/ui/accordion/AccordionContent.vue +24 -0
  9. package/components/ui/accordion/AccordionItem.vue +24 -0
  10. package/components/ui/accordion/AccordionTrigger.vue +39 -0
  11. package/components/ui/accordion/index.js +4 -0
  12. package/components/ui/accordion/index.ts +4 -0
  13. package/components/ui/alert/Alert.vue +16 -0
  14. package/components/ui/alert/AlertDescription.vue +14 -0
  15. package/components/ui/alert/AlertTitle.vue +14 -0
  16. package/components/ui/alert/index.js +21 -0
  17. package/components/ui/alert/index.ts +23 -0
  18. package/components/ui/alert-dialog/AlertDialog.vue +14 -0
  19. package/components/ui/alert-dialog/AlertDialogAction.vue +20 -0
  20. package/components/ui/alert-dialog/AlertDialogCancel.vue +20 -0
  21. package/components/ui/alert-dialog/AlertDialogContent.vue +42 -0
  22. package/components/ui/alert-dialog/AlertDialogDescription.vue +25 -0
  23. package/components/ui/alert-dialog/AlertDialogFooter.vue +21 -0
  24. package/components/ui/alert-dialog/AlertDialogHeader.vue +16 -0
  25. package/components/ui/alert-dialog/AlertDialogTitle.vue +22 -0
  26. package/components/ui/alert-dialog/AlertDialogTrigger.vue +11 -0
  27. package/components/ui/alert-dialog/index.ts +9 -0
  28. package/components/ui/aspect-ratio/AspectRatio.vue +11 -0
  29. package/components/ui/aspect-ratio/index.ts +1 -0
  30. package/components/ui/auto-form/AutoForm.vue +105 -0
  31. package/components/ui/auto-form/AutoFormField.vue +45 -0
  32. package/components/ui/auto-form/AutoFormFieldArray.vue +110 -0
  33. package/components/ui/auto-form/AutoFormFieldBoolean.vue +41 -0
  34. package/components/ui/auto-form/AutoFormFieldDate.vue +57 -0
  35. package/components/ui/auto-form/AutoFormFieldEnum.vue +49 -0
  36. package/components/ui/auto-form/AutoFormFieldFile.vue +74 -0
  37. package/components/ui/auto-form/AutoFormFieldInput.vue +36 -0
  38. package/components/ui/auto-form/AutoFormFieldNumber.vue +32 -0
  39. package/components/ui/auto-form/AutoFormFieldObject.vue +78 -0
  40. package/components/ui/auto-form/AutoFormLabel.vue +14 -0
  41. package/components/ui/auto-form/constant.ts +39 -0
  42. package/components/ui/auto-form/dependencies.ts +92 -0
  43. package/components/ui/auto-form/index.ts +15 -0
  44. package/components/ui/auto-form/interface.ts +81 -0
  45. package/components/ui/auto-form/utils.ts +171 -0
  46. package/components/ui/avatar/Avatar.vue +21 -0
  47. package/components/ui/avatar/AvatarFallback.vue +11 -0
  48. package/components/ui/avatar/AvatarImage.vue +9 -0
  49. package/components/ui/avatar/index.ts +24 -0
  50. package/components/ui/badge/Badge.vue +16 -0
  51. package/components/ui/badge/index.ts +25 -0
  52. package/components/ui/breadcrumb/Breadcrumb.vue +13 -0
  53. package/components/ui/breadcrumb/BreadcrumbEllipsis.vue +22 -0
  54. package/components/ui/breadcrumb/BreadcrumbItem.vue +16 -0
  55. package/components/ui/breadcrumb/BreadcrumbLink.vue +19 -0
  56. package/components/ui/breadcrumb/BreadcrumbList.vue +16 -0
  57. package/components/ui/breadcrumb/BreadcrumbPage.vue +19 -0
  58. package/components/ui/breadcrumb/BreadcrumbSeparator.vue +21 -0
  59. package/components/ui/breadcrumb/index.ts +7 -0
  60. package/components/ui/button/Button.vue +26 -0
  61. package/components/ui/button/index.js +33 -0
  62. package/components/ui/button/index.ts +35 -0
  63. package/components/ui/calendar/Calendar.vue +60 -0
  64. package/components/ui/calendar/CalendarCell.vue +24 -0
  65. package/components/ui/calendar/CalendarCellTrigger.vue +38 -0
  66. package/components/ui/calendar/CalendarGrid.vue +24 -0
  67. package/components/ui/calendar/CalendarGridBody.vue +11 -0
  68. package/components/ui/calendar/CalendarGridHead.vue +11 -0
  69. package/components/ui/calendar/CalendarGridRow.vue +21 -0
  70. package/components/ui/calendar/CalendarHeadCell.vue +21 -0
  71. package/components/ui/calendar/CalendarHeader.vue +21 -0
  72. package/components/ui/calendar/CalendarHeading.vue +27 -0
  73. package/components/ui/calendar/CalendarNextButton.vue +32 -0
  74. package/components/ui/calendar/CalendarPrevButton.vue +32 -0
  75. package/components/ui/calendar/index.ts +12 -0
  76. package/components/ui/card/Card.vue +21 -0
  77. package/components/ui/card/CardContent.vue +14 -0
  78. package/components/ui/card/CardDescription.vue +14 -0
  79. package/components/ui/card/CardFooter.vue +14 -0
  80. package/components/ui/card/CardHeader.vue +14 -0
  81. package/components/ui/card/CardTitle.vue +18 -0
  82. package/components/ui/card/index.js +6 -0
  83. package/components/ui/card/index.ts +6 -0
  84. package/components/ui/carousel/Carousel.vue +44 -0
  85. package/components/ui/carousel/CarouselContent.vue +29 -0
  86. package/components/ui/carousel/CarouselItem.vue +23 -0
  87. package/components/ui/carousel/CarouselNext.vue +30 -0
  88. package/components/ui/carousel/CarouselPrevious.vue +30 -0
  89. package/components/ui/carousel/index.ts +10 -0
  90. package/components/ui/carousel/interface.ts +20 -0
  91. package/components/ui/carousel/useCarousel.ts +59 -0
  92. package/components/ui/chart/ChartCrosshair.vue +44 -0
  93. package/components/ui/chart/ChartLegend.vue +50 -0
  94. package/components/ui/chart/ChartSingleTooltip.vue +63 -0
  95. package/components/ui/chart/ChartTooltip.vue +40 -0
  96. package/components/ui/chart/index.ts +18 -0
  97. package/components/ui/chart/interface.ts +64 -0
  98. package/components/ui/chart-area/AreaChart.vue +136 -0
  99. package/components/ui/chart-area/index.ts +66 -0
  100. package/components/ui/chart-bar/BarChart.vue +115 -0
  101. package/components/ui/chart-bar/index.ts +66 -0
  102. package/components/ui/chart-donut/DonutChart.vue +100 -0
  103. package/components/ui/chart-donut/index.ts +39 -0
  104. package/components/ui/chart-line/LineChart.vue +105 -0
  105. package/components/ui/chart-line/index.ts +66 -0
  106. package/components/ui/checkbox/Checkbox.vue +33 -0
  107. package/components/ui/checkbox/index.ts +1 -0
  108. package/components/ui/collapsible/Collapsible.vue +15 -0
  109. package/components/ui/collapsible/CollapsibleContent.vue +11 -0
  110. package/components/ui/collapsible/CollapsibleTrigger.vue +11 -0
  111. package/components/ui/collapsible/index.ts +3 -0
  112. package/components/ui/command/Command.vue +30 -0
  113. package/components/ui/command/CommandDialog.vue +21 -0
  114. package/components/ui/command/CommandEmpty.vue +20 -0
  115. package/components/ui/command/CommandGroup.vue +29 -0
  116. package/components/ui/command/CommandInput.vue +33 -0
  117. package/components/ui/command/CommandItem.vue +26 -0
  118. package/components/ui/command/CommandList.vue +27 -0
  119. package/components/ui/command/CommandSeparator.vue +23 -0
  120. package/components/ui/command/CommandShortcut.vue +14 -0
  121. package/components/ui/command/index.js +9 -0
  122. package/components/ui/command/index.ts +9 -0
  123. package/components/ui/context-menu/ContextMenu.vue +15 -0
  124. package/components/ui/context-menu/ContextMenuCheckboxItem.vue +40 -0
  125. package/components/ui/context-menu/ContextMenuContent.vue +36 -0
  126. package/components/ui/context-menu/ContextMenuGroup.vue +11 -0
  127. package/components/ui/context-menu/ContextMenuItem.vue +34 -0
  128. package/components/ui/context-menu/ContextMenuLabel.vue +25 -0
  129. package/components/ui/context-menu/ContextMenuPortal.vue +11 -0
  130. package/components/ui/context-menu/ContextMenuRadioGroup.vue +19 -0
  131. package/components/ui/context-menu/ContextMenuRadioItem.vue +40 -0
  132. package/components/ui/context-menu/ContextMenuSeparator.vue +20 -0
  133. package/components/ui/context-menu/ContextMenuShortcut.vue +14 -0
  134. package/components/ui/context-menu/ContextMenuSub.vue +19 -0
  135. package/components/ui/context-menu/ContextMenuSubContent.vue +35 -0
  136. package/components/ui/context-menu/ContextMenuSubTrigger.vue +34 -0
  137. package/components/ui/context-menu/ContextMenuTrigger.vue +13 -0
  138. package/components/ui/context-menu/index.ts +14 -0
  139. package/components/ui/dialog/Dialog.vue +14 -0
  140. package/components/ui/dialog/DialogClose.vue +11 -0
  141. package/components/ui/dialog/DialogContent.vue +50 -0
  142. package/components/ui/dialog/DialogDescription.vue +24 -0
  143. package/components/ui/dialog/DialogFooter.vue +19 -0
  144. package/components/ui/dialog/DialogHeader.vue +16 -0
  145. package/components/ui/dialog/DialogScrollContent.vue +59 -0
  146. package/components/ui/dialog/DialogTitle.vue +29 -0
  147. package/components/ui/dialog/DialogTrigger.vue +11 -0
  148. package/components/ui/dialog/index.js +9 -0
  149. package/components/ui/dialog/index.ts +9 -0
  150. package/components/ui/drawer/Drawer.vue +19 -0
  151. package/components/ui/drawer/DrawerContent.vue +28 -0
  152. package/components/ui/drawer/DrawerDescription.vue +20 -0
  153. package/components/ui/drawer/DrawerFooter.vue +14 -0
  154. package/components/ui/drawer/DrawerHeader.vue +14 -0
  155. package/components/ui/drawer/DrawerOverlay.vue +18 -0
  156. package/components/ui/drawer/DrawerTitle.vue +20 -0
  157. package/components/ui/drawer/index.ts +8 -0
  158. package/components/ui/dropdown-menu/DropdownMenu.vue +14 -0
  159. package/components/ui/dropdown-menu/DropdownMenuCheckboxItem.vue +40 -0
  160. package/components/ui/dropdown-menu/DropdownMenuContent.vue +38 -0
  161. package/components/ui/dropdown-menu/DropdownMenuGroup.vue +11 -0
  162. package/components/ui/dropdown-menu/DropdownMenuItem.vue +28 -0
  163. package/components/ui/dropdown-menu/DropdownMenuLabel.vue +24 -0
  164. package/components/ui/dropdown-menu/DropdownMenuRadioGroup.vue +19 -0
  165. package/components/ui/dropdown-menu/DropdownMenuRadioItem.vue +41 -0
  166. package/components/ui/dropdown-menu/DropdownMenuSeparator.vue +22 -0
  167. package/components/ui/dropdown-menu/DropdownMenuShortcut.vue +14 -0
  168. package/components/ui/dropdown-menu/DropdownMenuSub.vue +19 -0
  169. package/components/ui/dropdown-menu/DropdownMenuSubContent.vue +30 -0
  170. package/components/ui/dropdown-menu/DropdownMenuSubTrigger.vue +33 -0
  171. package/components/ui/dropdown-menu/DropdownMenuTrigger.vue +13 -0
  172. package/components/ui/dropdown-menu/index.ts +16 -0
  173. package/components/ui/form/FormControl.vue +16 -0
  174. package/components/ui/form/FormDescription.vue +20 -0
  175. package/components/ui/form/FormItem.vue +19 -0
  176. package/components/ui/form/FormLabel.vue +23 -0
  177. package/components/ui/form/FormMessage.vue +16 -0
  178. package/components/ui/form/index.js +7 -0
  179. package/components/ui/form/index.ts +7 -0
  180. package/components/ui/form/injectionKeys.js +1 -0
  181. package/components/ui/form/injectionKeys.ts +4 -0
  182. package/components/ui/form/useFormField.js +36 -0
  183. package/components/ui/form/useFormField.ts +30 -0
  184. package/components/ui/hover-card/HoverCard.vue +14 -0
  185. package/components/ui/hover-card/HoverCardContent.vue +41 -0
  186. package/components/ui/hover-card/HoverCardTrigger.vue +11 -0
  187. package/components/ui/hover-card/index.ts +3 -0
  188. package/components/ui/input/Input.vue +24 -0
  189. package/components/ui/input/index.js +1 -0
  190. package/components/ui/input/index.ts +1 -0
  191. package/components/ui/label/Label.vue +27 -0
  192. package/components/ui/label/index.js +1 -0
  193. package/components/ui/label/index.ts +1 -0
  194. package/components/ui/menubar/Menubar.vue +35 -0
  195. package/components/ui/menubar/MenubarCheckboxItem.vue +40 -0
  196. package/components/ui/menubar/MenubarContent.vue +43 -0
  197. package/components/ui/menubar/MenubarGroup.vue +11 -0
  198. package/components/ui/menubar/MenubarItem.vue +35 -0
  199. package/components/ui/menubar/MenubarLabel.vue +13 -0
  200. package/components/ui/menubar/MenubarMenu.vue +11 -0
  201. package/components/ui/menubar/MenubarRadioGroup.vue +20 -0
  202. package/components/ui/menubar/MenubarRadioItem.vue +40 -0
  203. package/components/ui/menubar/MenubarSeparator.vue +19 -0
  204. package/components/ui/menubar/MenubarShortcut.vue +14 -0
  205. package/components/ui/menubar/MenubarSub.vue +19 -0
  206. package/components/ui/menubar/MenubarSubContent.vue +39 -0
  207. package/components/ui/menubar/MenubarSubTrigger.vue +30 -0
  208. package/components/ui/menubar/MenubarTrigger.vue +29 -0
  209. package/components/ui/menubar/index.ts +15 -0
  210. package/components/ui/navigation-menu/NavigationMenu.vue +33 -0
  211. package/components/ui/navigation-menu/NavigationMenuContent.vue +34 -0
  212. package/components/ui/navigation-menu/NavigationMenuIndicator.vue +24 -0
  213. package/components/ui/navigation-menu/NavigationMenuItem.vue +11 -0
  214. package/components/ui/navigation-menu/NavigationMenuLink.vue +19 -0
  215. package/components/ui/navigation-menu/NavigationMenuList.vue +29 -0
  216. package/components/ui/navigation-menu/NavigationMenuTrigger.vue +34 -0
  217. package/components/ui/navigation-menu/NavigationMenuViewport.vue +33 -0
  218. package/components/ui/navigation-menu/index.ts +12 -0
  219. package/components/ui/number-field/NumberField.vue +23 -0
  220. package/components/ui/number-field/NumberFieldContent.vue +14 -0
  221. package/components/ui/number-field/NumberFieldDecrement.vue +25 -0
  222. package/components/ui/number-field/NumberFieldIncrement.vue +25 -0
  223. package/components/ui/number-field/NumberFieldInput.vue +8 -0
  224. package/components/ui/number-field/index.ts +5 -0
  225. package/components/ui/pagination/PaginationEllipsis.vue +22 -0
  226. package/components/ui/pagination/PaginationFirst.vue +29 -0
  227. package/components/ui/pagination/PaginationLast.vue +29 -0
  228. package/components/ui/pagination/PaginationNext.vue +29 -0
  229. package/components/ui/pagination/PaginationPrev.vue +29 -0
  230. package/components/ui/pagination/index.ts +10 -0
  231. package/components/ui/pin-input/PinInput.vue +23 -0
  232. package/components/ui/pin-input/PinInputGroup.vue +18 -0
  233. package/components/ui/pin-input/PinInputInput.vue +18 -0
  234. package/components/ui/pin-input/PinInputSeparator.vue +15 -0
  235. package/components/ui/pin-input/index.ts +4 -0
  236. package/components/ui/popover/Popover.vue +15 -0
  237. package/components/ui/popover/PopoverContent.vue +48 -0
  238. package/components/ui/popover/PopoverTrigger.vue +11 -0
  239. package/components/ui/popover/index.js +3 -0
  240. package/components/ui/popover/index.ts +3 -0
  241. package/components/ui/progress/Progress.vue +39 -0
  242. package/components/ui/progress/index.js +1 -0
  243. package/components/ui/progress/index.ts +1 -0
  244. package/components/ui/radio-group/RadioGroup.vue +25 -0
  245. package/components/ui/radio-group/RadioGroupItem.vue +39 -0
  246. package/components/ui/radio-group/index.ts +2 -0
  247. package/components/ui/range-calendar/RangeCalendar.vue +60 -0
  248. package/components/ui/range-calendar/RangeCalendarCell.vue +24 -0
  249. package/components/ui/range-calendar/RangeCalendarCellTrigger.vue +40 -0
  250. package/components/ui/range-calendar/RangeCalendarGrid.vue +24 -0
  251. package/components/ui/range-calendar/RangeCalendarGridBody.vue +11 -0
  252. package/components/ui/range-calendar/RangeCalendarGridHead.vue +11 -0
  253. package/components/ui/range-calendar/RangeCalendarGridRow.vue +21 -0
  254. package/components/ui/range-calendar/RangeCalendarHeadCell.vue +21 -0
  255. package/components/ui/range-calendar/RangeCalendarHeader.vue +21 -0
  256. package/components/ui/range-calendar/RangeCalendarHeading.vue +27 -0
  257. package/components/ui/range-calendar/RangeCalendarNextButton.vue +32 -0
  258. package/components/ui/range-calendar/RangeCalendarPrevButton.vue +32 -0
  259. package/components/ui/range-calendar/index.ts +12 -0
  260. package/components/ui/resizable/ResizableHandle.vue +26 -0
  261. package/components/ui/resizable/ResizablePanelGroup.vue +21 -0
  262. package/components/ui/resizable/index.ts +3 -0
  263. package/components/ui/scroll-area/ScrollArea.vue +29 -0
  264. package/components/ui/scroll-area/ScrollBar.vue +30 -0
  265. package/components/ui/scroll-area/index.ts +2 -0
  266. package/components/ui/select/Select.vue +15 -0
  267. package/components/ui/select/SelectContent.vue +53 -0
  268. package/components/ui/select/SelectGroup.vue +19 -0
  269. package/components/ui/select/SelectItem.vue +44 -0
  270. package/components/ui/select/SelectItemText.vue +11 -0
  271. package/components/ui/select/SelectLabel.vue +13 -0
  272. package/components/ui/select/SelectScrollDownButton.vue +24 -0
  273. package/components/ui/select/SelectScrollUpButton.vue +24 -0
  274. package/components/ui/select/SelectSeparator.vue +17 -0
  275. package/components/ui/select/SelectTrigger.vue +31 -0
  276. package/components/ui/select/SelectValue.vue +11 -0
  277. package/components/ui/select/index.ts +11 -0
  278. package/components/ui/separator/Separator.vue +20 -0
  279. package/components/ui/separator/index.js +1 -0
  280. package/components/ui/separator/index.ts +1 -0
  281. package/components/ui/sheet/Sheet.vue +14 -0
  282. package/components/ui/sheet/SheetClose.vue +11 -0
  283. package/components/ui/sheet/SheetContent.vue +56 -0
  284. package/components/ui/sheet/SheetDescription.vue +22 -0
  285. package/components/ui/sheet/SheetFooter.vue +19 -0
  286. package/components/ui/sheet/SheetHeader.vue +16 -0
  287. package/components/ui/sheet/SheetTitle.vue +22 -0
  288. package/components/ui/sheet/SheetTrigger.vue +11 -0
  289. package/components/ui/sheet/index.ts +31 -0
  290. package/components/ui/skeleton/Skeleton.vue +14 -0
  291. package/components/ui/skeleton/index.ts +1 -0
  292. package/components/ui/slider/Slider.vue +36 -0
  293. package/components/ui/slider/index.ts +1 -0
  294. package/components/ui/sonner/Sonner.vue +22 -0
  295. package/components/ui/sonner/index.ts +1 -0
  296. package/components/ui/switch/Switch.vue +37 -0
  297. package/components/ui/switch/index.ts +1 -0
  298. package/components/ui/table/Table.vue +16 -0
  299. package/components/ui/table/TableBody.vue +14 -0
  300. package/components/ui/table/TableCaption.vue +14 -0
  301. package/components/ui/table/TableCell.vue +21 -0
  302. package/components/ui/table/TableEmpty.vue +37 -0
  303. package/components/ui/table/TableFooter.vue +14 -0
  304. package/components/ui/table/TableHead.vue +14 -0
  305. package/components/ui/table/TableHeader.vue +14 -0
  306. package/components/ui/table/TableRow.vue +14 -0
  307. package/components/ui/table/index.ts +8 -0
  308. package/components/ui/tabs/Tabs.vue +15 -0
  309. package/components/ui/tabs/TabsContent.vue +22 -0
  310. package/components/ui/tabs/TabsList.vue +25 -0
  311. package/components/ui/tabs/TabsTrigger.vue +27 -0
  312. package/components/ui/tabs/index.ts +4 -0
  313. package/components/ui/tags-input/TagsInput.vue +22 -0
  314. package/components/ui/tags-input/TagsInputInput.vue +19 -0
  315. package/components/ui/tags-input/TagsInputItem.vue +22 -0
  316. package/components/ui/tags-input/TagsInputItemDelete.vue +24 -0
  317. package/components/ui/tags-input/TagsInputItemText.vue +19 -0
  318. package/components/ui/tags-input/index.ts +5 -0
  319. package/components/ui/textarea/Textarea.vue +24 -0
  320. package/components/ui/textarea/index.ts +1 -0
  321. package/components/ui/toast/Toast.vue +28 -0
  322. package/components/ui/toast/ToastAction.vue +19 -0
  323. package/components/ui/toast/ToastClose.vue +22 -0
  324. package/components/ui/toast/ToastDescription.vue +19 -0
  325. package/components/ui/toast/ToastProvider.vue +11 -0
  326. package/components/ui/toast/ToastTitle.vue +19 -0
  327. package/components/ui/toast/ToastViewport.vue +17 -0
  328. package/components/ui/toast/Toaster.vue +30 -0
  329. package/components/ui/toast/index.ts +38 -0
  330. package/components/ui/toast/use-toast.ts +165 -0
  331. package/components/ui/toggle/Toggle.vue +35 -0
  332. package/components/ui/toggle/index.ts +27 -0
  333. package/components/ui/toggle-group/ToggleGroup.vue +34 -0
  334. package/components/ui/toggle-group/ToggleGroupItem.vue +35 -0
  335. package/components/ui/toggle-group/index.ts +2 -0
  336. package/components/ui/tooltip/Tooltip.vue +14 -0
  337. package/components/ui/tooltip/TooltipContent.vue +31 -0
  338. package/components/ui/tooltip/TooltipProvider.vue +11 -0
  339. package/components/ui/tooltip/TooltipTrigger.vue +11 -0
  340. package/components/ui/tooltip/index.ts +4 -0
  341. package/components/ui/v-calendar/Calendar.vue +331 -0
  342. package/components/ui/v-calendar/index.ts +22 -0
  343. package/components.json +17 -0
  344. package/edge-components-install.sh +1 -0
  345. package/jsconfig.json +9 -0
  346. package/lib/utils.ts +6 -0
  347. package/nuxt.config.ts +28 -11
  348. package/package.json +33 -14
  349. package/pages/app/account/[page].vue +72 -0
  350. package/pages/app/dashboard/[[collection]]/[[docId]].vue +183 -0
  351. package/pages/app/login.vue +9 -7
  352. package/pages/app/signup.vue +9 -7
  353. package/plugins/icons.ts +72 -0
  354. package/tailwind.config.js +85 -0
  355. package/components/.gitkeep +0 -0
  356. package/components/account.vue +0 -107
  357. package/components/billing.vue +0 -8
  358. package/components/bottomMenu.vue +0 -35
  359. package/components/dashboard.vue +0 -186
  360. package/components/editor.vue +0 -247
  361. package/components/topMenu.vue +0 -17
  362. package/components/userMenu.vue +0 -64
  363. package/composables/vuetify.ts +0 -10
  364. package/pages/app/[[page]]/[[collection]]/[[docId]].vue +0 -48
  365. package/plugins/edgeFirebaseFramework.ts +0 -5
  366. package/plugins/vuetify.ts +0 -14
@@ -0,0 +1,183 @@
1
+ <script setup>
2
+ import { toTypedSchema } from '@vee-validate/zod'
3
+ import * as z from 'zod'
4
+ const route = useRoute()
5
+ const router = useRouter()
6
+ // const edgeGlobal = inject('edgeGlobal')
7
+
8
+ const edgeFirebase = inject('edgeFirebase')
9
+
10
+ const state = reactive({
11
+ filter: '',
12
+ newDocs: {
13
+ things: {
14
+ name: { bindings: { 'field-type': 'text', 'label': 'Name', 'helper': 'Name' }, cols: '12', value: '' },
15
+ description: { bindings: { 'field-type': 'text', 'label': 'Description', 'helper': 'Description' }, cols: '12', value: '' },
16
+ subthings: { bindings: { 'field-type': 'collection', 'label': 'Subthings', 'helper': 'Subthings', 'collection-path': 'subthings' }, cols: '12', value: '' },
17
+ },
18
+ subthings: {
19
+ name: { bindings: { 'field-type': 'text', 'label': 'Name', 'helper': 'Name' }, cols: '6', value: '' },
20
+ test: { bindings: { 'field-type': 'boolean', 'label': 'Description', 'helper': 'Test' }, cols: '6', value: '' },
21
+ selectTest: { bindings: { 'field-type': 'select', 'label': 'Select', 'helper': 'Select', 'items': ['test1', 'test2', 'test3'] }, cols: '12', value: '' },
22
+ testtextarea: { bindings: { 'field-type': 'textarea', 'label': 'Test Textarea', 'helper': 'Textarea' }, cols: '12', value: '' },
23
+ arrayThing: { bindings: { 'field-type': 'array', 'label': 'Array', 'helper': 'Array' }, cols: '12', value: [] },
24
+ objectThing: { bindings: { 'field-type': 'object', 'label': 'Object', 'helper': 'Obj' }, cols: '12', value: {} },
25
+ stringArray: { bindings: { 'field-type': 'stringArray', 'label': 'stringArray', 'helper': 'Obj' }, cols: '12', value: [] },
26
+ numberArray: { bindings: { 'field-type': 'numberArray', 'label': 'numberArray', 'helper': 'Obj' }, cols: '12', value: [] },
27
+ intArray: { bindings: { 'field-type': 'intArray', 'label': 'intArray', 'helper': 'Obj' }, cols: '12', value: [] },
28
+ usersThing: { bindings: { 'field-type': 'users', 'label': 'Users', 'helper': 'Users', 'hint': 'Choose a user' }, cols: '12', value: '' },
29
+ numberTest: { bindings: { 'field-type': 'number', 'label': 'Number', 'helper': 'Number' }, cols: '12', value: 0 },
30
+ intTest: { bindings: { 'field-type': 'integer', 'label': 'Int', 'helper': 'Int' }, cols: '12', value: 0 },
31
+ moneyTest: { bindings: { 'field-type': 'money', 'label': 'Money', 'helper': 'Money' }, cols: '12', value: 0 },
32
+ },
33
+ },
34
+ })
35
+
36
+ const schemas = {
37
+ things: toTypedSchema(z.object({
38
+ name: z.string({
39
+ required_error: 'Name is required',
40
+ }).min(1, { message: 'Name is required' }),
41
+ })),
42
+ subthings: toTypedSchema(z.object({
43
+ name: z.string({
44
+ required_error: 'Name is required',
45
+ }).min(1, { message: 'Name is required' }),
46
+ })),
47
+ }
48
+
49
+ const collection = computed(() => {
50
+ if (route.params.collection) {
51
+ return route.params.collection
52
+ }
53
+ return 'things'
54
+ })
55
+ const docId = computed(() => {
56
+ if (route.params.docId) {
57
+ return route.params.docId
58
+ }
59
+ return ''
60
+ })
61
+ definePageMeta({
62
+ middleware: 'auth',
63
+ })
64
+
65
+ onMounted(() => {
66
+ if (!route.params.collection) {
67
+ // If making a static collection route, this onMounted should be removed
68
+ router.push('/app/dashboard/things')
69
+ }
70
+ })
71
+ </script>
72
+
73
+ <template>
74
+ <div
75
+ v-if="edgeFirebase?.user?.loggedIn"
76
+ class="p-3 w-full h-[calc(100vh-118px)] overflow-y-auto"
77
+ >
78
+ <edge-dashboard v-if="docId === ''" :filter="state.filter" :collection="collection">
79
+ <template #header-start>
80
+ <LayoutDashboard class="mr-2" />
81
+ <span class="capitalize">{{ collection }}</span>
82
+ </template>
83
+ <template #header-center>
84
+ <div class="w-full px-6">
85
+ <edge-shad-input
86
+ v-model="state.filter"
87
+ label=""
88
+ name="filter"
89
+ placeholder="Filter..."
90
+ />
91
+ </div>
92
+ </template>
93
+ <template #header-end="slotProps">
94
+ <edge-shad-button class="uppercase bg-slate-600" :to="`/app/dashboard/${collection}/new`">
95
+ Add {{ slotProps.title }}
96
+ </edge-shad-button>
97
+ </template>
98
+ <template #list-item="slotProps">
99
+ <edge-shad-button variant="text" class="cursor-pointer w-full flex justify-between slotProps.items-center py-2 gap-3" :to="`/app/dashboard/${collection}/${slotProps.item.docId}`">
100
+ <div>
101
+ <Avatar class="cursor-pointer p-0 h-8 w-8 mr-2">
102
+ <FilePenLine class="h-5 w-5" />
103
+ </Avatar>
104
+ </div>
105
+ <div class="grow text-left">
106
+ <div class="text-lg">
107
+ {{ slotProps.item.name }}
108
+ </div>
109
+ </div>
110
+ <div>
111
+ <edge-shad-button
112
+ size="icon"
113
+ class="bg-slate-600 h-7 w-7"
114
+ @click.stop="slotProps.deleteItem(slotProps.item.docId)"
115
+ >
116
+ <Trash class="h-5 w-5" />
117
+ </edge-shad-button>
118
+ </div>
119
+ </edge-shad-button>
120
+ <Separator class="dark:bg-slate-600" />
121
+ </template>
122
+ </edge-dashboard>
123
+ <edge-editor
124
+ v-else
125
+ :collection="collection"
126
+ :doc-id="docId"
127
+ :schema="schemas[collection]"
128
+ :new-doc-schema="state.newDocs[collection]"
129
+ >
130
+ <template #header-start="slotProps">
131
+ <FilePenLine class="mr-2" />
132
+ {{ slotProps.title }}
133
+ </template>
134
+ <template #header-end="slotProps">
135
+ <edge-shad-button
136
+ v-if="!slotProps.unsavedChanges"
137
+ :to="`/app/dashboard/${collection}`"
138
+ class="bg-red-700 uppercase h-8 hover:bg-slate-400 w-20"
139
+ >
140
+ Close
141
+ </edge-shad-button>
142
+ <edge-shad-button
143
+ v-else
144
+ :to="`/app/dashboard/${collection}`"
145
+ class="bg-red-700 uppercase h-8 hover:bg-slate-400 w-20"
146
+ >
147
+ Cancel
148
+ </edge-shad-button>
149
+ <edge-shad-button
150
+ type="submit"
151
+ class="bg-slate-500 uppercase h-8 hover:bg-slate-400 w-20"
152
+ >
153
+ Save
154
+ </edge-shad-button>
155
+ </template>
156
+ <template #footer="slotProps">
157
+ <div class="flex w-full gap-1 items-center justify-end">
158
+ <edge-shad-button
159
+ v-if="!slotProps.unsavedChanges"
160
+ :to="`/app/dashboard/${collection}`"
161
+ class="bg-red-700 uppercase h-8 hover:bg-slate-400 w-20"
162
+ >
163
+ Close
164
+ </edge-shad-button>
165
+ <edge-shad-button
166
+ v-else
167
+ :to="`/app/dashboard/${collection}`"
168
+ class="bg-red-700 uppercase h-8 hover:bg-slate-400 w-20"
169
+ >
170
+ Cancel
171
+ </edge-shad-button>
172
+
173
+ <edge-shad-button
174
+ type="submit"
175
+ class="bg-slate-500 uppercase h-8 hover:bg-slate-400 w-20"
176
+ >
177
+ Save
178
+ </edge-shad-button>
179
+ </div>
180
+ </template>
181
+ </edge-editor>
182
+ </div>
183
+ </template>
@@ -2,13 +2,15 @@
2
2
  </script>
3
3
 
4
4
  <template>
5
- <v-container class="fill-height" fluid>
6
- <v-row align="center" class="fill-height" justify="center">
7
- <v-col cols="12" class="center-align" sm="8" md="6">
8
- <edge-auth type="login" />
9
- </v-col>
10
- </v-row>
11
- </v-container>
5
+ <div class="flex w-full h-full align-center items-center overflow-y-auto">
6
+ <edge-auth type="login" class="p-8 mx-auto max-w-lg w-full">
7
+ <div class="grid gap-2 text-center">
8
+ <h1 class="text-2xl font-bold">
9
+ Login
10
+ </h1>
11
+ </div>
12
+ </edge-auth>
13
+ </div>
12
14
  </template>
13
15
 
14
16
  <style lang="scss" scoped>
@@ -3,13 +3,15 @@ const config = useRuntimeConfig()
3
3
  </script>
4
4
 
5
5
  <template>
6
- <v-container class="fill-height" fluid>
7
- <v-row align="center" class="fill-height" justify="center">
8
- <v-col cols="12" class="center-align" sm="8" md="6">
9
- <edge-auth type="register" :registration-code="config.public.registrationCode" />
10
- </v-col>
11
- </v-row>
12
- </v-container>
6
+ <div class="flex w-full h-full align-center overflow-y-auto">
7
+ <edge-auth type="register" :registration-code="config.public.registrationCode" class="p-8 mx-auto max-w-lg w-full">
8
+ <div class="grid gap-2 text-center">
9
+ <h1 class="text-2xl font-bold">
10
+ Sign Up
11
+ </h1>
12
+ </div>
13
+ </edge-auth>
14
+ </div>
13
15
  </template>
14
16
 
15
17
  <style lang="scss" scoped>
@@ -0,0 +1,72 @@
1
+ import {
2
+ ArrowLeft,
3
+ ArrowRight,
4
+ Box,
5
+ Braces,
6
+ Brackets,
7
+ CalendarIcon,
8
+ Check,
9
+ ChevronDown,
10
+ ChevronLeft,
11
+ ChevronRight,
12
+ ChevronsUpDown,
13
+ CircleUser,
14
+ Copy,
15
+ Eye,
16
+ EyeOff,
17
+ FilePenLine,
18
+ Grip,
19
+ Group,
20
+ Info,
21
+ LayoutDashboard,
22
+ List,
23
+ ListPlus,
24
+ Loader2,
25
+ LogOut, MoreHorizontal,
26
+ Package,
27
+ Pencil,
28
+ PlusIcon,
29
+ Settings,
30
+ Settings2,
31
+ Trash,
32
+ TrashIcon,
33
+ User,
34
+ Users,
35
+ } from 'lucide-vue-next'
36
+
37
+ export default defineNuxtPlugin((nuxtApp) => {
38
+ nuxtApp.vueApp.component('Package', Package)
39
+ nuxtApp.vueApp.component('Braces', Braces)
40
+ nuxtApp.vueApp.component('Brackets', Brackets)
41
+ nuxtApp.vueApp.component('Grip', Grip)
42
+ nuxtApp.vueApp.component('ListPlus', ListPlus)
43
+ nuxtApp.vueApp.component('Pencil', Pencil)
44
+ nuxtApp.vueApp.component('Trash', Trash)
45
+ nuxtApp.vueApp.component('Check', Check)
46
+ nuxtApp.vueApp.component('Loader2', Loader2)
47
+ nuxtApp.vueApp.component('User', User)
48
+ nuxtApp.vueApp.component('ChevronsUpDown', ChevronsUpDown)
49
+ nuxtApp.vueApp.component('Eye', Eye)
50
+ nuxtApp.vueApp.component('EyeOff', EyeOff)
51
+ nuxtApp.vueApp.component('CircleUser', CircleUser)
52
+ nuxtApp.vueApp.component('Group', Group)
53
+ nuxtApp.vueApp.component('Settings', Settings)
54
+ nuxtApp.vueApp.component('Users', Users)
55
+ nuxtApp.vueApp.component('Settings2', Settings2)
56
+ nuxtApp.vueApp.component('ChevronDown', ChevronDown)
57
+ nuxtApp.vueApp.component('PlusIcon', PlusIcon)
58
+ nuxtApp.vueApp.component('TrashIcon', TrashIcon)
59
+ nuxtApp.vueApp.component('CalendarIcon', CalendarIcon)
60
+ nuxtApp.vueApp.component('MoreHorizontal', MoreHorizontal)
61
+ nuxtApp.vueApp.component('ChevronRight', ChevronRight)
62
+ nuxtApp.vueApp.component('ChevronLeft', ChevronLeft)
63
+ nuxtApp.vueApp.component('ArrowRight', ArrowRight)
64
+ nuxtApp.vueApp.component('ArrowLeft', ArrowLeft)
65
+ nuxtApp.vueApp.component('Box', Box)
66
+ nuxtApp.vueApp.component('LogOut', LogOut)
67
+ nuxtApp.vueApp.component('Info', Info)
68
+ nuxtApp.vueApp.component('FilePenLine', FilePenLine)
69
+ nuxtApp.vueApp.component('List', List)
70
+ nuxtApp.vueApp.component('Copy', Copy)
71
+ nuxtApp.vueApp.component('LayoutDashboard', LayoutDashboard)
72
+ })
@@ -0,0 +1,85 @@
1
+ const animate = require('tailwindcss-animate')
2
+
3
+ /** @type {import('tailwindcss').Config} */
4
+ module.exports = {
5
+ darkMode: ['class'],
6
+ safelist: ['dark'],
7
+ prefix: '',
8
+ theme: {
9
+ container: {
10
+ center: true,
11
+ padding: '2rem',
12
+ screens: {
13
+ '2xl': '1400px',
14
+ },
15
+ },
16
+ extend: {
17
+ colors: {
18
+ border: 'hsl(var(--border))',
19
+ input: 'hsl(var(--input))',
20
+ ring: 'hsl(var(--ring))',
21
+ background: 'hsl(var(--background))',
22
+ foreground: 'hsl(var(--foreground))',
23
+ primary: {
24
+ DEFAULT: 'hsl(var(--primary))',
25
+ foreground: 'hsl(var(--primary-foreground))',
26
+ },
27
+ secondary: {
28
+ DEFAULT: 'hsl(var(--secondary))',
29
+ foreground: 'hsl(var(--secondary-foreground))',
30
+ },
31
+ destructive: {
32
+ DEFAULT: 'hsl(var(--destructive))',
33
+ foreground: 'hsl(var(--destructive-foreground))',
34
+ },
35
+ muted: {
36
+ DEFAULT: 'hsl(var(--muted))',
37
+ foreground: 'hsl(var(--muted-foreground))',
38
+ },
39
+ accent: {
40
+ DEFAULT: 'hsl(var(--accent))',
41
+ foreground: 'hsl(var(--accent-foreground))',
42
+ },
43
+ popover: {
44
+ DEFAULT: 'hsl(var(--popover))',
45
+ foreground: 'hsl(var(--popover-foreground))',
46
+ },
47
+ card: {
48
+ DEFAULT: 'hsl(var(--card))',
49
+ foreground: 'hsl(var(--card-foreground))',
50
+ },
51
+ },
52
+ borderRadius: {
53
+ xl: 'calc(var(--radius) + 4px)',
54
+ lg: 'var(--radius)',
55
+ md: 'calc(var(--radius) - 2px)',
56
+ sm: 'calc(var(--radius) - 4px)',
57
+ },
58
+ keyframes: {
59
+ 'accordion-down': {
60
+ from: { height: 0 },
61
+ to: { height: 'var(--radix-accordion-content-height)' },
62
+ },
63
+ 'accordion-up': {
64
+ from: { height: 'var(--radix-accordion-content-height)' },
65
+ to: { height: 0 },
66
+ },
67
+ 'collapsible-down': {
68
+ from: { height: 0 },
69
+ to: { height: 'var(--radix-collapsible-content-height)' },
70
+ },
71
+ 'collapsible-up': {
72
+ from: { height: 'var(--radix-collapsible-content-height)' },
73
+ to: { height: 0 },
74
+ },
75
+ },
76
+ animation: {
77
+ 'accordion-down': 'accordion-down 0.2s ease-out',
78
+ 'accordion-up': 'accordion-up 0.2s ease-out',
79
+ 'collapsible-down': 'collapsible-down 0.2s ease-in-out',
80
+ 'collapsible-up': 'collapsible-up 0.2s ease-in-out',
81
+ },
82
+ },
83
+ },
84
+ plugins: [animate],
85
+ }
File without changes
@@ -1,107 +0,0 @@
1
- <script setup>
2
- import { useRoute, useRouter } from 'vue-router'
3
-
4
- const route = useRoute()
5
- const router = useRouter()
6
- const edgeGlobal = inject('edgeGlobal')
7
- const site = computed(() => {
8
- return route.params.collection
9
- })
10
- const metaFields = [
11
- {
12
- field: 'name',
13
- type: 'text',
14
- label: 'Name',
15
- hint: 'Your name, shown in the user interface.',
16
- rules: [edgeGlobal.edgeRules.required],
17
- },
18
- ]
19
- const orgFields = [
20
- {
21
- field: 'name',
22
- type: 'text',
23
- label: 'Name',
24
- hint: 'Your name, shown in the user interface.',
25
- rules: [edgeGlobal.edgeRules.required],
26
- },
27
- ]
28
-
29
- const config = useRuntimeConfig()
30
- </script>
31
-
32
- <template>
33
- <v-card :rounded="0">
34
- <sub-toolbar>
35
- <v-icon class="mx-4">
36
- mdi-account
37
- </v-icon>
38
- Account Settings
39
- </sub-toolbar>
40
- <v-card-text>
41
- <v-row>
42
- <v-col cols="12" sm="3" class="d-none d-sm-block">
43
- <!-- Desktop sidebar -->
44
- <v-card>
45
- <v-list :lines="false" density="compact" nav>
46
- <v-list-subheader class="">
47
- Organization
48
- </v-list-subheader>
49
- <v-list-item link to="/app/account/organization-settings">
50
- <v-list-item-title>Settings</v-list-item-title>
51
- </v-list-item>
52
-
53
- <v-list-item link to="/app/account/organization-members">
54
- <v-list-item-title>Members</v-list-item-title>
55
- </v-list-item>
56
- </v-list>
57
- <v-divider />
58
- <v-list :lines="false" density="compact" nav>
59
- <v-list-subheader class="">
60
- My Settings
61
- </v-list-subheader>
62
- <v-list-item link to="/app/account/my-profile">
63
- <v-list-item-title>Profile</v-list-item-title>
64
- </v-list-item>
65
-
66
- <v-list-item link to="/app/account/my-account">
67
- <v-list-item-title>Account</v-list-item-title>
68
- </v-list-item>
69
- <v-list-item link to="/app/account/my-organizations">
70
- <v-list-item-title>Organizations</v-list-item-title>
71
- </v-list-item>
72
- </v-list>
73
-
74
- <v-divider />
75
- </v-card>
76
- </v-col>
77
- <v-col cols="12" sm="9">
78
- <!-- Mobile tabs -->
79
- <v-tabs v-model="site" center-active show-arrows class="d-sm-none">
80
- <v-tab key="org-settings" value="org-settings" to="/app/account/organization-settings">
81
- Org Settings
82
- </v-tab>
83
- <v-tab key="org-members" value="org-members" to="/app/account/organization-members">
84
- Org Members
85
- </v-tab>
86
- <v-tab key="my-profile" value="my-profile" to="/app/account/my-profile">
87
- Profile
88
- </v-tab>
89
- <v-tab key="my-account" value="my-account" to="/app/account/my-account">
90
- Account
91
- </v-tab>
92
- <v-tab key="my-organizations" value="my-organizations" to="/app/account/my-organizations">
93
- Organizations
94
- </v-tab>
95
- </v-tabs>
96
- <!-- Content -->
97
- <edge-organization-settings v-if="site === 'organization-settings'" :org-fields="orgFields" />
98
- <edge-my-account v-if="site === 'my-account'" />
99
- <edge-my-profile v-if="site === 'my-profile'" :meta-fields="metaFields" />
100
- <edge-organization-members v-if="site === 'organization-members'" />
101
- <edge-my-organizations v-if="site === 'my-organizations'" :registration-code="config.public.registrationCode" />
102
- <billing v-if="site === 'subscription'" />
103
- </v-col>
104
- </v-row>
105
- </v-card-text>
106
- </v-card>
107
- </template>
@@ -1,8 +0,0 @@
1
- <script setup>
2
- </script>
3
-
4
- <template>
5
- <div>
6
- <v-card v-if="globalState.subscribedStatus.isSubscribed" outlined />
7
- </div>
8
- </template>
@@ -1,35 +0,0 @@
1
- <script setup>
2
- const edgeFirebase = inject('edgeFirebase')
3
- const edgeGlobal = inject('edgeGlobal')
4
- </script>
5
-
6
- <template>
7
- <v-bottom-navigation>
8
- <v-btn to="/app/dashboard">
9
- <v-icon>mdi-view-dashboard</v-icon>
10
-
11
- Dashboard
12
- </v-btn>
13
- <v-btn to="/app/dashboard/subthings">
14
- <v-icon>mdi-cube</v-icon>
15
-
16
- Sub Things
17
- </v-btn>
18
-
19
- <v-btn to="/app/account/organization-settings">
20
- <v-icon>mdi-cog</v-icon>
21
-
22
- Settings
23
- </v-btn>
24
-
25
- <v-btn @click="logOut(edgeFirebase, edgeGlobal)">
26
- <v-icon>mdi-logout</v-icon>
27
-
28
- Logout
29
- </v-btn>
30
- </v-bottom-navigation>
31
- </template>
32
-
33
- <style lang="scss" scoped>
34
-
35
- </style>