提交 eb824626 编写于 作者: Q qiang

fix: postcss-uniapp-plugin support postcss8

上级 97eb491c
...@@ -29,7 +29,6 @@ ...@@ -29,7 +29,6 @@
"mkdirp": "^0.5.1", "mkdirp": "^0.5.1",
"module-alias": "^2.1.0", "module-alias": "^2.1.0",
"neo-async": "^2.6.1", "neo-async": "^2.6.1",
"postcss": "^7.0.7",
"postcss-import": "^12.0.1", "postcss-import": "^12.0.1",
"postcss-selector-parser": "^5.0.0", "postcss-selector-parser": "^5.0.0",
"postcss-value-parser": "^3.3.1", "postcss-value-parser": "^3.3.1",
...@@ -39,5 +38,8 @@ ...@@ -39,5 +38,8 @@
"wrap-loader": "^0.2.0", "wrap-loader": "^0.2.0",
"xregexp": "4.0.0" "xregexp": "4.0.0"
}, },
"peerDependencies": {
"postcss": ">=7"
},
"gitHead": "9e2d0f8e244724fcd64880316c57d837d1778cf8" "gitHead": "9e2d0f8e244724fcd64880316c57d837d1778cf8"
} }
...@@ -156,7 +156,7 @@ if (process.env.UNI_USING_V3) { ...@@ -156,7 +156,7 @@ if (process.env.UNI_USING_V3) {
* 转换 upx * 转换 upx
* 转换 px * 转换 px
*/ */
module.exports = postcss.plugin('postcss-uniapp-plugin', function (opts) { const fn = function (opts) {
opts = { opts = {
...defaultOpts, ...defaultOpts,
...opts ...opts
...@@ -265,5 +265,20 @@ if (process.env.UNI_USING_V3) { ...@@ -265,5 +265,20 @@ if (process.env.UNI_USING_V3) {
}) })
} }
} }
}) }
const version = Number(require('postcss/package.json').version.split('.')[0])
if (version < 8) {
module.exports = postcss.plugin('postcss-uniapp-plugin', fn)
} else {
module.exports = function (opts) {
return {
postcssPlugin: 'postcss-uniapp-plugin',
Once: fn(opts)
}
}
module.exports.postcss = true
}
} }
const postcss = require('postcss')
const selectorParser = require('postcss-selector-parser') const selectorParser = require('postcss-selector-parser')
const TAGS = Object.keys(require('@dcloudio/uni-cli-shared').tags) const TAGS = Object.keys(require('@dcloudio/uni-cli-shared').tags)
...@@ -14,34 +13,50 @@ const isInsideKeyframes = function (rule) { ...@@ -14,34 +13,50 @@ const isInsideKeyframes = function (rule) {
let rewriteUrl let rewriteUrl
module.exports = postcss.plugin('postcss-uniapp-plugin', function (opts) { function once (root) {
return function (root, result) { if (!rewriteUrl) {
if (!rewriteUrl) { rewriteUrl = require('@dcloudio/uni-cli-shared/lib/url-loader').rewriteUrl
rewriteUrl = require('@dcloudio/uni-cli-shared/lib/url-loader').rewriteUrl }
} rewriteUrl(root)
rewriteUrl(root)
root.walkRules(rule => {
root.walkRules(rule => { // Transform each rule here
// Transform each rule here if (!isInsideKeyframes(rule)) {
if (!isInsideKeyframes(rule)) { // rule.selectors == comma seperated selectors
// rule.selectors == comma seperated selectors // a, b.c {} => ["a", "b.c"]
// a, b.c {} => ["a", "b.c"] rule.selectors = rule.selectors.map(complexSelector =>
rule.selectors = rule.selectors.map(complexSelector => // complexSelector => simpleSelectors
// complexSelector => simpleSelectors // "a.b#c" => ["a", ".b", "#c"]
// "a.b#c" => ["a", ".b", "#c"] transformSelector(complexSelector, simpleSelectors => {
transformSelector(complexSelector, simpleSelectors => { // only process type selector, leave alone class & id selectors
// only process type selector, leave alone class & id selectors return simpleSelectors.walkTags(tag => {
return simpleSelectors.walkTags(tag => { if (tag.value === 'page') {
if (tag.value === 'page') { tag.value = 'body'
tag.value = 'body' } else if (~TAGS.indexOf(tag.value) && tag.value.substring(
} else if (~TAGS.indexOf(tag.value) && tag.value.substring( 0, 4) !== 'uni-') {
0, 4) !== 'uni-') { tag.value = 'uni-' + tag.value
tag.value = 'uni-' + tag.value }
}
})
}) })
) })
} )
}) }
})
}
const version = Number(require('postcss/package.json').version.split('.')[0])
if (version < 8) {
const postcss = require('postcss')
module.exports = postcss.plugin('postcss-uniapp-plugin', function (opts) {
return once
})
} else {
module.exports = function (opts) {
return {
postcssPlugin: 'postcss-uniapp-plugin',
Once: once
}
} }
})
module.exports.postcss = true
}
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册