Commit 878554991ee238921c8b83ed1fd21fbd36075c4c
Merge branch 'dev-ww' into 'main_dev'
fix: 修复teambition bug See merge request yunteng/thingskit-view!45
Showing
5 changed files
with
67 additions
and
10 deletions
| ... | ... | @@ -26,7 +26,7 @@ export const useFetchTargetData = () => { |
| 26 | 26 | } catch (error) { |
| 27 | 27 | loading.value = false |
| 28 | 28 | console.error(error); |
| 29 | - window['$message'].warning('数据异常,请检查参数!') | |
| 29 | + // window['$message'].warning('数据异常,请检查参数!') | |
| 30 | 30 | } |
| 31 | 31 | } |
| 32 | 32 | return { fetchTargetData, loading } | ... | ... |
src/utils/external/utils.ts
0 → 100644
| 1 | +import { excludeParseEventKeyList, excludeParseEventValueList } from "@/enums/eventEnum" | |
| 2 | + | |
| 3 | +const tryRunFunction = (v: string) => { | |
| 4 | + try { | |
| 5 | + return eval(`(function(){return ${v}})()`) | |
| 6 | + } catch (error) { | |
| 7 | + return v | |
| 8 | + } | |
| 9 | +} | |
| 10 | + | |
| 11 | +export const JSONParse = (data: string) => { | |
| 12 | + return JSON.parse(data, (k, v) => { | |
| 13 | + // 过滤函数字符串 | |
| 14 | + if (excludeParseEventKeyList.includes(k)) return v | |
| 15 | + // 过滤函数值表达式 | |
| 16 | + if (typeof v === 'string') { | |
| 17 | + const someValue = excludeParseEventValueList.some(excludeValue => v.indexOf(excludeValue) > -1) | |
| 18 | + if (someValue) return v | |
| 19 | + } | |
| 20 | + // 还原函数值 | |
| 21 | + if (typeof v === 'string' && v.indexOf && (v.indexOf('function') > -1 || v.indexOf('=>') > -1)) { | |
| 22 | + return tryRunFunction(v) | |
| 23 | + } else if (typeof v === 'string' && v.indexOf && v.indexOf('return ') > -1) { | |
| 24 | + const baseLeftIndex = v.indexOf('(') | |
| 25 | + if (baseLeftIndex > -1) { | |
| 26 | + const newFn = `function ${v.substring(baseLeftIndex)}` | |
| 27 | + return tryRunFunction(newFn) | |
| 28 | + } | |
| 29 | + } | |
| 30 | + return v | |
| 31 | + }) | |
| 32 | +} | ... | ... |
| ... | ... | @@ -12,6 +12,9 @@ import { RequestHttpIntervalEnum, RequestParamsObjType } from '@/enums/httpEnum' |
| 12 | 12 | import { CreateComponentType, CreateComponentGroupType } from '@/packages/index.d' |
| 13 | 13 | import { excludeParseEventKeyList, excludeParseEventValueList } from '@/enums/eventEnum' |
| 14 | 14 | |
| 15 | +/// THINGS_KIT 替换JSONParse解析 | |
| 16 | +export { JSONParse } from './external/utils' | |
| 17 | + | |
| 15 | 18 | /** |
| 16 | 19 | * * 判断是否是开发环境 |
| 17 | 20 | * @return { Boolean } |
| ... | ... | @@ -127,11 +130,11 @@ export const fileToUrl = (file: File): string => { |
| 127 | 130 | * * file转base64 |
| 128 | 131 | */ |
| 129 | 132 | export const fileTobase64 = (file: File, callback: Function) => { |
| 130 | - let reader = new FileReader() | |
| 133 | + const reader = new FileReader() | |
| 131 | 134 | reader.readAsDataURL(file) |
| 132 | 135 | reader.onload = function (e: ProgressEvent<FileReader>) { |
| 133 | 136 | if (e.target) { |
| 134 | - let base64 = e.target.result | |
| 137 | + const base64 = e.target.result | |
| 135 | 138 | callback(base64) |
| 136 | 139 | } |
| 137 | 140 | } |
| ... | ... | @@ -318,7 +321,8 @@ export const JSONStringify = <T>(data: T) => { |
| 318 | 321 | * * JSON反序列化,支持函数和 undefined |
| 319 | 322 | * @param data |
| 320 | 323 | */ |
| 321 | -export const JSONParse = (data: string) => { | |
| 324 | +/// THINGS_KIT 重命名 JSONParse 为 JSONParseOriginal | |
| 325 | +export const JSONParseOriginal = (data: string) => { | |
| 322 | 326 | return JSON.parse(data, (k, v) => { |
| 323 | 327 | // 过滤函数字符串 |
| 324 | 328 | if (excludeParseEventKeyList.includes(k)) return v |
| ... | ... | @@ -347,4 +351,4 @@ export const JSONParse = (data: string) => { |
| 347 | 351 | */ |
| 348 | 352 | export const setTitle = (title?: string) => { |
| 349 | 353 | title && (document.title = title) |
| 350 | -} | |
| \ No newline at end of file | ||
| 354 | +} | ... | ... |
| ... | ... | @@ -29,10 +29,7 @@ const designStore = useDesignStore() |
| 29 | 29 | * 修改后的代码 const selectedRequestType = ref(targetData.value.request.requestDataType || RequestDataTypeEnum.Pond) |
| 30 | 30 | * 修改后代码在//ft之间 |
| 31 | 31 | */ |
| 32 | - | |
| 33 | 32 | const selectedRequestType = ref(targetData.value.request.requestDataType || RequestDataTypeEnum.Pond) |
| 34 | -console.log(targetData.value.request.requestDataType) | |
| 35 | -//ft | |
| 36 | 33 | |
| 37 | 34 | const getApiRequestType: SelectOption[] = [ |
| 38 | 35 | { label: '自定义请求', value: RequestDataTypeEnum.AJAX }, |
| ... | ... | @@ -50,7 +47,10 @@ const { fetchTargetData, } = useFetchTargetData() |
| 50 | 47 | |
| 51 | 48 | // 发送请求 |
| 52 | 49 | const sendHandle = async () => { |
| 53 | - if (!targetData.value?.request) return | |
| 50 | + if (!targetData.value?.request || !targetData.value.request.requestUrl) { | |
| 51 | + window['$message'].warning('请先配置请求') | |
| 52 | + return | |
| 53 | + } | |
| 54 | 54 | loading.value = true |
| 55 | 55 | try { |
| 56 | 56 | const res = await fetchTargetData() | ... | ... |
| ... | ... | @@ -11,6 +11,9 @@ import { PublicInterfaceForm } from '../PublicInterfaceForm'; |
| 11 | 11 | import ComponentConfiguration from './ComponentConfiguration.vue'; |
| 12 | 12 | import GlobalPublicConfiguration from './GlobalPublicConfiguration.vue'; |
| 13 | 13 | import { createRequestModalContext } from './useRequestModalContext'; |
| 14 | +import { useTargetData } from '../../../../hooks/useTargetData.hook'; | |
| 15 | +import { useFetchTargetData } from '@/hooks/external/useFetchTargetData'; | |
| 16 | +import { useFilterFn } from '@/hooks/external/useFilterFn'; | |
| 14 | 17 | |
| 15 | 18 | |
| 16 | 19 | const requestDataType = ref<RequestDataTypeEnum>(RequestDataTypeEnum.AJAX) |
| ... | ... | @@ -67,9 +70,26 @@ const getResult = () => { |
| 67 | 70 | return {} as unknown as RequestConfigType |
| 68 | 71 | } |
| 69 | 72 | |
| 73 | +const { targetData } = useTargetData() | |
| 74 | +const { fetchTargetData } = useFetchTargetData() | |
| 75 | +// 发送请求 | |
| 76 | +const sendHandle = async () => { | |
| 77 | + if (!targetData.value?.request || !targetData.value.request.requestUrl) { | |
| 78 | + window['$message'].warning('请先配置请求') | |
| 79 | + return | |
| 80 | + } | |
| 81 | + const res = await fetchTargetData() | |
| 82 | + if (res) { | |
| 83 | + const { value } = useFilterFn(targetData.value.filter, res) | |
| 84 | + targetData.value.option.dataset = value | |
| 85 | + return | |
| 86 | + } | |
| 87 | + | |
| 88 | +} | |
| 89 | + | |
| 70 | 90 | const handleSaveAction = async () => { |
| 71 | 91 | if (!(await validate())) return |
| 72 | - const value = getResult() | |
| 92 | + const value = getResult() | |
| 73 | 93 | if (unref(selectTarget)) { |
| 74 | 94 | chartEditStore.updateComponentList(chartEditStore.fetchTargetIndex(), { |
| 75 | 95 | ...unref(selectTarget)!, |
| ... | ... | @@ -77,6 +97,7 @@ const handleSaveAction = async () => { |
| 77 | 97 | }) |
| 78 | 98 | } |
| 79 | 99 | showModal.value = false |
| 100 | + sendHandle() | |
| 80 | 101 | } |
| 81 | 102 | |
| 82 | 103 | createRequestModalContext({ | ... | ... |