ny
23 小时以前 282fbc6488f4e8ceb5fda759f963ee88fbf7b999
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
<script lang="ts" setup>
import type { BasicColumn } from '@jnpf/ui/vxeTable';
 
import { reactive } from 'vue';
 
import { useMessage } from '@jnpf/hooks';
import { BasicVxeTable, useVxeTable } from '@jnpf/ui/vxeTable';
 
import dayjs from 'dayjs';
 
import { batchDelLog, delLog, getLogList } from '#/api/system/log';
import { $t } from '#/locales';
 
defineOptions({ name: 'SysLogLoginLog' });
 
interface State {
  category: string;
}
const state = reactive<State>({
  category: '1',
});
const { createMessage, createConfirm } = useMessage();
 
const columns: BasicColumn[] = [
  { title: '类型', dataIndex: 'loginType', width: 100, slots: { default: 'loginType' } },
  { title: '时间', dataIndex: 'creatorTime', width: 150, format: 'date|YYYY-MM-DD HH:mm:ss' },
  { title: '用户', dataIndex: 'userName', width: 120 },
  { title: 'IP地址', dataIndex: 'ipAddress', width: 120 },
  { title: '地点', dataIndex: 'ipAddressName', width: 120 },
  { title: '浏览器', dataIndex: 'browser', width: 120 },
  { title: '操作系统', dataIndex: 'platForm', width: 120 },
  { title: '耗时(毫秒)', dataIndex: 'requestDuration', width: 90, align: 'center' },
  { title: '状态', dataIndex: 'loginMark', width: 70, align: 'center', slots: { default: 'loginMark' } },
  { title: '说明', dataIndex: 'abstracts', minWidth: 200 },
];
 
const [registerTable, { reload, getSelectRows }] = useVxeTable({
  api: getLogList,
  rowSelection: { type: 'checkbox' },
  clickToRowSelect: false,
  clearSelectOnPageChange: true,
  searchInfo: { category: state.category },
  useSearchForm: true,
  formConfig: {
    schemas: [
      {
        field: 'keyword',
        label: $t('common.keyword'),
        component: 'Input',
        componentProps: {
          placeholder: $t('common.enterKeyword'),
          submitOnPressEnter: true,
        },
      },
      {
        field: 'loginType',
        label: '类型',
        component: 'Select',
        componentProps: {
          placeholder: '请选择',
          options: [
            { fullName: '登录', id: 0 },
            { fullName: '退出', id: 1 },
          ],
        },
      },
      {
        field: 'loginMark',
        label: '状态',
        component: 'Select',
        componentProps: {
          placeholder: '请选择',
          options: [
            { fullName: '成功', id: 1 },
            { fullName: '失败', id: 0 },
          ],
        },
      },
      {
        field: 'pickerVal',
        label: '时间',
        component: 'DateRange',
        componentProps: {
          format: 'YYYY-MM-DD HH:mm:ss',
          showTime: { defaultValue: [dayjs('00:00:00', 'HH:mm:ss'), dayjs('23:59:59', 'HH:mm:ss')] },
          placeholder: ['开始时间', '结束时间'],
        },
      },
    ],
    fieldMapToTime: [['pickerVal', ['startTime', 'endTime']]],
  },
  columns,
});
 
function handleDelete() {
  const list: any[] = getSelectRows() || [];
  if (!list.length) return createMessage.error($t('common.selectDataTip'));
  const query = { ids: list.map((item) => item.id) };
  createConfirm({
    iconType: 'warning',
    title: $t('common.tipTitle'),
    content: $t('common.batchDelTip'),
    onOk: () => {
      delLog(query).then((res) => {
        createMessage.success(res.msg);
        reload();
      });
    },
  });
}
function handleDelAll() {
  createConfirm({
    iconType: 'warning',
    title: $t('common.tipTitle'),
    content: '此操作会将所有日志删除,是否继续?',
    onOk: () => {
      batchDelLog(state.category).then((res) => {
        createMessage.success(res.msg);
        reload();
      });
    },
  });
}
</script>
<template>
  <div class="jnpf-content-wrapper">
    <div class="jnpf-content-wrapper-center">
      <div class="jnpf-content-wrapper-content">
        <BasicVxeTable @register="registerTable">
          <template #tableTitle>
            <a-button type="error" pre-icon="icon-ym icon-ym-btn-clearn" @click="handleDelete">{{ $t('common.delText') }}</a-button>
            <a-button type="link" danger @click="handleDelAll">一键清空</a-button>
          </template>
          <template #loginType="{ record }">
            <div class="login-type-box">
              <span class="circle-box" :class="record.loginType == 0 ? 'circle-box-primary' : 'circle-box-error'"></span>
              {{ record.loginType == 0 ? '登录' : '退出' }}
            </div>
          </template>
          <template #loginMark="{ record }">
            <a-tag :color="record.loginMark == 1 ? 'success' : 'error'">{{ record.loginMark == 1 ? '成功' : '失败' }}</a-tag>
          </template>
        </BasicVxeTable>
      </div>
    </div>
  </div>
</template>