1 | 'use strict'
|
2 |
|
3 | const path = require('path')
|
4 | const autoprefixer = require('autoprefixer')
|
5 | const ExtractTextPlugin = require('extract-text-webpack-plugin')
|
6 | const config = require('../../config')
|
7 | const maraConf = require(config.paths.marauder)
|
8 | const shouldUseRelativeAssetPaths = maraConf.publicPath === './'
|
9 |
|
10 | const postcssPlugin = [
|
11 | require('postcss-flexbugs-fixes'),
|
12 | autoprefixer(config.postcss)
|
13 | ]
|
14 |
|
15 |
|
16 | const postcssPluginAdvanced = [
|
17 |
|
18 |
|
19 |
|
20 | require('postcss-import')(),
|
21 |
|
22 | require('postcss-url')(),
|
23 | require('postcss-preset-env')(config.postcss),
|
24 | ...postcssPlugin
|
25 | ]
|
26 |
|
27 |
|
28 |
|
29 | function wrapLoader(options, loaders) {
|
30 | if (!options.extract) {
|
31 | return [
|
32 | {
|
33 | loader: 'vue-style-loader',
|
34 | options: {
|
35 |
|
36 | sourceMap: options.sourceMap
|
37 | }
|
38 | }
|
39 | ].concat(loaders)
|
40 | }
|
41 |
|
42 | const assets = options.library ? '' : `${config.assetsDir}/css`
|
43 |
|
44 | const cssFilename = maraConf.hash
|
45 | ? path.posix.join(assets, '[name].[contenthash:8].css')
|
46 | : path.posix.join(assets, '[name].min.css')
|
47 |
|
48 |
|
49 |
|
50 |
|
51 |
|
52 | const extractTextPluginOptions = shouldUseRelativeAssetPaths
|
53 | ?
|
54 | { publicPath: Array(cssFilename.split('/').length).join('../') }
|
55 | : {}
|
56 |
|
57 | return ExtractTextPlugin.extract(
|
58 | Object.assign(
|
59 | {
|
60 | use: loaders,
|
61 | fallback: 'vue-style-loader'
|
62 | },
|
63 | extractTextPluginOptions
|
64 | )
|
65 | )
|
66 | }
|
67 |
|
68 |
|
69 |
|
70 |
|
71 |
|
72 |
|
73 | function cssLoaders(options = {}) {
|
74 |
|
75 | function generateLoaders(loader, loaderOptions) {
|
76 | let loaders = [
|
77 | {
|
78 | loader: 'css-loader',
|
79 | options: {
|
80 | importLoaders: loader ? 2 : 1,
|
81 |
|
82 | sourceMap: options.sourceMap
|
83 | }
|
84 | }
|
85 | ]
|
86 | const postcssLoader = {
|
87 | loader: 'postcss-loader',
|
88 | options: {
|
89 | plugins: loader ? postcssPlugin : postcssPluginAdvanced,
|
90 | sourceMap: options.sourceMap
|
91 | }
|
92 | }
|
93 |
|
94 |
|
95 |
|
96 | if (!options.vue) {
|
97 | loaders.push(postcssLoader)
|
98 | }
|
99 |
|
100 |
|
101 |
|
102 |
|
103 | if (loader) {
|
104 | loaders.push({
|
105 | loader: loader + '-loader',
|
106 | options: Object.assign({}, loaderOptions, {
|
107 | sourceMap: options.sourceMap
|
108 | })
|
109 | })
|
110 | }
|
111 |
|
112 | return wrapLoader(options, loaders)
|
113 | }
|
114 |
|
115 |
|
116 | return {
|
117 | css: generateLoaders(),
|
118 | less: generateLoaders('less'),
|
119 | sass: generateLoaders('sass', { indentedSyntax: true }),
|
120 | scss: generateLoaders('sass')
|
121 | }
|
122 | }
|
123 |
|
124 |
|
125 | function styleLoaders(options) {
|
126 | const loaders = cssLoaders(options)
|
127 |
|
128 | return Object.keys(loaders).map(ext => ({
|
129 | test: new RegExp('\\.' + ext + '$'),
|
130 | use: loaders[ext]
|
131 | }))
|
132 | }
|
133 |
|
134 | module.exports = {
|
135 | cssLoaders,
|
136 | styleLoaders,
|
137 | postcssPlugin
|
138 | }
|