@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
@@ -0,0 +1,185 @@
|
|
1
|
+
---
|
2
|
+
/**
|
3
|
+
* @component CodeExample
|
4
|
+
*
|
5
|
+
* @description
|
6
|
+
* 用于展示组件示例及其源代码的组件。
|
7
|
+
* 采用标签形式,默认显示预览,用户可以点击标签切换到源代码视图。
|
8
|
+
* 支持亮色和暗黑模式,会根据系统设置自动切换主题。
|
9
|
+
*
|
10
|
+
* @usage
|
11
|
+
* ```astro
|
12
|
+
* <CodeExample
|
13
|
+
* title="示例标题"
|
14
|
+
* description="示例描述"
|
15
|
+
* code={`<Alert type="info">这是一个示例</Alert>`}
|
16
|
+
* >
|
17
|
+
* <Alert type="info">这是一个示例</Alert>
|
18
|
+
* </CodeExample>
|
19
|
+
* ```
|
20
|
+
*
|
21
|
+
* @props
|
22
|
+
* @prop {string} [title] - 示例标题
|
23
|
+
* @prop {string} [description] - 示例描述
|
24
|
+
* @prop {string} code - 要展示的源代码
|
25
|
+
*
|
26
|
+
* @slots
|
27
|
+
* @slot default - 组件的实际渲染内容
|
28
|
+
*/
|
29
|
+
|
30
|
+
import { ClipboardIcon, CheckIcon } from '../../index-astro';
|
31
|
+
import '../../style.ts';
|
32
|
+
|
33
|
+
interface Props {
|
34
|
+
title?: string;
|
35
|
+
description?: string;
|
36
|
+
code: string;
|
37
|
+
}
|
38
|
+
|
39
|
+
const { title, description, code } = Astro.props;
|
40
|
+
---
|
41
|
+
|
42
|
+
<div data-role="code-example" class="cosy:mb-8 cosy:card" ignore-heading>
|
43
|
+
{
|
44
|
+
title && (
|
45
|
+
<h3 class="cosy:p-4 cosy:border-b cosy:border-base-300 cosy:card-title">
|
46
|
+
{title}
|
47
|
+
</h3>
|
48
|
+
)
|
49
|
+
}
|
50
|
+
{
|
51
|
+
description && (
|
52
|
+
<p class="cosy:px-4 cosy:pt-4 cosy:text-base-content/70">{description}</p>
|
53
|
+
)
|
54
|
+
}
|
55
|
+
|
56
|
+
<div
|
57
|
+
class="cosy:flex cosy:justify-between cosy:items-center cosy:bg-base-200 cosy:px-4 cosy:rounded-t">
|
58
|
+
<div role="tablist" class="cosy:tabs cosy:tabs-box">
|
59
|
+
<button role="tab" class="cosy:tab cosy:tab-active" data-tab="preview"
|
60
|
+
>预览</button
|
61
|
+
>
|
62
|
+
<button role="tab" class="cosy:tab" data-tab="code">代码</button>
|
63
|
+
</div>
|
64
|
+
<div class="cosy:flex cosy:items-center cosy:gap-2">
|
65
|
+
<button
|
66
|
+
class="cosy:gap-2 cosy:btn cosy:btn-ghost cosy:btn-sm"
|
67
|
+
aria-label="复制代码">
|
68
|
+
<span class="cosy:copy-icon"><ClipboardIcon /></span>
|
69
|
+
<span class="cosy:hidden cosy:text-success cosy:check-icon"
|
70
|
+
><CheckIcon /></span
|
71
|
+
>
|
72
|
+
<span class="cosy:copy-text">复制代码</span>
|
73
|
+
</button>
|
74
|
+
</div>
|
75
|
+
</div>
|
76
|
+
|
77
|
+
<div
|
78
|
+
class="cosy:relative cosy:p-4 cosy:bg-gradient-to-br cosy:from-red-100 cosy:to-green-300 cosy:rounded-b">
|
79
|
+
<div class="cosy:block cosy:code-example-panel" data-panel="preview">
|
80
|
+
<slot />
|
81
|
+
</div>
|
82
|
+
|
83
|
+
<div class="cosy:hidden cosy:code-example-panel" data-panel="code">
|
84
|
+
<pre
|
85
|
+
class="cosy:overflow-x-auto"
|
86
|
+
style="margin:0"><code class="cosy:language-astro">{code}</code></pre>
|
87
|
+
</div>
|
88
|
+
</div>
|
89
|
+
</div>
|
90
|
+
|
91
|
+
<script>
|
92
|
+
function initializeCodeExample() {
|
93
|
+
// 标签切换功能
|
94
|
+
const tabs = document.querySelectorAll('.cosy\\:tab');
|
95
|
+
|
96
|
+
tabs.forEach((tab) => {
|
97
|
+
tab.addEventListener('click', () => {
|
98
|
+
// 获取当前标签组
|
99
|
+
const tabGroup = tab.closest('.cosy\\:tabs');
|
100
|
+
if (!tabGroup) return;
|
101
|
+
|
102
|
+
const codeExample = tab.closest('.cosy\\:card');
|
103
|
+
if (!codeExample) return;
|
104
|
+
|
105
|
+
const contentContainer = codeExample.querySelector('.cosy\\:relative');
|
106
|
+
if (!contentContainer) return;
|
107
|
+
|
108
|
+
// 获取目标面板
|
109
|
+
const targetTab = tab.getAttribute('data-tab');
|
110
|
+
if (!targetTab) return;
|
111
|
+
|
112
|
+
// 更新标签状态
|
113
|
+
tabGroup.querySelectorAll('.cosy\\:tab').forEach((t) => {
|
114
|
+
t.classList.remove('cosy:tab-active');
|
115
|
+
});
|
116
|
+
tab.classList.add('cosy:tab-active');
|
117
|
+
|
118
|
+
// 更新面板状态
|
119
|
+
const panels = contentContainer.querySelectorAll('[data-panel]');
|
120
|
+
panels.forEach((panel) => {
|
121
|
+
if (panel.getAttribute('data-panel') === targetTab) {
|
122
|
+
panel.classList.remove('cosy:hidden');
|
123
|
+
panel.classList.add('cosy:block');
|
124
|
+
} else {
|
125
|
+
panel.classList.add('cosy:hidden');
|
126
|
+
panel.classList.remove('cosy:block');
|
127
|
+
}
|
128
|
+
});
|
129
|
+
});
|
130
|
+
});
|
131
|
+
|
132
|
+
// 复制代码功能
|
133
|
+
const copyButtons = document.querySelectorAll('.cosy\\:btn-ghost');
|
134
|
+
|
135
|
+
copyButtons.forEach((button) => {
|
136
|
+
button.addEventListener('click', () => {
|
137
|
+
const codeExample = button.closest('.cosy\\:card');
|
138
|
+
if (!codeExample) return;
|
139
|
+
|
140
|
+
const codePanel = codeExample.querySelector('[data-panel="code"]');
|
141
|
+
if (!codePanel) return;
|
142
|
+
|
143
|
+
const codeElement = codePanel.querySelector('code');
|
144
|
+
if (!codeElement) return;
|
145
|
+
|
146
|
+
const code = codeElement.textContent || '';
|
147
|
+
|
148
|
+
// 复制到剪贴板
|
149
|
+
navigator.clipboard.writeText(code).then(() => {
|
150
|
+
// 显示复制成功状态
|
151
|
+
button.classList.add('cosy:btn-success');
|
152
|
+
button
|
153
|
+
.querySelector('.cosy\\:copy-icon')
|
154
|
+
?.classList.add('cosy:hidden');
|
155
|
+
button
|
156
|
+
.querySelector('.cosy\\:check-icon')
|
157
|
+
?.classList.remove('cosy:hidden');
|
158
|
+
button
|
159
|
+
.querySelector('.cosy\\:copy-text')
|
160
|
+
?.classList.add('cosy:text-success');
|
161
|
+
|
162
|
+
// 3秒后恢复原状
|
163
|
+
setTimeout(() => {
|
164
|
+
button.classList.remove('cosy:btn-success');
|
165
|
+
button
|
166
|
+
.querySelector('.cosy\\:copy-icon')
|
167
|
+
?.classList.remove('cosy:hidden');
|
168
|
+
button
|
169
|
+
.querySelector('.cosy\\:check-icon')
|
170
|
+
?.classList.add('cosy:hidden');
|
171
|
+
button
|
172
|
+
.querySelector('.cosy\\:copy-text')
|
173
|
+
?.classList.remove('cosy:text-success');
|
174
|
+
}, 3000);
|
175
|
+
});
|
176
|
+
});
|
177
|
+
});
|
178
|
+
}
|
179
|
+
|
180
|
+
// 初始化
|
181
|
+
initializeCodeExample();
|
182
|
+
|
183
|
+
// Astro 页面切换时重新初始化
|
184
|
+
document.addEventListener('astro:page-load', initializeCodeExample);
|
185
|
+
</script>
|
@@ -0,0 +1 @@
|
|
1
|
+
export { default as CodeExample } from './CodeExample.astro';
|
@@ -0,0 +1,321 @@
|
|
1
|
+
---
|
2
|
+
/**
|
3
|
+
* @component Contact
|
4
|
+
*
|
5
|
+
* @description
|
6
|
+
* Contact 组件用于展示企业或个人的联系信息,支持多种联系方式(邮件、电话、地址)和社交媒体链接。
|
7
|
+
* 组件设计简洁专业,适合在企业网站的联系页面、页脚或关于我们页面中使用。
|
8
|
+
*
|
9
|
+
* @usage
|
10
|
+
* 基本用法:
|
11
|
+
* ```astro
|
12
|
+
* <Contact
|
13
|
+
* email="contact@company.com"
|
14
|
+
* phone="+1 (555) 123-4567"
|
15
|
+
* address="123 Business St, City, State 12345"
|
16
|
+
* />
|
17
|
+
* ```
|
18
|
+
*
|
19
|
+
* 带社交媒体链接:
|
20
|
+
* ```astro
|
21
|
+
* <Contact
|
22
|
+
* email="contact@company.com"
|
23
|
+
* phone="+1 (555) 123-4567"
|
24
|
+
* address="123 Business St, City, State 12345"
|
25
|
+
* github="https://github.com/company"
|
26
|
+
* twitter="https://twitter.com/company"
|
27
|
+
* facebook="https://facebook.com/company"
|
28
|
+
* />
|
29
|
+
* ```
|
30
|
+
*
|
31
|
+
* 带标题和描述:
|
32
|
+
* ```astro
|
33
|
+
* <Contact
|
34
|
+
* title="联系我们"
|
35
|
+
* description="欢迎随时与我们取得联系"
|
36
|
+
* email="contact@company.com"
|
37
|
+
* phone="+1 (555) 123-4567"
|
38
|
+
* />
|
39
|
+
* ```
|
40
|
+
*
|
41
|
+
* 紧凑模式:
|
42
|
+
* ```astro
|
43
|
+
* <Contact
|
44
|
+
* email="contact@company.com"
|
45
|
+
* phone="+1 (555) 123-4567"
|
46
|
+
* compact
|
47
|
+
* />
|
48
|
+
* ```
|
49
|
+
*
|
50
|
+
* @props
|
51
|
+
* @prop {string} [title] - 联系信息标题
|
52
|
+
* @prop {string} [description] - 联系信息描述
|
53
|
+
* @prop {string} [email] - 电子邮件地址
|
54
|
+
* @prop {string} [phone] - 电话号码
|
55
|
+
* @prop {string} [address] - 地址信息
|
56
|
+
* @prop {string} [website] - 网站链接
|
57
|
+
* @prop {string} [github] - GitHub链接
|
58
|
+
* @prop {string} [twitter] - Twitter链接
|
59
|
+
* @prop {string} [facebook] - Facebook链接
|
60
|
+
* @prop {string} [linkedin] - LinkedIn链接
|
61
|
+
* @prop {boolean} [compact] - 是否使用紧凑模式
|
62
|
+
* @prop {string} [class] - 自定义CSS类,可用于覆盖默认样式
|
63
|
+
*
|
64
|
+
* @slots
|
65
|
+
* @slot default - 额外的联系信息内容
|
66
|
+
*/
|
67
|
+
|
68
|
+
import '../../style.ts';
|
69
|
+
|
70
|
+
interface Props {
|
71
|
+
title?: string;
|
72
|
+
description?: string;
|
73
|
+
email?: string;
|
74
|
+
phone?: string;
|
75
|
+
address?: string;
|
76
|
+
website?: string;
|
77
|
+
github?: string;
|
78
|
+
twitter?: string;
|
79
|
+
facebook?: string;
|
80
|
+
linkedin?: string;
|
81
|
+
compact?: boolean;
|
82
|
+
class?: string;
|
83
|
+
}
|
84
|
+
|
85
|
+
const {
|
86
|
+
title,
|
87
|
+
description,
|
88
|
+
email,
|
89
|
+
phone,
|
90
|
+
address,
|
91
|
+
website,
|
92
|
+
github,
|
93
|
+
twitter,
|
94
|
+
facebook,
|
95
|
+
linkedin,
|
96
|
+
compact,
|
97
|
+
class: className = '',
|
98
|
+
} = Astro.props;
|
99
|
+
|
100
|
+
// 构建联系信息容器样式
|
101
|
+
const contactClasses = [
|
102
|
+
'cosy:card',
|
103
|
+
'cosy:w-full',
|
104
|
+
'cosy:bg-base-100',
|
105
|
+
'cosy:shadow-lg',
|
106
|
+
compact ? 'cosy:card-compact' : '',
|
107
|
+
className,
|
108
|
+
]
|
109
|
+
.filter(Boolean)
|
110
|
+
.join(' ');
|
111
|
+
|
112
|
+
// 内容区域的padding
|
113
|
+
const contentPadding = compact ? 'cosy:p-4' : 'cosy:p-6';
|
114
|
+
|
115
|
+
// 联系信息项的样式
|
116
|
+
const contactItemClass =
|
117
|
+
'cosy:flex cosy:items-center cosy:gap-3 cosy:mb-4 last:cosy:mb-0';
|
118
|
+
const iconClass = 'cosy:w-5 cosy:h-5 cosy:text-primary cosy:flex-shrink-0';
|
119
|
+
const linkClass =
|
120
|
+
'cosy:link cosy:link-hover cosy:text-base-content cosy:no-underline hover:cosy:text-primary cosy:transition-colors';
|
121
|
+
|
122
|
+
// 社交媒体链接样式
|
123
|
+
const socialLinksClass =
|
124
|
+
'cosy:flex cosy:gap-4 cosy:mt-6 cosy:pt-4 cosy:border-t cosy:border-base-300';
|
125
|
+
const socialLinkClass =
|
126
|
+
'cosy:btn cosy:btn-ghost cosy:btn-circle cosy:btn-sm cosy:text-base-content hover:cosy:text-primary hover:cosy:bg-primary/10';
|
127
|
+
---
|
128
|
+
|
129
|
+
<div class={contactClasses}>
|
130
|
+
<div class={`cosy:card-body ${contentPadding}`}>
|
131
|
+
{
|
132
|
+
title && (
|
133
|
+
<h2 class="cosy:card-title cosy:text-2xl cosy:font-bold cosy:mb-2">
|
134
|
+
{title}
|
135
|
+
</h2>
|
136
|
+
)
|
137
|
+
}
|
138
|
+
|
139
|
+
{
|
140
|
+
description && (
|
141
|
+
<p class="cosy:text-base-content/70 cosy:mb-6">{description}</p>
|
142
|
+
)
|
143
|
+
}
|
144
|
+
|
145
|
+
<div class="cosy:space-y-0">
|
146
|
+
{
|
147
|
+
email && (
|
148
|
+
<div class={contactItemClass}>
|
149
|
+
<svg
|
150
|
+
class={iconClass}
|
151
|
+
fill="none"
|
152
|
+
stroke="currentColor"
|
153
|
+
viewBox="0 0 24 24">
|
154
|
+
<path
|
155
|
+
stroke-linecap="round"
|
156
|
+
stroke-linejoin="round"
|
157
|
+
stroke-width="2"
|
158
|
+
d="M3 8l7.89 4.26a2 2 0 002.22 0L21 8M5 19h14a2 2 0 002-2V7a2 2 0 00-2-2H5a2 2 0 00-2 2v10a2 2 0 002 2z"
|
159
|
+
/>
|
160
|
+
</svg>
|
161
|
+
<a href={`mailto:${email}`} class={linkClass}>
|
162
|
+
{email}
|
163
|
+
</a>
|
164
|
+
</div>
|
165
|
+
)
|
166
|
+
}
|
167
|
+
|
168
|
+
{
|
169
|
+
phone && (
|
170
|
+
<div class={contactItemClass}>
|
171
|
+
<svg
|
172
|
+
class={iconClass}
|
173
|
+
fill="none"
|
174
|
+
stroke="currentColor"
|
175
|
+
viewBox="0 0 24 24">
|
176
|
+
<path
|
177
|
+
stroke-linecap="round"
|
178
|
+
stroke-linejoin="round"
|
179
|
+
stroke-width="2"
|
180
|
+
d="M3 5a2 2 0 012-2h3.28a1 1 0 01.948.684l1.498 4.493a1 1 0 01-.502 1.21l-2.257 1.13a11.042 11.042 0 005.516 5.516l1.13-2.257a1 1 0 011.21-.502l4.493 1.498a1 1 0 01.684.949V19a2 2 0 01-2 2h-1C9.716 21 3 14.284 3 6V5z"
|
181
|
+
/>
|
182
|
+
</svg>
|
183
|
+
<a href={`tel:${phone}`} class={linkClass}>
|
184
|
+
{phone}
|
185
|
+
</a>
|
186
|
+
</div>
|
187
|
+
)
|
188
|
+
}
|
189
|
+
|
190
|
+
{
|
191
|
+
address && (
|
192
|
+
<div class={contactItemClass}>
|
193
|
+
<svg
|
194
|
+
class={iconClass}
|
195
|
+
fill="none"
|
196
|
+
stroke="currentColor"
|
197
|
+
viewBox="0 0 24 24">
|
198
|
+
<path
|
199
|
+
stroke-linecap="round"
|
200
|
+
stroke-linejoin="round"
|
201
|
+
stroke-width="2"
|
202
|
+
d="M17.657 16.657L13.414 20.9a1.998 1.998 0 01-2.827 0l-4.244-4.243a8 8 0 1111.314 0z"
|
203
|
+
/>
|
204
|
+
<path
|
205
|
+
stroke-linecap="round"
|
206
|
+
stroke-linejoin="round"
|
207
|
+
stroke-width="2"
|
208
|
+
d="M15 11a3 3 0 11-6 0 3 3 0 016 0z"
|
209
|
+
/>
|
210
|
+
</svg>
|
211
|
+
<span class="cosy:text-base-content">{address}</span>
|
212
|
+
</div>
|
213
|
+
)
|
214
|
+
}
|
215
|
+
|
216
|
+
{
|
217
|
+
website && (
|
218
|
+
<div class={contactItemClass}>
|
219
|
+
<svg
|
220
|
+
class={iconClass}
|
221
|
+
fill="none"
|
222
|
+
stroke="currentColor"
|
223
|
+
viewBox="0 0 24 24">
|
224
|
+
<path
|
225
|
+
stroke-linecap="round"
|
226
|
+
stroke-linejoin="round"
|
227
|
+
stroke-width="2"
|
228
|
+
d="M21 12a9 9 0 01-9 9m9-9a9 9 0 00-9-9m9 9H3m9 9a9 9 0 01-9-9m9 9c1.657 0 3-4.03 3-9s-1.343-9-3-9m0 18c-1.657 0-3-4.03-3-9s1.343-9 3-9m-9 9a9 9 0 019-9"
|
229
|
+
/>
|
230
|
+
</svg>
|
231
|
+
<a
|
232
|
+
href={website}
|
233
|
+
target="_blank"
|
234
|
+
rel="noopener noreferrer"
|
235
|
+
class={linkClass}>
|
236
|
+
{website.replace(/^https?:\/\//, '')}
|
237
|
+
</a>
|
238
|
+
</div>
|
239
|
+
)
|
240
|
+
}
|
241
|
+
</div>
|
242
|
+
|
243
|
+
{
|
244
|
+
Astro.slots.has('default') && (
|
245
|
+
<div class="cosy:mt-4">
|
246
|
+
<slot />
|
247
|
+
</div>
|
248
|
+
)
|
249
|
+
}
|
250
|
+
|
251
|
+
{
|
252
|
+
(github || twitter || facebook || linkedin) && (
|
253
|
+
<div class={socialLinksClass}>
|
254
|
+
{github && (
|
255
|
+
<a
|
256
|
+
href={github}
|
257
|
+
target="_blank"
|
258
|
+
rel="noopener noreferrer"
|
259
|
+
class={socialLinkClass}
|
260
|
+
title="GitHub">
|
261
|
+
<svg
|
262
|
+
class="cosy:w-5 cosy:h-5"
|
263
|
+
fill="currentColor"
|
264
|
+
viewBox="0 0 24 24">
|
265
|
+
<path d="M12 0c-6.626 0-12 5.373-12 12 0 5.302 3.438 9.8 8.207 11.387.599.111.793-.261.793-.577v-2.234c-3.338.726-4.033-1.416-4.033-1.416-.546-1.387-1.333-1.756-1.333-1.756-1.089-.745.083-.729.083-.729 1.205.084 1.839 1.237 1.839 1.237 1.07 1.834 2.807 1.304 3.492.997.107-.775.418-1.305.762-1.604-2.665-.305-5.467-1.334-5.467-5.931 0-1.311.469-2.381 1.236-3.221-.124-.303-.535-1.524.117-3.176 0 0 1.008-.322 3.301 1.23.957-.266 1.983-.399 3.003-.404 1.02.005 2.047.138 3.006.404 2.291-1.552 3.297-1.23 3.297-1.23.653 1.653.242 2.874.118 3.176.77.84 1.235 1.911 1.235 3.221 0 4.609-2.807 5.624-5.479 5.921.43.372.823 1.102.823 2.222v3.293c0 .319.192.694.801.576 4.765-1.589 8.199-6.086 8.199-11.386 0-6.627-5.373-12-12-12z" />
|
266
|
+
</svg>
|
267
|
+
</a>
|
268
|
+
)}
|
269
|
+
|
270
|
+
{twitter && (
|
271
|
+
<a
|
272
|
+
href={twitter}
|
273
|
+
target="_blank"
|
274
|
+
rel="noopener noreferrer"
|
275
|
+
class={socialLinkClass}
|
276
|
+
title="Twitter">
|
277
|
+
<svg
|
278
|
+
class="cosy:w-5 cosy:h-5"
|
279
|
+
fill="currentColor"
|
280
|
+
viewBox="0 0 24 24">
|
281
|
+
<path d="M23.953 4.57a10 10 0 01-2.825.775 4.958 4.958 0 002.163-2.723c-.951.555-2.005.959-3.127 1.184a4.92 4.92 0 00-8.384 4.482C7.69 8.095 4.067 6.13 1.64 3.162a4.822 4.822 0 00-.666 2.475c0 1.71.87 3.213 2.188 4.096a4.904 4.904 0 01-2.228-.616v.06a4.923 4.923 0 003.946 4.827 4.996 4.996 0 01-2.212.085 4.936 4.936 0 004.604 3.417 9.867 9.867 0 01-6.102 2.105c-.39 0-.779-.023-1.17-.067a13.995 13.995 0 007.557 2.209c9.053 0 13.998-7.496 13.998-13.985 0-.21 0-.42-.015-.63A9.935 9.935 0 0024 4.59z" />
|
282
|
+
</svg>
|
283
|
+
</a>
|
284
|
+
)}
|
285
|
+
|
286
|
+
{facebook && (
|
287
|
+
<a
|
288
|
+
href={facebook}
|
289
|
+
target="_blank"
|
290
|
+
rel="noopener noreferrer"
|
291
|
+
class={socialLinkClass}
|
292
|
+
title="Facebook">
|
293
|
+
<svg
|
294
|
+
class="cosy:w-5 cosy:h-5"
|
295
|
+
fill="currentColor"
|
296
|
+
viewBox="0 0 24 24">
|
297
|
+
<path d="M24 12.073c0-6.627-5.373-12-12-12s-12 5.373-12 12c0 5.99 4.388 10.954 10.125 11.854v-8.385H7.078v-3.47h3.047V9.43c0-3.007 1.792-4.669 4.533-4.669 1.312 0 2.686.235 2.686.235v2.953H15.83c-1.491 0-1.956.925-1.956 1.874v2.25h3.328l-.532 3.47h-2.796v8.385C19.612 23.027 24 18.062 24 12.073z" />
|
298
|
+
</svg>
|
299
|
+
</a>
|
300
|
+
)}
|
301
|
+
|
302
|
+
{linkedin && (
|
303
|
+
<a
|
304
|
+
href={linkedin}
|
305
|
+
target="_blank"
|
306
|
+
rel="noopener noreferrer"
|
307
|
+
class={socialLinkClass}
|
308
|
+
title="LinkedIn">
|
309
|
+
<svg
|
310
|
+
class="cosy:w-5 cosy:h-5"
|
311
|
+
fill="currentColor"
|
312
|
+
viewBox="0 0 24 24">
|
313
|
+
<path d="M20.447 20.452h-3.554v-5.569c0-1.328-.027-3.037-1.852-3.037-1.853 0-2.136 1.445-2.136 2.939v5.667H9.351V9h3.414v1.561h.046c.477-.9 1.637-1.85 3.37-1.85 3.601 0 4.267 2.37 4.267 5.455v6.286zM5.337 7.433c-1.144 0-2.063-.926-2.063-2.065 0-1.138.92-2.063 2.063-2.063 1.14 0 2.064.925 2.064 2.063 0 1.139-.925 2.065-2.064 2.065zm1.782 13.019H3.555V9h3.564v11.452zM22.225 0H1.771C.792 0 0 .774 0 1.729v20.542C0 23.227.792 24 1.771 24h20.451C23.2 24 24 23.227 24 22.271V1.729C24 .774 23.2 0 22.222 0h.003z" />
|
314
|
+
</svg>
|
315
|
+
</a>
|
316
|
+
)}
|
317
|
+
</div>
|
318
|
+
)
|
319
|
+
}
|
320
|
+
</div>
|
321
|
+
</div>
|
@@ -0,0 +1,15 @@
|
|
1
|
+
---
|
2
|
+
/**
|
3
|
+
* @component Contact.Basic
|
4
|
+
*
|
5
|
+
* @description
|
6
|
+
* 基础Contact组件示例,展示最简单的联系信息用法。
|
7
|
+
*/
|
8
|
+
import Contact from './Contact.astro';
|
9
|
+
---
|
10
|
+
|
11
|
+
<Contact
|
12
|
+
email="contact@company.com"
|
13
|
+
phone="+1 (555) 123-4567"
|
14
|
+
address="123 Business St, City, State 12345"
|
15
|
+
/>
|
@@ -0,0 +1,11 @@
|
|
1
|
+
---
|
2
|
+
import { CodeContainer } from '../../index-astro';
|
3
|
+
import ContactBasic from './EContactBasic.astro';
|
4
|
+
import ContactBasicSourceCode from './EContactBasic.astro?raw';
|
5
|
+
---
|
6
|
+
|
7
|
+
<CodeContainer codes={[ContactBasicSourceCode]}>
|
8
|
+
<div id="tab-1">
|
9
|
+
<ContactBasic />
|
10
|
+
</div>
|
11
|
+
</CodeContainer>
|
@@ -0,0 +1,11 @@
|
|
1
|
+
---
|
2
|
+
import { CodeContainer } from '../../index-astro';
|
3
|
+
import ContactCompact from './EContactCompact.astro';
|
4
|
+
import ContactCompactSourceCode from './EContactCompact.astro?raw';
|
5
|
+
---
|
6
|
+
|
7
|
+
<CodeContainer codes={[ContactCompactSourceCode]}>
|
8
|
+
<div id="tab-1">
|
9
|
+
<ContactCompact />
|
10
|
+
</div>
|
11
|
+
</CodeContainer>
|
@@ -0,0 +1,21 @@
|
|
1
|
+
---
|
2
|
+
/**
|
3
|
+
* @component Contact.CustomStyle
|
4
|
+
*
|
5
|
+
* @description
|
6
|
+
* 展示如何使用class属性自定义Contact组件的样式。
|
7
|
+
*/
|
8
|
+
import '../../style.ts';
|
9
|
+
import Contact from './Contact.astro';
|
10
|
+
---
|
11
|
+
|
12
|
+
<Contact
|
13
|
+
title="联系我们"
|
14
|
+
description="自定义样式的联系信息卡片"
|
15
|
+
email="contact@company.com"
|
16
|
+
phone="+1 (555) 123-4567"
|
17
|
+
address="123 Business St, City, State 12345"
|
18
|
+
github="https://github.com/company"
|
19
|
+
twitter="https://twitter.com/company"
|
20
|
+
class="cosy:bg-gradient-to-br cosy:from-blue-50 cosy:to-purple-50 cosy:border-2 cosy:border-blue-200 cosy:shadow-2xl"
|
21
|
+
/>
|
@@ -0,0 +1,11 @@
|
|
1
|
+
---
|
2
|
+
import { CodeContainer } from '../../index-astro';
|
3
|
+
import ContactCustomStyle from './EContactCustomStyle.astro';
|
4
|
+
import ContactCustomStyleSourceCode from './EContactCustomStyle.astro?raw';
|
5
|
+
---
|
6
|
+
|
7
|
+
<CodeContainer codes={[ContactCustomStyleSourceCode]}>
|
8
|
+
<div id="tab-1">
|
9
|
+
<ContactCustomStyle />
|
10
|
+
</div>
|
11
|
+
</CodeContainer>
|
@@ -0,0 +1,20 @@
|
|
1
|
+
---
|
2
|
+
/**
|
3
|
+
* @component Contact.Social
|
4
|
+
*
|
5
|
+
* @description
|
6
|
+
* 带社交媒体链接的Contact组件示例。
|
7
|
+
*/
|
8
|
+
import Contact from './Contact.astro';
|
9
|
+
---
|
10
|
+
|
11
|
+
<Contact
|
12
|
+
title="联系我们"
|
13
|
+
email="contact@company.com"
|
14
|
+
phone="+1 (555) 123-4567"
|
15
|
+
website="https://www.company.com"
|
16
|
+
github="https://github.com/company"
|
17
|
+
twitter="https://twitter.com/company"
|
18
|
+
facebook="https://facebook.com/company"
|
19
|
+
linkedin="https://linkedin.com/company/company"
|
20
|
+
/>
|
@@ -0,0 +1,11 @@
|
|
1
|
+
---
|
2
|
+
import { CodeContainer } from '../../index-astro';
|
3
|
+
import ContactSocial from './EContactSocial.astro';
|
4
|
+
import ContactSocialSourceCode from './EContactSocial.astro?raw';
|
5
|
+
---
|
6
|
+
|
7
|
+
<CodeContainer codes={[ContactSocialSourceCode]}>
|
8
|
+
<div id="tab-1">
|
9
|
+
<ContactSocial />
|
10
|
+
</div>
|
11
|
+
</CodeContainer>
|
@@ -0,0 +1,17 @@
|
|
1
|
+
---
|
2
|
+
/**
|
3
|
+
* @component Contact.WithTitle
|
4
|
+
*
|
5
|
+
* @description
|
6
|
+
* 带标题和描述的Contact组件示例。
|
7
|
+
*/
|
8
|
+
import Contact from './Contact.astro';
|
9
|
+
---
|
10
|
+
|
11
|
+
<Contact
|
12
|
+
title="联系我们"
|
13
|
+
description="欢迎随时与我们取得联系,我们将尽快回复您"
|
14
|
+
email="contact@company.com"
|
15
|
+
phone="+1 (555) 123-4567"
|
16
|
+
address="123 Business St, City, State 12345"
|
17
|
+
/>
|
@@ -0,0 +1,11 @@
|
|
1
|
+
---
|
2
|
+
import { CodeContainer } from '../../index-astro';
|
3
|
+
import ContactWithTitle from './EContactWithTitle.astro';
|
4
|
+
import ContactWithTitleSourceCode from './EContactWithTitle.astro?raw';
|
5
|
+
---
|
6
|
+
|
7
|
+
<CodeContainer codes={[ContactWithTitleSourceCode]}>
|
8
|
+
<div id="tab-1">
|
9
|
+
<ContactWithTitle />
|
10
|
+
</div>
|
11
|
+
</CodeContainer>
|
@@ -0,0 +1,21 @@
|
|
1
|
+
import Contact from './Contact.astro';
|
2
|
+
|
3
|
+
// Container components
|
4
|
+
import ContactBasicContainer from './EContactBasicContainer.astro';
|
5
|
+
import ContactWithTitleContainer from './EContactWithTitleContainer.astro';
|
6
|
+
import ContactSocialContainer from './EContactSocialContainer.astro';
|
7
|
+
import ContactCompactContainer from './EContactCompactContainer.astro';
|
8
|
+
import ContactCustomStyleContainer from './EContactCustomStyleContainer.astro';
|
9
|
+
|
10
|
+
export { Contact };
|
11
|
+
|
12
|
+
export const ContactPackage = {
|
13
|
+
Contact,
|
14
|
+
ContactContainers: {
|
15
|
+
Basic: ContactBasicContainer,
|
16
|
+
WithTitle: ContactWithTitleContainer,
|
17
|
+
Social: ContactSocialContainer,
|
18
|
+
Compact: ContactCompactContainer,
|
19
|
+
CustomStyle: ContactCustomStyleContainer,
|
20
|
+
},
|
21
|
+
};
|