@modern-js/main-doc 2.0.0-beta.0 → 2.0.0-beta.1

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.
Files changed (507) hide show
  1. package/.turbo/turbo-build.log +4 -0
  2. package/en/docusaurus-plugin-content-docs/current/apis/app/commands/_category_.json +8 -0
  3. package/en/docusaurus-plugin-content-docs/current/apis/app/commands/build.md +44 -0
  4. package/en/docusaurus-plugin-content-docs/current/apis/app/commands/dev.md +31 -0
  5. package/en/docusaurus-plugin-content-docs/current/apis/app/commands/index.md +12 -0
  6. package/en/docusaurus-plugin-content-docs/current/apis/app/commands/inspect.md +39 -0
  7. package/en/docusaurus-plugin-content-docs/current/apis/app/commands/lint.md +22 -0
  8. package/en/docusaurus-plugin-content-docs/current/apis/app/commands/new.md +59 -0
  9. package/en/docusaurus-plugin-content-docs/current/apis/app/commands/start.md +32 -0
  10. package/en/docusaurus-plugin-content-docs/current/apis/app/commands/test.md +36 -0
  11. package/en/docusaurus-plugin-content-docs/current/apis/app/commands/upgrade.md +21 -0
  12. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/_category_.json +8 -0
  13. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/api/_category_.json +4 -0
  14. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/api/framework/_category_.json +4 -0
  15. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/api/framework/lambda.md +54 -0
  16. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/api/functions/_category_.json +4 -0
  17. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/api/functions/api.md +78 -0
  18. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/api/functions/app.md +12 -0
  19. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/api/functions/common.md +10 -0
  20. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/api/test.md +10 -0
  21. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/config/_category_.json +4 -0
  22. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/config/html.md +8 -0
  23. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/config/icon.md +15 -0
  24. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/config/mock.md +6 -0
  25. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/config/public.md +28 -0
  26. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/config/storybook.md +12 -0
  27. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/config/upload.md +42 -0
  28. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/index.md +7 -0
  29. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/modern-config.md +8 -0
  30. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/server/_category_.json +4 -0
  31. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/server/index_.md +14 -0
  32. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/server/test.md +10 -0
  33. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/shared.md +6 -0
  34. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/src/_category_.json +4 -0
  35. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/src/app.md +45 -0
  36. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/src/index_.md +34 -0
  37. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/src/pages.md +180 -0
  38. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/src/stories.md +12 -0
  39. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/src/test.md +12 -0
  40. package/en/docusaurus-plugin-content-docs/current/apis/app/overview.md +12 -0
  41. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/_category_.json +9 -0
  42. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/app/_category_.json +4 -0
  43. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/app/define-config.md +60 -0
  44. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/bff/_category_.json +4 -0
  45. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/bff/hook.md +43 -0
  46. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/bff/use-context.md +36 -0
  47. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/core/_category_.json +5 -0
  48. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/core/bootstrap.md +55 -0
  49. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/core/create-app.md +47 -0
  50. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/core/use-loader.md +83 -0
  51. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/core/use-module-apps.md +101 -0
  52. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/core/use-runtime-context.md +59 -0
  53. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/default-alias.md +25 -0
  54. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/env.md +72 -0
  55. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/index.md +12 -0
  56. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/Provider.md +35 -0
  57. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/_category_.json +4 -0
  58. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/auto-actions.md +120 -0
  59. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/connect.md +140 -0
  60. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/create-app.md +73 -0
  61. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/create-store.md +62 -0
  62. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/handle-effect.md +105 -0
  63. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/model_.md +197 -0
  64. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/use-local-model.md +27 -0
  65. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/use-model.md +89 -0
  66. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/use-static-model.md +49 -0
  67. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/use-store.md +48 -0
  68. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/plugin/_category_.json +4 -0
  69. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/plugin/abstract.md +26 -0
  70. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/plugin/hook-api.md +896 -0
  71. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/plugin/hook.md +170 -0
  72. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/plugin/plugin-api.md +117 -0
  73. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/router/_category_.json +4 -0
  74. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/router/router.md +492 -0
  75. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/ssr/_category_.json +4 -0
  76. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/ssr/no-ssr.md +44 -0
  77. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/ssr/pre-render.md +91 -0
  78. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/testing/_category_.json +4 -0
  79. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/testing/act.md +34 -0
  80. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/testing/cleanup.md +38 -0
  81. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/testing/render.md +72 -0
  82. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/testing/renderApp.md +33 -0
  83. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/utility/_category_.json +4 -0
  84. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/utility/css-in-js.md +42 -0
  85. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/utility/head.md +39 -0
  86. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/utility/loadable.md +85 -0
  87. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/web-server/_category_.json +4 -0
  88. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/web-server/hook.md +131 -0
  89. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/web-server/middleware.md +106 -0
  90. package/en/docusaurus-plugin-content-docs/current/configure/app/bff/fetcher.md +28 -0
  91. package/en/docusaurus-plugin-content-docs/current/configure/app/bff/prefix.md +33 -0
  92. package/en/docusaurus-plugin-content-docs/current/configure/app/bff/proxy.md +75 -0
  93. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/dev/asset-prefix.md +0 -1
  94. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/dev/hmr.md +0 -1
  95. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/dev/https.md +0 -1
  96. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/dev/port.md +0 -1
  97. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/dev/progress-bar.md +0 -1
  98. package/en/docusaurus-plugin-content-docs/current/configure/app/dev/proxy.md +80 -0
  99. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/dev/start-url.md +0 -1
  100. package/en/docusaurus-plugin-content-docs/current/configure/app/dev/with-master-app.md +32 -0
  101. package/en/docusaurus-plugin-content-docs/current/configure/app/experiments/lazy-compilation.md +12 -0
  102. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/app-icon.md +0 -1
  103. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/crossorigin.md +0 -1
  104. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/disable-html-folder.md +0 -1
  105. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/favicon-by-entries.md +0 -1
  106. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/favicon.md +0 -1
  107. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/inject-by-entries.md +0 -1
  108. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/inject.md +0 -1
  109. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/meta-by-entries.md +0 -1
  110. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/meta.md +0 -1
  111. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/mount-id.md +0 -1
  112. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/template-by-entries.md +0 -1
  113. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/template-parameters-by-entries.md +0 -1
  114. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/template-parameters.md +0 -1
  115. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/template.md +0 -1
  116. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/title-by-entries.md +0 -1
  117. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/title.md +0 -1
  118. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/asset-prefix.md +0 -1
  119. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/assets-retry.md +0 -1
  120. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/charset.md +0 -1
  121. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/clean-dist-path.md +0 -1
  122. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/convert-to-rem.md +0 -1
  123. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/copy.md +0 -1
  124. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/css-module-local-ident-name.md +0 -1
  125. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/data-uri-limit.md +0 -1
  126. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/disable-css-module-extension.md +0 -1
  127. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/disable-filename-hash.md +0 -1
  128. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/disable-inline-runtime-chunk.md +0 -1
  129. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/disable-minimize.md +0 -1
  130. package/en/docusaurus-plugin-content-docs/current/configure/app/output/disable-node-polyfill.md +20 -0
  131. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/disable-source-map.md +0 -1
  132. package/en/docusaurus-plugin-content-docs/current/configure/app/output/disable-ts-checker.md +12 -0
  133. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/dist-path.md +0 -1
  134. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/enable-asset-fallback.md +0 -1
  135. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/enable-asset-manifest.md +0 -1
  136. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/enable-css-module-tsdeclaration.md +0 -1
  137. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/enable-inline-scripts.md +0 -1
  138. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/enable-inline-styles.md +0 -1
  139. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/enable-latest-decorators.md +0 -1
  140. package/en/docusaurus-plugin-content-docs/current/configure/app/output/enable-modern-mode.md +34 -0
  141. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/externals.md +0 -1
  142. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/filename.md +0 -1
  143. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/legal-comments.md +0 -1
  144. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/override-browserslist.md +0 -1
  145. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/polyfill.md +0 -1
  146. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/svg-default-export.md +0 -1
  147. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/performance/build-cache.md +0 -1
  148. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/performance/bundle-analyze.md +0 -1
  149. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/performance/chunk-split.md +0 -1
  150. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/performance/print-file-size.md +0 -1
  151. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/performance/profile.md +0 -1
  152. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/performance/remove-console.md +0 -1
  153. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/performance/remove-moment-locale.md +0 -1
  154. package/en/docusaurus-plugin-content-docs/current/configure/app/plugins.md +74 -0
  155. package/en/docusaurus-plugin-content-docs/current/configure/app/runtime/intro.md +91 -0
  156. package/en/docusaurus-plugin-content-docs/current/configure/app/runtime/master-app.md +60 -0
  157. package/en/docusaurus-plugin-content-docs/current/configure/app/runtime/router.md +19 -0
  158. package/en/docusaurus-plugin-content-docs/current/configure/app/runtime/state.md +41 -0
  159. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/security/sri.md +0 -1
  160. package/en/docusaurus-plugin-content-docs/current/configure/app/server/base-url.md +33 -0
  161. package/en/docusaurus-plugin-content-docs/current/configure/app/server/port.md +18 -0
  162. package/en/docusaurus-plugin-content-docs/current/configure/app/server/public-routes.md +26 -0
  163. package/en/docusaurus-plugin-content-docs/current/configure/app/server/routes.md +91 -0
  164. package/en/docusaurus-plugin-content-docs/current/configure/app/server/ssr-by-entries.md +28 -0
  165. package/en/docusaurus-plugin-content-docs/current/configure/app/server/ssr.md +20 -0
  166. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/source/alias.md +0 -1
  167. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/source/compile-js-data-uri.md +0 -1
  168. package/en/docusaurus-plugin-content-docs/current/configure/app/source/config-dir.md +23 -0
  169. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/source/define.md +0 -1
  170. package/en/docusaurus-plugin-content-docs/current/configure/app/source/design-system.md +1150 -0
  171. package/en/docusaurus-plugin-content-docs/current/configure/app/source/disable-default-entries.md +28 -0
  172. package/en/docusaurus-plugin-content-docs/current/configure/app/source/enable-async-entry.md +50 -0
  173. package/en/docusaurus-plugin-content-docs/current/configure/app/source/entries-dir.md +38 -0
  174. package/en/docusaurus-plugin-content-docs/current/configure/app/source/entries.md +62 -0
  175. package/en/docusaurus-plugin-content-docs/current/configure/app/source/exclude.md +12 -0
  176. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/source/global-vars.md +0 -1
  177. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/source/include.md +0 -1
  178. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/source/module-scopes.md +0 -1
  179. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/source/pre-entry.md +0 -1
  180. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/source/resolve-extension-prefix.md +0 -1
  181. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/source/resolve-main-fields.md +0 -1
  182. package/en/docusaurus-plugin-content-docs/current/configure/app/testing/transformer.md +18 -0
  183. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/autoprefixer.md +0 -1
  184. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/babel.md +0 -1
  185. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/css-extract.md +0 -1
  186. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/css-loader.md +0 -1
  187. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/dev-server.md +0 -1
  188. package/en/docusaurus-plugin-content-docs/current/configure/app/tools/esbuild.md +61 -0
  189. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/html-plugin.md +0 -1
  190. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/inspector.md +0 -1
  191. package/en/docusaurus-plugin-content-docs/current/configure/app/tools/jest.md +39 -0
  192. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/less.md +0 -1
  193. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/minify-css.md +0 -1
  194. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/postcss.md +0 -1
  195. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/pug.md +0 -1
  196. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/sass.md +0 -1
  197. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/style-loader.md +0 -1
  198. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/styled-components.md +0 -1
  199. package/en/docusaurus-plugin-content-docs/current/configure/app/tools/tailwindcss.md +47 -0
  200. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/terser.md +0 -1
  201. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/ts-checker.md +0 -1
  202. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/ts-loader.md +0 -1
  203. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/webpack-chain.md +0 -1
  204. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/webpack.md +0 -1
  205. package/en/docusaurus-plugin-content-docs/current/configure/app/usage.md +92 -0
  206. package/en/{tutorials → docusaurus-plugin-content-docs/current/tutorials}/foundations/_category_.json +0 -0
  207. package/en/{tutorials → docusaurus-plugin-content-docs/current/tutorials}/foundations/basic.md +0 -0
  208. package/en/{tutorials → docusaurus-plugin-content-docs/current/tutorials}/foundations/introduction.md +0 -0
  209. package/en/docusaurus-plugin-content-docs/current.json +262 -0
  210. package/package.json +7 -5
  211. package/scripts/config.ts +98 -0
  212. package/scripts/summary.en.json +1 -0
  213. package/scripts/summary.zh.json +1 -0
  214. package/scripts/sync.ts +26 -5
  215. package/zh/apis/app/commands/build.md +2 -2
  216. package/zh/apis/app/commands/dev.md +1 -1
  217. package/zh/apis/app/commands/index.md +1 -1
  218. package/zh/apis/app/commands/lint.md +2 -2
  219. package/zh/apis/app/commands/new.md +1 -1
  220. package/zh/apis/app/commands/start.md +1 -1
  221. package/zh/apis/app/commands/test.md +1 -1
  222. package/zh/apis/app/commands/upgrade.md +0 -2
  223. package/zh/apis/app/hooks/api/framework/_category_.json +1 -1
  224. package/zh/apis/app/hooks/api/framework/lambda.md +8 -33
  225. package/zh/apis/app/hooks/api/functions/_category_.json +1 -1
  226. package/zh/apis/app/hooks/api/functions/api.md +29 -2
  227. package/zh/apis/app/hooks/api/functions/app.md +5 -3
  228. package/zh/apis/app/hooks/api/functions/common.md +3 -5
  229. package/zh/apis/app/hooks/api/test.md +2 -4
  230. package/zh/apis/app/hooks/config/html.md +1 -3
  231. package/zh/apis/app/hooks/config/icon.md +2 -2
  232. package/zh/apis/app/hooks/config/mock.md +2 -8
  233. package/zh/apis/app/hooks/config/public.md +2 -4
  234. package/zh/apis/app/hooks/config/storybook.md +2 -4
  235. package/zh/apis/app/hooks/config/upload.md +1 -7
  236. package/zh/apis/app/hooks/modern-config.md +1 -3
  237. package/zh/apis/app/hooks/server/index_.md +12 -0
  238. package/zh/apis/app/hooks/server/test.md +3 -3
  239. package/zh/apis/app/hooks/shared.md +1 -2
  240. package/zh/apis/app/hooks/src/app.md +8 -4
  241. package/zh/apis/app/hooks/src/{index.md → index_.md} +2 -2
  242. package/zh/apis/app/hooks/src/pages.md +3 -4
  243. package/zh/apis/app/hooks/src/stories.md +2 -2
  244. package/zh/apis/app/hooks/src/test.md +1 -1
  245. package/zh/apis/app/overview.md +1 -1
  246. package/zh/apis/app/runtime/app/_category_.json +2 -2
  247. package/zh/apis/app/runtime/app/define-config.md +14 -10
  248. package/zh/apis/app/runtime/bff/_category_.json +4 -0
  249. package/zh/apis/app/runtime/bff/hook.md +43 -0
  250. package/zh/apis/app/runtime/bff/use-context.md +36 -0
  251. package/zh/apis/app/runtime/core/_category_.json +4 -0
  252. package/zh/apis/app/runtime/core/bootstrap.md +55 -0
  253. package/zh/apis/app/runtime/core/create-app.md +47 -0
  254. package/zh/apis/app/runtime/core/use-loader.md +83 -0
  255. package/zh/apis/app/runtime/core/use-module-apps.md +101 -0
  256. package/zh/apis/app/runtime/core/use-runtime-context.md +59 -0
  257. package/zh/apis/app/runtime/default-alias.md +4 -7
  258. package/zh/apis/app/runtime/env.md +22 -20
  259. package/zh/apis/app/runtime/model/Provider.md +6 -8
  260. package/zh/apis/app/runtime/model/_category_.json +1 -1
  261. package/zh/apis/app/runtime/model/auto-actions.md +1 -2
  262. package/zh/apis/app/runtime/model/connect.md +8 -5
  263. package/zh/apis/app/runtime/model/create-app.md +3 -4
  264. package/zh/apis/app/runtime/model/create-store.md +5 -3
  265. package/zh/apis/app/runtime/model/handle-effect.md +5 -5
  266. package/zh/apis/app/runtime/model/model_.md +3 -3
  267. package/zh/apis/app/runtime/model/use-local-model.md +2 -2
  268. package/zh/apis/app/runtime/model/use-model.md +6 -7
  269. package/zh/apis/app/runtime/model/use-static-model.md +2 -2
  270. package/zh/apis/app/runtime/model/use-store.md +3 -3
  271. package/zh/apis/app/runtime/router/_category_.json +4 -0
  272. package/zh/apis/app/runtime/{container → router}/router.md +0 -0
  273. package/zh/apis/app/runtime/ssr/_category_.json +4 -0
  274. package/zh/apis/app/runtime/ssr/no-ssr.md +41 -0
  275. package/zh/apis/app/runtime/ssr/pre-render.md +91 -0
  276. package/zh/apis/app/runtime/testing/_category_.json +1 -1
  277. package/zh/apis/app/runtime/testing/act.md +8 -8
  278. package/zh/apis/app/runtime/testing/cleanup.md +10 -9
  279. package/zh/apis/app/runtime/testing/render.md +43 -23
  280. package/zh/apis/app/runtime/testing/renderApp.md +8 -8
  281. package/zh/apis/app/runtime/utility/_category_.json +1 -1
  282. package/zh/apis/app/runtime/utility/css-in-js.md +17 -35
  283. package/zh/apis/app/runtime/{app → utility}/head.md +6 -10
  284. package/zh/apis/app/runtime/utility/{loadable/loadable_.md → loadable.md} +29 -56
  285. package/zh/apis/app/runtime/web-server/_category_.json +1 -1
  286. package/zh/apis/app/runtime/web-server/hook.md +100 -90
  287. package/zh/apis/app/runtime/web-server/middleware.md +106 -0
  288. package/zh/apis/monorepo/commands/bump.md +1 -1
  289. package/zh/apis/monorepo/commands/change.md +1 -1
  290. package/zh/apis/monorepo/commands/clear.md +1 -1
  291. package/zh/apis/monorepo/commands/deploy.md +1 -1
  292. package/zh/apis/monorepo/commands/gen-release-note.md +1 -1
  293. package/zh/apis/monorepo/commands/lint.md +1 -1
  294. package/zh/apis/monorepo/commands/new.md +1 -1
  295. package/zh/apis/monorepo/commands/pre.md +1 -1
  296. package/zh/apis/monorepo/commands/release.md +1 -1
  297. package/zh/configure/app/bff/fetcher.md +1 -2
  298. package/zh/configure/app/bff/prefix.md +2 -3
  299. package/zh/configure/app/bff/proxy.md +8 -13
  300. package/zh/configure/app/dev/asset-prefix.md +0 -1
  301. package/zh/configure/app/dev/hmr.md +0 -1
  302. package/zh/configure/app/dev/https.md +0 -1
  303. package/zh/configure/app/dev/port.md +0 -1
  304. package/zh/configure/app/dev/progress-bar.md +0 -1
  305. package/zh/configure/app/dev/proxy.md +2 -3
  306. package/zh/configure/app/dev/start-url.md +0 -1
  307. package/zh/configure/app/dev/with-master-app.md +0 -1
  308. package/zh/configure/app/experiments/lazy-compilation.md +12 -0
  309. package/zh/configure/app/html/app-icon.md +0 -1
  310. package/zh/configure/app/html/crossorigin.md +0 -1
  311. package/zh/configure/app/html/disable-html-folder.md +0 -1
  312. package/zh/configure/app/html/favicon-by-entries.md +0 -1
  313. package/zh/configure/app/html/favicon.md +0 -1
  314. package/zh/configure/app/html/inject-by-entries.md +0 -1
  315. package/zh/configure/app/html/inject.md +0 -1
  316. package/zh/configure/app/html/meta-by-entries.md +0 -1
  317. package/zh/configure/app/html/meta.md +0 -1
  318. package/zh/configure/app/html/mount-id.md +0 -1
  319. package/zh/configure/app/html/template-by-entries.md +0 -1
  320. package/zh/configure/app/html/template-parameters-by-entries.md +0 -1
  321. package/zh/configure/app/html/template-parameters.md +0 -1
  322. package/zh/configure/app/html/template.md +0 -1
  323. package/zh/configure/app/html/title-by-entries.md +0 -1
  324. package/zh/configure/app/html/title.md +0 -1
  325. package/zh/configure/app/output/asset-prefix.md +0 -1
  326. package/zh/configure/app/output/assets-retry.md +0 -1
  327. package/zh/configure/app/output/charset.md +0 -1
  328. package/zh/configure/app/output/clean-dist-path.md +0 -1
  329. package/zh/configure/app/output/convert-to-rem.md +0 -1
  330. package/zh/configure/app/output/copy.md +0 -1
  331. package/zh/configure/app/output/css-module-local-ident-name.md +0 -1
  332. package/zh/configure/app/output/data-uri-limit.md +0 -1
  333. package/zh/configure/app/output/disable-css-module-extension.md +0 -1
  334. package/zh/configure/app/output/disable-filename-hash.md +0 -1
  335. package/zh/configure/app/output/disable-inline-runtime-chunk.md +0 -1
  336. package/zh/configure/app/output/disable-minimize.md +0 -1
  337. package/zh/configure/app/output/disable-node-polyfill.md +2 -4
  338. package/zh/configure/app/output/disable-source-map.md +0 -1
  339. package/zh/configure/app/output/disable-ts-checker.md +12 -0
  340. package/zh/configure/app/output/dist-path.md +0 -1
  341. package/zh/configure/app/output/enable-asset-fallback.md +0 -1
  342. package/zh/configure/app/output/enable-asset-manifest.md +0 -1
  343. package/zh/configure/app/output/enable-css-module-tsdeclaration.md +0 -1
  344. package/zh/configure/app/output/enable-inline-scripts.md +0 -1
  345. package/zh/configure/app/output/enable-inline-styles.md +0 -1
  346. package/zh/configure/app/output/enable-latest-decorators.md +0 -1
  347. package/zh/configure/app/output/enable-modern-mode.md +13 -5
  348. package/zh/configure/app/output/externals.md +0 -1
  349. package/zh/configure/app/output/filename.md +0 -1
  350. package/zh/configure/app/output/legal-comments.md +0 -1
  351. package/zh/configure/app/output/override-browserslist.md +0 -1
  352. package/zh/configure/app/output/polyfill.md +0 -1
  353. package/zh/configure/app/output/svg-default-export.md +0 -1
  354. package/zh/configure/app/performance/build-cache.md +0 -1
  355. package/zh/configure/app/performance/bundle-analyze.md +0 -1
  356. package/zh/configure/app/performance/chunk-split.md +0 -1
  357. package/zh/configure/app/performance/print-file-size.md +0 -1
  358. package/zh/configure/app/performance/profile.md +0 -1
  359. package/zh/configure/app/performance/remove-console.md +0 -1
  360. package/zh/configure/app/performance/remove-moment-locale.md +0 -1
  361. package/zh/configure/app/runtime/intro.md +92 -0
  362. package/zh/configure/app/runtime/master-app.md +8 -21
  363. package/zh/configure/app/runtime/router.md +4 -38
  364. package/zh/configure/app/runtime/state.md +10 -13
  365. package/zh/configure/app/security/sri.md +0 -1
  366. package/zh/configure/app/server/base-url.md +1 -2
  367. package/zh/configure/app/server/port.md +1 -2
  368. package/zh/configure/app/server/public-routes.md +1 -2
  369. package/zh/configure/app/server/routes.md +4 -5
  370. package/zh/configure/app/server/ssr-by-entries.md +2 -3
  371. package/zh/configure/app/server/ssr.md +1 -2
  372. package/zh/configure/app/source/alias.md +0 -1
  373. package/zh/configure/app/source/compile-js-data-uri.md +0 -1
  374. package/zh/configure/app/source/config-dir.md +12 -4
  375. package/zh/configure/app/source/define.md +0 -1
  376. package/zh/configure/app/source/design-system.md +14 -24
  377. package/zh/configure/app/source/disable-default-entries.md +8 -3
  378. package/zh/configure/app/source/enable-async-entry.md +3 -3
  379. package/zh/configure/app/source/entries-dir.md +1 -1
  380. package/zh/configure/app/source/entries.md +16 -9
  381. package/zh/configure/app/source/exclude.md +12 -0
  382. package/zh/configure/app/source/global-vars.md +0 -1
  383. package/zh/configure/app/source/include.md +0 -1
  384. package/zh/configure/app/source/module-scopes.md +0 -1
  385. package/zh/configure/app/source/pre-entry.md +0 -1
  386. package/zh/configure/app/source/resolve-extension-prefix.md +0 -1
  387. package/zh/configure/app/source/resolve-main-fields.md +0 -1
  388. package/zh/configure/app/testing/transformer.md +2 -4
  389. package/zh/configure/app/tools/autoprefixer.md +0 -1
  390. package/zh/configure/app/tools/babel.md +0 -1
  391. package/zh/configure/app/tools/css-extract.md +0 -1
  392. package/zh/configure/app/tools/css-loader.md +0 -1
  393. package/zh/configure/app/tools/dev-server.md +0 -1
  394. package/zh/configure/app/tools/esbuild.md +5 -5
  395. package/zh/configure/app/tools/html-plugin.md +0 -1
  396. package/zh/configure/app/tools/inspector.md +0 -1
  397. package/zh/configure/app/tools/jest.md +2 -4
  398. package/zh/configure/app/tools/less.md +0 -1
  399. package/zh/configure/app/tools/minify-css.md +0 -1
  400. package/zh/configure/app/tools/postcss.md +0 -1
  401. package/zh/configure/app/tools/pug.md +0 -1
  402. package/zh/configure/app/tools/sass.md +0 -1
  403. package/zh/configure/app/tools/style-loader.md +0 -1
  404. package/zh/configure/app/tools/styled-components.md +0 -1
  405. package/zh/configure/app/tools/terser.md +0 -1
  406. package/zh/configure/app/tools/ts-checker.md +0 -1
  407. package/zh/configure/app/tools/ts-loader.md +0 -1
  408. package/zh/configure/app/tools/webpack-chain.md +0 -1
  409. package/zh/configure/app/tools/webpack.md +0 -1
  410. package/zh/configure/app/usage.md +15 -4
  411. package/zh/guides/advanced-features/bff/bff-server.md +1 -1
  412. package/zh/guides/advanced-features/bff/frameworks.md +0 -221
  413. package/zh/guides/advanced-features/code-split.md +1 -1
  414. package/zh/guides/advanced-features/low-level.md +2 -2
  415. package/zh/guides/advanced-features/ssg.md +2 -2
  416. package/zh/guides/advanced-features/ssr.md +4 -4
  417. package/zh/guides/basic-features/alias.md +1 -1
  418. package/zh/guides/basic-features/css/postcss.md +1 -1
  419. package/zh/guides/basic-features/css/tailwindcss.md +2 -2
  420. package/zh/guides/basic-features/env-vars.md +2 -3
  421. package/zh/guides/basic-features/proxy.md +2 -2
  422. package/zh/guides/topic-detail/compile-speed.md +5 -5
  423. package/zh/guides/topic-detail/generator/_category_.json +4 -0
  424. package/zh/guides/topic-detail/generator/codesmith/_category_.json +4 -0
  425. package/zh/guides/topic-detail/generator/codesmith/introduce.md +5 -0
  426. package/zh/guides/topic-detail/generator/config/_category_.json +4 -0
  427. package/zh/{configure/generator/introduce.md → guides/topic-detail/generator/config/common.md} +35 -42
  428. package/zh/{configure/generator → guides/topic-detail/generator/config}/module.md +7 -11
  429. package/zh/{configure/generator → guides/topic-detail/generator/config}/monorepo.md +4 -4
  430. package/zh/{configure/generator → guides/topic-detail/generator/config}/mwa.md +11 -45
  431. package/zh/guides/topic-detail/generator/plugin/_category_.json +4 -0
  432. package/zh/guides/topic-detail/{generator-plugin → generator/plugin}/abstract.md +0 -0
  433. package/zh/guides/topic-detail/generator/plugin/api/_category_.json +4 -0
  434. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/file/_category_.json +0 -0
  435. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/file/addFile.md +1 -1
  436. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/file/addHelper.md +0 -0
  437. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/file/addManyFile.md +1 -1
  438. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/file/addPartial.md +0 -0
  439. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/file/introduce.md +0 -0
  440. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/file/rmDir.md +0 -0
  441. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/file/rmFile.md +0 -0
  442. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/file/updateJSONFile.md +0 -0
  443. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/file/updateModernConfig.md +0 -0
  444. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/file/updateTextRawFile.md +0 -0
  445. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/git/_category_.json +0 -0
  446. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/git/gitAddAndCommit.md +0 -0
  447. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/git/initGitRepo.md +0 -0
  448. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/git/isInGitRepo.md +0 -0
  449. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/hook/_category_.json +0 -0
  450. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/hook/afterForged.md +1 -1
  451. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/hook/onForged.md +1 -1
  452. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/info/_category_.json +0 -0
  453. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/info/isFileExit.md +0 -0
  454. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/info/locale.md +0 -0
  455. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/info/readDir.md +0 -0
  456. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/input/_category_.json +0 -0
  457. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/input/addInputAfter.md +14 -6
  458. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/input/addInputBefore.md +14 -6
  459. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/input/setInput.md +2 -2
  460. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/input/setInputValue.md +0 -0
  461. package/zh/guides/topic-detail/generator/plugin/api/input/type.md +65 -0
  462. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/introduce.md +0 -0
  463. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/new/_category_.json +0 -0
  464. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/new/createElement.md +1 -1
  465. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/new/createSubProject.md +1 -1
  466. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/new/enableFunc.md +1 -3
  467. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/new/introduce.md +3 -3
  468. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/npm/_category_.json +0 -0
  469. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/npm/install.md +0 -0
  470. package/zh/guides/topic-detail/{generator-plugin → generator/plugin}/develop.md +4 -4
  471. package/zh/guides/topic-detail/{generator-plugin → generator/plugin}/use.md +0 -0
  472. package/zh/guides/topic-detail/generator/project.md +117 -0
  473. package/zh/guides/topic-detail/micro-frontend/debugging.md +5 -5
  474. package/zh/guides/topic-detail/micro-frontend/route-mode.md +2 -2
  475. package/zh/guides/troubleshooting/compile.md +3 -3
  476. package/zh/tutorials/first-app/c01-getting-started/1.4-enable-ssr.md +2 -2
  477. package/zh/tutorials/first-app/c04-es6-plus-and-ts/4.3-compatibility.md +4 -4
  478. package/zh/tutorials/first-app/c06-css-and-component/6.4-design-system.md +3 -3
  479. package/zh/tutorials/first-app/c07-app-entry/7.3-manage-entries-by-hand.md +2 -2
  480. package/zh/tutorials/first-app/c08-client-side-routing/8.1-code-based-routing.md +1 -1
  481. package/scripts/gen-config.ts +0 -60
  482. package/zh/apis/app/hooks/api/framework/app.md +0 -100
  483. package/zh/apis/app/hooks/server/index.md +0 -14
  484. package/zh/apis/app/hooks/src/error.md +0 -10
  485. package/zh/apis/app/hooks/src/eslint.md +0 -9
  486. package/zh/apis/app/runtime/app/bootstrap.md +0 -83
  487. package/zh/apis/app/runtime/app/create-app.md +0 -47
  488. package/zh/apis/app/runtime/app/no-ssr.md +0 -41
  489. package/zh/apis/app/runtime/app/pre-render.md +0 -77
  490. package/zh/apis/app/runtime/app/use-module-app.md +0 -60
  491. package/zh/apis/app/runtime/app/use-module-apps.md +0 -64
  492. package/zh/apis/app/runtime/app/use-runtime-context.md +0 -39
  493. package/zh/apis/app/runtime/bff-server/_category_.json +0 -4
  494. package/zh/apis/app/runtime/bff-server/after-lambda-registed.md +0 -35
  495. package/zh/apis/app/runtime/bff-server/hook.md +0 -120
  496. package/zh/apis/app/runtime/bff-server/use-context.md +0 -70
  497. package/zh/apis/app/runtime/container/_category_.json +0 -4
  498. package/zh/apis/app/runtime/container/use-loader.md +0 -64
  499. package/zh/apis/app/runtime/utility/loadable/_category_.json +0 -4
  500. package/zh/apis/app/runtime/utility/loadable/lazy.md +0 -29
  501. package/zh/apis/app/runtime/utility/loadable/loadable-component.md +0 -61
  502. package/zh/apis/app/runtime/utility/loadable/loadable-library.md +0 -67
  503. package/zh/apis/generator/plugin/_category_.json +0 -4
  504. package/zh/apis/generator/plugin/input/addOptionAfter.md +0 -45
  505. package/zh/apis/generator/plugin/input/addOptionBefore.md +0 -45
  506. package/zh/apis/generator/plugin/input/type.md +0 -101
  507. package/zh/guides/topic-detail/generator-plugin/_category_.json +0 -4
@@ -0,0 +1,1150 @@
1
+ ---
2
+ title: source.designSystem
3
+ sidebar_label: designSystem
4
+ ---
5
+
6
+ * Type: `Object`
7
+ * Default: See configuration details below。
8
+
9
+ :::caution Caution
10
+ You need to enable the Tailwind CSS feature through `pnpm run new` first.
11
+ :::
12
+
13
+ <details>
14
+ <summary>DesignSystem Configuration Details</summary>
15
+
16
+ ```js
17
+ const designSystem = {
18
+ screens: {
19
+ sm: '640px',
20
+ md: '768px',
21
+ lg: '1024px',
22
+ xl: '1280px',
23
+ },
24
+ colors: {
25
+ transparent: 'transparent',
26
+ current: 'currentColor',
27
+
28
+ black: '#000',
29
+ white: '#fff',
30
+
31
+ gray: {
32
+ 100: '#f7fafc',
33
+ 200: '#edf2f7',
34
+ 300: '#e2e8f0',
35
+ 400: '#cbd5e0',
36
+ 500: '#a0aec0',
37
+ 600: '#718096',
38
+ 700: '#4a5568',
39
+ 800: '#2d3748',
40
+ 900: '#1a202c',
41
+ },
42
+ red: {
43
+ 100: '#fff5f5',
44
+ 200: '#fed7d7',
45
+ 300: '#feb2b2',
46
+ 400: '#fc8181',
47
+ 500: '#f56565',
48
+ 600: '#e53e3e',
49
+ 700: '#c53030',
50
+ 800: '#9b2c2c',
51
+ 900: '#742a2a',
52
+ },
53
+ orange: {
54
+ 100: '#fffaf0',
55
+ 200: '#feebc8',
56
+ 300: '#fbd38d',
57
+ 400: '#f6ad55',
58
+ 500: '#ed8936',
59
+ 600: '#dd6b20',
60
+ 700: '#c05621',
61
+ 800: '#9c4221',
62
+ 900: '#7b341e',
63
+ },
64
+ yellow: {
65
+ 100: '#fffff0',
66
+ 200: '#fefcbf',
67
+ 300: '#faf089',
68
+ 400: '#f6e05e',
69
+ 500: '#ecc94b',
70
+ 600: '#d69e2e',
71
+ 700: '#b7791f',
72
+ 800: '#975a16',
73
+ 900: '#744210',
74
+ },
75
+ green: {
76
+ 100: '#f0fff4',
77
+ 200: '#c6f6d5',
78
+ 300: '#9ae6b4',
79
+ 400: '#68d391',
80
+ 500: '#48bb78',
81
+ 600: '#38a169',
82
+ 700: '#2f855a',
83
+ 800: '#276749',
84
+ 900: '#22543d',
85
+ },
86
+ teal: {
87
+ 100: '#e6fffa',
88
+ 200: '#b2f5ea',
89
+ 300: '#81e6d9',
90
+ 400: '#4fd1c5',
91
+ 500: '#38b2ac',
92
+ 600: '#319795',
93
+ 700: '#2c7a7b',
94
+ 800: '#285e61',
95
+ 900: '#234e52',
96
+ },
97
+ blue: {
98
+ 100: '#ebf8ff',
99
+ 200: '#bee3f8',
100
+ 300: '#90cdf4',
101
+ 400: '#63b3ed',
102
+ 500: '#4299e1',
103
+ 600: '#3182ce',
104
+ 700: '#2b6cb0',
105
+ 800: '#2c5282',
106
+ 900: '#2a4365',
107
+ },
108
+ indigo: {
109
+ 100: '#ebf4ff',
110
+ 200: '#c3dafe',
111
+ 300: '#a3bffa',
112
+ 400: '#7f9cf5',
113
+ 500: '#667eea',
114
+ 600: '#5a67d8',
115
+ 700: '#4c51bf',
116
+ 800: '#434190',
117
+ 900: '#3c366b',
118
+ },
119
+ purple: {
120
+ 100: '#faf5ff',
121
+ 200: '#e9d8fd',
122
+ 300: '#d6bcfa',
123
+ 400: '#b794f4',
124
+ 500: '#9f7aea',
125
+ 600: '#805ad5',
126
+ 700: '#6b46c1',
127
+ 800: '#553c9a',
128
+ 900: '#44337a',
129
+ },
130
+ pink: {
131
+ 100: '#fff5f7',
132
+ 200: '#fed7e2',
133
+ 300: '#fbb6ce',
134
+ 400: '#f687b3',
135
+ 500: '#ed64a6',
136
+ 600: '#d53f8c',
137
+ 700: '#b83280',
138
+ 800: '#97266d',
139
+ 900: '#702459',
140
+ },
141
+ },
142
+ spacing: {
143
+ px: '1px',
144
+ '0': '0',
145
+ '1': '0.25rem',
146
+ '2': '0.5rem',
147
+ '3': '0.75rem',
148
+ '4': '1rem',
149
+ '5': '1.25rem',
150
+ '6': '1.5rem',
151
+ '8': '2rem',
152
+ '10': '2.5rem',
153
+ '12': '3rem',
154
+ '16': '4rem',
155
+ '20': '5rem',
156
+ '24': '6rem',
157
+ '32': '8rem',
158
+ '40': '10rem',
159
+ '48': '12rem',
160
+ '56': '14rem',
161
+ '64': '16rem',
162
+ },
163
+ backgroundColor: theme => theme('colors'),
164
+ backgroundOpacity: theme => theme('opacity'),
165
+ backgroundPosition: {
166
+ bottom: 'bottom',
167
+ center: 'center',
168
+ left: 'left',
169
+ 'left-bottom': 'left bottom',
170
+ 'left-top': 'left top',
171
+ right: 'right',
172
+ 'right-bottom': 'right bottom',
173
+ 'right-top': 'right top',
174
+ top: 'top',
175
+ },
176
+ backgroundSize: {
177
+ auto: 'auto',
178
+ cover: 'cover',
179
+ contain: 'contain',
180
+ },
181
+ borderColor: theme => ({
182
+ ...theme('colors'),
183
+ default: theme('colors.gray.300', 'currentColor'),
184
+ }),
185
+ borderOpacity: theme => theme('opacity'),
186
+ borderRadius: {
187
+ none: '0',
188
+ sm: '0.125rem',
189
+ default: '0.25rem',
190
+ md: '0.375rem',
191
+ lg: '0.5rem',
192
+ full: '9999px',
193
+ },
194
+ borderWidth: {
195
+ default: '1px',
196
+ '0': '0',
197
+ '2': '2px',
198
+ '4': '4px',
199
+ '8': '8px',
200
+ },
201
+ boxShadow: {
202
+ xs: '0 0 0 1px rgba(0, 0, 0, 0.05)',
203
+ sm: '0 1px 2px 0 rgba(0, 0, 0, 0.05)',
204
+ default: '0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06)',
205
+ md: '0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06)',
206
+ lg: '0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05)',
207
+ xl: '0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04)',
208
+ '2xl': '0 25px 50px -12px rgba(0, 0, 0, 0.25)',
209
+ inner: 'inset 0 2px 4px 0 rgba(0, 0, 0, 0.06)',
210
+ outline: '0 0 0 3px rgba(66, 153, 225, 0.5)',
211
+ none: 'none',
212
+ },
213
+ container: {},
214
+ cursor: {
215
+ auto: 'auto',
216
+ default: 'default',
217
+ pointer: 'pointer',
218
+ wait: 'wait',
219
+ text: 'text',
220
+ move: 'move',
221
+ 'not-allowed': 'not-allowed',
222
+ },
223
+ divideColor: theme => theme('borderColor'),
224
+ divideOpacity: theme => theme('borderOpacity'),
225
+ divideWidth: theme => theme('borderWidth'),
226
+ fill: {
227
+ current: 'currentColor',
228
+ },
229
+ flex: {
230
+ '1': '1 1 0%',
231
+ auto: '1 1 auto',
232
+ initial: '0 1 auto',
233
+ none: 'none',
234
+ },
235
+ flexGrow: {
236
+ '0': '0',
237
+ default: '1',
238
+ },
239
+ flexShrink: {
240
+ '0': '0',
241
+ default: '1',
242
+ },
243
+ fontFamily: {
244
+ sans: [
245
+ 'system-ui',
246
+ '-apple-system',
247
+ 'BlinkMacSystemFont',
248
+ '"Segoe UI"',
249
+ 'Roboto',
250
+ '"Helvetica Neue"',
251
+ 'Arial',
252
+ '"Noto Sans"',
253
+ 'sans-serif',
254
+ '"Apple Color Emoji"',
255
+ '"Segoe UI Emoji"',
256
+ '"Segoe UI Symbol"',
257
+ '"Noto Color Emoji"',
258
+ ],
259
+ serif: ['Georgia', 'Cambria', '"Times New Roman"', 'Times', 'serif'],
260
+ mono: ['Menlo', 'Monaco', 'Consolas', '"Liberation Mono"', '"Courier New"', 'monospace'],
261
+ },
262
+ fontSize: {
263
+ xs: '0.75rem',
264
+ sm: '0.875rem',
265
+ base: '1rem',
266
+ lg: '1.125rem',
267
+ xl: '1.25rem',
268
+ '2xl': '1.5rem',
269
+ '3xl': '1.875rem',
270
+ '4xl': '2.25rem',
271
+ '5xl': '3rem',
272
+ '6xl': '4rem',
273
+ },
274
+ fontWeight: {
275
+ hairline: '100',
276
+ thin: '200',
277
+ light: '300',
278
+ normal: '400',
279
+ medium: '500',
280
+ semibold: '600',
281
+ bold: '700',
282
+ extrabold: '800',
283
+ black: '900',
284
+ },
285
+ height: theme => ({
286
+ auto: 'auto',
287
+ ...theme('spacing'),
288
+ full: '100%',
289
+ screen: '100vh',
290
+ }),
291
+ inset: {
292
+ '0': '0',
293
+ auto: 'auto',
294
+ },
295
+ letterSpacing: {
296
+ tighter: '-0.05em',
297
+ tight: '-0.025em',
298
+ normal: '0',
299
+ wide: '0.025em',
300
+ wider: '0.05em',
301
+ widest: '0.1em',
302
+ },
303
+ lineHeight: {
304
+ none: '1',
305
+ tight: '1.25',
306
+ snug: '1.375',
307
+ normal: '1.5',
308
+ relaxed: '1.625',
309
+ loose: '2',
310
+ '3': '.75rem',
311
+ '4': '1rem',
312
+ '5': '1.25rem',
313
+ '6': '1.5rem',
314
+ '7': '1.75rem',
315
+ '8': '2rem',
316
+ '9': '2.25rem',
317
+ '10': '2.5rem',
318
+ },
319
+ listStyleType: {
320
+ none: 'none',
321
+ disc: 'disc',
322
+ decimal: 'decimal',
323
+ },
324
+ margin: (theme, { negative }) => ({
325
+ auto: 'auto',
326
+ ...theme('spacing'),
327
+ ...negative(theme('spacing')),
328
+ }),
329
+ maxHeight: {
330
+ full: '100%',
331
+ screen: '100vh',
332
+ },
333
+ maxWidth: (theme, { breakpoints }) => ({
334
+ none: 'none',
335
+ xs: '20rem',
336
+ sm: '24rem',
337
+ md: '28rem',
338
+ lg: '32rem',
339
+ xl: '36rem',
340
+ '2xl': '42rem',
341
+ '3xl': '48rem',
342
+ '4xl': '56rem',
343
+ '5xl': '64rem',
344
+ '6xl': '72rem',
345
+ full: '100%',
346
+ ...breakpoints(theme('screens')),
347
+ }),
348
+ minHeight: {
349
+ '0': '0',
350
+ full: '100%',
351
+ screen: '100vh',
352
+ },
353
+ minWidth: {
354
+ '0': '0',
355
+ full: '100%',
356
+ },
357
+ objectPosition: {
358
+ bottom: 'bottom',
359
+ center: 'center',
360
+ left: 'left',
361
+ 'left-bottom': 'left bottom',
362
+ 'left-top': 'left top',
363
+ right: 'right',
364
+ 'right-bottom': 'right bottom',
365
+ 'right-top': 'right top',
366
+ top: 'top',
367
+ },
368
+ opacity: {
369
+ '0': '0',
370
+ '25': '0.25',
371
+ '50': '0.5',
372
+ '75': '0.75',
373
+ '100': '1',
374
+ },
375
+ order: {
376
+ first: '-9999',
377
+ last: '9999',
378
+ none: '0',
379
+ '1': '1',
380
+ '2': '2',
381
+ '3': '3',
382
+ '4': '4',
383
+ '5': '5',
384
+ '6': '6',
385
+ '7': '7',
386
+ '8': '8',
387
+ '9': '9',
388
+ '10': '10',
389
+ '11': '11',
390
+ '12': '12',
391
+ },
392
+ padding: theme => theme('spacing'),
393
+ placeholderColor: theme => theme('colors'),
394
+ placeholderOpacity: theme => theme('opacity'),
395
+ space: (theme, { negative }) => ({
396
+ ...theme('spacing'),
397
+ ...negative(theme('spacing')),
398
+ }),
399
+ stroke: {
400
+ current: 'currentColor',
401
+ },
402
+ strokeWidth: {
403
+ '0': '0',
404
+ '1': '1',
405
+ '2': '2',
406
+ },
407
+ textColor: theme => theme('colors'),
408
+ textOpacity: theme => theme('opacity'),
409
+ width: theme => ({
410
+ auto: 'auto',
411
+ ...theme('spacing'),
412
+ '1/2': '50%',
413
+ '1/3': '33.333333%',
414
+ '2/3': '66.666667%',
415
+ '1/4': '25%',
416
+ '2/4': '50%',
417
+ '3/4': '75%',
418
+ '1/5': '20%',
419
+ '2/5': '40%',
420
+ '3/5': '60%',
421
+ '4/5': '80%',
422
+ '1/6': '16.666667%',
423
+ '2/6': '33.333333%',
424
+ '3/6': '50%',
425
+ '4/6': '66.666667%',
426
+ '5/6': '83.333333%',
427
+ '1/12': '8.333333%',
428
+ '2/12': '16.666667%',
429
+ '3/12': '25%',
430
+ '4/12': '33.333333%',
431
+ '5/12': '41.666667%',
432
+ '6/12': '50%',
433
+ '7/12': '58.333333%',
434
+ '8/12': '66.666667%',
435
+ '9/12': '75%',
436
+ '10/12': '83.333333%',
437
+ '11/12': '91.666667%',
438
+ full: '100%',
439
+ screen: '100vw',
440
+ }),
441
+ zIndex: {
442
+ auto: 'auto',
443
+ '0': '0',
444
+ '10': '10',
445
+ '20': '20',
446
+ '30': '30',
447
+ '40': '40',
448
+ '50': '50',
449
+ },
450
+ gap: theme => theme('spacing'),
451
+ gridTemplateColumns: {
452
+ none: 'none',
453
+ '1': 'repeat(1, minmax(0, 1fr))',
454
+ '2': 'repeat(2, minmax(0, 1fr))',
455
+ '3': 'repeat(3, minmax(0, 1fr))',
456
+ '4': 'repeat(4, minmax(0, 1fr))',
457
+ '5': 'repeat(5, minmax(0, 1fr))',
458
+ '6': 'repeat(6, minmax(0, 1fr))',
459
+ '7': 'repeat(7, minmax(0, 1fr))',
460
+ '8': 'repeat(8, minmax(0, 1fr))',
461
+ '9': 'repeat(9, minmax(0, 1fr))',
462
+ '10': 'repeat(10, minmax(0, 1fr))',
463
+ '11': 'repeat(11, minmax(0, 1fr))',
464
+ '12': 'repeat(12, minmax(0, 1fr))',
465
+ },
466
+ gridColumn: {
467
+ auto: 'auto',
468
+ 'span-1': 'span 1 / span 1',
469
+ 'span-2': 'span 2 / span 2',
470
+ 'span-3': 'span 3 / span 3',
471
+ 'span-4': 'span 4 / span 4',
472
+ 'span-5': 'span 5 / span 5',
473
+ 'span-6': 'span 6 / span 6',
474
+ 'span-7': 'span 7 / span 7',
475
+ 'span-8': 'span 8 / span 8',
476
+ 'span-9': 'span 9 / span 9',
477
+ 'span-10': 'span 10 / span 10',
478
+ 'span-11': 'span 11 / span 11',
479
+ 'span-12': 'span 12 / span 12',
480
+ },
481
+ gridColumnStart: {
482
+ auto: 'auto',
483
+ '1': '1',
484
+ '2': '2',
485
+ '3': '3',
486
+ '4': '4',
487
+ '5': '5',
488
+ '6': '6',
489
+ '7': '7',
490
+ '8': '8',
491
+ '9': '9',
492
+ '10': '10',
493
+ '11': '11',
494
+ '12': '12',
495
+ '13': '13',
496
+ },
497
+ gridColumnEnd: {
498
+ auto: 'auto',
499
+ '1': '1',
500
+ '2': '2',
501
+ '3': '3',
502
+ '4': '4',
503
+ '5': '5',
504
+ '6': '6',
505
+ '7': '7',
506
+ '8': '8',
507
+ '9': '9',
508
+ '10': '10',
509
+ '11': '11',
510
+ '12': '12',
511
+ '13': '13',
512
+ },
513
+ gridTemplateRows: {
514
+ none: 'none',
515
+ '1': 'repeat(1, minmax(0, 1fr))',
516
+ '2': 'repeat(2, minmax(0, 1fr))',
517
+ '3': 'repeat(3, minmax(0, 1fr))',
518
+ '4': 'repeat(4, minmax(0, 1fr))',
519
+ '5': 'repeat(5, minmax(0, 1fr))',
520
+ '6': 'repeat(6, minmax(0, 1fr))',
521
+ },
522
+ gridRow: {
523
+ auto: 'auto',
524
+ 'span-1': 'span 1 / span 1',
525
+ 'span-2': 'span 2 / span 2',
526
+ 'span-3': 'span 3 / span 3',
527
+ 'span-4': 'span 4 / span 4',
528
+ 'span-5': 'span 5 / span 5',
529
+ 'span-6': 'span 6 / span 6',
530
+ },
531
+ gridRowStart: {
532
+ auto: 'auto',
533
+ '1': '1',
534
+ '2': '2',
535
+ '3': '3',
536
+ '4': '4',
537
+ '5': '5',
538
+ '6': '6',
539
+ '7': '7',
540
+ },
541
+ gridRowEnd: {
542
+ auto: 'auto',
543
+ '1': '1',
544
+ '2': '2',
545
+ '3': '3',
546
+ '4': '4',
547
+ '5': '5',
548
+ '6': '6',
549
+ '7': '7',
550
+ },
551
+ transformOrigin: {
552
+ center: 'center',
553
+ top: 'top',
554
+ 'top-right': 'top right',
555
+ right: 'right',
556
+ 'bottom-right': 'bottom right',
557
+ bottom: 'bottom',
558
+ 'bottom-left': 'bottom left',
559
+ left: 'left',
560
+ 'top-left': 'top left',
561
+ },
562
+ scale: {
563
+ '0': '0',
564
+ '50': '.5',
565
+ '75': '.75',
566
+ '90': '.9',
567
+ '95': '.95',
568
+ '100': '1',
569
+ '105': '1.05',
570
+ '110': '1.1',
571
+ '125': '1.25',
572
+ '150': '1.5',
573
+ },
574
+ rotate: {
575
+ '-180': '-180deg',
576
+ '-90': '-90deg',
577
+ '-45': '-45deg',
578
+ '0': '0',
579
+ '45': '45deg',
580
+ '90': '90deg',
581
+ '180': '180deg',
582
+ },
583
+ translate: (theme, { negative }) => ({
584
+ ...theme('spacing'),
585
+ ...negative(theme('spacing')),
586
+ '-full': '-100%',
587
+ '-1/2': '-50%',
588
+ '1/2': '50%',
589
+ full: '100%',
590
+ }),
591
+ skew: {
592
+ '-12': '-12deg',
593
+ '-6': '-6deg',
594
+ '-3': '-3deg',
595
+ '0': '0',
596
+ '3': '3deg',
597
+ '6': '6deg',
598
+ '12': '12deg',
599
+ },
600
+ transitionProperty: {
601
+ none: 'none',
602
+ all: 'all',
603
+ default: 'background-color, border-color, color, fill, stroke, opacity, box-shadow, transform',
604
+ colors: 'background-color, border-color, color, fill, stroke',
605
+ opacity: 'opacity',
606
+ shadow: 'box-shadow',
607
+ transform: 'transform',
608
+ },
609
+ transitionTimingFunction: {
610
+ linear: 'linear',
611
+ in: 'cubic-bezier(0.4, 0, 1, 1)',
612
+ out: 'cubic-bezier(0, 0, 0.2, 1)',
613
+ 'in-out': 'cubic-bezier(0.4, 0, 0.2, 1)',
614
+ },
615
+ transitionDuration: {
616
+ '75': '75ms',
617
+ '100': '100ms',
618
+ '150': '150ms',
619
+ '200': '200ms',
620
+ '300': '300ms',
621
+ '500': '500ms',
622
+ '700': '700ms',
623
+ '1000': '1000ms',
624
+ },
625
+ transitionDelay: {
626
+ '75': '75ms',
627
+ '100': '100ms',
628
+ '150': '150ms',
629
+ '200': '200ms',
630
+ '300': '300ms',
631
+ '500': '500ms',
632
+ '700': '700ms',
633
+ '1000': '1000ms',
634
+ },
635
+ };
636
+ ```
637
+
638
+ :::tip 提示
639
+ More about:<a href="https://tailwindcss.com/docs/configuration#theme" target="_blank">TailwindCSS configuration</a>。
640
+ :::
641
+ </details>
642
+
643
+ `designSystem` is used to define the project's color palette, typographic scale (Typographic Scales or Type Scale), font list, breakpoints, border rounded values, and more. Because Modern.js borrowed the design method of Tailwind Theme, and also integrates Tailwind CSS internally, the `designSystem` is used in the same way as Tailwind CSS Theme.
644
+
645
+ ### Structure
646
+
647
+ The `designSystem` object contains properties for `screens`, `colors`, and `spacing`, as well as each customizable core plugin.
648
+
649
+ #### Screens
650
+
651
+ Use `screens` to customize response breakpoints in your project:
652
+
653
+ ```js
654
+ const designSystem = {
655
+ screens: {
656
+ sm: '640px',
657
+ md: '768px',
658
+ lg: '1024px',
659
+ xl: '1280px',
660
+ },
661
+ };
662
+ ```
663
+
664
+ Where the property name in the `screens` object is the screen name (used as a prefix for adaptive utility variants generated by `Tailwind CSS`, such as `md:text-center`), and the value is the `min-width` at which the breakpoint should begin.
665
+
666
+ Default breakpoints are inspired by common device resolutions:
667
+
668
+ ```js
669
+ const designSystem = {
670
+ screens: {
671
+ sm: '640px',
672
+ // => @media (min-width: 640px) { ... }
673
+
674
+ md: '768px',
675
+ // => @media (min-width: 768px) { ... }
676
+
677
+ lg: '1024px',
678
+ // => @media (min-width: 1024px) { ... }
679
+
680
+ xl: '1280px',
681
+ // => @media (min-width: 1280px) { ... }
682
+ },
683
+ };
684
+ ```
685
+
686
+ You can use any name you like as a breakpoint property in your project:
687
+
688
+ ```js
689
+ const designSystem = {
690
+ screens: {
691
+ tablet: '640px',
692
+ // => @media (min-width: 640px) { ... }
693
+
694
+ laptop: '1024px',
695
+ // => @media (min-width: 1024px) { ... }
696
+
697
+ desktop: '1280px',
698
+ // => @media (min-width: 1280px) { ... }
699
+ },
700
+ };
701
+ ```
702
+
703
+ These screen names are reflected in `utilities`, so `text-center` now looks like this:
704
+
705
+ ```css
706
+ .text-center { text-align: center }
707
+
708
+ @media (min-width: 640px) {
709
+ .tablet\:text-center { text-align: center }
710
+ }
711
+
712
+ @media (min-width: 1024px) {
713
+ .laptop\:text-center { text-align: center }
714
+ }
715
+
716
+ @media (min-width: 1280px) {
717
+ .desktop\:text-center { text-align: center }
718
+ }
719
+ ```
720
+
721
+ ##### Max-width breakpoint
722
+
723
+ If you want to use a `max-width` breakpoint instead of a `min-width`, you can specify the screen as an object with a `max` property:
724
+
725
+ ```js
726
+ const designSystem = {
727
+ screens: {
728
+ xl: { max: '1279px' },
729
+ // => @media (max-width: 1279px) { ... }
730
+
731
+ lg: { max: '1023px' },
732
+ // => @media (max-width: 1023px) { ... }
733
+
734
+ md: { max: '767px' },
735
+ // => @media (max-width: 767px) { ... }
736
+
737
+ sm: { max: '639px' },
738
+ // => @media (max-width: 639px) { ... }
739
+ },
740
+ };
741
+ ```
742
+
743
+ If necessary, to create breakpoints with `min-width` and `max-width` definitions, for example:
744
+
745
+ ```js
746
+ const designSystem = {
747
+ screens: {
748
+ sm: { min: '640px', max: '767px' },
749
+ md: { min: '768px', max: '1023px' },
750
+ lg: { min: '1024px', max: '1279px' },
751
+ xl: { min: '1280px' },
752
+ },
753
+ };
754
+ ```
755
+
756
+ ##### Multiple ranges of breakpoints
757
+
758
+ Sometimes it is useful to apply a single breakpoint definition to multiple scopes.
759
+
760
+ For example, let's say you have a `sidebar` and want the breakpoint to be based on the width of the content area rather than the entire viewport. You can simulate this situation, using a smaller breakpoint style when the `sidebar` is visible and shrinks the content area:
761
+
762
+ ```js
763
+ const designSystem = {
764
+ screens: {
765
+ sm: '500px',
766
+ md: [
767
+ // Sidebar appears at 768px, so revert to `sm:` styles between 768px
768
+ // and 868px, after which the main content area is wide enough again to
769
+ // apply the `md:` styles.
770
+ { min: '668px', max: '767px' },
771
+ { min: '868px' },
772
+ ],
773
+ lg: '1100px',
774
+ xl: '1400px',
775
+ },
776
+ };
777
+ ```
778
+
779
+ ##### Custom media queries
780
+
781
+ If you need to provide a fully customized media query for the breakpoint, you can use an object with a `raw` attribute:
782
+
783
+ ```js
784
+ const designSystem = {
785
+ extend: {
786
+ screens: {
787
+ portrait: { raw: '(orientation: portrait)' },
788
+ // => @media (orientation: portrait) { ... }
789
+ },
790
+ },
791
+ };
792
+ ```
793
+
794
+ ##### Print Style
795
+
796
+ The `raw` option can be especially useful if you need to apply a different style to the print.
797
+
798
+ All you need to do is add a `print` in `designSystem.extend.screens`:
799
+
800
+ ```js
801
+ const designSystem = {
802
+ extend: {
803
+ screens: {
804
+ print: { raw: 'print' },
805
+ // => @media print { ... }
806
+ },
807
+ },
808
+ };
809
+ ```
810
+
811
+ You can then use a class like `print:text-black` to specify styles that are only applied when someone tries to print a page:
812
+
813
+ ```html
814
+ <div class="text-gray-700 print:text-black">
815
+ <!-- ... -->
816
+ </div>
817
+ ```
818
+
819
+ ##### Dark Mode
820
+
821
+ The `raw` option can be used to implement the "dark mode" screen:
822
+
823
+ ```js
824
+ const designSystem = {
825
+ extend: {
826
+ screens: {
827
+ dark: { raw: '(prefers-color-scheme: dark)' },
828
+ // => @media (prefers-color-scheme: dark) { ... }
829
+ },
830
+ },
831
+ };
832
+ ```
833
+
834
+ You can then style the element differently in dark mode using the `dark:` prefix:
835
+
836
+ ```html
837
+ <div class="text-gray-700 dark:text-gray-200">
838
+ <!-- ... -->
839
+ </div>
840
+ ```
841
+
842
+ Note that since these `screen variants` are implemented in `Tailwind CSS`, ** you cannot use this method to combine breakpoints with dark modes **, for example `md:dark:text-gray-300` will not work.
843
+
844
+ #### Colors
845
+
846
+ The `colors` property allows you to customize the global palette of your project.
847
+
848
+ ```js
849
+ const designSystem = {
850
+ colors: {
851
+ transparent: 'transparent',
852
+ black: '#000',
853
+ white: '#fff',
854
+ gray: {
855
+ 100: '#f7fafc',
856
+ // ...
857
+ 900: '#1a202c',
858
+ },
859
+
860
+ // ...
861
+ },
862
+ };
863
+ ```
864
+
865
+ By default, these colors are inherited by the `backgroundColor`, `textColor`, and `borderColor` core plugins.
866
+
867
+
868
+ o learn more, see: [Customizing Colors](https://tailwindcss.com/docs/customizing-colors)。
869
+
870
+ #### Spacing
871
+
872
+ Using the `space` property, you can customize the global spacing and scaling of items:
873
+
874
+ ```js
875
+ const designSystem = {
876
+ spacing: {
877
+ px: '1px',
878
+ 0: '0',
879
+ 1: '0.25rem',
880
+ 2: '0.5rem',
881
+ 3: '0.75rem',
882
+ 4: '1rem',
883
+ 5: '1.25rem',
884
+ 6: '1.5rem',
885
+ 8: '2rem',
886
+ 10: '2.5rem',
887
+ 12: '3rem',
888
+ 16: '4rem',
889
+ 20: '5rem',
890
+ 24: '6rem',
891
+ 32: '8rem',
892
+ 40: '10rem',
893
+ 48: '12rem',
894
+ 56: '14rem',
895
+ 64: '16rem',
896
+ },
897
+ };
898
+ ```
899
+ By default, these values are inherited by the `padding`, `margin`, `negativeMargin`, `width`, and `height` core plugins.
900
+
901
+
902
+ To learn more, see: [Customizing Spacing](https://tailwindcss.com/docs/customizing-spacing)。
903
+
904
+ #### Core plugins
905
+
906
+ The rest of the topic section is used to configure the values available for each core plugin.
907
+
908
+ For example, the `borderRadius` property allows you to customize the `utilities` of the rounded corners that will be generated:
909
+
910
+ ```js
911
+ const designSystem = {
912
+ borderRadius: {
913
+ none: '0',
914
+ sm: '.125rem',
915
+ default: '.25rem',
916
+ lg: '.5rem',
917
+ full: '9999px',
918
+ },
919
+ };
920
+ ```
921
+
922
+ ** The property name determines the suffix of the generated class, and the value determines the value of the actual CSS declaration. ** The example `borderRadius` configuration above will generate the following CSS class:
923
+
924
+ ```css
925
+ .rounded-none { border-radius: 0 }
926
+ .rounded-sm { border-radius: .125rem }
927
+ .rounded { border-radius: .25rem }
928
+ .rounded-lg { border-radius: .5rem }
929
+ .rounded-full { border-radius: 9999px }
930
+ ```
931
+
932
+ You will notice that the `rounded` class is created without the suffix using the `default` property in the theme configuration. This is a common convention in Tailwind CSS supported by many, though not all, core plugins.
933
+
934
+
935
+ To learn more about customizing a specific core plugin, visit the plugin's documentation.
936
+
937
+ ### Custom default configuration
938
+
939
+ Out of the box, your project will automatically inherit values from the default theme configuration. If you want to customize the default theme, you have several different options depending on the target.
940
+
941
+ #### Override default configuration
942
+
943
+ To override the options in the default configuration, add the properties to override in `designSystem`:
944
+
945
+ ```typescript title="modern.config.ts"
946
+ const designSystem = {
947
+ // Replaces all of the default `opacity` values
948
+ opacity: {
949
+ 0: '0',
950
+ 20: '0.2',
951
+ 40: '0.4',
952
+ 60: '0.6',
953
+ 80: '0.8',
954
+ 100: '1',
955
+ },
956
+ };
957
+
958
+ export default defineConfig({
959
+ source: {
960
+ designSystem,
961
+ },
962
+ });
963
+ ```
964
+
965
+ This completely replaces the default property configuration, so in the example above, the default `opacity utilities` is not generated.
966
+
967
+ Any properties you don't provide will be inherited from the default theme, so in the example above, the default theme configuration for color, spacing, border rounded corners, background position, and more will be preserved.
968
+
969
+ #### Extension default configuration
970
+
971
+ If you want to keep the default value for the theme option, but want to add a new value, add the extended content in the `designSystem.extend` property.
972
+
973
+ For example, if you want to add an additional breakpoint but keep the existing one, you can extend the `screens` property:
974
+
975
+ ```typescript title="modern.config.ts"
976
+ const designSystem = {
977
+ extend: {
978
+ // Adds a new breakpoint in addition to the default breakpoints
979
+ screens: {
980
+ '2xl': '1440px',
981
+ },
982
+ },
983
+ };
984
+
985
+ export default defineConfig({
986
+ source: {
987
+ designSystem,
988
+ },
989
+ });
990
+ ```
991
+
992
+ You can of course override some parts of the default theme and extend other parts of the default theme in the same configuration:
993
+
994
+ ```typescript title="modern.config.ts"
995
+ const designSystem = {
996
+ opacity: {
997
+ 0: '0',
998
+ 20: '0.2',
999
+ 40: '0.4',
1000
+ 60: '0.6',
1001
+ 80: '0.8',
1002
+ 100: '1',
1003
+ },
1004
+ extend: {
1005
+ screens: {
1006
+ '2xl': '1440px',
1007
+ },
1008
+ },
1009
+ };
1010
+
1011
+ export default defineConfig({
1012
+ source: {
1013
+ designSystem,
1014
+ },
1015
+ });
1016
+ ```
1017
+
1018
+ #### Reference other values
1019
+
1020
+ If you need to reference another value in the configuration, you can do so by providing a closure function instead of a static value. The function will receive a `theme()` function as an argument, which you can use to look up other values in the configuration using dot notation.
1021
+
1022
+
1023
+ For example, you can generate a `fill` utility for each color in the palette by referencing `theme('colors')` on a `fill` configuration.
1024
+
1025
+ ```typescript title="modern.config.ts"
1026
+ const designSystem = {
1027
+ colors: {
1028
+ // ...
1029
+ },
1030
+ fill: theme => theme('colors'),
1031
+ };
1032
+
1033
+ export default defineConfig({
1034
+ source: {
1035
+ designSystem,
1036
+ },
1037
+ });
1038
+ ```
1039
+
1040
+ The `theme()` function tries to find the value you're looking for from a fully merged configuration object, so it can reference your own custom settings as well as default theme values. It also works recursively, so as long as there's a static value at the end of the chain, it can parse the value you're looking for.
1041
+
1042
+ **Reference default configuration**
1043
+
1044
+ If you want to reference a value in the default configuration for any reason, you can import it from `tailwindcss/defaultTheme`. A useful example is if you want to add one of the fonts provided by the default configuration:
1045
+
1046
+ ```typescript title="modern.config.ts"
1047
+ const defaultTheme = require('tailwindcss/defaultTheme');
1048
+
1049
+ const designSystem = {
1050
+ extend: {
1051
+ fontFamily: {
1052
+ sans: ['Lato', ...defaultTheme.fontFamily.sans],
1053
+ },
1054
+ },
1055
+ };
1056
+
1057
+ export default defineConfig({
1058
+ source: {
1059
+ designSystem,
1060
+ },
1061
+ });
1062
+ ```
1063
+
1064
+ #### Disable the entire core plugin
1065
+
1066
+ If you don't want to generate any classes for a core plugin, it's better to set the plugin to `false` in the `corePlugins` configuration instead of providing an empty object for this property in the configuration:
1067
+
1068
+ ```js
1069
+ // Don't assign an empty object in your theme configuration
1070
+
1071
+ const designSystem = {
1072
+ opacity: {},
1073
+ };
1074
+
1075
+ // Do disable the plugin in your corePlugins configuration
1076
+ const designSyttem = {
1077
+ corePlugins: {
1078
+ opacity: false,
1079
+ },
1080
+ };
1081
+ ```
1082
+
1083
+ The end result is the same, but since many core plugins don't expose any configuration, they can only be disabled using `corePlugins` anyway, and it's best to keep them consistent.
1084
+
1085
+ #### Add your own key
1086
+
1087
+ In many cases, it can be useful to add your own properties to the configuration object.
1088
+
1089
+ An example of this is adding new properties for reuse between multiple core plugins. For example, you can extract a `positions` object that both the `backgroundPosition` and `objectPosition` plugins can reference:
1090
+
1091
+ ```js
1092
+ const designSystem = {
1093
+ positions: {
1094
+ bottom: 'bottom',
1095
+ center: 'center',
1096
+ left: 'left',
1097
+ 'left-bottom': 'left bottom',
1098
+ 'left-top': 'left top',
1099
+ right: 'right',
1100
+ 'right-bottom': 'right bottom',
1101
+ 'right-top': 'right top',
1102
+ top: 'top',
1103
+ },
1104
+ backgroundPosition: theme => theme('positions'),
1105
+ objectPosition: theme => theme('positions'),
1106
+ };
1107
+ ```
1108
+
1109
+ Another example is adding new attributes to a custom plugin for reference. For example, if you wrote a gradual change plugin for a project, you can add a gradual change attribute to the subject object referenced by the plugin:
1110
+
1111
+ ```typescript title="modern.config.ts"
1112
+ const designSystem = {
1113
+ gradients: theme => ({
1114
+ 'blue-green': [theme('colors.blue.500'), theme('colors.green.500')],
1115
+ 'purple-blue': [theme('colors.purple.500'), theme('colors.blue.500')],
1116
+ // ...
1117
+ }),
1118
+ };
1119
+
1120
+ export default defineConfig({
1121
+ source: {
1122
+ designSystem,
1123
+ },
1124
+ tools: {
1125
+ tailwind: {
1126
+ plugins: [require('./plugins/gradients')],
1127
+ },
1128
+ },
1129
+ });
1130
+ ```
1131
+
1132
+ ### Configure reference
1133
+
1134
+ With the exception of `screens`, `colors`, and `spacing`, all properties in the configuration object map to the core plugin of `Tailwind CSS`. Since many plugins are responsible for accepting only CSS properties for static value sets (eg `float`), note that not every plugin has corresponding properties in the theme object.
1135
+
1136
+
1137
+ All of these properties can also be used in the `designSystem.extend` property to extend the default theme.
1138
+
1139
+ See this [link](https://tailwindcss.com/docs/theme#configuration-reference) for what all properties do.
1140
+
1141
+ ### Additional configuration
1142
+
1143
+ In addition to the same configuration as the Tailwind CSS Theme, there are additional configurations available Modern.js.
1144
+
1145
+ #### source.designSystem.supportStyledComponents
1146
+
1147
+ The configuration type is `boolean` and defaults to `false`.
1148
+
1149
+
1150
+ When the configuration value is `true`, the runtime provides the `styled-components` `ThemeProvider` component outside the application and will inject it through the `Theme Token` object generated by `designSystem`.