@coffic/cosy-ui 0.7.4 → 0.8.6
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/dist/app.css +1 -1
- package/dist/index-astro.ts +86 -0
- package/dist/index-collection.ts +104 -0
- package/dist/index-vue.ts +33 -0
- package/dist/src-astro/alert/Alert.astro +100 -0
- package/dist/src-astro/alert/EAlertBasic.astro +11 -0
- package/dist/src-astro/alert/EAlertBasicContainer.astro +11 -0
- package/dist/src-astro/alert/EAlertCustomStyle.astro +16 -0
- package/dist/src-astro/alert/EAlertCustomStyleContainer.astro +11 -0
- package/dist/src-astro/alert/EAlertError.astro +6 -0
- package/dist/src-astro/alert/EAlertInfo.astro +6 -0
- package/dist/src-astro/alert/EAlertSuccess.astro +6 -0
- package/dist/src-astro/alert/EAlertTypesContainer.astro +43 -0
- package/dist/src-astro/alert/EAlertWarning.astro +6 -0
- package/dist/src-astro/alert/EAlertWithTitle.astro +12 -0
- package/dist/src-astro/alert/EAlertWithTitleContainer.astro +11 -0
- package/dist/src-astro/alert/index.ts +16 -0
- package/dist/src-astro/article/Article.astro +139 -0
- package/dist/src-astro/article/ArticleBasic.astro +35 -0
- package/dist/src-astro/article/index.ts +11 -0
- package/dist/src-astro/assets/iconData.ts +117 -0
- package/dist/src-astro/banner/Banner.astro +174 -0
- package/dist/src-astro/banner/BannerAllAnimations.astro +10 -0
- package/dist/src-astro/banner/BannerBasic.astro +5 -0
- package/dist/src-astro/banner/BannerCustomStyle.astro +8 -0
- package/dist/src-astro/banner/BannerDanger.astro +5 -0
- package/dist/src-astro/banner/BannerFadeIn.astro +5 -0
- package/dist/src-astro/banner/BannerInfo.astro +5 -0
- package/dist/src-astro/banner/BannerPrimary.astro +5 -0
- package/dist/src-astro/banner/BannerSecondary.astro +5 -0
- package/dist/src-astro/banner/BannerSlideUp.astro +5 -0
- package/dist/src-astro/banner/BannerSuccess.astro +5 -0
- package/dist/src-astro/banner/BannerWarning.astro +5 -0
- package/dist/src-astro/banner/index.ts +54 -0
- package/dist/src-astro/button/Button.astro +192 -0
- package/dist/src-astro/button/ButtonBasic.astro +18 -0
- package/dist/src-astro/button/ButtonBasicContainer.astro +11 -0
- package/dist/src-astro/button/ButtonIconBoth.astro +9 -0
- package/dist/src-astro/button/ButtonIconLeft.astro +8 -0
- package/dist/src-astro/button/ButtonIconRight.astro +8 -0
- package/dist/src-astro/button/ButtonLinkContainer.astro +19 -0
- package/dist/src-astro/button/ButtonLinkExternal.astro +8 -0
- package/dist/src-astro/button/ButtonShapes.astro +23 -0
- package/dist/src-astro/button/ButtonShapesContainer.astro +29 -0
- package/dist/src-astro/button/ButtonSizes.astro +15 -0
- package/dist/src-astro/button/ButtonSizesContainer.astro +11 -0
- package/dist/src-astro/button/ButtonStates.astro +12 -0
- package/dist/src-astro/button/ButtonStatesContainer.astro +11 -0
- package/dist/src-astro/button/ButtonVariants.astro +14 -0
- package/dist/src-astro/button/ButtonVariantsContainer.astro +73 -0
- package/dist/src-astro/button/ButtonWidth.astro +8 -0
- package/dist/src-astro/button/ButtonWidthContainer.astro +19 -0
- package/dist/src-astro/button/ButtonWithIcons.astro +25 -0
- package/dist/src-astro/button/ButtonWithIconsContainer.astro +29 -0
- package/dist/src-astro/button/index_astro.ts +60 -0
- package/dist/src-astro/card/Card.astro +151 -0
- package/dist/src-astro/card/CardCourse.astro +34 -0
- package/dist/src-astro/card/ECardBasic.astro +13 -0
- package/dist/src-astro/card/ECardBasicContainer.astro +11 -0
- package/dist/src-astro/card/ECardClickable.astro +16 -0
- package/dist/src-astro/card/ECardClickableContainer.astro +11 -0
- package/dist/src-astro/card/ECardCompact.astro +13 -0
- package/dist/src-astro/card/ECardCompactContainer.astro +11 -0
- package/dist/src-astro/card/ECardCustomStyle.astro +17 -0
- package/dist/src-astro/card/ECardCustomStyleContainer.astro +11 -0
- package/dist/src-astro/card/ECardWithImage.astro +16 -0
- package/dist/src-astro/card/ECardWithImageContainer.astro +11 -0
- package/dist/src-astro/card/ECardWithSubtitle.astro +13 -0
- package/dist/src-astro/card/ECardWithSubtitleContainer.astro +11 -0
- package/dist/src-astro/card/index.ts +27 -0
- package/dist/src-astro/code-block/CodeBlock.astro +155 -0
- package/dist/src-astro/code-block/index.ts +1 -0
- package/dist/src-astro/code-container/CodeContainer.astro +280 -0
- package/dist/src-astro/code-container/ECodeContainerBasic.astro +19 -0
- package/dist/src-astro/code-container/ECodeContainerMultiple.astro +49 -0
- package/dist/src-astro/code-container/index.ts +14 -0
- package/dist/src-astro/code-example/CodeExample.astro +185 -0
- package/dist/src-astro/code-example/index.ts +1 -0
- package/dist/src-astro/contact/Contact.astro +321 -0
- package/dist/src-astro/contact/EContactBasic.astro +15 -0
- package/dist/src-astro/contact/EContactBasicContainer.astro +11 -0
- package/dist/src-astro/contact/EContactCompact.astro +11 -0
- package/dist/src-astro/contact/EContactCompactContainer.astro +11 -0
- package/dist/src-astro/contact/EContactCustomStyle.astro +21 -0
- package/dist/src-astro/contact/EContactCustomStyleContainer.astro +11 -0
- package/dist/src-astro/contact/EContactSocial.astro +20 -0
- package/dist/src-astro/contact/EContactSocialContainer.astro +11 -0
- package/dist/src-astro/contact/EContactWithTitle.astro +17 -0
- package/dist/src-astro/contact/EContactWithTitleContainer.astro +11 -0
- package/dist/src-astro/contact/index.ts +21 -0
- package/dist/src-astro/container/Container.astro +211 -0
- package/dist/src-astro/container/EContainerBasic.astro +15 -0
- package/dist/src-astro/container/EContainerBasicContainer.astro +11 -0
- package/dist/src-astro/container/EContainerFlexBetween.astro +23 -0
- package/dist/src-astro/container/EContainerFlexCenter.astro +30 -0
- package/dist/src-astro/container/EContainerFlexColumn.astro +23 -0
- package/dist/src-astro/container/EContainerFlexContainer.astro +34 -0
- package/dist/src-astro/container/EContainerFlexRow.astro +23 -0
- package/dist/src-astro/container/EContainerPadding.astro +32 -0
- package/dist/src-astro/container/EContainerPaddingContainer.astro +11 -0
- package/dist/src-astro/container/EContainerSizes.astro +36 -0
- package/dist/src-astro/container/EContainerSizesContainer.astro +11 -0
- package/dist/src-astro/container/index.ts +16 -0
- package/dist/src-astro/cosy.ts +6 -0
- package/dist/src-astro/database/BaseDB.ts +264 -0
- package/dist/src-astro/database/BlogDB.ts +198 -0
- package/dist/src-astro/database/CourseDB.ts +90 -0
- package/dist/src-astro/database/ExperimentDB.ts +106 -0
- package/dist/src-astro/database/LessonDB.ts +106 -0
- package/dist/src-astro/database/MetaDB.ts +74 -0
- package/dist/src-astro/entities/BaseDoc.ts +207 -0
- package/dist/src-astro/entities/BlogDoc.ts +107 -0
- package/dist/src-astro/entities/CourseDoc.ts +101 -0
- package/dist/src-astro/entities/ExperimentDoc.ts +119 -0
- package/dist/src-astro/entities/Feature.ts +53 -0
- package/dist/src-astro/entities/LessonDoc.ts +153 -0
- package/dist/src-astro/entities/MetaDoc.ts +93 -0
- package/dist/src-astro/entities/SidebarItem.ts +89 -0
- package/dist/src-astro/entities/Tag.ts +42 -0
- package/dist/src-astro/env.d.ts +42 -0
- package/dist/src-astro/errors/403.astro +135 -0
- package/dist/src-astro/errors/404.astro +124 -0
- package/dist/src-astro/errors/404Basic.astro +7 -0
- package/dist/src-astro/errors/500.astro +165 -0
- package/dist/src-astro/errors/503.astro +189 -0
- package/dist/src-astro/errors/E403Basic.astro +11 -0
- package/dist/src-astro/errors/E403BasicContainer.astro +20 -0
- package/dist/src-astro/errors/E404Basic.astro +11 -0
- package/dist/src-astro/errors/E404BasicContainer.astro +20 -0
- package/dist/src-astro/errors/E404WithDebug.astro +18 -0
- package/dist/src-astro/errors/E500Basic.astro +11 -0
- package/dist/src-astro/errors/E500BasicContainer.astro +20 -0
- package/dist/src-astro/errors/E503Maintenance.astro +20 -0
- package/dist/src-astro/errors/E503MaintenanceContainer.astro +21 -0
- package/dist/src-astro/errors/EErrorPageCustomStyle.astro +21 -0
- package/dist/src-astro/errors/EErrorPageCustomStyleContainer.astro +21 -0
- package/dist/src-astro/errors/EErrorPageShowcase.astro +68 -0
- package/dist/src-astro/errors/EErrorPageShowcaseContainer.astro +21 -0
- package/dist/src-astro/errors/ErrorPage.astro +119 -0
- package/dist/src-astro/errors/index.ts +77 -0
- package/dist/src-astro/flex/Flex.astro +138 -0
- package/dist/src-astro/flex/FlexBasic.astro +26 -0
- package/dist/src-astro/flex/index.ts +11 -0
- package/dist/src-astro/footer/EFooterBasic.astro +18 -0
- package/dist/src-astro/footer/EFooterBasicContainer.astro +11 -0
- package/dist/src-astro/footer/EFooterComplete.astro +50 -0
- package/dist/src-astro/footer/EFooterCompleteContainer.astro +11 -0
- package/dist/src-astro/footer/EFooterFeaturesContainer.astro +40 -0
- package/dist/src-astro/footer/EFooterWithLogo.astro +28 -0
- package/dist/src-astro/footer/EFooterWithLogoContainer.astro +11 -0
- package/dist/src-astro/footer/EFooterWithNavigation.astro +24 -0
- package/dist/src-astro/footer/EFooterWithNavigationContainer.astro +11 -0
- package/dist/src-astro/footer/EFooterWithProducts.astro +24 -0
- package/dist/src-astro/footer/EFooterWithProductsContainer.astro +11 -0
- package/dist/src-astro/footer/EFooterWithSocial.astro +24 -0
- package/dist/src-astro/footer/EFooterWithSocialContainer.astro +11 -0
- package/dist/src-astro/footer/Footer.astro +351 -0
- package/dist/src-astro/footer/FooterSection.astro +49 -0
- package/dist/src-astro/footer/index.ts +31 -0
- package/dist/src-astro/grid/Grid.astro +190 -0
- package/dist/src-astro/grid/GridBasic.astro +21 -0
- package/dist/src-astro/grid/index.ts +11 -0
- package/dist/src-astro/header/Header.astro +209 -0
- package/dist/src-astro/header/HeaderBasic.astro +19 -0
- package/dist/src-astro/header/HeaderCustomNavbarCenter.astro +28 -0
- package/dist/src-astro/header/HeaderCustomNavbarEnd.astro +25 -0
- package/dist/src-astro/header/HeaderCustomNavbarStart.astro +27 -0
- package/dist/src-astro/header/HeaderCustomPosition.astro +34 -0
- package/dist/src-astro/header/HeaderWithNavigation.astro +27 -0
- package/dist/src-astro/header/index.ts +40 -0
- package/dist/src-astro/heading/Heading.astro +245 -0
- package/dist/src-astro/heading/index.ts +11 -0
- package/dist/src-astro/hero/Hero.astro +381 -0
- package/dist/src-astro/hero/HeroAlignCenter.astro +13 -0
- package/dist/src-astro/hero/HeroAlignContainer.astro +27 -0
- package/dist/src-astro/hero/HeroAlignLeft.astro +13 -0
- package/dist/src-astro/hero/HeroAlignRight.astro +13 -0
- package/dist/src-astro/hero/HeroBackgroundContainer.astro +18 -0
- package/dist/src-astro/hero/HeroBackgroundImage.astro +16 -0
- package/dist/src-astro/hero/HeroBackgroundImageContainer.astro +11 -0
- package/dist/src-astro/hero/HeroBasic.astro +12 -0
- package/dist/src-astro/hero/HeroBasicContainer.astro +11 -0
- package/dist/src-astro/hero/HeroGradientBackground.astro +10 -0
- package/dist/src-astro/hero/HeroPlainBackground.astro +10 -0
- package/dist/src-astro/hero/HeroWithButton.astro +15 -0
- package/dist/src-astro/hero/HeroWithButtonContainer.astro +11 -0
- package/dist/src-astro/hero/HeroWithImage.astro +16 -0
- package/dist/src-astro/hero/HeroWithImageContainer.astro +11 -0
- package/dist/src-astro/hero/index.ts +39 -0
- package/dist/src-astro/icons/AlertTriangle.astro +28 -0
- package/dist/src-astro/icons/AstroIcon.astro +62 -0
- package/dist/src-astro/icons/CalendarIcon.astro +28 -0
- package/dist/src-astro/icons/CheckCircle.astro +27 -0
- package/dist/src-astro/icons/CheckIcon.astro +31 -0
- package/dist/src-astro/icons/ChevronDownIcon.astro +28 -0
- package/dist/src-astro/icons/ClipboardIcon.astro +31 -0
- package/dist/src-astro/icons/CloseIcon.astro +31 -0
- package/dist/src-astro/icons/ErrorIcon.astro +28 -0
- package/dist/src-astro/icons/GithubIcon.astro +25 -0
- package/dist/src-astro/icons/InboxArchive.astro +27 -0
- package/dist/src-astro/icons/InfoCircle.astro +28 -0
- package/dist/src-astro/icons/InfoIcon.astro +30 -0
- package/dist/src-astro/icons/LinkIcon.astro +31 -0
- package/dist/src-astro/icons/LinkedinIcon.astro +27 -0
- package/dist/src-astro/icons/MenuIcon.astro +31 -0
- package/dist/src-astro/icons/SearchIcon.astro +27 -0
- package/dist/src-astro/icons/SettingsIcon.astro +18 -0
- package/dist/src-astro/icons/SocialIcon.astro +100 -0
- package/dist/src-astro/icons/SuccessIcon.astro +28 -0
- package/dist/src-astro/icons/SunCloudyIcon.astro +27 -0
- package/dist/src-astro/icons/TwitterIcon.astro +28 -0
- package/dist/src-astro/icons/UserIcon.astro +28 -0
- package/dist/src-astro/icons/WarningIcon.astro +31 -0
- package/dist/src-astro/icons/XCircle.astro +28 -0
- package/dist/src-astro/icons/index.ts +25 -0
- package/dist/src-astro/image/Image.astro +338 -0
- package/dist/src-astro/image/ImageBasic.astro +0 -0
- package/dist/src-astro/image/ImageEffects.astro +34 -0
- package/dist/src-astro/image/ImageLoading.astro +37 -0
- package/dist/src-astro/image/index.ts +17 -0
- package/dist/src-astro/integration.ts +14 -0
- package/dist/src-astro/language-switcher/LanguageSwitcher.astro +64 -0
- package/dist/src-astro/language-switcher/LanguageSwitcherBasic.astro +7 -0
- package/dist/src-astro/language-switcher/index.ts +11 -0
- package/dist/src-astro/layout-app/AppLayout.astro +267 -0
- package/dist/src-astro/layout-app/AppLayoutBasic.astro +54 -0
- package/dist/src-astro/layout-app/index.ts +11 -0
- package/dist/src-astro/layout-basic/BaseLayout.astro +103 -0
- package/dist/src-astro/layout-basic/BaseLayoutBasic.astro +17 -0
- package/dist/src-astro/layout-basic/index.ts +11 -0
- package/dist/src-astro/layout-dashboard/DashboardLayout.astro +686 -0
- package/dist/src-astro/layout-dashboard/DashboardLayoutBasic.astro +51 -0
- package/dist/src-astro/layout-dashboard/index.ts +11 -0
- package/dist/src-astro/link/Link.astro +160 -0
- package/dist/src-astro/link/LinkAnimations.astro +29 -0
- package/dist/src-astro/link/LinkBasic.astro +17 -0
- package/dist/src-astro/link/LinkVariants.astro +20 -0
- package/dist/src-astro/link/index.ts +17 -0
- package/dist/src-astro/main/Main.astro +155 -0
- package/dist/src-astro/main/index.ts +1 -0
- package/dist/src-astro/modal/Modal.astro +126 -0
- package/dist/src-astro/modal/index.ts +1 -0
- package/dist/src-astro/module/Module.astro +68 -0
- package/dist/src-astro/module/ModuleBasic.astro +12 -0
- package/dist/src-astro/module/ModuleCustom.astro +14 -0
- package/dist/src-astro/module/ModuleGrid.astro +27 -0
- package/dist/src-astro/module/index.ts +17 -0
- package/dist/src-astro/nav-item/NavItems.astro +44 -0
- package/dist/src-astro/nav-item/NavItemsBasic.astro +30 -0
- package/dist/src-astro/nav-item/index.ts +11 -0
- package/dist/src-astro/nav-section/NavSection.astro +41 -0
- package/dist/src-astro/nav-section/NavSectionBasic.astro +12 -0
- package/dist/src-astro/nav-section/index.ts +11 -0
- package/dist/src-astro/products/ProductCard.astro +374 -0
- package/dist/src-astro/products/Products.astro +200 -0
- package/dist/src-astro/products/index.ts +2 -0
- package/dist/src-astro/section/Section.astro +150 -0
- package/dist/src-astro/section/index.ts +1 -0
- package/dist/src-astro/sidebar/Sidebar.astro +192 -0
- package/dist/src-astro/sidebar/SidebarBasic.astro +0 -0
- package/dist/src-astro/sidebar/index.ts +11 -0
- package/dist/src-astro/sidebar-nav/SidebarNav.astro +136 -0
- package/dist/src-astro/sidebar-nav/SidebarNavBasic.astro +32 -0
- package/dist/src-astro/sidebar-nav/index.ts +11 -0
- package/dist/src-astro/speak/Speak.astro +73 -0
- package/dist/src-astro/speak/SpeakBasic.astro +13 -0
- package/dist/src-astro/speak/SpeakGrid.astro +30 -0
- package/dist/src-astro/speak/index.ts +14 -0
- package/dist/src-astro/stack/Stack.astro +153 -0
- package/dist/src-astro/stack/StackBasic.astro +21 -0
- package/dist/src-astro/stack/index.ts +11 -0
- package/dist/src-astro/team-member/TeamMember.astro +137 -0
- package/dist/src-astro/team-member/TeamMemberBasic.astro +25 -0
- package/dist/src-astro/team-member/TeamMemberCustomStyle.astro +26 -0
- package/dist/src-astro/team-member/TeamMemberGroup.astro +60 -0
- package/dist/src-astro/team-member/TeamMemberWithSocial.astro +30 -0
- package/dist/src-astro/team-member/TeamMembers.astro +96 -0
- package/dist/src-astro/team-member/index.ts +30 -0
- package/dist/src-astro/text/Text.astro +189 -0
- package/dist/src-astro/text/TextBasic.astro +12 -0
- package/dist/src-astro/text/TextSizes.astro +11 -0
- package/dist/src-astro/text/index.ts +11 -0
- package/dist/src-astro/theme-switcher/ThemeItem.astro +45 -0
- package/dist/src-astro/theme-switcher/ThemeSwitcher.astro +121 -0
- package/dist/src-astro/theme-switcher/ThemeSwitcherBasic.astro +7 -0
- package/dist/src-astro/theme-switcher/index.ts +11 -0
- package/dist/src-astro/toc/TableOfContents.astro +438 -0
- package/dist/src-astro/toc/TableOfContentsBasic.astro +25 -0
- package/dist/src-astro/toc/index.ts +11 -0
- package/dist/src-astro/types/article.ts +22 -0
- package/dist/src-astro/types/footer.ts +129 -0
- package/dist/src-astro/types/header.ts +87 -0
- package/dist/src-astro/types/heading.ts +13 -0
- package/dist/src-astro/types/image.ts +16 -0
- package/dist/src-astro/types/layout.ts +71 -0
- package/dist/src-astro/types/main.ts +86 -0
- package/dist/src-astro/types/menu.ts +24 -0
- package/dist/src-astro/types/meta.ts +55 -0
- package/dist/src-astro/types/product.ts +10 -0
- package/dist/src-astro/types/sidebar.ts +59 -0
- package/dist/src-astro/types/static-path.ts +8 -0
- package/dist/src-astro/utils/component.ts +42 -0
- package/dist/src-astro/utils/i18n.ts +83 -0
- package/dist/src-astro/utils/image.ts +128 -0
- package/dist/src-astro/utils/lang_entry.ts +240 -0
- package/dist/src-astro/utils/lang_package.ts +150 -0
- package/dist/src-astro/utils/language.ts +121 -0
- package/dist/src-astro/utils/link.ts +250 -0
- package/dist/src-astro/utils/logger.ts +136 -0
- package/dist/src-astro/utils/path.ts +59 -0
- package/dist/src-astro/utils/social.ts +90 -0
- package/dist/src-astro/utils/theme.ts +122 -0
- package/dist/src-astro/utils/url.ts +17 -0
- package/dist/vue/SmartLink.vue +21 -0
- package/dist/vue/TagList.vue +23 -0
- package/dist/vue/alert-dialog-vue/AlertDialog.vue +130 -0
- package/dist/vue/alert-dialog-vue/Basic.vue +38 -0
- package/dist/vue/alert-dialog-vue/Multilang.vue +58 -0
- package/dist/vue/alert-dialog-vue/index.ts +20 -0
- package/dist/vue/banner-box-vue/BannerBox.vue +336 -0
- package/dist/vue/banner-box-vue/DownloadButton.vue +244 -0
- package/dist/vue/banner-box-vue/ExampleBasic.vue +34 -0
- package/dist/vue/banner-box-vue/ExampleCustomBg.vue +34 -0
- package/dist/vue/banner-box-vue/ExampleDisplayModeAlways.vue +36 -0
- package/dist/vue/banner-box-vue/ExampleDisplayModeHover.vue +36 -0
- package/dist/vue/banner-box-vue/ExampleDisplayModeNever.vue +36 -0
- package/dist/vue/banner-box-vue/ExampleImageExport.vue +42 -0
- package/dist/vue/banner-box-vue/ExampleSizePreset.vue +39 -0
- package/dist/vue/banner-box-vue/FeatureCard.vue +205 -0
- package/dist/vue/banner-box-vue/SmartBanner.vue +48 -0
- package/dist/vue/banner-box-vue/bgStyles.ts +55 -0
- package/dist/vue/banner-box-vue/index.ts +48 -0
- package/dist/vue/banner-box-vue/sizePresets.ts +23 -0
- package/dist/vue/blog-vue/Basic.vue +30 -0
- package/dist/vue/blog-vue/BlogList.vue +102 -0
- package/dist/vue/blog-vue/Empty.vue +8 -0
- package/dist/vue/blog-vue/EmptyEnglish.vue +8 -0
- package/dist/vue/blog-vue/English.vue +24 -0
- package/dist/vue/blog-vue/index.ts +29 -0
- package/dist/vue/buttons-vue/Button.vue +105 -0
- package/dist/vue/buttons-vue/ButtonBasic.vue +11 -0
- package/dist/vue/buttons-vue/ButtonFeature.vue +100 -0
- package/dist/vue/buttons-vue/ButtonFeatureBasic.vue +8 -0
- package/dist/vue/buttons-vue/ButtonFeatureWithTips.vue +7 -0
- package/dist/vue/buttons-vue/ButtonLink.vue +13 -0
- package/dist/vue/buttons-vue/ButtonSizes.vue +12 -0
- package/dist/vue/buttons-vue/ButtonVariants.vue +16 -0
- package/dist/vue/buttons-vue/ButtonWithIcons.vue +21 -0
- package/dist/vue/buttons-vue/index.ts +1 -0
- package/dist/vue/confirm-dialog-vue/Basic.vue +62 -0
- package/dist/vue/confirm-dialog-vue/ConfirmDialog.vue +147 -0
- package/dist/vue/confirm-dialog-vue/CustomButtons.vue +81 -0
- package/dist/vue/confirm-dialog-vue/index.ts +20 -0
- package/dist/vue/cosy.ts +6 -0
- package/dist/vue/counter-vue/VueCounter.vue +29 -0
- package/dist/vue/counter-vue/index.ts +1 -0
- package/dist/vue/iPhone-vue/Basic.vue +33 -0
- package/dist/vue/iPhone-vue/CustomBackground.vue +35 -0
- package/dist/vue/iPhone-vue/NoFrame.vue +33 -0
- package/dist/vue/iPhone-vue/WeatherApp.vue +143 -0
- package/dist/vue/iPhone-vue/iPhoneWindow.vue +247 -0
- package/dist/vue/iPhone-vue/index.ts +31 -0
- package/dist/vue/icons-vue/AlertTriangleIcon.vue +30 -0
- package/dist/vue/icons-vue/CalendarIcon.vue +30 -0
- package/dist/vue/icons-vue/CheckCircleIcon.vue +30 -0
- package/dist/vue/icons-vue/CheckIcon.vue +30 -0
- package/dist/vue/icons-vue/ChevronDownIcon.vue +30 -0
- package/dist/vue/icons-vue/ClipboardIcon.vue +30 -0
- package/dist/vue/icons-vue/CloseIcon.vue +30 -0
- package/dist/vue/icons-vue/InboxArchiveIcon.vue +30 -0
- package/dist/vue/icons-vue/InfoCircleIcon.vue +30 -0
- package/dist/vue/icons-vue/InfoIcon.vue +30 -0
- package/dist/vue/icons-vue/LinkIcon.vue +30 -0
- package/dist/vue/icons-vue/MenuIcon.vue +30 -0
- package/dist/vue/icons-vue/SearchIcon.vue +30 -0
- package/dist/vue/icons-vue/SettingsIcon.vue +30 -0
- package/dist/vue/icons-vue/UserIcon.vue +30 -0
- package/dist/vue/icons-vue/VueIcon.vue +86 -0
- package/dist/vue/icons-vue/XCircleIcon.vue +30 -0
- package/dist/vue/icons-vue/index.ts +1 -0
- package/dist/vue/list-vue/ListItem.vue +5 -0
- package/dist/vue/list-vue/index.ts +1 -0
- package/dist/vue/mac-window-vue/Basic.vue +9 -0
- package/dist/vue/mac-window-vue/CustomHeight.vue +13 -0
- package/dist/vue/mac-window-vue/MacWindow.vue +283 -0
- package/dist/vue/mac-window-vue/WithEvents.vue +40 -0
- package/dist/vue/mac-window-vue/WithSidebar.vue +31 -0
- package/dist/vue/mac-window-vue/WithTabs.vue +26 -0
- package/dist/vue/mac-window-vue/WithToolbar.vue +44 -0
- package/dist/vue/mac-window-vue/index.ts +36 -0
- package/dist/vue/utils/component.ts +42 -0
- package/dist/vue/utils/i18n.ts +83 -0
- package/dist/vue/utils/image.ts +128 -0
- package/dist/vue/utils/lang_entry.ts +240 -0
- package/dist/vue/utils/lang_package.ts +150 -0
- package/dist/vue/utils/language.ts +121 -0
- package/dist/vue/utils/link.ts +250 -0
- package/dist/vue/utils/logger.ts +136 -0
- package/dist/vue/utils/path.ts +59 -0
- package/dist/vue/utils/social.ts +90 -0
- package/dist/vue/utils/theme.ts +122 -0
- package/dist/vue/utils/url.ts +17 -0
- package/package.json +85 -82
- package/LICENSE +0 -21
- package/README.md +0 -31
- package/dist/alert/Alert.astro +0 -94
- package/dist/alert/EAlertBasic.astro +0 -11
- package/dist/alert/EAlertBasicContainer.astro +0 -11
- package/dist/alert/EAlertCustomStyle.astro +0 -14
- package/dist/alert/EAlertCustomStyleContainer.astro +0 -11
- package/dist/alert/EAlertError.astro +0 -6
- package/dist/alert/EAlertInfo.astro +0 -6
- package/dist/alert/EAlertSuccess.astro +0 -6
- package/dist/alert/EAlertTypesContainer.astro +0 -43
- package/dist/alert/EAlertWarning.astro +0 -6
- package/dist/alert/EAlertWithTitle.astro +0 -12
- package/dist/alert/EAlertWithTitleContainer.astro +0 -11
- package/dist/alert/index.ts +0 -16
- package/dist/alert-dialog-vue/AlertDialog.vue +0 -120
- package/dist/alert-dialog-vue/Basic.vue +0 -38
- package/dist/alert-dialog-vue/Multilang.vue +0 -48
- package/dist/alert-dialog-vue/index.ts +0 -20
- package/dist/article/Article.astro +0 -139
- package/dist/article/ArticleBasic.astro +0 -31
- package/dist/article/index.ts +0 -11
- package/dist/assets/iconData.ts +0 -116
- package/dist/banner/Banner.astro +0 -165
- package/dist/banner/BannerAllAnimations.astro +0 -10
- package/dist/banner/BannerBasic.astro +0 -5
- package/dist/banner/BannerCustomStyle.astro +0 -7
- package/dist/banner/BannerDanger.astro +0 -5
- package/dist/banner/BannerFadeIn.astro +0 -5
- package/dist/banner/BannerInfo.astro +0 -5
- package/dist/banner/BannerPrimary.astro +0 -5
- package/dist/banner/BannerSecondary.astro +0 -5
- package/dist/banner/BannerSlideUp.astro +0 -5
- package/dist/banner/BannerSuccess.astro +0 -5
- package/dist/banner/BannerWarning.astro +0 -5
- package/dist/banner/index.ts +0 -41
- package/dist/banner-box-vue/BannerBox.vue +0 -296
- package/dist/banner-box-vue/DownloadButton.vue +0 -202
- package/dist/banner-box-vue/ExampleBasic.vue +0 -32
- package/dist/banner-box-vue/ExampleCustomBg.vue +0 -32
- package/dist/banner-box-vue/ExampleDisplayModeAlways.vue +0 -34
- package/dist/banner-box-vue/ExampleDisplayModeHover.vue +0 -34
- package/dist/banner-box-vue/ExampleDisplayModeNever.vue +0 -34
- package/dist/banner-box-vue/ExampleImageExport.vue +0 -37
- package/dist/banner-box-vue/ExampleSizePreset.vue +0 -35
- package/dist/banner-box-vue/FeatureCard.vue +0 -190
- package/dist/banner-box-vue/SmartBanner.vue +0 -44
- package/dist/banner-box-vue/bgStyles.ts +0 -55
- package/dist/banner-box-vue/index.ts +0 -48
- package/dist/banner-box-vue/sizePresets.ts +0 -23
- package/dist/blog/Blog.astro +0 -249
- package/dist/blog/index.ts +0 -1
- package/dist/blog-vue/Basic.vue +0 -30
- package/dist/blog-vue/BlogList.vue +0 -100
- package/dist/blog-vue/Empty.vue +0 -8
- package/dist/blog-vue/EmptyEnglish.vue +0 -8
- package/dist/blog-vue/English.vue +0 -24
- package/dist/blog-vue/index.ts +0 -29
- package/dist/button/Button.astro +0 -192
- package/dist/button/ButtonBasic.astro +0 -18
- package/dist/button/ButtonBasicContainer.astro +0 -11
- package/dist/button/ButtonIconBoth.astro +0 -9
- package/dist/button/ButtonIconLeft.astro +0 -8
- package/dist/button/ButtonIconRight.astro +0 -8
- package/dist/button/ButtonLinkContainer.astro +0 -19
- package/dist/button/ButtonLinkExternal.astro +0 -8
- package/dist/button/ButtonShapes.astro +0 -23
- package/dist/button/ButtonShapesContainer.astro +0 -25
- package/dist/button/ButtonSizes.astro +0 -15
- package/dist/button/ButtonSizesContainer.astro +0 -11
- package/dist/button/ButtonStates.astro +0 -12
- package/dist/button/ButtonStatesContainer.astro +0 -11
- package/dist/button/ButtonVariants.astro +0 -14
- package/dist/button/ButtonVariantsContainer.astro +0 -64
- package/dist/button/ButtonWidth.astro +0 -8
- package/dist/button/ButtonWidthContainer.astro +0 -19
- package/dist/button/ButtonWithIcons.astro +0 -25
- package/dist/button/ButtonWithIconsContainer.astro +0 -25
- package/dist/button/index_astro.ts +0 -62
- package/dist/buttons-vue/Button.vue +0 -105
- package/dist/buttons-vue/ButtonBasic.vue +0 -11
- package/dist/buttons-vue/ButtonFeature.vue +0 -91
- package/dist/buttons-vue/ButtonFeatureBasic.vue +0 -8
- package/dist/buttons-vue/ButtonFeatureWithTips.vue +0 -7
- package/dist/buttons-vue/ButtonLink.vue +0 -13
- package/dist/buttons-vue/ButtonSizes.vue +0 -12
- package/dist/buttons-vue/ButtonVariants.vue +0 -16
- package/dist/buttons-vue/ButtonWithIcons.vue +0 -21
- package/dist/buttons-vue/index.ts +0 -1
- package/dist/card/Card.astro +0 -140
- package/dist/card/CardCompact.astro +0 -77
- package/dist/card/CardCourse.astro +0 -32
- package/dist/card/CardLink.astro +0 -75
- package/dist/card/CardWithImage.astro +0 -39
- package/dist/card/ECardBasic.astro +0 -11
- package/dist/card/ECardBasicContainer.astro +0 -11
- package/dist/card/ECardClickable.astro +0 -13
- package/dist/card/ECardClickableContainer.astro +0 -11
- package/dist/card/ECardCompact.astro +0 -13
- package/dist/card/ECardCompactContainer.astro +0 -11
- package/dist/card/ECardCustomStyle.astro +0 -17
- package/dist/card/ECardCustomStyleContainer.astro +0 -11
- package/dist/card/ECardWithImage.astro +0 -16
- package/dist/card/ECardWithImageContainer.astro +0 -11
- package/dist/card/ECardWithSubtitle.astro +0 -13
- package/dist/card/ECardWithSubtitleContainer.astro +0 -11
- package/dist/card/index.ts +0 -33
- package/dist/code-block/CodeBlock.astro +0 -152
- package/dist/code-block/index.ts +0 -1
- package/dist/code-container/CodeContainer.astro +0 -254
- package/dist/code-container/ECodeContainerBasic.astro +0 -19
- package/dist/code-container/ECodeContainerMultiple.astro +0 -49
- package/dist/code-container/index.ts +0 -14
- package/dist/code-example/CodeExample.astro +0 -157
- package/dist/code-example/index.ts +0 -1
- package/dist/confirm-dialog-vue/Basic.vue +0 -57
- package/dist/confirm-dialog-vue/ConfirmDialog.vue +0 -134
- package/dist/confirm-dialog-vue/CustomButtons.vue +0 -69
- package/dist/confirm-dialog-vue/index.ts +0 -20
- package/dist/contact/Contact.astro +0 -279
- package/dist/contact/EContactBasic.astro +0 -15
- package/dist/contact/EContactBasicContainer.astro +0 -12
- package/dist/contact/EContactCompact.astro +0 -12
- package/dist/contact/EContactCompactContainer.astro +0 -12
- package/dist/contact/EContactCustomStyle.astro +0 -22
- package/dist/contact/EContactCustomStyleContainer.astro +0 -12
- package/dist/contact/EContactSocial.astro +0 -21
- package/dist/contact/EContactSocialContainer.astro +0 -12
- package/dist/contact/EContactWithTitle.astro +0 -18
- package/dist/contact/EContactWithTitleContainer.astro +0 -12
- package/dist/contact/index.ts +0 -21
- package/dist/container/Container.astro +0 -211
- package/dist/container/EContainerBasic.astro +0 -13
- package/dist/container/EContainerBasicContainer.astro +0 -11
- package/dist/container/EContainerFlexBetween.astro +0 -16
- package/dist/container/EContainerFlexCenter.astro +0 -23
- package/dist/container/EContainerFlexColumn.astro +0 -16
- package/dist/container/EContainerFlexContainer.astro +0 -34
- package/dist/container/EContainerFlexRow.astro +0 -16
- package/dist/container/EContainerPadding.astro +0 -32
- package/dist/container/EContainerPaddingContainer.astro +0 -11
- package/dist/container/EContainerSizes.astro +0 -36
- package/dist/container/EContainerSizesContainer.astro +0 -11
- package/dist/container/index.ts +0 -16
- package/dist/cosy.ts +0 -6
- package/dist/counter-vue/VueCounter.vue +0 -29
- package/dist/counter-vue/index.ts +0 -1
- package/dist/database/BaseDB.ts +0 -231
- package/dist/database/BlogDB.ts +0 -198
- package/dist/database/CourseDB.ts +0 -84
- package/dist/database/ExperimentDB.ts +0 -102
- package/dist/database/LessonDB.ts +0 -102
- package/dist/database/MetaDB.ts +0 -74
- package/dist/entities/BaseDoc.ts +0 -195
- package/dist/entities/BlogDoc.ts +0 -104
- package/dist/entities/CourseDoc.ts +0 -96
- package/dist/entities/ExperimentDoc.ts +0 -114
- package/dist/entities/Feature.ts +0 -53
- package/dist/entities/LessonDoc.ts +0 -148
- package/dist/entities/MetaDoc.ts +0 -90
- package/dist/entities/SidebarItem.ts +0 -89
- package/dist/entities/Tag.ts +0 -42
- package/dist/env.d.ts +0 -32
- package/dist/errors/404.astro +0 -27
- package/dist/errors/404Basic.astro +0 -5
- package/dist/errors/index.ts +0 -11
- package/dist/flex/Flex.astro +0 -138
- package/dist/flex/FlexBasic.astro +0 -9
- package/dist/flex/index.ts +0 -11
- package/dist/footer/EFooterBasic.astro +0 -18
- package/dist/footer/EFooterBasicContainer.astro +0 -11
- package/dist/footer/EFooterComplete.astro +0 -45
- package/dist/footer/EFooterCompleteContainer.astro +0 -11
- package/dist/footer/EFooterFeaturesContainer.astro +0 -40
- package/dist/footer/EFooterWithLogo.astro +0 -23
- package/dist/footer/EFooterWithLogoContainer.astro +0 -11
- package/dist/footer/EFooterWithNavigation.astro +0 -24
- package/dist/footer/EFooterWithNavigationContainer.astro +0 -11
- package/dist/footer/EFooterWithProducts.astro +0 -24
- package/dist/footer/EFooterWithProductsContainer.astro +0 -11
- package/dist/footer/EFooterWithSocial.astro +0 -24
- package/dist/footer/EFooterWithSocialContainer.astro +0 -11
- package/dist/footer/Footer.astro +0 -339
- package/dist/footer/FooterSection.astro +0 -48
- package/dist/footer/index.ts +0 -31
- package/dist/grid/Grid.astro +0 -190
- package/dist/grid/GridBasic.astro +0 -9
- package/dist/grid/index.ts +0 -11
- package/dist/header/Header.astro +0 -204
- package/dist/header/HeaderBasic.astro +0 -14
- package/dist/header/HeaderCustomNavbarCenter.astro +0 -23
- package/dist/header/HeaderCustomNavbarEnd.astro +0 -20
- package/dist/header/HeaderCustomNavbarStart.astro +0 -20
- package/dist/header/HeaderCustomPosition.astro +0 -23
- package/dist/header/HeaderWithNavigation.astro +0 -22
- package/dist/header/index.ts +0 -26
- package/dist/heading/Heading.astro +0 -238
- package/dist/heading/index.ts +0 -11
- package/dist/hero/Hero.astro +0 -368
- package/dist/hero/HeroAlignCenter.astro +0 -13
- package/dist/hero/HeroAlignContainer.astro +0 -23
- package/dist/hero/HeroAlignLeft.astro +0 -13
- package/dist/hero/HeroAlignRight.astro +0 -13
- package/dist/hero/HeroBackgroundContainer.astro +0 -18
- package/dist/hero/HeroBackgroundImage.astro +0 -12
- package/dist/hero/HeroBackgroundImageContainer.astro +0 -11
- package/dist/hero/HeroBasic.astro +0 -12
- package/dist/hero/HeroBasicContainer.astro +0 -11
- package/dist/hero/HeroGradientBackground.astro +0 -10
- package/dist/hero/HeroPlainBackground.astro +0 -10
- package/dist/hero/HeroWithButton.astro +0 -11
- package/dist/hero/HeroWithButtonContainer.astro +0 -11
- package/dist/hero/HeroWithImage.astro +0 -16
- package/dist/hero/HeroWithImageContainer.astro +0 -11
- package/dist/hero/index.ts +0 -39
- package/dist/iPhone-vue/Basic.vue +0 -33
- package/dist/iPhone-vue/CustomBackground.vue +0 -33
- package/dist/iPhone-vue/NoFrame.vue +0 -33
- package/dist/iPhone-vue/WeatherApp.vue +0 -97
- package/dist/iPhone-vue/iPhoneWindow.vue +0 -193
- package/dist/iPhone-vue/index.ts +0 -28
- package/dist/icons/AlertTriangle.astro +0 -24
- package/dist/icons/AstroIcon.astro +0 -61
- package/dist/icons/CalendarIcon.astro +0 -24
- package/dist/icons/CheckCircle.astro +0 -23
- package/dist/icons/CheckIcon.astro +0 -27
- package/dist/icons/ChevronDownIcon.astro +0 -24
- package/dist/icons/ClipboardIcon.astro +0 -27
- package/dist/icons/CloseIcon.astro +0 -27
- package/dist/icons/ErrorIcon.astro +0 -24
- package/dist/icons/GithubIcon.astro +0 -19
- package/dist/icons/InboxArchive.astro +0 -23
- package/dist/icons/InfoCircle.astro +0 -24
- package/dist/icons/InfoIcon.astro +0 -26
- package/dist/icons/LinkIcon.astro +0 -27
- package/dist/icons/LinkedinIcon.astro +0 -23
- package/dist/icons/MenuIcon.astro +0 -27
- package/dist/icons/SearchIcon.astro +0 -23
- package/dist/icons/SettingsIcon.astro +0 -18
- package/dist/icons/SocialIcon.astro +0 -100
- package/dist/icons/SuccessIcon.astro +0 -24
- package/dist/icons/SunCloudyIcon.astro +0 -23
- package/dist/icons/TwitterIcon.astro +0 -24
- package/dist/icons/UserIcon.astro +0 -24
- package/dist/icons/WarningIcon.astro +0 -27
- package/dist/icons/XCircle.astro +0 -24
- package/dist/icons/index.ts +0 -3
- package/dist/icons-vue/AlertTriangleIcon.vue +0 -30
- package/dist/icons-vue/CalendarIcon.vue +0 -30
- package/dist/icons-vue/CheckCircleIcon.vue +0 -30
- package/dist/icons-vue/CheckIcon.vue +0 -30
- package/dist/icons-vue/ChevronDownIcon.vue +0 -30
- package/dist/icons-vue/ClipboardIcon.vue +0 -30
- package/dist/icons-vue/CloseIcon.vue +0 -30
- package/dist/icons-vue/InboxArchiveIcon.vue +0 -30
- package/dist/icons-vue/InfoCircleIcon.vue +0 -30
- package/dist/icons-vue/InfoIcon.vue +0 -30
- package/dist/icons-vue/LinkIcon.vue +0 -30
- package/dist/icons-vue/MenuIcon.vue +0 -30
- package/dist/icons-vue/SearchIcon.vue +0 -30
- package/dist/icons-vue/SettingsIcon.vue +0 -30
- package/dist/icons-vue/UserIcon.vue +0 -30
- package/dist/icons-vue/VueIcon.vue +0 -76
- package/dist/icons-vue/XCircleIcon.vue +0 -30
- package/dist/icons-vue/index.ts +0 -1
- package/dist/image/Image.astro +0 -342
- package/dist/image/ImageBasic.astro +0 -1
- package/dist/image/ImageEffects.astro +0 -32
- package/dist/image/ImageLoading.astro +0 -35
- package/dist/image/index.ts +0 -17
- package/dist/index.ts +0 -3
- package/dist/index_astro.ts +0 -77
- package/dist/index_collection.ts +0 -104
- package/dist/index_icons.ts +0 -24
- package/dist/index_utils.ts +0 -8
- package/dist/index_vue.ts +0 -33
- package/dist/integration.ts +0 -14
- package/dist/language-switcher/LanguageSwitcher.astro +0 -64
- package/dist/language-switcher/LanguageSwitcherBasic.astro +0 -7
- package/dist/language-switcher/index.ts +0 -11
- package/dist/layout-app/AppLayout.astro +0 -259
- package/dist/layout-app/AppLayoutBasic.astro +0 -53
- package/dist/layout-app/index.ts +0 -11
- package/dist/layout-basic/BaseLayout.astro +0 -99
- package/dist/layout-basic/BaseLayoutBasic.astro +0 -16
- package/dist/layout-basic/index.ts +0 -11
- package/dist/layout-dashboard/DashboardLayout.astro +0 -671
- package/dist/layout-dashboard/DashboardLayoutBasic.astro +0 -48
- package/dist/layout-dashboard/index.ts +0 -11
- package/dist/link/Link.astro +0 -145
- package/dist/link/LinkAnimations.astro +0 -21
- package/dist/link/LinkBasic.astro +0 -17
- package/dist/link/LinkVariants.astro +0 -20
- package/dist/link/index.ts +0 -17
- package/dist/list-vue/ListItem.vue +0 -5
- package/dist/list-vue/index.ts +0 -1
- package/dist/mac-window-vue/Basic.vue +0 -11
- package/dist/mac-window-vue/CustomHeight.vue +0 -13
- package/dist/mac-window-vue/MacWindow.vue +0 -262
- package/dist/mac-window-vue/WithEvents.vue +0 -34
- package/dist/mac-window-vue/WithSidebar.vue +0 -21
- package/dist/mac-window-vue/WithTabs.vue +0 -21
- package/dist/mac-window-vue/WithToolbar.vue +0 -43
- package/dist/mac-window-vue/index.ts +0 -36
- package/dist/main/Main.astro +0 -147
- package/dist/main/index.ts +0 -1
- package/dist/modal/Modal.astro +0 -119
- package/dist/modal/index.ts +0 -1
- package/dist/module/Module.astro +0 -61
- package/dist/module/ModuleBasic.astro +0 -12
- package/dist/module/ModuleCustom.astro +0 -14
- package/dist/module/ModuleGrid.astro +0 -26
- package/dist/module/index.ts +0 -17
- package/dist/nav-item/NavItems.astro +0 -44
- package/dist/nav-item/NavItemsBasic.astro +0 -27
- package/dist/nav-item/index.ts +0 -11
- package/dist/nav-section/NavSection.astro +0 -42
- package/dist/nav-section/NavSectionBasic.astro +0 -12
- package/dist/nav-section/index.ts +0 -11
- package/dist/products/ProductCard.astro +0 -375
- package/dist/products/Products.astro +0 -195
- package/dist/products/index.ts +0 -2
- package/dist/section/Section.astro +0 -140
- package/dist/section/index.ts +0 -1
- package/dist/sidebar/Sidebar.astro +0 -174
- package/dist/sidebar/SidebarBasic.astro +0 -1
- package/dist/sidebar/index.ts +0 -11
- package/dist/sidebar-nav/SidebarNav.astro +0 -117
- package/dist/sidebar-nav/SidebarNavBasic.astro +0 -32
- package/dist/sidebar-nav/index.ts +0 -11
- package/dist/speak/Speak.astro +0 -65
- package/dist/speak/SpeakBasic.astro +0 -13
- package/dist/speak/SpeakGrid.astro +0 -29
- package/dist/speak/index.ts +0 -14
- package/dist/stack/Stack.astro +0 -151
- package/dist/stack/StackBasic.astro +0 -15
- package/dist/stack/index.ts +0 -11
- package/dist/team-member/TeamMember.astro +0 -135
- package/dist/team-member/TeamMemberBasic.astro +0 -25
- package/dist/team-member/TeamMemberCustomStyle.astro +0 -26
- package/dist/team-member/TeamMemberGroup.astro +0 -60
- package/dist/team-member/TeamMemberWithSocial.astro +0 -30
- package/dist/team-member/TeamMembers.astro +0 -104
- package/dist/team-member/index.ts +0 -23
- package/dist/text/Text.astro +0 -189
- package/dist/text/TextBasic.astro +0 -12
- package/dist/text/TextSizes.astro +0 -11
- package/dist/text/index.ts +0 -11
- package/dist/theme-switcher/ThemeItem.astro +0 -45
- package/dist/theme-switcher/ThemeSwitcher.astro +0 -120
- package/dist/theme-switcher/ThemeSwitcherBasic.astro +0 -7
- package/dist/theme-switcher/index.ts +0 -11
- package/dist/toc/TableOfContents.astro +0 -405
- package/dist/toc/TableOfContentsBasic.astro +0 -25
- package/dist/toc/index.ts +0 -11
- package/dist/types/article.ts +0 -22
- package/dist/types/footer.ts +0 -129
- package/dist/types/header.ts +0 -87
- package/dist/types/heading.ts +0 -13
- package/dist/types/image.ts +0 -16
- package/dist/types/layout.ts +0 -71
- package/dist/types/main.ts +0 -80
- package/dist/types/menu.ts +0 -24
- package/dist/types/meta.ts +0 -55
- package/dist/types/product.ts +0 -10
- package/dist/types/sidebar.ts +0 -39
- package/dist/types/static-path.ts +0 -8
- package/dist/utils/component.ts +0 -39
- package/dist/utils/i18n.ts +0 -83
- package/dist/utils/image.ts +0 -126
- package/dist/utils/lang_entry.ts +0 -240
- package/dist/utils/lang_package.ts +0 -150
- package/dist/utils/language.ts +0 -118
- package/dist/utils/link.ts +0 -248
- package/dist/utils/logger.ts +0 -130
- package/dist/utils/path.ts +0 -55
- package/dist/utils/social.ts +0 -90
- package/dist/utils/theme.ts +0 -114
- package/dist/utils/url.ts +0 -17
- /package/dist/{assets → src-astro/assets}/book.png +0 -0
- /package/dist/{assets → src-astro/assets}/logo-rounded.png +0 -0
- /package/dist/{assets → src-astro/assets}/logo.png +0 -0
- /package/dist/{button → src-astro/button}/ButtonBlock.astro +0 -0
- /package/dist/{button → src-astro/button}/ButtonError.astro +0 -0
- /package/dist/{button → src-astro/button}/ButtonGhost.astro +0 -0
- /package/dist/{button → src-astro/button}/ButtonInfo.astro +0 -0
- /package/dist/{button → src-astro/button}/ButtonLink.astro +0 -0
- /package/dist/{button → src-astro/button}/ButtonNeutral.astro +0 -0
- /package/dist/{button → src-astro/button}/ButtonOutline.astro +0 -0
- /package/dist/{button → src-astro/button}/ButtonShapeCircle.astro +0 -0
- /package/dist/{button → src-astro/button}/ButtonShapeDefault.astro +0 -0
- /package/dist/{button → src-astro/button}/ButtonShapeSquare.astro +0 -0
- /package/dist/{button → src-astro/button}/ButtonSuccess.astro +0 -0
- /package/dist/{button → src-astro/button}/ButtonWarning.astro +0 -0
- /package/dist/{button → src-astro/button}/ButtonWide.astro +0 -0
- /package/dist/{card → src-astro/card}/CardBasic.astro +0 -0
- /package/dist/{heading → src-astro/heading}/HeadingBasic.astro +0 -0
- /package/dist/{types → src-astro/types}/nav.ts +0 -0
- /package/dist/{iPhone-vue → vue/iPhone-vue}/assets/iPhone 14 Pro - Deep Purple - Landscape.png +0 -0
- /package/dist/{iPhone-vue → vue/iPhone-vue}/assets/iPhone 14 Pro - Deep Purple - Portrait.png +0 -0
- /package/dist/{iPhone-vue → vue/iPhone-vue}/assets/iPhone 14 Pro - Gold - Landscape.png +0 -0
- /package/dist/{iPhone-vue → vue/iPhone-vue}/assets/iPhone 14 Pro - Gold - Portrait.png +0 -0
- /package/dist/{iPhone-vue → vue/iPhone-vue}/assets/iPhone 14 Pro - Silver - Landscape.png +0 -0
- /package/dist/{iPhone-vue → vue/iPhone-vue}/assets/iPhone 14 Pro - Silver - Portrait.png +0 -0
- /package/dist/{iPhone-vue → vue/iPhone-vue}/assets/iPhone 14 Pro - Space Black - Landscape.png +0 -0
- /package/dist/{iPhone-vue → vue/iPhone-vue}/assets/iPhone 14 Pro - Space Black - Portrait.png +0 -0
@@ -1,10 +0,0 @@
|
|
1
|
-
---
|
2
|
-
import { Banner } from '../index';
|
3
|
-
---
|
4
|
-
|
5
|
-
<div class="flex flex-col gap-4">
|
6
|
-
<Banner animation="none">这是一个没有动画的横幅</Banner>
|
7
|
-
<Banner animation="fade">这是一个只有淡入动画的横幅</Banner>
|
8
|
-
<Banner animation="slide">这是一个只有上滑动画的横幅</Banner>
|
9
|
-
<Banner animation="both">这是一个同时有淡入和上滑动画的横幅</Banner>
|
10
|
-
</div>
|
package/dist/banner/index.ts
DELETED
@@ -1,41 +0,0 @@
|
|
1
|
-
import Banner from './Banner.astro';
|
2
|
-
import BannerBasic from './BannerBasic.astro';
|
3
|
-
import BannerPrimary from './BannerPrimary.astro';
|
4
|
-
import BannerSecondary from './BannerSecondary.astro';
|
5
|
-
import BannerSuccess from './BannerSuccess.astro';
|
6
|
-
import BannerWarning from './BannerWarning.astro';
|
7
|
-
import BannerDanger from './BannerDanger.astro';
|
8
|
-
import BannerInfo from './BannerInfo.astro';
|
9
|
-
import BannerCustomStyle from './BannerCustomStyle.astro';
|
10
|
-
import BannerFadeIn from './BannerFadeIn.astro';
|
11
|
-
import BannerSlideUp from './BannerSlideUp.astro';
|
12
|
-
import BannerAllAnimations from './BannerAllAnimations.astro';
|
13
|
-
import BasicSourceCode from './BannerBasic.astro?raw';
|
14
|
-
import PrimarySourceCode from './BannerPrimary.astro?raw';
|
15
|
-
import SecondarySourceCode from './BannerSecondary.astro?raw';
|
16
|
-
import SuccessSourceCode from './BannerSuccess.astro?raw';
|
17
|
-
import WarningSourceCode from './BannerWarning.astro?raw';
|
18
|
-
import DangerSourceCode from './BannerDanger.astro?raw';
|
19
|
-
import InfoSourceCode from './BannerInfo.astro?raw';
|
20
|
-
import CustomStyleSourceCode from './BannerCustomStyle.astro?raw';
|
21
|
-
import FadeInSourceCode from './BannerFadeIn.astro?raw';
|
22
|
-
import SlideUpSourceCode from './BannerSlideUp.astro?raw';
|
23
|
-
import AllAnimationsSourceCode from './BannerAllAnimations.astro?raw';
|
24
|
-
import { extractSimpleExample } from '../utils/component';
|
25
|
-
|
26
|
-
export { Banner, BannerBasic, BannerPrimary, BannerSecondary, BannerSuccess, BannerWarning, BannerDanger, BannerInfo, BannerCustomStyle, BannerFadeIn, BannerSlideUp, BannerAllAnimations };
|
27
|
-
|
28
|
-
// 导出示例源代码
|
29
|
-
export const BannerExampleCodes = {
|
30
|
-
Basic: extractSimpleExample(BasicSourceCode, 'Banner'),
|
31
|
-
Primary: extractSimpleExample(PrimarySourceCode, 'Banner'),
|
32
|
-
Secondary: extractSimpleExample(SecondarySourceCode, 'Banner'),
|
33
|
-
Success: extractSimpleExample(SuccessSourceCode, 'Banner'),
|
34
|
-
Warning: extractSimpleExample(WarningSourceCode, 'Banner'),
|
35
|
-
Danger: extractSimpleExample(DangerSourceCode, 'Banner'),
|
36
|
-
Info: extractSimpleExample(InfoSourceCode, 'Banner'),
|
37
|
-
CustomStyle: extractSimpleExample(CustomStyleSourceCode, 'Banner'),
|
38
|
-
FadeIn: extractSimpleExample(FadeInSourceCode, 'Banner'),
|
39
|
-
SlideUp: extractSimpleExample(SlideUpSourceCode, 'Banner'),
|
40
|
-
AllAnimations: extractSimpleExample(AllAnimationsSourceCode, 'Banner'),
|
41
|
-
};
|
@@ -1,296 +0,0 @@
|
|
1
|
-
<!--
|
2
|
-
@component BannerBox
|
3
|
-
|
4
|
-
@description
|
5
|
-
BannerBox 组件是一个可定制的横幅容器,支持自定义背景、尺寸调整和导出为图片功能。
|
6
|
-
可以直接用作容器,也可以通过传入标题、描述和特性列表来显示内容。
|
7
|
-
适用于创建营销横幅、特性展示、社交媒体卡片等内容。
|
8
|
-
|
9
|
-
@usage
|
10
|
-
基本用法:
|
11
|
-
```vue
|
12
|
-
<BannerBox>
|
13
|
-
<div>横幅内容</div>
|
14
|
-
</BannerBox>
|
15
|
-
```
|
16
|
-
|
17
|
-
使用标题和描述:
|
18
|
-
```vue
|
19
|
-
<BannerBox
|
20
|
-
title="我的横幅标题"
|
21
|
-
description="这是一段描述文字"
|
22
|
-
:features="[
|
23
|
-
{ emoji: '🚀', title: '高性能' },
|
24
|
-
{ emoji: '⚡', title: '快速响应' },
|
25
|
-
{ emoji: '🔒', title: '安全可靠' }
|
26
|
-
]"
|
27
|
-
/>
|
28
|
-
```
|
29
|
-
|
30
|
-
自定义背景:
|
31
|
-
```vue
|
32
|
-
<BannerBox :backgroundClassIndex="5">
|
33
|
-
<div>自定义背景的横幅</div>
|
34
|
-
</BannerBox>
|
35
|
-
```
|
36
|
-
|
37
|
-
设置下载按钮显示模式:
|
38
|
-
```vue
|
39
|
-
<BannerBox displayMode="always">
|
40
|
-
<div>总是显示下载按钮</div>
|
41
|
-
</BannerBox>
|
42
|
-
```
|
43
|
-
|
44
|
-
@props
|
45
|
-
@prop {String} [displayMode='hover'] - 下载按钮显示模式:'always'(总是显示),'hover'(悬停显示),'never'(不显示)
|
46
|
-
@prop {Number} [backgroundClassIndex=0] - 背景样式索引,对应内置的背景样式列表
|
47
|
-
@prop {String} [title=''] - 横幅标题
|
48
|
-
@prop {String} [description=''] - 横幅描述
|
49
|
-
@prop {Array} [features=[]] - 特性列表,每项包含{emoji, title, link}
|
50
|
-
|
51
|
-
@slots
|
52
|
-
@slot default - 横幅内容
|
53
|
-
-->
|
54
|
-
|
55
|
-
<script lang="ts">
|
56
|
-
import { ref, onMounted, watch, onUnmounted, computed, defineComponent } from 'vue';
|
57
|
-
import { RiDownloadLine } from '@remixicon/vue';
|
58
|
-
import { toPng } from 'html-to-image';
|
59
|
-
import FeatureCard from './FeatureCard.vue';
|
60
|
-
import DownloadButton from './DownloadButton.vue';
|
61
|
-
import { bgClasses } from './bgStyles';
|
62
|
-
import { sizePresets } from './sizePresets';
|
63
|
-
import '../../style'
|
64
|
-
|
65
|
-
export interface IFeature {
|
66
|
-
emoji: string;
|
67
|
-
title: string;
|
68
|
-
link?: string;
|
69
|
-
}
|
70
|
-
|
71
|
-
export default defineComponent({
|
72
|
-
name: 'BannerBox',
|
73
|
-
components: {
|
74
|
-
RiDownloadLine,
|
75
|
-
FeatureCard,
|
76
|
-
DownloadButton
|
77
|
-
},
|
78
|
-
props: {
|
79
|
-
displayMode: {
|
80
|
-
type: String,
|
81
|
-
default: 'hover',
|
82
|
-
validator: (value: string) => ['always', 'hover', 'never'].includes(value)
|
83
|
-
},
|
84
|
-
backgroundClassIndex: {
|
85
|
-
type: Number,
|
86
|
-
default: 0
|
87
|
-
},
|
88
|
-
title: {
|
89
|
-
type: String,
|
90
|
-
default: ''
|
91
|
-
},
|
92
|
-
description: {
|
93
|
-
type: String,
|
94
|
-
default: ''
|
95
|
-
},
|
96
|
-
features: {
|
97
|
-
type: Array as () => IFeature[],
|
98
|
-
default: () => []
|
99
|
-
},
|
100
|
-
},
|
101
|
-
setup(props) {
|
102
|
-
const componentRef = ref<HTMLElement | null>(null);
|
103
|
-
const isDropdownOpen = ref(false);
|
104
|
-
const isLoadedFromStorage = ref(false);
|
105
|
-
const selectedBgIndex = ref(props.backgroundClassIndex);
|
106
|
-
|
107
|
-
const selectedSize = ref(sizePresets[0]);
|
108
|
-
|
109
|
-
const toggleDropdown = () => {
|
110
|
-
console.log("Toggle Dropdown")
|
111
|
-
isDropdownOpen.value = !isDropdownOpen.value;
|
112
|
-
};
|
113
|
-
|
114
|
-
// 监听尺寸变化并保存到 localStorage
|
115
|
-
watch(selectedSize, (newSize) => {
|
116
|
-
localStorage.setItem('bannerBoxSize', JSON.stringify(newSize));
|
117
|
-
// 当尺寸改变时,发出事件通知其他组件
|
118
|
-
window.dispatchEvent(new CustomEvent('bannerBoxSizeChange', {
|
119
|
-
detail: newSize
|
120
|
-
}));
|
121
|
-
// 设置为已加载状态,显示尺寸标签
|
122
|
-
isLoadedFromStorage.value = true;
|
123
|
-
});
|
124
|
-
|
125
|
-
// 创建自定义事件处理函数
|
126
|
-
const handleSizeClear = () => {
|
127
|
-
selectedSize.value = sizePresets[0];
|
128
|
-
isLoadedFromStorage.value = false;
|
129
|
-
};
|
130
|
-
|
131
|
-
// 处理尺寸变化的事件
|
132
|
-
const handleSizeChange = (event: Event) => {
|
133
|
-
const customEvent = event as CustomEvent;
|
134
|
-
selectedSize.value = customEvent.detail;
|
135
|
-
isLoadedFromStorage.value = true;
|
136
|
-
};
|
137
|
-
|
138
|
-
onMounted(() => {
|
139
|
-
const savedSize = localStorage.getItem('bannerBoxSize');
|
140
|
-
if (savedSize) {
|
141
|
-
const parsed = JSON.parse(savedSize);
|
142
|
-
const found = sizePresets.find(preset => preset.name === parsed.name);
|
143
|
-
if (found) {
|
144
|
-
selectedSize.value = found;
|
145
|
-
isLoadedFromStorage.value = true;
|
146
|
-
}
|
147
|
-
}
|
148
|
-
|
149
|
-
// 添加事件监听
|
150
|
-
window.addEventListener('bannerBoxClear', handleSizeClear);
|
151
|
-
window.addEventListener('bannerBoxSizeChange', handleSizeChange);
|
152
|
-
|
153
|
-
// 恢复到简单的点击监听方式,但使用正确的选择器
|
154
|
-
document.addEventListener('click', (event) => {
|
155
|
-
if (!isDropdownOpen.value) return; // 如果下拉菜单已经关闭,就不需要处理
|
156
|
-
|
157
|
-
const target = event.target as HTMLElement;
|
158
|
-
// 检查点击的元素是否是下拉菜单中的元素
|
159
|
-
const isClickedOnDropdown = !!target.closest('[data-dropdown]');
|
160
|
-
|
161
|
-
if (!isClickedOnDropdown) {
|
162
|
-
isDropdownOpen.value = false;
|
163
|
-
}
|
164
|
-
});
|
165
|
-
});
|
166
|
-
|
167
|
-
// Update downloadAsImage function to accept scale parameter
|
168
|
-
const downloadAsImage = async () => {
|
169
|
-
try {
|
170
|
-
const element = componentRef.value;
|
171
|
-
if (!element) {
|
172
|
-
console.error('Component reference is null');
|
173
|
-
return;
|
174
|
-
}
|
175
|
-
|
176
|
-
const dataUrl = await toPng(element, {
|
177
|
-
backgroundColor: undefined,
|
178
|
-
style: {
|
179
|
-
transform: 'scale(1)',
|
180
|
-
transformOrigin: 'top left'
|
181
|
-
}
|
182
|
-
});
|
183
|
-
|
184
|
-
const link = document.createElement('a');
|
185
|
-
const fileName = `feature-${element.offsetWidth}x${element.offsetHeight}.png`;
|
186
|
-
link.download = fileName;
|
187
|
-
link.href = dataUrl;
|
188
|
-
link.click();
|
189
|
-
isDropdownOpen.value = false;
|
190
|
-
} catch (error) {
|
191
|
-
console.error('Failed to download image:', error);
|
192
|
-
}
|
193
|
-
};
|
194
|
-
|
195
|
-
const getBackgroundClass = (): string => {
|
196
|
-
return bgClasses[selectedBgIndex.value % bgClasses.length];
|
197
|
-
}
|
198
|
-
|
199
|
-
const clearStoredSize = () => {
|
200
|
-
localStorage.removeItem('bannerBoxSize');
|
201
|
-
// 触发自定义事件
|
202
|
-
window.dispatchEvent(new CustomEvent('bannerBoxClear'));
|
203
|
-
isDropdownOpen.value = false;
|
204
|
-
};
|
205
|
-
|
206
|
-
// 确保在组件卸载时清理事件监听器
|
207
|
-
onUnmounted(() => {
|
208
|
-
window.removeEventListener('bannerBoxClear', handleSizeClear);
|
209
|
-
window.removeEventListener('bannerBoxSizeChange', handleSizeChange);
|
210
|
-
});
|
211
|
-
|
212
|
-
// 计算下载按钮是否显示及其样式类
|
213
|
-
const downloadButtonStyles = computed(() => {
|
214
|
-
switch (props.displayMode) {
|
215
|
-
case 'always':
|
216
|
-
return {
|
217
|
-
show: true,
|
218
|
-
classes: 'cosy:opacity-100'
|
219
|
-
};
|
220
|
-
case 'hover':
|
221
|
-
return {
|
222
|
-
show: true,
|
223
|
-
classes: 'cosy:opacity-0 cosy:hover:opacity-100 cosy:transition-opacity'
|
224
|
-
};
|
225
|
-
case 'never':
|
226
|
-
return {
|
227
|
-
show: false,
|
228
|
-
classes: ''
|
229
|
-
};
|
230
|
-
default:
|
231
|
-
return {
|
232
|
-
show: true,
|
233
|
-
classes: 'cosy:opacity-0 cosy:hover:opacity-100 cosy:transition-opacity'
|
234
|
-
};
|
235
|
-
}
|
236
|
-
});
|
237
|
-
|
238
|
-
return {
|
239
|
-
componentRef,
|
240
|
-
isDropdownOpen,
|
241
|
-
isLoadedFromStorage,
|
242
|
-
selectedSize,
|
243
|
-
sizePresets,
|
244
|
-
selectedBgIndex,
|
245
|
-
toggleDropdown,
|
246
|
-
downloadAsImage,
|
247
|
-
getBackgroundClass,
|
248
|
-
clearStoredSize,
|
249
|
-
downloadButtonStyles,
|
250
|
-
bgClasses
|
251
|
-
};
|
252
|
-
}
|
253
|
-
});
|
254
|
-
</script>
|
255
|
-
|
256
|
-
<template>
|
257
|
-
<div class="cosy:relative cosy:w-full cosy:rounded-2xl cosy:max-w-7xl cosy:mx-auto">
|
258
|
-
<!-- Size indicator -->
|
259
|
-
<div v-if="isLoadedFromStorage"
|
260
|
-
class="cosy:absolute cosy:top-4 cosy:right-4 cosy:bg-yellow-500/30 cosy:backdrop-blur-sm cosy:px-3 cosy:py-1 cosy:rounded-lg cosy:text-sm cosy:text-white">
|
261
|
-
{{ selectedSize.name }}
|
262
|
-
</div>
|
263
|
-
|
264
|
-
<!-- Download button with dropdown menu -->
|
265
|
-
<DownloadButton :displayMode="displayMode" :isLoadedFromStorage="isLoadedFromStorage"
|
266
|
-
:selectedSize="selectedSize" :selectedBgIndex="selectedBgIndex" @update:selectedSize="selectedSize = $event"
|
267
|
-
@update:selectedBgIndex="selectedBgIndex = $event" @clear-stored-size="clearStoredSize"
|
268
|
-
@download-image="downloadAsImage" />
|
269
|
-
|
270
|
-
<div ref="componentRef" class="cosy:flex cosy:p-8 cosy:rounded-2xl cosy:shadow" :class="[
|
271
|
-
getBackgroundClass(),
|
272
|
-
selectedSize.width,
|
273
|
-
selectedSize.height
|
274
|
-
]">
|
275
|
-
<div class="cosy:py-16 cosy:px-8 cosy:text-center cosy:w-full cosy:rounded-2xl" data-type="smart-banner">
|
276
|
-
<h2 v-if="title.length > 0" class="cosy:text-4xl cosy:mb-4">
|
277
|
-
{{ title }}
|
278
|
-
</h2>
|
279
|
-
|
280
|
-
<p v-if="description.length > 0" class="cosy:text-lg cosy:text-center cosy:max-w-2xl cosy:mx-auto">
|
281
|
-
{{ description }}
|
282
|
-
</p>
|
283
|
-
|
284
|
-
<div v-if="features.length > 0"
|
285
|
-
class="cosy:flex cosy:flex-row cosy:justify-center cosy:gap-8 cosy:mx-auto cosy:w-full cosy:mt-24">
|
286
|
-
<FeatureCard v-for="feature in features" :key="feature.title" :emoji="feature.emoji"
|
287
|
-
:title="feature.title" :link="feature.link" />
|
288
|
-
</div>
|
289
|
-
|
290
|
-
<div :class="{ 'cosy:mt-12': title.length > 0 || description.length > 0 || features.length > 0 }">
|
291
|
-
<slot />
|
292
|
-
</div>
|
293
|
-
</div>
|
294
|
-
</div>
|
295
|
-
</div>
|
296
|
-
</template>
|
@@ -1,202 +0,0 @@
|
|
1
|
-
<!--
|
2
|
-
@component DownloadButton
|
3
|
-
|
4
|
-
@description
|
5
|
-
DownloadButton 组件提供了一个下载按钮,带有可展开的下拉菜单,用于调整尺寸、背景和下载图片。
|
6
|
-
|
7
|
-
@usage
|
8
|
-
基本用法:
|
9
|
-
```vue
|
10
|
-
<DownloadButton
|
11
|
-
:displayMode="'hover'"
|
12
|
-
:isLoadedFromStorage="true"
|
13
|
-
:selectedSize="selectedSize"
|
14
|
-
:selectedBgIndex="selectedBgIndex"
|
15
|
-
:sizePresets="sizePresets"
|
16
|
-
:bgClasses="bgClasses"
|
17
|
-
@update:selectedSize="selectedSize = $event"
|
18
|
-
@update:selectedBgIndex="selectedBgIndex = $event"
|
19
|
-
@clear-stored-size="clearStoredSize"
|
20
|
-
@download-image="downloadAsImage"
|
21
|
-
/>
|
22
|
-
```
|
23
|
-
|
24
|
-
@props
|
25
|
-
@prop {String} [displayMode='hover'] - 下载按钮显示模式:'always'(总是显示),'hover'(悬停显示),'never'(不显示)
|
26
|
-
@prop {Boolean} [isLoadedFromStorage=false] - 是否已从存储中加载尺寸
|
27
|
-
@prop {Object} [selectedSize] - 当前选中的尺寸预设
|
28
|
-
@prop {Number} [selectedBgIndex=0] - 当前选中的背景样式索引
|
29
|
-
@prop {Array} [sizePresets] - 尺寸预设列表
|
30
|
-
@prop {Array} [bgClasses] - 背景样式类列表
|
31
|
-
|
32
|
-
@emits
|
33
|
-
@emit update:selectedSize - 当选择新的尺寸预设时触发
|
34
|
-
@emit update:selectedBgIndex - 当选择新的背景样式时触发
|
35
|
-
@emit clear-stored-size - 当清除存储的尺寸时触发
|
36
|
-
@emit download-image - 当请求下载图片时触发
|
37
|
-
-->
|
38
|
-
|
39
|
-
<script lang="ts">
|
40
|
-
import { ref, computed, defineComponent } from 'vue';
|
41
|
-
import { RiDownloadLine } from '@remixicon/vue';
|
42
|
-
import { bgClasses } from './bgStyles';
|
43
|
-
import { sizePresets, type SizePreset } from './sizePresets';
|
44
|
-
import '../../style'
|
45
|
-
|
46
|
-
export default defineComponent({
|
47
|
-
name: 'DownloadButton',
|
48
|
-
components: {
|
49
|
-
RiDownloadLine
|
50
|
-
},
|
51
|
-
props: {
|
52
|
-
displayMode: {
|
53
|
-
type: String,
|
54
|
-
default: 'hover',
|
55
|
-
validator: (value: string) => ['always', 'hover', 'never'].includes(value)
|
56
|
-
},
|
57
|
-
isLoadedFromStorage: {
|
58
|
-
type: Boolean,
|
59
|
-
default: false
|
60
|
-
},
|
61
|
-
selectedSize: {
|
62
|
-
type: Object as () => SizePreset,
|
63
|
-
required: true
|
64
|
-
},
|
65
|
-
selectedBgIndex: {
|
66
|
-
type: Number,
|
67
|
-
default: 0
|
68
|
-
}
|
69
|
-
},
|
70
|
-
emits: ['update:selectedSize', 'update:selectedBgIndex', 'clear-stored-size', 'download-image'],
|
71
|
-
setup(props, { emit }) {
|
72
|
-
const isDropdownOpen = ref(false);
|
73
|
-
|
74
|
-
const toggleDropdown = () => {
|
75
|
-
isDropdownOpen.value = !isDropdownOpen.value;
|
76
|
-
};
|
77
|
-
|
78
|
-
// 计算下载按钮是否显示及其样式类
|
79
|
-
const downloadButtonStyles = computed(() => {
|
80
|
-
switch (props.displayMode) {
|
81
|
-
case 'always':
|
82
|
-
return {
|
83
|
-
show: true,
|
84
|
-
classes: 'cosy:opacity-100'
|
85
|
-
};
|
86
|
-
case 'hover':
|
87
|
-
return {
|
88
|
-
show: true,
|
89
|
-
classes: 'cosy:opacity-0 cosy:hover:opacity-100 cosy:transition-opacity'
|
90
|
-
};
|
91
|
-
case 'never':
|
92
|
-
return {
|
93
|
-
show: false,
|
94
|
-
classes: ''
|
95
|
-
};
|
96
|
-
default:
|
97
|
-
return {
|
98
|
-
show: true,
|
99
|
-
classes: 'cosy:opacity-0 cosy:hover:opacity-100 cosy:transition-opacity'
|
100
|
-
};
|
101
|
-
}
|
102
|
-
});
|
103
|
-
|
104
|
-
const selectSize = (size: SizePreset) => {
|
105
|
-
emit('update:selectedSize', size);
|
106
|
-
};
|
107
|
-
|
108
|
-
const selectBackground = (index: number) => {
|
109
|
-
emit('update:selectedBgIndex', index);
|
110
|
-
};
|
111
|
-
|
112
|
-
const clearStoredSize = () => {
|
113
|
-
emit('clear-stored-size');
|
114
|
-
isDropdownOpen.value = false;
|
115
|
-
};
|
116
|
-
|
117
|
-
const downloadImage = () => {
|
118
|
-
emit('download-image');
|
119
|
-
isDropdownOpen.value = false;
|
120
|
-
};
|
121
|
-
|
122
|
-
return {
|
123
|
-
isDropdownOpen,
|
124
|
-
toggleDropdown,
|
125
|
-
downloadButtonStyles,
|
126
|
-
selectSize,
|
127
|
-
selectBackground,
|
128
|
-
clearStoredSize,
|
129
|
-
downloadImage,
|
130
|
-
bgClasses,
|
131
|
-
sizePresets
|
132
|
-
};
|
133
|
-
}
|
134
|
-
});
|
135
|
-
</script>
|
136
|
-
|
137
|
-
<template>
|
138
|
-
<div v-if="downloadButtonStyles.show" class="cosy:absolute cosy:top-4 cosy:left-4"
|
139
|
-
:class="downloadButtonStyles.classes">
|
140
|
-
<div class="cosy:relative" data-dropdown>
|
141
|
-
<button
|
142
|
-
class="cosy:bg-yellow-500/30 cosy:backdrop-blur-sm cosy:p-2 cosy:rounded-lg hover:cosy:bg-yellow-500/40"
|
143
|
-
@click="toggleDropdown">
|
144
|
-
<RiDownloadLine class="cosy:w-6 cosy:h-6 cosy:text-white" />
|
145
|
-
</button>
|
146
|
-
<!-- Size selection dropdown -->
|
147
|
-
<div v-if="isDropdownOpen"
|
148
|
-
class="cosy:absolute cosy:left-0 cosy:mt-2 cosy:w-96 cosy:bg-white dark:cosy:bg-gray-800 cosy:rounded-lg cosy:shadow-lg cosy:py-2 cosy:z-50">
|
149
|
-
<!-- Component size presets -->
|
150
|
-
<div class="cosy:px-4 cosy:py-2 cosy:border-b cosy:border-gray-200 dark:cosy:border-gray-700">
|
151
|
-
<div class="cosy:grid cosy:grid-cols-3 cosy:gap-2">
|
152
|
-
<button v-for="preset in sizePresets" :key="preset.name" :class="[
|
153
|
-
'cosy:p-2 cosy:text-left cosy:rounded cosy:text-sm',
|
154
|
-
selectedSize.name === preset.name
|
155
|
-
? 'cosy:bg-yellow-500/30 cosy:text-yellow-900 dark:cosy:text-yellow-100'
|
156
|
-
: 'hover:cosy:bg-gray-100 dark:hover:cosy:bg-gray-700'
|
157
|
-
]" @click="selectSize(preset)">
|
158
|
-
<div class="cosy:flex cosy:flex-col">
|
159
|
-
<span class="cosy:font-medium">{{ preset.name }}</span>
|
160
|
-
<span class="cosy:text-xs cosy:text-gray-500 dark:cosy:text-gray-400">
|
161
|
-
{{ preset.width.replace('cosy:w-[', '').replace(']', '') }}
|
162
|
-
</span>
|
163
|
-
</div>
|
164
|
-
</button>
|
165
|
-
<!-- Clear size button -->
|
166
|
-
<button
|
167
|
-
class="cosy:p-2 cosy:text-left cosy:rounded cosy:text-sm hover:cosy:bg-gray-100 dark:hover:cosy:bg-gray-700"
|
168
|
-
@click="clearStoredSize">
|
169
|
-
<div class="cosy:flex cosy:flex-col">
|
170
|
-
<span class="cosy:font-medium cosy:text-red-600 dark:cosy:text-red-400">清除记住的尺寸</span>
|
171
|
-
<span class="cosy:text-xs cosy:text-gray-500 dark:cosy:text-gray-400">重置为默认尺寸</span>
|
172
|
-
</div>
|
173
|
-
</button>
|
174
|
-
</div>
|
175
|
-
</div>
|
176
|
-
<!-- Background settings -->
|
177
|
-
<div class="cosy:px-4 cosy:py-2 cosy:border-b cosy:border-gray-200 dark:cosy:border-gray-700">
|
178
|
-
<div class="cosy:mt-2">
|
179
|
-
<div class="cosy:grid cosy:grid-cols-8 cosy:gap-2">
|
180
|
-
<button v-for="(className, index) in bgClasses" :key="index" :class="[
|
181
|
-
className,
|
182
|
-
'cosy:w-8 cosy:h-8 cosy:rounded-lg cosy:border-2',
|
183
|
-
selectedBgIndex === index ? 'cosy:border-yellow-500' : 'cosy:border-transparent'
|
184
|
-
]" @click="selectBackground(index)" />
|
185
|
-
</div>
|
186
|
-
</div>
|
187
|
-
</div>
|
188
|
-
<!-- Size options -->
|
189
|
-
<div class="cosy:p-4">
|
190
|
-
<button
|
191
|
-
class="cosy:w-full cosy:p-2 cosy:text-center cosy:rounded hover:cosy:bg-gray-100 dark:hover:cosy:bg-gray-700"
|
192
|
-
@click="downloadImage">
|
193
|
-
<div class="cosy:flex cosy:items-center cosy:justify-center cosy:gap-2">
|
194
|
-
<RiDownloadLine class="cosy:w-4 cosy:h-4" />
|
195
|
-
<span class="cosy:font-medium">下载图片</span>
|
196
|
-
</div>
|
197
|
-
</button>
|
198
|
-
</div>
|
199
|
-
</div>
|
200
|
-
</div>
|
201
|
-
</div>
|
202
|
-
</template>
|
@@ -1,32 +0,0 @@
|
|
1
|
-
<!--
|
2
|
-
@component BannerBox.Basic
|
3
|
-
|
4
|
-
@description
|
5
|
-
BannerBox 组件的基础示例,展示最基本的横幅容器用法。
|
6
|
-
|
7
|
-
@usage
|
8
|
-
```vue
|
9
|
-
<BannerBoxExamples.Basic />
|
10
|
-
```
|
11
|
-
-->
|
12
|
-
|
13
|
-
<script lang="ts">
|
14
|
-
import '../../app.css'
|
15
|
-
import { defineComponent } from 'vue'
|
16
|
-
import BannerBox from './BannerBox.vue'
|
17
|
-
|
18
|
-
export default defineComponent({
|
19
|
-
name: 'BannerBoxBasicExample',
|
20
|
-
components: {
|
21
|
-
BannerBox
|
22
|
-
}
|
23
|
-
})
|
24
|
-
</script>
|
25
|
-
|
26
|
-
<template>
|
27
|
-
<BannerBox>
|
28
|
-
<div class="cosy:flex cosy:items-center cosy:justify-center cosy:min-h-[200px]">
|
29
|
-
<h2 class="cosy:text-3xl cosy:font-bold">欢迎使用 BannerBox</h2>
|
30
|
-
</div>
|
31
|
-
</BannerBox>
|
32
|
-
</template>
|