feat: switch to TypeScript, custom ESLint config, update deps

This commit is contained in:
Nex Zhu 2021-12-27 10:44:31 +08:00
parent bc6bc455d8
commit a7c776a85e
No known key found for this signature in database
GPG Key ID: 15C6254AD19362B4
18 changed files with 5655 additions and 12741 deletions

View File

@ -1,12 +1,11 @@
# http://editorconfig.org # http://editorconfig.org
root = true root = true
lib
[*] [*]
charset = utf-8 charset = utf-8
indent_style = space indent_style = space
indent_size = 4 indent_size = 2
end_of_line = lf end_of_line = lf
insert_final_newline = true insert_final_newline = true
trim_trailing_whitespace = true trim_trailing_whitespace = true

View File

@ -1,14 +1,21 @@
module.exports = { module.exports = {
extends: ['@webank/eslint-config-webank/vue.js'], root: true,
overrides: [ extends: ['@daotl/eslint-config-vue/typescript'],
{ parserOptions: {
files: [ project: 'tsconfig.json',
'**/__tests__/*.{j,t}s?(x)', },
'**/tests/unit/**/*.spec.{j,t}s?(x)' rules: {
] 'vue/multi-word-component-names': 'off',
} },
], overrides: [
env: { {
jest: true files: [
} '**/__tests__/*.{j,t}s?(x)',
}; '**/tests/unit/**/*.spec.{j,t}s?(x)',
],
env: {
jest: true,
},
},
],
}

52
.fes.js
View File

@ -1,26 +1,34 @@
// .fes.js 只负责管理编译时配置只能使用plain Object // .fes.js 只负责管理编译时配置只能使用plain Object
export default { export default {
publicPath: './', publicPath: './',
access: { // TODO: `alias` doesn't support TS for now
roles: { // alias: {
admin: ["*"], // '~': 'src',
manager: ["/"] // },
} access: {
roles: {
admin: ['*'],
manager: ['/'],
}, },
layout: { },
title: "Fes.js", layout: {
footer: 'Created by MumbleFe', title: 'Fes.js',
multiTabs: false, footer: 'Created by MumbleFe',
menus: [{ multiTabs: false,
name: 'index' menus: [
}] {
}, name: 'index',
devServer: { },
port: 8000 ],
}, },
enums: { devServer: {
status: [['0', '无效的'], ['1', '有效的']] port: 8000,
} },
}; enums: {
status: [
['0', '无效的'],
['1', '有效的'],
],
},
}

View File

@ -1,6 +1,5 @@
// .fes.js 只负责管理编译时配置只能使用plain Object // .fes.js 只负责管理编译时配置只能使用plain Object
export default { export default {
publicPath: '' publicPath: '',
}; }

View File

@ -1,4 +0,0 @@
{
"singleQuote": true,
"trailingComma": "none"
}

View File

@ -1,3 +1,3 @@
# fes-template # fes-starter
Template for [fes.js](https://github.com/WeBankFinTech/fes.js). A [fes.js](https://github.com/WeBankFinTech/fes.js) + TypeScript starter template.

18045
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -1,14 +1,19 @@
{ {
"name": "@fesjs/template", "name": "@daotl/fes-starter",
"version": "2.0.0", "version": "2.0.0",
"description": "fes项目模版", "description": "A fes.js + TypeScript starter template",
"scripts": { "scripts": {
"build": "fes build", "build": "fes build",
"prod": "FES_ENV=prod fes build", "prod": "FES_ENV=prod fes build",
"analyze": "ANALYZE=1 fes build", "analyze": "ANALYZE=1 fes build",
"dev": "fes dev", "dev": "fes dev",
"test:unit": "fes test:unit" "test:unit": "fes test:unit",
"lint": "npm run eslint && npm run stylelint",
"lint:fix": "npm run eslint:fix && npm run stylelint:fix",
"eslint": "npx eslint src/**/*.{js,ts,tsx,vue}",
"eslint:fix": "npx eslint src/**/*.{js,ts,tsx,vue} --fix"
}, },
"prettier": "@daotl/prettier-config",
"keywords": [ "keywords": [
"管理端", "管理端",
"fes", "fes",
@ -16,44 +21,32 @@
"easy", "easy",
"strong" "strong"
], ],
"files": [
".eslintrc.js",
".gitignore",
".fes.js",
".fes.prod.js",
"mock.js",
"package.json",
"README.md",
"tsconfig.json",
"/src",
"/config"
],
"repository": { "repository": {
"type": "git", "type": "git",
"url": "git+https://github.com/WeBankFinTech/fes.js.git", "url": "git+https://github.com/daotl/fes-starter.git"
"directory": "packages/fes-template"
}, },
"author": "harrywan", "author": "Nex Zhu <hitnexup@gmail.com>",
"license": "MIT", "license": "MIT",
"bugs": { "bugs": {
"url": "https://github.com/WeBankFinTech/fes.js/issues" "url": "https://github.com/daotl/fes-starter/issues"
}, },
"homepage": "https://github.com/WeBankFinTech/fes.js#readme", "homepage": "https://github.com/daotl/fes-starter#readme",
"publishConfig": { "publishConfig": {
"access": "public" "access": "public"
}, },
"devDependencies": { "devDependencies": {
"@vue/compiler-sfc": "^3.2.6", "@daotl/eslint-config-vue": "0.2.3",
"@webank/eslint-config-webank": "0.4.2" "@daotl/prettier-config": "^0.1.2",
"@daotl/tsconfig": "^0.0.4",
"@vue/compiler-sfc": "^3.2.26"
}, },
"dependencies": { "dependencies": {
"@fesjs/fes": "^2.0.0", "@fesjs/fes": "^2.0.11",
"@fesjs/plugin-access": "^2.0.0", "@fesjs/plugin-access": "^2.0.2",
"@fesjs/plugin-enums": "^2.0.0", "@fesjs/plugin-enums": "^2.0.2",
"@fesjs/plugin-layout": "^2.0.0", "@fesjs/plugin-layout": "^2.0.9",
"@fesjs/plugin-model": "^2.0.0", "@fesjs/plugin-model": "^2.0.3",
"ant-design-vue": "^2.2.0", "ant-design-vue": "^2.2.0",
"vue": "^3.2.6" "vue": "^3.2.6"
}, }
"private": true
} }

View File

@ -1,25 +0,0 @@
import { access } from '@fesjs/fes';
import PageLoading from '@/components/PageLoading';
import UserCenter from '@/components/UserCenter';
export const beforeRender = {
loading: <PageLoading />,
action() {
const { setRole } = access;
return new Promise((resolve) => {
setTimeout(() => {
setRole('admin');
// 初始化应用的全局状态,可以通过 useModel('@@initialState') 获取,具体用法看@/components/UserCenter 文件
resolve({
userName: 'harrywan'
});
}, 1000);
});
}
};
export const layout = {
customHeader: <UserCenter />
};

29
src/app.ts Normal file
View File

@ -0,0 +1,29 @@
import { access } from '@fesjs/fes'
import PageLoading from '@/components/PageLoading.vue'
import UserCenter from '@/components/UserCenter.vue'
export const beforeRender = {
loading: PageLoading,
action() {
const { setRole } = access
return new Promise((resolve) => {
setTimeout(() => {
void setRole('admin')
// 初始化应用的全局状态,可以通过 useModel('@@initialState') 获取,具体用法看@/components/UserCenter 文件
resolve(state)
}, 1000)
})
},
}
export type State = {
userName: string
}
const state: State = {
userName: 'harrywan',
}
export const layout = {
customHeader: UserCenter,
}

View File

@ -1,27 +1,23 @@
<template> <template>
<div class="page-loading"> <div class="page-loading">
<Spin size="large" /> <Spin size="large" />
</div> </div>
</template> </template>
<script>
import Spin from 'ant-design-vue/lib/spin';
import 'ant-design-vue/lib/spin/style/css';
export default { <script setup lang="ts">
components: { import Spin from 'ant-design-vue/lib/spin'
Spin import 'ant-design-vue/lib/spin/style/css'
}
};
</script> </script>
<style> <style>
.page-loading{ .page-loading {
position: fixed; position: fixed;
top: 0; top: 0;
left: 0; left: 0;
right: 0; right: 0;
bottom: 0; bottom: 0;
display: flex; display: flex;
align-items: center; align-items: center;
justify-content: center; justify-content: center;
} }
</style> </style>

View File

@ -1,21 +1,17 @@
<template> <template>
<div class="right">{{initialState.userName}}</div> <div class="right">{{ initialState.userName }}</div>
</template> </template>
<script>
import { useModel } from '@fesjs/fes';
export default { <script setup lang="ts">
setup() { import { useModel } from '@fesjs/fes'
const initialState = useModel('@@initialState'); import type { State } from '@/app'
return {
initialState const initialState = useModel('@@initialState') as State
};
}
};
</script> </script>
<style scope> <style scope>
.right { .right {
text-align: right; text-align: right;
padding: 0 20px; padding: 0 20px;
} }
</style> </style>

View File

@ -1,38 +1,29 @@
<template> <template>
<div style="padding: 32px;"> <div style="padding: 32px">
<h3>fes & 拉夫德鲁 </h3> <h3>fes & 拉夫德鲁</h3>
<h4>数据字典</h4> <h4>数据字典</h4>
<div v-for="item in enumsGet('status')" :key="item.key">{{item.value}}{{item.key}}</div> <div v-for="item in enumsGet('status')" :key="item.key">
{{ item.value }}{{ item.key }}
<section>
计数器
<button @click="increment">click me{{count}}</button>
</section>
</div> </div>
<section>
计数器
<button @click="increment">click me{{ count }}</button>
</section>
</div>
</template> </template>
<script> <script setup lang="ts">
import { ref } from 'vue'; import { ref } from 'vue'
import { import { enums } from '@fesjs/fes'
enums
} from '@fesjs/fes';
export default { const count = ref(0)
setup() {
const fes = ref('fes upgrade to vue3');
const count = ref(0);
const increment = () => {
count.value++;
};
return { const increment = () => {
fes, count.value++
increment, }
count,
enumsGet: enums.get const enumsGet = enums.get
};
}
};
</script> </script>
<config> <config>

6
src/types/shims.d.ts vendored Normal file
View File

@ -0,0 +1,6 @@
// shims.d.ts
declare module '*.vue' {
import { ComponentOptions } from 'vue'
const component: ComponentOptions
export default component
}

View File

@ -1,25 +1,13 @@
{ {
"extends": "@daotl/tsconfig/vue.json",
"compilerOptions": { "compilerOptions": {
"outDir": "build/dist", "outDir": "build/dist",
"module": "esnext",
"target": "esnext",
"lib": ["esnext", "dom"],
"sourceMap": true,
"baseUrl": ".", "baseUrl": ".",
"jsx": "preserve",
"allowSyntheticDefaultImports": true,
"moduleResolution": "node",
"forceConsistentCasingInFileNames": true,
"noImplicitReturns": true,
"suppressImplicitAnyIndexErrors": true,
"noUnusedLocals": true,
"allowJs": true,
"skipLibCheck": true,
"experimentalDecorators": true,
"strict": true,
"paths": { "paths": {
"@/*": ["./src/*"], // TODO: `.fes.js` > `alias` doesn't support TS for now
"@@/*": ["./src/.fes/*"] // "~/*": ["src/*"],
"@/*": ["src/*"],
"@@/*": ["src/.fes/*"]
} }
}, },
"include": [ "include": [
@ -33,5 +21,13 @@
".stylelintrc.js", ".stylelintrc.js",
".prettierrc.js" ".prettierrc.js"
], ],
"exclude": ["node_modules", "build", "dist", "scripts", "src/.fes/*", "webpack", "jest"] "exclude": [
"node_modules",
"build",
"dist",
"scripts",
"src/.fes/*",
"webpack",
"jest"
]
} }