index.vue 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. <template>
  2. <div class="layout-padding">
  3. <div class="layout-padding-auto layout-padding-view">
  4. <el-row class="ml10" v-show="showSearch">
  5. <el-form :inline="true" :model="state.queryForm" @keyup.enter="getDataList" ref="queryRef">
  6. <el-form-item :label="$t('systoken.ip')" prop="ip">
  7. <el-input :placeholder="$t('systoken.inputIpTip')" v-model="state.queryForm.ip"></el-input>
  8. </el-form-item>
  9. <el-form-item :label="$t('systoken.domain')" prop="domain">
  10. <el-input :placeholder="$t('systoken.inputDomainTip')" v-model="state.queryForm.domain"></el-input>
  11. </el-form-item>
  12. <el-form-item>
  13. <el-button @click="getDataList" icon="Search" type="primary">{{ $t('common.queryBtn') }} </el-button>
  14. <el-button @click="resetQuery" icon="Refresh">{{ $t('common.resetBtn') }}</el-button>
  15. </el-form-item>
  16. </el-form>
  17. </el-row>
  18. <el-table
  19. :data="state.dataList"
  20. @sort-change="sortChangeHandle"
  21. style="width: 100%"
  22. v-loading="state.loading"
  23. border
  24. :cell-style="tableStyle.cellStyle"
  25. :header-cell-style="tableStyle.headerCellStyle"
  26. >
  27. <!-- <el-table-column align="center" type="selection" width="40" /> -->
  28. <el-table-column :label="$t('systoken.ip')" prop="ip" show-overflow-tooltip></el-table-column>
  29. <el-table-column :label="$t('systoken.domain')" prop="domain" show-overflow-tooltip ></el-table-column>
  30. <el-table-column :label="$t('systoken.content')" prop="content" show-overflow-tooltip></el-table-column>
  31. <el-table-column :label="$t('systoken.active')" prop="active" show-overflow-tooltip></el-table-column>
  32. </el-table>
  33. <pagination @current-change="currentChangeHandle" @size-change="sizeChangeHandle" v-bind="state.pagination"> </pagination>
  34. </div>
  35. </div>
  36. </template>
  37. <script lang="ts" setup>
  38. import { BasicTableProps, useTable } from '/@/hooks/table';
  39. import { pageList } from '/@/api/marketing/statistics';
  40. import { useI18n } from 'vue-i18n';
  41. import { useMessage, useMessageBox } from '/@/hooks/message';
  42. import { Session } from '/@/utils/storage';
  43. const { t } = useI18n();
  44. // 定义变量内容
  45. const queryRef = ref();
  46. const showSearch = ref(true);
  47. // table hook
  48. const state: BasicTableProps = reactive<BasicTableProps>({
  49. queryForm: {
  50. ip: '',
  51. domain:''
  52. },
  53. pageList: pageList,
  54. });
  55. const { getDataList, currentChangeHandle, sortChangeHandle, sizeChangeHandle, tableStyle } = useTable(state);
  56. // 清空搜索条件
  57. const resetQuery = () => {
  58. queryRef.value?.resetFields();
  59. getDataList();
  60. };
  61. </script>