mirror of
https://github.com/WeBankFinTech/fes.js.git
synced 2025-04-06 03:59:53 +08:00
feat: 添加枚举字典插件
This commit is contained in:
parent
f34fa069a4
commit
39ba4d89ee
@ -15,6 +15,7 @@ const headPkgs = [
|
|||||||
"fes-plugin-layout",
|
"fes-plugin-layout",
|
||||||
"fes-plugin-icon",
|
"fes-plugin-icon",
|
||||||
"fes-plugin-locale",
|
"fes-plugin-locale",
|
||||||
|
"fes-plugin-enums",
|
||||||
"create-fes-app"
|
"create-fes-app"
|
||||||
];
|
];
|
||||||
const tailPkgs = [];
|
const tailPkgs = [];
|
||||||
|
3
packages/fes-plugin-enums/.fatherrc.js
Normal file
3
packages/fes-plugin-enums/.fatherrc.js
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
export default {
|
||||||
|
disableTypeCheck: false,
|
||||||
|
};
|
21
packages/fes-plugin-enums/LICENSE
Normal file
21
packages/fes-plugin-enums/LICENSE
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
MIT License
|
||||||
|
|
||||||
|
Copyright (c) 2020-present webank
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
in the Software without restriction, including without limitation the rights
|
||||||
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
copies of the Software, and to permit persons to whom the Software is
|
||||||
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in all
|
||||||
|
copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
SOFTWARE.
|
2
packages/fes-plugin-enums/README.md
Normal file
2
packages/fes-plugin-enums/README.md
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
|
||||||
|
|
33
packages/fes-plugin-enums/package.json
Normal file
33
packages/fes-plugin-enums/package.json
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
{
|
||||||
|
"name": "@webank/fes-plugin-enums",
|
||||||
|
"version": "2.0.0-alpha.2",
|
||||||
|
"description": "@webank/fes-plugin-enums",
|
||||||
|
"main": "lib/index.js",
|
||||||
|
"files": [
|
||||||
|
"lib"
|
||||||
|
],
|
||||||
|
"scripts": {
|
||||||
|
"test": "echo \"Error: no test specified\" && exit 1"
|
||||||
|
},
|
||||||
|
"repository": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "git+https://github.com/WeBankFinTech/fes.js.git",
|
||||||
|
"directory": "packages/fes-plugin-enums"
|
||||||
|
},
|
||||||
|
"keywords": [
|
||||||
|
"fes"
|
||||||
|
],
|
||||||
|
"author": "aringlai",
|
||||||
|
"license": "MIT",
|
||||||
|
"bugs": {
|
||||||
|
"url": "https://github.com/WeBankFinTech/fes.js/issues"
|
||||||
|
},
|
||||||
|
"homepage": "https://github.com/WeBankFinTech/fes.js#readme",
|
||||||
|
"publishConfig": {
|
||||||
|
"access": "public"
|
||||||
|
},
|
||||||
|
"peerDependencies": {
|
||||||
|
"@webank/fes": "^2.0.0-alpha.0",
|
||||||
|
"vue": "^3.0.4"
|
||||||
|
}
|
||||||
|
}
|
48
packages/fes-plugin-enums/src/index.js
Normal file
48
packages/fes-plugin-enums/src/index.js
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
import { readFileSync } from 'fs';
|
||||||
|
import { join } from 'path';
|
||||||
|
|
||||||
|
const namespace = 'plugin-enums';
|
||||||
|
|
||||||
|
export default (api) => {
|
||||||
|
const {
|
||||||
|
utils: { Mustache }
|
||||||
|
} = api;
|
||||||
|
|
||||||
|
api.describe({
|
||||||
|
key: 'enums',
|
||||||
|
config: {
|
||||||
|
schema(joi) {
|
||||||
|
return joi.object();
|
||||||
|
},
|
||||||
|
onChange: api.ConfigChangeType.regenerateTmpFiles
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
const absoluteFilePath = join(namespace, 'core.js');
|
||||||
|
api.onGenerateFiles(() => {
|
||||||
|
// 文件写出
|
||||||
|
const enums = api.config.enums || {};
|
||||||
|
api.writeTmpFile({
|
||||||
|
path: absoluteFilePath,
|
||||||
|
content: Mustache.render(
|
||||||
|
readFileSync(join(__dirname, 'runtime/core.tpl'), 'utf-8'),
|
||||||
|
{
|
||||||
|
REPLACE_ENUMS: JSON.stringify(enums)
|
||||||
|
}
|
||||||
|
)
|
||||||
|
});
|
||||||
|
|
||||||
|
api.copyTmpFiles({
|
||||||
|
namespace,
|
||||||
|
path: join(__dirname, 'runtime'),
|
||||||
|
ignore: ['.tpl']
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
api.addPluginExports(() => [
|
||||||
|
{
|
||||||
|
specifiers: ['enums'],
|
||||||
|
source: absoluteFilePath
|
||||||
|
}
|
||||||
|
]);
|
||||||
|
};
|
119
packages/fes-plugin-enums/src/runtime/core.tpl
Normal file
119
packages/fes-plugin-enums/src/runtime/core.tpl
Normal file
@ -0,0 +1,119 @@
|
|||||||
|
// [[key, value]],默认配置格式
|
||||||
|
const _ENUMS = {{{REPLACE_ENUMS}}}
|
||||||
|
const ENUMS = {}
|
||||||
|
Object.keys(_ENUMS).forEach(key => {
|
||||||
|
ENUMS[key] = convert(key, _ENUMS[key])
|
||||||
|
})
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取枚举键值,如不传key,则返回name的枚举数组
|
||||||
|
* @param {string} name 枚举名称
|
||||||
|
* @param {string} key 枚举键名称
|
||||||
|
* @param {string} dir 枚举键值路径,默认value,格式如:value.propName、value.propName[0]
|
||||||
|
*/
|
||||||
|
function get(name, key, dir='value') {
|
||||||
|
let list = ENUMS[name] || []
|
||||||
|
if (key) {
|
||||||
|
let value = list.filter(item => item.key === key)[0]
|
||||||
|
if (!value) return key
|
||||||
|
return parseValueDir(value, dir)
|
||||||
|
} else {
|
||||||
|
return list
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 移除枚举
|
||||||
|
* @param {string} name 枚举名称
|
||||||
|
*/
|
||||||
|
function remove(name) {
|
||||||
|
delete ENUMS[name]
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 添加一个新的枚举,重复添加会覆盖
|
||||||
|
* @param {string} name 枚举名称
|
||||||
|
* @param {Array<Object|Array>} _enum 枚举数组,数组元素可以是数组或者对象
|
||||||
|
* @param {string} keyName 指定枚举键名称取值属性
|
||||||
|
* @param {string} valueName 指定枚举键值取值属性
|
||||||
|
*/
|
||||||
|
function push(name, _enum, keyName='key', valueName='value') {
|
||||||
|
if (ENUMS[name]) {
|
||||||
|
console.warn(`enums warn: the ${name}'s enum already exists, cover!`)
|
||||||
|
}
|
||||||
|
ENUMS[name] = convert(name, _enum, keyName, valueName)
|
||||||
|
return get(name)
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 根据dir解析value的属性值
|
||||||
|
* @param value
|
||||||
|
* @param dir
|
||||||
|
*/
|
||||||
|
function parseValueDir(value, dir='value') {
|
||||||
|
if (['object', 'function'].indexOf(typeof value) || !value || !dir) return value
|
||||||
|
if (dir.startsWith('[')) {
|
||||||
|
let key = dir.slice(1, dir.indexOf(']'))
|
||||||
|
return parseValueDir(value[key], dir.slice(dir.indexOf(']') + 1))
|
||||||
|
} else {
|
||||||
|
if (dir.startsWith('.')) {
|
||||||
|
dir = dir.slice(1)
|
||||||
|
}
|
||||||
|
let index = dir.indexOf('.')
|
||||||
|
let _index = dir.indexOf('[')
|
||||||
|
if (index === -1) index = dir.length
|
||||||
|
if (_index === -1) _index = dir.length
|
||||||
|
index = Math.min(index, _index)
|
||||||
|
let key = dir.slice(0, index)
|
||||||
|
return parseValueDir(value[key], dir.slice(index))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 转换传入的枚举数组
|
||||||
|
* @param {string} name 枚举名称
|
||||||
|
* @param {Array<Object|Array>} _enum 枚举数组,数组元素可以是数组或者对象
|
||||||
|
* @param {string} keyName 指定枚举键名称取值属性
|
||||||
|
* @param {string} valueName 指定枚举键值取值属性
|
||||||
|
*/
|
||||||
|
function convert(name, _enum, keyName='key', valueName='value') {
|
||||||
|
if (!name) {
|
||||||
|
throw new Error(`enums error: name must not be empty!`)
|
||||||
|
}
|
||||||
|
if (!Array.isArray(_enum)) {
|
||||||
|
throw new Error(`enums error: the ${name}'s enum must be array!`)
|
||||||
|
}
|
||||||
|
let list = []
|
||||||
|
_enum.forEach((item, index) => {
|
||||||
|
if (Array.isArray(item)) {
|
||||||
|
let _item = item[1]
|
||||||
|
if (Object.prototype.toString.call(_item) !== '[object Object]') {
|
||||||
|
_item = { value: _item }
|
||||||
|
}
|
||||||
|
_item.key = item[0]
|
||||||
|
list.push(_item)
|
||||||
|
} else if(Object.prototype.toString.call(item) === '[object Object]') {
|
||||||
|
list.push({
|
||||||
|
key: item[keyName],
|
||||||
|
value: item[valueName],
|
||||||
|
...item
|
||||||
|
})
|
||||||
|
} else {
|
||||||
|
console.log(`enums warn: the ${name}'s enum item[${index}] must be array or object!`)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
return list
|
||||||
|
}
|
||||||
|
|
||||||
|
const $data = new Proxy(ENUMS, {
|
||||||
|
get: function(target, key) {
|
||||||
|
return get(key)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
export const enums = {
|
||||||
|
get,
|
||||||
|
push,
|
||||||
|
remove,
|
||||||
|
$data
|
||||||
|
}
|
@ -27,5 +27,8 @@ export default {
|
|||||||
},
|
},
|
||||||
devServer: {
|
devServer: {
|
||||||
port: 8080
|
port: 8080
|
||||||
|
},
|
||||||
|
enums: {
|
||||||
|
status: [['1', '有效的'], ['0', '无效的']]
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -48,6 +48,7 @@
|
|||||||
"@webank/fes-plugin-layout": "^2.0.0-alpha.0",
|
"@webank/fes-plugin-layout": "^2.0.0-alpha.0",
|
||||||
"@webank/fes-plugin-locale": "^2.0.0-alpha.0",
|
"@webank/fes-plugin-locale": "^2.0.0-alpha.0",
|
||||||
"@webank/fes-plugin-model": "^2.0.0-alpha.0",
|
"@webank/fes-plugin-model": "^2.0.0-alpha.0",
|
||||||
|
"@webank/fes-plugin-enums": "^2.0.0-alpha.0",
|
||||||
"ant-design-vue": "2.0.0-rc.3",
|
"ant-design-vue": "2.0.0-rc.3",
|
||||||
"vue": "3.0.4"
|
"vue": "3.0.4"
|
||||||
},
|
},
|
||||||
|
@ -5,6 +5,11 @@
|
|||||||
<access :id="accessId"> accessOnepicess1 <input /> </access>
|
<access :id="accessId"> accessOnepicess1 <input /> </access>
|
||||||
<div v-access="accessId"> accessOnepicess2 <input /> </div>
|
<div v-access="accessId"> accessOnepicess2 <input /> </div>
|
||||||
<input />
|
<input />
|
||||||
|
<div>
|
||||||
|
<div>数据字典:</div>
|
||||||
|
<div v-for="item in status" :key="item.key">{{item.value}}-{{item.key}}</div>
|
||||||
|
<div v-for="item in coustomStatus" :key="item.key">{{item.value}}-{{item.key}}</div>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
<config>
|
<config>
|
||||||
@ -14,9 +19,9 @@
|
|||||||
}
|
}
|
||||||
</config>
|
</config>
|
||||||
<script>
|
<script>
|
||||||
import { ref, onMounted } from 'vue';
|
import { ref, onMounted, reactive } from 'vue';
|
||||||
import {
|
import {
|
||||||
access, useAccess, useRouter, useI18n, locale
|
access, useAccess, useRouter, useI18n, locale, enums
|
||||||
} from '@webank/fes';
|
} from '@webank/fes';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
@ -26,6 +31,9 @@ export default {
|
|||||||
const localI18n = useI18n();
|
const localI18n = useI18n();
|
||||||
const router = useRouter();
|
const router = useRouter();
|
||||||
const accessId = ref('/onepiece1');
|
const accessId = ref('/onepiece1');
|
||||||
|
const status = reactive(enums.$data.status);
|
||||||
|
enums.push('coustomStatus', [{ id: 1, desc: '是' }, { id: 1, desc: '否' }], 'id', 'desc');
|
||||||
|
const coustomStatus = reactive(enums.$data.coustomStatus);
|
||||||
onMounted(() => {
|
onMounted(() => {
|
||||||
console.log(router);
|
console.log(router);
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
@ -43,7 +51,9 @@ export default {
|
|||||||
accessId,
|
accessId,
|
||||||
fes,
|
fes,
|
||||||
accessOnepicess,
|
accessOnepicess,
|
||||||
t: localI18n.t
|
t: localI18n.t,
|
||||||
|
status,
|
||||||
|
coustomStatus
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
Loading…
x
Reference in New Issue
Block a user