@utogether/udp-core 1.0.4 → 2.0.0-beta.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{403-DASI6Pwz.js → 403-DjXGcxpa.js} +3 -3
- package/dist/{404-YhBA92cb.js → 404-B_MSn6FQ.js} +1 -1
- package/dist/{500-ywbFF5MX.js → 500-CtI21E9g.js} +2 -2
- package/dist/{AuthorityInfo-tCSX2Fh7.js → AuthorityInfo-CYhRUS8K.js} +1 -1
- package/dist/{AuthorityInfo.vue_vue_type_style_index_0_lang-Cwd6UT2i.js → AuthorityInfo.vue_vue_type_style_index_0_lang-BY8hkJ2R.js} +2 -2
- package/dist/{AuthorityPanel-BeBNiwqc.js → AuthorityPanel-CRlAwbaI.js} +1 -1
- package/dist/{AuthorityPanel.vue_vue_type_style_index_0_lang-CIYmnP9-.js → AuthorityPanel.vue_vue_type_style_index_0_lang-DxhZjp1S.js} +31 -24
- package/dist/{Company-l23MEzdM.js → Company-BVH3Zyy0.js} +3 -3
- package/dist/{CompanyPanel-D_s0rh6h.js → CompanyPanel-BKx3WVgS.js} +1 -1
- package/dist/{Department-DSEvORLg.js → Department-BZcr0_eu.js} +3 -3
- package/dist/{DepartmentPanel-WN8nOgCV.js → DepartmentPanel-BZNV3WaF.js} +3 -3
- package/dist/{DesignPanel-DirEGh9M.js → DesignPanel-7gr0Fljt.js} +1 -1
- package/dist/{DesignPanel.vue_vue_type_style_index_0_lang-D02hXSrN.js → DesignPanel.vue_vue_type_style_index_0_lang-By9HKa8W.js} +3 -3
- package/dist/{DictView-DiIQdiek.js → DictView-B0dRdinW.js} +20 -19
- package/dist/{InvOrganization-b7v3g9EJ.js → InvOrganization-CwTNjj-a.js} +2 -2
- package/dist/{Org-BORfx1PL.js → Org-D59oQ0VY.js} +2 -2
- package/dist/{Preview-DkRn_TSc.js → Preview-sbZrWUWr.js} +1 -1
- package/dist/{ReportDefine-Cd0QeaWA.js → ReportDefine-C7CZ6RSh.js} +1 -1
- package/dist/{ReportDesign-4qNqyeEW.js → ReportDesign-CuevdD_6.js} +3 -3
- package/dist/{ReportQuery-BJfTFpec.js → ReportQuery-BndhM0Ji.js} +1 -1
- package/dist/{ReportQueryFrom-CB7sExZx.js → ReportQueryFrom-n2k7BNX9.js} +1 -1
- package/dist/{ReportQueryFrom.vue_vue_type_style_index_0_lang-CqO_2Ier.js → ReportQueryFrom.vue_vue_type_style_index_0_lang-CFtXbzOb.js} +1 -1
- package/dist/{ReportTemplate-B69muSgT.js → ReportTemplate-43Rx_knT.js} +1 -1
- package/dist/{Role-Bo4YrNDC.js → Role-BS2QH_H8.js} +3 -3
- package/dist/{RoleAssign-kOMYJ4s3.js → RoleAssign-C6wMcgfW.js} +3 -3
- package/dist/{RolePanel-BSJmjyqc.js → RolePanel-BwyuGmJw.js} +1 -1
- package/dist/{RolePanel-B1d4e6uk.js → RolePanel-DJop6xpJ.js} +1 -1
- package/dist/{RolePanel.vue_vue_type_script_setup_true_lang-DgQpfjaU.js → RolePanel.vue_vue_type_script_setup_true_lang-CSkU6fAb.js} +3 -3
- package/dist/{RolePanel.vue_vue_type_script_setup_true_lang-DCzX-ZP_.js → RolePanel.vue_vue_type_script_setup_true_lang-Cf0BCtgL.js} +2 -2
- package/dist/{ScrollPanel.vue_vue_type_style_index_0_lang-WNOYFxJ1.js → ScrollPanel.vue_vue_type_style_index_0_lang-BZY0JkpB.js} +32 -31
- package/dist/Staff-DI6eAVQs.js +26 -0
- package/dist/{StaffInfo-DcU9_40C.js → StaffInfo-BQhMyQ7u.js} +1 -1
- package/dist/{StaffInfo.vue_vue_type_script_setup_true_lang-CtfN2CAr.js → StaffInfo.vue_vue_type_script_setup_true_lang-D79C6rw0.js} +9 -9
- package/dist/{StaffPanel-7exWkZd9.js → StaffPanel-By5elrj9.js} +1 -1
- package/dist/StaffPanel.vue_vue_type_script_setup_true_lang-DtbIZdcq.js +154 -0
- package/dist/{SysUser-B3uB_cp2.js → SysUser-DNYitHEW.js} +2 -2
- package/dist/{SysUserPanel-B0CLp5AO.js → SysUserPanel-_WDSXjfT.js} +1 -1
- package/dist/{SysUserPanel.vue_vue_type_script_setup_true_lang-Cwea_4dY.js → SysUserPanel.vue_vue_type_script_setup_true_lang-BFhIa5Gs.js} +126 -111
- package/dist/{SystemMenu-a59l4hTk.js → SystemMenu-C_H0bTA7.js} +52 -49
- package/dist/{UserInfo-D1IA2oLt.js → UserInfo-Bx25xdkh.js} +1 -1
- package/dist/{UserInfo.vue_vue_type_style_index_0_lang-DDVgYRD5.js → UserInfo.vue_vue_type_style_index_0_lang-B6FE4Epn.js} +2 -2
- package/dist/await-to-js.es5-Bv3Eu4mi.js +10 -0
- package/dist/{childView-6rCeLcsx.js → childView-CiKCAXKS.js} +1 -1
- package/dist/{childView-JdrkroL5.js → childView-WAzRvHLp.js} +1 -1
- package/dist/{childView.vue_vue_type_style_index_0_lang-B8x99f1B.js → childView.vue_vue_type_style_index_0_lang-3n_-DrRj.js} +2 -2
- package/dist/{childView.vue_vue_type_style_index_0_lang-BfcnWnx9.js → childView.vue_vue_type_style_index_0_lang-Bz4630fS.js} +26 -20
- package/dist/{code-rule-2lkPF547.js → code-rule-BehFVVOx.js} +2 -2
- package/dist/core.es.js +1 -1
- package/dist/{cron-task-DV1pGO1m.js → cron-task-C0-R_b64.js} +2 -2
- package/dist/{frameView-C0bzSB8c.js → frameView-4E2U2LM3.js} +1 -1
- package/dist/index-BvU3LB8R.js +7275 -0
- package/dist/layout-home-DJywZo1E.js +232 -0
- package/dist/{layoutView-CTV-E4Cj.js → layoutView-JGsVdXXu.js} +148 -149
- package/dist/{log-in-CoBP2x6u.js → log-in-l4FpOtBL.js} +2 -2
- package/dist/{log-out-KX8FiRVf.js → log-out-Cij2dkih.js} +2 -2
- package/dist/{login-CtCoGWzD.js → login-D4hfm7ZW.js} +124 -134
- package/dist/{login-log-DJBGJVV0.js → login-log-BEHYT0v0.js} +5 -5
- package/dist/{lov-view-Bm0JEzzg.js → lov-view-CpJedb5y.js} +3 -3
- package/dist/{menuInfo-D2qPoRwz.js → menuInfo-ClhT8lVG.js} +1 -1
- package/dist/{menuInfo.vue_vue_type_style_index_0_lang-DoQjX9Ly.js → menuInfo.vue_vue_type_style_index_0_lang-VuKVlyhc.js} +38 -36
- package/dist/{pda-app-SbcIclbH.js → pda-app-D_w1bNyU.js} +2 -2
- package/dist/{resource-Cdq1UKGI.js → resource-BxTwBnU4.js} +1 -1
- package/dist/su-welcome-BLNjs5WE.js +42181 -0
- package/dist/{sys-config-CCOf4xbj.js → sys-config-C0RJg9l1.js} +2 -2
- package/dist/udp-core.css +1 -1
- package/package.json +5 -2
- package/src/App.vue +37 -31
- package/src/components/SuScrollTree/ScrollPanel.vue +176 -170
- package/src/components/udp/content/index.vue +88 -88
- package/src/components/udp/form-upload/form-upload.vue +496 -0
- package/src/components/udp/grid/index.vue +524 -524
- package/src/components/udp/index.ts +6 -5
- package/src/components/udp/ut-stamp-badge/index.vue +271 -271
- package/src/components/udp/utils.ts +8 -2
- package/src/layout/components/lay-content/index.vue +4 -11
- package/src/layout/components/lay-search/components/SearchModal.vue +181 -189
- package/src/layout/components/lay-setting/index.vue +503 -503
- package/src/layout/components/lay-sidebar/sidebar-logo.vue +101 -101
- package/src/layout/components/lay-tag/index.vue +598 -598
- package/src/layout/hooks/useNav.ts +176 -176
- package/src/layout/hooks/useTag.ts +227 -227
- package/src/layout/layoutView.vue +216 -215
- package/src/layout/types.ts +93 -93
- package/src/main.ts +111 -115
- package/src/plugins/i18n/zh.ts +19 -3
- package/src/plugins/vxe-table/render.tsx +60 -15
- package/src/router/index.ts +187 -187
- package/src/router/modules/home.ts +32 -32
- package/src/router/utils.ts +420 -420
- package/src/store/modules/epTheme.ts +48 -48
- package/src/style/vxetable.scss +18 -2
- package/src/utils/dataFormat/index.ts +222 -222
- package/src/utils/lifecycle.ts +39 -39
- package/src/views/organization/department/DepartmentPanel.vue +303 -303
- package/src/views/organization/staff/Staff.vue +59 -58
- package/src/views/organization/staff/StaffInfo.vue +3 -2
- package/src/views/organization/staff/StaffPanel.vue +13 -1
- package/src/views/system/layout/layout-home.vue +238 -0
- package/src/views/system/menu/AuthorityPanel.vue +10 -9
- package/src/views/system/menu/SystemMenu.vue +194 -185
- package/src/views/system/menu/menuInfo.vue +384 -384
- package/src/views/system/sysUser/SysUserPanel.vue +363 -347
- package/src/views/udev/coderule/code-rule.vue +132 -132
- package/src/views/udev/dict/DictView.vue +4 -4
- package/src/views/udev/dict/childView.vue +6 -4
- package/src/views/udev/lov/childView.vue +174 -174
- package/src/views/ufile/aggregation/File.vue +85 -87
- package/src/views/uhome/components/common-menu.vue +118 -0
- package/src/views/uhome/components/dynamic-component.vue +66 -0
- package/src/views/uhome/components/home-todo.vue +175 -0
- package/src/views/uhome/components/menu-favorite.vue +315 -315
- package/src/views/uhome/dynamic-card.vue +31 -0
- package/src/views/uhome/su-welcome.vue +47 -114
- package/src/views/ulogin/login.vue +336 -325
- package/src/views/upms/interface/log-in.vue +100 -100
- package/src/views/upms/interface/log-out.vue +104 -104
- package/src/views/upms/user/login-log.vue +54 -54
- package/types/global.d.ts +232 -231
- package/vite.config.ts +83 -84
- package/dist/Staff-BFp3zNNR.js +0 -25
- package/dist/StaffPanel.vue_vue_type_script_setup_true_lang-v5xOXKRS.js +0 -143
- package/dist/await-to-js.es5-BtRbN2QH.js +0 -10
- package/dist/index-BbtbEMCH.js +0 -4649
- package/dist/su-welcome-BHDsjqqV.js +0 -524
|
@@ -1,100 +1,100 @@
|
|
|
1
|
-
<!--
|
|
2
|
-
* @Author: wei.li
|
|
3
|
-
* @Date: 2021-12-23 11:22:51
|
|
4
|
-
* @LastEditors: levi7754 levi7754@163.com
|
|
5
|
-
* @LastEditTime: 2025-11-21 18:19:06
|
|
6
|
-
* @Description: 入站接口日志
|
|
7
|
-
-->
|
|
8
|
-
|
|
9
|
-
<template>
|
|
10
|
-
<div>
|
|
11
|
-
<ut-grid ref="xgrid" :items="formItems" :columns="columns" :url="url" :editable="false" />
|
|
12
|
-
<ut-modal-form
|
|
13
|
-
v-if="data.showModal"
|
|
14
|
-
ref="suModalRef"
|
|
15
|
-
:record="data.record"
|
|
16
|
-
:items="items"
|
|
17
|
-
:width="640"
|
|
18
|
-
:height="480"
|
|
19
|
-
:title="data.title"
|
|
20
|
-
@close="data.showModal = false"
|
|
21
|
-
/>
|
|
22
|
-
</div>
|
|
23
|
-
</template>
|
|
24
|
-
<script setup lang="tsx">
|
|
25
|
-
import { ref, reactive } from 'vue';
|
|
26
|
-
import { useRender } from '@utogether/utils';
|
|
27
|
-
import { getServiceApi } from '../../../api';
|
|
28
|
-
import { getEnv } from '../../../config';
|
|
29
|
-
import to from 'await-to-js';
|
|
30
|
-
|
|
31
|
-
defineOptions({ name: 'LoginLog' });
|
|
32
|
-
|
|
33
|
-
const renderHook = useRender();
|
|
34
|
-
const data = reactive({
|
|
35
|
-
showModal: false,
|
|
36
|
-
record: {},
|
|
37
|
-
title: ''
|
|
38
|
-
});
|
|
39
|
-
|
|
40
|
-
const baseService = getEnv().VITE_BUINESS_SERVICE;
|
|
41
|
-
|
|
42
|
-
const url = `${baseService}/v1/invoke-inbound`;
|
|
43
|
-
|
|
44
|
-
const formItems = [
|
|
45
|
-
{ field: 'interfaceName' },
|
|
46
|
-
{ field: 'interfaceUrl' },
|
|
47
|
-
{ field: 'requestBodyParameter', title: 'message.requestParameter' },
|
|
48
|
-
{ field: 'responseContent' },
|
|
49
|
-
{ field: 'ip', title: 'message.udp.ip' },
|
|
50
|
-
{ field: 'requestDate', itemRender: { name: '#SuDateRange', props: { type: 'daterange' } } },
|
|
51
|
-
{ field: 'requestStatus', itemRender: renderHook.renderDict('SU.REQUEST.STATUS') }
|
|
52
|
-
];
|
|
53
|
-
|
|
54
|
-
const items = [
|
|
55
|
-
{
|
|
56
|
-
field: 'requestBodyParameter',
|
|
57
|
-
title: 'message.requestParameter',
|
|
58
|
-
itemRender: renderHook.renderTextarea({ rows: 8 })
|
|
59
|
-
},
|
|
60
|
-
{ field: 'responseContent', itemRender: renderHook.renderTextarea({ rows: 6 }) },
|
|
61
|
-
{ field: 'stacktrace', itemRender: renderHook.renderTextarea({ rows: 3 }) }
|
|
62
|
-
];
|
|
63
|
-
|
|
64
|
-
// 列字段
|
|
65
|
-
const xgrid = ref(null);
|
|
66
|
-
const columns = [
|
|
67
|
-
{ field: 'interfaceName', minWidth: 120 },
|
|
68
|
-
{ field: 'interfaceUrl', minWidth: 150 },
|
|
69
|
-
{ field: 'ip', title: 'message.udp.ip', width: 120 },
|
|
70
|
-
{ field: 'requestDate', width: 160 },
|
|
71
|
-
{ field: 'responseTimeConsume', width: 120 },
|
|
72
|
-
{ field: 'requestStatus', width: 90, formatter: ['formatDict', 'SU.REQUEST.STATUS'] },
|
|
73
|
-
{
|
|
74
|
-
field: 'operate',
|
|
75
|
-
width: 70,
|
|
76
|
-
slots: {
|
|
77
|
-
default: ({ row }) => {
|
|
78
|
-
if (!row.id) return null;
|
|
79
|
-
return [
|
|
80
|
-
<>
|
|
81
|
-
<ut-button content="detail" icon="ri-eye-line" onTap={() => handleShowDetail(row)} />
|
|
82
|
-
</>
|
|
83
|
-
];
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
];
|
|
88
|
-
// 详情
|
|
89
|
-
const handleShowDetail = async record => {
|
|
90
|
-
const [err, res]: any = await to(getServiceApi().get(url + '/detail', { id: record.id }));
|
|
91
|
-
if (err) return;
|
|
92
|
-
console.log(res);
|
|
93
|
-
const resContent = JSON.parse(res.responseContent);
|
|
94
|
-
record.resContent = resContent?.data?.list || resContent?.data;
|
|
95
|
-
record.resContent = record.resContent ? JSON.stringify(record.resContent) : '';
|
|
96
|
-
data.record = res;
|
|
97
|
-
data.showModal = true;
|
|
98
|
-
data.title = `【${record.interfaceName}】接口明细`;
|
|
99
|
-
};
|
|
100
|
-
</script>
|
|
1
|
+
<!--
|
|
2
|
+
* @Author: wei.li
|
|
3
|
+
* @Date: 2021-12-23 11:22:51
|
|
4
|
+
* @LastEditors: levi7754 levi7754@163.com
|
|
5
|
+
* @LastEditTime: 2025-11-21 18:19:06
|
|
6
|
+
* @Description: 入站接口日志
|
|
7
|
+
-->
|
|
8
|
+
|
|
9
|
+
<template>
|
|
10
|
+
<div>
|
|
11
|
+
<ut-grid ref="xgrid" :items="formItems" :columns="columns" :url="url" :editable="false" />
|
|
12
|
+
<ut-modal-form
|
|
13
|
+
v-if="data.showModal"
|
|
14
|
+
ref="suModalRef"
|
|
15
|
+
:record="data.record"
|
|
16
|
+
:items="items"
|
|
17
|
+
:width="640"
|
|
18
|
+
:height="480"
|
|
19
|
+
:title="data.title"
|
|
20
|
+
@close="data.showModal = false"
|
|
21
|
+
/>
|
|
22
|
+
</div>
|
|
23
|
+
</template>
|
|
24
|
+
<script setup lang="tsx">
|
|
25
|
+
import { ref, reactive } from 'vue';
|
|
26
|
+
import { useRender } from '@utogether/utils';
|
|
27
|
+
import { getServiceApi } from '../../../api';
|
|
28
|
+
import { getEnv } from '../../../config';
|
|
29
|
+
import to from 'await-to-js';
|
|
30
|
+
|
|
31
|
+
defineOptions({ name: 'LoginLog' });
|
|
32
|
+
|
|
33
|
+
const renderHook = useRender();
|
|
34
|
+
const data = reactive({
|
|
35
|
+
showModal: false,
|
|
36
|
+
record: {},
|
|
37
|
+
title: ''
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
const baseService = getEnv().VITE_BUINESS_SERVICE;
|
|
41
|
+
|
|
42
|
+
const url = `${baseService}/v1/invoke-inbound`;
|
|
43
|
+
|
|
44
|
+
const formItems = [
|
|
45
|
+
{ field: 'interfaceName' },
|
|
46
|
+
{ field: 'interfaceUrl' },
|
|
47
|
+
{ field: 'requestBodyParameter', title: 'message.requestParameter' },
|
|
48
|
+
{ field: 'responseContent' },
|
|
49
|
+
{ field: 'ip', title: 'message.udp.ip' },
|
|
50
|
+
{ field: 'requestDate', itemRender: { name: '#SuDateRange', props: { type: 'daterange' } } },
|
|
51
|
+
{ field: 'requestStatus', itemRender: renderHook.renderDict('SU.REQUEST.STATUS') }
|
|
52
|
+
];
|
|
53
|
+
|
|
54
|
+
const items = [
|
|
55
|
+
{
|
|
56
|
+
field: 'requestBodyParameter',
|
|
57
|
+
title: 'message.requestParameter',
|
|
58
|
+
itemRender: renderHook.renderTextarea({ rows: 8 })
|
|
59
|
+
},
|
|
60
|
+
{ field: 'responseContent', itemRender: renderHook.renderTextarea({ rows: 6 }) },
|
|
61
|
+
{ field: 'stacktrace', itemRender: renderHook.renderTextarea({ rows: 3 }) }
|
|
62
|
+
];
|
|
63
|
+
|
|
64
|
+
// 列字段
|
|
65
|
+
const xgrid = ref(null);
|
|
66
|
+
const columns = [
|
|
67
|
+
{ field: 'interfaceName', minWidth: 120 },
|
|
68
|
+
{ field: 'interfaceUrl', minWidth: 150 },
|
|
69
|
+
{ field: 'ip', title: 'message.udp.ip', width: 120 },
|
|
70
|
+
{ field: 'requestDate', width: 160 },
|
|
71
|
+
{ field: 'responseTimeConsume', width: 120 },
|
|
72
|
+
{ field: 'requestStatus', width: 90, formatter: ['formatDict', 'SU.REQUEST.STATUS'] },
|
|
73
|
+
{
|
|
74
|
+
field: 'operate',
|
|
75
|
+
width: 70,
|
|
76
|
+
slots: {
|
|
77
|
+
default: ({ row }) => {
|
|
78
|
+
if (!row.id) return null;
|
|
79
|
+
return [
|
|
80
|
+
<>
|
|
81
|
+
<ut-button content="detail" icon="ri-eye-line" onTap={() => handleShowDetail(row)} />
|
|
82
|
+
</>
|
|
83
|
+
];
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
];
|
|
88
|
+
// 详情
|
|
89
|
+
const handleShowDetail = async record => {
|
|
90
|
+
const [err, res]: any = await to(getServiceApi().get(url + '/detail', { id: record.id }));
|
|
91
|
+
if (err) return;
|
|
92
|
+
console.log(res);
|
|
93
|
+
const resContent = JSON.parse(res.responseContent);
|
|
94
|
+
record.resContent = resContent?.data?.list || resContent?.data;
|
|
95
|
+
record.resContent = record.resContent ? JSON.stringify(record.resContent) : '';
|
|
96
|
+
data.record = res;
|
|
97
|
+
data.showModal = true;
|
|
98
|
+
data.title = `【${record.interfaceName}】接口明细`;
|
|
99
|
+
};
|
|
100
|
+
</script>
|
|
@@ -1,104 +1,104 @@
|
|
|
1
|
-
<!--
|
|
2
|
-
* @Author: wei.li
|
|
3
|
-
* @Date: 2021-12-23 11:22:51
|
|
4
|
-
* @LastEditors: levi7754 levi7754@163.com
|
|
5
|
-
* @LastEditTime: 2025-11-21 18:17:10
|
|
6
|
-
* @Description: 出站接口日志
|
|
7
|
-
-->
|
|
8
|
-
|
|
9
|
-
<template>
|
|
10
|
-
<div>
|
|
11
|
-
<ut-grid ref="xgrid" :items="formItems" :columns="columns" :url="url" :editable="false" />
|
|
12
|
-
|
|
13
|
-
<ut-modal-form
|
|
14
|
-
v-if="data.showModal"
|
|
15
|
-
ref="suModalRef"
|
|
16
|
-
:record="data.record"
|
|
17
|
-
:items="items"
|
|
18
|
-
:width="640"
|
|
19
|
-
:height="480"
|
|
20
|
-
:title="data.title"
|
|
21
|
-
@close="data.showModal = false"
|
|
22
|
-
/>
|
|
23
|
-
</div>
|
|
24
|
-
</template>
|
|
25
|
-
|
|
26
|
-
<script setup lang="tsx">
|
|
27
|
-
import { ref, reactive } from 'vue';
|
|
28
|
-
import { useRender } from '@utogether/utils';
|
|
29
|
-
|
|
30
|
-
import { getEnv } from '../../../config';
|
|
31
|
-
import to from 'await-to-js';
|
|
32
|
-
import { getServiceApi } from '../../../api';
|
|
33
|
-
|
|
34
|
-
defineOptions({ name: 'LogoutLog' });
|
|
35
|
-
|
|
36
|
-
const renderHook = useRender();
|
|
37
|
-
|
|
38
|
-
const baseService = getEnv().VITE_BUINESS_SERVICE;
|
|
39
|
-
|
|
40
|
-
const url = `${baseService}/v1/invoke-outbound`;
|
|
41
|
-
|
|
42
|
-
const data = reactive({
|
|
43
|
-
showModal: false,
|
|
44
|
-
record: {},
|
|
45
|
-
title: ''
|
|
46
|
-
});
|
|
47
|
-
|
|
48
|
-
const formItems = [
|
|
49
|
-
{ field: 'interfaceName' },
|
|
50
|
-
{ field: 'interfaceUrl' },
|
|
51
|
-
{ field: 'requestParameter' },
|
|
52
|
-
{ field: 'responseContent' },
|
|
53
|
-
// { field: 'ip', },
|
|
54
|
-
{ field: 'requestDate', itemRender: { name: '#SuDateRange', props: { type: 'daterange' } } },
|
|
55
|
-
{ field: 'requestStatus', itemRender: renderHook.renderDict('SU.REQUEST.STATUS') }
|
|
56
|
-
];
|
|
57
|
-
|
|
58
|
-
const items = [
|
|
59
|
-
{ field: 'requestParameter', itemRender: { name: '$textarea', props: { rows: 5 } } },
|
|
60
|
-
{
|
|
61
|
-
field: 'responseContent',
|
|
62
|
-
itemRender: { name: '$textarea', props: { rows: 10 } }
|
|
63
|
-
},
|
|
64
|
-
{ field: 'stacktrace', itemRender: { name: '$textarea', props: { rows: 3 } } }
|
|
65
|
-
];
|
|
66
|
-
|
|
67
|
-
const xgrid = ref(null);
|
|
68
|
-
// 列字段
|
|
69
|
-
const columns = [
|
|
70
|
-
{ field: 'interfaceName', minWidth: 120 },
|
|
71
|
-
{ field: 'interfaceUrl', minWidth: 150 },
|
|
72
|
-
// { field: 'ip', width: 120 },
|
|
73
|
-
{ field: 'requestDate', width: 160 },
|
|
74
|
-
{ field: 'responseTimeConsume', width: 120 },
|
|
75
|
-
{ field: 'requestStatus', width: 90, formatter: ['formatDict', 'SU.REQUEST.STATUS'] },
|
|
76
|
-
{
|
|
77
|
-
field: 'operate',
|
|
78
|
-
width: 70,
|
|
79
|
-
slots: {
|
|
80
|
-
default: ({ row }) => {
|
|
81
|
-
if (!row.id) return null;
|
|
82
|
-
return [
|
|
83
|
-
<>
|
|
84
|
-
<ut-button content="detail" icon="ri-eye-line ri-1x" onTap={() => handleShowDetail(row)} />
|
|
85
|
-
</>
|
|
86
|
-
];
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
];
|
|
91
|
-
// 详情
|
|
92
|
-
const handleShowDetail = async row => {
|
|
93
|
-
const [err, res]: any = await to(getServiceApi().get(url + '/detail', { id: row.id }));
|
|
94
|
-
if (err) return;
|
|
95
|
-
console.log(res);
|
|
96
|
-
// const resContent = JSON.parse(record.responseContent);
|
|
97
|
-
// console.log(resContent);
|
|
98
|
-
// record.resContent = resContent?.data?.list || resContent?.data;
|
|
99
|
-
// record.resContent = record.resContent ? JSON.stringify(record.resContent) : '';
|
|
100
|
-
data.record = res;
|
|
101
|
-
data.showModal = true;
|
|
102
|
-
data.title = `【${res.interfaceName}】接口明细`;
|
|
103
|
-
};
|
|
104
|
-
</script>
|
|
1
|
+
<!--
|
|
2
|
+
* @Author: wei.li
|
|
3
|
+
* @Date: 2021-12-23 11:22:51
|
|
4
|
+
* @LastEditors: levi7754 levi7754@163.com
|
|
5
|
+
* @LastEditTime: 2025-11-21 18:17:10
|
|
6
|
+
* @Description: 出站接口日志
|
|
7
|
+
-->
|
|
8
|
+
|
|
9
|
+
<template>
|
|
10
|
+
<div>
|
|
11
|
+
<ut-grid ref="xgrid" :items="formItems" :columns="columns" :url="url" :editable="false" />
|
|
12
|
+
|
|
13
|
+
<ut-modal-form
|
|
14
|
+
v-if="data.showModal"
|
|
15
|
+
ref="suModalRef"
|
|
16
|
+
:record="data.record"
|
|
17
|
+
:items="items"
|
|
18
|
+
:width="640"
|
|
19
|
+
:height="480"
|
|
20
|
+
:title="data.title"
|
|
21
|
+
@close="data.showModal = false"
|
|
22
|
+
/>
|
|
23
|
+
</div>
|
|
24
|
+
</template>
|
|
25
|
+
|
|
26
|
+
<script setup lang="tsx">
|
|
27
|
+
import { ref, reactive } from 'vue';
|
|
28
|
+
import { useRender } from '@utogether/utils';
|
|
29
|
+
|
|
30
|
+
import { getEnv } from '../../../config';
|
|
31
|
+
import to from 'await-to-js';
|
|
32
|
+
import { getServiceApi } from '../../../api';
|
|
33
|
+
|
|
34
|
+
defineOptions({ name: 'LogoutLog' });
|
|
35
|
+
|
|
36
|
+
const renderHook = useRender();
|
|
37
|
+
|
|
38
|
+
const baseService = getEnv().VITE_BUINESS_SERVICE;
|
|
39
|
+
|
|
40
|
+
const url = `${baseService}/v1/invoke-outbound`;
|
|
41
|
+
|
|
42
|
+
const data = reactive({
|
|
43
|
+
showModal: false,
|
|
44
|
+
record: {},
|
|
45
|
+
title: ''
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
const formItems = [
|
|
49
|
+
{ field: 'interfaceName' },
|
|
50
|
+
{ field: 'interfaceUrl' },
|
|
51
|
+
{ field: 'requestParameter' },
|
|
52
|
+
{ field: 'responseContent' },
|
|
53
|
+
// { field: 'ip', },
|
|
54
|
+
{ field: 'requestDate', itemRender: { name: '#SuDateRange', props: { type: 'daterange' } } },
|
|
55
|
+
{ field: 'requestStatus', itemRender: renderHook.renderDict('SU.REQUEST.STATUS') }
|
|
56
|
+
];
|
|
57
|
+
|
|
58
|
+
const items = [
|
|
59
|
+
{ field: 'requestParameter', itemRender: { name: '$textarea', props: { rows: 5 } } },
|
|
60
|
+
{
|
|
61
|
+
field: 'responseContent',
|
|
62
|
+
itemRender: { name: '$textarea', props: { rows: 10 } }
|
|
63
|
+
},
|
|
64
|
+
{ field: 'stacktrace', itemRender: { name: '$textarea', props: { rows: 3 } } }
|
|
65
|
+
];
|
|
66
|
+
|
|
67
|
+
const xgrid = ref(null);
|
|
68
|
+
// 列字段
|
|
69
|
+
const columns = [
|
|
70
|
+
{ field: 'interfaceName', minWidth: 120 },
|
|
71
|
+
{ field: 'interfaceUrl', minWidth: 150 },
|
|
72
|
+
// { field: 'ip', width: 120 },
|
|
73
|
+
{ field: 'requestDate', width: 160 },
|
|
74
|
+
{ field: 'responseTimeConsume', width: 120 },
|
|
75
|
+
{ field: 'requestStatus', width: 90, formatter: ['formatDict', 'SU.REQUEST.STATUS'] },
|
|
76
|
+
{
|
|
77
|
+
field: 'operate',
|
|
78
|
+
width: 70,
|
|
79
|
+
slots: {
|
|
80
|
+
default: ({ row }) => {
|
|
81
|
+
if (!row.id) return null;
|
|
82
|
+
return [
|
|
83
|
+
<>
|
|
84
|
+
<ut-button content="detail" icon="ri-eye-line ri-1x" onTap={() => handleShowDetail(row)} />
|
|
85
|
+
</>
|
|
86
|
+
];
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
];
|
|
91
|
+
// 详情
|
|
92
|
+
const handleShowDetail = async row => {
|
|
93
|
+
const [err, res]: any = await to(getServiceApi().get(url + '/detail', { id: row.id }));
|
|
94
|
+
if (err) return;
|
|
95
|
+
console.log(res);
|
|
96
|
+
// const resContent = JSON.parse(record.responseContent);
|
|
97
|
+
// console.log(resContent);
|
|
98
|
+
// record.resContent = resContent?.data?.list || resContent?.data;
|
|
99
|
+
// record.resContent = record.resContent ? JSON.stringify(record.resContent) : '';
|
|
100
|
+
data.record = res;
|
|
101
|
+
data.showModal = true;
|
|
102
|
+
data.title = `【${res.interfaceName}】接口明细`;
|
|
103
|
+
};
|
|
104
|
+
</script>
|
|
@@ -1,54 +1,54 @@
|
|
|
1
|
-
<!--
|
|
2
|
-
* @Author: wei.li
|
|
3
|
-
* @Date: 2021-12-23 11:22:51
|
|
4
|
-
* @LastEditors: levi7754 levi7754@163.com
|
|
5
|
-
* @LastEditTime: 2025-12-08 08:22:23
|
|
6
|
-
* @Description: 用户登录日志
|
|
7
|
-
-->
|
|
8
|
-
|
|
9
|
-
<template>
|
|
10
|
-
<div>
|
|
11
|
-
<ut-grid ref="xgrid" :items="formItems" :columns="columns" url="/upfm/v1/userMonitor" :editable="false" />
|
|
12
|
-
</div>
|
|
13
|
-
</template>
|
|
14
|
-
<script lang="tsx">
|
|
15
|
-
export default {
|
|
16
|
-
name: 'LoginLog'
|
|
17
|
-
};
|
|
18
|
-
</script>
|
|
19
|
-
<script setup lang="tsx">
|
|
20
|
-
import { ref } from 'vue';
|
|
21
|
-
// import { useRouter } from 'vue-router';
|
|
22
|
-
// import to from 'await-to-js';
|
|
23
|
-
// import { clone } from 'xe-utils';
|
|
24
|
-
// import { useRender } from '@utogether/utils';
|
|
25
|
-
|
|
26
|
-
// const renderHook = useRender();
|
|
27
|
-
// const renderOption = renderOptions();
|
|
28
|
-
|
|
29
|
-
// const router = useRouter();
|
|
30
|
-
|
|
31
|
-
const formItems = [
|
|
32
|
-
{ field: 'employeeName' },
|
|
33
|
-
{ field: 'userName', title: 'message.udp.
|
|
34
|
-
{ field: 'operatingSystem', title: 'message.udp.operatingSystem' },
|
|
35
|
-
{ field: 'browserVersion', title: 'message.udp.browserVersion' },
|
|
36
|
-
{
|
|
37
|
-
field: 'loginTime',
|
|
38
|
-
title: 'message.udp.loginTime',
|
|
39
|
-
itemRender: { name: '#SuDateRange', props: { type: 'daterange' } }
|
|
40
|
-
}
|
|
41
|
-
];
|
|
42
|
-
|
|
43
|
-
// 列字段
|
|
44
|
-
const xgrid = ref(null);
|
|
45
|
-
const columns = [
|
|
46
|
-
{ field: 'employeeName', minWidth: 120 },
|
|
47
|
-
{ field: 'userName', title: 'message.udp.
|
|
48
|
-
{ field: 'loginTime', title: 'message.udp.loginTime', width: 160 },
|
|
49
|
-
{ field: 'operatingSystem', title: 'message.udp.operatingSystem', width: 120 },
|
|
50
|
-
{ field: 'browser', title: 'message.udp.browser', width: 130 },
|
|
51
|
-
{ field: 'browserVersion', title: 'message.udp.browserVersion', width: 150 },
|
|
52
|
-
{ field: 'ip', title: 'message.udp.ip', width: 200 }
|
|
53
|
-
];
|
|
54
|
-
</script>
|
|
1
|
+
<!--
|
|
2
|
+
* @Author: wei.li
|
|
3
|
+
* @Date: 2021-12-23 11:22:51
|
|
4
|
+
* @LastEditors: levi7754 levi7754@163.com
|
|
5
|
+
* @LastEditTime: 2025-12-08 08:22:23
|
|
6
|
+
* @Description: 用户登录日志
|
|
7
|
+
-->
|
|
8
|
+
|
|
9
|
+
<template>
|
|
10
|
+
<div>
|
|
11
|
+
<ut-grid ref="xgrid" :items="formItems" :columns="columns" url="/upfm/v1/userMonitor" :editable="false" />
|
|
12
|
+
</div>
|
|
13
|
+
</template>
|
|
14
|
+
<script lang="tsx">
|
|
15
|
+
export default {
|
|
16
|
+
name: 'LoginLog'
|
|
17
|
+
};
|
|
18
|
+
</script>
|
|
19
|
+
<script setup lang="tsx">
|
|
20
|
+
import { ref } from 'vue';
|
|
21
|
+
// import { useRouter } from 'vue-router';
|
|
22
|
+
// import to from 'await-to-js';
|
|
23
|
+
// import { clone } from 'xe-utils';
|
|
24
|
+
// import { useRender } from '@utogether/utils';
|
|
25
|
+
|
|
26
|
+
// const renderHook = useRender();
|
|
27
|
+
// const renderOption = renderOptions();
|
|
28
|
+
|
|
29
|
+
// const router = useRouter();
|
|
30
|
+
|
|
31
|
+
const formItems = [
|
|
32
|
+
{ field: 'employeeName' },
|
|
33
|
+
{ field: 'userName', title: 'message.udp.loginUser' },
|
|
34
|
+
{ field: 'operatingSystem', title: 'message.udp.operatingSystem' },
|
|
35
|
+
{ field: 'browserVersion', title: 'message.udp.browserVersion' },
|
|
36
|
+
{
|
|
37
|
+
field: 'loginTime',
|
|
38
|
+
title: 'message.udp.loginTime',
|
|
39
|
+
itemRender: { name: '#SuDateRange', props: { type: 'daterange' } }
|
|
40
|
+
}
|
|
41
|
+
];
|
|
42
|
+
|
|
43
|
+
// 列字段
|
|
44
|
+
const xgrid = ref(null);
|
|
45
|
+
const columns = [
|
|
46
|
+
{ field: 'employeeName', minWidth: 120 },
|
|
47
|
+
{ field: 'userName', title: 'message.udp.loginUser', width: 220 },
|
|
48
|
+
{ field: 'loginTime', title: 'message.udp.loginTime', width: 160 },
|
|
49
|
+
{ field: 'operatingSystem', title: 'message.udp.operatingSystem', width: 120 },
|
|
50
|
+
{ field: 'browser', title: 'message.udp.browser', width: 130 },
|
|
51
|
+
{ field: 'browserVersion', title: 'message.udp.browserVersion', width: 150 },
|
|
52
|
+
{ field: 'ip', title: 'message.udp.ip', width: 200 }
|
|
53
|
+
];
|
|
54
|
+
</script>
|