Geen omschrijving

uno.config.ts 4.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. import type { Preset } from 'unocss'
  2. import { FileSystemIconLoader } from '@iconify/utils/lib/loader/node-loaders'
  3. // https://www.npmjs.com/package/@uni-helper/unocss-preset-uni
  4. import { presetUni } from '@uni-helper/unocss-preset-uni'
  5. // @see https://unocss.dev/presets/legacy-compat
  6. import { presetLegacyCompat } from '@unocss/preset-legacy-compat'
  7. import {
  8. defineConfig,
  9. presetIcons,
  10. transformerDirectives,
  11. transformerVariantGroup,
  12. } from 'unocss'
  13. export default defineConfig({
  14. presets: [
  15. presetUni({
  16. attributify: false,
  17. }),
  18. presetIcons({
  19. scale: 1.2,
  20. warn: true,
  21. extraProperties: {
  22. display: 'inline-block',
  23. 'vertical-align': 'middle',
  24. },
  25. collections: {
  26. // 注册本地 SVG 图标集合, 从本地文件系统加载图标
  27. // 在 './src/static/my-icons' 目录下的所有 svg 文件将被注册为图标,
  28. // my-icons 是图标集合名称,使用 `i-my-icons-图标名` 调用
  29. 'my-icons': FileSystemIconLoader(
  30. './src/static/my-icons',
  31. // 可选的,你可以提供一个 transform 回调来更改每个图标
  32. (svg) => {
  33. let svgStr = svg
  34. // 如果 SVG 文件未定义 `fill` 属性,则默认填充 `currentColor`, 这样图标颜色会继承文本颜色,方便在不同场景下适配
  35. svgStr = svgStr.includes('fill="')
  36. ? svgStr
  37. : svgStr.replace(/^<svg /, '<svg fill="currentColor" ')
  38. // 如果 svg 有 width, 和 height 属性,将这些属性改为 1em,否则无法显示图标
  39. svgStr = svgStr
  40. .replace(/(<svg.*?width=)"(.*?)"/, '$1"1em"')
  41. .replace(/(<svg.*?height=)"(.*?)"/, '$1"1em"')
  42. return svgStr
  43. }
  44. ),
  45. },
  46. }),
  47. // TODO: check 是否会有别的影响
  48. // 处理低端安卓机的样式问题
  49. // 将颜色函数 (rgb()和hsl()) 从空格分隔转换为逗号分隔,更好的兼容性app端,example:
  50. // `rgb(255 0 0)` -> `rgb(255, 0, 0)`
  51. // `rgba(255 0 0 / 0.5)` -> `rgba(255, 0, 0, 0.5)`
  52. presetLegacyCompat({
  53. commaStyleColorFunction: true,
  54. }) as Preset,
  55. ],
  56. transformers: [
  57. // 启用指令功能:主要用于支持 @apply、@screen 和 theme() 等 CSS 指令
  58. transformerDirectives(),
  59. // 启用 () 分组功能
  60. // 支持css class组合,eg: `<div class="hover:(bg-gray-400 font-medium) font-(light mono)">测试 unocss</div>`
  61. transformerVariantGroup(),
  62. ],
  63. shortcuts: [
  64. {
  65. center: 'flex justify-center items-center',
  66. },
  67. ],
  68. // 动态图标需要在这里配置,或者写在vue页面中注释掉
  69. safelist: [
  70. 'i-carbon-code',
  71. 'i-carbon-home',
  72. 'i-carbon-user',
  73. 'i-carbon-archive',
  74. 'i-carbon-SatelliteRadar',
  75. 'i-carbon-Notebook',
  76. 'i-carbon-FolderDetails',
  77. 'i-carbon-Analytics',
  78. 'i-carbon-Event'
  79. ],
  80. rules: [
  81. [
  82. 'p-safe',
  83. {
  84. padding:
  85. 'env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)',
  86. },
  87. ],
  88. ['pt-safe', { 'padding-top': 'env(safe-area-inset-top)' }],
  89. ['pb-safe', { 'padding-bottom': 'env(safe-area-inset-bottom)' }],
  90. ],
  91. theme: {
  92. colors: {
  93. /** 主题色,用法如: text-primary */
  94. primary: 'var(--wot-color-theme,#0957DE)',
  95. },
  96. fontSize: {
  97. /** 提供更小号的字体,用法如:text-2xs */
  98. '2xs': ['20rpx', '28rpx'],
  99. '3xs': ['18rpx', '26rpx'],
  100. },
  101. },
  102. // windows 系统会报错:[plugin:unocss:transformers:pre] Cannot overwrite a zero-length range - use append Left or prependRight instead.
  103. // 去掉下面的就正常了
  104. // content: {
  105. // /**
  106. // * 解决小程序报错 `./app.wxss(78:2814): unexpected unexpected at pos 5198`
  107. // * 为什么同时使用include和exclude?虽然看起来多余,但同时配置两者是一种常见的 `防御性编程` 做法。
  108. // 1. 结构变化保障 : 如果未来项目结构发生变化,某些排除目录可能被移动到包含路径下,exclude配置可以确保它们仍被排除
  109. // 2. 明确性 : 明确列出要排除的目录使配置意图更加清晰
  110. // 3. 性能优化 : 避免处理不必要的文件,提高构建性能
  111. // 4. 防止冲突 : 排除第三方库和构建输出目录,避免潜在的CSS冲突
  112. // */
  113. // pipeline: {
  114. // exclude: [
  115. // 'node_modules/**/*',
  116. // 'public/**/*',
  117. // 'dist/**/*',
  118. // ],
  119. // include: [
  120. // './src/**/*',
  121. // ],
  122. // },
  123. // },
  124. })