Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nextcloud-libraries/nextcloud-prettier-config
Shared stylistic rules for Nextcloud apps and libraries
https://github.com/nextcloud-libraries/nextcloud-prettier-config
codestyle nextcloud prettier
Last synced: about 1 month ago
JSON representation
Shared stylistic rules for Nextcloud apps and libraries
- Host: GitHub
- URL: https://github.com/nextcloud-libraries/nextcloud-prettier-config
- Owner: nextcloud-libraries
- License: other
- Created: 2024-01-30T14:12:28.000Z (12 months ago)
- Default Branch: main
- Last Pushed: 2024-01-30T15:10:13.000Z (12 months ago)
- Last Synced: 2024-01-31T15:55:45.338Z (12 months ago)
- Topics: codestyle, nextcloud, prettier
- Language: JavaScript
- Homepage:
- Size: 9.77 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Nextcloud Prettier configuration
[![REUSE status](https://api.reuse.software/badge/github.com/nextcloud-libraries/nextcloud-prettier-config)](https://api.reuse.software/info/github.com/nextcloud-libraries/nextcloud-prettier-config)
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.## Setup
### Prepare ESLint
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](https://github.com/prettier/eslint-config-prettier?tab=readme-ov-file#installation).In short, this should be your ESLint config:
```json
{
"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)_```json
"extends": [
"@nextcloud",
"prettier"
],
"overrides": [
{
"files": ["**/*.vue"],
"rules": {
"vue/first-attribute-linebreak": "off"
}
}
]
```### Prepare StyleLint
Stylelint already removed all stylistic rules, so make sure to use `@nextcloud/stylelint-config` **3+** together with `stylelint` 16+.
### Configure Prettier
Install this configuration using:
```shell
npm install --save-dev @nextcloud/prettier-config
```Either configure Prettier within your `package.json`:
```json
{
"name": "nextcloud-app",
"version": "1.33.7",
"prettier": "@nextcloud/prettier-config"
}
```Or in a dedicated `.prettierrc.json`:
```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:
```shell
# version control systems directories
**/.git
**/.svn
**/.hg# 3rdparty dependencies
**/node_modules
**/vendor# Compiled JS output
js/# PHP
lib/
**/*.php
```