@edgedev/create-edge-app 1.0.41 → 1.0.42

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 +71 -0
  350. package/pages/app/dashboard/[[collection]]/[[docId]].vue +181 -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,181 @@
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 state = reactive({
9
+ filter: '',
10
+ newDocs: {
11
+ things: {
12
+ name: { bindings: { 'field-type': 'text', 'label': 'Name', 'helper': 'Name' }, cols: '12', value: '' },
13
+ description: { bindings: { 'field-type': 'text', 'label': 'Description', 'helper': 'Description' }, cols: '12', value: '' },
14
+ subthings: { bindings: { 'field-type': 'collection', 'label': 'Subthings', 'helper': 'Subthings', 'collection-path': 'subthings' }, cols: '12', value: '' },
15
+ },
16
+ subthings: {
17
+ name: { bindings: { 'field-type': 'text', 'label': 'Name', 'helper': 'Name' }, cols: '6', value: '' },
18
+ test: { bindings: { 'field-type': 'boolean', 'label': 'Description', 'helper': 'Test' }, cols: '6', value: '' },
19
+ selectTest: { bindings: { 'field-type': 'select', 'label': 'Select', 'helper': 'Select', 'items': ['test1', 'test2', 'test3'] }, cols: '12', value: '' },
20
+ testtextarea: { bindings: { 'field-type': 'textarea', 'label': 'Test Textarea', 'helper': 'Textarea' }, cols: '12', value: '' },
21
+ arrayThing: { bindings: { 'field-type': 'array', 'label': 'Array', 'helper': 'Array' }, cols: '12', value: [] },
22
+ objectThing: { bindings: { 'field-type': 'object', 'label': 'Object', 'helper': 'Obj' }, cols: '12', value: {} },
23
+ stringArray: { bindings: { 'field-type': 'stringArray', 'label': 'stringArray', 'helper': 'Obj' }, cols: '12', value: [] },
24
+ numberArray: { bindings: { 'field-type': 'numberArray', 'label': 'numberArray', 'helper': 'Obj' }, cols: '12', value: [] },
25
+ intArray: { bindings: { 'field-type': 'intArray', 'label': 'intArray', 'helper': 'Obj' }, cols: '12', value: [] },
26
+ usersThing: { bindings: { 'field-type': 'users', 'label': 'Users', 'helper': 'Users', 'hint': 'Choose a user' }, cols: '12', value: '' },
27
+ numberTest: { bindings: { 'field-type': 'number', 'label': 'Number', 'helper': 'Number' }, cols: '12', value: 0 },
28
+ intTest: { bindings: { 'field-type': 'integer', 'label': 'Int', 'helper': 'Int' }, cols: '12', value: 0 },
29
+ moneyTest: { bindings: { 'field-type': 'money', 'label': 'Money', 'helper': 'Money' }, cols: '12', value: 0 },
30
+ },
31
+ },
32
+ })
33
+
34
+ const schemas = {
35
+ things: toTypedSchema(z.object({
36
+ name: z.string({
37
+ required_error: 'Name is required',
38
+ }).min(1, { message: 'Name is required' }),
39
+ })),
40
+ subthings: toTypedSchema(z.object({
41
+ name: z.string({
42
+ required_error: 'Name is required',
43
+ }).min(1, { message: 'Name is required' }),
44
+ })),
45
+ }
46
+
47
+ const collection = computed(() => {
48
+ if (route.params.collection) {
49
+ return route.params.collection
50
+ }
51
+ return 'things'
52
+ })
53
+ const docId = computed(() => {
54
+ if (route.params.docId) {
55
+ return route.params.docId
56
+ }
57
+ return ''
58
+ })
59
+ definePageMeta({
60
+ middleware: 'auth',
61
+ })
62
+
63
+ onMounted(() => {
64
+ if (!route.params.collection) {
65
+ // If making a static collection route, this onMounted should be removed
66
+ router.push('/app/dashboard/things')
67
+ }
68
+ })
69
+ </script>
70
+
71
+ <template>
72
+ <div
73
+ v-if="edgeGlobal.edgeState.organizationDocPath"
74
+ class="p-3 w-full h-[calc(100vh-118px)] overflow-y-auto"
75
+ >
76
+ <edge-dashboard v-if="docId === ''" :filter="state.filter" :collection="collection">
77
+ <template #header-start>
78
+ <LayoutDashboard class="mr-2" />
79
+ <span class="capitalize">{{ collection }}</span>
80
+ </template>
81
+ <template #header-center>
82
+ <div class="w-full px-6">
83
+ <edge-shad-input
84
+ v-model="state.filter"
85
+ label=""
86
+ name="filter"
87
+ placeholder="Filter..."
88
+ />
89
+ </div>
90
+ </template>
91
+ <template #header-end="slotProps">
92
+ <edge-shad-button class="uppercase bg-slate-600" :to="`/app/dashboard/${collection}/new`">
93
+ Add {{ slotProps.title }}
94
+ </edge-shad-button>
95
+ </template>
96
+ <template #list-item="slotProps">
97
+ <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}`">
98
+ <div>
99
+ <Avatar class="cursor-pointer p-0 h-8 w-8 mr-2">
100
+ <FilePenLine class="h-5 w-5" />
101
+ </Avatar>
102
+ </div>
103
+ <div class="grow text-left">
104
+ <div class="text-lg">
105
+ {{ slotProps.item.name }}
106
+ </div>
107
+ </div>
108
+ <div>
109
+ <edge-shad-button
110
+ size="icon"
111
+ class="bg-slate-600 h-7 w-7"
112
+ @click.stop="slotProps.deleteItem(slotProps.item.docId)"
113
+ >
114
+ <Trash class="h-5 w-5" />
115
+ </edge-shad-button>
116
+ </div>
117
+ </edge-shad-button>
118
+ <Separator class="dark:bg-slate-600" />
119
+ </template>
120
+ </edge-dashboard>
121
+ <edge-editor
122
+ v-else
123
+ :collection="collection"
124
+ :doc-id="docId"
125
+ :schema="schemas[collection]"
126
+ :new-doc-schema="state.newDocs[collection]"
127
+ >
128
+ <template #header-start="slotProps">
129
+ <FilePenLine class="mr-2" />
130
+ {{ slotProps.title }}
131
+ </template>
132
+ <template #header-end="slotProps">
133
+ <edge-shad-button
134
+ v-if="!slotProps.unsavedChanges"
135
+ :to="`/app/dashboard/${collection}`"
136
+ class="bg-red-700 uppercase h-8 hover:bg-slate-400 w-20"
137
+ >
138
+ Close
139
+ </edge-shad-button>
140
+ <edge-shad-button
141
+ v-else
142
+ :to="`/app/dashboard/${collection}`"
143
+ class="bg-red-700 uppercase h-8 hover:bg-slate-400 w-20"
144
+ >
145
+ Cancel
146
+ </edge-shad-button>
147
+ <edge-shad-button
148
+ type="submit"
149
+ class="bg-slate-500 uppercase h-8 hover:bg-slate-400 w-20"
150
+ >
151
+ Save
152
+ </edge-shad-button>
153
+ </template>
154
+ <template #footer="slotProps">
155
+ <div class="flex w-full gap-1 items-center justify-end">
156
+ <edge-shad-button
157
+ v-if="!slotProps.unsavedChanges"
158
+ :to="`/app/dashboard/${collection}`"
159
+ class="bg-red-700 uppercase h-8 hover:bg-slate-400 w-20"
160
+ >
161
+ Close
162
+ </edge-shad-button>
163
+ <edge-shad-button
164
+ v-else
165
+ :to="`/app/dashboard/${collection}`"
166
+ class="bg-red-700 uppercase h-8 hover:bg-slate-400 w-20"
167
+ >
168
+ Cancel
169
+ </edge-shad-button>
170
+
171
+ <edge-shad-button
172
+ type="submit"
173
+ class="bg-slate-500 uppercase h-8 hover:bg-slate-400 w-20"
174
+ >
175
+ Save
176
+ </edge-shad-button>
177
+ </div>
178
+ </template>
179
+ </edge-editor>
180
+ </div>
181
+ </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>