123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208 |
- <template>
- <div class="relics-layout">
- <div class="relics-header">
- <div class="search">
- <el-form label-width="100px" inline>
- <el-form-item label="文物名称:">
- <el-input
- v-model="pageProps.name"
- style="width: 250px"
- placeholder="请输入"
- />
- </el-form-item>
- <el-form-item label="文物级别:">
- <el-select style="width: 250px" v-model="pageProps.level">
- <el-option
- :value="Number(key)"
- :label="type"
- v-for="(type, key) in relicsLevelDesc"
- />
- </el-select>
- </el-form-item>
- <el-form-item label="类别:">
- <el-select style="width: 250px" v-model="pageProps.category">
- <el-option
- :value="Number(key)"
- :label="type"
- v-for="(type, key) in relicsTypeDesc"
- />
- </el-select>
- </el-form-item>
- <el-form-item class="searh-btns">
- <el-button type="primary" @click="refresh">查询</el-button>
- <el-button type="primary" plain @click="pageProps = { ...initProps }">
- 重置
- </el-button>
- <el-button type="primary" @click="addHandler">创建文物</el-button>
- </el-form-item>
- </el-form>
- </div>
- <!-- <div class="relics-oper">
- <el-button type="primary" @click="inputMode = true">新增</el-button>
- </div> -->
- </div>
- <el-table :data="relicsArray" border>
- <el-table-column prop="name" label="文物保护单位名称" />
- <el-table-column prop="unicode" label="文物编号" />
- <el-table-column
- prop="name"
- label="文物级别"
- v-slot:default="{ row }: { row: Relics }"
- >
- {{ relicsLevelDesc[row.level!] }}
- </el-table-column>
- <el-table-column prop="name" label="类别" v-slot:default="{ row }: { row: Relics }">
- {{ relicsTypeDesc[row.category!] }}
- </el-table-column>
- <el-table-column prop="address" label="文物地址" />
- <el-table-column label="创建时间" prop="createTime" v-slot:default="{ row }">
- {{ row.createTime && row.createTime.substr(0, 16) }}
- </el-table-column>
- <el-table-column prop="userName" label="创建人" />
- <el-table-column
- prop="creationMethod"
- label="创建方式"
- v-slot:default="{ row }: { row: Relics }"
- >
- {{ creationMethodDesc[row.creationMethod!] }}
- {{}}
- </el-table-column>
- <el-table-column label="操作" width="240" fixed="right">
- <template #default="{ row }">
- <el-button link type="primary" size="small" @click="shareHandler(row)">
- 文物链接
- </el-button>
- <el-button link type="primary" size="small" @click="editHandler(row)">
- 编辑
- </el-button>
- <el-button
- link
- type="primary"
- size="small"
- @click="router.push({ name: 'map', params: { relicsId: row.relicsId } })"
- >
- 数据提取
- </el-button>
- <el-button link type="danger" @click="delHandler(row.relicsId)" size="small">
- 删除
- </el-button>
- </template>
- </el-table-column>
- </el-table>
- <div class="pag-layout">
- <el-pagination
- background
- layout="prev, pager, next, sizes, jumper"
- v-model:page-size="pageProps.pageSize"
- :page-sizes="[10, 20, 50, 100]"
- :total="total"
- @current-change="(data: number) => pageProps.pageNum = data"
- :current-page="pageProps.pageNum"
- :page-size="pageProps.pageSize"
- />
- </div>
- </div>
- </template>
- <script lang="ts" setup>
- import { onActivated, ref, watchEffect } from "vue";
- import {
- relicsPageFetch,
- RelicsPageProps,
- addRelicsFetch,
- delRelicsFetch,
- updateRelicsFetch,
- } from "@/request";
- import {
- Relics,
- relicsLevelDesc,
- relicsTypeDesc,
- creationMethodDesc,
- } from "@/store/relics";
- import { router } from "@/router";
- import { ElMessage, ElMessageBox } from "element-plus";
- import { copyText } from "@/util";
- import { relicsEdit } from "./quisk";
- const initProps: RelicsPageProps = {
- pageNum: 1,
- pageSize: 10,
- };
- const pageProps = ref({ ...initProps });
- const total = ref<number>(0);
- const relicsArray = ref<Relics[]>([]);
- const refresh = async () => {
- const data = await relicsPageFetch(pageProps.value);
- total.value = data.total;
- relicsArray.value = data.records;
- };
- const delHandler = async (relicsId: number) => {
- const ok = await ElMessageBox.confirm("确定要删除吗", {
- type: "warning",
- });
- if (ok) {
- await delRelicsFetch(relicsId);
- await refresh();
- }
- };
- const getQueryRouteLocation = (row: Relics) =>
- router.resolve({ name: "query-map", params: { relicsId: row.relicsId } });
- const shareHandler = async (row: Relics) => {
- const link = location.origin + location.pathname + getQueryRouteLocation(row).href;
- window.open(link);
- // await copyText(link);
- // await ElMessage.success("链接复制成功");
- };
- const addHandler = async () => {
- const a = await relicsEdit({
- submit: async (data) => {
- await addRelicsFetch(data);
- await refresh();
- },
- });
- console.log(a);
- };
- const editHandler = async (relics: Relics) => {
- await relicsEdit({
- relics,
- submit: async (data) => {
- await updateRelicsFetch(data);
- await refresh();
- },
- });
- };
- watchEffect(refresh);
- onActivated(refresh);
- </script>
- <style scoped lang="scss">
- .relics-layout {
- height: 100%;
- overflow-y: auto;
- padding: 30px;
- }
- .pag-layout {
- margin-top: 20px;
- display: flex;
- justify-content: center;
- }
- .relics-header {
- display: flex;
- align-items: center;
- margin-bottom: 20px;
- .search {
- flex: 1;
- }
- .relics-oper {
- flex: 0 0 100px;
- text-align: right;
- }
- }
- </style>
|