@maizzle/framework 6.0.0-9 → 6.0.0-rc.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.
- package/bin/maizzle.mjs +10 -0
- package/dist/build.d.mts +19 -0
- package/dist/build.d.mts.map +1 -0
- package/dist/build.mjs +121 -0
- package/dist/build.mjs.map +1 -0
- package/dist/components/Button.vue +141 -0
- package/dist/components/Divider.vue +105 -0
- package/dist/components/NoWidows.vue +123 -0
- package/dist/components/NotOutlook.vue +17 -0
- package/dist/components/Outlook.vue +74 -0
- package/dist/components/Spacer.vue +36 -0
- package/dist/components/Vml.vue +89 -0
- package/dist/components/WithUrl.vue +190 -0
- package/dist/components/utils.d.mts +5 -0
- package/dist/components/utils.d.mts.map +1 -0
- package/dist/components/utils.mjs +9 -0
- package/dist/components/utils.mjs.map +1 -0
- package/dist/components/utils.ts +6 -0
- package/dist/composables/defineConfig.d.mts +14 -0
- package/dist/composables/defineConfig.d.mts.map +1 -0
- package/dist/composables/defineConfig.mjs +34 -0
- package/dist/composables/defineConfig.mjs.map +1 -0
- package/dist/composables/renderContext.d.mts +19 -0
- package/dist/composables/renderContext.d.mts.map +1 -0
- package/dist/composables/renderContext.mjs +6 -0
- package/dist/composables/renderContext.mjs.map +1 -0
- package/dist/composables/useConfig.d.mts +9 -0
- package/dist/composables/useConfig.d.mts.map +1 -0
- package/dist/composables/useConfig.mjs +13 -0
- package/dist/composables/useConfig.mjs.map +1 -0
- package/dist/composables/useDoctype.d.mts +13 -0
- package/dist/composables/useDoctype.d.mts.map +1 -0
- package/dist/composables/useDoctype.mjs +20 -0
- package/dist/composables/useDoctype.mjs.map +1 -0
- package/dist/composables/useEvent.d.mts +17 -0
- package/dist/composables/useEvent.d.mts.map +1 -0
- package/dist/composables/useEvent.mjs +25 -0
- package/dist/composables/useEvent.mjs.map +1 -0
- package/dist/composables/usePlaintext.d.mts +19 -0
- package/dist/composables/usePlaintext.d.mts.map +1 -0
- package/dist/composables/usePlaintext.mjs +22 -0
- package/dist/composables/usePlaintext.mjs.map +1 -0
- package/dist/config/defaults.d.mts +6 -0
- package/dist/config/defaults.d.mts.map +1 -0
- package/dist/config/defaults.mjs +28 -0
- package/dist/config/defaults.mjs.map +1 -0
- package/dist/config/index.d.mts +15 -0
- package/dist/config/index.d.mts.map +1 -0
- package/dist/config/index.mjs +47 -0
- package/dist/config/index.mjs.map +1 -0
- package/dist/events/index.d.mts +91 -0
- package/dist/events/index.d.mts.map +1 -0
- package/dist/events/index.mjs +110 -0
- package/dist/events/index.mjs.map +1 -0
- package/dist/index.d.mts +29 -0
- package/dist/index.mjs +29 -0
- package/dist/plaintext.d.mts +5 -0
- package/dist/plaintext.d.mts.map +1 -0
- package/dist/plaintext.mjs +15 -0
- package/dist/plaintext.mjs.map +1 -0
- package/dist/plugin.d.mts +17 -0
- package/dist/plugin.d.mts.map +1 -0
- package/dist/plugin.mjs +41 -0
- package/dist/plugin.mjs.map +1 -0
- package/dist/plugins/postcss/mergeMediaQueries.d.mts +18 -0
- package/dist/plugins/postcss/mergeMediaQueries.d.mts.map +1 -0
- package/dist/plugins/postcss/mergeMediaQueries.mjs +22 -0
- package/dist/plugins/postcss/mergeMediaQueries.mjs.map +1 -0
- package/dist/plugins/postcss/pruneVars.d.mts +8 -0
- package/dist/plugins/postcss/pruneVars.d.mts.map +1 -0
- package/dist/plugins/postcss/pruneVars.mjs +49 -0
- package/dist/plugins/postcss/pruneVars.mjs.map +1 -0
- package/dist/plugins/postcss/removeDeclarations.d.mts +12 -0
- package/dist/plugins/postcss/removeDeclarations.d.mts.map +1 -0
- package/dist/plugins/postcss/removeDeclarations.mjs +45 -0
- package/dist/plugins/postcss/removeDeclarations.mjs.map +1 -0
- package/dist/plugins/postcss/tailwindCleanup.d.mts +18 -0
- package/dist/plugins/postcss/tailwindCleanup.d.mts.map +1 -0
- package/dist/plugins/postcss/tailwindCleanup.mjs +35 -0
- package/dist/plugins/postcss/tailwindCleanup.mjs.map +1 -0
- package/dist/render/createRenderer.d.mts +34 -0
- package/dist/render/createRenderer.d.mts.map +1 -0
- package/dist/render/createRenderer.mjs +149 -0
- package/dist/render/createRenderer.mjs.map +1 -0
- package/dist/render/index.d.mts +26 -0
- package/dist/render/index.d.mts.map +1 -0
- package/dist/render/index.mjs +40 -0
- package/dist/render/index.mjs.map +1 -0
- package/dist/serve.d.mts +25 -0
- package/dist/serve.d.mts.map +1 -0
- package/dist/serve.mjs +402 -0
- package/dist/serve.mjs.map +1 -0
- package/dist/server/compatibility.d.mts +6 -0
- package/dist/server/compatibility.d.mts.map +1 -0
- package/dist/server/compatibility.mjs +83 -0
- package/dist/server/compatibility.mjs.map +1 -0
- package/dist/server/linter.d.mts +6 -0
- package/dist/server/linter.d.mts.map +1 -0
- package/dist/server/linter.mjs +200 -0
- package/dist/server/linter.mjs.map +1 -0
- package/dist/server/ui/App.vue +360 -0
- package/dist/server/ui/components/ui/button/Button.vue +31 -0
- package/dist/server/ui/components/ui/button/index.ts +38 -0
- package/dist/server/ui/components/ui/command/Command.vue +87 -0
- package/dist/server/ui/components/ui/command/CommandDialog.vue +31 -0
- package/dist/server/ui/components/ui/command/CommandEmpty.vue +27 -0
- package/dist/server/ui/components/ui/command/CommandGroup.vue +45 -0
- package/dist/server/ui/components/ui/command/CommandInput.vue +39 -0
- package/dist/server/ui/components/ui/command/CommandItem.vue +76 -0
- package/dist/server/ui/components/ui/command/CommandList.vue +25 -0
- package/dist/server/ui/components/ui/command/CommandSeparator.vue +21 -0
- package/dist/server/ui/components/ui/command/CommandShortcut.vue +17 -0
- package/dist/server/ui/components/ui/command/index.ts +25 -0
- package/dist/server/ui/components/ui/dialog/Dialog.vue +19 -0
- package/dist/server/ui/components/ui/dialog/DialogClose.vue +15 -0
- package/dist/server/ui/components/ui/dialog/DialogContent.vue +53 -0
- package/dist/server/ui/components/ui/dialog/DialogDescription.vue +23 -0
- package/dist/server/ui/components/ui/dialog/DialogFooter.vue +27 -0
- package/dist/server/ui/components/ui/dialog/DialogHeader.vue +17 -0
- package/dist/server/ui/components/ui/dialog/DialogOverlay.vue +21 -0
- package/dist/server/ui/components/ui/dialog/DialogScrollContent.vue +59 -0
- package/dist/server/ui/components/ui/dialog/DialogTitle.vue +23 -0
- package/dist/server/ui/components/ui/dialog/DialogTrigger.vue +15 -0
- package/dist/server/ui/components/ui/dialog/index.ts +10 -0
- package/dist/server/ui/components/ui/dropdown-menu/DropdownMenu.vue +19 -0
- package/dist/server/ui/components/ui/dropdown-menu/DropdownMenuCheckboxItem.vue +39 -0
- package/dist/server/ui/components/ui/dropdown-menu/DropdownMenuContent.vue +39 -0
- package/dist/server/ui/components/ui/dropdown-menu/DropdownMenuGroup.vue +15 -0
- package/dist/server/ui/components/ui/dropdown-menu/DropdownMenuItem.vue +31 -0
- package/dist/server/ui/components/ui/dropdown-menu/DropdownMenuLabel.vue +23 -0
- package/dist/server/ui/components/ui/dropdown-menu/DropdownMenuRadioGroup.vue +21 -0
- package/dist/server/ui/components/ui/dropdown-menu/DropdownMenuRadioItem.vue +40 -0
- package/dist/server/ui/components/ui/dropdown-menu/DropdownMenuSeparator.vue +23 -0
- package/dist/server/ui/components/ui/dropdown-menu/DropdownMenuShortcut.vue +17 -0
- package/dist/server/ui/components/ui/dropdown-menu/DropdownMenuSub.vue +18 -0
- package/dist/server/ui/components/ui/dropdown-menu/DropdownMenuSubContent.vue +27 -0
- package/dist/server/ui/components/ui/dropdown-menu/DropdownMenuSubTrigger.vue +31 -0
- package/dist/server/ui/components/ui/dropdown-menu/DropdownMenuTrigger.vue +17 -0
- package/dist/server/ui/components/ui/dropdown-menu/index.ts +16 -0
- package/dist/server/ui/components/ui/empty/Empty.vue +20 -0
- package/dist/server/ui/components/ui/empty/EmptyContent.vue +20 -0
- package/dist/server/ui/components/ui/empty/EmptyDescription.vue +20 -0
- package/dist/server/ui/components/ui/empty/EmptyHeader.vue +20 -0
- package/dist/server/ui/components/ui/empty/EmptyMedia.vue +21 -0
- package/dist/server/ui/components/ui/empty/EmptyTitle.vue +17 -0
- package/dist/server/ui/components/ui/empty/index.ts +26 -0
- package/dist/server/ui/components/ui/input/Input.vue +33 -0
- package/dist/server/ui/components/ui/input/index.ts +1 -0
- package/dist/server/ui/components/ui/kbd/Kbd.vue +20 -0
- package/dist/server/ui/components/ui/kbd/KbdGroup.vue +17 -0
- package/dist/server/ui/components/ui/kbd/index.ts +2 -0
- package/dist/server/ui/components/ui/resizable/ResizableHandle.vue +30 -0
- package/dist/server/ui/components/ui/resizable/ResizablePanel.vue +21 -0
- package/dist/server/ui/components/ui/resizable/ResizablePanelGroup.vue +25 -0
- package/dist/server/ui/components/ui/resizable/index.ts +3 -0
- package/dist/server/ui/components/ui/scroll-area/ScrollArea.vue +33 -0
- package/dist/server/ui/components/ui/scroll-area/ScrollBar.vue +32 -0
- package/dist/server/ui/components/ui/scroll-area/index.ts +2 -0
- package/dist/server/ui/components/ui/separator/Separator.vue +29 -0
- package/dist/server/ui/components/ui/separator/index.ts +1 -0
- package/dist/server/ui/components/ui/sheet/Sheet.vue +19 -0
- package/dist/server/ui/components/ui/sheet/SheetClose.vue +15 -0
- package/dist/server/ui/components/ui/sheet/SheetContent.vue +62 -0
- package/dist/server/ui/components/ui/sheet/SheetDescription.vue +21 -0
- package/dist/server/ui/components/ui/sheet/SheetFooter.vue +16 -0
- package/dist/server/ui/components/ui/sheet/SheetHeader.vue +15 -0
- package/dist/server/ui/components/ui/sheet/SheetOverlay.vue +21 -0
- package/dist/server/ui/components/ui/sheet/SheetTitle.vue +21 -0
- package/dist/server/ui/components/ui/sheet/SheetTrigger.vue +15 -0
- package/dist/server/ui/components/ui/sheet/index.ts +8 -0
- package/dist/server/ui/components/ui/sidebar/Sidebar.vue +96 -0
- package/dist/server/ui/components/ui/sidebar/SidebarContent.vue +18 -0
- package/dist/server/ui/components/ui/sidebar/SidebarFooter.vue +18 -0
- package/dist/server/ui/components/ui/sidebar/SidebarGroup.vue +18 -0
- package/dist/server/ui/components/ui/sidebar/SidebarGroupAction.vue +27 -0
- package/dist/server/ui/components/ui/sidebar/SidebarGroupContent.vue +18 -0
- package/dist/server/ui/components/ui/sidebar/SidebarGroupLabel.vue +25 -0
- package/dist/server/ui/components/ui/sidebar/SidebarHeader.vue +18 -0
- package/dist/server/ui/components/ui/sidebar/SidebarInput.vue +31 -0
- package/dist/server/ui/components/ui/sidebar/SidebarInset.vue +21 -0
- package/dist/server/ui/components/ui/sidebar/SidebarMenu.vue +18 -0
- package/dist/server/ui/components/ui/sidebar/SidebarMenuAction.vue +35 -0
- package/dist/server/ui/components/ui/sidebar/SidebarMenuBadge.vue +26 -0
- package/dist/server/ui/components/ui/sidebar/SidebarMenuButton.vue +48 -0
- package/dist/server/ui/components/ui/sidebar/SidebarMenuButtonChild.vue +36 -0
- package/dist/server/ui/components/ui/sidebar/SidebarMenuItem.vue +18 -0
- package/dist/server/ui/components/ui/sidebar/SidebarMenuSkeleton.vue +35 -0
- package/dist/server/ui/components/ui/sidebar/SidebarMenuSub.vue +22 -0
- package/dist/server/ui/components/ui/sidebar/SidebarMenuSubButton.vue +36 -0
- package/dist/server/ui/components/ui/sidebar/SidebarMenuSubItem.vue +18 -0
- package/dist/server/ui/components/ui/sidebar/SidebarProvider.vue +82 -0
- package/dist/server/ui/components/ui/sidebar/SidebarRail.vue +33 -0
- package/dist/server/ui/components/ui/sidebar/SidebarSeparator.vue +19 -0
- package/dist/server/ui/components/ui/sidebar/SidebarTrigger.vue +28 -0
- package/dist/server/ui/components/ui/sidebar/index.ts +60 -0
- package/dist/server/ui/components/ui/sidebar/utils.ts +19 -0
- package/dist/server/ui/components/ui/skeleton/Skeleton.vue +17 -0
- package/dist/server/ui/components/ui/skeleton/index.ts +1 -0
- package/dist/server/ui/components/ui/tabs/Tabs.vue +24 -0
- package/dist/server/ui/components/ui/tabs/TabsContent.vue +21 -0
- package/dist/server/ui/components/ui/tabs/TabsList.vue +24 -0
- package/dist/server/ui/components/ui/tabs/TabsTrigger.vue +26 -0
- package/dist/server/ui/components/ui/tabs/index.ts +4 -0
- package/dist/server/ui/components/ui/toggle/Toggle.vue +35 -0
- package/dist/server/ui/components/ui/toggle/index.ts +28 -0
- package/dist/server/ui/components/ui/toggle-group/ToggleGroup.vue +49 -0
- package/dist/server/ui/components/ui/toggle-group/ToggleGroupItem.vue +46 -0
- package/dist/server/ui/components/ui/toggle-group/index.ts +2 -0
- package/dist/server/ui/components/ui/tooltip/Tooltip.vue +19 -0
- package/dist/server/ui/components/ui/tooltip/TooltipContent.vue +34 -0
- package/dist/server/ui/components/ui/tooltip/TooltipProvider.vue +14 -0
- package/dist/server/ui/components/ui/tooltip/TooltipTrigger.vue +15 -0
- package/dist/server/ui/components/ui/tooltip/index.ts +4 -0
- package/dist/server/ui/favicon.svg +1 -0
- package/dist/server/ui/index.html +13 -0
- package/dist/server/ui/lib/utils.ts +7 -0
- package/dist/server/ui/logo-gradient.svg +1 -0
- package/dist/server/ui/logo.svg +1 -0
- package/dist/server/ui/main.css +129 -0
- package/dist/server/ui/main.ts +16 -0
- package/dist/server/ui/mark-gradient.svg +1 -0
- package/dist/server/ui/mark.svg +1 -0
- package/dist/server/ui/pages/Home.vue +39 -0
- package/dist/server/ui/pages/Preview.vue +609 -0
- package/dist/server/ui/stripes.svg +174 -0
- package/dist/transformers/addAttributes.d.mts +32 -0
- package/dist/transformers/addAttributes.d.mts.map +1 -0
- package/dist/transformers/addAttributes.mjs +101 -0
- package/dist/transformers/addAttributes.mjs.map +1 -0
- package/dist/transformers/attributeToStyle.d.mts +25 -0
- package/dist/transformers/attributeToStyle.d.mts.map +1 -0
- package/dist/transformers/attributeToStyle.mjs +80 -0
- package/dist/transformers/attributeToStyle.mjs.map +1 -0
- package/dist/transformers/base.d.mts +8 -0
- package/dist/transformers/base.d.mts.map +1 -0
- package/dist/transformers/base.mjs +160 -0
- package/dist/transformers/base.mjs.map +1 -0
- package/dist/transformers/entities.d.mts +8 -0
- package/dist/transformers/entities.d.mts.map +1 -0
- package/dist/transformers/entities.mjs +38 -0
- package/dist/transformers/entities.mjs.map +1 -0
- package/dist/transformers/format.d.mts +15 -0
- package/dist/transformers/format.d.mts.map +1 -0
- package/dist/transformers/format.mjs +26 -0
- package/dist/transformers/format.mjs.map +1 -0
- package/dist/transformers/index.d.mts +35 -0
- package/dist/transformers/index.d.mts.map +1 -0
- package/dist/transformers/index.mjs +73 -0
- package/dist/transformers/index.mjs.map +1 -0
- package/dist/transformers/inlineCSS.d.mts +30 -0
- package/dist/transformers/inlineCSS.d.mts.map +1 -0
- package/dist/transformers/inlineCSS.mjs +79 -0
- package/dist/transformers/inlineCSS.mjs.map +1 -0
- package/dist/transformers/inlineLink.d.mts +14 -0
- package/dist/transformers/inlineLink.d.mts.map +1 -0
- package/dist/transformers/inlineLink.mjs +76 -0
- package/dist/transformers/inlineLink.mjs.map +1 -0
- package/dist/transformers/minify.d.mts +17 -0
- package/dist/transformers/minify.d.mts.map +1 -0
- package/dist/transformers/minify.mjs +24 -0
- package/dist/transformers/minify.mjs.map +1 -0
- package/dist/transformers/purgeCSS.d.mts +23 -0
- package/dist/transformers/purgeCSS.d.mts.map +1 -0
- package/dist/transformers/purgeCSS.mjs +66 -0
- package/dist/transformers/purgeCSS.mjs.map +1 -0
- package/dist/transformers/removeAttributes.d.mts +31 -0
- package/dist/transformers/removeAttributes.d.mts.map +1 -0
- package/dist/transformers/removeAttributes.mjs +63 -0
- package/dist/transformers/removeAttributes.mjs.map +1 -0
- package/dist/transformers/replaceStrings.d.mts +16 -0
- package/dist/transformers/replaceStrings.d.mts.map +1 -0
- package/dist/transformers/replaceStrings.mjs +19 -0
- package/dist/transformers/replaceStrings.mjs.map +1 -0
- package/dist/transformers/safeClassNames.d.mts +22 -0
- package/dist/transformers/safeClassNames.d.mts.map +1 -0
- package/dist/transformers/safeClassNames.mjs +103 -0
- package/dist/transformers/safeClassNames.mjs.map +1 -0
- package/dist/transformers/shorthandCSS.d.mts +24 -0
- package/dist/transformers/shorthandCSS.d.mts.map +1 -0
- package/dist/transformers/shorthandCSS.mjs +48 -0
- package/dist/transformers/shorthandCSS.mjs.map +1 -0
- package/dist/transformers/tailwindcss.d.mts +20 -0
- package/dist/transformers/tailwindcss.d.mts.map +1 -0
- package/dist/transformers/tailwindcss.mjs +136 -0
- package/dist/transformers/tailwindcss.mjs.map +1 -0
- package/dist/transformers/urlQuery.d.mts +24 -0
- package/dist/transformers/urlQuery.d.mts.map +1 -0
- package/dist/transformers/urlQuery.mjs +65 -0
- package/dist/transformers/urlQuery.mjs.map +1 -0
- package/dist/types/config.d.mts +129 -0
- package/dist/types/config.d.mts.map +1 -0
- package/dist/types/config.mjs +1 -0
- package/dist/types/index.d.mts +2 -0
- package/dist/types/index.mjs +1 -0
- package/dist/utils/ast/index.d.mts +4 -0
- package/dist/utils/ast/index.mjs +5 -0
- package/dist/utils/ast/parser.d.mts +7 -0
- package/dist/utils/ast/parser.d.mts.map +1 -0
- package/dist/utils/ast/parser.mjs +15 -0
- package/dist/utils/ast/parser.mjs.map +1 -0
- package/dist/utils/ast/serializer.d.mts +7 -0
- package/dist/utils/ast/serializer.d.mts.map +1 -0
- package/dist/utils/ast/serializer.mjs +13 -0
- package/dist/utils/ast/serializer.mjs.map +1 -0
- package/dist/utils/ast/walker.d.mts +7 -0
- package/dist/utils/ast/walker.d.mts.map +1 -0
- package/dist/utils/ast/walker.mjs +12 -0
- package/dist/utils/ast/walker.mjs.map +1 -0
- package/dist/utils/url.d.mts +8 -0
- package/dist/utils/url.d.mts.map +1 -0
- package/dist/utils/url.mjs +32 -0
- package/dist/utils/url.mjs.map +1 -0
- package/node_modules/@clack/core/CHANGELOG.md +257 -0
- package/node_modules/@clack/core/LICENSE +9 -0
- package/node_modules/@clack/core/README.md +22 -0
- package/node_modules/@clack/core/dist/index.cjs +15 -0
- package/node_modules/@clack/core/dist/index.cjs.map +1 -0
- package/node_modules/@clack/core/dist/index.d.cts +211 -0
- package/node_modules/@clack/core/dist/index.d.mts +211 -0
- package/node_modules/@clack/core/dist/index.d.ts +211 -0
- package/node_modules/@clack/core/dist/index.mjs +15 -0
- package/node_modules/@clack/core/dist/index.mjs.map +1 -0
- package/node_modules/@clack/core/package.json +62 -0
- package/node_modules/@clack/prompts/CHANGELOG.md +412 -0
- package/node_modules/@clack/prompts/LICENSE +9 -0
- package/node_modules/@clack/prompts/README.md +207 -0
- package/node_modules/@clack/prompts/dist/index.cjs +87 -0
- package/node_modules/@clack/prompts/dist/index.cjs.map +1 -0
- package/node_modules/@clack/prompts/dist/index.d.cts +165 -0
- package/node_modules/@clack/prompts/dist/index.d.mts +165 -0
- package/node_modules/@clack/prompts/dist/index.d.ts +165 -0
- package/node_modules/@clack/prompts/dist/index.mjs +87 -0
- package/node_modules/@clack/prompts/dist/index.mjs.map +1 -0
- package/node_modules/@clack/prompts/package.json +61 -0
- package/node_modules/@maizzle/cli/LICENSE +21 -0
- package/node_modules/@maizzle/cli/README.md +58 -0
- package/node_modules/@maizzle/cli/dist/commands/make/component.d.mts +4 -0
- package/node_modules/@maizzle/cli/dist/commands/make/component.mjs +31 -0
- package/node_modules/@maizzle/cli/dist/commands/make/config.d.mts +4 -0
- package/node_modules/@maizzle/cli/dist/commands/make/config.mjs +21 -0
- package/node_modules/@maizzle/cli/dist/commands/make/layout.d.mts +4 -0
- package/node_modules/@maizzle/cli/dist/commands/make/layout.mjs +31 -0
- package/node_modules/@maizzle/cli/dist/commands/make/scaffold.d.mts +5 -0
- package/node_modules/@maizzle/cli/dist/commands/make/scaffold.mjs +28 -0
- package/node_modules/@maizzle/cli/dist/commands/make/stubs/component.vue +9 -0
- package/node_modules/@maizzle/cli/dist/commands/make/stubs/config.ts +9 -0
- package/node_modules/@maizzle/cli/dist/commands/make/stubs/layout.vue +39 -0
- package/node_modules/@maizzle/cli/dist/commands/make/stubs/template.vue +8 -0
- package/node_modules/@maizzle/cli/dist/commands/make/template.d.mts +4 -0
- package/node_modules/@maizzle/cli/dist/commands/make/template.mjs +31 -0
- package/node_modules/@maizzle/cli/dist/index.d.mts +8 -0
- package/node_modules/@maizzle/cli/dist/index.mjs +42 -0
- package/node_modules/@maizzle/cli/package.json +59 -0
- package/node_modules/citty/LICENSE +36 -0
- package/node_modules/citty/README.md +134 -0
- package/node_modules/citty/dist/index.cjs +475 -0
- package/node_modules/citty/dist/index.d.cts +80 -0
- package/node_modules/citty/dist/index.d.mts +80 -0
- package/node_modules/citty/dist/index.d.ts +80 -0
- package/node_modules/citty/dist/index.mjs +463 -0
- package/node_modules/citty/package.json +49 -0
- package/node_modules/commander/LICENSE +22 -0
- package/node_modules/commander/Readme.md +1149 -0
- package/node_modules/commander/esm.mjs +16 -0
- package/node_modules/commander/index.js +24 -0
- package/node_modules/commander/lib/argument.js +149 -0
- package/node_modules/commander/lib/command.js +2662 -0
- package/node_modules/commander/lib/error.js +39 -0
- package/node_modules/commander/lib/help.js +709 -0
- package/node_modules/commander/lib/option.js +367 -0
- package/node_modules/commander/lib/suggestSimilar.js +101 -0
- package/node_modules/commander/package-support.json +16 -0
- package/node_modules/commander/package.json +82 -0
- package/node_modules/commander/typings/esm.d.mts +3 -0
- package/node_modules/commander/typings/index.d.ts +1045 -0
- package/node_modules/consola/LICENSE +47 -0
- package/node_modules/consola/README.md +352 -0
- package/node_modules/consola/basic.d.ts +1 -0
- package/node_modules/consola/browser.d.ts +1 -0
- package/node_modules/consola/core.d.ts +1 -0
- package/node_modules/consola/dist/basic.cjs +32 -0
- package/node_modules/consola/dist/basic.d.cts +23 -0
- package/node_modules/consola/dist/basic.d.mts +21 -0
- package/node_modules/consola/dist/basic.d.ts +23 -0
- package/node_modules/consola/dist/basic.mjs +24 -0
- package/node_modules/consola/dist/browser.cjs +84 -0
- package/node_modules/consola/dist/browser.d.cts +23 -0
- package/node_modules/consola/dist/browser.d.mts +21 -0
- package/node_modules/consola/dist/browser.d.ts +23 -0
- package/node_modules/consola/dist/browser.mjs +76 -0
- package/node_modules/consola/dist/chunks/prompt.cjs +288 -0
- package/node_modules/consola/dist/chunks/prompt.mjs +280 -0
- package/node_modules/consola/dist/core.cjs +517 -0
- package/node_modules/consola/dist/core.d.cts +459 -0
- package/node_modules/consola/dist/core.d.mts +459 -0
- package/node_modules/consola/dist/core.d.ts +459 -0
- package/node_modules/consola/dist/core.mjs +512 -0
- package/node_modules/consola/dist/index.cjs +663 -0
- package/node_modules/consola/dist/index.d.cts +24 -0
- package/node_modules/consola/dist/index.d.mts +22 -0
- package/node_modules/consola/dist/index.d.ts +24 -0
- package/node_modules/consola/dist/index.mjs +651 -0
- package/node_modules/consola/dist/shared/consola.DCGIlDNP.cjs +75 -0
- package/node_modules/consola/dist/shared/consola.DRwqZj3T.mjs +72 -0
- package/node_modules/consola/dist/shared/consola.DXBYu-KD.mjs +288 -0
- package/node_modules/consola/dist/shared/consola.DwRq1yyg.cjs +312 -0
- package/node_modules/consola/dist/utils.cjs +64 -0
- package/node_modules/consola/dist/utils.d.cts +286 -0
- package/node_modules/consola/dist/utils.d.mts +286 -0
- package/node_modules/consola/dist/utils.d.ts +286 -0
- package/node_modules/consola/dist/utils.mjs +54 -0
- package/node_modules/consola/lib/index.cjs +10 -0
- package/node_modules/consola/package.json +136 -0
- package/node_modules/consola/utils.d.ts +1 -0
- package/node_modules/create-maizzle/README.md +86 -0
- package/node_modules/create-maizzle/bin/create-maizzle.mjs +4 -0
- package/node_modules/create-maizzle/node_modules/@clack/core/CHANGELOG.md +340 -0
- package/node_modules/create-maizzle/node_modules/@clack/core/LICENSE +9 -0
- package/node_modules/create-maizzle/node_modules/@clack/core/README.md +22 -0
- package/node_modules/create-maizzle/node_modules/@clack/core/dist/index.d.mts +349 -0
- package/node_modules/create-maizzle/node_modules/@clack/core/dist/index.mjs +11 -0
- package/node_modules/create-maizzle/node_modules/@clack/core/dist/index.mjs.map +1 -0
- package/node_modules/create-maizzle/node_modules/@clack/core/package.json +60 -0
- package/node_modules/create-maizzle/node_modules/@clack/prompts/CHANGELOG.md +576 -0
- package/node_modules/create-maizzle/node_modules/@clack/prompts/LICENSE +9 -0
- package/node_modules/create-maizzle/node_modules/@clack/prompts/README.md +270 -0
- package/node_modules/create-maizzle/node_modules/@clack/prompts/dist/index.d.mts +391 -0
- package/node_modules/create-maizzle/node_modules/@clack/prompts/dist/index.mjs +137 -0
- package/node_modules/create-maizzle/node_modules/@clack/prompts/dist/index.mjs.map +1 -0
- package/node_modules/create-maizzle/node_modules/@clack/prompts/package.json +65 -0
- package/node_modules/create-maizzle/package.json +47 -0
- package/node_modules/create-maizzle/src/index.js +242 -0
- package/node_modules/defu/LICENSE +21 -0
- package/node_modules/defu/README.md +171 -0
- package/node_modules/defu/dist/defu.cjs +77 -0
- package/node_modules/defu/dist/defu.d.cts +31 -0
- package/node_modules/defu/dist/defu.d.mts +29 -0
- package/node_modules/defu/dist/defu.d.ts +31 -0
- package/node_modules/defu/dist/defu.mjs +69 -0
- package/node_modules/defu/lib/defu.cjs +10 -0
- package/node_modules/defu/lib/defu.d.cts +12 -0
- package/node_modules/defu/package.json +48 -0
- package/node_modules/fast-string-truncated-width/dist/index.d.ts +4 -0
- package/node_modules/fast-string-truncated-width/dist/index.js +171 -0
- package/node_modules/fast-string-truncated-width/dist/types.d.ts +22 -0
- package/node_modules/fast-string-truncated-width/dist/types.js +2 -0
- package/node_modules/fast-string-truncated-width/dist/utils.d.ts +4 -0
- package/node_modules/fast-string-truncated-width/dist/utils.js +15 -0
- package/node_modules/fast-string-truncated-width/license +21 -0
- package/node_modules/fast-string-truncated-width/package.json +35 -0
- package/node_modules/fast-string-truncated-width/readme.md +60 -0
- package/node_modules/fast-string-width/dist/index.d.ts +4 -0
- package/node_modules/fast-string-width/dist/index.js +14 -0
- package/node_modules/fast-string-width/license +21 -0
- package/node_modules/fast-string-width/package.json +34 -0
- package/node_modules/fast-string-width/readme.md +45 -0
- package/node_modules/fast-wrap-ansi/LICENSE +23 -0
- package/node_modules/fast-wrap-ansi/README.md +26 -0
- package/node_modules/fast-wrap-ansi/lib/main.d.ts +6 -0
- package/node_modules/fast-wrap-ansi/lib/main.js +216 -0
- package/node_modules/fast-wrap-ansi/lib/main.js.map +1 -0
- package/node_modules/fast-wrap-ansi/package.json +51 -0
- package/node_modules/giget/LICENSE +184 -0
- package/node_modules/giget/README.md +248 -0
- package/node_modules/giget/dist/cli.mjs +112 -0
- package/node_modules/giget/dist/index.d.mts +49 -0
- package/node_modules/giget/dist/index.mjs +22 -0
- package/node_modules/giget/dist/shared/giget.OCaTp9b-.mjs +468 -0
- package/node_modules/giget/package.json +62 -0
- package/node_modules/node-fetch-native/LICENSE +114 -0
- package/node_modules/node-fetch-native/README.md +225 -0
- package/node_modules/node-fetch-native/dist/chunks/multipart-parser.cjs +2 -0
- package/node_modules/node-fetch-native/dist/chunks/multipart-parser.mjs +2 -0
- package/node_modules/node-fetch-native/dist/index.cjs +1 -0
- package/node_modules/node-fetch-native/dist/index.mjs +1 -0
- package/node_modules/node-fetch-native/dist/native.cjs +1 -0
- package/node_modules/node-fetch-native/dist/native.mjs +1 -0
- package/node_modules/node-fetch-native/dist/node.cjs +19 -0
- package/node_modules/node-fetch-native/dist/node.mjs +19 -0
- package/node_modules/node-fetch-native/dist/polyfill.cjs +1 -0
- package/node_modules/node-fetch-native/dist/polyfill.mjs +1 -0
- package/node_modules/node-fetch-native/dist/proxy-stub.cjs +1 -0
- package/node_modules/node-fetch-native/dist/proxy-stub.mjs +1 -0
- package/node_modules/node-fetch-native/dist/proxy.cjs +58 -0
- package/node_modules/node-fetch-native/dist/shared/node-fetch-native.DfbY2q-x.mjs +1 -0
- package/node_modules/node-fetch-native/dist/shared/node-fetch-native.DhEqb06g.cjs +1 -0
- package/node_modules/node-fetch-native/index.d.ts +1 -0
- package/node_modules/node-fetch-native/lib/empty.cjs +0 -0
- package/node_modules/node-fetch-native/lib/empty.mjs +0 -0
- package/node_modules/node-fetch-native/lib/index.cjs +11 -0
- package/node_modules/node-fetch-native/lib/index.d.cts +10 -0
- package/node_modules/node-fetch-native/lib/index.d.mts +10 -0
- package/node_modules/node-fetch-native/lib/index.d.ts +10 -0
- package/node_modules/node-fetch-native/lib/native.cjs +11 -0
- package/node_modules/node-fetch-native/lib/polyfill.d.cts +1 -0
- package/node_modules/node-fetch-native/lib/polyfill.d.mts +1 -0
- package/node_modules/node-fetch-native/lib/polyfill.d.ts +1 -0
- package/node_modules/node-fetch-native/lib/proxy.d.ts +32 -0
- package/node_modules/node-fetch-native/node.d.ts +1 -0
- package/node_modules/node-fetch-native/package.json +138 -0
- package/node_modules/node-fetch-native/polyfill.d.ts +1 -0
- package/node_modules/node-fetch-native/proxy.d.ts +1 -0
- package/node_modules/nypm/LICENSE +21 -0
- package/node_modules/nypm/README.md +152 -0
- package/node_modules/nypm/dist/cli.d.mts +1 -0
- package/node_modules/nypm/dist/cli.mjs +460 -0
- package/node_modules/nypm/dist/index.d.mts +209 -0
- package/node_modules/nypm/dist/index.mjs +423 -0
- package/node_modules/nypm/node_modules/citty/LICENSE +21 -0
- package/node_modules/nypm/node_modules/citty/README.md +231 -0
- package/node_modules/nypm/node_modules/citty/dist/THIRD-PARTY-LICENSES.md +33 -0
- package/node_modules/nypm/node_modules/citty/dist/_chunks/libs/scule.mjs +70 -0
- package/node_modules/nypm/node_modules/citty/dist/index.d.mts +112 -0
- package/node_modules/nypm/node_modules/citty/dist/index.mjs +425 -0
- package/node_modules/nypm/node_modules/citty/package.json +42 -0
- package/node_modules/nypm/package.json +54 -0
- package/node_modules/pathe/LICENSE +70 -0
- package/node_modules/pathe/README.md +73 -0
- package/node_modules/pathe/dist/index.cjs +39 -0
- package/node_modules/pathe/dist/index.d.cts +47 -0
- package/node_modules/pathe/dist/index.d.mts +47 -0
- package/node_modules/pathe/dist/index.d.ts +47 -0
- package/node_modules/pathe/dist/index.mjs +19 -0
- package/node_modules/pathe/dist/shared/pathe.BSlhyZSM.cjs +266 -0
- package/node_modules/pathe/dist/shared/pathe.M-eThtNZ.mjs +249 -0
- package/node_modules/pathe/dist/utils.cjs +82 -0
- package/node_modules/pathe/dist/utils.d.cts +32 -0
- package/node_modules/pathe/dist/utils.d.mts +32 -0
- package/node_modules/pathe/dist/utils.d.ts +32 -0
- package/node_modules/pathe/dist/utils.mjs +77 -0
- package/node_modules/pathe/package.json +61 -0
- package/node_modules/pathe/utils.d.ts +1 -0
- package/node_modules/picocolors/LICENSE +15 -0
- package/node_modules/picocolors/README.md +21 -0
- package/node_modules/picocolors/package.json +25 -0
- package/node_modules/picocolors/picocolors.browser.js +4 -0
- package/node_modules/picocolors/picocolors.d.ts +5 -0
- package/node_modules/picocolors/picocolors.js +75 -0
- package/node_modules/picocolors/types.d.ts +51 -0
- package/node_modules/sisteransi/license +21 -0
- package/node_modules/sisteransi/package.json +34 -0
- package/node_modules/sisteransi/readme.md +113 -0
- package/node_modules/sisteransi/src/index.js +58 -0
- package/node_modules/sisteransi/src/sisteransi.d.ts +35 -0
- package/node_modules/tinyexec/LICENSE +21 -0
- package/node_modules/tinyexec/README.md +269 -0
- package/node_modules/tinyexec/dist/LICENSES.txt +83 -0
- package/node_modules/tinyexec/dist/main.d.mts +71 -0
- package/node_modules/tinyexec/dist/main.mjs +642 -0
- package/node_modules/tinyexec/package.json +62 -0
- package/package.json +74 -73
- package/CHANGELOG.md +0 -770
- package/bin/maizzle +0 -5
- package/src/commands/build.js +0 -348
- package/src/commands/serve.js +0 -3
- package/src/generators/plaintext.js +0 -222
- package/src/generators/render.js +0 -129
- package/src/index.js +0 -49
- package/src/posthtml/defaultComponentsConfig.js +0 -19
- package/src/posthtml/defaultConfig.js +0 -14
- package/src/posthtml/index.js +0 -102
- package/src/posthtml/plugins/combineMediaQueries.js +0 -42
- package/src/posthtml/plugins/envAttributes.js +0 -32
- package/src/posthtml/plugins/envTags.js +0 -33
- package/src/posthtml/plugins/expandLinkTag.js +0 -59
- package/src/posthtml/plugins/postcss/compileCss.js +0 -125
- package/src/posthtml/plugins/removeRawStyleAttributes.js +0 -30
- package/src/server/client.js +0 -182
- package/src/server/index.js +0 -464
- package/src/server/routes/hmr.js +0 -26
- package/src/server/routes/index.js +0 -77
- package/src/server/views/404.html +0 -59
- package/src/server/views/error.html +0 -83
- package/src/server/views/index.html +0 -172
- package/src/server/websockets.js +0 -27
- package/src/transformers/addAttributes.js +0 -29
- package/src/transformers/attributeToStyle.js +0 -90
- package/src/transformers/baseUrl.js +0 -154
- package/src/transformers/core.js +0 -32
- package/src/transformers/filters/defaultFilters.js +0 -146
- package/src/transformers/filters/index.js +0 -18
- package/src/transformers/index.js +0 -259
- package/src/transformers/inline.js +0 -306
- package/src/transformers/markdown.js +0 -26
- package/src/transformers/minify.js +0 -27
- package/src/transformers/posthtmlMso.js +0 -14
- package/src/transformers/prettify.js +0 -29
- package/src/transformers/preventWidows.js +0 -37
- package/src/transformers/purge.js +0 -56
- package/src/transformers/removeAttributes.js +0 -55
- package/src/transformers/replaceStrings.js +0 -37
- package/src/transformers/safeClassNames.js +0 -29
- package/src/transformers/shorthandCss.js +0 -20
- package/src/transformers/sixHex.js +0 -30
- package/src/transformers/template.js +0 -26
- package/src/transformers/urlParameters.js +0 -20
- package/src/transformers/useAttributeSizes.js +0 -63
- package/src/utils/getConfigByFilePath.js +0 -143
- package/src/utils/node.js +0 -68
- package/src/utils/string.js +0 -186
- package/types/build.d.ts +0 -166
- package/types/config.d.ts +0 -638
- package/types/css/combineMediaQueries.d.ts +0 -90
- package/types/css/inline.d.ts +0 -218
- package/types/css/purge.d.ts +0 -125
- package/types/events.d.ts +0 -153
- package/types/index.d.ts +0 -232
- package/types/markdown.d.ts +0 -33
- package/types/minify.d.ts +0 -138
- package/types/plaintext.d.ts +0 -56
- package/types/posthtml.d.ts +0 -162
- package/types/render.d.ts +0 -13
- package/types/urlParameters.d.ts +0 -40
- package/types/widowWords.d.ts +0 -38
|
@@ -0,0 +1,609 @@
|
|
|
1
|
+
<script setup lang="ts">
|
|
2
|
+
import { ref, watch, nextTick, onMounted, onUnmounted } from 'vue'
|
|
3
|
+
import { useRoute } from 'vue-router'
|
|
4
|
+
import { ChevronUp, ChevronDown, Check } from 'lucide-vue-next'
|
|
5
|
+
import {
|
|
6
|
+
DropdownMenu,
|
|
7
|
+
DropdownMenuContent,
|
|
8
|
+
DropdownMenuItem,
|
|
9
|
+
DropdownMenuTrigger,
|
|
10
|
+
} from '@/components/ui/dropdown-menu'
|
|
11
|
+
import {
|
|
12
|
+
ResizableHandle,
|
|
13
|
+
ResizablePanel,
|
|
14
|
+
ResizablePanelGroup,
|
|
15
|
+
} from '@/components/ui/resizable'
|
|
16
|
+
import { Tabs, TabsContent, TabsList, TabsTrigger } from '@/components/ui/tabs'
|
|
17
|
+
import { Button } from '@/components/ui/button'
|
|
18
|
+
|
|
19
|
+
import stripesUrl from '../stripes.svg'
|
|
20
|
+
|
|
21
|
+
interface Device {
|
|
22
|
+
name: string
|
|
23
|
+
width: number
|
|
24
|
+
height: number
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
const props = defineProps<{
|
|
28
|
+
device?: Device | null
|
|
29
|
+
resetKey?: number
|
|
30
|
+
}>()
|
|
31
|
+
|
|
32
|
+
const viewMode = defineModel<'preview' | 'source'>('viewMode', { default: 'preview' })
|
|
33
|
+
|
|
34
|
+
const route = useRoute()
|
|
35
|
+
const srcdoc = ref('')
|
|
36
|
+
const sourceHtml = ref('')
|
|
37
|
+
const vueSourceHtml = ref('')
|
|
38
|
+
const plaintextContent = ref('')
|
|
39
|
+
const sourceView = ref<'compiled' | 'vue' | 'plaintext'>('compiled')
|
|
40
|
+
const copied = ref(false)
|
|
41
|
+
|
|
42
|
+
const iframeEl = ref<HTMLIFrameElement>()
|
|
43
|
+
const vueSourceEl = ref<HTMLElement>()
|
|
44
|
+
const containerEl = ref<HTMLElement>()
|
|
45
|
+
const previewEl = ref<InstanceType<typeof ResizablePanel>>()
|
|
46
|
+
const leftPanel = ref<InstanceType<typeof ResizablePanel>>()
|
|
47
|
+
const rightPanel = ref<InstanceType<typeof ResizablePanel>>()
|
|
48
|
+
const topPanel = ref<InstanceType<typeof ResizablePanel>>()
|
|
49
|
+
const bottomPanel = ref<InstanceType<typeof ResizablePanel>>()
|
|
50
|
+
|
|
51
|
+
const panelWidth = defineModel<number>('panelWidth', { default: 0 })
|
|
52
|
+
const panelHeight = defineModel<number>('panelHeight', { default: 0 })
|
|
53
|
+
const isDragging = defineModel<boolean>('isDragging', { default: false })
|
|
54
|
+
const isFullSize = defineModel<boolean>('isFullSize', { default: true })
|
|
55
|
+
|
|
56
|
+
const sideSizes = ref({ left: 0, right: 0, top: 0, bottom: 0 })
|
|
57
|
+
|
|
58
|
+
function updateFullSize() {
|
|
59
|
+
isFullSize.value = sideSizes.value.left < 0.5
|
|
60
|
+
&& sideSizes.value.right < 0.5
|
|
61
|
+
&& sideSizes.value.top < 0.5
|
|
62
|
+
&& sideSizes.value.bottom < 0.5
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
async function copySource() {
|
|
66
|
+
if (sourceView.value === 'compiled') {
|
|
67
|
+
await navigator.clipboard.writeText(srcdoc.value)
|
|
68
|
+
} else if (sourceView.value === 'plaintext') {
|
|
69
|
+
await navigator.clipboard.writeText(plaintextContent.value)
|
|
70
|
+
} else {
|
|
71
|
+
const el = document.createElement('div')
|
|
72
|
+
el.innerHTML = vueSourceHtml.value
|
|
73
|
+
await navigator.clipboard.writeText(el.textContent || '')
|
|
74
|
+
}
|
|
75
|
+
copied.value = true
|
|
76
|
+
setTimeout(() => { copied.value = false }, 2000)
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
interface CompatibilityIssue {
|
|
80
|
+
type: 'error' | 'warning'
|
|
81
|
+
title: string
|
|
82
|
+
clients: Array<{ name: string, notes: string[] }>
|
|
83
|
+
url?: string
|
|
84
|
+
line?: number
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
interface LintIssue {
|
|
88
|
+
type: 'error' | 'warning'
|
|
89
|
+
title: string
|
|
90
|
+
message: string
|
|
91
|
+
line?: number
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
interface TemplateStats {
|
|
95
|
+
size: { bytes: number, formatted: string }
|
|
96
|
+
images: number
|
|
97
|
+
links: number
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
const compatibilityIssues = ref<CompatibilityIssue[]>([])
|
|
101
|
+
const compatibilityLoading = ref(false)
|
|
102
|
+
const lintIssues = ref<LintIssue[]>([])
|
|
103
|
+
const lintLoading = ref(false)
|
|
104
|
+
const stats = ref<TemplateStats | null>(null)
|
|
105
|
+
const statsLoading = ref(false)
|
|
106
|
+
|
|
107
|
+
async function fetchTemplate() {
|
|
108
|
+
const res = await fetch(`/__maizzle/render/${route.params.template}`)
|
|
109
|
+
srcdoc.value = await res.text()
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
async function fetchSource() {
|
|
113
|
+
const res = await fetch(`/__maizzle/source/${route.params.template}`)
|
|
114
|
+
sourceHtml.value = await res.text()
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
async function fetchVueSource() {
|
|
118
|
+
const res = await fetch(`/__maizzle/vue-source/${route.params.template}`)
|
|
119
|
+
vueSourceHtml.value = await res.text()
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
async function fetchPlaintext() {
|
|
123
|
+
const res = await fetch(`/__maizzle/plaintext/${route.params.template}`)
|
|
124
|
+
plaintextContent.value = await res.text()
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
async function fetchStats() {
|
|
128
|
+
statsLoading.value = true
|
|
129
|
+
try {
|
|
130
|
+
const res = await fetch(`/__maizzle/stats/${route.params.template}`)
|
|
131
|
+
stats.value = await res.json()
|
|
132
|
+
} catch {
|
|
133
|
+
stats.value = null
|
|
134
|
+
} finally {
|
|
135
|
+
statsLoading.value = false
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
async function fetchCompatibility() {
|
|
140
|
+
compatibilityLoading.value = true
|
|
141
|
+
try {
|
|
142
|
+
const res = await fetch(`/__maizzle/compatibility/${route.params.template}`)
|
|
143
|
+
compatibilityIssues.value = await res.json()
|
|
144
|
+
} catch {
|
|
145
|
+
compatibilityIssues.value = []
|
|
146
|
+
} finally {
|
|
147
|
+
compatibilityLoading.value = false
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
async function fetchLint() {
|
|
152
|
+
lintLoading.value = true
|
|
153
|
+
try {
|
|
154
|
+
const res = await fetch(`/__maizzle/lint/${route.params.template}`)
|
|
155
|
+
lintIssues.value = await res.json()
|
|
156
|
+
} catch {
|
|
157
|
+
lintIssues.value = []
|
|
158
|
+
} finally {
|
|
159
|
+
lintLoading.value = false
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
watch(() => route.params.template, () => {
|
|
164
|
+
sourceHtml.value = ''
|
|
165
|
+
vueSourceHtml.value = ''
|
|
166
|
+
plaintextContent.value = ''
|
|
167
|
+
compatibilityIssues.value = []
|
|
168
|
+
lintIssues.value = []
|
|
169
|
+
stats.value = null
|
|
170
|
+
sourceView.value = 'compiled'
|
|
171
|
+
fetchTemplate()
|
|
172
|
+
fetchCompatibility()
|
|
173
|
+
fetchLint()
|
|
174
|
+
fetchStats()
|
|
175
|
+
if (viewMode.value === 'source') fetchSource()
|
|
176
|
+
}, { immediate: true })
|
|
177
|
+
|
|
178
|
+
watch(viewMode, (mode) => {
|
|
179
|
+
if (mode === 'source' && !sourceHtml.value) fetchSource()
|
|
180
|
+
})
|
|
181
|
+
|
|
182
|
+
watch(sourceView, (view) => {
|
|
183
|
+
if (view === 'vue' && !vueSourceHtml.value) fetchVueSource()
|
|
184
|
+
if (view === 'compiled' && !sourceHtml.value) fetchSource()
|
|
185
|
+
if (view === 'plaintext' && !plaintextContent.value) fetchPlaintext()
|
|
186
|
+
})
|
|
187
|
+
|
|
188
|
+
if ((import.meta as any).hot) {
|
|
189
|
+
;(import.meta as any).hot.on('maizzle:template-updated', () => {
|
|
190
|
+
fetchTemplate()
|
|
191
|
+
fetchCompatibility()
|
|
192
|
+
fetchLint()
|
|
193
|
+
fetchStats()
|
|
194
|
+
// Clear non-active source views so they re-fetch when switched to
|
|
195
|
+
if (sourceView.value !== 'compiled') sourceHtml.value = ''
|
|
196
|
+
if (sourceView.value !== 'vue') vueSourceHtml.value = ''
|
|
197
|
+
if (sourceView.value !== 'plaintext') plaintextContent.value = ''
|
|
198
|
+
|
|
199
|
+
if (viewMode.value === 'source') {
|
|
200
|
+
if (sourceView.value === 'compiled') fetchSource()
|
|
201
|
+
if (sourceView.value === 'vue') fetchVueSource()
|
|
202
|
+
if (sourceView.value === 'plaintext') fetchPlaintext()
|
|
203
|
+
}
|
|
204
|
+
})
|
|
205
|
+
}
|
|
206
|
+
|
|
207
|
+
|
|
208
|
+
async function goToLine(line: number) {
|
|
209
|
+
// Switch to source view showing Vue source
|
|
210
|
+
viewMode.value = 'source'
|
|
211
|
+
sourceView.value = 'vue'
|
|
212
|
+
|
|
213
|
+
// Ensure vue source is loaded
|
|
214
|
+
if (!vueSourceHtml.value) {
|
|
215
|
+
await fetchVueSource()
|
|
216
|
+
}
|
|
217
|
+
|
|
218
|
+
await nextTick()
|
|
219
|
+
|
|
220
|
+
const el = vueSourceEl.value
|
|
221
|
+
if (!el) return
|
|
222
|
+
|
|
223
|
+
// Remove previous highlight
|
|
224
|
+
el.querySelectorAll('.shiki-highlight-line').forEach(l => l.classList.remove('shiki-highlight-line'))
|
|
225
|
+
|
|
226
|
+
// Find and highlight the line
|
|
227
|
+
const lineEl = el.querySelector(`[data-line="${line}"]`)
|
|
228
|
+
if (lineEl) {
|
|
229
|
+
lineEl.classList.add('shiki-highlight-line')
|
|
230
|
+
lineEl.scrollIntoView({ block: 'center', behavior: 'smooth' })
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
|
|
234
|
+
// Track which axis is being user-dragged so we can sync the opposite panel
|
|
235
|
+
let hDragging = false
|
|
236
|
+
let vDragging = false
|
|
237
|
+
|
|
238
|
+
const emit = defineEmits<{ 'clear-device': [] }>()
|
|
239
|
+
|
|
240
|
+
function onHDragStart() { hDragging = true; isDragging.value = true; emit('clear-device') }
|
|
241
|
+
function onHDragEnd() { setTimeout(() => { hDragging = false }, 50); isDragging.value = false }
|
|
242
|
+
function onVDragStart() { vDragging = true; isDragging.value = true; emit('clear-device') }
|
|
243
|
+
function onVDragEnd() { setTimeout(() => { vDragging = false }, 50); isDragging.value = false }
|
|
244
|
+
|
|
245
|
+
function onHorizontalLayout(sizes: number[]) {
|
|
246
|
+
if (!hDragging) return
|
|
247
|
+
|
|
248
|
+
const [left, , right] = sizes
|
|
249
|
+
if (Math.abs(left - right) < 0.5) return
|
|
250
|
+
|
|
251
|
+
hDragging = false
|
|
252
|
+
const side = Math.max(left, right)
|
|
253
|
+
if (left < side) leftPanel.value?.resize(side)
|
|
254
|
+
if (right < side) rightPanel.value?.resize(side)
|
|
255
|
+
}
|
|
256
|
+
|
|
257
|
+
function onVerticalLayout(sizes: number[]) {
|
|
258
|
+
if (!vDragging) return
|
|
259
|
+
|
|
260
|
+
const [top, , bottom] = sizes
|
|
261
|
+
if (Math.abs(top - bottom) < 0.5) return
|
|
262
|
+
|
|
263
|
+
vDragging = false
|
|
264
|
+
const side = Math.max(top, bottom)
|
|
265
|
+
if (top < side) topPanel.value?.resize(side)
|
|
266
|
+
if (bottom < side) bottomPanel.value?.resize(side)
|
|
267
|
+
}
|
|
268
|
+
|
|
269
|
+
function applyDeviceSize(device: Device | null | undefined) {
|
|
270
|
+
const el = containerEl.value
|
|
271
|
+
if (!el) return
|
|
272
|
+
|
|
273
|
+
if (!device) {
|
|
274
|
+
if (!hDragging && !vDragging) {
|
|
275
|
+
leftPanel.value?.resize(0)
|
|
276
|
+
rightPanel.value?.resize(0)
|
|
277
|
+
topPanel.value?.resize(0)
|
|
278
|
+
bottomPanel.value?.resize(0)
|
|
279
|
+
}
|
|
280
|
+
return
|
|
281
|
+
}
|
|
282
|
+
|
|
283
|
+
const rect = el.getBoundingClientRect()
|
|
284
|
+
if (!rect.width || !rect.height) return
|
|
285
|
+
|
|
286
|
+
const handleSize = 16
|
|
287
|
+
const hPanelSpace = rect.width - handleSize * 2
|
|
288
|
+
const vPanelSpace = rect.height - handleSize * 2
|
|
289
|
+
|
|
290
|
+
const hSide = Math.max(0, ((hPanelSpace - device.width) / 2) / hPanelSpace * 100)
|
|
291
|
+
const vSide = Math.max(0, ((vPanelSpace - device.height) / 2) / vPanelSpace * 100)
|
|
292
|
+
|
|
293
|
+
leftPanel.value?.resize(hSide)
|
|
294
|
+
rightPanel.value?.resize(hSide)
|
|
295
|
+
topPanel.value?.resize(vSide)
|
|
296
|
+
bottomPanel.value?.resize(vSide)
|
|
297
|
+
}
|
|
298
|
+
|
|
299
|
+
watch(() => props.device, (device) => {
|
|
300
|
+
if (viewMode.value === 'source') return
|
|
301
|
+
applyDeviceSize(device)
|
|
302
|
+
})
|
|
303
|
+
|
|
304
|
+
watch(() => props.resetKey, () => {
|
|
305
|
+
applyDeviceSize(null)
|
|
306
|
+
})
|
|
307
|
+
|
|
308
|
+
watch(viewMode, async (mode) => {
|
|
309
|
+
if (mode === 'preview' && props.device) {
|
|
310
|
+
await nextTick()
|
|
311
|
+
applyDeviceSize(props.device)
|
|
312
|
+
}
|
|
313
|
+
})
|
|
314
|
+
|
|
315
|
+
let observer: ResizeObserver | null = null
|
|
316
|
+
|
|
317
|
+
function forwardIframeKeys(iframe: HTMLIFrameElement) {
|
|
318
|
+
try {
|
|
319
|
+
const iframeDoc = iframe.contentDocument
|
|
320
|
+
if (!iframeDoc) return
|
|
321
|
+
|
|
322
|
+
iframeDoc.addEventListener('keydown', (e: KeyboardEvent) => {
|
|
323
|
+
document.dispatchEvent(new KeyboardEvent('keydown', {
|
|
324
|
+
key: e.key,
|
|
325
|
+
code: e.code,
|
|
326
|
+
ctrlKey: e.ctrlKey,
|
|
327
|
+
metaKey: e.metaKey,
|
|
328
|
+
shiftKey: e.shiftKey,
|
|
329
|
+
altKey: e.altKey,
|
|
330
|
+
}))
|
|
331
|
+
})
|
|
332
|
+
} catch {}
|
|
333
|
+
}
|
|
334
|
+
|
|
335
|
+
onMounted(() => {
|
|
336
|
+
const el = iframeEl.value
|
|
337
|
+
if (el) {
|
|
338
|
+
const rect = el.getBoundingClientRect()
|
|
339
|
+
panelWidth.value = Math.round(rect.width)
|
|
340
|
+
panelHeight.value = Math.round(rect.height)
|
|
341
|
+
observer = new ResizeObserver((entries) => {
|
|
342
|
+
for (const entry of entries) {
|
|
343
|
+
panelWidth.value = Math.round(entry.contentRect.width)
|
|
344
|
+
panelHeight.value = Math.round(entry.contentRect.height)
|
|
345
|
+
}
|
|
346
|
+
})
|
|
347
|
+
observer.observe(el)
|
|
348
|
+
el.addEventListener('load', () => forwardIframeKeys(el))
|
|
349
|
+
}
|
|
350
|
+
})
|
|
351
|
+
|
|
352
|
+
onUnmounted(() => {
|
|
353
|
+
observer?.disconnect()
|
|
354
|
+
})
|
|
355
|
+
|
|
356
|
+
const bottomPanelOpen = ref(false)
|
|
357
|
+
const tabsPanelHeight = ref(40)
|
|
358
|
+
const activeTab = ref<string | undefined>(undefined)
|
|
359
|
+
|
|
360
|
+
function toggleBottomPanel() {
|
|
361
|
+
bottomPanelOpen.value = !bottomPanelOpen.value
|
|
362
|
+
if (bottomPanelOpen.value) {
|
|
363
|
+
tabsPanelHeight.value = 200
|
|
364
|
+
if (!activeTab.value) activeTab.value = 'compatibility'
|
|
365
|
+
} else {
|
|
366
|
+
tabsPanelHeight.value = 40
|
|
367
|
+
activeTab.value = undefined
|
|
368
|
+
}
|
|
369
|
+
}
|
|
370
|
+
|
|
371
|
+
function onTabClick(tab: string) {
|
|
372
|
+
if (tab === activeTab.value && bottomPanelOpen.value) {
|
|
373
|
+
bottomPanelOpen.value = false
|
|
374
|
+
tabsPanelHeight.value = 40
|
|
375
|
+
activeTab.value = undefined
|
|
376
|
+
return
|
|
377
|
+
}
|
|
378
|
+
activeTab.value = tab
|
|
379
|
+
if (!bottomPanelOpen.value) {
|
|
380
|
+
bottomPanelOpen.value = true
|
|
381
|
+
tabsPanelHeight.value = 200
|
|
382
|
+
}
|
|
383
|
+
}
|
|
384
|
+
|
|
385
|
+
const tabsDragging = ref(false)
|
|
386
|
+
|
|
387
|
+
function onTabsDragStart(e: MouseEvent) {
|
|
388
|
+
e.preventDefault()
|
|
389
|
+
tabsDragging.value = true
|
|
390
|
+
const startY = e.clientY
|
|
391
|
+
const startHeight = tabsPanelHeight.value
|
|
392
|
+
|
|
393
|
+
const onMouseMove = (e: MouseEvent) => {
|
|
394
|
+
const newHeight = Math.max(40, startHeight + startY - e.clientY)
|
|
395
|
+
tabsPanelHeight.value = newHeight
|
|
396
|
+
bottomPanelOpen.value = newHeight > 40
|
|
397
|
+
|
|
398
|
+
if (!bottomPanelOpen.value) {
|
|
399
|
+
activeTab.value = undefined
|
|
400
|
+
} else if (!activeTab.value) {
|
|
401
|
+
activeTab.value = 'compatibility'
|
|
402
|
+
}
|
|
403
|
+
}
|
|
404
|
+
|
|
405
|
+
const onMouseUp = () => {
|
|
406
|
+
tabsDragging.value = false
|
|
407
|
+
document.removeEventListener('mousemove', onMouseMove)
|
|
408
|
+
document.removeEventListener('mouseup', onMouseUp)
|
|
409
|
+
}
|
|
410
|
+
|
|
411
|
+
document.addEventListener('mousemove', onMouseMove)
|
|
412
|
+
document.addEventListener('mouseup', onMouseUp)
|
|
413
|
+
}
|
|
414
|
+
|
|
415
|
+
const stripeBg = {
|
|
416
|
+
backgroundImage: `url(${stripesUrl})`,
|
|
417
|
+
backgroundRepeat: 'repeat',
|
|
418
|
+
backgroundAttachment: 'fixed',
|
|
419
|
+
}
|
|
420
|
+
</script>
|
|
421
|
+
|
|
422
|
+
<template>
|
|
423
|
+
<div class="flex flex-col h-full">
|
|
424
|
+
<div class="relative flex-1 min-h-0">
|
|
425
|
+
<!-- Source code view -->
|
|
426
|
+
<div v-show="viewMode === 'source'" class="absolute inset-0 min-w-0 overflow-hidden">
|
|
427
|
+
<div class="absolute top-3 left-6 z-10">
|
|
428
|
+
<DropdownMenu :modal="false">
|
|
429
|
+
<DropdownMenuTrigger class="inline-flex items-center gap-1 rounded-md bg-white/10 px-2.5 h-7 text-xs font-medium text-gray-300 hover:bg-white/15 transition-colors">
|
|
430
|
+
{{ sourceView === 'compiled' ? 'HTML' : sourceView === 'vue' ? 'Source' : 'Plaintext' }}
|
|
431
|
+
<ChevronDown class="size-3 opacity-50" />
|
|
432
|
+
</DropdownMenuTrigger>
|
|
433
|
+
<DropdownMenuContent align="start" class="min-w-0 bg-white/10 backdrop-blur-md border-white/10">
|
|
434
|
+
<DropdownMenuItem class="text-xs font-medium text-gray-300 hover:text-white focus:bg-white/10 focus:text-white" @click="sourceView = 'vue'">
|
|
435
|
+
<Check v-if="sourceView === 'vue'" class="size-3.5" />
|
|
436
|
+
<span :class="sourceView === 'vue' ? '' : 'pl-5.5'">Source</span>
|
|
437
|
+
</DropdownMenuItem>
|
|
438
|
+
<DropdownMenuItem class="text-xs font-medium text-gray-300 hover:text-white focus:bg-white/10 focus:text-white" @click="sourceView = 'compiled'">
|
|
439
|
+
<Check v-if="sourceView === 'compiled'" class="size-3.5" />
|
|
440
|
+
<span :class="sourceView === 'compiled' ? '' : 'pl-5.5'">HTML</span>
|
|
441
|
+
</DropdownMenuItem>
|
|
442
|
+
<DropdownMenuItem class="text-xs font-medium text-gray-300 hover:text-white focus:bg-white/10 focus:text-white" @click="sourceView = 'plaintext'">
|
|
443
|
+
<Check v-if="sourceView === 'plaintext'" class="size-3.5" />
|
|
444
|
+
<span :class="sourceView === 'plaintext' ? '' : 'pl-5.5'">Plaintext</span>
|
|
445
|
+
</DropdownMenuItem>
|
|
446
|
+
</DropdownMenuContent>
|
|
447
|
+
</DropdownMenu>
|
|
448
|
+
</div>
|
|
449
|
+
<button
|
|
450
|
+
class="absolute top-3 right-6 z-10 inline-flex items-center justify-center rounded-md px-2.5 h-8 bg-transparent hover:bg-transparent group disabled:opacity-50 disabled:cursor-not-allowed transition-all"
|
|
451
|
+
:disabled="copied"
|
|
452
|
+
@click="copySource"
|
|
453
|
+
>
|
|
454
|
+
<svg v-if="!copied" class="size-5 text-gray-400 group-hover:text-gray-300" viewBox="0 0 18 18" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M14.25 5.25H7.25C6.14543 5.25 5.25 6.14543 5.25 7.25V14.25C5.25 15.3546 6.14543 16.25 7.25 16.25H14.25C15.3546 16.25 16.25 15.3546 16.25 14.25V7.25C16.25 6.14543 15.3546 5.25 14.25 5.25Z" stroke="currentColor" stroke-width="1" stroke-linecap="round" stroke-linejoin="round" /><path d="M2.80103 11.998L1.77203 5.07397C1.61003 3.98097 2.36403 2.96397 3.45603 2.80197L10.38 1.77297C11.313 1.63397 12.19 2.16297 12.528 3.00097" stroke="currentColor" stroke-width="1" stroke-linecap="round" stroke-linejoin="round" /></svg>
|
|
455
|
+
<svg v-else class="size-5 text-emerald-400" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M20 6 9 17l-5-5" /></svg>
|
|
456
|
+
</button>
|
|
457
|
+
<div
|
|
458
|
+
v-show="sourceView === 'compiled'"
|
|
459
|
+
class="shiki-line-numbers h-full overflow-auto [&_pre]:p-6 [&_pre]:pt-14 [&_pre]:text-base [&_pre]:leading-6 [&_pre]:min-h-full [&_pre]:overflow-x-auto"
|
|
460
|
+
v-html="sourceHtml"
|
|
461
|
+
/>
|
|
462
|
+
<div
|
|
463
|
+
ref="vueSourceEl"
|
|
464
|
+
v-show="sourceView === 'vue'"
|
|
465
|
+
class="shiki-line-numbers h-full overflow-auto [&_pre]:p-6 [&_pre]:pt-14 [&_pre]:text-base [&_pre]:leading-6 [&_pre]:min-h-full [&_pre]:overflow-x-auto"
|
|
466
|
+
v-html="vueSourceHtml"
|
|
467
|
+
/>
|
|
468
|
+
<pre
|
|
469
|
+
v-show="sourceView === 'plaintext'"
|
|
470
|
+
class="h-full overflow-auto p-6 pt-14 text-sm leading-6 min-h-full text-gray-300 bg-[#27212e] whitespace-pre-wrap break-words"
|
|
471
|
+
>{{ plaintextContent }}</pre>
|
|
472
|
+
</div>
|
|
473
|
+
|
|
474
|
+
<!-- Preview view -->
|
|
475
|
+
<div v-show="viewMode !== 'source'" class="absolute inset-0">
|
|
476
|
+
<div class="relative h-full opacity-5" :style="stripeBg" />
|
|
477
|
+
</div>
|
|
478
|
+
|
|
479
|
+
<div v-show="viewMode !== 'source'" ref="containerEl" class="absolute inset-0 z-10 flex flex-col">
|
|
480
|
+
<div class="flex-1 min-h-0">
|
|
481
|
+
<ResizablePanelGroup direction="vertical" class="h-full" @layout="onVerticalLayout">
|
|
482
|
+
<ResizablePanel ref="topPanel" :default-size="0" @resize="(s: number) => { sideSizes.top = s; updateFullSize() }" />
|
|
483
|
+
<ResizableHandle class="h-4! bg-gray-50 hover:bg-gray-100 dark:bg-white/5 dark:hover:bg-white/10 transition-colors after:hidden!" @dragging="(v: boolean) => v ? onVDragStart() : onVDragEnd()" />
|
|
484
|
+
<ResizablePanel :default-size="100" :min-size="20">
|
|
485
|
+
<ResizablePanelGroup direction="horizontal" class="h-full" @layout="onHorizontalLayout">
|
|
486
|
+
<ResizablePanel ref="leftPanel" :default-size="0" @resize="(s: number) => { sideSizes.left = s; updateFullSize() }" />
|
|
487
|
+
<ResizableHandle class="w-4 bg-gray-50 hover:bg-gray-100 dark:bg-white/5 dark:hover:bg-white/10 transition-colors after:hidden!" @dragging="(v: boolean) => v ? onHDragStart() : onHDragEnd()" />
|
|
488
|
+
<ResizablePanel ref="previewEl" :default-size="100" :min-size="20">
|
|
489
|
+
<iframe
|
|
490
|
+
ref="iframeEl"
|
|
491
|
+
:srcdoc="srcdoc"
|
|
492
|
+
class="h-full w-full border-0 bg-white"
|
|
493
|
+
/>
|
|
494
|
+
</ResizablePanel>
|
|
495
|
+
<ResizableHandle class="w-4 bg-gray-50 hover:bg-gray-100 dark:bg-white/5 dark:hover:bg-white/10 transition-colors after:hidden!" @dragging="(v: boolean) => v ? onHDragStart() : onHDragEnd()" />
|
|
496
|
+
<ResizablePanel ref="rightPanel" :default-size="0" @resize="(s: number) => { sideSizes.right = s; updateFullSize() }" />
|
|
497
|
+
</ResizablePanelGroup>
|
|
498
|
+
</ResizablePanel>
|
|
499
|
+
<ResizableHandle class="h-4! bg-gray-50 hover:bg-gray-100 dark:bg-white/5 dark:hover:bg-white/10 transition-colors after:hidden!" @dragging="(v: boolean) => v ? onVDragStart() : onVDragEnd()" />
|
|
500
|
+
<ResizablePanel ref="bottomPanel" :default-size="0" @resize="(s: number) => { sideSizes.bottom = s; updateFullSize() }" />
|
|
501
|
+
</ResizablePanelGroup>
|
|
502
|
+
</div>
|
|
503
|
+
</div>
|
|
504
|
+
</div>
|
|
505
|
+
|
|
506
|
+
<!-- Tabs panel (always visible) -->
|
|
507
|
+
<div
|
|
508
|
+
class="shrink-0 bg-white dark:bg-gray-950 overflow-hidden"
|
|
509
|
+
:class="!tabsDragging ? 'transition-[height] duration-200 ease-in-out' : ''"
|
|
510
|
+
:style="{ height: `${tabsPanelHeight}px` }"
|
|
511
|
+
>
|
|
512
|
+
<div
|
|
513
|
+
class="relative h-px bg-gray-200 dark:bg-gray-800 cursor-row-resize before:absolute before:-top-2 before:left-0 before:right-0 before:h-5 before:content-['']"
|
|
514
|
+
@mousedown="onTabsDragStart"
|
|
515
|
+
/>
|
|
516
|
+
<Tabs :model-value="activeTab" class="flex flex-col min-h-0 h-full">
|
|
517
|
+
<div class="flex items-center justify-between min-h-10 px-4 shrink-0" :class="bottomPanelOpen ? 'border-b' : ''">
|
|
518
|
+
<TabsList class="h-full bg-transparent! rounded-none! p-0 gap-1">
|
|
519
|
+
<TabsTrigger value="compatibility" class="text-xs px-3 h-full rounded-none! border-0! shadow-none! border-b! border-transparent data-[state=active]:border-gray-400 data-[state=active]:dark:border-gray-600 data-[state=active]:bg-transparent data-[state=inactive]:bg-transparent" @click="onTabClick('compatibility')">
|
|
520
|
+
Compatibility
|
|
521
|
+
</TabsTrigger>
|
|
522
|
+
<TabsTrigger value="lint" class="text-xs px-3 h-full rounded-none! border-0! shadow-none! border-b! border-transparent data-[state=active]:border-gray-400 data-[state=active]:dark:border-gray-600 data-[state=active]:bg-transparent data-[state=inactive]:bg-transparent" @click="onTabClick('lint')">
|
|
523
|
+
Linter
|
|
524
|
+
</TabsTrigger>
|
|
525
|
+
<TabsTrigger value="stats" class="text-xs px-3 h-full rounded-none! border-0! shadow-none! border-b! border-transparent data-[state=active]:border-gray-400 data-[state=active]:dark:border-gray-600 data-[state=active]:bg-transparent data-[state=inactive]:bg-transparent" @click="onTabClick('stats')">
|
|
526
|
+
Stats
|
|
527
|
+
</TabsTrigger>
|
|
528
|
+
</TabsList>
|
|
529
|
+
<Button variant="ghost" size="icon" class="h-7 w-7 hover:bg-transparent!" @click="toggleBottomPanel">
|
|
530
|
+
<ChevronUp v-if="!bottomPanelOpen" class="size-4" />
|
|
531
|
+
<ChevronDown v-else class="size-4" />
|
|
532
|
+
</Button>
|
|
533
|
+
</div>
|
|
534
|
+
<div class="flex-1 overflow-auto">
|
|
535
|
+
<TabsContent value="compatibility" class="mt-0">
|
|
536
|
+
<p v-if="compatibilityLoading" class="px-4 py-3 text-xs text-gray-500 dark:text-gray-400">Checking compatibility...</p>
|
|
537
|
+
<p v-else-if="compatibilityIssues.length === 0" class="px-4 py-3 text-xs text-gray-500 dark:text-gray-400">No compatibility issues found.</p>
|
|
538
|
+
<ul v-else class="text-xs divide-y">
|
|
539
|
+
<li
|
|
540
|
+
v-for="(issue, i) in compatibilityIssues"
|
|
541
|
+
:key="i"
|
|
542
|
+
class="px-4 py-2 hover:bg-gray-50 dark:hover:bg-white/5"
|
|
543
|
+
>
|
|
544
|
+
<div class="flex items-start justify-between gap-4">
|
|
545
|
+
<div>
|
|
546
|
+
<a v-if="issue.url" :href="issue.url" target="_blank" rel="noopener" class="font-medium hover:underline" :class="issue.type === 'error' ? 'text-red-600' : 'text-amber-600'">
|
|
547
|
+
{{ issue.title }}
|
|
548
|
+
</a>
|
|
549
|
+
<span v-else class="font-medium" :class="issue.type === 'error' ? 'text-red-600' : 'text-amber-600'">
|
|
550
|
+
{{ issue.title }}
|
|
551
|
+
</span>
|
|
552
|
+
<div class="text-gray-500 dark:text-gray-400 mt-1 space-y-0.5">
|
|
553
|
+
<div v-for="client in issue.clients" :key="client.name">
|
|
554
|
+
<span class="text-gray-700 dark:text-gray-300">{{ client.name }}</span><span v-if="client.notes.length">: {{ client.notes.join('. ') }}</span>
|
|
555
|
+
</div>
|
|
556
|
+
</div>
|
|
557
|
+
</div>
|
|
558
|
+
<button v-if="issue.line" class="text-gray-500 dark:text-gray-400 hover:text-gray-900 dark:hover:text-gray-100 cursor-pointer tabular-nums shrink-0" @click="goToLine(issue.line!)">L{{ issue.line }}</button>
|
|
559
|
+
</div>
|
|
560
|
+
</li>
|
|
561
|
+
</ul>
|
|
562
|
+
</TabsContent>
|
|
563
|
+
<TabsContent value="lint" class="mt-0">
|
|
564
|
+
<p v-if="lintLoading" class="px-4 py-3 text-xs text-gray-500 dark:text-gray-400">Linting...</p>
|
|
565
|
+
<p v-else-if="lintIssues.length === 0" class="px-4 py-3 text-xs text-gray-500 dark:text-gray-400">No issues found.</p>
|
|
566
|
+
<ul v-else class="text-xs divide-y">
|
|
567
|
+
<li
|
|
568
|
+
v-for="(issue, i) in lintIssues"
|
|
569
|
+
:key="i"
|
|
570
|
+
class="px-4 py-2 hover:bg-gray-50 dark:hover:bg-white/5"
|
|
571
|
+
>
|
|
572
|
+
<div class="flex items-start justify-between gap-4">
|
|
573
|
+
<div>
|
|
574
|
+
<span class="font-medium" :class="issue.type === 'error' ? 'text-red-600' : 'text-amber-600'">
|
|
575
|
+
{{ issue.title }}
|
|
576
|
+
</span>
|
|
577
|
+
<div class="text-gray-500 dark:text-gray-400 mt-0.5">{{ issue.message }}</div>
|
|
578
|
+
</div>
|
|
579
|
+
<button v-if="issue.line" class="text-gray-500 dark:text-gray-400 hover:text-gray-900 dark:hover:text-gray-100 cursor-pointer tabular-nums shrink-0" @click="goToLine(issue.line!)">L{{ issue.line }}</button>
|
|
580
|
+
</div>
|
|
581
|
+
</li>
|
|
582
|
+
</ul>
|
|
583
|
+
</TabsContent>
|
|
584
|
+
<TabsContent value="stats" class="mt-0">
|
|
585
|
+
<p v-if="statsLoading" class="px-4 py-3 text-xs text-gray-500 dark:text-gray-400">Loading stats...</p>
|
|
586
|
+
<p v-else-if="!stats" class="px-4 py-3 text-xs text-gray-500 dark:text-gray-400">No stats available.</p>
|
|
587
|
+
<div v-else class="px-4 py-3 flex items-center gap-6 text-xs">
|
|
588
|
+
<div class="flex items-center gap-1.5">
|
|
589
|
+
<span class="text-gray-500 dark:text-gray-400">Size</span>
|
|
590
|
+
<span
|
|
591
|
+
class="font-medium tabular-nums"
|
|
592
|
+
:class="stats.size.bytes > 102400 ? 'text-red-600' : stats.size.bytes > 51200 ? 'text-amber-600' : 'text-gray-900 dark:text-gray-100'"
|
|
593
|
+
>{{ stats.size.formatted }}</span>
|
|
594
|
+
</div>
|
|
595
|
+
<div class="flex items-center gap-1.5">
|
|
596
|
+
<span class="text-gray-500 dark:text-gray-400">Images</span>
|
|
597
|
+
<span class="font-medium tabular-nums">{{ stats.images }}</span>
|
|
598
|
+
</div>
|
|
599
|
+
<div class="flex items-center gap-1.5">
|
|
600
|
+
<span class="text-gray-500 dark:text-gray-400">Links</span>
|
|
601
|
+
<span class="font-medium tabular-nums">{{ stats.links }}</span>
|
|
602
|
+
</div>
|
|
603
|
+
</div>
|
|
604
|
+
</TabsContent>
|
|
605
|
+
</div>
|
|
606
|
+
</Tabs>
|
|
607
|
+
</div>
|
|
608
|
+
</div>
|
|
609
|
+
</template>
|