@rynt/sdk 0.9.53
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/README.md +122 -0
- package/REGISTRIES.md +189 -0
- package/env.d.ts +11 -0
- package/host-shims.d.ts +30 -0
- package/package.json +88 -0
- package/src/extension-marketplace/api-types.ts +141 -0
- package/src/extension-marketplace/client.ts +296 -0
- package/src/extension-marketplace/index.ts +22 -0
- package/src/extension-marketplace/schemas.ts +178 -0
- package/src/extensions/ExtensionRoutePage.vue +17 -0
- package/src/extensions/context.ts +37 -0
- package/src/extensions/disabled-folder.ts +21 -0
- package/src/extensions/extension-expose-map.ts +5 -0
- package/src/extensions/extension-expose.ts +48 -0
- package/src/extensions/graph.ts +67 -0
- package/src/extensions/index.ts +251 -0
- package/src/extensions/invite-handler/types.ts +20 -0
- package/src/extensions/launcher-entities/create-launcher-entity.ts +25 -0
- package/src/extensions/launcher-entities/keys.ts +46 -0
- package/src/extensions/launcher-entities/launcher-entity-components.ts +177 -0
- package/src/extensions/launcher-entities/props-map.ts +69 -0
- package/src/extensions/launcher-entities/registry.ts +32 -0
- package/src/extensions/launcher-models/apis/accounts-contracts.ts +102 -0
- package/src/extensions/launcher-models/apis/launcher-model-apis.ts +553 -0
- package/src/extensions/launcher-models/keys.ts +23 -0
- package/src/extensions/launcher-models/public.ts +9 -0
- package/src/extensions/launcher-models/registry-core.ts +34 -0
- package/src/extensions/manifest-types.ts +22 -0
- package/src/extensions/manifest.ts +46 -0
- package/src/extensions/marketplace-open-key.ts +26 -0
- package/src/extensions/plugin-types.ts +44 -0
- package/src/extensions/plugin.ts +62 -0
- package/src/extensions/registries/bootstrap.ts +11 -0
- package/src/extensions/registries/builtins/account-provider.ts +6 -0
- package/src/extensions/registries/builtins/app-topbar-left-widgets.ts +6 -0
- package/src/extensions/registries/builtins/app-topbar-right-widgets.ts +6 -0
- package/src/extensions/registries/builtins/app-topbar-status-widgets.ts +6 -0
- package/src/extensions/registries/builtins/build-card-actions.ts +6 -0
- package/src/extensions/registries/builtins/build-card-after-meta.ts +6 -0
- package/src/extensions/registries/builtins/build-card-before-media.ts +6 -0
- package/src/extensions/registries/builtins/build-card-before-meta.ts +6 -0
- package/src/extensions/registries/builtins/build-card-footer-actions.ts +6 -0
- package/src/extensions/registries/builtins/build-detail-after-content.ts +6 -0
- package/src/extensions/registries/builtins/build-detail-before-content.ts +6 -0
- package/src/extensions/registries/builtins/build-detail-before-hero.ts +6 -0
- package/src/extensions/registries/builtins/build-detail-header-actions.ts +6 -0
- package/src/extensions/registries/builtins/build-detail-mod-row-actions.ts +6 -0
- package/src/extensions/registries/builtins/build-detail-resourcepack-row-actions.ts +6 -0
- package/src/extensions/registries/builtins/build-detail-right-column-bottom.ts +6 -0
- package/src/extensions/registries/builtins/build-detail-right-column-top.ts +6 -0
- package/src/extensions/registries/builtins/dialog-footer-actions.ts +6 -0
- package/src/extensions/registries/builtins/feed-after-content.ts +6 -0
- package/src/extensions/registries/builtins/feed-before-content.ts +6 -0
- package/src/extensions/registries/builtins/file-editor.ts +19 -0
- package/src/extensions/registries/builtins/friends-after-list.ts +6 -0
- package/src/extensions/registries/builtins/friends-before-list.ts +6 -0
- package/src/extensions/registries/builtins/index.ts +141 -0
- package/src/extensions/registries/builtins/invite-handler.ts +7 -0
- package/src/extensions/registries/builtins/library-after-content.ts +6 -0
- package/src/extensions/registries/builtins/library-before-content.ts +6 -0
- package/src/extensions/registries/builtins/loader.ts +8 -0
- package/src/extensions/registries/builtins/map-card-actions.ts +6 -0
- package/src/extensions/registries/builtins/map-card-after-meta.ts +6 -0
- package/src/extensions/registries/builtins/map-card-before-meta.ts +6 -0
- package/src/extensions/registries/builtins/map-card-footer-actions.ts +6 -0
- package/src/extensions/registries/builtins/map-detail-after-content.ts +6 -0
- package/src/extensions/registries/builtins/map-detail-before-content.ts +6 -0
- package/src/extensions/registries/builtins/map-detail-header-actions.ts +6 -0
- package/src/extensions/registries/builtins/markdown-editor-tiptap-extensions.ts +7 -0
- package/src/extensions/registries/builtins/markdown-editor-toolbar-actions.ts +6 -0
- package/src/extensions/registries/builtins/markdown-renderer-after-content.ts +6 -0
- package/src/extensions/registries/builtins/markdown-renderer-before-content.ts +6 -0
- package/src/extensions/registries/builtins/mod-details-footer-actions.ts +6 -0
- package/src/extensions/registries/builtins/mod-manage-actions.ts +6 -0
- package/src/extensions/registries/builtins/mod-provider.ts +5 -0
- package/src/extensions/registries/builtins/nav.ts +7 -0
- package/src/extensions/registries/builtins/page.ts +13 -0
- package/src/extensions/registries/builtins/projects-after-content.ts +6 -0
- package/src/extensions/registries/builtins/projects-before-content.ts +6 -0
- package/src/extensions/registries/builtins/resourcepack-manage-actions.ts +7 -0
- package/src/extensions/registries/builtins/server-card-actions.ts +6 -0
- package/src/extensions/registries/builtins/server-card-after-meta.ts +6 -0
- package/src/extensions/registries/builtins/server-card-before-meta.ts +6 -0
- package/src/extensions/registries/builtins/server-card-footer-actions.ts +6 -0
- package/src/extensions/registries/builtins/server-detail-after-content.ts +6 -0
- package/src/extensions/registries/builtins/server-detail-before-content.ts +6 -0
- package/src/extensions/registries/builtins/server-detail-header-actions.ts +6 -0
- package/src/extensions/registries/builtins/settings-after-sections.ts +6 -0
- package/src/extensions/registries/builtins/settings-before-sections.ts +6 -0
- package/src/extensions/registries/builtins/settings-section-widgets.ts +6 -0
- package/src/extensions/registries/builtins/shaderpack-manage-actions.ts +7 -0
- package/src/extensions/registries/builtins/shell.ts +5 -0
- package/src/extensions/registries/builtins/sidebar-after-content.ts +6 -0
- package/src/extensions/registries/builtins/sidebar-before-content.ts +6 -0
- package/src/extensions/registries/builtins/sidebar-footer-widgets.ts +6 -0
- package/src/extensions/registries/builtins/sidebar-header-widgets.ts +6 -0
- package/src/extensions/registries/builtins/sidebar.ts +11 -0
- package/src/extensions/registries/builtins/theme.ts +5 -0
- package/src/extensions/registries/builtins/user-card-after-meta.ts +6 -0
- package/src/extensions/registries/builtins/user-card-before-meta.ts +6 -0
- package/src/extensions/registries/builtins/user-menu-actions.ts +6 -0
- package/src/extensions/registries/builtins/user-menu-after-actions.ts +6 -0
- package/src/extensions/registries/builtins/user-menu-before-actions.ts +6 -0
- package/src/extensions/registries/builtins/user-strip.ts +5 -0
- package/src/extensions/registries/clear-extension-ui-registries.ts +15 -0
- package/src/extensions/registries/define-extension-registry.ts +58 -0
- package/src/extensions/registries/extension-host-api.ts +41 -0
- package/src/extensions/registries/extension-registry-api.ts +103 -0
- package/src/extensions/registries/extension-registry-payload-map.ts +9 -0
- package/src/extensions/registries/extension-scope.ts +41 -0
- package/src/extensions/registries/get-registry.ts +23 -0
- package/src/extensions/registries/index.ts +58 -0
- package/src/extensions/registries/manifest-rynt.ts +193 -0
- package/src/extensions/registries/registry-slot.ts +40 -0
- package/src/extensions/registries/registry-value-map.ts +89 -0
- package/src/extensions/registries/store.ts +206 -0
- package/src/extensions/resolve-extensions.ts +245 -0
- package/src/extensions/router-bridge.ts +103 -0
- package/src/extensions/session.ts +6 -0
- package/src/extensions/slug.ts +23 -0
- package/src/extensions/version.ts +147 -0
- package/src/host/extensions-composables.ts +33 -0
- package/src/host/extensions-init.ts +194 -0
- package/src/host/index.ts +11 -0
- package/src/host/launcher-models/index.ts +4 -0
- package/src/index.ts +229 -0
- package/src/minecraft-loader/base-loader.ts +102 -0
- package/src/minecraft-loader/index.ts +11 -0
- package/src/minecraft-loader/loader-registry.ts +72 -0
- package/src/shared/api/assets.ts +112 -0
- package/src/shared/api/auth.ts +283 -0
- package/src/shared/api/builds.ts +647 -0
- package/src/shared/api/config.ts +19 -0
- package/src/shared/api/download-stats.ts +103 -0
- package/src/shared/api/downloads.ts +36 -0
- package/src/shared/api/entity-authorship.ts +60 -0
- package/src/shared/api/events.ts +393 -0
- package/src/shared/api/friends.ts +140 -0
- package/src/shared/api/graphql.ts +87 -0
- package/src/shared/api/index.ts +23 -0
- package/src/shared/api/invites.ts +262 -0
- package/src/shared/api/library.ts +44 -0
- package/src/shared/api/maps.ts +385 -0
- package/src/shared/api/notify-websocket.ts +140 -0
- package/src/shared/api/posts.ts +357 -0
- package/src/shared/api/projectServers.ts +379 -0
- package/src/shared/api/serverMembers.ts +173 -0
- package/src/shared/api/users.ts +294 -0
- package/src/shared/composables/buildEditor/useBuildEditor.ts +66 -0
- package/src/shared/composables/buildManifest/buildManifest.ts +447 -0
- package/src/shared/composables/filesEditor/filesEditor.ts +346 -0
- package/src/shared/composables/index.ts +10 -0
- package/src/shared/composables/modsEditor/modsEditor.ts +1678 -0
- package/src/shared/composables/registrySlot/registry-slot-utils.ts +25 -0
- package/src/shared/composables/registrySlot/useRegistrySlotMissing.ts +35 -0
- package/src/shared/composables/resourcePacksEditor/resourcePacksEditor.ts +448 -0
- package/src/shared/composables/shaderPacksEditor/shaderPacksEditor.ts +395 -0
- package/src/shared/composables/useSkinRender.ts +70 -0
- package/src/shared/composables/useZlDeepLink.ts +178 -0
- package/src/shared/definitions/defineGraphCache.ts +216 -0
- package/src/shared/definitions/defineStore.ts +32 -0
- package/src/shared/definitions/index.ts +2 -0
- package/src/shared/minecraft-types/build-manifest.ts +611 -0
- package/src/shared/minecraft-types/index.ts +3 -0
- package/src/shared/minecraft-types/launcher-versions.ts +32 -0
- package/src/shared/minecraft-types/minecraft-launcher-types.ts +276 -0
- package/src/shared/mocks/index.ts +1 -0
- package/src/shared/mocks/navigation.ts +17 -0
- package/src/shared/mods/http.ts +45 -0
- package/src/shared/mods/index.ts +5 -0
- package/src/shared/mods/marketplace-editor-search.ts +266 -0
- package/src/shared/mods/marketplace-search-utils.ts +42 -0
- package/src/shared/mods/mod-marketplace-registry.ts +66 -0
- package/src/shared/mods/mod-marketplace-types.ts +28 -0
- package/src/shared/mods/providers/curseforge.ts +464 -0
- package/src/shared/mods/providers/index.ts +8 -0
- package/src/shared/mods/providers/modrinth.ts +402 -0
- package/src/shared/mods/resolve-mods-provider-loader-ids.ts +77 -0
- package/src/shared/mods/types.ts +76 -0
- package/src/shared/styles/index.css +713 -0
- package/src/shared/themes/index.ts +23 -0
- package/src/shared/themes/theme-tokens-black.json +126 -0
- package/src/shared/themes/theme-tokens-classic.json +126 -0
- package/src/shared/themes/theme-tokens-pink.json +126 -0
- package/src/shared/themes/theme-tokens.json +126 -0
- package/src/shared/themes/types.ts +85 -0
- package/src/shared/types/API_DOCUMENTATION.md +422 -0
- package/src/shared/types/account.ts +40 -0
- package/src/shared/types/build.ts +8 -0
- package/src/shared/types/entities.ts +181 -0
- package/src/shared/types/index.ts +6 -0
- package/src/shared/types/invite-payloads.ts +60 -0
- package/src/shared/types/navigation.ts +16 -0
- package/src/shared/types/running-build.ts +51 -0
- package/src/shared/types/serverMember.ts +17 -0
- package/src/shared/types/user.ts +55 -0
- package/src/shared/ui/base/Avatar.vue +262 -0
- package/src/shared/ui/base/Badge.vue +47 -0
- package/src/shared/ui/base/Button.vue +78 -0
- package/src/shared/ui/base/Divider.vue +42 -0
- package/src/shared/ui/base/Icon.vue +597 -0
- package/src/shared/ui/base/StatusIndicator.vue +44 -0
- package/src/shared/ui/base/index.ts +7 -0
- package/src/shared/ui/cards/InviteCard.vue +47 -0
- package/src/shared/ui/cards/index.ts +2 -0
- package/src/shared/ui/dialog/Dialog.vue +71 -0
- package/src/shared/ui/dialog/DialogContent.vue +31 -0
- package/src/shared/ui/dialog/DialogFooter.vue +14 -0
- package/src/shared/ui/dialog/DialogHeader.vue +41 -0
- package/src/shared/ui/dialog/index.ts +5 -0
- package/src/shared/ui/editors/AttachmentImagesEditor.vue +133 -0
- package/src/shared/ui/editors/ContentAttachmentsDisplay.vue +76 -0
- package/src/shared/ui/editors/MarkdownEditor.vue +956 -0
- package/src/shared/ui/editors/MarkdownRenderer.vue +299 -0
- package/src/shared/ui/editors/RichContentImageViewer.vue +85 -0
- package/src/shared/ui/editors/SocialPostMediaZone.vue +320 -0
- package/src/shared/ui/editors/index.ts +6 -0
- package/src/shared/ui/editors/markdown-editor-gallery.ts +234 -0
- package/src/shared/ui/editors/markdown-editor-image.ts +178 -0
- package/src/shared/ui/form/Checkbox.vue +38 -0
- package/src/shared/ui/form/FormField.vue +30 -0
- package/src/shared/ui/form/FormGrid.vue +38 -0
- package/src/shared/ui/form/ImageEditor.vue +598 -0
- package/src/shared/ui/form/Input.vue +72 -0
- package/src/shared/ui/form/Range.vue +65 -0
- package/src/shared/ui/form/Select.vue +76 -0
- package/src/shared/ui/form/Switch.vue +38 -0
- package/src/shared/ui/form/Textarea.vue +144 -0
- package/src/shared/ui/form/index.ts +9 -0
- package/src/shared/ui/index.ts +9 -0
- package/src/shared/ui/layout/BusyOverlay.vue +31 -0
- package/src/shared/ui/layout/Callout.vue +44 -0
- package/src/shared/ui/layout/Card.vue +38 -0
- package/src/shared/ui/layout/Container.vue +36 -0
- package/src/shared/ui/layout/EmptyState.vue +99 -0
- package/src/shared/ui/layout/EntityMediaRow.vue +54 -0
- package/src/shared/ui/layout/FilterResultsLayout.vue +22 -0
- package/src/shared/ui/layout/FloatingPanel.vue +37 -0
- package/src/shared/ui/layout/FullscreenDimmer.vue +11 -0
- package/src/shared/ui/layout/Grid.vue +40 -0
- package/src/shared/ui/layout/Inline.vue +59 -0
- package/src/shared/ui/layout/LoadingState.vue +39 -0
- package/src/shared/ui/layout/MediaBox.vue +47 -0
- package/src/shared/ui/layout/OverlayPanel.vue +28 -0
- package/src/shared/ui/layout/OverlayWaitPanel.vue +22 -0
- package/src/shared/ui/layout/PageSection.vue +43 -0
- package/src/shared/ui/layout/PageToolbar.vue +29 -0
- package/src/shared/ui/layout/Panel.vue +39 -0
- package/src/shared/ui/layout/ProgressBar.vue +49 -0
- package/src/shared/ui/layout/Section.vue +30 -0
- package/src/shared/ui/layout/SegmentedControl.vue +43 -0
- package/src/shared/ui/layout/SelectableCard.vue +46 -0
- package/src/shared/ui/layout/SelectableRow.vue +41 -0
- package/src/shared/ui/layout/Skeleton.vue +25 -0
- package/src/shared/ui/layout/SkeletonAvatar.vue +30 -0
- package/src/shared/ui/layout/SkeletonEntityCard.vue +20 -0
- package/src/shared/ui/layout/SkeletonFeedPost.vue +22 -0
- package/src/shared/ui/layout/SkeletonGrid.vue +18 -0
- package/src/shared/ui/layout/SkeletonListRow.vue +31 -0
- package/src/shared/ui/layout/SkeletonText.vue +25 -0
- package/src/shared/ui/layout/Stack.vue +42 -0
- package/src/shared/ui/layout/StateBlock.vue +44 -0
- package/src/shared/ui/layout/TwoPaneLayout.vue +35 -0
- package/src/shared/ui/layout/VirtualList.vue +160 -0
- package/src/shared/ui/layout/index.ts +35 -0
- package/src/shared/ui/layout/skeletonSurfaceStyles.ts +24 -0
- package/src/shared/ui/navigation/NavItem.vue +139 -0
- package/src/shared/ui/navigation/Tab.vue +61 -0
- package/src/shared/ui/navigation/Tabs.vue +37 -0
- package/src/shared/ui/navigation/index.ts +4 -0
- package/src/shared/ui/primitives/Action.vue +19 -0
- package/src/shared/ui/primitives/Block.vue +28 -0
- package/src/shared/ui/primitives/CanvasView.vue +19 -0
- package/src/shared/ui/primitives/Control.vue +24 -0
- package/src/shared/ui/primitives/ControlSelect.vue +19 -0
- package/src/shared/ui/primitives/ControlTextarea.vue +17 -0
- package/src/shared/ui/primitives/FieldLabel.vue +19 -0
- package/src/shared/ui/primitives/Form.vue +19 -0
- package/src/shared/ui/primitives/Heading.vue +29 -0
- package/src/shared/ui/primitives/Image.vue +17 -0
- package/src/shared/ui/primitives/LineBreak.vue +3 -0
- package/src/shared/ui/primitives/Link.vue +19 -0
- package/src/shared/ui/primitives/List.vue +28 -0
- package/src/shared/ui/primitives/ListItem.vue +19 -0
- package/src/shared/ui/primitives/OptionItem.vue +19 -0
- package/src/shared/ui/primitives/Text.vue +28 -0
- package/src/shared/ui/primitives/VideoView.vue +19 -0
- package/src/shared/ui/primitives/index.ts +19 -0
- package/src/shared/ui/primitives/resolveElement.ts +25 -0
- package/src/shared/ui/special/AngularAccent.vue +106 -0
- package/src/shared/ui/special/ExtensionRegistrySlotButton.vue +143 -0
- package/src/shared/ui/special/InfoRow.vue +39 -0
- package/src/shared/ui/special/LogViewer.vue +53 -0
- package/src/shared/ui/special/PageHeader.vue +23 -0
- package/src/shared/ui/special/RegistrySlotMissingCallout.vue +48 -0
- package/src/shared/ui/special/WelcomeCard.vue +32 -0
- package/src/shared/ui/special/index.ts +9 -0
- package/src/shared/utils/app-paths.ts +50 -0
- package/src/shared/utils/attachments.ts +16 -0
- package/src/shared/utils/autostart.ts +213 -0
- package/src/shared/utils/build-files.ts +439 -0
- package/src/shared/utils/build-manifest-init.ts +176 -0
- package/src/shared/utils/cloudinary.ts +67 -0
- package/src/shared/utils/cn.ts +7 -0
- package/src/shared/utils/download-stats-week.ts +165 -0
- package/src/shared/utils/entity-api-to-cache.ts +84 -0
- package/src/shared/utils/entity-build-from-api.ts +1 -0
- package/src/shared/utils/entity-display.ts +27 -0
- package/src/shared/utils/entity-map-from-api.ts +1 -0
- package/src/shared/utils/file-hash.ts +65 -0
- package/src/shared/utils/formatSize.ts +5 -0
- package/src/shared/utils/formatTime.ts +157 -0
- package/src/shared/utils/getAccountSkinRender.ts +32 -0
- package/src/shared/utils/index.ts +34 -0
- package/src/shared/utils/local-mods.ts +678 -0
- package/src/shared/utils/local-settings.ts +217 -0
- package/src/shared/utils/member-join-stats.ts +35 -0
- package/src/shared/utils/platform.ts +86 -0
- package/src/shared/utils/play-host-slug.ts +92 -0
- package/src/shared/utils/rich-content.ts +294 -0
- package/src/shared/utils/safeRequest.ts +23 -0
- package/src/shared/utils/semver.ts +81 -0
- package/src/shared/utils/serverPermissions.ts +155 -0
- package/src/shared/utils/skin-render-cache.ts +372 -0
- package/src/shared/utils/stripMarkdown.ts +45 -0
- package/src/shared/utils/transliterate.ts +74 -0
- package/src/shared/utils/updateAccountSkinRender.ts +64 -0
- package/src/shared/utils/updater.ts +218 -0
- package/src/shared/utils/uploadImage.ts +195 -0
- package/src/shared/utils/user-status.ts +9 -0
- package/src/tiptap/index.ts +7 -0
- package/tsconfig.json +13 -0
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<div :class="tabsClasses">
|
|
3
|
+
<slot />
|
|
4
|
+
</div>
|
|
5
|
+
</template>
|
|
6
|
+
|
|
7
|
+
<script setup lang="ts">
|
|
8
|
+
import { computed } from 'vue';
|
|
9
|
+
import { cn } from '../../utils/cn';
|
|
10
|
+
|
|
11
|
+
interface Props {
|
|
12
|
+
/** default: нижний бордер; pills: секции форм; rail: сайд нав как на zaklauncher.xyz */
|
|
13
|
+
variant?: 'default' | 'pills' | 'rail';
|
|
14
|
+
orientation?: 'horizontal' | 'vertical';
|
|
15
|
+
class?: string;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
const props = withDefaults(defineProps<Props>(), {
|
|
19
|
+
variant: 'default',
|
|
20
|
+
orientation: 'horizontal',
|
|
21
|
+
});
|
|
22
|
+
|
|
23
|
+
const tabsClasses = computed(() => {
|
|
24
|
+
if (props.variant === 'rail') {
|
|
25
|
+
return cn('rnt-rail-tabs', props.class);
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
const baseClasses = 'flex';
|
|
29
|
+
|
|
30
|
+
const orientationClasses = {
|
|
31
|
+
horizontal: 'gap-1 border-b border-border',
|
|
32
|
+
vertical: 'flex-col gap-1',
|
|
33
|
+
};
|
|
34
|
+
|
|
35
|
+
return cn(baseClasses, orientationClasses[props.orientation], props.class);
|
|
36
|
+
});
|
|
37
|
+
</script>
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<button ref="element" v-bind="$attrs">
|
|
3
|
+
<slot />
|
|
4
|
+
</button>
|
|
5
|
+
</template>
|
|
6
|
+
|
|
7
|
+
<script setup lang="ts">
|
|
8
|
+
import { ref } from 'vue';
|
|
9
|
+
|
|
10
|
+
defineOptions({
|
|
11
|
+
inheritAttrs: false,
|
|
12
|
+
});
|
|
13
|
+
|
|
14
|
+
const element = ref<HTMLButtonElement | null>(null);
|
|
15
|
+
|
|
16
|
+
defineExpose({
|
|
17
|
+
element,
|
|
18
|
+
});
|
|
19
|
+
</script>
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<component :is="as" ref="element" v-bind="$attrs">
|
|
3
|
+
<slot />
|
|
4
|
+
</component>
|
|
5
|
+
</template>
|
|
6
|
+
|
|
7
|
+
<script setup lang="ts">
|
|
8
|
+
import { ref } from 'vue';
|
|
9
|
+
|
|
10
|
+
defineOptions({
|
|
11
|
+
inheritAttrs: false,
|
|
12
|
+
});
|
|
13
|
+
|
|
14
|
+
withDefaults(
|
|
15
|
+
defineProps<{
|
|
16
|
+
as?: 'div' | 'section' | 'article' | 'main' | 'header' | 'footer' | 'aside';
|
|
17
|
+
}>(),
|
|
18
|
+
{
|
|
19
|
+
as: 'div',
|
|
20
|
+
},
|
|
21
|
+
);
|
|
22
|
+
|
|
23
|
+
const element = ref<HTMLElement | null>(null);
|
|
24
|
+
|
|
25
|
+
defineExpose({
|
|
26
|
+
element,
|
|
27
|
+
});
|
|
28
|
+
</script>
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<canvas ref="element" v-bind="$attrs">
|
|
3
|
+
<slot />
|
|
4
|
+
</canvas>
|
|
5
|
+
</template>
|
|
6
|
+
|
|
7
|
+
<script setup lang="ts">
|
|
8
|
+
import { ref } from 'vue';
|
|
9
|
+
|
|
10
|
+
defineOptions({
|
|
11
|
+
inheritAttrs: false,
|
|
12
|
+
});
|
|
13
|
+
|
|
14
|
+
const element = ref<HTMLCanvasElement | null>(null);
|
|
15
|
+
|
|
16
|
+
defineExpose({
|
|
17
|
+
element,
|
|
18
|
+
});
|
|
19
|
+
</script>
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<input ref="element" v-bind="$attrs" />
|
|
3
|
+
</template>
|
|
4
|
+
|
|
5
|
+
<script setup lang="ts">
|
|
6
|
+
import { ref } from 'vue';
|
|
7
|
+
|
|
8
|
+
defineOptions({
|
|
9
|
+
inheritAttrs: false,
|
|
10
|
+
});
|
|
11
|
+
|
|
12
|
+
const element = ref<HTMLInputElement | null>(null);
|
|
13
|
+
|
|
14
|
+
defineExpose({
|
|
15
|
+
element,
|
|
16
|
+
click: () => element.value?.click(),
|
|
17
|
+
get files() {
|
|
18
|
+
return element.value?.files ?? null;
|
|
19
|
+
},
|
|
20
|
+
get value() {
|
|
21
|
+
return element.value?.value;
|
|
22
|
+
},
|
|
23
|
+
});
|
|
24
|
+
</script>
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<select ref="element" v-bind="$attrs">
|
|
3
|
+
<slot />
|
|
4
|
+
</select>
|
|
5
|
+
</template>
|
|
6
|
+
|
|
7
|
+
<script setup lang="ts">
|
|
8
|
+
import { ref } from 'vue';
|
|
9
|
+
|
|
10
|
+
defineOptions({
|
|
11
|
+
inheritAttrs: false,
|
|
12
|
+
});
|
|
13
|
+
|
|
14
|
+
const element = ref<HTMLSelectElement | null>(null);
|
|
15
|
+
|
|
16
|
+
defineExpose({
|
|
17
|
+
element,
|
|
18
|
+
});
|
|
19
|
+
</script>
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<textarea ref="element" v-bind="$attrs" />
|
|
3
|
+
</template>
|
|
4
|
+
|
|
5
|
+
<script setup lang="ts">
|
|
6
|
+
import { ref } from 'vue';
|
|
7
|
+
|
|
8
|
+
defineOptions({
|
|
9
|
+
inheritAttrs: false,
|
|
10
|
+
});
|
|
11
|
+
|
|
12
|
+
const element = ref<HTMLTextAreaElement | null>(null);
|
|
13
|
+
|
|
14
|
+
defineExpose({
|
|
15
|
+
element,
|
|
16
|
+
});
|
|
17
|
+
</script>
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<label ref="element" v-bind="$attrs">
|
|
3
|
+
<slot />
|
|
4
|
+
</label>
|
|
5
|
+
</template>
|
|
6
|
+
|
|
7
|
+
<script setup lang="ts">
|
|
8
|
+
import { ref } from 'vue';
|
|
9
|
+
|
|
10
|
+
defineOptions({
|
|
11
|
+
inheritAttrs: false,
|
|
12
|
+
});
|
|
13
|
+
|
|
14
|
+
const element = ref<HTMLLabelElement | null>(null);
|
|
15
|
+
|
|
16
|
+
defineExpose({
|
|
17
|
+
element,
|
|
18
|
+
});
|
|
19
|
+
</script>
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<form ref="element" v-bind="$attrs">
|
|
3
|
+
<slot />
|
|
4
|
+
</form>
|
|
5
|
+
</template>
|
|
6
|
+
|
|
7
|
+
<script setup lang="ts">
|
|
8
|
+
import { ref } from 'vue';
|
|
9
|
+
|
|
10
|
+
defineOptions({
|
|
11
|
+
inheritAttrs: false,
|
|
12
|
+
});
|
|
13
|
+
|
|
14
|
+
const element = ref<HTMLFormElement | null>(null);
|
|
15
|
+
|
|
16
|
+
defineExpose({
|
|
17
|
+
element,
|
|
18
|
+
});
|
|
19
|
+
</script>
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<component :is="tag" ref="element" v-bind="$attrs">
|
|
3
|
+
<slot />
|
|
4
|
+
</component>
|
|
5
|
+
</template>
|
|
6
|
+
|
|
7
|
+
<script setup lang="ts">
|
|
8
|
+
import { computed, ref } from 'vue';
|
|
9
|
+
|
|
10
|
+
defineOptions({
|
|
11
|
+
inheritAttrs: false,
|
|
12
|
+
});
|
|
13
|
+
|
|
14
|
+
const props = withDefaults(
|
|
15
|
+
defineProps<{
|
|
16
|
+
level?: 1 | 2 | 3 | 4 | 5 | 6;
|
|
17
|
+
}>(),
|
|
18
|
+
{
|
|
19
|
+
level: 2,
|
|
20
|
+
},
|
|
21
|
+
);
|
|
22
|
+
|
|
23
|
+
const element = ref<HTMLHeadingElement | null>(null);
|
|
24
|
+
const tag = computed(() => `h${props.level}`);
|
|
25
|
+
|
|
26
|
+
defineExpose({
|
|
27
|
+
element,
|
|
28
|
+
});
|
|
29
|
+
</script>
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<img ref="element" v-bind="$attrs" />
|
|
3
|
+
</template>
|
|
4
|
+
|
|
5
|
+
<script setup lang="ts">
|
|
6
|
+
import { ref } from 'vue';
|
|
7
|
+
|
|
8
|
+
defineOptions({
|
|
9
|
+
inheritAttrs: false,
|
|
10
|
+
});
|
|
11
|
+
|
|
12
|
+
const element = ref<HTMLImageElement | null>(null);
|
|
13
|
+
|
|
14
|
+
defineExpose({
|
|
15
|
+
element,
|
|
16
|
+
});
|
|
17
|
+
</script>
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<a ref="element" v-bind="$attrs">
|
|
3
|
+
<slot />
|
|
4
|
+
</a>
|
|
5
|
+
</template>
|
|
6
|
+
|
|
7
|
+
<script setup lang="ts">
|
|
8
|
+
import { ref } from 'vue';
|
|
9
|
+
|
|
10
|
+
defineOptions({
|
|
11
|
+
inheritAttrs: false,
|
|
12
|
+
});
|
|
13
|
+
|
|
14
|
+
const element = ref<HTMLAnchorElement | null>(null);
|
|
15
|
+
|
|
16
|
+
defineExpose({
|
|
17
|
+
element,
|
|
18
|
+
});
|
|
19
|
+
</script>
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<component :is="ordered ? 'ol' : 'ul'" ref="element" v-bind="$attrs">
|
|
3
|
+
<slot />
|
|
4
|
+
</component>
|
|
5
|
+
</template>
|
|
6
|
+
|
|
7
|
+
<script setup lang="ts">
|
|
8
|
+
import { ref } from 'vue';
|
|
9
|
+
|
|
10
|
+
defineOptions({
|
|
11
|
+
inheritAttrs: false,
|
|
12
|
+
});
|
|
13
|
+
|
|
14
|
+
withDefaults(
|
|
15
|
+
defineProps<{
|
|
16
|
+
ordered?: boolean;
|
|
17
|
+
}>(),
|
|
18
|
+
{
|
|
19
|
+
ordered: false,
|
|
20
|
+
},
|
|
21
|
+
);
|
|
22
|
+
|
|
23
|
+
const element = ref<HTMLUListElement | HTMLOListElement | null>(null);
|
|
24
|
+
|
|
25
|
+
defineExpose({
|
|
26
|
+
element,
|
|
27
|
+
});
|
|
28
|
+
</script>
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<li ref="element" v-bind="$attrs">
|
|
3
|
+
<slot />
|
|
4
|
+
</li>
|
|
5
|
+
</template>
|
|
6
|
+
|
|
7
|
+
<script setup lang="ts">
|
|
8
|
+
import { ref } from 'vue';
|
|
9
|
+
|
|
10
|
+
defineOptions({
|
|
11
|
+
inheritAttrs: false,
|
|
12
|
+
});
|
|
13
|
+
|
|
14
|
+
const element = ref<HTMLLIElement | null>(null);
|
|
15
|
+
|
|
16
|
+
defineExpose({
|
|
17
|
+
element,
|
|
18
|
+
});
|
|
19
|
+
</script>
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<option ref="element" v-bind="$attrs">
|
|
3
|
+
<slot />
|
|
4
|
+
</option>
|
|
5
|
+
</template>
|
|
6
|
+
|
|
7
|
+
<script setup lang="ts">
|
|
8
|
+
import { ref } from 'vue';
|
|
9
|
+
|
|
10
|
+
defineOptions({
|
|
11
|
+
inheritAttrs: false,
|
|
12
|
+
});
|
|
13
|
+
|
|
14
|
+
const element = ref<HTMLOptionElement | null>(null);
|
|
15
|
+
|
|
16
|
+
defineExpose({
|
|
17
|
+
element,
|
|
18
|
+
});
|
|
19
|
+
</script>
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<component :is="as" ref="element" v-bind="$attrs">
|
|
3
|
+
<slot />
|
|
4
|
+
</component>
|
|
5
|
+
</template>
|
|
6
|
+
|
|
7
|
+
<script setup lang="ts">
|
|
8
|
+
import { ref } from 'vue';
|
|
9
|
+
|
|
10
|
+
defineOptions({
|
|
11
|
+
inheritAttrs: false,
|
|
12
|
+
});
|
|
13
|
+
|
|
14
|
+
withDefaults(
|
|
15
|
+
defineProps<{
|
|
16
|
+
as?: 'p' | 'span' | 'strong' | 'code';
|
|
17
|
+
}>(),
|
|
18
|
+
{
|
|
19
|
+
as: 'p',
|
|
20
|
+
},
|
|
21
|
+
);
|
|
22
|
+
|
|
23
|
+
const element = ref<HTMLElement | null>(null);
|
|
24
|
+
|
|
25
|
+
defineExpose({
|
|
26
|
+
element,
|
|
27
|
+
});
|
|
28
|
+
</script>
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<video ref="element" v-bind="$attrs">
|
|
3
|
+
<slot />
|
|
4
|
+
</video>
|
|
5
|
+
</template>
|
|
6
|
+
|
|
7
|
+
<script setup lang="ts">
|
|
8
|
+
import { ref } from 'vue';
|
|
9
|
+
|
|
10
|
+
defineOptions({
|
|
11
|
+
inheritAttrs: false,
|
|
12
|
+
});
|
|
13
|
+
|
|
14
|
+
const element = ref<HTMLVideoElement | null>(null);
|
|
15
|
+
|
|
16
|
+
defineExpose({
|
|
17
|
+
element,
|
|
18
|
+
});
|
|
19
|
+
</script>
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
export { default as Action } from './Action.vue';
|
|
2
|
+
export { default as Block } from './Block.vue';
|
|
3
|
+
export { default as CanvasView } from './CanvasView.vue';
|
|
4
|
+
export { default as Control } from './Control.vue';
|
|
5
|
+
export { default as ControlSelect } from './ControlSelect.vue';
|
|
6
|
+
export { default as ControlTextarea } from './ControlTextarea.vue';
|
|
7
|
+
export { default as FieldLabel } from './FieldLabel.vue';
|
|
8
|
+
export { default as Form } from './Form.vue';
|
|
9
|
+
export { default as Heading } from './Heading.vue';
|
|
10
|
+
export { default as Image } from './Image.vue';
|
|
11
|
+
export { default as Link } from './Link.vue';
|
|
12
|
+
export { default as LineBreak } from './LineBreak.vue';
|
|
13
|
+
export { default as List } from './List.vue';
|
|
14
|
+
export { default as ListItem } from './ListItem.vue';
|
|
15
|
+
export { default as OptionItem } from './OptionItem.vue';
|
|
16
|
+
export { default as Text } from './Text.vue';
|
|
17
|
+
export { default as VideoView } from './VideoView.vue';
|
|
18
|
+
export { resolveElement } from './resolveElement';
|
|
19
|
+
export type { PrimitiveElementRef } from './resolveElement';
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
export type PrimitiveElementRef<T extends Element> =
|
|
2
|
+
| T
|
|
3
|
+
| { element?: T | null }
|
|
4
|
+
| null
|
|
5
|
+
| undefined;
|
|
6
|
+
|
|
7
|
+
export const resolveElement = <T extends Element>(
|
|
8
|
+
value: PrimitiveElementRef<T> | PrimitiveElementRef<T>[],
|
|
9
|
+
): T | null => {
|
|
10
|
+
const candidate = Array.isArray(value) ? value[0] : value;
|
|
11
|
+
|
|
12
|
+
if (!candidate) return null;
|
|
13
|
+
if (typeof Element !== 'undefined' && candidate instanceof Element)
|
|
14
|
+
return candidate;
|
|
15
|
+
|
|
16
|
+
if (
|
|
17
|
+
typeof candidate === 'object' &&
|
|
18
|
+
candidate !== null &&
|
|
19
|
+
'element' in candidate
|
|
20
|
+
) {
|
|
21
|
+
return (candidate as { element?: T | null }).element ?? null;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
return null;
|
|
25
|
+
};
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<div
|
|
3
|
+
:class="accentClasses"
|
|
4
|
+
:style="accentStyle"
|
|
5
|
+
/>
|
|
6
|
+
</template>
|
|
7
|
+
|
|
8
|
+
<script setup lang="ts">
|
|
9
|
+
import { computed } from 'vue';
|
|
10
|
+
import { cn } from '../../utils/cn';
|
|
11
|
+
|
|
12
|
+
interface Props {
|
|
13
|
+
variant?: 'gradient' | 'solid';
|
|
14
|
+
position?: 'left' | 'right' | 'top' | 'bottom' | 'inset' | 'top-right';
|
|
15
|
+
size?: 'sm' | 'md' | 'lg';
|
|
16
|
+
color?: 'indigo' | 'green' | 'purple';
|
|
17
|
+
gradient?: 'indigo-to-transparent' | 'white-to-transparent' | 'black-overlay';
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
const props = withDefaults(defineProps<Props>(), {
|
|
21
|
+
variant: 'gradient',
|
|
22
|
+
position: 'left',
|
|
23
|
+
size: 'md',
|
|
24
|
+
color: 'indigo',
|
|
25
|
+
gradient: 'indigo-to-transparent',
|
|
26
|
+
});
|
|
27
|
+
|
|
28
|
+
const sizeMap = {
|
|
29
|
+
sm: { width: 'w-24', height: 'h-full' },
|
|
30
|
+
md: { width: 'w-32', height: 'h-full' },
|
|
31
|
+
lg: { width: 'w-40', height: 'h-full' },
|
|
32
|
+
'top-right': { width: 'w-24', height: 'h-24' },
|
|
33
|
+
inset: { width: 'w-full', height: 'h-full' },
|
|
34
|
+
};
|
|
35
|
+
|
|
36
|
+
const colorMap = {
|
|
37
|
+
indigo: 'from-primary/12 to-transparent',
|
|
38
|
+
green: 'from-green-500/10 to-transparent',
|
|
39
|
+
purple: 'from-accent-secondary/12 to-transparent',
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
const gradientMap = {
|
|
43
|
+
'indigo-to-transparent': 'from-primary/12 to-transparent',
|
|
44
|
+
'white-to-transparent': 'from-white/5 to-transparent',
|
|
45
|
+
'black-overlay': 'bg-foreground/20',
|
|
46
|
+
};
|
|
47
|
+
|
|
48
|
+
const clipPathMap = {
|
|
49
|
+
left: 'polygon(0 0, 100% 0, 85% 100%, 0 100%)',
|
|
50
|
+
right: 'polygon(15% 0, 100% 0, 100% 100%, 0 100%)',
|
|
51
|
+
top: 'polygon(0 0, 100% 0, 100% 85%, 0 100%)',
|
|
52
|
+
bottom: 'polygon(0 15%, 100% 0, 100% 100%, 0 100%)',
|
|
53
|
+
inset: 'none',
|
|
54
|
+
'top-right': 'polygon(30% 0, 100% 0, 100% 70%)',
|
|
55
|
+
};
|
|
56
|
+
|
|
57
|
+
const gradientDirectionMap = {
|
|
58
|
+
left: 'bg-gradient-to-r',
|
|
59
|
+
right: 'bg-gradient-to-l',
|
|
60
|
+
top: 'bg-gradient-to-b',
|
|
61
|
+
bottom: 'bg-gradient-to-t',
|
|
62
|
+
};
|
|
63
|
+
|
|
64
|
+
const accentClasses = computed(() => {
|
|
65
|
+
const baseClasses = 'absolute';
|
|
66
|
+
const positionClasses = {
|
|
67
|
+
left: 'left-0 top-0',
|
|
68
|
+
right: 'right-0 top-0',
|
|
69
|
+
top: 'top-0 left-0 w-full',
|
|
70
|
+
bottom: 'bottom-0 left-0 w-full',
|
|
71
|
+
inset: 'inset-0',
|
|
72
|
+
'top-right': 'top-0 right-0',
|
|
73
|
+
};
|
|
74
|
+
|
|
75
|
+
const variantClasses = {
|
|
76
|
+
gradient: props.gradient === 'black-overlay'
|
|
77
|
+
? gradientMap[props.gradient]
|
|
78
|
+
: props.gradient && gradientMap[props.gradient]
|
|
79
|
+
? (() => {
|
|
80
|
+
const dir = props.position === 'top-right' ? 'l' : props.position === 'inset' ? 'r' : gradientDirectionMap[props.position as keyof typeof gradientDirectionMap]?.split('-')[2] || 'r';
|
|
81
|
+
return `bg-gradient-to-${dir} ${gradientMap[props.gradient]}`;
|
|
82
|
+
})()
|
|
83
|
+
: props.position in gradientDirectionMap
|
|
84
|
+
? `${gradientDirectionMap[props.position as keyof typeof gradientDirectionMap]} ${colorMap[props.color]}`
|
|
85
|
+
: `bg-gradient-to-r ${colorMap[props.color]}`,
|
|
86
|
+
solid: `bg-${props.color}-500/10`,
|
|
87
|
+
};
|
|
88
|
+
|
|
89
|
+
const size = props.position === 'inset' || props.position === 'top-right'
|
|
90
|
+
? sizeMap[props.position]
|
|
91
|
+
: sizeMap[props.size];
|
|
92
|
+
|
|
93
|
+
return cn(
|
|
94
|
+
baseClasses,
|
|
95
|
+
positionClasses[props.position],
|
|
96
|
+
size.width,
|
|
97
|
+
size.height,
|
|
98
|
+
variantClasses[props.variant]
|
|
99
|
+
);
|
|
100
|
+
});
|
|
101
|
+
|
|
102
|
+
const accentStyle = computed(() => {
|
|
103
|
+
return { 'clip-path': clipPathMap[props.position] };
|
|
104
|
+
});
|
|
105
|
+
</script>
|
|
106
|
+
|