10 Commits

Author SHA1 Message Date
Kent C. Dodds
281993d1ca add npm-run-all --parallel 2019-08-14 11:59:53 -06:00
Kent C. Dodds
a1e30ee995 add lint-staged 2019-08-14 11:59:52 -06:00
Kent C. Dodds
cc6fdf9d84 add husky 2019-08-14 11:59:50 -06:00
Kent C. Dodds
a5d2d971dd add typescript 2019-08-14 11:59:13 -06:00
Kent C. Dodds
b41c948eeb prettier --list-different 2019-08-06 13:43:20 -06:00
Kent C. Dodds
a8d752b04f setup eslint-config-prettier 2019-08-06 13:43:19 -06:00
Kent C. Dodds
dda36098bd config prettier 2019-08-06 13:43:17 -06:00
Kent C. Dodds
945eaac136 install and run prettier 2019-08-06 13:43:16 -06:00
Kent C. Dodds
df642497e9 scripting eslint 2019-08-06 13:43:15 -06:00
Kent C. Dodds
8fb12ded93 eslint extends 2019-08-06 13:43:11 -06:00
9 changed files with 1729 additions and 193 deletions

View File

@@ -1,18 +1,23 @@
{ {
"parser": "@typescript-eslint/parser",
"parserOptions": { "parserOptions": {
"ecmaVersion": 2019, "ecmaVersion": 2019,
"sourceType": "module", "sourceType": "module",
"ecmaFeatures": { "ecmaFeatures": {
"jsx": true "jsx": true
} },
"project": "./tsconfig.json"
}, },
"plugins": ["@typescript-eslint/eslint-plugin"],
"extends": [
"eslint:recommended",
"plugin:@typescript-eslint/eslint-recommended",
"plugin:@typescript-eslint/recommended",
"eslint-config-prettier",
"eslint-config-prettier/@typescript-eslint"
],
"rules": { "rules": {
"strict": ["error", "never"], "strict": ["error", "never"]
"valid-typeof": "error",
"no-unsafe-negation": "error",
"no-unused-vars": "error",
"no-unexpected-multiline": "error",
"no-undef": "error"
}, },
"env": { "env": {
"browser": true "browser": true

5
.huskyrc Normal file
View File

@@ -0,0 +1,5 @@
{
"hooks": {
"pre-commit": "npm run check-types && lint-staged"
}
}

9
.lintstagedrc Normal file
View File

@@ -0,0 +1,9 @@
{
"*.js": [
"eslint"
],
"*.+(js|json|ts)": [
"prettier --write",
"git add"
]
}

17
.prettierrc Normal file
View File

@@ -0,0 +1,17 @@
{
"arrowParens": "avoid",
"bracketSpacing": false,
"htmlWhitespaceSensitivity": "css",
"insertPragma": false,
"jsxBracketSameLine": false,
"jsxSingleQuote": false,
"printWidth": 80,
"proseWrap": "always",
"quoteProps": "as-needed",
"requirePragma": false,
"semi": false,
"singleQuote": true,
"tabWidth": 2,
"trailingComma": "all",
"useTabs": false
}

1814
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@@ -4,12 +4,26 @@
"author": "Kent C. Dodds (http://kentcdodds.com/)", "author": "Kent C. Dodds (http://kentcdodds.com/)",
"license": "GPLv3", "license": "GPLv3",
"scripts": { "scripts": {
"build": "babel src --out-dir dist" "build": "babel src --out-dir dist",
"lint": "eslint --ignore-path .gitignore --ext .js,.ts,.tsx .",
"check-types": "tsc",
"prettier": "prettier --ignore-path .gitignore --write \"**/*.+(js|json)\"",
"format": "npm run prettier -- --write",
"check-format": "npm run prettier -- --list-different",
"validate": "npm-run-all --parallel check-types check-format lint build"
}, },
"devDependencies": { "devDependencies": {
"@babel/cli": "^7.5.5", "@babel/cli": "^7.5.5",
"@babel/core": "^7.5.5", "@babel/core": "^7.5.5",
"@babel/preset-env": "^7.5.5", "@babel/preset-env": "^7.5.5",
"eslint": "^6.1.0" "@typescript-eslint/eslint-plugin": "^2.0.0",
"@typescript-eslint/parser": "^2.0.0",
"eslint": "^6.1.0",
"eslint-config-prettier": "^6.0.0",
"husky": "^3.0.2",
"lint-staged": "^9.2.1",
"npm-run-all": "^4.1.5",
"prettier": "^1.18.2",
"typescript": "^3.5.3"
} }
} }

View File

@@ -1,12 +1,10 @@
'use strict'
const username = 'freddy' const username = 'freddy'
typeof username === 'strng' typeof username === 'string'
if (!'serviceWorker' in navigator) { if (!('serviceWorker' in navigator)) {
// you have an old browser :-( // you have an old browser :-(
} }
const greeting = 'hello' const greeting = 'hello'
console.log('${greeting} world!') console.log(`${greeting} world!`)
[1, 2, 3].forEach(x => console.log(x)) ;[1, 2, 3].forEach(x => console.log(x))

21
src/typescript-example.ts Normal file
View File

@@ -0,0 +1,21 @@
function add(a: number, b: number): number {
return a + b
}
interface User {
name: {
first: string
middle: string
last: string
}
}
function getFullName(user: User): string {
const {
name: {first, middle, last},
} = user
return [first, middle, last].filter(Boolean).join('')
}
add(1, 2)
getFullName({name: {first: 'Joe', middle: 'Bud', last: 'Matthews'}})

9
tsconfig.json Normal file
View File

@@ -0,0 +1,9 @@
{
"compilerOptions": {
// because we're compiling with Babel instead of TypeScript
// and we're only using TypeScript for type checking, we'll set "noEmit"
// to true so running type checking doesn't generate any files.
"noEmit": true,
"baseUrl": "./src"
}
}