Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Install Prettier For Automatic Code Formatting (JS, HTML, & SCSS) #146

Merged
merged 11 commits into from
Jan 10, 2025
Merged
Show file tree
Hide file tree
Changes from 4 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
154 changes: 104 additions & 50 deletions .eslintrc.js
Original file line number Diff line number Diff line change
@@ -1,64 +1,118 @@
module.exports = {
'env': {
'browser': true,
'node': true,
'es2021': true,
env: {
browser: true,
node: true,
es2021: true,
},
'extends': [
'eslint:recommended',
'plugin:@typescript-eslint/eslint-recommended',
'plugin:@typescript-eslint/recommended',
'plugin:vue/recommended',
extends: [
"eslint:recommended",
"plugin:@typescript-eslint/eslint-recommended",
"plugin:@typescript-eslint/recommended",
"plugin:vue/recommended",
],
'parserOptions': {
"parser": "@typescript-eslint/parser",
"project": "./tsconfig.json",
'extraFileExtensions': [ '.vue' ]
parserOptions: {
parser: "@typescript-eslint/parser",
project: "./tsconfig.json",
extraFileExtensions: [".vue"],
},
'plugins': [
'vue',
],
'rules': {
'max-len': ['error', {
'code': 100,
// Fixes errors in HTML files with long links
'ignoreUrls': true,
}],
plugins: ["vue"],
rules: {
"max-len": [
"error",
{
code: 100,
// Fixes errors in HTML files with long links
ignoreUrls: true,
},
],

// Disable stylistic rules that interfere with Prettier
"vue/html-closing-bracket-newline": "off",
"vue/html-self-closing": "off",
"vue/max-attributes-per-line": "off",
"vue/singleline-html-element-content-newline": "off",
"vue/html-indent": "off",

'vue/multi-word-component-names': ['off'],
"vue/multi-word-component-names": ["off"],
// This rule is for Vue3, and Gridsome uses Vue2
'vue/no-deprecated-filter': ['off'],
"vue/no-deprecated-filter": ["off"],
// Don't make <g-link> multiline, it adds spaces
"vue/multiline-html-element-content-newline": ["error", {
"ignores": [
"g-link",
// Original inline elements from: https://github.com/vuejs/eslint-plugin-vue/blob/master/lib/utils/inline-non-void-elements.json
"a", "abbr", "audio", "b", "bdi", "bdo", "canvas", "cite", "code", "data", "del", "dfn", "em", "i", "iframe", "ins", "kbd", "label", "map", "mark", "noscript", "object", "output", "picture", "q", "ruby", "s", "samp", "small", "span", "strong", "sub", "sup", "svg", "time", "u", "var", "video"
],
}],
"vue/singleline-html-element-content-newline": ["error", {
"externalIgnores": ["g-link"]
}],
"vue/multiline-html-element-content-newline": [
"error",
{
ignores: [
"g-link",
// Original inline elements from: https://github.com/vuejs/eslint-plugin-vue/blob/master/lib/utils/inline-non-void-elements.json
"a",
"abbr",
"audio",
"b",
"bdi",
"bdo",
"canvas",
"cite",
"code",
"data",
"del",
"dfn",
"em",
"i",
"iframe",
"ins",
"kbd",
"label",
"map",
"mark",
"noscript",
"object",
"output",
"picture",
"q",
"ruby",
"s",
"samp",
"small",
"span",
"strong",
"sub",
"sup",
"svg",
"time",
"u",
"var",
"video",
],
},
],
"vue/singleline-html-element-content-newline": [
"error",
{
externalIgnores: ["g-link"],
},
],

'@typescript-eslint/indent': ['error', 2],
"semi": ["error", "always"],
"@typescript-eslint/indent": ["error", 2],
semi: ["error", "always"],
"arrow-parens": ["error", "always"],
"comma-dangle": ["error", "always-multiline"],

"@typescript-eslint/explicit-function-return-type": ["error", {
"allowExpressions": true,
"allowHigherOrderFunctions": true,
"allowTypedFunctionExpressions": true
}]
"@typescript-eslint/explicit-function-return-type": [
"error",
{
allowExpressions: true,
allowHigherOrderFunctions: true,
allowTypedFunctionExpressions: true,
},
],
},
'overrides': [
overrides: [
{
'files': ['*.vue', 'declarations/*.ts'],
'rules': {
'indent': 'off',
'@typescript-eslint/indent': 'off',
'@typescript-eslint/no-var-requires': 0,
}
}
]
files: ["*.vue", "declarations/*.ts"],
rules: {
indent: "off",
"@typescript-eslint/indent": "off",
"@typescript-eslint/no-var-requires": 0,
},
},
],
};
11 changes: 7 additions & 4 deletions .github/workflows/eslint.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,18 +3,18 @@
# More details at https://github.com/eslint/eslint
# and https://eslint.org

name: ESLint
name: ESLint & Prettier

on:
push:
branches: [ "main" ]
branches: ["main"]
pull_request:
# The branches below must be a subset of the branches above
branches: [ "main" ]
branches: ["main"]

jobs:
eslint:
name: Run ESLint scanning
name: Run ESLint & Prettier
runs-on: ubuntu-latest
permissions:
contents: read
Expand All @@ -36,6 +36,9 @@ jobs:
run: yarn lint-ci
continue-on-error: true

- name: Run Prettier
run: yarn prettier . --check

- name: Upload analysis results to GitHub
uses: github/codeql-action/upload-sarif@v2
with:
Expand Down
8 changes: 4 additions & 4 deletions .github/workflows/pytest.yml
Original file line number Diff line number Diff line change
Expand Up @@ -4,21 +4,21 @@ name: Pytest Data Tests

on:
push:
branches: [ "main" ]
branches: ["main"]
pull_request:
# The branches below must be a subset of the branches above
branches: [ "main" ]
branches: ["main"]

jobs:
pytest:
name: 'Pytest'
name: "Pytest"
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v4
with:
python-version: '3.9'
python-version: "3.9"
- name: Install dependencies
run: |
cd src/data
Expand Down
2 changes: 2 additions & 0 deletions .prettierignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
# Ignore built files
dist
1 change: 1 addition & 0 deletions .prettierrc
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
{}
28 changes: 14 additions & 14 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -72,7 +72,7 @@ docker-compose run --rm electrify-chicago yarn lint-fix
### Run Data Processing

1. If you update the raw data CSVs or the data scripts that post-process them (like if you are adding
a new statistical analysis), you need to re-run the data processing.
a new statistical analysis), you need to re-run the data processing.

2. To then process a new CSV file (at `src/data/source/ChicagoEnergyBenchmarking.csv`), you need to run the following command:

Expand All @@ -93,8 +93,9 @@ docker-compose run --rm electrify-chicago bash create_test_data.sh
```bash
docker-compose run --rm electrify-chicago python -m pytest
```

3. Run the following command for individual unit test suite (where YOUR_FILE_NAME is something like
`test_clean_all_years`):
`test_clean_all_years`):

```bash
docker-compose run --rm electrify-chicago python -m pytest tests/data/scripts/unit/YOUR_FILE_NAME.py
Expand All @@ -107,7 +108,7 @@ docker-compose run --rm electrify-chicago python -m pytest tests/data/scripts/un
If there's a new large building owner to add, simply:

1. **Add the building owner in the `BuildingOwners` constant** in `buildings-custom-info.constant.vue` -
this defines metadata about the owner like their name and logo URLs
this defines metadata about the owner like their name and logo URLs

Example:

Expand All @@ -122,8 +123,8 @@ iit: {
```

2. **Tag buildings they own in the `BuildingsCustomInfo` constant** (in the same
`buildings-custom-info.constant.vue` file) - this associates a given building (by its numeric unique
ID, found under its address on its details page), with a given owner.
`buildings-custom-info.constant.vue` file) - this associates a given building (by its numeric unique
ID, found under its address on its details page), with a given owner.

Example:

Expand All @@ -133,24 +134,24 @@ Example:
```

3. **Setup their route by adding the new owner's ID (key) to `BuildingOwnerIds`** (in
`gridsome.server.js`) - this tells Gridsome to create a route for this given slug
`gridsome.server.js`) - this tells Gridsome to create a route for this given slug

Example:

```ts
const BuildingOwnerIds = [
'iit',
"iit",
// ...
]
];
```

**Note:** You'll have to restart your `yarn develop` after step 3 to see changes, since
`gridsome.server.js` just runs once.

### Adding Building Images

1. **Find A Suitable Image* -- Building images can be sourced from Google Maps or a source that allows redistribution, like
Wikimedia.
1. \*_Find A Suitable Image_ -- Building images can be sourced from Google Maps or a source that allows redistribution, like
Wikimedia.

2 **Process the Image**

Expand All @@ -162,12 +163,11 @@ We should reasonably crop images if needed and then scale them to be EITHER:
Make sure to export it as a `.jpg` image at a quality level of 70, which should ensure a reasonable
file size under 200 kB.

**Store the image in `/static/building-imgs/`.
\*\*Store the image in `/static/building-imgs/`.

3. **Tell The Site There's a Building Image** - Follow the pattern of other buildings in the
`building-images.constant.vue`, providing an attribution URL, the image file name, and specify
whether it's a tall (portrait) image and whether it's from Google Maps.

`building-images.constant.vue`, providing an attribution URL, the image file name, and specify
whether it's a tall (portrait) image and whether it's from Google Maps.

4. **Confirm the image is visible and looks good** - and that's all there is to it!

Expand Down
2 changes: 1 addition & 1 deletion docker-compose.yml
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
version: '3.8'
version: "3.8"

services:
electrify-chicago:
Expand Down
34 changes: 16 additions & 18 deletions gridsome.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,56 +4,54 @@
// Changes here require a server restart.
// To restart press CTRL + C in terminal and run `gridsome develop`

const path = require('path');
const path = require("path");

/**
* A function that loads in all our global SCSS files
*
* @param {string} rule A rule?
*/
function addStyleResource(rule) {
rule.use('style-resource')
.loader('style-resources-loader')
.options({
patterns: [
path.resolve(__dirname, './src/scss/*.scss'),
],
});
rule
.use("style-resource")
.loader("style-resources-loader")
.options({
patterns: [path.resolve(__dirname, "./src/scss/*.scss")],
});
}


module.exports = {
siteName: 'Electrify Chicago',
siteName: "Electrify Chicago",
plugins: [
{
use: 'gridsome-plugin-typescript',
use: "gridsome-plugin-typescript",
},
],

templates: {
// Register building details path
Building: [
{
path: '/building/:slugSource',
component: './src/templates/BuildingDetails.vue',
path: "/building/:slugSource",
component: "./src/templates/BuildingDetails.vue",
},
{
// A path that redirects from a building ID to the canonical slug URL
name: 'building-id-redirect',
path: '/building-id/:ID',
component: './src/templates/BuildingIDRedirect.vue',
name: "building-id-redirect",
path: "/building-id/:ID",
component: "./src/templates/BuildingIDRedirect.vue",
},
],
},

// Ensure /scss folder is globally available
chainWebpack(config) {
// Load variables for all vue-files
const types = ['vue-modules', 'vue', 'normal-modules', 'normal'];
const types = ["vue-modules", "vue", "normal-modules", "normal"];

// or if you use scss
types.forEach((type) => {
addStyleResource(config.module.rule('scss').oneOf(type));
addStyleResource(config.module.rule("scss").oneOf(type));
});
},
};
Loading
Loading