Skip to content

Commit

Permalink
style: configure eslint
Browse files Browse the repository at this point in the history
  • Loading branch information
cwillisf committed Oct 17, 2023
1 parent c485bf6 commit 7b4176e
Show file tree
Hide file tree
Showing 7 changed files with 68 additions and 42 deletions.
11 changes: 11 additions & 0 deletions .editorconfig
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
root = true

[*]
end_of_line = lf
insert_final_newline = true
charset = utf-8
indent_size = 4
trim_trailing_whitespace = true

[*.js]
indent_style = space
2 changes: 2 additions & 0 deletions .eslintignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
dist/*
node_modules/*
3 changes: 3 additions & 0 deletions .eslintrc.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
module.exports = {
extends: ['scratch', 'scratch/node', 'scratch/es6']
};
4 changes: 3 additions & 1 deletion .github/workflows/ci-cd.yml
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,9 @@ jobs:
GitHub head ref: ${{ github.head_ref }}
EOF
- name: Setup
run: npm ci --legacy-peer-deps
run: npm ci
- name: Lint
run: npm run lint
- name: Setup Deploy
run: |
echo "export NPM_TAG=latest" >> $GITHUB_ENV
Expand Down
1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
"scripts": {
"build": "npm run clean && webpack --progress --bail",
"clean": "rimraf ./dist",
"lint": "eslint .",
"test": "npm run build",
"watch": "webpack --progress --watch"
},
Expand Down
7 changes: 7 additions & 0 deletions src/.eslintrc.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
module.exports = {
root: true,
extends: ['scratch', 'scratch/es6'],
env: {
browser: true
}
};
82 changes: 41 additions & 41 deletions src/index.js
Original file line number Diff line number Diff line change
@@ -1,41 +1,41 @@
// Synchronously load TTF fonts.
// First, have Webpack load their data as Base 64 strings.
let FONTS;

const getFonts = function () {
if (FONTS) return FONTS;
/* eslint-disable global-require */
FONTS = {
'Sans Serif': require('base64-loader!./NotoSans-Medium.ttf'),
'Serif': require('base64-loader!./SourceSerifPro-Regular.otf'),
'Handwriting': require('base64-loader!./handlee-regular.ttf'),
'Marker': require('base64-loader!./Knewave.ttf'),
'Curly': require('base64-loader!./Griffy-Regular.ttf'),
'Pixel': require('base64-loader!./Grand9K-Pixel.ttf'),
'Scratch': require('base64-loader!./Scratch.ttf')
};
/* eslint-enable global-require */

// For each Base 64 string,
// 1. Replace each with a usable @font-face tag that points to a Data URI.
// 2. Inject the font into a style on `document.body`, so measurements
// can be accurately taken in SvgRenderer._transformMeasurements.
for (const fontName in FONTS) {
const fontData = FONTS[fontName];
FONTS[fontName] = '@font-face {' +
`font-family: "${fontName}";src: url("data:application/x-font-ttf;charset=utf-8;base64,${fontData}");}`;
}

if (!document.getElementById('scratch-font-styles')) {
const documentStyleTag = document.createElement('style');
documentStyleTag.id = 'scratch-font-styles';
for (const fontName in FONTS) {
documentStyleTag.textContent += FONTS[fontName];
}
document.body.insertBefore(documentStyleTag, document.body.firstChild);
}

return FONTS;
}

module.exports = getFonts;
// Synchronously load TTF fonts.
// First, have Webpack load their data as Base 64 strings.
let FONTS;

const getFonts = function () {
if (FONTS) return FONTS;
/* eslint-disable global-require */
FONTS = {
'Sans Serif': require('base64-loader!./NotoSans-Medium.ttf'),
'Serif': require('base64-loader!./SourceSerifPro-Regular.otf'),
'Handwriting': require('base64-loader!./handlee-regular.ttf'),
'Marker': require('base64-loader!./Knewave.ttf'),
'Curly': require('base64-loader!./Griffy-Regular.ttf'),
'Pixel': require('base64-loader!./Grand9K-Pixel.ttf'),
'Scratch': require('base64-loader!./Scratch.ttf')
};
/* eslint-enable global-require */

// For each Base 64 string,
// 1. Replace each with a usable @font-face tag that points to a Data URI.
// 2. Inject the font into a style on `document.body`, so measurements
// can be accurately taken in SvgRenderer._transformMeasurements.
for (const fontName in FONTS) {
const fontData = FONTS[fontName];
FONTS[fontName] = '@font-face {' +
`font-family: "${fontName}";src: url("data:application/x-font-ttf;charset=utf-8;base64,${fontData}");}`;
}

if (!document.getElementById('scratch-font-styles')) {
const documentStyleTag = document.createElement('style');
documentStyleTag.id = 'scratch-font-styles';
for (const fontName in FONTS) {
documentStyleTag.textContent += FONTS[fontName];
}
document.body.insertBefore(documentStyleTag, document.body.firstChild);
}

return FONTS;
};

module.exports = getFonts;

0 comments on commit 7b4176e

Please sign in to comment.