Skip to content

massimo-cassandro/dev-boilerplate

Repository files navigation

Setup snippets

.browserslistrc

.browserslistrc:

echo "# https://github.com/browserslist/browserslist\n# https://browsersl.ist/\n\nlast 2 major versions\nsince 2023\nnot dead\n\nnot op_mini all\nnot op_mob > 0\nnot and_uc > 0\nnot and_qq > 0\nnot baidu > 0\nnot kaios > 0\nnot android > 0\nnot ie > 0\nnot ie_mob > 0\nnot bb > 0\n\nsafari >= 16\nios_saf >= 16\nedge >= 109\nchrome >= 109\nfirefox esr\nopera >= 95\nsamsung >= 20\n\n> 3% in IT\n" > .browserslistrc

.editorconfig

.editorconfig:

echo "# https://editorconfig.org\n\n# top-most EditorConfig file\nroot = true\n\n[*]\ncharset = utf-8\nend_of_line = lf\nindent_size = 2\nindent_style = space\ninsert_final_newline = true\ntrim_trailing_whitespace = true\n\n[*.md]\nmax_line_length = off\ntrim_trailing_whitespace = false\n\n[*.{yml,yaml}]\nindent_size = 4\n" > .editorconfig

.gitignore

.gitignore:

echo "*~\n.DS_Store\n**/*.mwb.bak\n**/*.mwb.beforefix\n\nnode_modules\nbower_components\nvendor\npackage-lock.json\ncomposer.lock\n\n.env\n.env.local\n.env.development\n.env.test\n.env.development.local\n.env.test.local\n.env.production.local\n\n*.sass-cache\n/@files-repo\n/@db-backup\n/pswd\n/**/.vscode/\n*.code-workspace\n*.sketch\n*.ai\n*.psd\n/progetto\n*TODO*.md\n\n\n" > .gitignore

css reset

dev-updater

npm i -D @massimo-cassandro/dev-updater

eslint9 (+ uninstall eslint8)

npm uninstall eslint @massimo-cassandro/eslint-config
npm i -D eslint@^9 @eslint/js globals && npm i -D @massimo-cassandro/eslint-config@^2

eslint.config.mjs:

echo "import eslint_config from '@massimo-cassandro/eslint-config';\n\nexport default [\n  ...eslint_config,\n  // {\n  //   files: ['src/**/*.js'],\n  //   ignores: [\n  //     'dist/',\n  //     'build/',\n  //     '**/vendor/'\n  //   ],\n  // }\n];\n" > eslint.config.mjs

jsconfig.json

jsconfig.json:

echo "{\n  \"compilerOptions\": {\n    \"target\": \"es2023\",\n    \"baseUrl\": \".\",\n    \"module\": \"ES6\",\n    \"allowSyntheticDefaultImports\": false,\n    \"paths\": {\n\n      \"@apps/*\": [\"./apps/*\"],\n      \"@js/*\": [\"./js/*\"],\n      \"@scss/*\": [\"./scss/*\"],\n      \"@src/*\": [\"./src/*\"]\n    }\n  },\n  \"exclude\": [\"node_modules\", \"dist\", \"docs\", \"build\"]\n}\n" > jsconfig.json

Local servers

  • "python server": "python3 -m http.server 8000 # --directory __dirname__ # 8000 = default port",
  • "php server": "php -S localhost:8000 # -t root_dir/",
  • "symfony local server": "symfony serve -d",

open-props + postcss-jit-props

npm i -S open-props && npm i -D postcss-jit-props

postcss + plugins (webpack)

npm i -D postcss autoprefixer postcss-custom-media @csstools/postcss-global-data

postcss.config.cjs:

echo "/* eslint-env node */\n\n// const path = require('path');\n\n\nconst isDevelopment = process.env.NODE_ENV === 'development';\n\nconst postcssConfig = {\n  plugins: [\n\n    require('@csstools/postcss-global-data')({\n      files: [\n        './node_modules/open-props/media.min.css',\n        './frontend/css/custom-properties.css',\n      ]\n    }),\n\n    // https://github.com/GoogleChromeLabs/postcss-jit-props\n    // https://github.com/argyleink/open-props\n    // require('postcss-jit-props')(require('open-props')),\n    require('postcss-jit-props')({\n      ...require('open-props'),\n      custom_selector: ':where(html)'\n    }),\n\n    // per IOS < 17 (test)\n    // https://github.com/csstools/postcss-plugins/tree/main/plugins/postcss-nesting\n    // https://github.com/csstools/postcss-plugins/tree/main/plugins/postcss-light-dark-function#readme\n    // require('postcss-nesting')({\n    //  edition: '2021',\n    //  noIsPseudoSelector: true\n    //}),\n    // require('@csstools/postcss-light-dark-function')({preserve: false}), /* NB non funziona benissimo... */\n\n    require('autoprefixer'),\n\n    // https://github.com/csstools/postcss-plugins/tree/main/plugins/postcss-custom-media\n    require('postcss-custom-media')({\n      preserve: isDevelopment\n    }),\n\n    // https://purgecss.com/configuration.html\n    // require('@fullhuman/postcss-purgecss')({\n    //   content: [\n    //     // './node_modules/@massimo-cassandro/**/.js',\n    //     './templates/**/*.html.twig',\n    //     './public/**/*.html',\n    //     './src/**/*.{js,jsx}',\n    //   ],\n    //   // css: ['./src/css/custom-properties-figma.css'],\n    //   // output: ['./AppBundle/Resources/public/css/'],\n    //   // variables: true,\n    //   // fontFace: true,\n    //   // keyframes: true,\n    //   safelist: {\n    //     standard: [/:focus$/],\n    //     // deep: [],\n    //     // greedy: [/yellow$/]\n    //   }\n    // }),\n\n  ]\n};\n\nif (process.env.NODE_ENV === 'production') {\n  postcssConfig.plugins.push(\n\n    // per IOS < 17\n    // require('postcss-nesting')({\n    //  edition: '2021',\n    //  noIsPseudoSelector: true\n    //}),\n    // require('@csstools/postcss-light-dark-function'), /* NB non funziona benissimo... */\n\n    // https://github.com/cssnano/cssnano\n    require('cssnano')({\n      // use the safe preset so that it doesn't\n      // mutate or remove code from our css\n      preset: 'default',\n    })\n  );\n}\n\nmodule.exports = postcssConfig;\n\n" > postcss.config.cjs

postcss cli

  • Per creare file css di test.
  • postcss-import è necessario per risolvere le importazioni da cli (con webpack non serve, l’operazione è svolta da css-loader)
  • [npx] postcss ./src/source.css -o ./test/test.css --no-map --verbose --env development --config ./ --use postcss-import --watch
npm i -D postcss-cli postcss-import

sass cli

npm i -D sass

sass per webpack

npm i -D sass-loader sass

stylelint

  • ## upd config file:
  • mv -f .stylelintrc.cjs stylelint.config.cjs
  • ## uunistall versione prec.:
  • npm uninstall @massimo-cassandro/stylelint-config stylelint stylelint-config-css-modules stylelint-config-twbs-bootstrap
npm i -D @stylistic/stylelint-plugin stylelint-config-css-modules stylelint-config-twbs-bootstrap stylelint && npm i -D @massimo-cassandro/stylelint-config

stylelint.config.cjs:

echo "/* eslint-env node */\n\nmodule.exports = {\n  extends: ['@massimo-cassandro/stylelint-config'],\n  ignoreFiles: ['node_modules/**/*.{css,scss}', 'dist/**/*.css', 'build/**/*.css', 'public/**/*.css', 'test/**/*.css'],\n\n  // tailwind\n  // 'rules': {\n  //   'value-keyword-case': null,\n  //   '@stylistic/number-no-trailing-zeros': null\n  // }\n};\n" > stylelint.config.cjs

webpack

  • Non include Postcss
  • "webpack DEV": "NODE_ENV=development webpack serve --config ./webpack.config.cjs #--open-app-name 'Google Chrome',
  • "webpack PROD": "NODE_ENV=production webpack --config ./webpack.config.cjs",
npm i -D @babel/core @babel/preset-env babel-loader copy-webpack-plugin css-loader css-minimizer-webpack-plugin dotenv-webpack file-loader html-loader html-webpack-plugin mini-css-extract-plugin mini-svg-data-uri postcss-loader postcss-preset-env style-loader terser-webpack-plugin @principalstudio/html-webpack-inject-preload && npm i -D webpack-cli webpack-dev-server webpack-manifest-plugin webpack-remove-empty-scripts webpack

auto-datatables-bs5

npm i -S @massimo-cassandro/auto-datatables-bs5

autocomplete

npm i -S @massimo-cassandro/autocomplete

bootstrap

npm i -S bootstrap

ckeditor-utilities

npm i -S @massimo-cassandro/ckeditor-utilities

cookie-consent

npm i -S @massimo-cassandro/cookie-consent

create-favicons

npm i -D @massimo-cassandro/create-favicons

eslint 8

npm i -D eslint@^8 && npm i -D @massimo-cassandro/eslint-config@^1

gulp per icone

  • "build_icons": "cd ./path/to/icone && gulp",
npm i -D gulp@latest gulp-concat gulp-dom gulp-flatmap gulp-inject-string gulp-rename gulp-replace gulp-svgmin gulp-svgstore gulp-wrap

gulp-jsbeautifier (aggiunta per icone react)

npm i -D gulp-jsbeautifier

gulp-wrap (aggiunta per icone react)

npm i -D gulp-wrap

html-react-parser

npm i -D html-react-parser

js-file-uploader

npm i -S @massimo-cassandro/js-file-uploader

js-utilities

npm i -S @massimo-cassandro/js-utilities

json-table

npm i -S @massimo-cassandro/json-table

layout-tools

npm i -D @massimo-cassandro/layout-tools

modal-alert

npm i -S @massimo-cassandro/modal-alert

normalize.css

npm i -S normalize.css

POSTCSS per supportare nuove funzionalità con browser meno recenti

  • Per utilizzare css nesting, light-dark() ecc. con IOS <= 16 e per le email (NB light-dark disabilitata di default
  • npm i -D @csstools/postcss-light-dark-function
npm i -D postcss-nesting

postcss-banner

npm i -D postcss-banner

prismjs

npm i -S prismjs

react (NB: richiede eslint 8)

npm i -D @babel/preset-react babel-plugin-transform-react-remove-prop-types eslint-config-react-app && npm i -D classnames nanoid prop-types && npm i -D react-dom react

React utilities

npm i -D classnames nanoid prop-types

react-html-comment

npm i -D react-html-comment

rollup base

  • "rollup": "npx rollup --config ./config/rollup.config.mjs --watch",
npm i -D rollup@latest @rollup/plugin-terser @rollup/plugin-node-resolve @rollup/plugin-json @rollup/plugin-image @rollup/plugin-replace @rollup/plugin-commonjs

rollup.config.mjs:

echo "import terser  from '@rollup/plugin-terser';\nimport fs from 'fs';\nimport node_resolve from '@rollup/plugin-node-resolve';\nimport commonjs from '@rollup/plugin-commonjs';\n\n// https://github.com/hyhappy/rollup-plugin-string-html\n// import htmlString from 'rollup-plugin-string-html';\n\n// https://github.com/exuanbo/rollup-plugin-minify-html-template-literals\n// https://github.com/asyncLiz/minify-html-literals\n// https://github.com/kangax/html-minifier#options-quick-reference\n// import minifyHTML from 'rollup-plugin-minify-html-template-literals';\n\nimport p from '../package.json'; // assert { type: 'json' };\n\nconst terserOptions = {\n    compress: {\n      passes: 2\n    }\n  },\n  anno = new Date().getFullYear(),\n  dirs = [\n    {source_dir: './front-end/js', output_dir: './AppBundle/Resources/public/js'}\n  ];\n\nlet config = [];\n\n// lettura subdir apps e aggiunta a `dirs`\nfs.readdirSync('./front-end/apps').forEach(item => {\n  let stats = fs.statSync(`./front-end/apps/${item}`); // stats.isFile() / stats.isDirectory()\n  if(stats.isDirectory()) {\n    dirs.push({\n      source_dir: `./front-end/apps/${item}`,\n      output_dir: `./AppBundle/Resources/public/apps/${item}`\n    });\n  }\n});\n\ndirs.forEach(dir => {\n\n  fs.readdirSync(dir.source_dir)\n    .filter(f => /\.js$/.test(f))\n    .filter(f => /^[^_]/.test(f)) // ignore files starting with _\n    .forEach(file => {\n\n      let format = 'iife',\n        name = null;\n\n      if(/(-umd\.js)$/.test(file)) {\n        format = 'umd';\n        name = file.replace('-umd.js', '').replace(/-/g, '_');\n      }\n\n      config.push(\n        {\n          // preserveEntrySignatures: false,\n          input: `${dir.source_dir}/${file}`,\n          plugins: [\n            // deve essere il primo\n            // minifyHTML({\n            //   options: {\n            //     minifyOptions: {\n            //       html5: true,\n            //       collapseWhitespace: true,\n            //       collapseInlineTagWhitespace: true,\n            //       conservativeCollapse: true,\n            //       decodeEntities: true\n            //     },\n            //     shouldMinify: () => true\n            //   },\n            // }),\n            node_resolve(),\n            commonjs(),\n            terser(terserOptions),\n          ],\n          output: [{\n            file: `${dir.output_dir}/${file.replace('.js', '-min.js')}`,\n            format: format,\n            sourcemap: true,\n            name: name,\n            banner: `/*! xxxx v.${p.version} - Massimo Cassandro ${anno} */`,\n            // footer: `//! Released on ${new Date().toLocaleString('it-IT', { year: 'numeric',  month: 'short', day: '2-digit', hour12: false, hour:'2-digit', minute:'2-digit' })}`\n          }]\n        }\n      );\n\n    });\n});\n\nexport default config;\n\n\n// versione statica\n\n// export default [\n//   {\n//     input: 'input.js',\n//     plugins: [\n//       node_resolve(),\n//       // commonjs(),\n//       terser({ compress: { passes: 2 } }),\n//     ],\n//     output: [\n//       {\n//         file: 'output.min.js',\n//         format: 'iife',\n//         sourcemap: true,\n\n//         banner: `/*! xxxx v.${p.version} - Massimo Cassandro ${anno} */`,\n//         // footer: `//! Released on ${new Date().toLocaleString('it-IT', { year: 'numeric',  month: 'short', day: '2-digit', hour12: false, hour:'2-digit', minute:'2-digit' })}`\n//       }\n//     ]\n//   },\n//   ...\n// ];\n" > rollup.config.mjs

rollup-plugin-string-html

npm i -D rollup-plugin-string-html

scss-utilities

npm i -S @massimo-cassandro/scss-utilities

sharing-links

npm i -S @massimo-cassandro/sharing-links

solid-js (webpack)

npm i -D solid-js babel-loader @babel/preset-env @babel/plugin-syntax-jsx babel-preset-solid

styled-components

npm i -D babel-plugin-styled-components styled-components

twig-utilities

npm i -S @massimo-cassandro/twig-utilities

typescript per react/webpack

npm i -D @types/react-dom @types/react ts-loader typescript-plugin-css-modules typescript

unsplash-page

npm i -S @massimo-cassandro/unsplash-page

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published