uno.config.ts 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. import type {
  2. Preset,
  3. } from 'unocss'
  4. import { FileSystemIconLoader } from '@iconify/utils/lib/loader/node-loaders'
  5. // https://www.npmjs.com/package/@uni-helper/unocss-preset-uni
  6. import { presetUni } from '@uni-helper/unocss-preset-uni'
  7. // @see https://unocss.dev/presets/legacy-compat
  8. import { presetLegacyCompat } from '@unocss/preset-legacy-compat'
  9. import {
  10. defineConfig,
  11. presetAttributify,
  12. presetIcons,
  13. transformerDirectives,
  14. transformerVariantGroup,
  15. } from 'unocss'
  16. export default defineConfig({
  17. presets: [
  18. presetUni({
  19. attributify: false,
  20. }),
  21. presetIcons({
  22. scale: 1.2,
  23. warn: true,
  24. extraProperties: {
  25. 'display': 'inline-block',
  26. 'vertical-align': 'middle',
  27. },
  28. collections: {
  29. // 注册本地 SVG 图标集合, 从本地文件系统加载图标
  30. // 在 './src/static/my-icons' 目录下的所有 svg 文件将被注册为图标,
  31. // my-icons 是图标集合名称,使用 `i-my-icons-图标名` 调用
  32. 'my-icons': FileSystemIconLoader(
  33. './src/static/my-icons',
  34. // 可选的,你可以提供一个 transform 回调来更改每个图标
  35. (svg) => {
  36. let svgStr = svg
  37. // 如果 SVG 文件未定义 `fill` 属性,则默认填充 `currentColor`, 这样图标颜色会继承文本颜色,方便在不同场景下适配
  38. svgStr = svgStr.includes('fill="') ? svgStr : svgStr.replace(/^<svg /, '<svg fill="currentColor" ')
  39. // 如果 svg 有 width, 和 height 属性,将这些属性改为 1em,否则无法显示图标
  40. svgStr = svgStr.replace(/(<svg.*?width=)"(.*?)"/, '$1"1em"').replace(/(<svg.*?height=)"(.*?)"/, '$1"1em"')
  41. return svgStr
  42. },
  43. ),
  44. },
  45. }),
  46. // 支持css class属性化
  47. presetAttributify(),
  48. // TODO: check 是否会有别的影响
  49. // 处理低端安卓机的样式问题
  50. // 将颜色函数 (rgb()和hsl()) 从空格分隔转换为逗号分隔,更好的兼容性app端,example:
  51. // `rgb(255 0 0)` -> `rgb(255, 0, 0)`
  52. // `rgba(255 0 0 / 0.5)` -> `rgba(255, 0, 0, 0.5)`
  53. presetLegacyCompat({
  54. commaStyleColorFunction: true,
  55. }) as Preset,
  56. ],
  57. transformers: [
  58. // 启用指令功能:主要用于支持 @apply、@screen 和 theme() 等 CSS 指令
  59. transformerDirectives(),
  60. // 启用 () 分组功能
  61. // 支持css class组合,eg: `<div class="hover:(bg-gray-400 font-medium) font-(light mono)">测试 unocss</div>`
  62. transformerVariantGroup(),
  63. ],
  64. shortcuts: [
  65. {
  66. center: 'flex justify-center items-center',
  67. },
  68. ],
  69. // 动态图标需要在这里配置,或者写在vue页面中注释掉
  70. safelist: ['i-carbon-code', 'i-carbon-home', 'i-carbon-user'],
  71. rules: [
  72. [
  73. 'p-safe',
  74. {
  75. padding:
  76. 'env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)',
  77. },
  78. ],
  79. ['pt-safe', { 'padding-top': 'env(safe-area-inset-top)' }],
  80. ['pb-safe', { 'padding-bottom': 'env(safe-area-inset-bottom)' }],
  81. ],
  82. theme: {
  83. colors: {
  84. /** 主题色,用法如: text-primary */
  85. primary: 'var(--wot-color-theme,#0957DE)',
  86. },
  87. fontSize: {
  88. /** 提供更小号的字体,用法如:text-2xs */
  89. '2xs': ['20rpx', '28rpx'],
  90. '3xs': ['18rpx', '26rpx'],
  91. },
  92. },
  93. })