dumi-theme-antd
Version:
Ant Design 5.0 官网风格类似的 dumi2 主题插件
57 lines • 72.4 kB
JavaScript
import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
import { css } from '@emotion/react';
import { Button, Space, Typography } from 'antd';
import { Link, useSearchParams } from 'dumi';
import React, { useContext } from 'react';
import useAdditionalThemeConfig from "../../hooks/useAdditionalThemeConfig";
import useLocaleValue from "../../hooks/useLocaleValue";
import useSiteToken from "../../hooks/useSiteToken";
import SiteContext from "dumi/theme/slots/SiteContext";
import { isExternalLinks } from "../../utils";
import Features from "./components/Features";
import { GroupMask } from "./components/Group";
import { jsx as ___EmotionJSX } from "@emotion/react";
var bannerConfigDefault = {
showBanner: true,
bannerMobileImgUrl: 'https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*JmlaR5oQn3MAAAAAAAAAAAAADrJ8AQ/original',
bannerImgUrl: ''
};
var _ref = process.env.NODE_ENV === "production" ? {
name: "eivff4",
styles: "display:none"
} : {
name: "1iadxno-bannerDisplayNone",
styles: "display:none;label:bannerDisplayNone;",
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAkC0B","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { Button, Space, Typography } from 'antd';\nimport { Link, useSearchParams } from 'dumi';\nimport React, { useContext, type FC } from 'react';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useLocaleValue from '../../hooks/useLocaleValue';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport SiteContext from '../../slots/SiteContext';\nimport type { SiteContextProps } from '../../slots/SiteContext';\nimport { IAction, IBannerConfig } from '../../types';\nimport { isExternalLinks } from '../../utils';\nimport Features from './components/Features';\nimport { GroupMask } from './components/Group';\n\nconst bannerConfigDefault: IBannerConfig = {\n  showBanner: true,\n  bannerMobileImgUrl:\n    'https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*JmlaR5oQn3MAAAAAAAAAAAAADrJ8AQ/original',\n  bannerImgUrl: ''\n};\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n  const { isMobile } = useContext(SiteContext);\n\n  return {\n    mainContent: css`\n      position: relative;\n      text-align: center;\n      flex: 1;\n    `,\n    bannerDisplay: css`\n      display: block;\n    `,\n    bannerDisplayNone: css`\n      display: none;\n    `,\n    titleBase: css`\n      h1& {\n        font-family: AliPuHui, ${token.fontFamily};\n      }\n    `,\n    title: isMobile\n      ? css`\n          h1& {\n            margin-bottom: ${token.margin}px;\n            font-weight: normal;\n            font-size: ${token.fontSizeHeading1 + 2}px;\n            line-height: ${token.lineHeightHeading2};\n          }\n        `\n      : css`\n          h1& {\n            margin-bottom: ${token.marginMD}px;\n            font-weight: 900;\n            font-size: 68px;\n          }\n        `\n  };\n};\n\nconst HomeBaseLayout: FC = () => {\n  const style = useStyle();\n  const { token } = useSiteToken();\n  const { isMobile, theme } = useContext<SiteContextProps>(SiteContext);\n  const { bannerConfig, name } = useAdditionalThemeConfig();\n  const actions: IAction[] = useLocaleValue('actions');\n  const title = useLocaleValue('title');\n  const description = useLocaleValue('description');\n  const [searchParams] = useSearchParams();\n\n  // 如果配置了 bannerImgUrl 字段，展示配置图片，否则展示 ant-design 默认 banner 视频\n  const { showBanner, bannerImgUrl, bannerMobileImgUrl } = Object.assign(\n    bannerConfigDefault,\n    bannerConfig\n  );\n\n  const bannerContent = bannerImgUrl ? (\n    <img src={bannerImgUrl} style={{ width: '100%', maxWidth: '100%' }} alt=\"\" />\n  ) : (\n    <React.Fragment>\n      <div\n        style={{\n          backgroundImage:\n            'url(https://gw.alipayobjects.com/mdn/rms_08e378/afts/img/A*6d50SboraPIAAAAAAAAAAAAAARQnAQ)',\n          flex: 'auto',\n          backgroundRepeat: 'repeat-x',\n          backgroundPosition: '100% 0',\n          backgroundSize: 'auto 100%'\n        }}\n      />\n\n      <video style={{ height: '100%', objectFit: 'contain' }} autoPlay muted loop>\n        <source\n          src=\"https://mdn.alipayobjects.com/huamei_iwk9zp/afts/file/A*uYT7SZwhJnUAAAAAAAAAAAAADgCCAQ\"\n          type=\"video/webm\"\n        />\n        <source\n          src=\"https://gw.alipayobjects.com/mdn/rms_08e378/afts/file/A*XYYNQJ3NbmMAAAAAAAAAAAAAARQnAQ\"\n          type=\"video/mp4\"\n        />\n      </video>\n\n      <div\n        style={{\n          backgroundImage:\n            'url(https://gw.alipayobjects.com/mdn/rms_08e378/afts/img/A*8ILtRrQlVDMAAAAAAAAAAAAAARQnAQ)',\n          flex: 'auto',\n          backgroundRepeat: 'repeat-x',\n          backgroundPosition: '0 0',\n          backgroundSize: 'auto 100%',\n          marginLeft: -1\n        }}\n      />\n    </React.Fragment>\n  );\n  return (\n    <div css={style.mainContent}>\n      {isMobile ? (\n        <img\n          src={bannerMobileImgUrl}\n          style={{\n            width: '100%',\n            maxWidth: '100%',\n            display: `${showBanner ? 'inline-block' : 'none'} `,\n            opacity: `${theme.indexOf('dark') > -1 ? '0.8' : 1}`\n          }}\n          alt=\"\"\n        />\n      ) : (\n        <div\n          style={{\n            height: bannerConfig ? 'auto' : 320,\n            background: '#77C6FF',\n            display: `${showBanner ? 'flex' : 'none'} `,\n            flexWrap: 'nowrap',\n            justifyContent: 'center',\n            opacity: `${theme.indexOf('dark') > -1 ? '0.8' : 1}`\n          }}\n        >\n          {bannerContent}\n        </div>\n      )}\n      {/* Image Left Top */}\n      <div style={{ position: 'relative' }}>\n        <GroupMask\n          style={{\n            textAlign: 'center',\n            paddingTop: token.marginFar - 16,\n            paddingBottom: token.marginFarSM\n          }}\n        >\n          {/* Image Left Top */}\n          <img\n            style={{ position: 'absolute', left: isMobile ? -120 : 0, top: 0, width: 240 }}\n            src=\"https://gw.alipayobjects.com/zos/bmw-prod/49f963db-b2a8-4f15-857a-270d771a1204.svg\"\n            alt=\"bg\"\n          />\n          {/* Image Right Top */}\n          <img\n            style={{ position: 'absolute', right: isMobile ? 0 : 120, top: 0, width: 240 }}\n            src=\"https://gw.alipayobjects.com/zos/bmw-prod/e152223c-bcae-4913-8938-54fda9efe330.svg\"\n            alt=\"bg\"\n          />\n          <Typography.Title level={1} css={[style.titleBase, style.title]}>\n            {title || name}\n          </Typography.Title>\n          <Typography.Paragraph\n            style={{\n              fontSize: token.fontSizeHeading5,\n              lineHeight: token.lineHeightHeading5,\n              marginBottom: token.marginMD * 2\n            }}\n          >\n            <div>{description}</div>\n          </Typography.Paragraph>\n          <Space\n            size=\"middle\"\n            style={{\n              marginBottom: token.marginFar\n            }}\n          >\n            {actions?.map(({ link, text, type }) => {\n              return isExternalLinks(link) ? (\n                <Button size=\"large\" type={type} href={link} target=\"_blank\" key={link}>\n                  {text}\n                </Button>\n              ) : (\n                <Link\n                  to={`${link}${link.search(/\\?/) === -1 ? '?' : '&'}${searchParams.toString()}`}\n                  key={link}\n                >\n                  <Button size=\"large\" type={type}>\n                    {text}\n                  </Button>\n                </Link>\n              );\n            })}\n          </Space>\n          <Features />\n        </GroupMask>\n      </div>\n    </div>\n  );\n};\n\nexport default HomeBaseLayout;\n"]} */",
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
};
var _ref2 = process.env.NODE_ENV === "production" ? {
name: "4zleql",
styles: "display:block"
} : {
name: "e4uzn-bannerDisplay",
styles: "display:block;label:bannerDisplay;",
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA+BsB","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { Button, Space, Typography } from 'antd';\nimport { Link, useSearchParams } from 'dumi';\nimport React, { useContext, type FC } from 'react';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useLocaleValue from '../../hooks/useLocaleValue';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport SiteContext from '../../slots/SiteContext';\nimport type { SiteContextProps } from '../../slots/SiteContext';\nimport { IAction, IBannerConfig } from '../../types';\nimport { isExternalLinks } from '../../utils';\nimport Features from './components/Features';\nimport { GroupMask } from './components/Group';\n\nconst bannerConfigDefault: IBannerConfig = {\n  showBanner: true,\n  bannerMobileImgUrl:\n    'https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*JmlaR5oQn3MAAAAAAAAAAAAADrJ8AQ/original',\n  bannerImgUrl: ''\n};\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n  const { isMobile } = useContext(SiteContext);\n\n  return {\n    mainContent: css`\n      position: relative;\n      text-align: center;\n      flex: 1;\n    `,\n    bannerDisplay: css`\n      display: block;\n    `,\n    bannerDisplayNone: css`\n      display: none;\n    `,\n    titleBase: css`\n      h1& {\n        font-family: AliPuHui, ${token.fontFamily};\n      }\n    `,\n    title: isMobile\n      ? css`\n          h1& {\n            margin-bottom: ${token.margin}px;\n            font-weight: normal;\n            font-size: ${token.fontSizeHeading1 + 2}px;\n            line-height: ${token.lineHeightHeading2};\n          }\n        `\n      : css`\n          h1& {\n            margin-bottom: ${token.marginMD}px;\n            font-weight: 900;\n            font-size: 68px;\n          }\n        `\n  };\n};\n\nconst HomeBaseLayout: FC = () => {\n  const style = useStyle();\n  const { token } = useSiteToken();\n  const { isMobile, theme } = useContext<SiteContextProps>(SiteContext);\n  const { bannerConfig, name } = useAdditionalThemeConfig();\n  const actions: IAction[] = useLocaleValue('actions');\n  const title = useLocaleValue('title');\n  const description = useLocaleValue('description');\n  const [searchParams] = useSearchParams();\n\n  // 如果配置了 bannerImgUrl 字段，展示配置图片，否则展示 ant-design 默认 banner 视频\n  const { showBanner, bannerImgUrl, bannerMobileImgUrl } = Object.assign(\n    bannerConfigDefault,\n    bannerConfig\n  );\n\n  const bannerContent = bannerImgUrl ? (\n    <img src={bannerImgUrl} style={{ width: '100%', maxWidth: '100%' }} alt=\"\" />\n  ) : (\n    <React.Fragment>\n      <div\n        style={{\n          backgroundImage:\n            'url(https://gw.alipayobjects.com/mdn/rms_08e378/afts/img/A*6d50SboraPIAAAAAAAAAAAAAARQnAQ)',\n          flex: 'auto',\n          backgroundRepeat: 'repeat-x',\n          backgroundPosition: '100% 0',\n          backgroundSize: 'auto 100%'\n        }}\n      />\n\n      <video style={{ height: '100%', objectFit: 'contain' }} autoPlay muted loop>\n        <source\n          src=\"https://mdn.alipayobjects.com/huamei_iwk9zp/afts/file/A*uYT7SZwhJnUAAAAAAAAAAAAADgCCAQ\"\n          type=\"video/webm\"\n        />\n        <source\n          src=\"https://gw.alipayobjects.com/mdn/rms_08e378/afts/file/A*XYYNQJ3NbmMAAAAAAAAAAAAAARQnAQ\"\n          type=\"video/mp4\"\n        />\n      </video>\n\n      <div\n        style={{\n          backgroundImage:\n            'url(https://gw.alipayobjects.com/mdn/rms_08e378/afts/img/A*8ILtRrQlVDMAAAAAAAAAAAAAARQnAQ)',\n          flex: 'auto',\n          backgroundRepeat: 'repeat-x',\n          backgroundPosition: '0 0',\n          backgroundSize: 'auto 100%',\n          marginLeft: -1\n        }}\n      />\n    </React.Fragment>\n  );\n  return (\n    <div css={style.mainContent}>\n      {isMobile ? (\n        <img\n          src={bannerMobileImgUrl}\n          style={{\n            width: '100%',\n            maxWidth: '100%',\n            display: `${showBanner ? 'inline-block' : 'none'} `,\n            opacity: `${theme.indexOf('dark') > -1 ? '0.8' : 1}`\n          }}\n          alt=\"\"\n        />\n      ) : (\n        <div\n          style={{\n            height: bannerConfig ? 'auto' : 320,\n            background: '#77C6FF',\n            display: `${showBanner ? 'flex' : 'none'} `,\n            flexWrap: 'nowrap',\n            justifyContent: 'center',\n            opacity: `${theme.indexOf('dark') > -1 ? '0.8' : 1}`\n          }}\n        >\n          {bannerContent}\n        </div>\n      )}\n      {/* Image Left Top */}\n      <div style={{ position: 'relative' }}>\n        <GroupMask\n          style={{\n            textAlign: 'center',\n            paddingTop: token.marginFar - 16,\n            paddingBottom: token.marginFarSM\n          }}\n        >\n          {/* Image Left Top */}\n          <img\n            style={{ position: 'absolute', left: isMobile ? -120 : 0, top: 0, width: 240 }}\n            src=\"https://gw.alipayobjects.com/zos/bmw-prod/49f963db-b2a8-4f15-857a-270d771a1204.svg\"\n            alt=\"bg\"\n          />\n          {/* Image Right Top */}\n          <img\n            style={{ position: 'absolute', right: isMobile ? 0 : 120, top: 0, width: 240 }}\n            src=\"https://gw.alipayobjects.com/zos/bmw-prod/e152223c-bcae-4913-8938-54fda9efe330.svg\"\n            alt=\"bg\"\n          />\n          <Typography.Title level={1} css={[style.titleBase, style.title]}>\n            {title || name}\n          </Typography.Title>\n          <Typography.Paragraph\n            style={{\n              fontSize: token.fontSizeHeading5,\n              lineHeight: token.lineHeightHeading5,\n              marginBottom: token.marginMD * 2\n            }}\n          >\n            <div>{description}</div>\n          </Typography.Paragraph>\n          <Space\n            size=\"middle\"\n            style={{\n              marginBottom: token.marginFar\n            }}\n          >\n            {actions?.map(({ link, text, type }) => {\n              return isExternalLinks(link) ? (\n                <Button size=\"large\" type={type} href={link} target=\"_blank\" key={link}>\n                  {text}\n                </Button>\n              ) : (\n                <Link\n                  to={`${link}${link.search(/\\?/) === -1 ? '?' : '&'}${searchParams.toString()}`}\n                  key={link}\n                >\n                  <Button size=\"large\" type={type}>\n                    {text}\n                  </Button>\n                </Link>\n              );\n            })}\n          </Space>\n          <Features />\n        </GroupMask>\n      </div>\n    </div>\n  );\n};\n\nexport default HomeBaseLayout;\n"]} */",
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
};
var _ref3 = process.env.NODE_ENV === "production" ? {
name: "od9oaz",
styles: "position:relative;text-align:center;flex:1"
} : {
name: "n73971-mainContent",
styles: "position:relative;text-align:center;flex:1;label:mainContent;",
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA0BoB","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { Button, Space, Typography } from 'antd';\nimport { Link, useSearchParams } from 'dumi';\nimport React, { useContext, type FC } from 'react';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useLocaleValue from '../../hooks/useLocaleValue';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport SiteContext from '../../slots/SiteContext';\nimport type { SiteContextProps } from '../../slots/SiteContext';\nimport { IAction, IBannerConfig } from '../../types';\nimport { isExternalLinks } from '../../utils';\nimport Features from './components/Features';\nimport { GroupMask } from './components/Group';\n\nconst bannerConfigDefault: IBannerConfig = {\n  showBanner: true,\n  bannerMobileImgUrl:\n    'https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*JmlaR5oQn3MAAAAAAAAAAAAADrJ8AQ/original',\n  bannerImgUrl: ''\n};\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n  const { isMobile } = useContext(SiteContext);\n\n  return {\n    mainContent: css`\n      position: relative;\n      text-align: center;\n      flex: 1;\n    `,\n    bannerDisplay: css`\n      display: block;\n    `,\n    bannerDisplayNone: css`\n      display: none;\n    `,\n    titleBase: css`\n      h1& {\n        font-family: AliPuHui, ${token.fontFamily};\n      }\n    `,\n    title: isMobile\n      ? css`\n          h1& {\n            margin-bottom: ${token.margin}px;\n            font-weight: normal;\n            font-size: ${token.fontSizeHeading1 + 2}px;\n            line-height: ${token.lineHeightHeading2};\n          }\n        `\n      : css`\n          h1& {\n            margin-bottom: ${token.marginMD}px;\n            font-weight: 900;\n            font-size: 68px;\n          }\n        `\n  };\n};\n\nconst HomeBaseLayout: FC = () => {\n  const style = useStyle();\n  const { token } = useSiteToken();\n  const { isMobile, theme } = useContext<SiteContextProps>(SiteContext);\n  const { bannerConfig, name } = useAdditionalThemeConfig();\n  const actions: IAction[] = useLocaleValue('actions');\n  const title = useLocaleValue('title');\n  const description = useLocaleValue('description');\n  const [searchParams] = useSearchParams();\n\n  // 如果配置了 bannerImgUrl 字段，展示配置图片，否则展示 ant-design 默认 banner 视频\n  const { showBanner, bannerImgUrl, bannerMobileImgUrl } = Object.assign(\n    bannerConfigDefault,\n    bannerConfig\n  );\n\n  const bannerContent = bannerImgUrl ? (\n    <img src={bannerImgUrl} style={{ width: '100%', maxWidth: '100%' }} alt=\"\" />\n  ) : (\n    <React.Fragment>\n      <div\n        style={{\n          backgroundImage:\n            'url(https://gw.alipayobjects.com/mdn/rms_08e378/afts/img/A*6d50SboraPIAAAAAAAAAAAAAARQnAQ)',\n          flex: 'auto',\n          backgroundRepeat: 'repeat-x',\n          backgroundPosition: '100% 0',\n          backgroundSize: 'auto 100%'\n        }}\n      />\n\n      <video style={{ height: '100%', objectFit: 'contain' }} autoPlay muted loop>\n        <source\n          src=\"https://mdn.alipayobjects.com/huamei_iwk9zp/afts/file/A*uYT7SZwhJnUAAAAAAAAAAAAADgCCAQ\"\n          type=\"video/webm\"\n        />\n        <source\n          src=\"https://gw.alipayobjects.com/mdn/rms_08e378/afts/file/A*XYYNQJ3NbmMAAAAAAAAAAAAAARQnAQ\"\n          type=\"video/mp4\"\n        />\n      </video>\n\n      <div\n        style={{\n          backgroundImage:\n            'url(https://gw.alipayobjects.com/mdn/rms_08e378/afts/img/A*8ILtRrQlVDMAAAAAAAAAAAAAARQnAQ)',\n          flex: 'auto',\n          backgroundRepeat: 'repeat-x',\n          backgroundPosition: '0 0',\n          backgroundSize: 'auto 100%',\n          marginLeft: -1\n        }}\n      />\n    </React.Fragment>\n  );\n  return (\n    <div css={style.mainContent}>\n      {isMobile ? (\n        <img\n          src={bannerMobileImgUrl}\n          style={{\n            width: '100%',\n            maxWidth: '100%',\n            display: `${showBanner ? 'inline-block' : 'none'} `,\n            opacity: `${theme.indexOf('dark') > -1 ? '0.8' : 1}`\n          }}\n          alt=\"\"\n        />\n      ) : (\n        <div\n          style={{\n            height: bannerConfig ? 'auto' : 320,\n            background: '#77C6FF',\n            display: `${showBanner ? 'flex' : 'none'} `,\n            flexWrap: 'nowrap',\n            justifyContent: 'center',\n            opacity: `${theme.indexOf('dark') > -1 ? '0.8' : 1}`\n          }}\n        >\n          {bannerContent}\n        </div>\n      )}\n      {/* Image Left Top */}\n      <div style={{ position: 'relative' }}>\n        <GroupMask\n          style={{\n            textAlign: 'center',\n            paddingTop: token.marginFar - 16,\n            paddingBottom: token.marginFarSM\n          }}\n        >\n          {/* Image Left Top */}\n          <img\n            style={{ position: 'absolute', left: isMobile ? -120 : 0, top: 0, width: 240 }}\n            src=\"https://gw.alipayobjects.com/zos/bmw-prod/49f963db-b2a8-4f15-857a-270d771a1204.svg\"\n            alt=\"bg\"\n          />\n          {/* Image Right Top */}\n          <img\n            style={{ position: 'absolute', right: isMobile ? 0 : 120, top: 0, width: 240 }}\n            src=\"https://gw.alipayobjects.com/zos/bmw-prod/e152223c-bcae-4913-8938-54fda9efe330.svg\"\n            alt=\"bg\"\n          />\n          <Typography.Title level={1} css={[style.titleBase, style.title]}>\n            {title || name}\n          </Typography.Title>\n          <Typography.Paragraph\n            style={{\n              fontSize: token.fontSizeHeading5,\n              lineHeight: token.lineHeightHeading5,\n              marginBottom: token.marginMD * 2\n            }}\n          >\n            <div>{description}</div>\n          </Typography.Paragraph>\n          <Space\n            size=\"middle\"\n            style={{\n              marginBottom: token.marginFar\n            }}\n          >\n            {actions?.map(({ link, text, type }) => {\n              return isExternalLinks(link) ? (\n                <Button size=\"large\" type={type} href={link} target=\"_blank\" key={link}>\n                  {text}\n                </Button>\n              ) : (\n                <Link\n                  to={`${link}${link.search(/\\?/) === -1 ? '?' : '&'}${searchParams.toString()}`}\n                  key={link}\n                >\n                  <Button size=\"large\" type={type}>\n                    {text}\n                  </Button>\n                </Link>\n              );\n            })}\n          </Space>\n          <Features />\n        </GroupMask>\n      </div>\n    </div>\n  );\n};\n\nexport default HomeBaseLayout;\n"]} */",
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
};
var useStyle = function useStyle() {
var _useSiteToken = useSiteToken(),
token = _useSiteToken.token;
var _useContext = useContext(SiteContext),
isMobile = _useContext.isMobile;
return {
mainContent: _ref3,
bannerDisplay: _ref2,
bannerDisplayNone: _ref,
titleBase: /*#__PURE__*/css("h1&{font-family:AliPuHui,", token.fontFamily, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:titleBase;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAqCkB","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { Button, Space, Typography } from 'antd';\nimport { Link, useSearchParams } from 'dumi';\nimport React, { useContext, type FC } from 'react';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useLocaleValue from '../../hooks/useLocaleValue';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport SiteContext from '../../slots/SiteContext';\nimport type { SiteContextProps } from '../../slots/SiteContext';\nimport { IAction, IBannerConfig } from '../../types';\nimport { isExternalLinks } from '../../utils';\nimport Features from './components/Features';\nimport { GroupMask } from './components/Group';\n\nconst bannerConfigDefault: IBannerConfig = {\n  showBanner: true,\n  bannerMobileImgUrl:\n    'https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*JmlaR5oQn3MAAAAAAAAAAAAADrJ8AQ/original',\n  bannerImgUrl: ''\n};\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n  const { isMobile } = useContext(SiteContext);\n\n  return {\n    mainContent: css`\n      position: relative;\n      text-align: center;\n      flex: 1;\n    `,\n    bannerDisplay: css`\n      display: block;\n    `,\n    bannerDisplayNone: css`\n      display: none;\n    `,\n    titleBase: css`\n      h1& {\n        font-family: AliPuHui, ${token.fontFamily};\n      }\n    `,\n    title: isMobile\n      ? css`\n          h1& {\n            margin-bottom: ${token.margin}px;\n            font-weight: normal;\n            font-size: ${token.fontSizeHeading1 + 2}px;\n            line-height: ${token.lineHeightHeading2};\n          }\n        `\n      : css`\n          h1& {\n            margin-bottom: ${token.marginMD}px;\n            font-weight: 900;\n            font-size: 68px;\n          }\n        `\n  };\n};\n\nconst HomeBaseLayout: FC = () => {\n  const style = useStyle();\n  const { token } = useSiteToken();\n  const { isMobile, theme } = useContext<SiteContextProps>(SiteContext);\n  const { bannerConfig, name } = useAdditionalThemeConfig();\n  const actions: IAction[] = useLocaleValue('actions');\n  const title = useLocaleValue('title');\n  const description = useLocaleValue('description');\n  const [searchParams] = useSearchParams();\n\n  // 如果配置了 bannerImgUrl 字段，展示配置图片，否则展示 ant-design 默认 banner 视频\n  const { showBanner, bannerImgUrl, bannerMobileImgUrl } = Object.assign(\n    bannerConfigDefault,\n    bannerConfig\n  );\n\n  const bannerContent = bannerImgUrl ? (\n    <img src={bannerImgUrl} style={{ width: '100%', maxWidth: '100%' }} alt=\"\" />\n  ) : (\n    <React.Fragment>\n      <div\n        style={{\n          backgroundImage:\n            'url(https://gw.alipayobjects.com/mdn/rms_08e378/afts/img/A*6d50SboraPIAAAAAAAAAAAAAARQnAQ)',\n          flex: 'auto',\n          backgroundRepeat: 'repeat-x',\n          backgroundPosition: '100% 0',\n          backgroundSize: 'auto 100%'\n        }}\n      />\n\n      <video style={{ height: '100%', objectFit: 'contain' }} autoPlay muted loop>\n        <source\n          src=\"https://mdn.alipayobjects.com/huamei_iwk9zp/afts/file/A*uYT7SZwhJnUAAAAAAAAAAAAADgCCAQ\"\n          type=\"video/webm\"\n        />\n        <source\n          src=\"https://gw.alipayobjects.com/mdn/rms_08e378/afts/file/A*XYYNQJ3NbmMAAAAAAAAAAAAAARQnAQ\"\n          type=\"video/mp4\"\n        />\n      </video>\n\n      <div\n        style={{\n          backgroundImage:\n            'url(https://gw.alipayobjects.com/mdn/rms_08e378/afts/img/A*8ILtRrQlVDMAAAAAAAAAAAAAARQnAQ)',\n          flex: 'auto',\n          backgroundRepeat: 'repeat-x',\n          backgroundPosition: '0 0',\n          backgroundSize: 'auto 100%',\n          marginLeft: -1\n        }}\n      />\n    </React.Fragment>\n  );\n  return (\n    <div css={style.mainContent}>\n      {isMobile ? (\n        <img\n          src={bannerMobileImgUrl}\n          style={{\n            width: '100%',\n            maxWidth: '100%',\n            display: `${showBanner ? 'inline-block' : 'none'} `,\n            opacity: `${theme.indexOf('dark') > -1 ? '0.8' : 1}`\n          }}\n          alt=\"\"\n        />\n      ) : (\n        <div\n          style={{\n            height: bannerConfig ? 'auto' : 320,\n            background: '#77C6FF',\n            display: `${showBanner ? 'flex' : 'none'} `,\n            flexWrap: 'nowrap',\n            justifyContent: 'center',\n            opacity: `${theme.indexOf('dark') > -1 ? '0.8' : 1}`\n          }}\n        >\n          {bannerContent}\n        </div>\n      )}\n      {/* Image Left Top */}\n      <div style={{ position: 'relative' }}>\n        <GroupMask\n          style={{\n            textAlign: 'center',\n            paddingTop: token.marginFar - 16,\n            paddingBottom: token.marginFarSM\n          }}\n        >\n          {/* Image Left Top */}\n          <img\n            style={{ position: 'absolute', left: isMobile ? -120 : 0, top: 0, width: 240 }}\n            src=\"https://gw.alipayobjects.com/zos/bmw-prod/49f963db-b2a8-4f15-857a-270d771a1204.svg\"\n            alt=\"bg\"\n          />\n          {/* Image Right Top */}\n          <img\n            style={{ position: 'absolute', right: isMobile ? 0 : 120, top: 0, width: 240 }}\n            src=\"https://gw.alipayobjects.com/zos/bmw-prod/e152223c-bcae-4913-8938-54fda9efe330.svg\"\n            alt=\"bg\"\n          />\n          <Typography.Title level={1} css={[style.titleBase, style.title]}>\n            {title || name}\n          </Typography.Title>\n          <Typography.Paragraph\n            style={{\n              fontSize: token.fontSizeHeading5,\n              lineHeight: token.lineHeightHeading5,\n              marginBottom: token.marginMD * 2\n            }}\n          >\n            <div>{description}</div>\n          </Typography.Paragraph>\n          <Space\n            size=\"middle\"\n            style={{\n              marginBottom: token.marginFar\n            }}\n          >\n            {actions?.map(({ link, text, type }) => {\n              return isExternalLinks(link) ? (\n                <Button size=\"large\" type={type} href={link} target=\"_blank\" key={link}>\n                  {text}\n                </Button>\n              ) : (\n                <Link\n                  to={`${link}${link.search(/\\?/) === -1 ? '?' : '&'}${searchParams.toString()}`}\n                  key={link}\n                >\n                  <Button size=\"large\" type={type}>\n                    {text}\n                  </Button>\n                </Link>\n              );\n            })}\n          </Space>\n          <Features />\n        </GroupMask>\n      </div>\n    </div>\n  );\n};\n\nexport default HomeBaseLayout;\n"]} */"),
title: isMobile ? /*#__PURE__*/css("h1&{margin-bottom:", token.margin, "px;font-weight:normal;font-size:", token.fontSizeHeading1 + 2, "px;line-height:", token.lineHeightHeading2, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:title;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA2CW","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { Button, Space, Typography } from 'antd';\nimport { Link, useSearchParams } from 'dumi';\nimport React, { useContext, type FC } from 'react';\nimport useAdditionalThemeConfig from '../../hooks/useAdditionalThemeConfig';\nimport useLocaleValue from '../../hooks/useLocaleValue';\nimport useSiteToken from '../../hooks/useSiteToken';\nimport SiteContext from '../../slots/SiteContext';\nimport type { SiteContextProps } from '../../slots/SiteContext';\nimport { IAction, IBannerConfig } from '../../types';\nimport { isExternalLinks } from '../../utils';\nimport Features from './components/Features';\nimport { GroupMask } from './components/Group';\n\nconst bannerConfigDefault: IBannerConfig = {\n  showBanner: true,\n  bannerMobileImgUrl:\n    'https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*JmlaR5oQn3MAAAAAAAAAAAAADrJ8AQ/original',\n  bannerImgUrl: ''\n};\n\nconst useStyle = () => {\n  const { token } = useSiteToken();\n  const { isMobile } = useContext(SiteContext);\n\n  return {\n    mainContent: css`\n      position: relative;\n      text-align: center;\n      flex: 1;\n    `,\n    bannerDisplay: css`\n      display: block;\n    `,\n    bannerDisplayNone: css`\n      display: none;\n    `,\n    titleBase: css`\n      h1& {\n        font-family: AliPuHui, ${token.fontFamily};\n      }\n    `,\n    title: isMobile\n      ? css`\n          h1& {\n            margin-bottom: ${token.margin}px;\n            font-weight: normal;\n            font-size: ${token.fontSizeHeading1 + 2}px;\n            line-height: ${token.lineHeightHeading2};\n          }\n        `\n      : css`\n          h1& {\n            margin-bottom: ${token.marginMD}px;\n            font-weight: 900;\n            font-size: 68px;\n          }\n        `\n  };\n};\n\nconst HomeBaseLayout: FC = () => {\n  const style = useStyle();\n  const { token } = useSiteToken();\n  const { isMobile, theme } = useContext<SiteContextProps>(SiteContext);\n  const { bannerConfig, name } = useAdditionalThemeConfig();\n  const actions: IAction[] = useLocaleValue('actions');\n  const title = useLocaleValue('title');\n  const description = useLocaleValue('description');\n  const [searchParams] = useSearchParams();\n\n  // 如果配置了 bannerImgUrl 字段，展示配置图片，否则展示 ant-design 默认 banner 视频\n  const { showBanner, bannerImgUrl, bannerMobileImgUrl } = Object.assign(\n    bannerConfigDefault,\n    bannerConfig\n  );\n\n  const bannerContent = bannerImgUrl ? (\n    <img src={bannerImgUrl} style={{ width: '100%', maxWidth: '100%' }} alt=\"\" />\n  ) : (\n    <React.Fragment>\n      <div\n        style={{\n          backgroundImage:\n            'url(https://gw.alipayobjects.com/mdn/rms_08e378/afts/img/A*6d50SboraPIAAAAAAAAAAAAAARQnAQ)',\n          flex: 'auto',\n          backgroundRepeat: 'repeat-x',\n          backgroundPosition: '100% 0',\n          backgroundSize: 'auto 100%'\n        }}\n      />\n\n      <video style={{ height: '100%', objectFit: 'contain' }} autoPlay muted loop>\n        <source\n          src=\"https://mdn.alipayobjects.com/huamei_iwk9zp/afts/file/A*uYT7SZwhJnUAAAAAAAAAAAAADgCCAQ\"\n          type=\"video/webm\"\n        />\n        <source\n          src=\"https://gw.alipayobjects.com/mdn/rms_08e378/afts/file/A*XYYNQJ3NbmMAAAAAAAAAAAAAARQnAQ\"\n          type=\"video/mp4\"\n        />\n      </video>\n\n      <div\n        style={{\n          backgroundImage:\n            'url(https://gw.alipayobjects.com/mdn/rms_08e378/afts/img/A*8ILtRrQlVDMAAAAAAAAAAAAAARQnAQ)',\n          flex: 'auto',\n          backgroundRepeat: 'repeat-x',\n          backgroundPosition: '0 0',\n          backgroundSize: 'auto 100%',\n          marginLeft: -1\n        }}\n      />\n    </React.Fragment>\n  );\n  return (\n    <div css={style.mainContent}>\n      {isMobile ? (\n        <img\n          src={bannerMobileImgUrl}\n          style={{\n            width: '100%',\n            maxWidth: '100%',\n            display: `${showBanner ? 'inline-block' : 'none'} `,\n            opacity: `${theme.indexOf('dark') > -1 ? '0.8' : 1}`\n          }}\n          alt=\"\"\n        />\n      ) : (\n        <div\n          style={{\n            height: bannerConfig ? 'auto' : 320,\n            background: '#77C6FF',\n            display: `${showBanner ? 'flex' : 'none'} `,\n            flexWrap: 'nowrap',\n            justifyContent: 'center',\n            opacity: `${theme.indexOf('dark') > -1 ? '0.8' : 1}`\n          }}\n        >\n          {bannerContent}\n        </div>\n      )}\n      {/* Image Left Top */}\n      <div style={{ position: 'relative' }}>\n        <GroupMask\n          style={{\n            textAlign: 'center',\n            paddingTop: token.marginFar - 16,\n            paddingBottom: token.marginFarSM\n          }}\n        >\n          {/* Image Left Top */}\n          <img\n            style={{ position: 'absolute', left: isMobile ? -120 : 0, top: 0, width: 240 }}\n            src=\"https://gw.alipayobjects.com/zos/bmw-prod/49f963db-b2a8-4f15-857a-270d771a1204.svg\"\n            alt=\"bg\"\n          />\n          {/* Image Right Top */}\n          <img\n            style={{ position: 'absolute', right: isMobile ? 0 : 120, top: 0, width: 240 }}\n            src=\"https://gw.alipayobjects.com/zos/bmw-prod/e152223c-bcae-4913-8938-54fda9efe330.svg\"\n            alt=\"bg\"\n          />\n          <Typography.Title level={1} css={[style.titleBase, style.title]}>\n            {title || name}\n          </Typography.Title>\n          <Typography.Paragraph\n            style={{\n              fontSize: token.fontSizeHeading5,\n              lineHeight: token.lineHeightHeading5,\n              marginBottom: token.marginMD * 2\n            }}\n          >\n            <div>{description}</div>\n          </Typography.Paragraph>\n          <Space\n            size=\"middle\"\n            style={{\n              marginBottom: token.marginFar\n            }}\n          >\n            {actions?.map(({ link, text, type }) => {\n              return isExternalLinks(link) ? (\n                <Button size=\"large\" type={type} href={link} target=\"_blank\" key={link}>\n                  {text}\n                </Button>\n              ) : (\n                <Link\n                  to={`${link}${link.search(/\\?/) === -1 ? '?' : '&'}${searchParams.toString()}`}\n                  key={link}\n                >\n                  <Button size=\"large\" type={type}>\n                    {text}\n                  </Button>\n                </Link>\n              );\n            })}\n          </Space>\n          <Features />\n        </GroupMask>\n      </div>\n    </div>\n  );\n};\n\nexport default HomeBaseLayout;\n"]} */") : /*#__PURE__*/css("h1&{margin-bottom:", token.marginMD, "px;font-weight:900;font-size:68px;}" + (process.env.NODE_ENV === "production" ? "" : ";label:title;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtRFciLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgQnV0dG9uLCBTcGFjZSwgVHlwb2dyYXBoeSB9IGZyb20gJ2FudGQnO1xuaW1wb3J0IHsgTGluaywgdXNlU2VhcmNoUGFyYW1zIH0gZnJvbSAnZHVtaSc7XG5pbXBvcnQgUmVhY3QsIHsgdXNlQ29udGV4dCwgdHlwZSBGQyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB1c2VBZGRpdGlvbmFsVGhlbWVDb25maWcgZnJvbSAnLi4vLi4vaG9va3MvdXNlQWRkaXRpb25hbFRoZW1lQ29uZmlnJztcbmltcG9ydCB1c2VMb2NhbGVWYWx1ZSBmcm9tICcuLi8uLi9ob29rcy91c2VMb2NhbGVWYWx1ZSc7XG5pbXBvcnQgdXNlU2l0ZVRva2VuIGZyb20gJy4uLy4uL2hvb2tzL3VzZVNpdGVUb2tlbic7XG5pbXBvcnQgU2l0ZUNvbnRleHQgZnJvbSAnLi4vLi4vc2xvdHMvU2l0ZUNvbnRleHQnO1xuaW1wb3J0IHR5cGUgeyBTaXRlQ29udGV4dFByb3BzIH0gZnJvbSAnLi4vLi4vc2xvdHMvU2l0ZUNvbnRleHQnO1xuaW1wb3J0IHsgSUFjdGlvbiwgSUJhbm5lckNvbmZpZyB9IGZyb20gJy4uLy4uL3R5cGVzJztcbmltcG9