123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207 |
- <template>
- <a-card :bordered="false">
- <div class="table-page-search-wrapper" v-if="hasPerm('sysVisLog:page')">
- <a-form layout="inline">
- <a-row :gutter="48">
- <a-col :md="8" :sm="24">
- <a-form-item label="日志名称">
- <a-input v-model="queryParam.name" allow-clear placeholder="请输入日志名称"/>
- </a-form-item>
- </a-col>
- <a-col :md="8" :sm="24">
- <a-form-item label="访问类型">
- <a-select v-model="queryParam.visType" allow-clear placeholder="请选择访问类型" >
- <a-select-option v-for="(item,index) in visTypeDict" :key="index" :value="item.code" >{{ item.value }}</a-select-option>
- </a-select>
- </a-form-item>
- </a-col>
- <template v-if="advanced">
- <a-col :md="8" :sm="24">
- <a-form-item label="是否成功">
- <a-select v-model="queryParam.success" placeholder="请选择是否成功" >
- <a-select-option v-for="(item,index) in successDict" :key="index" :value="item.code" >{{ item.value }}</a-select-option>
- </a-select>
- </a-form-item>
- </a-col>
- </template>
- <a-col :md="!advanced && 8 || 24" :sm="24">
- <span class="table-page-search-submitButtons" :style="advanced && { float: 'right', overflow: 'hidden' } || {} ">
- <a-button type="primary" @click="$refs.table.refresh(true)" >查询</a-button>
- <a-button style="margin-left: 8px" @click="() => queryParam = {}">重置</a-button>
- <a @click="toggleAdvanced" style="margin-left: 8px">
- {{ advanced ? '收起' : '展开' }}
- <a-icon :type="advanced ? 'up' : 'down'"/>
- </a>
- </span>
- </a-col>
- </a-row>
- </a-form>
- </div>
- <div class="table-operator" v-if="hasPerm('sysVisLog:delete')">
- <a-popconfirm v-if="hasPerm('sysVisLog:delete')" placement="top" title="确认清空日志?" @confirm="() => sysVisLogDelete()">
- <a-button >清空日志</a-button>
- </a-popconfirm>
- </div>
- <s-table
- ref="table"
- size="default"
- :columns="columns"
- :data="loadData"
- :alert="true"
- :rowKey="(record) => record.id"
- :rowSelection="{ selectedRowKeys: selectedRowKeys, onChange: onSelectChange }"
- >
- <span slot="name" slot-scope="text">
- <ellipsis :length="10" tooltip>{{ text }}</ellipsis>
- </span>
- <span slot="visTime" slot-scope="text">
- <ellipsis :length="10" tooltip>{{ text }}</ellipsis>
- </span>
- <span slot="visType" slot-scope="text">
- {{ visTypeFilter(text) }}
- </span>
- <span slot="success" slot-scope="text">
- {{ successFilter(text) }}
- </span>
- <span slot="action" slot-scope="text, record">
- <span slot="action" >
- <a @click="$refs.detailsVislog.details(record)">查看详情</a>
- </span>
- </span>
- </s-table>
- <details-vislog ref="detailsVislog"/>
- </a-card>
- </template>
- <script>
- import { STable, Ellipsis } from '@/components'
- import { sysVisLogPage, sysVisLogDelete } from '@/api/modular/system/logManage'
- import detailsVislog from './details'
- import { sysDictTypeDropDown } from '@/api/modular/system/dictManage'
- export default {
- components: {
- STable,
- Ellipsis,
- detailsVislog
- },
- data () {
- return {
- advanced: false,
- // 查询参数
- queryParam: {},
- // 表头
- columns: [
- {
- title: '日志名称',
- dataIndex: 'name',
- scopedSlots: { customRender: 'name' }
- },
- {
- title: '访问类型',
- dataIndex: 'visType',
- scopedSlots: { customRender: 'visType' }
- },
- {
- title: '是否成功',
- dataIndex: 'success',
- scopedSlots: { customRender: 'success' }
- },
- {
- title: 'ip',
- dataIndex: 'ip'
- },
- {
- title: '浏览器',
- dataIndex: 'browser'
- },
- {
- title: '访问时间',
- dataIndex: 'visTime',
- scopedSlots: { customRender: 'visTime' }
- },
- {
- title: '访问人',
- dataIndex: 'account'
- },
- {
- title: '详情',
- dataIndex: 'action',
- width: '150px',
- scopedSlots: { customRender: 'action' }
- }
- ],
- // 加载数据方法 必须为 Promise 对象
- loadData: parameter => {
- return sysVisLogPage(Object.assign(parameter, this.queryParam)).then((res) => {
- return res.data
- })
- },
- selectedRowKeys: [],
- selectedRows: [],
- defaultExpandedKeys: [],
- visTypeDict: [],
- successDict: []
- }
- },
- /**
- * 相当于html的onload方法,进来初始化
- */
- created () {
- this.sysDictTypeDropDown()
- },
- methods: {
- visTypeFilter (visType) {
- // eslint-disable-next-line eqeqeq
- const values = this.visTypeDict.filter(item => item.code == visType)
- if (values.length > 0) {
- return values[0].value
- }
- },
- successFilter (success) {
- // eslint-disable-next-line eqeqeq
- const values = this.successDict.filter(item => item.code == success)
- if (values.length > 0) {
- return values[0].value
- }
- },
- /**
- * 获取字典数据
- */
- sysDictTypeDropDown () {
- sysDictTypeDropDown({ code: 'vis_type' }).then((res) => {
- this.visTypeDict = res.data
- })
- sysDictTypeDropDown({ code: 'yes_or_no' }).then((res) => {
- this.successDict = res.data
- })
- },
- /**
- * 清空日志
- */
- sysVisLogDelete () {
- sysVisLogDelete().then((res) => {
- if (res.success) {
- this.$message.success('清空成功')
- this.$refs.table.refresh(true)
- } else {
- this.$message.error('清空失败:' + res.message)
- }
- })
- },
- toggleAdvanced () {
- this.advanced = !this.advanced
- },
- onSelectChange (selectedRowKeys, selectedRows) {
- this.selectedRowKeys = selectedRowKeys
- this.selectedRows = selectedRows
- }
- }
- }
- </script>
- <style lang="less">
- .table-operator {
- margin-bottom: 18px;
- }
- button {
- margin-right: 8px;
- }
- </style>
|