-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathwebpack.mix.js
112 lines (109 loc) · 5.08 KB
/
webpack.mix.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
const mix = require('laravel-mix');
const SVGSpritemapPlugin = require('svg-spritemap-webpack-plugin');
const CopyWebpackPlugin = require('copy-webpack-plugin');
const ImageminPlugin = require('imagemin-webpack-plugin').default;
const imageminMozjpeg = require('imagemin-mozjpeg');
require('laravel-mix-webp');
require('laravel-mix-polyfill');
mix
// Обрабатываем JS
.js(
'resources/assets/js/main.js',
'public/assets/js'
)
// Используем полифиллы
.polyfill({
enabled: true,
useBuiltIns: "usage",
targets: false, // Используем настройки browserslist из package.json
debug: true,
corejs: '3.8',
})
// Преобразовываем SASS в CSS
.sass(
'resources/assets/scss/main.scss', // Путь относительно каталога с webpack.mix.js
'public/assets/css/' // Путь относительно каталога с webpack.mix.js
)
// Переопределяем параметры mix
.options({
processCssUrls: false, // Отключаем автоматическое обновление URL в CSS
postCss: [
// Добавляем вендорные префиксы в CSS
require('autoprefixer')({
cascade: false, // Отключаем выравнивание вендорных префиксов
}),
// Группируем стили по медиа-запросам
require('postcss-sort-media-queries'),
],
})
// Настраиваем webpack для обработки изображений
.webpackConfig({
plugins: [
// Создаем svg-спрайт с иконками
new SVGSpritemapPlugin(
'resources/assets/images/icons/*.svg', // Путь относительно каталога с webpack.mix.js
{
output: {
filename: 'assets/images/icons.svg', // Путь относительно каталога public/
svg4everybody: false, // Отключаем плагин "SVG for Everybody"
svg: {
sizes: false // Удаляем инлайновые размеры svg
},
chunk: {
keep: true, // Включаем, чтобы при сборке не было ошибок из-за отсутствия spritemap.js
},
svgo: {
plugins : [
{
'removeStyleElement': false // Удаляем из svg теги <style>
},
{
'removeAttrs': {
attrs: ["fill", "stroke"] // Удаляем часть атрибутов для управления стилями из CSS
}
},
]
},
},
sprite: {
prefix: 'icon-', // Префикс для id иконок в спрайте, будет иметь вид 'icon-имя_файла_с_иконкой'
generate: {
title: false, // Не добавляем в спрайт теги <title>
},
},
}
),
// Копируем картинки из каталога ресурсов в публичный каталог
new CopyWebpackPlugin({
patterns: [
{
from: 'resources/assets/images', // Путь относительно каталога с webpack.mix.js
to: 'assets/images', // Путь относительно каталога public/,
globOptions: {
ignore: ["**/icons/**"], // Игнорируем каталог с иконками
},
},
],
}),
// Оптимизируем качество изображений
new ImageminPlugin({
test: /\.(jpe?g|png|gif)$/i,
plugins: [
imageminMozjpeg({
quality: 80,
progressive: true,
}),
],
}),
],
})
// Создаем WEBP версии картинок
.ImageWebp({
from: 'resources/assets/images', // Путь относительно каталога с webpack.mix.js
to: 'public/assets/images', // Путь относительно каталога с webpack.mix.js
imageminWebpOptions: {
quality: 70
}
})
// Включаем версионность
.version();