@coffic/cosy-ui 0.7.2 → 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/{alert → src-astro/alert}/Alert.astro +39 -33
- package/dist/{alert → src-astro/alert}/EAlertBasic.astro +1 -1
- package/dist/{alert → src-astro/alert}/EAlertBasicContainer.astro +4 -4
- package/dist/src-astro/alert/EAlertCustomStyle.astro +16 -0
- package/dist/{alert → src-astro/alert}/EAlertCustomStyleContainer.astro +4 -4
- 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/{alert → src-astro/alert}/EAlertTypesContainer.astro +21 -21
- package/dist/src-astro/alert/EAlertWarning.astro +6 -0
- package/dist/{alert → src-astro/alert}/EAlertWithTitle.astro +2 -2
- package/dist/{alert → src-astro/alert}/EAlertWithTitleContainer.astro +4 -4
- package/dist/{alert → src-astro/alert}/index.ts +9 -9
- package/dist/{article → src-astro/article}/Article.astro +17 -17
- package/dist/src-astro/article/ArticleBasic.astro +35 -0
- package/dist/{article → src-astro/article}/index.ts +1 -1
- 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/{banner → src-astro/banner}/BannerBasic.astro +1 -1
- package/dist/src-astro/banner/BannerCustomStyle.astro +8 -0
- package/dist/{banner → src-astro/banner}/BannerDanger.astro +1 -1
- package/dist/{banner → src-astro/banner}/BannerFadeIn.astro +1 -1
- package/dist/{banner → src-astro/banner}/BannerInfo.astro +1 -1
- package/dist/{banner → src-astro/banner}/BannerPrimary.astro +1 -1
- package/dist/{banner → src-astro/banner}/BannerSecondary.astro +1 -1
- package/dist/{banner → src-astro/banner}/BannerSlideUp.astro +1 -1
- package/dist/{banner → src-astro/banner}/BannerSuccess.astro +1 -1
- package/dist/{banner → src-astro/banner}/BannerWarning.astro +1 -1
- package/dist/{banner → src-astro/banner}/index.ts +15 -2
- package/dist/src-astro/button/Button.astro +192 -0
- package/dist/src-astro/button/ButtonBasic.astro +18 -0
- package/dist/{button → src-astro/button}/ButtonBasicContainer.astro +4 -4
- package/dist/src-astro/button/ButtonIconBoth.astro +9 -0
- package/dist/{button → src-astro/button}/ButtonIconLeft.astro +2 -2
- package/dist/{button → src-astro/button}/ButtonIconRight.astro +2 -2
- package/dist/{button → src-astro/button}/ButtonLinkContainer.astro +9 -9
- package/dist/{button → src-astro/button}/ButtonLinkExternal.astro +2 -2
- package/dist/src-astro/button/ButtonShapes.astro +23 -0
- package/dist/{button → src-astro/button}/ButtonShapesContainer.astro +16 -12
- package/dist/src-astro/button/ButtonSizes.astro +15 -0
- package/dist/{button → src-astro/button}/ButtonSizesContainer.astro +4 -4
- package/dist/src-astro/button/ButtonStates.astro +12 -0
- package/dist/{button → src-astro/button}/ButtonStatesContainer.astro +4 -4
- package/dist/src-astro/button/ButtonVariants.astro +14 -0
- package/dist/{button → src-astro/button}/ButtonVariantsContainer.astro +45 -36
- package/dist/{button → src-astro/button}/ButtonWidth.astro +2 -2
- package/dist/{button → src-astro/button}/ButtonWidthContainer.astro +9 -9
- package/dist/src-astro/button/ButtonWithIcons.astro +25 -0
- package/dist/{button → src-astro/button}/ButtonWithIconsContainer.astro +16 -12
- package/dist/{button → src-astro/button}/index_astro.ts +29 -31
- package/dist/{card → src-astro/card}/Card.astro +75 -15
- 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/{code-container → src-astro/code-container}/ECodeContainerBasic.astro +3 -3
- package/dist/{code-container → src-astro/code-container}/ECodeContainerMultiple.astro +16 -16
- package/dist/{code-container → src-astro/code-container}/index.ts +2 -2
- 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/{container → src-astro/container}/EContainerBasicContainer.astro +4 -4
- 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/{container → src-astro/container}/EContainerFlexContainer.astro +20 -20
- package/dist/src-astro/container/EContainerFlexRow.astro +23 -0
- package/dist/src-astro/container/EContainerPadding.astro +32 -0
- package/dist/{container → src-astro/container}/EContainerPaddingContainer.astro +4 -4
- package/dist/src-astro/container/EContainerSizes.astro +36 -0
- package/dist/{container → src-astro/container}/EContainerSizesContainer.astro +4 -4
- package/dist/{container → src-astro/container}/index.ts +8 -8
- package/dist/{cosy.ts → src-astro/cosy.ts} +1 -1
- 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/{database → src-astro/database}/ExperimentDB.ts +51 -47
- package/dist/{database → src-astro/database}/LessonDB.ts +51 -47
- package/dist/src-astro/database/MetaDB.ts +74 -0
- package/dist/src-astro/entities/BaseDoc.ts +207 -0
- package/dist/{entities → src-astro/entities}/BlogDoc.ts +50 -47
- 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/{flex → src-astro/flex}/Flex.astro +31 -31
- package/dist/src-astro/flex/FlexBasic.astro +26 -0
- package/dist/{flex → src-astro/flex}/index.ts +1 -1
- package/dist/src-astro/footer/EFooterBasic.astro +18 -0
- package/dist/{footer → src-astro/footer}/EFooterBasicContainer.astro +4 -4
- package/dist/src-astro/footer/EFooterComplete.astro +50 -0
- package/dist/{footer → src-astro/footer}/EFooterCompleteContainer.astro +4 -4
- package/dist/{footer → src-astro/footer}/EFooterFeaturesContainer.astro +24 -24
- package/dist/src-astro/footer/EFooterWithLogo.astro +28 -0
- package/dist/{footer → src-astro/footer}/EFooterWithLogoContainer.astro +4 -4
- package/dist/src-astro/footer/EFooterWithNavigation.astro +24 -0
- package/dist/{footer → src-astro/footer}/EFooterWithNavigationContainer.astro +4 -4
- package/dist/src-astro/footer/EFooterWithProducts.astro +24 -0
- package/dist/{footer → src-astro/footer}/EFooterWithProductsContainer.astro +4 -4
- package/dist/src-astro/footer/EFooterWithSocial.astro +24 -0
- package/dist/{footer → src-astro/footer}/EFooterWithSocialContainer.astro +4 -4
- package/dist/{footer → src-astro/footer}/Footer.astro +170 -158
- package/dist/src-astro/footer/FooterSection.astro +49 -0
- package/dist/{footer → src-astro/footer}/index.ts +11 -11
- package/dist/{grid → src-astro/grid}/Grid.astro +99 -99
- package/dist/src-astro/grid/GridBasic.astro +21 -0
- package/dist/{grid → src-astro/grid}/index.ts +1 -1
- package/dist/src-astro/header/Header.astro +209 -0
- package/dist/{header → src-astro/header}/HeaderBasic.astro +6 -1
- 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/{header → src-astro/header}/HeaderCustomPosition.astro +17 -6
- package/dist/src-astro/header/HeaderWithNavigation.astro +27 -0
- package/dist/{header → src-astro/header}/index.ts +22 -8
- package/dist/src-astro/heading/Heading.astro +245 -0
- package/dist/{heading → src-astro/heading}/index.ts +1 -1
- package/dist/src-astro/hero/Hero.astro +381 -0
- package/dist/src-astro/hero/HeroAlignCenter.astro +13 -0
- package/dist/{hero → src-astro/hero}/HeroAlignContainer.astro +16 -12
- package/dist/src-astro/hero/HeroAlignLeft.astro +13 -0
- package/dist/src-astro/hero/HeroAlignRight.astro +13 -0
- package/dist/{hero → src-astro/hero}/HeroBackgroundContainer.astro +9 -9
- package/dist/src-astro/hero/HeroBackgroundImage.astro +16 -0
- package/dist/{hero → src-astro/hero}/HeroBackgroundImageContainer.astro +4 -4
- package/dist/src-astro/hero/HeroBasic.astro +12 -0
- package/dist/{hero → src-astro/hero}/HeroBasicContainer.astro +4 -4
- 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/{hero → src-astro/hero}/HeroWithButtonContainer.astro +4 -4
- package/dist/src-astro/hero/HeroWithImage.astro +16 -0
- package/dist/{hero → src-astro/hero}/HeroWithImageContainer.astro +4 -4
- package/dist/{hero → src-astro/hero}/index.ts +19 -19
- 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/{icons → src-astro/icons}/SettingsIcon.astro +8 -8
- package/dist/{icons → src-astro/icons}/SocialIcon.astro +36 -36
- 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/{image → src-astro/image}/index.ts +3 -3
- package/dist/src-astro/integration.ts +14 -0
- package/dist/{language-switcher → src-astro/language-switcher}/LanguageSwitcher.astro +22 -22
- package/dist/{language-switcher → src-astro/language-switcher}/LanguageSwitcherBasic.astro +1 -1
- package/dist/{language-switcher → src-astro/language-switcher}/index.ts +1 -1
- package/dist/{layout-app → src-astro/layout-app}/AppLayout.astro +83 -75
- package/dist/src-astro/layout-app/AppLayoutBasic.astro +54 -0
- package/dist/{layout-app → src-astro/layout-app}/index.ts +1 -1
- package/dist/{layout-basic → src-astro/layout-basic}/BaseLayout.astro +35 -31
- package/dist/src-astro/layout-basic/BaseLayoutBasic.astro +17 -0
- package/dist/{layout-basic → src-astro/layout-basic}/index.ts +1 -1
- package/dist/src-astro/layout-dashboard/DashboardLayout.astro +686 -0
- package/dist/src-astro/layout-dashboard/DashboardLayoutBasic.astro +51 -0
- package/dist/{layout-dashboard → src-astro/layout-dashboard}/index.ts +1 -1
- package/dist/{link → src-astro/link}/Link.astro +72 -57
- 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/{link → src-astro/link}/index.ts +3 -3
- package/dist/{main → src-astro/main}/Main.astro +68 -60
- 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/{module → src-astro/module}/Module.astro +30 -23
- 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/{module → src-astro/module}/index.ts +3 -3
- package/dist/src-astro/nav-item/NavItems.astro +44 -0
- package/dist/src-astro/nav-item/NavItemsBasic.astro +30 -0
- package/dist/{nav-item → src-astro/nav-item}/index.ts +1 -1
- package/dist/src-astro/nav-section/NavSection.astro +41 -0
- package/dist/src-astro/nav-section/NavSectionBasic.astro +12 -0
- package/dist/{nav-section → src-astro/nav-section}/index.ts +1 -1
- 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/{sidebar → src-astro/sidebar}/index.ts +1 -1
- package/dist/src-astro/sidebar-nav/SidebarNav.astro +136 -0
- package/dist/src-astro/sidebar-nav/SidebarNavBasic.astro +32 -0
- package/dist/{sidebar-nav → src-astro/sidebar-nav}/index.ts +1 -1
- 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/{speak → src-astro/speak}/index.ts +2 -2
- package/dist/{stack → src-astro/stack}/Stack.astro +67 -65
- package/dist/src-astro/stack/StackBasic.astro +21 -0
- package/dist/{stack → src-astro/stack}/index.ts +1 -1
- 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/{team-member → src-astro/team-member}/TeamMembers.astro +40 -48
- package/dist/{team-member → src-astro/team-member}/index.ts +9 -2
- package/dist/{text → src-astro/text}/Text.astro +50 -50
- package/dist/{text → src-astro/text}/TextBasic.astro +1 -1
- package/dist/src-astro/text/TextSizes.astro +11 -0
- package/dist/{text → src-astro/text}/index.ts +1 -1
- package/dist/{theme-switcher → src-astro/theme-switcher}/ThemeItem.astro +20 -20
- package/dist/src-astro/theme-switcher/ThemeSwitcher.astro +121 -0
- package/dist/{theme-switcher → src-astro/theme-switcher}/ThemeSwitcherBasic.astro +1 -1
- package/dist/{theme-switcher → src-astro/theme-switcher}/index.ts +1 -1
- package/dist/src-astro/toc/TableOfContents.astro +438 -0
- package/dist/src-astro/toc/TableOfContentsBasic.astro +25 -0
- package/dist/{toc → src-astro/toc}/index.ts +1 -1
- 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/{types → src-astro/types}/image.ts +4 -4
- 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/{utils → src-astro/utils}/url.ts +2 -2
- 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/{button → vue/buttons-vue}/ButtonVariants.vue +2 -2
- 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/assets/iPhone 14 Pro - Deep Purple - Landscape.png +0 -0
- package/dist/vue/iPhone-vue/assets/iPhone 14 Pro - Deep Purple - Portrait.png +0 -0
- package/dist/vue/iPhone-vue/assets/iPhone 14 Pro - Gold - Landscape.png +0 -0
- package/dist/vue/iPhone-vue/assets/iPhone 14 Pro - Gold - Portrait.png +0 -0
- package/dist/vue/iPhone-vue/assets/iPhone 14 Pro - Silver - Landscape.png +0 -0
- package/dist/vue/iPhone-vue/assets/iPhone 14 Pro - Silver - Portrait.png +0 -0
- package/dist/vue/iPhone-vue/assets/iPhone 14 Pro - Space Black - Landscape.png +0 -0
- package/dist/vue/iPhone-vue/assets/iPhone 14 Pro - Space Black - Portrait.png +0 -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/EAlertCustomStyle.astro +0 -14
- package/dist/alert/EAlertError.astro +0 -6
- package/dist/alert/EAlertInfo.astro +0 -6
- package/dist/alert/EAlertSuccess.astro +0 -6
- package/dist/alert/EAlertWarning.astro +0 -6
- package/dist/article/ArticleBasic.astro +0 -31
- package/dist/assets/iconData.ts +0 -116
- package/dist/banner/Banner.astro +0 -165
- package/dist/banner/BannerAllAnimations.astro +0 -10
- package/dist/banner/BannerCustomStyle.astro +0 -7
- package/dist/blog/Blog.astro +0 -249
- package/dist/blog/index.ts +0 -1
- package/dist/button/Button.astro +0 -192
- package/dist/button/ButtonBasic.astro +0 -18
- package/dist/button/ButtonIconBoth.astro +0 -9
- package/dist/button/ButtonShapes.astro +0 -23
- package/dist/button/ButtonSizes.astro +0 -15
- package/dist/button/ButtonStates.astro +0 -12
- package/dist/button/ButtonVariants.astro +0 -14
- package/dist/button/ButtonWithIcons.astro +0 -25
- 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/index.ts +0 -7
- 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-example/CodeExample.astro +0 -157
- package/dist/code-example/index.ts +0 -1
- package/dist/container/Container.astro +0 -211
- package/dist/container/EContainerBasic.astro +0 -13
- package/dist/container/EContainerFlexBetween.astro +0 -16
- package/dist/container/EContainerFlexCenter.astro +0 -23
- package/dist/container/EContainerFlexColumn.astro +0 -16
- package/dist/container/EContainerFlexRow.astro +0 -16
- package/dist/container/EContainerPadding.astro +0 -32
- package/dist/container/EContainerSizes.astro +0 -36
- package/dist/database/BaseDB.ts +0 -231
- package/dist/database/BlogDB.ts +0 -198
- package/dist/database/CourseDB.ts +0 -84
- package/dist/database/MetaDB.ts +0 -74
- package/dist/entities/BaseDoc.ts +0 -195
- 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/FlexBasic.astro +0 -9
- package/dist/footer/EFooterBasic.astro +0 -18
- package/dist/footer/EFooterComplete.astro +0 -45
- package/dist/footer/EFooterWithLogo.astro +0 -23
- package/dist/footer/EFooterWithNavigation.astro +0 -24
- package/dist/footer/EFooterWithProducts.astro +0 -24
- package/dist/footer/EFooterWithSocial.astro +0 -24
- package/dist/footer/FooterSection.astro +0 -48
- package/dist/grid/GridBasic.astro +0 -9
- package/dist/header/Header.astro +0 -204
- package/dist/header/HeaderCustomNavbarCenter.astro +0 -23
- package/dist/header/HeaderCustomNavbarEnd.astro +0 -20
- package/dist/header/HeaderCustomNavbarStart.astro +0 -20
- package/dist/header/HeaderWithNavigation.astro +0 -22
- package/dist/heading/Heading.astro +0 -238
- package/dist/hero/Hero.astro +0 -368
- package/dist/hero/HeroAlignCenter.astro +0 -13
- package/dist/hero/HeroAlignLeft.astro +0 -13
- package/dist/hero/HeroAlignRight.astro +0 -13
- package/dist/hero/HeroBackgroundImage.astro +0 -12
- package/dist/hero/HeroBasic.astro +0 -12
- package/dist/hero/HeroGradientBackground.astro +0 -10
- package/dist/hero/HeroPlainBackground.astro +0 -10
- package/dist/hero/HeroWithButton.astro +0 -11
- package/dist/hero/HeroWithImage.astro +0 -16
- 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/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/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/index.ts +0 -3
- package/dist/index_astro.ts +0 -68
- 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 -44
- package/dist/integration.ts +0 -14
- package/dist/layout-app/AppLayoutBasic.astro +0 -53
- package/dist/layout-basic/BaseLayoutBasic.astro +0 -16
- package/dist/layout-dashboard/DashboardLayout.astro +0 -671
- package/dist/layout-dashboard/DashboardLayoutBasic.astro +0 -48
- package/dist/link/LinkAnimations.astro +0 -21
- package/dist/link/LinkBasic.astro +0 -17
- package/dist/link/LinkVariants.astro +0 -20
- package/dist/main/index.ts +0 -1
- package/dist/modal/Modal.astro +0 -119
- package/dist/modal/index.ts +0 -1
- package/dist/module/ModuleBasic.astro +0 -12
- package/dist/module/ModuleCustom.astro +0 -14
- package/dist/module/ModuleGrid.astro +0 -26
- package/dist/nav-item/NavItems.astro +0 -44
- package/dist/nav-item/NavItemsBasic.astro +0 -27
- package/dist/nav-section/NavSection.astro +0 -42
- package/dist/nav-section/NavSectionBasic.astro +0 -12
- 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-nav/SidebarNav.astro +0 -117
- package/dist/sidebar-nav/SidebarNavBasic.astro +0 -32
- package/dist/speak/Speak.astro +0 -65
- package/dist/speak/SpeakBasic.astro +0 -13
- package/dist/speak/SpeakGrid.astro +0 -29
- package/dist/stack/StackBasic.astro +0 -15
- 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/text/TextSizes.astro +0 -11
- package/dist/theme-switcher/ThemeSwitcher.astro +0 -120
- package/dist/toc/TableOfContents.astro +0 -405
- package/dist/toc/TableOfContentsBasic.astro +0 -25
- 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/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/{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
@@ -1,14 +0,0 @@
|
|
1
|
-
---
|
2
|
-
import Button from './Button.astro';
|
3
|
-
---
|
4
|
-
|
5
|
-
<div class="cosy:flex cosy:flex-wrap cosy:gap-2">
|
6
|
-
<Button variant="info">信息按钮</Button>
|
7
|
-
<Button variant="success">成功按钮</Button>
|
8
|
-
<Button variant="warning">警告按钮</Button>
|
9
|
-
<Button variant="error">错误按钮</Button>
|
10
|
-
<Button variant="ghost">幽灵按钮</Button>
|
11
|
-
<Button variant="link">链接按钮</Button>
|
12
|
-
<Button variant="outline">描边按钮</Button>
|
13
|
-
<Button variant="neutral">中性按钮</Button>
|
14
|
-
</div>
|
@@ -1,25 +0,0 @@
|
|
1
|
-
---
|
2
|
-
import Button from './Button.astro';
|
3
|
-
---
|
4
|
-
|
5
|
-
<div class="cosy:flex cosy:flex-wrap cosy:gap-2">
|
6
|
-
<Button variant="primary">
|
7
|
-
<span slot="icon-left">👈</span>
|
8
|
-
返回
|
9
|
-
</Button>
|
10
|
-
|
11
|
-
<Button variant="success">
|
12
|
-
确认
|
13
|
-
<span slot="icon-right">✅</span>
|
14
|
-
</Button>
|
15
|
-
|
16
|
-
<Button variant="info">
|
17
|
-
<span slot="icon-left">💾</span>
|
18
|
-
保存
|
19
|
-
<span slot="icon-right">📁</span>
|
20
|
-
</Button>
|
21
|
-
|
22
|
-
<Button variant="warning" shape="circle">
|
23
|
-
<span slot="icon-left">⚠️</span>
|
24
|
-
</Button>
|
25
|
-
</div>
|
@@ -1,77 +0,0 @@
|
|
1
|
-
---
|
2
|
-
/**
|
3
|
-
* CardCompact - 紧凑模式卡片组件
|
4
|
-
*
|
5
|
-
* @prop {string} [title] - 卡片标题
|
6
|
-
* @prop {string} [subtitle] - 卡片副标题或描述
|
7
|
-
* @prop {string} [class] - 自定义CSS类
|
8
|
-
*/
|
9
|
-
|
10
|
-
import '../style.ts';
|
11
|
-
|
12
|
-
interface Props {
|
13
|
-
title?: string;
|
14
|
-
subtitle?: string;
|
15
|
-
class?: string;
|
16
|
-
}
|
17
|
-
|
18
|
-
const { title, subtitle, class: className = '' } = Astro.props;
|
19
|
-
|
20
|
-
const cardClasses = [
|
21
|
-
'cosy-card',
|
22
|
-
'cosy:bg-base-100',
|
23
|
-
'cosy:bg-opacity-70',
|
24
|
-
'cosy:backdrop-blur-sm',
|
25
|
-
'cosy:rounded-xl',
|
26
|
-
'cosy:shadow-md',
|
27
|
-
'cosy:overflow-hidden',
|
28
|
-
'cosy:transition-all',
|
29
|
-
'cosy:duration-300',
|
30
|
-
'cosy:ease-in-out',
|
31
|
-
'cosy:hover:shadow-lg',
|
32
|
-
'cosy:hover:scale-[1.02]',
|
33
|
-
'cosy-card--compact',
|
34
|
-
className,
|
35
|
-
].join(' ');
|
36
|
-
---
|
37
|
-
|
38
|
-
<article class={cardClasses}>
|
39
|
-
<header class="cosy-card__header">
|
40
|
-
<h3 class="cosy-card__title">{title}</h3>
|
41
|
-
{subtitle && <p class="cosy-card__subtitle">{subtitle}</p>}
|
42
|
-
</header>
|
43
|
-
|
44
|
-
<div class="cosy-card__content">
|
45
|
-
<slot />
|
46
|
-
</div>
|
47
|
-
</article>
|
48
|
-
|
49
|
-
<style scoped>
|
50
|
-
.cosy-card--compact {
|
51
|
-
padding: 0.75rem;
|
52
|
-
}
|
53
|
-
|
54
|
-
.cosy-card__header {
|
55
|
-
margin-bottom: 0.5rem;
|
56
|
-
}
|
57
|
-
|
58
|
-
.cosy-card__title {
|
59
|
-
font-size: 0.95rem;
|
60
|
-
margin-bottom: 0.25rem;
|
61
|
-
}
|
62
|
-
|
63
|
-
.cosy-card__subtitle {
|
64
|
-
font-size: 0.85rem;
|
65
|
-
}
|
66
|
-
|
67
|
-
.cosy-card__content {
|
68
|
-
font-size: 0.85rem;
|
69
|
-
line-height: 1.4;
|
70
|
-
}
|
71
|
-
|
72
|
-
@media (prefers-reduced-motion: reduce) {
|
73
|
-
.cosy-card:hover {
|
74
|
-
transform: none !important;
|
75
|
-
}
|
76
|
-
}
|
77
|
-
</style>
|
@@ -1,32 +0,0 @@
|
|
1
|
-
---
|
2
|
-
import { Image } from 'astro:assets';
|
3
|
-
import bookCover from '../assets/book.png';
|
4
|
-
|
5
|
-
interface Props {
|
6
|
-
title: string;
|
7
|
-
link: string;
|
8
|
-
}
|
9
|
-
|
10
|
-
const { title, link } = Astro.props;
|
11
|
-
---
|
12
|
-
|
13
|
-
<div>
|
14
|
-
<a href={link} class="justify-center flex no-underline text-base-content">
|
15
|
-
<div class="w-56 h-80">
|
16
|
-
<div
|
17
|
-
class="bg-gradient-to-br w-full h-full from-accent/50 to-primary/30 rounded-3xl shadow-lg backdrop-blur-sm">
|
18
|
-
<div
|
19
|
-
class="bg-base-100/60 w-full h-full rounded-3xl border border-base-content/30 hover:scale-105 hover:shadow-2xl transform duration-200 backdrop-filter backdrop-blur-sm">
|
20
|
-
<div class="card-body p-1 h-full">
|
21
|
-
<Image src={bookCover} alt={title} class="h-3/5 w-full" />
|
22
|
-
<div>
|
23
|
-
<h2 class="text-lg text-center font-medium">
|
24
|
-
{title}
|
25
|
-
</h2>
|
26
|
-
</div>
|
27
|
-
</div>
|
28
|
-
</div>
|
29
|
-
</div>
|
30
|
-
</div>
|
31
|
-
</a>
|
32
|
-
</div>
|
package/dist/card/CardLink.astro
DELETED
@@ -1,75 +0,0 @@
|
|
1
|
-
---
|
2
|
-
/**
|
3
|
-
* CardLink - 可点击的卡片组件
|
4
|
-
*
|
5
|
-
* @prop {string} [title] - 卡片标题
|
6
|
-
* @prop {string} [subtitle] - 卡片副标题或描述
|
7
|
-
* @prop {string} [imageUrl] - 卡片图片URL
|
8
|
-
* @prop {string} [href] - 卡片链接地址
|
9
|
-
* @prop {string} [class] - 自定义CSS类
|
10
|
-
*/
|
11
|
-
|
12
|
-
import '../style.ts';
|
13
|
-
|
14
|
-
interface Props {
|
15
|
-
title?: string;
|
16
|
-
subtitle?: string;
|
17
|
-
imageUrl?: string;
|
18
|
-
href: string;
|
19
|
-
class?: string;
|
20
|
-
}
|
21
|
-
|
22
|
-
const { title, subtitle, imageUrl, href, class: className = '' } = Astro.props;
|
23
|
-
|
24
|
-
const cardClasses = [
|
25
|
-
'cosy-card',
|
26
|
-
'cosy:bg-base-100',
|
27
|
-
'cosy:bg-opacity-70',
|
28
|
-
'cosy:backdrop-blur-sm',
|
29
|
-
'cosy:rounded-xl',
|
30
|
-
'cosy:shadow-md',
|
31
|
-
'cosy:overflow-hidden',
|
32
|
-
'cosy:transition-all',
|
33
|
-
'cosy:duration-300',
|
34
|
-
'cosy:ease-in-out',
|
35
|
-
'cosy:hover:shadow-lg',
|
36
|
-
'cosy:hover:scale-[1.02]',
|
37
|
-
className,
|
38
|
-
].join(' ');
|
39
|
-
---
|
40
|
-
|
41
|
-
<a href={href} class={cardClasses} aria-label={`${title} ${subtitle || ''}`.trim()}>
|
42
|
-
{
|
43
|
-
imageUrl && (
|
44
|
-
<div
|
45
|
-
class="cosy-card__image"
|
46
|
-
style={`background-image: url(${imageUrl})`}
|
47
|
-
aria-hidden="true"
|
48
|
-
/>
|
49
|
-
)
|
50
|
-
}
|
51
|
-
|
52
|
-
<header class="cosy-card__header">
|
53
|
-
<h3 class="cosy-card__title">{title}</h3>
|
54
|
-
{subtitle && <p class="cosy-card__subtitle">{subtitle}</p>}
|
55
|
-
</header>
|
56
|
-
|
57
|
-
<div class="cosy-card__content">
|
58
|
-
<slot />
|
59
|
-
</div>
|
60
|
-
</a>
|
61
|
-
|
62
|
-
<style scoped>
|
63
|
-
.cosy-card__image {
|
64
|
-
height: 180px;
|
65
|
-
background-size: cover;
|
66
|
-
background-position: center;
|
67
|
-
border-radius: 12px 12px 0 0;
|
68
|
-
}
|
69
|
-
|
70
|
-
@media (prefers-reduced-motion: reduce) {
|
71
|
-
.cosy-card:hover {
|
72
|
-
transform: none !important;
|
73
|
-
}
|
74
|
-
}
|
75
|
-
</style>
|
@@ -1,39 +0,0 @@
|
|
1
|
-
---
|
2
|
-
import '../style.ts';
|
3
|
-
|
4
|
-
interface Props {
|
5
|
-
title: string;
|
6
|
-
subtitle?: string;
|
7
|
-
imageUrl: string;
|
8
|
-
class?: string;
|
9
|
-
}
|
10
|
-
|
11
|
-
const { title, subtitle, imageUrl, class: className } = Astro.props;
|
12
|
-
---
|
13
|
-
|
14
|
-
<article class={`cosy-card cosy-card--with-image ${className || ''}`}>
|
15
|
-
<div class="cosy-card__image" style={`background-image: url(${imageUrl})`} aria-hidden="true">
|
16
|
-
</div>
|
17
|
-
|
18
|
-
<header class="cosy-card__header">
|
19
|
-
<h3 class="cosy-card__title">{title}</h3>
|
20
|
-
{subtitle && <p class="cosy-card__subtitle">{subtitle}</p>}
|
21
|
-
</header>
|
22
|
-
|
23
|
-
<div class="cosy-card__content">
|
24
|
-
<slot />
|
25
|
-
</div>
|
26
|
-
</article>
|
27
|
-
|
28
|
-
<style>
|
29
|
-
.cosy-card__image {
|
30
|
-
height: 160px;
|
31
|
-
background-size: cover;
|
32
|
-
background-position: center;
|
33
|
-
border-radius: 8px 8px 0 0;
|
34
|
-
}
|
35
|
-
|
36
|
-
.cosy-card__header {
|
37
|
-
padding-top: 1rem;
|
38
|
-
}
|
39
|
-
</style>
|
package/dist/card/index.ts
DELETED
@@ -1,7 +0,0 @@
|
|
1
|
-
|
2
|
-
export { default as Card } from './Card.astro';
|
3
|
-
export { default as CardCourse } from './CardCourse.astro';
|
4
|
-
export { default as CardBasic } from './CardBasic.astro';
|
5
|
-
export { default as CardWithImage } from './CardWithImage.astro';
|
6
|
-
export { default as CardLink } from './CardLink.astro';
|
7
|
-
export { default as CardCompact } from './CardCompact.astro';
|
@@ -1,152 +0,0 @@
|
|
1
|
-
---
|
2
|
-
/**
|
3
|
-
* @component CodeBlock
|
4
|
-
*
|
5
|
-
* @description
|
6
|
-
* CodeBlock 组件用于在页面中展示格式化的代码片段,支持语法高亮、行号显示和代码复制功能。
|
7
|
-
* 组件设计简洁美观,提供良好的代码可读性和用户交互体验。
|
8
|
-
*
|
9
|
-
* @design
|
10
|
-
* 设计理念:
|
11
|
-
* 1. 可读性优先 - 清晰的字体、合适的间距和语法高亮,确保代码易于阅读
|
12
|
-
* 2. 功能完备 - 支持行号显示、代码复制等实用功能
|
13
|
-
* 3. 视觉一致性 - 与整体设计系统保持一致的视觉风格
|
14
|
-
* 4. 响应式设计 - 在不同屏幕尺寸下保持良好的可用性
|
15
|
-
*
|
16
|
-
* 视觉特点:
|
17
|
-
* - 语法高亮:使用北欧风格的配色方案,柔和且易于阅读
|
18
|
-
* - 行号显示:可选的行号显示,帮助定位代码位置
|
19
|
-
* - 标题栏:可选的标题栏,显示文件名或代码类型
|
20
|
-
* - 复制按钮:便捷的代码复制功能,带有状态反馈
|
21
|
-
*
|
22
|
-
* @usage
|
23
|
-
* 基本用法:
|
24
|
-
* ```astro
|
25
|
-
* <CodeBlock code={`console.log('Hello, world!');`} lang="js" />
|
26
|
-
* ```
|
27
|
-
*
|
28
|
-
* 带标题和行号:
|
29
|
-
* ```astro
|
30
|
-
* <CodeBlock
|
31
|
-
* code={`function greet(name) {\n return 'Hello, ' + name + '!';\n}`}
|
32
|
-
* lang="js"
|
33
|
-
* title="greeting.js"
|
34
|
-
* showLineNumbers={true}
|
35
|
-
* />
|
36
|
-
* ```
|
37
|
-
*
|
38
|
-
* @props
|
39
|
-
* @prop {string} code - 要显示的代码字符串
|
40
|
-
* @prop {string} [lang="plaintext"] - 代码语言,用于语法高亮
|
41
|
-
* @prop {string} [title] - 代码块的标题,通常是文件名
|
42
|
-
* @prop {boolean} [showLineNumbers=true] - 是否显示行号
|
43
|
-
*
|
44
|
-
* @accessibility
|
45
|
-
* - 使用语义化HTML结构
|
46
|
-
* - 复制按钮提供清晰的视觉反馈
|
47
|
-
* - 代码使用等宽字体,确保对齐和可读性
|
48
|
-
*/
|
49
|
-
|
50
|
-
import '../style.ts';
|
51
|
-
|
52
|
-
interface Props {
|
53
|
-
code: string;
|
54
|
-
title?: string;
|
55
|
-
showLineNumbers?: boolean;
|
56
|
-
}
|
57
|
-
|
58
|
-
const { code, title, showLineNumbers = true } = Astro.props;
|
59
|
-
|
60
|
-
// 移除代码字符串开头和结尾的空行
|
61
|
-
const trimmedCode = code.trim();
|
62
|
-
|
63
|
-
// 生成行号
|
64
|
-
const lines = trimmedCode.split('\n');
|
65
|
-
const lineNumbers = Array.from({ length: lines.length }, (_, i) => i + 1);
|
66
|
-
---
|
67
|
-
|
68
|
-
<div class="cosy:border cosy:border-base-300 cosy:rounded-lg cosy:overflow-hidden cosy:not-prose">
|
69
|
-
{/* 标题栏 */}
|
70
|
-
{
|
71
|
-
title && (
|
72
|
-
<div class="cosy:flex cosy:justify-between cosy:items-center cosy:bg-base-200 cosy:px-4 cosy:py-2 cosy:border-b cosy:border-base-300">
|
73
|
-
<span class="cosy:font-medium cosy:text-base-content">{title}</span>
|
74
|
-
<button
|
75
|
-
class="cosy:flex cosy:items-center cosy:gap-1 cosy:hover:bg-base-300 cosy:px-2 cosy:py-1 cosy:rounded-md cosy:text-sm cosy:text-base-content cosy:transition-colors"
|
76
|
-
data-code={trimmedCode}
|
77
|
-
title="复制代码">
|
78
|
-
<svg
|
79
|
-
class="cosy:w-4 cosy:h-4"
|
80
|
-
xmlns="http://www.w3.org/2000/svg"
|
81
|
-
viewBox="0 0 24 24"
|
82
|
-
fill="none"
|
83
|
-
stroke="currentColor">
|
84
|
-
<rect x="9" y="9" width="13" height="13" rx="2" ry="2" />
|
85
|
-
<path d="M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1" />
|
86
|
-
</svg>
|
87
|
-
<span class="cosy:copy-text">复制</span>
|
88
|
-
</button>
|
89
|
-
</div>
|
90
|
-
)
|
91
|
-
}
|
92
|
-
|
93
|
-
{/* 代码区域 */}
|
94
|
-
<div class="cosy:flex cosy:overflow-auto">
|
95
|
-
{/* 行号 */}
|
96
|
-
{
|
97
|
-
showLineNumbers && (
|
98
|
-
<div class="cosy:flex cosy:flex-col cosy:bg-base-100 cosy:py-2 cosy:pr-2 cosy:pl-3 cosy:border-r cosy:border-base-300 cosy:text-base-content cosy:text-right cosy:text-opacity-50 cosy:select-none">
|
99
|
-
{lineNumbers.map((num) => (
|
100
|
-
<div class="cosy:font-mono cosy:text-xs cosy:leading-5">{num}</div>
|
101
|
-
))}
|
102
|
-
</div>
|
103
|
-
)
|
104
|
-
}
|
105
|
-
|
106
|
-
{/* 代码内容 */}
|
107
|
-
<pre
|
108
|
-
class:list={[
|
109
|
-
'cosy:p-2 cosy:overflow-auto cosy:font-mono cosy:text-sm cosy:bg-base-100 cosy:text-base-content cosy:w-full',
|
110
|
-
{ 'cosy:pl-0': showLineNumbers },
|
111
|
-
]}>
|
112
|
-
<code class="cosy:block cosy:font-mono" set:html={trimmedCode} />
|
113
|
-
</pre>
|
114
|
-
</div>
|
115
|
-
</div>
|
116
|
-
|
117
|
-
<script>
|
118
|
-
function initializeCopyButtons() {
|
119
|
-
const copyButtons = document.querySelectorAll('.cosy\\:flex.cosy\\:items-center.cosy\\:gap-1');
|
120
|
-
|
121
|
-
copyButtons.forEach((button) => {
|
122
|
-
button.addEventListener('click', async () => {
|
123
|
-
const code = button.getAttribute('data-code') || '';
|
124
|
-
const copyText = button.querySelector('.cosy\\:copy-text');
|
125
|
-
|
126
|
-
try {
|
127
|
-
await navigator.clipboard.writeText(code);
|
128
|
-
if (copyText) {
|
129
|
-
copyText.textContent = '已复制!';
|
130
|
-
setTimeout(() => {
|
131
|
-
copyText.textContent = '复制';
|
132
|
-
}, 2000);
|
133
|
-
}
|
134
|
-
} catch (err) {
|
135
|
-
console.error('复制失败:', err);
|
136
|
-
if (copyText) {
|
137
|
-
copyText.textContent = '复制失败';
|
138
|
-
setTimeout(() => {
|
139
|
-
copyText.textContent = '复制';
|
140
|
-
}, 2000);
|
141
|
-
}
|
142
|
-
}
|
143
|
-
});
|
144
|
-
});
|
145
|
-
}
|
146
|
-
|
147
|
-
// 在页面加载时初始化
|
148
|
-
initializeCopyButtons();
|
149
|
-
|
150
|
-
// 在 Astro 页面切换时重新初始化
|
151
|
-
document.addEventListener('astro:page-load', initializeCopyButtons);
|
152
|
-
</script>
|
package/dist/code-block/index.ts
DELETED
@@ -1 +0,0 @@
|
|
1
|
-
export { default as CodeBlock} from './CodeBlock.astro';
|
@@ -1,254 +0,0 @@
|
|
1
|
-
---
|
2
|
-
/**
|
3
|
-
* @component CodeContainer
|
4
|
-
*
|
5
|
-
* @description
|
6
|
-
* 用于展示代码示例的容器组件。使用时只需在默认slot中传入内容,
|
7
|
-
* 并为每个示例设置对应的id (tab-1, tab-2等)
|
8
|
-
*
|
9
|
-
* @example
|
10
|
-
* ```astro
|
11
|
-
* <CodeContainer>
|
12
|
-
* <div id="tab-1">
|
13
|
-
* <Alert type="info">这是第一个示例</Alert>
|
14
|
-
* </div>
|
15
|
-
* <div id="tab-2">
|
16
|
-
* <Alert type="success">这是第二个示例</Alert>
|
17
|
-
* </div>
|
18
|
-
* </CodeContainer>
|
19
|
-
* ```
|
20
|
-
*/
|
21
|
-
|
22
|
-
import { ClipboardIcon, CheckIcon, InfoIcon } from '../index';
|
23
|
-
import '../style.ts';
|
24
|
-
|
25
|
-
interface Props {
|
26
|
-
/**
|
27
|
-
* tab的标题,如果不提供则使用"示例 1"这样的默认标题
|
28
|
-
*/
|
29
|
-
titles?: string[];
|
30
|
-
/**
|
31
|
-
* tab的描述文本
|
32
|
-
*/
|
33
|
-
descriptions?: string[];
|
34
|
-
/**
|
35
|
-
* 每个示例对应的源代码
|
36
|
-
*/
|
37
|
-
codes: string[];
|
38
|
-
}
|
39
|
-
|
40
|
-
const { titles = [], descriptions = [], codes } = Astro.props;
|
41
|
-
---
|
42
|
-
|
43
|
-
<div data-role="code-container" class="cosy:mb-8 cosy:card" ignore-heading>
|
44
|
-
<!-- 工具栏 -->
|
45
|
-
<div
|
46
|
-
class="cosy:flex cosy:justify-between cosy:items-center cosy:bg-base-200 cosy:px-4 cosy:rounded-t">
|
47
|
-
<!-- 标签 -->
|
48
|
-
<div class="cosy:flex cosy:items-center cosy:gap-4">
|
49
|
-
<div role="tablist" class="cosy:tabs cosy:tabs-box">
|
50
|
-
{
|
51
|
-
codes.map((_, index) => (
|
52
|
-
<button
|
53
|
-
role="tab"
|
54
|
-
class={`cosy:tab ${index === 0 ? 'cosy:tab-active' : ''}`}
|
55
|
-
data-tab={`tab-${index + 1}`}>
|
56
|
-
{titles[index] || `示例 ${index + 1}`}
|
57
|
-
</button>
|
58
|
-
))
|
59
|
-
}
|
60
|
-
</div>
|
61
|
-
</div>
|
62
|
-
|
63
|
-
<!-- 工具按钮 -->
|
64
|
-
<div class="cosy:flex cosy:items-center cosy:gap-2">
|
65
|
-
<button
|
66
|
-
role="switch"
|
67
|
-
class="cosy:btn cosy:btn-ghost cosy:btn-sm"
|
68
|
-
aria-checked="false"
|
69
|
-
aria-label="切换代码/预览"
|
70
|
-
data-toggle="code">
|
71
|
-
<span class="cosy:code-icon"><InfoIcon /></span>
|
72
|
-
</button>
|
73
|
-
<button class="cosy:gap-2 cosy:btn cosy:btn-ghost cosy:btn-sm" aria-label="复制代码">
|
74
|
-
<span class="cosy:copy-icon"><ClipboardIcon /></span>
|
75
|
-
<span class="cosy:hidden cosy:check-icon"><CheckIcon /></span>
|
76
|
-
</button>
|
77
|
-
</div>
|
78
|
-
</div>
|
79
|
-
|
80
|
-
{
|
81
|
-
codes.map((code, index) => (
|
82
|
-
<div
|
83
|
-
class={`cosy:example-container ${index === 0 ? 'cosy:block' : 'cosy:hidden'}`}
|
84
|
-
data-example={`tab-${index + 1}`}>
|
85
|
-
{/* 描述 */}
|
86
|
-
{descriptions[index] && (
|
87
|
-
<p class="cosy:px-4 cosy:py-2 cosy:text-sm cosy:bg-gradient-to-b not-prose cosy:from-blue-100/50 cosy:to-blue-100/90 ">
|
88
|
-
{descriptions[index]}
|
89
|
-
</p>
|
90
|
-
)}
|
91
|
-
|
92
|
-
<div class="cosy:relative cosy:p-4 cosy:bg-gradient-to-br cosy:from-red-100 cosy:to-green-300 cosy:rounded-b">
|
93
|
-
<div class="cosy:block cosy:code-example-panel" data-panel="preview">
|
94
|
-
<slot />
|
95
|
-
</div>
|
96
|
-
|
97
|
-
<div class="cosy:hidden cosy:code-example-panel" data-panel="code">
|
98
|
-
<pre class="cosy:overflow-x-auto" style="margin:0">
|
99
|
-
<code class="cosy:language-astro">{code}</code>
|
100
|
-
</pre>
|
101
|
-
</div>
|
102
|
-
</div>
|
103
|
-
</div>
|
104
|
-
))
|
105
|
-
}
|
106
|
-
</div>
|
107
|
-
|
108
|
-
<script>
|
109
|
-
function initializeCodeContainer() {
|
110
|
-
console.log('CodeContainer: 初始化代码容器');
|
111
|
-
|
112
|
-
// 示例切换功能
|
113
|
-
const exampleTabs = document.querySelectorAll('[role="tab"][data-tab^="tab-"]');
|
114
|
-
exampleTabs.forEach((tab) => {
|
115
|
-
tab.addEventListener('click', () => {
|
116
|
-
console.log('CodeContainer: 切换示例', tab.getAttribute('data-tab'));
|
117
|
-
const container = tab.closest('[data-role="code-container"]');
|
118
|
-
if (!container) return;
|
119
|
-
|
120
|
-
// 更新标签状态
|
121
|
-
container.querySelectorAll('[role="tab"][data-tab^="tab-"]').forEach((t) => {
|
122
|
-
t.classList.remove('cosy:tab-active');
|
123
|
-
});
|
124
|
-
tab.classList.add('cosy:tab-active');
|
125
|
-
|
126
|
-
// 获取当前标签对应的内容 id
|
127
|
-
const targetId = tab.getAttribute('data-tab');
|
128
|
-
if (!targetId) return;
|
129
|
-
|
130
|
-
// 切换示例容器
|
131
|
-
container.querySelectorAll('.cosy\\:example-container').forEach((example) => {
|
132
|
-
if (example.getAttribute('data-example') === targetId) {
|
133
|
-
example.classList.remove('cosy:hidden');
|
134
|
-
example.classList.add('cosy:block');
|
135
|
-
} else {
|
136
|
-
example.classList.add('cosy:hidden');
|
137
|
-
example.classList.remove('cosy:block');
|
138
|
-
}
|
139
|
-
});
|
140
|
-
|
141
|
-
// 更新对应内容的可见性
|
142
|
-
const allContent = container.querySelectorAll('[id^="tab-"]');
|
143
|
-
allContent.forEach((content) => {
|
144
|
-
if (content.id === targetId) {
|
145
|
-
content.classList.remove('cosy:hidden');
|
146
|
-
content.classList.add('cosy:block');
|
147
|
-
} else {
|
148
|
-
content.classList.add('cosy:hidden');
|
149
|
-
content.classList.remove('cosy:block');
|
150
|
-
}
|
151
|
-
});
|
152
|
-
});
|
153
|
-
});
|
154
|
-
|
155
|
-
// 代码开关功能
|
156
|
-
const codeToggles = document.querySelectorAll('[data-toggle="code"]');
|
157
|
-
codeToggles.forEach((toggle) => {
|
158
|
-
toggle.addEventListener('click', () => {
|
159
|
-
console.log('code toggle clicked', toggle);
|
160
|
-
const container = toggle.closest('[data-role="code-container"]');
|
161
|
-
if (!container) {
|
162
|
-
console.error('CodeContainer: 无法找到父容器');
|
163
|
-
return;
|
164
|
-
}
|
165
|
-
|
166
|
-
// 切换开关状态
|
167
|
-
const isChecked = toggle.getAttribute('aria-checked') === 'true';
|
168
|
-
console.log('代码按钮 isChecked:', isChecked);
|
169
|
-
toggle.setAttribute('aria-checked', !isChecked ? 'true' : 'false');
|
170
|
-
toggle.classList.toggle('cosy:btn-primary', !isChecked);
|
171
|
-
toggle.classList.toggle('cosy:btn-ghost', isChecked);
|
172
|
-
|
173
|
-
// 找到当前显示的示例
|
174
|
-
const activeExample = container.querySelector(
|
175
|
-
'.cosy\\:example-container:not(.cosy\\:hidden)'
|
176
|
-
);
|
177
|
-
if (!activeExample) {
|
178
|
-
console.error('CodeContainer: 无法找到活动示例');
|
179
|
-
return;
|
180
|
-
}
|
181
|
-
|
182
|
-
// 切换面板
|
183
|
-
activeExample.querySelectorAll('.cosy\\:code-example-panel').forEach((panel) => {
|
184
|
-
if (panel.getAttribute('data-panel') === 'code') {
|
185
|
-
console.log('处理代码面板的展示/隐藏,此时的isChecked:', isChecked);
|
186
|
-
panel.classList.toggle('cosy:hidden', isChecked);
|
187
|
-
panel.classList.toggle('cosy:block', !isChecked);
|
188
|
-
} else {
|
189
|
-
console.log('处理预览面板的展示/隐藏,此时的isChecked:', isChecked);
|
190
|
-
panel.classList.toggle('cosy:hidden', !isChecked);
|
191
|
-
panel.classList.toggle('cosy:block', isChecked);
|
192
|
-
}
|
193
|
-
});
|
194
|
-
});
|
195
|
-
});
|
196
|
-
|
197
|
-
// 复制代码功能
|
198
|
-
const copyButtons = document.querySelectorAll('[aria-label="复制代码"]');
|
199
|
-
copyButtons.forEach((button) => {
|
200
|
-
button.addEventListener('click', () => {
|
201
|
-
const container = button.closest('[data-role="code-container"]');
|
202
|
-
if (!container) return;
|
203
|
-
|
204
|
-
// 确保代码面板是显示的
|
205
|
-
const codeToggle = container.querySelector('[data-toggle="code"]');
|
206
|
-
if (codeToggle?.getAttribute('aria-checked') !== 'true') {
|
207
|
-
(codeToggle as HTMLElement)?.click();
|
208
|
-
}
|
209
|
-
|
210
|
-
// 找到当前显示的示例
|
211
|
-
const activeExample = container.querySelector(
|
212
|
-
'.cosy\\:example-container:not(.cosy\\:hidden)'
|
213
|
-
);
|
214
|
-
if (!activeExample) return;
|
215
|
-
|
216
|
-
const codePanel = activeExample.querySelector('[data-panel="code"]');
|
217
|
-
if (!codePanel) return;
|
218
|
-
|
219
|
-
const codeElement = codePanel.querySelector('code');
|
220
|
-
if (!codeElement) return;
|
221
|
-
|
222
|
-
const code = codeElement.textContent || '';
|
223
|
-
|
224
|
-
// 复制到剪贴板
|
225
|
-
navigator.clipboard.writeText(code).then(() => {
|
226
|
-
button.classList.add('cosy:btn-success');
|
227
|
-
button.querySelector('.cosy\\:copy-icon')?.classList.add('cosy:hidden');
|
228
|
-
button.querySelector('.cosy\\:check-icon')?.classList.remove('cosy:hidden');
|
229
|
-
|
230
|
-
setTimeout(() => {
|
231
|
-
button.classList.remove('cosy:btn-success');
|
232
|
-
button.querySelector('.cosy\\:copy-icon')?.classList.remove('cosy:hidden');
|
233
|
-
button.querySelector('.cosy\\:check-icon')?.classList.add('cosy:hidden');
|
234
|
-
}, 3000);
|
235
|
-
});
|
236
|
-
});
|
237
|
-
});
|
238
|
-
|
239
|
-
// 初始化时隐藏除第一个以外的所有内容
|
240
|
-
document.querySelectorAll('[data-role="code-container"]').forEach((container) => {
|
241
|
-
const contents = container.querySelectorAll('[id^="tab-"]');
|
242
|
-
contents.forEach((content, index) => {
|
243
|
-
if (index !== 0) {
|
244
|
-
content.classList.add('cosy:hidden');
|
245
|
-
}
|
246
|
-
});
|
247
|
-
});
|
248
|
-
}
|
249
|
-
|
250
|
-
document.addEventListener('astro:page-load', () => {
|
251
|
-
console.log('CodeContainer: 页面加载完成,初始化代码容器');
|
252
|
-
initializeCodeContainer();
|
253
|
-
});
|
254
|
-
</script>
|