@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
@@ -0,0 +1,96 @@
|
|
1
|
+
---
|
2
|
+
/**
|
3
|
+
* @component TeamMembers
|
4
|
+
*
|
5
|
+
* @description
|
6
|
+
* TeamMembers 组件用于展示团队成员列表,以网格布局呈现多个 TeamMember 组件。
|
7
|
+
* 支持响应式布局,可以根据屏幕大小自动调整列数。
|
8
|
+
*
|
9
|
+
* @design
|
10
|
+
* 设计理念:
|
11
|
+
* 1. 一致性展示 - 以统一的卡片形式展示团队成员信息
|
12
|
+
* 2. 响应式布局 - 在不同屏幕尺寸下自动调整列数
|
13
|
+
* 3. 灵活配置 - 支持自定义列数和样式
|
14
|
+
*
|
15
|
+
* @usage
|
16
|
+
* 基本用法:
|
17
|
+
* ```astro
|
18
|
+
* <TeamMembers members={teamData} />
|
19
|
+
* ```
|
20
|
+
*
|
21
|
+
* 自定义列数:
|
22
|
+
* ```astro
|
23
|
+
* <TeamMembers members={teamData} columns={2} />
|
24
|
+
* ```
|
25
|
+
*
|
26
|
+
* 添加自定义类名:
|
27
|
+
* ```astro
|
28
|
+
* <TeamMembers members={teamData} class="mt-8" />
|
29
|
+
* ```
|
30
|
+
*/
|
31
|
+
|
32
|
+
import TeamMember from './TeamMember.astro';
|
33
|
+
import '../../style.ts';
|
34
|
+
import type { ImageSource } from '../types/image.ts';
|
35
|
+
|
36
|
+
interface SocialLink {
|
37
|
+
platform: 'github' | 'twitter' | 'linkedin' | 'website' | 'email';
|
38
|
+
url: string;
|
39
|
+
}
|
40
|
+
|
41
|
+
interface TeamMemberData {
|
42
|
+
name: string;
|
43
|
+
role: string;
|
44
|
+
avatar: ImageSource;
|
45
|
+
bio: string;
|
46
|
+
socialLinks?: SocialLink[];
|
47
|
+
}
|
48
|
+
|
49
|
+
interface Props {
|
50
|
+
/**
|
51
|
+
* 团队成员数据数组
|
52
|
+
*/
|
53
|
+
members: TeamMemberData[];
|
54
|
+
/**
|
55
|
+
* 网格列数
|
56
|
+
* @default 3
|
57
|
+
*/
|
58
|
+
columns?: 2 | 3 | 4;
|
59
|
+
/**
|
60
|
+
* 自定义类名
|
61
|
+
*/
|
62
|
+
class?: string;
|
63
|
+
}
|
64
|
+
|
65
|
+
const { members, columns = 3, class: className = '' } = Astro.props;
|
66
|
+
|
67
|
+
// 使用类型断言确保 columns 是有效的键
|
68
|
+
const columnsValue = columns as 2 | 3 | 4;
|
69
|
+
|
70
|
+
// 根据列数生成对应的类名
|
71
|
+
const getGridClasses = (cols: 2 | 3 | 4) => {
|
72
|
+
const baseClass = 'cosy:grid-cols-1';
|
73
|
+
const mdClass = 'cosy:md:grid-cols-2';
|
74
|
+
|
75
|
+
let lgClass = 'cosy:lg:grid-cols-3';
|
76
|
+
if (cols === 2) {
|
77
|
+
lgClass = 'cosy:lg:grid-cols-2';
|
78
|
+
} else if (cols === 4) {
|
79
|
+
lgClass = 'cosy:lg:grid-cols-4';
|
80
|
+
}
|
81
|
+
|
82
|
+
return [baseClass, mdClass, lgClass];
|
83
|
+
};
|
84
|
+
---
|
85
|
+
|
86
|
+
<div class:list={['cosy:w-full cosy:mx-auto cosy:px-4', className]}>
|
87
|
+
<div class:list={['cosy:grid cosy:gap-6', ...getGridClasses(columnsValue)]}>
|
88
|
+
{
|
89
|
+
members.map((member: TeamMemberData) => (
|
90
|
+
<div class="cosy:transition-all cosy:hover:-translate-y-1 cosy:duration-300 cosy:transform">
|
91
|
+
<TeamMember {...member} />
|
92
|
+
</div>
|
93
|
+
))
|
94
|
+
}
|
95
|
+
</div>
|
96
|
+
</div>
|
@@ -0,0 +1,30 @@
|
|
1
|
+
import TeamMember from './TeamMember.astro';
|
2
|
+
import TeamMemberBasic from './TeamMemberBasic.astro';
|
3
|
+
import TeamMemberWithSocial from './TeamMemberWithSocial.astro';
|
4
|
+
import TeamMemberCustomStyle from './TeamMemberCustomStyle.astro';
|
5
|
+
import TeamMemberGroup from './TeamMemberGroup.astro';
|
6
|
+
import TeamMemebrs from './TeamMembers.astro';
|
7
|
+
|
8
|
+
import BasicSourceCode from './TeamMemberBasic.astro?raw';
|
9
|
+
import WithSocialSourceCode from './TeamMemberWithSocial.astro?raw';
|
10
|
+
import CustomStyleSourceCode from './TeamMemberCustomStyle.astro?raw';
|
11
|
+
import GroupSourceCode from './TeamMemberGroup.astro?raw';
|
12
|
+
|
13
|
+
import { extractSimpleExample } from '../utils/component';
|
14
|
+
|
15
|
+
export {
|
16
|
+
TeamMember,
|
17
|
+
TeamMemberBasic,
|
18
|
+
TeamMemberWithSocial,
|
19
|
+
TeamMemberCustomStyle,
|
20
|
+
TeamMemberGroup,
|
21
|
+
TeamMemebrs,
|
22
|
+
};
|
23
|
+
|
24
|
+
// Export example codes
|
25
|
+
export const TeamMemberExampleCodes = {
|
26
|
+
Basic: extractSimpleExample(BasicSourceCode, 'TeamMember'),
|
27
|
+
WithSocial: extractSimpleExample(WithSocialSourceCode, 'TeamMember'),
|
28
|
+
CustomStyle: extractSimpleExample(CustomStyleSourceCode, 'TeamMember'),
|
29
|
+
Group: extractSimpleExample(GroupSourceCode, 'TeamMember'),
|
30
|
+
};
|
@@ -0,0 +1,189 @@
|
|
1
|
+
---
|
2
|
+
/**
|
3
|
+
* @component Text
|
4
|
+
*
|
5
|
+
* @description
|
6
|
+
* Text 组件用于创建各种文本元素,提供一致的排版样式和灵活的定制选项。
|
7
|
+
*
|
8
|
+
* @design
|
9
|
+
* 设计理念:
|
10
|
+
* 1. 一致性 - 确保整个应用中文本样式的一致性
|
11
|
+
* 2. 可读性 - 优化文本的可读性和舒适度
|
12
|
+
* 3. 可定制性 - 支持多种配置选项,适应不同场景需求
|
13
|
+
* 4. 无障碍性 - 遵循语义化HTML标准,确保屏幕阅读器可以正确解析内容
|
14
|
+
*
|
15
|
+
* 视觉特点:
|
16
|
+
* - 不同的字体大小和行高
|
17
|
+
* - 可选的字体粗细和样式
|
18
|
+
* - 可定制的颜色和对齐方式
|
19
|
+
* - 支持截断和省略号
|
20
|
+
*
|
21
|
+
* @usage
|
22
|
+
* 基本用法:
|
23
|
+
* ```astro
|
24
|
+
* <Text>这是一段普通文本</Text>
|
25
|
+
* ```
|
26
|
+
*
|
27
|
+
* 不同大小:
|
28
|
+
* ```astro
|
29
|
+
* <Text size="xs">超小文本</Text>
|
30
|
+
* <Text size="sm">小文本</Text>
|
31
|
+
* <Text size="md">中等文本</Text>
|
32
|
+
* <Text size="lg">大文本</Text>
|
33
|
+
* <Text size="xl">超大文本</Text>
|
34
|
+
* ```
|
35
|
+
*
|
36
|
+
* 不同颜色:
|
37
|
+
* ```astro
|
38
|
+
* <Text color="primary">主要颜色文本</Text>
|
39
|
+
* <Text color="secondary">次要颜色文本</Text>
|
40
|
+
* <Text color="accent">强调色文本</Text>
|
41
|
+
* <Text color="muted">柔和色文本</Text>
|
42
|
+
* ```
|
43
|
+
*
|
44
|
+
* 字体粗细:
|
45
|
+
* ```astro
|
46
|
+
* <Text weight="light">细体文本</Text>
|
47
|
+
* <Text weight="normal">常规文本</Text>
|
48
|
+
* <Text weight="medium">中等粗文本</Text>
|
49
|
+
* <Text weight="semibold">半粗体文本</Text>
|
50
|
+
* <Text weight="bold">粗体文本</Text>
|
51
|
+
* ```
|
52
|
+
*
|
53
|
+
* 文本对齐:
|
54
|
+
* ```astro
|
55
|
+
* <Text align="left">左对齐文本</Text>
|
56
|
+
* <Text align="center">居中对齐文本</Text>
|
57
|
+
* <Text align="right">右对齐文本</Text>
|
58
|
+
* <Text align="justify">两端对齐文本</Text>
|
59
|
+
* ```
|
60
|
+
*
|
61
|
+
* 文本截断:
|
62
|
+
* ```astro
|
63
|
+
* <Text truncate>这是一段很长的文本,将会被截断并显示省略号...</Text>
|
64
|
+
* ```
|
65
|
+
*
|
66
|
+
* 组合使用:
|
67
|
+
* ```astro
|
68
|
+
* <Text
|
69
|
+
* size="lg"
|
70
|
+
* color="primary"
|
71
|
+
* weight="bold"
|
72
|
+
* align="center"
|
73
|
+
* class="my-4"
|
74
|
+
* >
|
75
|
+
* 这是一段重要的提示文本
|
76
|
+
* </Text>
|
77
|
+
* ```
|
78
|
+
*
|
79
|
+
* @props
|
80
|
+
* @prop {string} [as='p'] - 要渲染的HTML元素,如 'p', 'span', 'div' 等
|
81
|
+
* @prop {'xs'|'sm'|'md'|'lg'|'xl'} [size='md'] - 文本大小
|
82
|
+
* @prop {'light'|'normal'|'medium'|'semibold'|'bold'} [weight='normal'] - 字体粗细
|
83
|
+
* @prop {'default'|'primary'|'secondary'|'accent'|'muted'} [color='default'] - 文本颜色
|
84
|
+
* @prop {'left'|'center'|'right'|'justify'} [align='left'] - 文本对齐方式
|
85
|
+
* @prop {boolean} [italic=false] - 是否使用斜体
|
86
|
+
* @prop {boolean} [underline=false] - 是否添加下划线
|
87
|
+
* @prop {boolean} [truncate=false] - 是否截断文本并显示省略号
|
88
|
+
* @prop {string} [class] - 自定义 CSS 类名
|
89
|
+
*
|
90
|
+
* @slots
|
91
|
+
* @slot default - 文本内容
|
92
|
+
*
|
93
|
+
* @accessibility
|
94
|
+
* - 使用语义化的HTML元素
|
95
|
+
* - 确保文本颜色与背景色的对比度符合WCAG标准
|
96
|
+
*/
|
97
|
+
|
98
|
+
import '../../style.ts';
|
99
|
+
|
100
|
+
export interface Props {
|
101
|
+
as?: string;
|
102
|
+
size?: 'xs' | 'sm' | 'md' | 'lg' | 'xl';
|
103
|
+
weight?: 'light' | 'normal' | 'medium' | 'semibold' | 'bold';
|
104
|
+
color?: 'default' | 'primary' | 'secondary' | 'accent' | 'muted';
|
105
|
+
align?: 'left' | 'center' | 'right' | 'justify';
|
106
|
+
italic?: boolean;
|
107
|
+
underline?: boolean;
|
108
|
+
truncate?: boolean;
|
109
|
+
class?: string;
|
110
|
+
}
|
111
|
+
|
112
|
+
const {
|
113
|
+
as: Element = 'p',
|
114
|
+
size = 'md',
|
115
|
+
weight = 'normal',
|
116
|
+
color = 'default',
|
117
|
+
align = 'left',
|
118
|
+
italic = false,
|
119
|
+
underline = false,
|
120
|
+
truncate = false,
|
121
|
+
class: className = '',
|
122
|
+
} = Astro.props;
|
123
|
+
|
124
|
+
// 根据大小设置样式
|
125
|
+
const sizeClasses = {
|
126
|
+
xs: 'cosy:text-xs',
|
127
|
+
sm: 'cosy:text-sm',
|
128
|
+
md: 'cosy:text-base',
|
129
|
+
lg: 'cosy:text-lg',
|
130
|
+
xl: 'cosy:text-xl',
|
131
|
+
};
|
132
|
+
const sizeClass = sizeClasses[size as keyof typeof sizeClasses];
|
133
|
+
|
134
|
+
// 根据粗细设置样式
|
135
|
+
const weightClasses = {
|
136
|
+
light: 'cosy:font-light',
|
137
|
+
normal: 'cosy:font-normal',
|
138
|
+
medium: 'cosy:font-medium',
|
139
|
+
semibold: 'cosy:font-semibold',
|
140
|
+
bold: 'cosy:font-bold',
|
141
|
+
};
|
142
|
+
const weightClass = weightClasses[weight as keyof typeof weightClasses];
|
143
|
+
|
144
|
+
// 根据颜色设置样式
|
145
|
+
const colorClasses = {
|
146
|
+
default: 'cosy:text-gray-900 cosy:dark:text-gray-100',
|
147
|
+
primary: 'cosy:text-primary-600 cosy:dark:text-primary-400',
|
148
|
+
secondary: 'cosy:text-secondary-600 cosy:dark:text-secondary-400',
|
149
|
+
accent: 'cosy:text-accent-600 cosy:dark:text-accent-400',
|
150
|
+
muted: 'cosy:text-gray-600 cosy:dark:text-gray-400',
|
151
|
+
};
|
152
|
+
const colorClass = colorClasses[color as keyof typeof colorClasses];
|
153
|
+
|
154
|
+
// 根据对齐方式设置样式
|
155
|
+
const alignClasses = {
|
156
|
+
left: 'cosy:text-left',
|
157
|
+
center: 'cosy:text-center',
|
158
|
+
right: 'cosy:text-right',
|
159
|
+
justify: 'cosy:text-justify',
|
160
|
+
};
|
161
|
+
const alignClass = alignClasses[align as keyof typeof alignClasses];
|
162
|
+
|
163
|
+
// 其他样式
|
164
|
+
const italicClass = italic ? 'cosy:italic' : '';
|
165
|
+
const underlineClass = underline ? 'cosy:underline' : '';
|
166
|
+
const truncateClass = truncate ? 'cosy:truncate' : '';
|
167
|
+
|
168
|
+
// 组合所有类名
|
169
|
+
const combinedClass = `text ${sizeClass} ${weightClass} ${colorClass} ${alignClass} ${italicClass} ${underlineClass} ${truncateClass} ${className}`;
|
170
|
+
---
|
171
|
+
|
172
|
+
<Element class={combinedClass}>
|
173
|
+
<slot />
|
174
|
+
</Element>
|
175
|
+
|
176
|
+
<style>
|
177
|
+
.text {
|
178
|
+
margin-bottom: 1em;
|
179
|
+
line-height: 1.5;
|
180
|
+
}
|
181
|
+
|
182
|
+
/* 确保截断文本正常工作 */
|
183
|
+
.truncate {
|
184
|
+
white-space: nowrap;
|
185
|
+
overflow: hidden;
|
186
|
+
text-overflow: ellipsis;
|
187
|
+
max-width: 100%;
|
188
|
+
}
|
189
|
+
</style>
|
@@ -0,0 +1,12 @@
|
|
1
|
+
---
|
2
|
+
import Text from './Text.astro';
|
3
|
+
---
|
4
|
+
|
5
|
+
<Text>这是一段普通文本</Text>
|
6
|
+
<Text size="xl" color="primary" weight="bold">超大主色粗体文本</Text>
|
7
|
+
<Text size="sm" color="secondary" italic>小号次色斜体文本</Text>
|
8
|
+
<Text size="lg" align="center" underline>居中大号带下划线文本</Text>
|
9
|
+
<Text size="md" weight="light" color="muted">中号柔和色细体文本</Text>
|
10
|
+
<Text truncate style="max-width: 120px; display: block;"
|
11
|
+
>这是一段很长的文本,将会被截断并显示省略号...</Text
|
12
|
+
>
|
@@ -0,0 +1,11 @@
|
|
1
|
+
---
|
2
|
+
import Text from './Text.astro';
|
3
|
+
---
|
4
|
+
|
5
|
+
<div class="cosy:space-y-4">
|
6
|
+
<Text size="xs">超小号文本 (xs)</Text>
|
7
|
+
<Text size="sm">小号文本 (sm)</Text>
|
8
|
+
<Text size="md">中号文本 (md)</Text>
|
9
|
+
<Text size="lg">大号文本 (lg)</Text>
|
10
|
+
<Text size="xl">超大号文本 (xl)</Text>
|
11
|
+
</div>
|
@@ -0,0 +1,11 @@
|
|
1
|
+
import Text from './Text.astro';
|
2
|
+
import TextBasic from './TextBasic.astro';
|
3
|
+
import BasicSourceCode from './TextBasic.astro?raw';
|
4
|
+
import { extractSimpleExample } from '../utils/component';
|
5
|
+
|
6
|
+
export { Text, TextBasic };
|
7
|
+
|
8
|
+
// 导出示例源代码
|
9
|
+
export const TextExampleCodes = {
|
10
|
+
Basic: extractSimpleExample(BasicSourceCode, 'Text'),
|
11
|
+
};
|
@@ -0,0 +1,45 @@
|
|
1
|
+
---
|
2
|
+
/**
|
3
|
+
* @component ThemeItem
|
4
|
+
*
|
5
|
+
* @description
|
6
|
+
* ThemeItem 组件用于主题切换菜单中的单个主题项。
|
7
|
+
* 它基于 Button 组件,提供了主题切换的交互功能。
|
8
|
+
*
|
9
|
+
* @usage
|
10
|
+
* 基本用法:
|
11
|
+
* ```astro
|
12
|
+
* <ThemeItem theme="light" label="浅色主题" />
|
13
|
+
* <ThemeItem theme="dark" label="深色主题" />
|
14
|
+
* ```
|
15
|
+
*/
|
16
|
+
|
17
|
+
import { Button } from '../../index-astro';
|
18
|
+
import '../../style.ts';
|
19
|
+
|
20
|
+
interface Props {
|
21
|
+
/**
|
22
|
+
* 主题名称
|
23
|
+
*/
|
24
|
+
theme: string;
|
25
|
+
/**
|
26
|
+
* 显示的标签文本
|
27
|
+
*/
|
28
|
+
label: string;
|
29
|
+
/**
|
30
|
+
* 自定义类名
|
31
|
+
*/
|
32
|
+
class?: string;
|
33
|
+
}
|
34
|
+
|
35
|
+
const { theme, label, class: className = '' } = Astro.props;
|
36
|
+
---
|
37
|
+
|
38
|
+
<Button
|
39
|
+
variant="ghost"
|
40
|
+
size="sm"
|
41
|
+
block
|
42
|
+
class={`cosy:text-left cosy:justify-start ${className} cosy:theme-item`}
|
43
|
+
data-theme={theme}>
|
44
|
+
{label}
|
45
|
+
</Button>
|
@@ -0,0 +1,121 @@
|
|
1
|
+
---
|
2
|
+
/**
|
3
|
+
* @component ThemeSwitcher
|
4
|
+
*
|
5
|
+
* @description
|
6
|
+
* ThemeSwitcher 组件提供一个主题切换下拉菜单,允许用户在多个预定义主题之间切换。
|
7
|
+
* 组件会记住用户的主题选择,并在页面重新加载或访问网站的其他页面时保持该主题。
|
8
|
+
*
|
9
|
+
* @design
|
10
|
+
* 设计理念:
|
11
|
+
* 1. 简洁直观 - 使用图标按钮和下拉菜单提供清晰的交互方式
|
12
|
+
* 2. 主题持久化 - 使用本地存储记住用户的主题选择
|
13
|
+
* 3. 无缝集成 - 与 DaisyUI 主题系统无缝集成
|
14
|
+
* 4. 广泛兼容 - 支持多种主题选项,适应不同的视觉偏好
|
15
|
+
*
|
16
|
+
* @usage
|
17
|
+
* 基本用法:
|
18
|
+
* ```astro
|
19
|
+
* <ThemeSwitcher />
|
20
|
+
* ```
|
21
|
+
*
|
22
|
+
* 自定义样式:
|
23
|
+
* ```astro
|
24
|
+
* <ThemeSwitcher class="cosy:top-4 cosy:right-4 cosy:fixed" />
|
25
|
+
* ```
|
26
|
+
*/
|
27
|
+
|
28
|
+
import { SunCloudyIcon } from '../../index-astro';
|
29
|
+
import ThemeItem from './ThemeItem.astro';
|
30
|
+
import '../../style.ts';
|
31
|
+
|
32
|
+
interface Props {
|
33
|
+
/**
|
34
|
+
* 自定义类名
|
35
|
+
*/
|
36
|
+
class?: string;
|
37
|
+
}
|
38
|
+
|
39
|
+
const { class: className } = Astro.props;
|
40
|
+
|
41
|
+
const themes = [
|
42
|
+
{ id: 'default', name: 'Default' },
|
43
|
+
{ id: 'light', name: 'Light' },
|
44
|
+
{ id: 'dark', name: 'Dark' },
|
45
|
+
{ id: 'pastel', name: 'Pastel' },
|
46
|
+
{ id: 'lemonade', name: 'Lemonade' },
|
47
|
+
{ id: 'cupcake', name: 'Cupcake' },
|
48
|
+
{ id: 'nord', name: 'Nord' },
|
49
|
+
{ id: 'business', name: 'Business' },
|
50
|
+
{ id: 'luxury', name: 'Luxury' },
|
51
|
+
];
|
52
|
+
---
|
53
|
+
|
54
|
+
<!-- 主题切换按钮 -->
|
55
|
+
<div class:list={['cosy:dropdown-end cosy:dropdown', className]}>
|
56
|
+
<div tabindex="0" role="button" class:list={['cosy:btn cosy:btn-ghost']}>
|
57
|
+
<SunCloudyIcon size="16px" class="cosy:w-4 cosy:h-4" />
|
58
|
+
</div>
|
59
|
+
<ul
|
60
|
+
tabindex={0}
|
61
|
+
class="cosy:dropdown-content cosy:menu cosy:bg-base-100 cosy:dark:bg-neutral-800 cosy:rounded-box cosy:z-[1] cosy:w-56 cosy:p-2 cosy:shadow-lg">
|
62
|
+
{themes.map((theme) => <ThemeItem theme={theme.id} label={theme.name} />)}
|
63
|
+
</ul>
|
64
|
+
</div>
|
65
|
+
|
66
|
+
<script>
|
67
|
+
import { createThemeManager } from '../utils/theme';
|
68
|
+
|
69
|
+
const themeManager = createThemeManager();
|
70
|
+
|
71
|
+
function updateActiveTheme() {
|
72
|
+
const currentTheme =
|
73
|
+
document.documentElement.getAttribute('data-theme') || 'default';
|
74
|
+
document.querySelectorAll('.cosy\\:theme-item').forEach((item) => {
|
75
|
+
const isActive = item.getAttribute('data-theme') === currentTheme;
|
76
|
+
item.setAttribute('data-active', String(isActive));
|
77
|
+
|
78
|
+
// 更新视觉状态
|
79
|
+
const checkmark = item.querySelector('.cosy\\:theme-check');
|
80
|
+
if (checkmark) {
|
81
|
+
if (isActive) {
|
82
|
+
checkmark.classList.remove('cosy:hidden');
|
83
|
+
item.classList.add('cosy:bg-base-200', 'cosy:font-medium');
|
84
|
+
} else {
|
85
|
+
checkmark.classList.add('cosy:hidden');
|
86
|
+
item.classList.remove('cosy:bg-base-200', 'cosy:font-medium');
|
87
|
+
}
|
88
|
+
}
|
89
|
+
});
|
90
|
+
}
|
91
|
+
|
92
|
+
// 初始化主题切换按钮
|
93
|
+
function initThemeSwitcher() {
|
94
|
+
document.querySelectorAll('.cosy\\:theme-item').forEach((item) => {
|
95
|
+
item.addEventListener('click', () => {
|
96
|
+
console.log('Theme item clicked:', item);
|
97
|
+
const theme = item.getAttribute('data-theme');
|
98
|
+
if (theme) {
|
99
|
+
themeManager.setTheme(theme);
|
100
|
+
updateActiveTheme();
|
101
|
+
}
|
102
|
+
});
|
103
|
+
});
|
104
|
+
}
|
105
|
+
|
106
|
+
// 初始加载时初始化
|
107
|
+
function initialize() {
|
108
|
+
themeManager.initialize();
|
109
|
+
initThemeSwitcher();
|
110
|
+
updateActiveTheme();
|
111
|
+
}
|
112
|
+
|
113
|
+
// 初始化
|
114
|
+
document.addEventListener('DOMContentLoaded', initialize);
|
115
|
+
|
116
|
+
// Astro view transitions 后重新初始化
|
117
|
+
document.addEventListener('astro:after-swap', initialize);
|
118
|
+
|
119
|
+
// 确保脚本加载后立即初始化
|
120
|
+
initialize();
|
121
|
+
</script>
|
@@ -0,0 +1,11 @@
|
|
1
|
+
import ThemeSwitcher from './ThemeSwitcher.astro';
|
2
|
+
import ThemeSwitcherBasic from './ThemeSwitcherBasic.astro';
|
3
|
+
import BasicSourceCode from './ThemeSwitcherBasic.astro?raw';
|
4
|
+
import { extractSimpleExample } from '../utils/component';
|
5
|
+
|
6
|
+
export { ThemeSwitcher, ThemeSwitcherBasic };
|
7
|
+
|
8
|
+
// 导出示例源代码
|
9
|
+
export const ThemeSwitcherExampleCodes = {
|
10
|
+
Basic: extractSimpleExample(BasicSourceCode, 'ThemeSwitcher'),
|
11
|
+
};
|