uno.config.ts 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. import type {
  2. Preset,
  3. } from 'unocss'
  4. // https://www.npmjs.com/package/@uni-helper/unocss-preset-uni
  5. import { presetUni } from '@uni-helper/unocss-preset-uni'
  6. // @see https://unocss.dev/presets/legacy-compat
  7. import { presetLegacyCompat } from '@unocss/preset-legacy-compat'
  8. import {
  9. defineConfig,
  10. presetAttributify,
  11. presetIcons,
  12. transformerDirectives,
  13. transformerVariantGroup,
  14. } from 'unocss'
  15. export default defineConfig({
  16. presets: [
  17. presetUni({
  18. attributify: false,
  19. }),
  20. presetIcons({
  21. scale: 1.2,
  22. warn: true,
  23. extraProperties: {
  24. 'display': 'inline-block',
  25. 'vertical-align': 'middle',
  26. },
  27. }),
  28. // 支持css class属性化
  29. presetAttributify(),
  30. // TODO: check 是否会有别的影响
  31. // 处理低端安卓机的样式问题
  32. // 将颜色函数 (rgb()和hsl()) 从空格分隔转换为逗号分隔,更好的兼容性app端,example:
  33. // `rgb(255 0 0)` -> `rgb(255, 0, 0)`
  34. // `rgba(255 0 0 / 0.5)` -> `rgba(255, 0, 0, 0.5)`
  35. presetLegacyCompat({
  36. commaStyleColorFunction: true,
  37. }) as Preset,
  38. ],
  39. transformers: [
  40. // 启用指令功能:主要用于支持 @apply、@screen 和 theme() 等 CSS 指令
  41. transformerDirectives(),
  42. // 启用 () 分组功能
  43. // 支持css class组合,eg: `<div class="hover:(bg-gray-400 font-medium) font-(light mono)">测试 unocss</div>`
  44. transformerVariantGroup(),
  45. ],
  46. shortcuts: [
  47. {
  48. center: 'flex justify-center items-center',
  49. },
  50. ],
  51. // 动态图标需要在这里配置,或者写在vue页面中注释掉
  52. safelist: ['i-carbon-code'],
  53. rules: [
  54. [
  55. 'p-safe',
  56. {
  57. padding:
  58. 'env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)',
  59. },
  60. ],
  61. ['pt-safe', { 'padding-top': 'env(safe-area-inset-top)' }],
  62. ['pb-safe', { 'padding-bottom': 'env(safe-area-inset-bottom)' }],
  63. ],
  64. theme: {
  65. colors: {
  66. /** 主题色,用法如: text-primary */
  67. primary: 'var(--wot-color-theme,#0957DE)',
  68. },
  69. fontSize: {
  70. /** 提供更小号的字体,用法如:text-2xs */
  71. '2xs': ['20rpx', '28rpx'],
  72. '3xs': ['18rpx', '26rpx'],
  73. },
  74. },
  75. })