мой gulp file с настройками:
"use strict";
const {src, dest} = require("gulp");
const gulp = require("gulp");
const autoprefixer = require("gulp-autoprefixer");
const cssbeautify = require("gulp-cssbeautify");
const removeComments = require('gulp-strip-css-comments');
const rename = require("gulp-rename");
const sass = require("gulp-sass");
const cssnano = require("gulp-cssnano");
const uglify = require("gulp-uglify");
const plumber = require("gulp-plumber");
const panini = require("panini");
const imagemin = require("gulp-imagemin");
const del = require("del");
const notify = require("gulp-notify");
const webpack = require('webpack');
const webpackStream = require('webpack-stream');
const browserSync = require("browser-sync").create();
/* Paths */
const srcPath = 'src/';
const distPath = 'dist/';
const path = {
build: {
html: distPath,
js: distPath + "assets/js/",
css: distPath + "assets/css/",
images: distPath + "assets/images/",
fonts: distPath + "assets/fonts/"
},
src: {
html: srcPath + "*.html",
js: srcPath + "assets/js/*.js",
css: srcPath + "assets/scss/*.scss",
images: srcPath + "assets/images/**/*.{jpg,png,svg,gif,ico,webp,webmanifest,xml,json}",
fonts: srcPath + "assets/fonts/**/*.{eot,woff,woff2,ttf,svg}"
},
watch: {
html: srcPath + "**/*.html",
js: srcPath + "assets/js/**/*.js",
css: srcPath + "assets/scss/**/*.scss",
images: srcPath + "assets/images/**/*.{jpg,png,svg,gif,ico,webp,webmanifest,xml,json}",
fonts: srcPath + "assets/fonts/**/*.{eot,woff,woff2,ttf,svg}"
},
clean: "./" + distPath
}
/* Tasks */
function serve() {
browserSync.init({
server: {
baseDir: "./" + distPath
}
});
}
function html(cb) {
panini.refresh();
return src(path.src.html, {base: srcPath})
.pipe(plumber())
.pipe(panini({
root: srcPath,
layouts: srcPath + 'layouts/',
partials: srcPath + 'partials/',
helpers: srcPath + 'helpers/',
data: srcPath + 'data/'
}))
.pipe(dest(path.build.html))
.pipe(browserSync.reload({stream: true}));
cb();
}
function css(cb) {
return src(path.src.css, {base: srcPath + "assets/scss/"})
.pipe(plumber({
errorHandler : function(err) {
notify.onError({
title: "SCSS Error",
message: "Error: <%= error.message %>"
})(err);
this.emit('end');
}
}))
.pipe(sass({
includePaths: './node_modules/'
}))
.pipe(autoprefixer({
cascade: true
}))
.pipe(cssbeautify())
.pipe(dest(path.build.css))
.pipe(cssnano({
zindex: false,
discardComments: {
removeAll: true
}
}))
.pipe(removeComments())
.pipe(rename({
suffix: ".min",
extname: ".css"
}))
.pipe(dest(path.build.css))
.pipe(browserSync.reload({stream: true}));
cb();
}
function cssWatch(cb) {
return src(path.src.css, {base: srcPath + "assets/scss/"})
.pipe(plumber({
errorHandler : function(err) {
notify.onError({
title: "SCSS Error",
message: "Error: <%= error.message %>"
})(err);
this.emit('end');
}
}))
.pipe(sass({
includePaths: './node_modules/'
}))
.pipe(rename({
suffix: ".min",
extname: ".css"
}))
.pipe(dest(path.build.css))
.pipe(browserSync.reload({stream: true}));
cb();
}
function js(cb) {
return src(path.src.js, {base: srcPath + 'assets/js/'})
.pipe(plumber({
errorHandler : function(err) {
notify.onError({
title: "JS Error",
message: "Error: <%= error.message %>"
})(err);
this.emit('end');
}
}))
.pipe(webpackStream({
mode: "production",
output: {
filename: 'app.js',
},
module: {
rules: [
{
test: /\.(js)$/,
exclude: /(node_modules)/,
loader: 'babel-loader',
query: {
presets: ['@babel/preset-env']
}
}
]
}
}))
.pipe(dest(path.build.js))
.pipe(browserSync.reload({stream: true}));
cb();
}
function jsWatch(cb) {
return src(path.src.js, {base: srcPath + 'assets/js/'})
.pipe(plumber({
errorHandler : function(err) {
notify.onError({
title: "JS Error",
message: "Error: <%= error.message %>"
})(err);
this.emit('end');
}
}))
.pipe(webpackStream({
mode: "development",
output: {
filename: 'app.js',
}
}))
.pipe(dest(path.build.js))
.pipe(browserSync.reload({stream: true}));
cb();
}
function images(cb) {
return src(path.src.images)
.pipe(imagemin([
imagemin.gifsicle({interlaced: true}),
imagemin.mozjpeg({quality: 95, progressive: true}),
imagemin.optipng({optimizationLevel: 5}),
imagemin.svgo({
plugins: [
{ removeViewBox: true },
{ cleanupIDs: false }
]
})
]))
.pipe(dest(path.build.images))
.pipe(browserSync.reload({stream: true}));
cb();
}
function fonts(cb) {
return src(path.src.fonts)
.pipe(dest(path.build.fonts))
.pipe(browserSync.reload({stream: true}));
cb();
}
function clean(cb) {
return del(path.clean);
cb();
}
function watchFiles() {
gulp.watch([path.watch.html], html);
gulp.watch([path.watch.css], cssWatch);
gulp.watch([path.watch.js], jsWatch);
gulp.watch([path.watch.images], images);
gulp.watch([path.watch.fonts], fonts);
}
const build = gulp.series(clean, gulp.parallel(html, css, js, images, fonts));
const watch = gulp.parallel(build, watchFiles, serve);
/* Exports Tasks */
exports.html = html;
exports.css = css;
exports.js = js;
exports.images = images;
exports.fonts = fonts;
exports.clean = clean;
exports.build = build;
exports.watch = watch;
exports.default = watch;
package.json:
{
"name": "wafelt",
"version": "1.0.0",
"description": "wafelt",
"author": "wafelt",
"devDependencies": {
"@babel/core": "^7.12.3",
"@babel/preset-env": "^7.12.1",
"babel-core": "^6.26.3",
"babel-loader": "^8.2.1",
"babel-preset-env": "^1.7.0",
"browser-sync": "^2.26.13",
"del": "^6.0.0",
"gulp": "^4.0.2",
"gulp-autoprefixer": "^7.0.1",
"gulp-babel": "^8.0.0",
"gulp-cssbeautify": "^3.0.0",
"gulp-cssnano": "^2.1.3",
"gulp-imagemin": "^7.1.0",
"gulp-notify": "^3.2.0",
"gulp-plumber": "^1.2.1",
"gulp-rename": "^2.0.0",
"gulp-sass": "^4.1.0",
"gulp-strip-css-comments": "^2.0.0",
"gulp-uglify": "^3.0.2",
"panini": "^1.7.1",
"webpack": "^5.4.0",
"webpack-stream": "^6.1.0"
},
"browserslist": [
"last 1 version",
"> 1%",
"IE 10"
],
"dependencies": {
"inputmask": "^5.0.6",
"lint-staged": "^12.1.4",
"lozad": "^1.16.0",
"normalize.css": "^8.0.1",
"swiper": "^7.4.1"
}
}
Мне нужно чтобы css свойства получяли prefix, сейчас autoprefix не работает как это исправить?