uno.config.ts 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. // https://www.npmjs.com/package/@uni-helper/unocss-preset-uni
  2. import { presetUni } from '@uni-helper/unocss-preset-uni'
  3. import {
  4. defineConfig,
  5. presetAttributify,
  6. presetIcons,
  7. transformerDirectives,
  8. transformerVariantGroup,
  9. } from 'unocss'
  10. export default defineConfig({
  11. presets: [
  12. presetUni(),
  13. presetIcons({
  14. scale: 1.2,
  15. warn: true,
  16. extraProperties: {
  17. 'display': 'inline-block',
  18. 'vertical-align': 'middle',
  19. },
  20. }),
  21. // 支持css class属性化
  22. presetAttributify(),
  23. ],
  24. transformers: [
  25. // 启用指令功能:主要用于支持 @apply、@screen 和 theme() 等 CSS 指令
  26. transformerDirectives(),
  27. // 启用 () 分组功能
  28. // 支持css class组合,eg: `<div class="hover:(bg-gray-400 font-medium) font-(light mono)">测试 unocss</div>`
  29. transformerVariantGroup(),
  30. ],
  31. shortcuts: [
  32. {
  33. center: 'flex justify-center items-center',
  34. },
  35. ],
  36. // 动态图标需要在这里配置,或者写在vue页面中注释掉
  37. safelist: ['i-carbon-code'],
  38. rules: [
  39. [
  40. 'p-safe',
  41. {
  42. padding:
  43. 'env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)',
  44. },
  45. ],
  46. ['pt-safe', { 'padding-top': 'env(safe-area-inset-top)' }],
  47. ['pb-safe', { 'padding-bottom': 'env(safe-area-inset-bottom)' }],
  48. ],
  49. theme: {
  50. colors: {
  51. /** 主题色,用法如: text-primary */
  52. primary: 'var(--wot-color-theme,#0957DE)',
  53. },
  54. fontSize: {
  55. /** 提供更小号的字体,用法如:text-2xs */
  56. '2xs': ['20rpx', '28rpx'],
  57. '3xs': ['18rpx', '26rpx'],
  58. },
  59. },
  60. })