| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698 |
- <template>
- <div>
- <div class="filters-container">
- <el-input placeholder="关键字" size="small" v-model="filter1" clearable class="filter-item"></el-input>
- <el-button @click="searchData" type="primary" size="small" icon="el-icon-search" class="filter-item">搜索
- </el-button>
- <el-button @click="showAdvancedQueryDialog = !showAdvancedQueryDialog" type="primary" size="small" icon="el-icon-search" class="filter-item">高级查询
- </el-button>
- <el-button @click="showTableSortDialog = !showTableSortDialog" type="primary" size="small" icon="el-icon-sort" class="filter-item">排序
- </el-button>
- <el-button @click="$router.push({path:'/aimPlaceContent',query:{column:$route.query.column}})" type="primary" size="small" icon="el-icon-edit" class="filter-item">添加
- </el-button>
- <el-button @click="exportExcel" type="primary" size="small" icon="el-icon-share" class="filter-item">导出EXCEL
- </el-button>
- <el-dropdown trigger="click" size="medium" class="table-column-filter">
- <span>
- 筛选数据
- <i class="el-icon-arrow-down el-icon--right"></i>
- </span>
- <el-dropdown-menu slot="dropdown" class="table-column-filter-wrapper">
- <el-checkbox v-for="item in tableColumns" :key="item.value" v-model="item.show">{{item.label}}
- </el-checkbox>
- </el-dropdown-menu>
- </el-dropdown>
- </div>
- <el-table :data="tableData" :height="tableHeight" row-key="id" ref="table">
- <el-table-column type="expand">
- <template scope="props">
- <el-table :data="props.row.aimPlaceContentChildList" border stripe v-if="props.row.aimPlaceContentChildList" size="mini">
- <el-table-column label="操作" align="center" min-width="80">
- <template slot-scope="scope">
- <el-button @click="editRow(scope.row)" type="primary" size="mini" plain>编辑</el-button>
- <el-button @click="deleteRow(scope.row)" type="danger" size="mini" plain>删除</el-button>
- </template>
- </el-table-column>
- <el-table-column prop="id" label="ID" min-width="100">
- </el-table-column>
- <el-table-column prop="aimPlaceContentId" label="目标点内容ID" min-width="100">
- </el-table-column>
- <el-table-column prop="type" label="类别" min-width="100">
- </el-table-column>
- <el-table-column prop="itemName" label="名称" min-width="100">
- </el-table-column>
- <el-table-column prop="itemMess" label="描述" min-width="100">
- </el-table-column>
- <el-table-column prop="itemDes" label="详细" min-width="100">
- </el-table-column>
- <el-table-column prop="remark1" label="备注1" min-width="100">
- </el-table-column>
- <el-table-column prop="remark2" label="备注2" min-width="100">
- </el-table-column>
- <el-table-column prop="remark3" label="备注3" min-width="100">
- </el-table-column>
- </el-table>
- </template>
- </el-table-column>
- <el-table-column v-if="multipleMode" align="center" type="selection" width="50">
- </el-table-column>
- <el-table-column type="index" min-width="50" align="center">
- </el-table-column>
- <el-table-column v-if="isColumnShow('id')" prop="id" label="ID" min-width="100">
- </el-table-column>
- <el-table-column v-if="isColumnShow('name')" prop="name" label="名称" min-width="100">
- </el-table-column>
- <el-table-column v-if="isColumnShow('type')" prop="type" label="类别" min-width="100">
- </el-table-column>
- <el-table-column v-if="isColumnShow('ownedLandMarkId')" prop="ownedLandMarkId" label="所属地标ID" min-width="100">
- </el-table-column>
- <el-table-column v-if="isColumnShow('arContentGroupId')" prop="arContentGroupId" label="AR内容组ID" min-width="100">
- </el-table-column>
- <el-table-column v-if="isColumnShow('arKitPosX')" prop="arKitPosX" label="ArKit坐标X" min-width="100">
- </el-table-column>
- <el-table-column v-if="isColumnShow('arKitPosY')" prop="arKitPosY" label="ArKit坐标Y" min-width="100">
- </el-table-column>
- <el-table-column v-if="isColumnShow('arKitPosZ')" prop="arKitPosZ" label="ArKit坐标Z" min-width="100">
- </el-table-column>
- <el-table-column v-if="isColumnShow('arKitScale')" prop="arKitScale" label="ArKit缩放" min-width="100">
- </el-table-column>
- <el-table-column v-if="isColumnShow('arKitAngle')" prop="arKitAngle" label="ArKit角度" min-width="100">
- </el-table-column>
- <el-table-column v-if="isColumnShow('arKitShowLenth')" prop="arKitShowLenth" label="ArKit一定距离显示" min-width="100">
- </el-table-column>
- <el-table-column v-if="isColumnShow('gyroPosX')" prop="gyroPosX" label="Gyro坐标X" min-width="100">
- </el-table-column>
- <el-table-column v-if="isColumnShow('gyroPosY')" prop="gyroPosY" label="Gyro坐标Y" min-width="100">
- </el-table-column>
- <el-table-column v-if="isColumnShow('gyroPosZ')" prop="gyroPosZ" label="Gyro坐标Z" min-width="100">
- </el-table-column>
- <el-table-column v-if="isColumnShow('gyroPosScale')" prop="gyroPosScale" label="Gyro缩放" min-width="100">
- </el-table-column>
- <el-table-column v-if="isColumnShow('gyroPosAngle')" prop="gyroPosAngle" label="Gyro角度" min-width="100">
- </el-table-column>
- <el-table-column v-if="isColumnShow('gyroPosShowLenth')" prop="gyroPosShowLenth" label="Gyro一定距离显示" min-width="100">
- </el-table-column>
- <el-table-column v-if="isColumnShow('vuforiaImageInfoAreaMarking')" prop="vuforiaImageInfoAreaMarking" label="Gyro绑定识别图区域标记编号" min-width="100">
- </el-table-column>
- <el-table-column v-if="isColumnShow('remark1')" prop="remark1" label="备注1" min-width="100">
- </el-table-column>
- <el-table-column v-if="isColumnShow('remark2')" prop="remark2" label="备注2" min-width="100">
- </el-table-column>
- <el-table-column v-if="isColumnShow('remark3')" prop="remark3" label="备注3" min-width="100">
- </el-table-column>
- <el-table-column v-if="isColumnShow('remark4')" prop="remark4" label="备注4" min-width="100">
- </el-table-column>
- <el-table-column v-if="isColumnShow('remark5')" prop="remark5" label="备注5" min-width="100">
- </el-table-column>
- <el-table-column v-if="isColumnShow('remark6')" prop="remark6" label="备注6" min-width="100">
- </el-table-column>
- <el-table-column label="操作" align="center" fixed="right" min-width="150">
- <template slot-scope="scope">
- <el-button @click="$router.push({path:'/AimPlaceContentChilds',query:{column:scope.row.id+',aimPlaceContentId'}})" type="primary" size="small" plain>内容子集
- </el-button>
- <el-button @click="editRow(scope.row)" type="primary" size="mini" plain>编辑</el-button>
- <el-button @click="deleteRow(scope.row)" type="danger" size="mini" plain>删除</el-button>
- </template>
- </el-table-column>
- </el-table>
- <div class="pagination-wrapper">
- <div class="multiple-mode-wrapper" v-if="0">
- <el-button size="small" v-if="!multipleMode" @click="toggleMultipleMode(true)">批量编辑</el-button>
- <el-button-group v-else>
- <el-button size="small" @click="operation1">批量操作1</el-button>
- <el-button size="small" @click="operation2">批量操作2</el-button>
- <el-button size="small" @click="toggleMultipleMode(false)">取消</el-button>
- </el-button-group>
- </div>
- <el-pagination background @size-change="pageSizeChange" @current-change="currentPageChange" :current-page="currentPage" :page-sizes="[10, 20, 30, 40, 50]" :page-size="pageSize" layout="total, sizes, prev, pager, next, jumper" :total="totalNumber">
- </el-pagination>
- </div>
- <el-dialog title="高级查询" :visible.sync="showAdvancedQueryDialog">
- <el-button @click="addField" type="text" icon="el-icon-plus">添加</el-button>
- <el-table :data="advancedQueryFields">
- <el-table-column prop="link" label="链接符" align="center">
- <template slot-scope="{row}">
- <el-select placeholder="链接" size="small" v-model="row.link" class="filter-item">
- <el-option label="AND" value="AND">
- </el-option>
- <el-option label="OR" value="OR">
- </el-option>
- </el-select>
- </template>
- </el-table-column>
- <el-table-column prop="name" label="字段" align="center">
- <template slot-scope="{row}">
- <el-select v-model="row.name">
- <el-option v-for="item in advancedQueryColumns" :label="item.label" :value="item.value" :key="item.value"></el-option>
- </el-select>
- </template>
- </el-table-column>
- <el-table-column prop="searchMethod" label="搜索方式" width="150" align="center">
- <template slot-scope="{row}">
- <el-select v-model="row.searchMethod">
- <el-option v-for="item in searchMethods" :label="item" :value="item" :key="item"></el-option>
- </el-select>
- </template>
- </el-table-column>
- <el-table-column prop="value" label="参数" align="center">
- <template slot-scope="{row}">
- <el-input v-model="row.value"></el-input>
- </template>
- </el-table-column>
- <el-table-column width="60" align="center">
- <template slot-scope="{ row, column, $index }">
- <el-button @click="removeField($index)" size="small" type="text">删除</el-button>
- </template>
- </el-table-column>
- </el-table>
- <span slot="footer" class="dialog-footer">
- <el-button @click="advancedQuery" :loading="$store.state.fetchingData">确定</el-button>
- </span>
- </el-dialog>
- <el-dialog title="排序" :visible.sync="showTableSortDialog">
- <el-button @click="addSortField" type="text" icon="el-icon-plus">添加</el-button>
- <el-table :data="tableSortFields">
- <el-table-column prop="name" label="字段" align="center">
- <template slot-scope="{row}">
- <el-select v-model="row.name">
- <el-option v-for="item in advancedQueryColumns" :label="item.label" :value="item.value" :key="item.value"></el-option>
- </el-select>
- </template>
- </el-table-column>
- <el-table-column prop="order" label="排序" align="center">
- <template slot-scope="{row}">
- <el-select v-model="row.order">
- <el-option label="降序" value="desc">
- </el-option>
- <el-option label="升序" value="asc">
- </el-option>
- </el-select>
- </template>
- </el-table-column>
- <el-table-column width="60" align="center">
- <template slot-scope="{ row, column, $index }">
- <el-button @click="removeSortField($index)" size="small" type="text">删除</el-button>
- </template>
- </el-table-column>
- </el-table>
- <span slot="footer" class="dialog-footer">
- <el-button @click="tableSortQuery" :loading="$store.state.fetchingData">确定</el-button>
- </span>
- </el-dialog>
- <el-dialog title="查看图片" :visible.sync="imageDialogVisible" size="small">
- <img width="100%" :src="imgSrc" alt="">
- </el-dialog>
- </div>
- </template>
- <script>
- import { mapState } from 'vuex'
- import { format } from 'date-fns'
- import zh from 'date-fns/locale/zh_cn'
- export default {
- name: 'AimPlaceContents',
- // props:{
- // ownedLandMarkId(){
- // type:Number,
- // }
- // },
- created() {
- this.getData();
- },
- data() {
- return {
- totalNumber: 0,
- totalPage: 10,
- currentPage: 1,
- pageSize: 20,
- tableData: [],
- filter1: '',
- filter2: '',
- tableColumns: [
- {
- label: 'ID',
- value: 'id',
- show: true
- },
- {
- label: '名称',
- value: 'name',
- show: true
- },
- {
- label: '类别',
- value: 'type',
- show: true
- },
- {
- label: '所属地标ID',
- value: 'ownedLandMarkId',
- show: true
- },
- {
- label: 'AR内容组ID',
- value: 'arContentGroupId',
- show: true
- },
- {
- label: 'ArKit坐标X',
- value: 'arKitPosX',
- show: true
- },
- {
- label: 'ArKit坐标Y',
- value: 'arKitPosY',
- show: true
- },
- {
- label: 'ArKit坐标Z',
- value: 'arKitPosZ',
- show: true
- },
- {
- label: 'ArKit缩放',
- value: 'arKitScale',
- show: true
- },
- {
- label: 'ArKit角度',
- value: 'arKitAngle',
- show: true
- },
- {
- label: 'ArKit一定距离显示',
- value: 'arKitShowLenth',
- show: true
- },
- {
- label: 'Gyro坐标X',
- value: 'gyroPosX',
- show: true
- },
- {
- label: 'Gyro坐标Y',
- value: 'gyroPosY',
- show: true
- },
- {
- label: 'Gyro坐标Z',
- value: 'gyroPosZ',
- show: true
- },
- {
- label: 'Gyro缩放',
- value: 'gyroPosScale',
- show: true
- },
- {
- label: 'Gyro角度',
- value: 'gyroPosAngle',
- show: true
- },
- {
- label: 'Gyro一定距离显示',
- value: 'gyroPosShowLenth',
- show: true
- },
- {
- label: 'Gyro绑定识别图区域标记编号',
- value: 'vuforiaImageInfoAreaMarking',
- show: true
- },
- {
- label: '备注1',
- value: 'remark1',
- show: true
- },
- {
- label: '备注2',
- value: 'remark2',
- show: true
- },
- {
- label: '备注3',
- value: 'remark3',
- show: true
- },
- {
- label: '备注4',
- value: 'remark4',
- show: true
- },
- {
- label: '备注5',
- value: 'remark5',
- show: true
- },
- {
- label: '备注6',
- value: 'remark6',
- show: true
- },
- ],
- multipleMode: false,
- showAdvancedQueryDialog: false,
- advancedQueryFields: [],
- showTableSortDialog: false,
- tableSortFields: [],
- searchMethods: ['=', '!=', '>', '>=', '<', '<=', 'like'],
- advancedQueryColumns: [
- {
- label: 'ID',
- value: 'id'
- },
- {
- label: '名称',
- value: 'name'
- },
- {
- label: '类别',
- value: 'type'
- },
- {
- label: '所属地标ID',
- value: 'owned_land_mark_id'
- },
- {
- label: 'AR内容组ID',
- value: 'ar_content_group_id'
- },
- {
- label: 'ArKit坐标X',
- value: 'ar_kit_pos_x'
- },
- {
- label: 'ArKit坐标Y',
- value: 'ar_kit_pos_y'
- },
- {
- label: 'ArKit坐标Z',
- value: 'ar_kit_pos_z'
- },
- {
- label: 'ArKit缩放',
- value: 'ar_kit_scale'
- },
- {
- label: 'ArKit角度',
- value: 'ar_kit_angle'
- },
- {
- label: 'ArKit一定距离显示',
- value: 'ar_kit_show_lenth'
- },
- {
- label: 'Gyro坐标X',
- value: 'gyro_pos_x'
- },
- {
- label: 'Gyro坐标Y',
- value: 'gyro_pos_y'
- },
- {
- label: 'Gyro坐标Z',
- value: 'gyro_pos_z'
- },
- {
- label: 'Gyro缩放',
- value: 'gyro_pos_scale'
- },
- {
- label: 'Gyro角度',
- value: 'gyro_pos_angle'
- },
- {
- label: 'Gyro一定距离显示',
- value: 'gyro_pos_show_lenth'
- },
- {
- label: 'Gyro绑定识别图区域标记编号',
- value: 'vuforia_image_info_area_marking'
- },
- {
- label: '备注1',
- value: 'remark1'
- },
- {
- label: '备注2',
- value: 'remark2'
- },
- {
- label: '备注3',
- value: 'remark3'
- },
- {
- label: '备注4',
- value: 'remark4'
- },
- {
- label: '备注5',
- value: 'remark5'
- },
- {
- label: '备注6',
- value: 'remark6'
- },
- ],
- advancedQuerySearchKey: '',
- orderByStr: '',
- imgSrc: '',
- imageDialogVisible: false,
- }
- },
- computed: {
- ...mapState(['tableHeight']),
- selection() {
- return this.$refs.table.selection.map(i => i.id);
- }
- },
- methods: {
- pageSizeChange(size) {
- this.currentPage = 1;
- this.pageSize = size;
- this.getData();
- },
- currentPageChange(page) {
- this.currentPage = page;
- this.getData();
- },
- getData() {
- var data = {
- currentPage: this.currentPage,
- pageNumber: this.pageSize,
- searchKey: this.filter1,
- advancedQuery: this.advancedQuerySearchKey,
- orderByStr: this.orderByStr,
- ownedLandMarkId: this.$route.query.id
- }
- // if (this.$route.query.column) {
- // var tempColumn = this.$route.query.column;
- // data[tempColumn.split(',')[1]] = tempColumn.split(',')[0];
- // }
- this.$http.get({
- url: '/aimPlaceContent/page',
- data: data
- }).then(res => {
- if (res.success) {
- this.totalNumber = res.data.page.totalNumber;
- this.tableData = res.data.pp;
- }
- })
- },
- isColumnShow(column) {
- var row = this.tableColumns.find(i => i.value === column);
- return row ? row.show : false;
- },
- toggleMultipleMode(multipleMode) {
- this.multipleMode = multipleMode;
- if (!multipleMode) {
- this.$refs.table.clearSelection();
- }
- },
- editRow(row) {
- this.$router.push({
- path: '/aimPlaceContent',
- query: {
- id: row.id,
- column: this.$route.query.column,
- }
- })
- },
- operation1() {
- this.$notify({
- title: '提示',
- message: this.selection
- });
- },
- operation2() {
- this.$message('操作2');
- },
- addField() {
- this.advancedQueryFields.push({
- link: 'AND',
- name: '',
- searchMethod: '=',
- value: '',
- });
- },
- removeField(i) {
- if (this.advancedQueryFields.length > 0) {
- this.advancedQueryFields.splice(i, 1);
- }
- },
- advancedQuery() {
- this.advancedQuerySearchKey = '';
- if (this.advancedQueryFields.length > 0) {
- var templist = [];
- this.advancedQueryFields.forEach(item => {
- if (item.link && item.name && item.searchMethod && item.value) {
- var tempItem = item.link + '_,' + item.name + '_,' + item.searchMethod + '_,' + item.value;
- templist.push(tempItem);
- }
- })
- if (templist.length > 0) {
- this.advancedQuerySearchKey = templist.join('_;');
- }
- }
- this.getData();
- this.showAdvancedQueryDialog = false;
- },
- addSortField() {
- this.tableSortFields.push({
- name: '',
- order: 'asc',
- });
- },
- removeSortField(i) {
- if (this.tableSortFields.length > 0) {
- this.tableSortFields.splice(i, 1);
- }
- },
- tableSortQuery() {
- this.orderByStr = '';
- if (this.tableSortFields.length > 0) {
- var templist = [];
- this.tableSortFields.forEach(item => {
- if (item.name && item.order) {
- var tempItem = item.name + '_,' + item.order;
- templist.push(tempItem);
- }
- })
- if (templist.length > 0) {
- this.orderByStr = templist.join('_;');
- }
- }
- this.getData();
- this.showTableSortDialog = false;
- },
- exportExcel() {
- window.location.href = this.$baseUrl + "/aimPlaceContent/exportExcel?searchKey="
- + this.filter1 + "&advancedQuery=" + this.advancedQuerySearchKey + "&orderByStr=" + this.orderByStr;
- },
- searchData() {
- this.currentPage = 1;
- this.getData();
- },
- deleteRow(row) {
- this.$alert('删除将无法恢复,确认要删除么?', '警告', { type: 'error' }).then(() => {
- return this.$http.post({
- url: '/aimPlaceContent/del',
- data: { id: row.id }
- })
- }).then(() => {
- this.$message.success('删除成功');
- this.getData();
- }).catch(action => {
- if (action === 'cancel') {
- this.$message.info('删除取消');
- } else {
- this.$message.error('删除失败');
- }
- })
- },
- DateTimeFormatter(row, column, cellValue) {
- if (cellValue) {
- return format(cellValue, 'YYYY/MM/DD HH:mm', { locale: zh })
- }
- },
- DateFormatter(row, column, cellValue) {
- if (cellValue) {
- return format(cellValue, 'YYYY/MM/DD', { locale: zh })
- }
- },
- showImg(img) {
- this.imgSrc = img;
- this.imageDialogVisible = true;
- },
- }
- }
- </script>
- <style lang="less" scoped>
- </style>
|