@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,51 @@
|
|
1
|
+
---
|
2
|
+
import DashboardLayout from './DashboardLayout.astro';
|
3
|
+
import type { IMenuItem } from '../types/menu';
|
4
|
+
|
5
|
+
const menuItems: IMenuItem[] = [
|
6
|
+
{
|
7
|
+
text: '仪表盘',
|
8
|
+
href: '/dashboard',
|
9
|
+
icon: 'dashboard',
|
10
|
+
},
|
11
|
+
{
|
12
|
+
text: '用户管理',
|
13
|
+
href: '/dashboard/users',
|
14
|
+
icon: 'users',
|
15
|
+
},
|
16
|
+
{
|
17
|
+
text: '设置',
|
18
|
+
href: '/dashboard/settings',
|
19
|
+
icon: 'settings',
|
20
|
+
},
|
21
|
+
];
|
22
|
+
---
|
23
|
+
|
24
|
+
<DashboardLayout
|
25
|
+
title="仪表盘布局示例"
|
26
|
+
description="这是一个仪表盘布局的示例页面"
|
27
|
+
navItems={menuItems}
|
28
|
+
>
|
29
|
+
<div
|
30
|
+
class="cosy:grid cosy:grid-cols-1 cosy:md:grid-cols-2 cosy:lg:grid-cols-3 cosy:gap-4"
|
31
|
+
>
|
32
|
+
<div class="cosy:card cosy:bg-base-100 cosy:shadow-xl">
|
33
|
+
<div class="cosy:card-body">
|
34
|
+
<h2 class="cosy:card-title">总用户数</h2>
|
35
|
+
<p class="cosy:text-4xl cosy:font-bold">1,234</p>
|
36
|
+
</div>
|
37
|
+
</div>
|
38
|
+
<div class="cosy:card cosy:bg-base-100 cosy:shadow-xl">
|
39
|
+
<div class="cosy:card-body">
|
40
|
+
<h2 class="cosy:card-title">今日活跃</h2>
|
41
|
+
<p class="cosy:text-4xl cosy:font-bold">567</p>
|
42
|
+
</div>
|
43
|
+
</div>
|
44
|
+
<div class="cosy:card cosy:bg-base-100 cosy:shadow-xl">
|
45
|
+
<div class="cosy:card-body">
|
46
|
+
<h2 class="cosy:card-title">转化率</h2>
|
47
|
+
<p class="cosy:text-4xl cosy:font-bold">45.8%</p>
|
48
|
+
</div>
|
49
|
+
</div>
|
50
|
+
</div>
|
51
|
+
</DashboardLayout>
|
@@ -54,7 +54,7 @@
|
|
54
54
|
* ```
|
55
55
|
*/
|
56
56
|
|
57
|
-
import '
|
57
|
+
import '../../style.ts';
|
58
58
|
|
59
59
|
import type { HTMLAttributes } from 'astro/types';
|
60
60
|
|
@@ -62,84 +62,99 @@ import type { HTMLAttributes } from 'astro/types';
|
|
62
62
|
type LinkSize = 'sm' | 'md' | 'lg';
|
63
63
|
|
64
64
|
// 定义链接变体类型
|
65
|
-
type LinkVariant =
|
65
|
+
type LinkVariant =
|
66
|
+
| 'default'
|
67
|
+
| 'primary'
|
68
|
+
| 'secondary'
|
69
|
+
| 'text'
|
70
|
+
| 'cta'
|
71
|
+
| 'ghost'
|
72
|
+
| 'light';
|
66
73
|
|
67
74
|
// 定义链接动画类型
|
68
75
|
type LinkAnimation = 'none' | 'hover-lift' | 'hover-glow' | 'hover-scale';
|
69
76
|
|
70
77
|
interface Props extends HTMLAttributes<'a'> {
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
78
|
+
href: string;
|
79
|
+
external?: boolean;
|
80
|
+
block?: boolean;
|
81
|
+
class?: string;
|
82
|
+
'class:list'?: any;
|
83
|
+
variant?: LinkVariant;
|
84
|
+
animation?: LinkAnimation;
|
85
|
+
size?: LinkSize;
|
86
|
+
debug?: boolean;
|
87
|
+
centerText?: boolean;
|
81
88
|
}
|
82
89
|
|
83
90
|
const {
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
91
|
+
href,
|
92
|
+
external = false,
|
93
|
+
block = false,
|
94
|
+
variant = 'default',
|
95
|
+
animation = 'none',
|
96
|
+
size = 'md',
|
97
|
+
class: className = '',
|
98
|
+
'class:list': classList,
|
99
|
+
debug = false,
|
100
|
+
centerText = false,
|
101
|
+
...rest
|
95
102
|
} = Astro.props;
|
96
103
|
|
97
104
|
// 构建类名
|
98
105
|
const classes = [
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
|
117
|
-
|
118
|
-
|
119
|
-
|
120
|
-
|
121
|
-
|
122
|
-
|
123
|
-
|
124
|
-
|
125
|
-
|
106
|
+
// 基础链接样式
|
107
|
+
'cosy:items-center cosy:cursor-pointer cosy:no-underline cosy:transition-all cosy:duration-200',
|
108
|
+
|
109
|
+
// 显示方式
|
110
|
+
block ? 'cosy:flex cosy:w-full' : 'cosy:inline-flex',
|
111
|
+
|
112
|
+
// 变体样式
|
113
|
+
variant === 'primary' && 'cosy:text-primary cosy:hover:text-primary-focus',
|
114
|
+
variant === 'secondary' &&
|
115
|
+
'cosy:text-secondary cosy:hover:text-secondary-focus',
|
116
|
+
variant === 'text' && 'cosy:text-neutral cosy:hover:text-neutral-focus',
|
117
|
+
variant === 'cta' &&
|
118
|
+
'cosy:text-accent cosy:hover:text-accent-focus cosy:font-medium',
|
119
|
+
variant === 'ghost' &&
|
120
|
+
'cosy:text-base-content cosy:hover:text-base-content/80',
|
121
|
+
variant === 'default' &&
|
122
|
+
'cosy:text-base-content cosy:hover:text-base-content/90',
|
123
|
+
variant === 'light' &&
|
124
|
+
'cosy:text-white cosy:hover:text-white/90 cosy:font-medium',
|
125
|
+
|
126
|
+
// 尺寸样式
|
127
|
+
size === 'sm' && 'cosy:text-sm',
|
128
|
+
size === 'md' && 'cosy:text-base',
|
129
|
+
size === 'lg' && 'cosy:text-lg',
|
130
|
+
|
131
|
+
// 动画效果
|
132
|
+
animation === 'hover-lift' &&
|
133
|
+
'cosy:hover:-translate-y-0.5 cosy:transition-transform',
|
134
|
+
animation === 'hover-glow' &&
|
135
|
+
'cosy:hover:brightness-125 cosy:transition-[filter]',
|
136
|
+
animation === 'hover-scale' &&
|
137
|
+
'cosy:hover:scale-105 cosy:transition-transform',
|
138
|
+
|
139
|
+
// 自定义类名
|
140
|
+
className,
|
126
141
|
];
|
127
142
|
|
128
143
|
// 文本居中样式
|
129
144
|
if (centerText) {
|
130
|
-
|
145
|
+
classes.push('cosy:justify-center cosy:text-center');
|
131
146
|
}
|
132
147
|
|
133
148
|
// 调试样式
|
134
149
|
if (debug) {
|
135
|
-
|
150
|
+
classes.push('cosy:border cosy:border-dashed cosy:border-red-500');
|
136
151
|
}
|
137
152
|
---
|
138
153
|
|
139
154
|
<a
|
140
|
-
|
141
|
-
|
142
|
-
|
143
|
-
|
144
|
-
|
155
|
+
href={href}
|
156
|
+
class:list={[classes, classList]}
|
157
|
+
{...external ? { target: '_blank', rel: 'noopener noreferrer' } : {}}
|
158
|
+
{...rest}>
|
159
|
+
<slot />
|
145
160
|
</a>
|
@@ -0,0 +1,29 @@
|
|
1
|
+
---
|
2
|
+
import Link from './Link.astro';
|
3
|
+
---
|
4
|
+
|
5
|
+
<div class="cosy:space-y-4">
|
6
|
+
<div class="cosy:flex cosy:gap-4">
|
7
|
+
<Link href="/hover-lift" animation="hover-lift" variant="primary">
|
8
|
+
上浮效果
|
9
|
+
</Link>
|
10
|
+
|
11
|
+
<Link href="/hover-glow" animation="hover-glow" variant="secondary">
|
12
|
+
发光效果
|
13
|
+
</Link>
|
14
|
+
|
15
|
+
<Link href="/hover-scale" animation="hover-scale" variant="cta">
|
16
|
+
缩放效果
|
17
|
+
</Link>
|
18
|
+
</div>
|
19
|
+
|
20
|
+
<div class="cosy:flex cosy:gap-4">
|
21
|
+
<Link href="/block-link" block centerText variant="primary">
|
22
|
+
块级居中链接
|
23
|
+
</Link>
|
24
|
+
</div>
|
25
|
+
|
26
|
+
<div class="cosy:bg-base-200 cosy:p-4">
|
27
|
+
<Link href="/light-variant" variant="light"> 浅色背景中的链接 </Link>
|
28
|
+
</div>
|
29
|
+
</div>
|
@@ -0,0 +1,17 @@
|
|
1
|
+
---
|
2
|
+
import Link from './Link.astro';
|
3
|
+
---
|
4
|
+
|
5
|
+
<div class="cosy:space-y-4">
|
6
|
+
<div>
|
7
|
+
<Link href="/about">默认链接</Link>
|
8
|
+
</div>
|
9
|
+
|
10
|
+
<div>
|
11
|
+
<Link href="https://example.com" external>外部链接</Link>
|
12
|
+
</div>
|
13
|
+
|
14
|
+
<div>
|
15
|
+
<p>这是一段文字,其中包含一个<Link href="/inline">内联链接</Link>。</p>
|
16
|
+
</div>
|
17
|
+
</div>
|
@@ -0,0 +1,20 @@
|
|
1
|
+
---
|
2
|
+
import Link from './Link.astro';
|
3
|
+
---
|
4
|
+
|
5
|
+
<div class="cosy:space-y-4">
|
6
|
+
<div class="cosy:flex cosy:gap-4">
|
7
|
+
<Link href="/signup" variant="primary">主要链接</Link>
|
8
|
+
<Link href="/learn-more" variant="secondary">次要链接</Link>
|
9
|
+
<Link href="/docs" variant="text">文本链接</Link>
|
10
|
+
<Link href="/get-started" variant="cta">行动号召</Link>
|
11
|
+
<Link href="/preview" variant="ghost">幽灵链接</Link>
|
12
|
+
<Link href="/help" variant="light">浅色链接</Link>
|
13
|
+
</div>
|
14
|
+
|
15
|
+
<div class="cosy:flex cosy:gap-4">
|
16
|
+
<Link href="/small" size="sm">小型链接</Link>
|
17
|
+
<Link href="/medium" size="md">中型链接</Link>
|
18
|
+
<Link href="/large" size="lg">大型链接</Link>
|
19
|
+
</div>
|
20
|
+
</div>
|
@@ -11,7 +11,7 @@ export { Link, LinkBasic, LinkVariants, LinkAnimations };
|
|
11
11
|
|
12
12
|
// 导出示例源代码
|
13
13
|
export const LinkExampleCodes = {
|
14
|
-
|
15
|
-
|
16
|
-
|
14
|
+
Basic: extractSimpleExample(BasicSourceCode, 'Link'),
|
15
|
+
Variants: extractSimpleExample(VariantsSourceCode, 'Link'),
|
16
|
+
Animations: extractSimpleExample(AnimationsSourceCode, 'Link'),
|
17
17
|
};
|
@@ -47,63 +47,69 @@
|
|
47
47
|
* </Main>
|
48
48
|
* ```
|
49
49
|
*/
|
50
|
-
import '
|
51
|
-
import {
|
50
|
+
import '../../style.ts';
|
51
|
+
import {
|
52
|
+
Article,
|
53
|
+
TableOfContents,
|
54
|
+
type IMainContentProps,
|
55
|
+
} from '../../index-astro';
|
52
56
|
|
53
57
|
export interface Props extends IMainContentProps {}
|
54
58
|
|
55
59
|
const {
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
60
|
+
size = 'md',
|
61
|
+
padding = 'md',
|
62
|
+
verticalPadding = 'md',
|
63
|
+
centered = true,
|
64
|
+
backgroundColor,
|
65
|
+
layout = 'row',
|
66
|
+
isArticle = false,
|
67
|
+
id,
|
68
|
+
showTableOfContents = false,
|
69
|
+
class: className,
|
70
|
+
'class:list': classList,
|
71
|
+
currentLocale,
|
72
|
+
...rest
|
69
73
|
} = Astro.props;
|
70
74
|
|
71
75
|
// 新增获取布局类的函数
|
72
76
|
function getLayoutClasses(layout: string) {
|
73
|
-
|
74
|
-
|
75
|
-
|
77
|
+
if (layout === 'row') return 'cosy:flex cosy:flex-row';
|
78
|
+
if (layout === 'column') return 'cosy:flex cosy:flex-col';
|
79
|
+
return 'cosy:flex cosy:flex-col'; // 默认列布局
|
76
80
|
}
|
77
81
|
|
78
82
|
const layoutClass = getLayoutClasses(layout as string);
|
79
83
|
|
80
84
|
// 获取垂直内边距的Tailwind类
|
81
85
|
function getVerticalPaddingClasses(padding: string) {
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
86
|
+
if (padding === 'none') return 'cosy:py-0';
|
87
|
+
if (padding === 'xs') return 'cosy:py-1';
|
88
|
+
if (padding === 'sm') return 'cosy:py-2';
|
89
|
+
if (padding === 'md') return 'cosy:py-4';
|
90
|
+
if (padding === 'lg') return 'cosy:py-6';
|
91
|
+
if (padding === 'xl') return 'cosy:py-8';
|
92
|
+
if (padding === '2xl') return 'cosy:py-10';
|
93
|
+
if (padding === '3xl') return 'cosy:py-12';
|
94
|
+
if (padding === '4xl') return 'cosy:py-16';
|
95
|
+
if (padding === '5xl') return 'cosy:py-20';
|
96
|
+
return ''; // 对于自定义padding,使用内联样式
|
93
97
|
}
|
94
98
|
|
95
99
|
// 获取背景颜色的Tailwind类
|
96
100
|
function getBgColorClasses(color: string | undefined) {
|
97
|
-
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
|
101
|
+
if (!color) return '';
|
102
|
+
if (color === 'primary') return 'cosy:bg-primary';
|
103
|
+
if (color === 'secondary') return 'cosy:bg-secondary';
|
104
|
+
if (color === 'tertiary') return 'cosy:bg-accent';
|
105
|
+
if (color === 'light') return 'cosy:bg-base-100';
|
106
|
+
if (color === 'dark') return 'cosy:bg-base-300';
|
107
|
+
return ''; // 对于自定义颜色,使用内联样式
|
104
108
|
}
|
105
109
|
|
106
|
-
const verticalPaddingClass = getVerticalPaddingClasses(
|
110
|
+
const verticalPaddingClass = getVerticalPaddingClasses(
|
111
|
+
verticalPadding as string
|
112
|
+
);
|
107
113
|
const bgColorClass = getBgColorClasses(backgroundColor);
|
108
114
|
|
109
115
|
// 构建自定义样式
|
@@ -111,37 +117,39 @@ const customStyle = [];
|
|
111
117
|
|
112
118
|
// 只有当没有对应的Tailwind类时,才使用内联样式
|
113
119
|
if (!verticalPaddingClass && verticalPadding && verticalPadding !== 'none') {
|
114
|
-
|
120
|
+
customStyle.push(
|
121
|
+
`padding-top: ${verticalPadding}; padding-bottom: ${verticalPadding};`
|
122
|
+
);
|
115
123
|
}
|
116
124
|
|
117
125
|
if (!bgColorClass && backgroundColor) {
|
118
|
-
|
126
|
+
customStyle.push(`background-color: ${backgroundColor};`);
|
119
127
|
}
|
120
128
|
|
121
129
|
const inlineStyle = customStyle.length > 0 ? customStyle.join(' ') : undefined;
|
122
130
|
---
|
123
131
|
|
124
132
|
<main
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
|
131
|
-
|
132
|
-
|
133
|
-
|
134
|
-
|
135
|
-
|
136
|
-
|
137
|
-
|
138
|
-
|
139
|
-
|
140
|
-
|
141
|
-
|
142
|
-
|
143
|
-
|
144
|
-
|
133
|
+
id={id}
|
134
|
+
class:list={[
|
135
|
+
'cosy:w-full',
|
136
|
+
layoutClass,
|
137
|
+
verticalPaddingClass,
|
138
|
+
bgColorClass,
|
139
|
+
className,
|
140
|
+
classList,
|
141
|
+
]}
|
142
|
+
style={inlineStyle}
|
143
|
+
{...rest}>
|
144
|
+
{
|
145
|
+
isArticle ? (
|
146
|
+
<Article>
|
147
|
+
<slot />
|
148
|
+
</Article>
|
149
|
+
) : (
|
150
|
+
<slot />
|
151
|
+
)
|
152
|
+
}
|
145
153
|
|
146
|
-
|
154
|
+
{showTableOfContents && <TableOfContents lang={currentLocale} />}
|
147
155
|
</main>
|
@@ -0,0 +1 @@
|
|
1
|
+
export { default as Main } from './Main.astro';
|
@@ -0,0 +1,126 @@
|
|
1
|
+
---
|
2
|
+
/**
|
3
|
+
* @component Modal
|
4
|
+
*
|
5
|
+
* @description
|
6
|
+
* Modal 组件是一个模态对话框,用于在不离开当前页面的情况下显示内容、通知或请求用户输入。
|
7
|
+
* 它会覆盖在页面内容上方,并提供一个聚焦的交互环境。
|
8
|
+
*
|
9
|
+
* @design
|
10
|
+
* 设计理念:
|
11
|
+
* 1. 聚焦交互 - 通过遮罩层和动画效果引导用户注意力
|
12
|
+
* 2. 灵活布局 - 支持标题、内容和操作按钮的灵活组合
|
13
|
+
* 3. 可访问性 - 支持键盘导航和屏幕阅读器
|
14
|
+
* 4. 响应式设计 - 在不同屏幕尺寸下保持良好的用户体验
|
15
|
+
*
|
16
|
+
* @usage
|
17
|
+
* 基本用法:
|
18
|
+
* ```astro
|
19
|
+
* <Modal id="my-modal" title="提示">
|
20
|
+
* <p>这是一个模态对话框的内容。</p>
|
21
|
+
* <button slot="actions" data-modal-target="my-modal">关闭</button>
|
22
|
+
* </Modal>
|
23
|
+
*
|
24
|
+
* <!-- 触发按钮 -->
|
25
|
+
* <button data-modal-target="my-modal">打开模态框</button>
|
26
|
+
* ```
|
27
|
+
*
|
28
|
+
* 自定义操作按钮:
|
29
|
+
* ```astro
|
30
|
+
* <Modal id="confirm-modal" title="确认操作">
|
31
|
+
* <p>您确定要执行此操作吗?</p>
|
32
|
+
* <div slot="actions">
|
33
|
+
* <button class="btn btn-primary">确认</button>
|
34
|
+
* <button class="btn" data-modal-target="confirm-modal">取消</button>
|
35
|
+
* </div>
|
36
|
+
* </Modal>
|
37
|
+
* ```
|
38
|
+
*
|
39
|
+
* 不带标题的模态框:
|
40
|
+
* ```astro
|
41
|
+
* <Modal id="image-modal">
|
42
|
+
* <img src="/images/large-image.jpg" alt="大图预览" />
|
43
|
+
* </Modal>
|
44
|
+
* ```
|
45
|
+
*/
|
46
|
+
|
47
|
+
import '../../style.ts';
|
48
|
+
import { Button } from '../../index-astro';
|
49
|
+
|
50
|
+
interface Props {
|
51
|
+
/**
|
52
|
+
* Modal 的唯一标识符
|
53
|
+
*/
|
54
|
+
id: string;
|
55
|
+
/**
|
56
|
+
* 模态框的标题
|
57
|
+
*/
|
58
|
+
title?: string;
|
59
|
+
/**
|
60
|
+
* 是否显示关闭按钮
|
61
|
+
* @default true
|
62
|
+
*/
|
63
|
+
showCloseButton?: boolean;
|
64
|
+
/**
|
65
|
+
* 自定义类名
|
66
|
+
*/
|
67
|
+
class?: string;
|
68
|
+
}
|
69
|
+
|
70
|
+
const {
|
71
|
+
id,
|
72
|
+
title,
|
73
|
+
showCloseButton = true,
|
74
|
+
class: className = '',
|
75
|
+
} = Astro.props;
|
76
|
+
---
|
77
|
+
|
78
|
+
<dialog id={id} class="cosy:modal">
|
79
|
+
<div class:list={['cosy:modal-box', className]}>
|
80
|
+
{
|
81
|
+
showCloseButton && (
|
82
|
+
<form method="dialog">
|
83
|
+
<Button
|
84
|
+
variant="ghost"
|
85
|
+
size="sm"
|
86
|
+
shape="circle"
|
87
|
+
formmethod="dialog"
|
88
|
+
class="cosy:modal-close-button">
|
89
|
+
✕
|
90
|
+
</Button>
|
91
|
+
</form>
|
92
|
+
)
|
93
|
+
}
|
94
|
+
|
95
|
+
{title && <h3 class="cosy:modal-title">{title}</h3>}
|
96
|
+
|
97
|
+
<div class="cosy:modal-content">
|
98
|
+
<slot />
|
99
|
+
</div>
|
100
|
+
|
101
|
+
<div class="cosy:modal-action">
|
102
|
+
<slot name="actions" />
|
103
|
+
</div>
|
104
|
+
</div>
|
105
|
+
|
106
|
+
<form method="dialog" class="cosy:modal-backdrop">
|
107
|
+
<button>关闭</button>
|
108
|
+
</form>
|
109
|
+
</dialog>
|
110
|
+
|
111
|
+
<script is:inline define:vars={{ id }}>
|
112
|
+
// 为了方便使用,我们提供一些辅助方法
|
113
|
+
document.addEventListener('DOMContentLoaded', () => {
|
114
|
+
const modal = document.getElementById(id);
|
115
|
+
if (!modal) return;
|
116
|
+
|
117
|
+
// 为所有触发这个模态框的按钮添加点击事件
|
118
|
+
document
|
119
|
+
.querySelectorAll(`[data-modal-target="${id}"]`)
|
120
|
+
.forEach((trigger) => {
|
121
|
+
trigger.addEventListener('click', () => {
|
122
|
+
modal.showModal();
|
123
|
+
});
|
124
|
+
});
|
125
|
+
});
|
126
|
+
</script>
|
@@ -0,0 +1 @@
|
|
1
|
+
export { default as Modal } from './Modal.astro';
|