This provides a shared configuration for Nextcloud apps and libraries to have consistent stylistic rules. Using stylistic rules in linters is not recommended as linters are for finding bugs while prettier is for code style. Moreover ESLint and StyleLint both deprecate and remove stylistic rules, as a replacement using Prettier is recommended.
If you are using ESLint you should enable the eslint-config-prettier
configuration which disables all ESLint rules that conflict with Prettier.
A detailed description can be found here: github.com/prettier/eslint-config-prettier.
In short, this should be your ESLint config:
{
"extends": [
"@nextcloud",
"prettier" // < this needs to be the last one to override all previous
]
}
If you still get errors about Vue files, you need to adjust your ESLint config like the following: (this will be fixed once the Nextcloud ESLint config support flat configs)
"extends": [
"@nextcloud",
"prettier"
],
"overrides": [
{
"files": ["**/*.vue"],
"rules": {
"vue/first-attribute-linebreak": "off"
}
}
]
Stylelint already removed all stylistic rules, so make sure to use @nextcloud/stylelint-config
3+ together with stylelint
16+.
Install this configuration using:
npm install --save-dev @nextcloud/prettier-config
Either configure Prettier within your package.json
:
{
"name": "nextcloud-app",
"version": "1.33.7",
"prettier": "@nextcloud/prettier-config"
}
Or in a dedicated .prettierrc.json
:
"@nextcloud/prettier-config"
You should create a .prettierignore
file in your project root to allow simply using prettier .
or prettier --write .
, the format is very similar to .gitignore
. For a Nextcloud app the file could look like this:
# version control systems directories
**/.git
**/.svn
**/.hg
# 3rdparty dependencies
**/node_modules
**/vendor
# Compiled JS output
js/
# PHP
lib/
**/*.php