| | |
| | | # 页面标题 |
| | | VUE_APP_TITLE = 档案管理系统 |
| | | VUE_APP_TITLE = 城市建设档案管理系统 |
| | | |
| | | # 开发环境配置 |
| | | ENV = 'development' |
| | |
| | | # 页面标题 |
| | | VUE_APP_TITLE = 档案管理系统 |
| | | VUE_APP_TITLE = 城市建设档案管理系统 |
| | | |
| | | # 生产环境配置 |
| | | ENV = 'production' |
| | |
| | | "axios": "0.28.1", |
| | | "clipboard": "2.0.8", |
| | | "core-js": "3.37.1", |
| | | "echarts": "5.4.0", |
| | | "echarts": "^5.4.0", |
| | | "element-ui": "2.15.14", |
| | | "file-saver": "2.0.5", |
| | | "fuse.js": "6.4.3", |
New file |
| | |
| | | import request from '@/utils/request' |
| | | |
| | | |
| | | |
| | | // 导出档案 |
| | | export function archiveAllExport(query) { |
| | | return request({ |
| | | url: '/system/archiveAllExport/export', |
| | | method: 'post', |
| | | |
| | | params: query |
| | | }) |
| | | } |
| | |
| | | import request from '@/utils/request' |
| | | |
| | | |
| | | // 查询【请填写功能名称】列表 |
| | | export function listArchiverecordstouserStatistic(query) { |
| | | return request({ |
| | | url: '/system/archiverecordstouser/listArToUser', |
| | | method: 'get', |
| | | params: query |
| | | }) |
| | | } |
| | | |
| | | |
| | | |
| | | |
| | | // 查询【请填写功能名称】列表 |
| | | export function listArchiverecordstouser(query) { |
| | | return request({ |
| | |
| | | import request from '@/utils/request' |
| | | //统计分析结果 |
| | | export function statisticInfo() |
| | | { |
| | | return request({ |
| | | url: '/system/records/analysisRes', |
| | | method: 'get', |
| | | }) |
| | | } |
| | | //更新状态 |
| | | export function updateStatusById(id) |
| | | { |
| | | return request({ |
| | | url: '/system/records/updateStatusById/' + id, |
| | | method: 'get', |
| | | // data: data |
| | | }) |
| | | } |
| | | |
| | | // 查询档案记录列表 |
| | | export function listRecords(query) { |
| | |
| | | import DictTag from '@/components/DictTag' |
| | | // 字典数据组件 |
| | | import DictData from '@/components/DictData' |
| | | import * as echarts from 'echarts' |
| | | |
| | | // 全局注册为$echarts |
| | | Vue.prototype.$echarts = echarts |
| | | // 全局方法挂载 |
| | | Vue.prototype.getDicts = getDicts |
| | | Vue.prototype.getConfigKey = getConfigKey |
New file |
| | |
| | | <template> |
| | | <div class="app-container"> |
| | | <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px"> |
| | | <el-form-item label="档案号" prop="recordId"> |
| | | <el-input |
| | | v-model="queryParams.recordId" |
| | | placeholder="请输入档案号" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="发文号" prop="inquiryNumber"> |
| | | <el-input |
| | | v-model="queryParams.inquiryNumber" |
| | | placeholder="请输入发文号" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="案卷题名" prop="caseTitle"> |
| | | <el-input |
| | | v-model="queryParams.caseTitle" |
| | | placeholder="请输入案卷题名" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="公开属性" prop="publicAttribute"> |
| | | <el-select |
| | | v-model="queryParams.publicAttribute" |
| | | placeholder="请选择公开属性" |
| | | clearable |
| | | > |
| | | <el-option |
| | | v-for="item in publicAttributeOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="编制单位" prop="preparationUnit"> |
| | | <el-input |
| | | v-model="queryParams.preparationUnit" |
| | | placeholder="请输入编制单位" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="编制日期" prop="preparationDate"> |
| | | <el-date-picker clearable |
| | | v-model="queryParams.preparationDate" |
| | | type="date" |
| | | value-format="yyyy-MM-dd" |
| | | placeholder="请选择编制日期"> |
| | | </el-date-picker> |
| | | </el-form-item> |
| | | <el-form-item label="保管期限" prop="retentionPeriod"> |
| | | <el-select |
| | | v-model="queryParams.retentionPeriod" |
| | | placeholder="请选择保管期限" |
| | | clearable |
| | | > |
| | | <el-option |
| | | v-for="item in retentionPeriodOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="密级" prop="securityClassification"> |
| | | |
| | | |
| | | <el-select |
| | | v-model="queryParams.securityClassification" |
| | | placeholder="请选择密级" |
| | | clearable |
| | | > |
| | | <el-option |
| | | v-for="item in securityLevelOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | |
| | | </el-form-item> |
| | | <el-form-item label="案卷页数" prop="pageCount"> |
| | | <el-input |
| | | v-model="queryParams.pageCount" |
| | | placeholder="请输入案卷页数" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="立案号" prop="filingNumber"> |
| | | <el-input |
| | | v-model="queryParams.filingNumber" |
| | | placeholder="请输入立案号" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | |
| | | |
| | | |
| | | <el-form-item label="缩微号" prop="microfilmNumber"> |
| | | <el-input |
| | | v-model="queryParams.microfilmNumber" |
| | | placeholder="请输入缩微号" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="历史相关发文号" prop="historicalReferenceNumber"> |
| | | <el-input |
| | | v-model="queryParams.historicalReferenceNumber" |
| | | placeholder="请输入历史相关发文号" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item> |
| | | <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button> |
| | | <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button> |
| | | </el-form-item> |
| | | </el-form> |
| | | |
| | | <el-row :gutter="10" class="mb8"> |
| | | <el-col :span="1.5"> |
| | | <el-button |
| | | type="primary" |
| | | plain |
| | | icon="el-icon-plus" |
| | | size="mini" |
| | | @click="handleAdd" |
| | | v-hasPermi="['system:records:add']" |
| | | >新增</el-button> |
| | | </el-col> |
| | | <el-col :span="1.5"> |
| | | <el-button |
| | | type="success" |
| | | plain |
| | | icon="el-icon-edit" |
| | | size="mini" |
| | | :disabled="single" |
| | | @click="handleUpdate" |
| | | v-hasPermi="['system:records:edit']" |
| | | >修改</el-button> |
| | | </el-col> |
| | | <el-col :span="1.5"> |
| | | <el-button |
| | | type="danger" |
| | | plain |
| | | icon="el-icon-delete" |
| | | size="mini" |
| | | :disabled="multiple" |
| | | @click="handleDelete" |
| | | v-hasPermi="['system:records:remove']" |
| | | >删除</el-button> |
| | | </el-col> |
| | | <el-col :span="1.5"> |
| | | <el-button |
| | | type="warning" |
| | | plain |
| | | icon="el-icon-download" |
| | | size="mini" |
| | | @click="handleExport" |
| | | >导出ISO包</el-button> |
| | | </el-col> |
| | | <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar> |
| | | </el-row> |
| | | |
| | | <el-table v-loading="loading" :data="recordsList" @selection-change="handleSelectionChange"> |
| | | <el-table-column type="selection" width="55" align="center" /> |
| | | <!-- <el-table-column label="${comment}" align="center" prop="id" /> --> |
| | | <el-table-column label="档案号" align="center" prop="recordId" /> |
| | | <el-table-column label="发文号" align="center" prop="inquiryNumber" /> |
| | | <el-table-column label="项目名称" align="center" prop="everyProjectName" show-overflow-tooltip /> |
| | | |
| | | <el-table-column label="案卷题名" align="center" prop="caseTitle" show-overflow-tooltip /> |
| | | <el-table-column label="公开属性" align="center" prop="publicAttribute" /> |
| | | <el-table-column label="编制单位" align="center" prop="preparationUnit" /> |
| | | |
| | | |
| | | |
| | | <el-table-column label="操作" align="center" width="190" class-name="small-padding fixed-width"> |
| | | <template slot-scope="scope"> |
| | | <el-button |
| | | :disabled="scope.row.recordStatus !== '录入完成'" |
| | | size="mini" |
| | | type="text" |
| | | icon="el-icon-edit" |
| | | @click="handleExportInfo(scope.row)" |
| | | v-hasPermi="['system:records:edit']" |
| | | >导出档案</el-button> |
| | | |
| | | <el-button |
| | | |
| | | |
| | | size="mini" |
| | | type="text" |
| | | icon="el-icon-edit" |
| | | @click="handleCheck(scope.row)" |
| | | >查看</el-button> |
| | | |
| | | </template> |
| | | </el-table-column> |
| | | </el-table> |
| | | |
| | | <pagination |
| | | v-show="total>0" |
| | | :total="total" |
| | | :page.sync="queryParams.pageNum" |
| | | :limit.sync="queryParams.pageSize" |
| | | @pagination="getList" |
| | | /> |
| | | <!-- 查看数据按钮 --> |
| | | <el-dialog :title="title" :visible.sync="open_check" width="800px" append-to-body> |
| | | <el-form ref="form" :model="form" :rules="rules" label-width="120px"> |
| | | <el-form-item label="档案号" > |
| | | |
| | | |
| | | <el-row :gutter="8"> |
| | | <el-col :span="6"> |
| | | <el-select |
| | | v-model="form.recordType" |
| | | placeholder="选择档案类型" |
| | | disabled |
| | | @change="handleRecordTypeChange" |
| | | > |
| | | <el-option |
| | | v-for="item in recordTypeOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-col> |
| | | <el-col :span="6"> |
| | | <el-input |
| | | v-model="form.recordYear" |
| | | placeholder="输入年份" |
| | | disabled |
| | | |
| | | |
| | | @input="generateRecordId" |
| | | /> |
| | | </el-col> |
| | | <el-col :span="6"> |
| | | <el-input |
| | | v-model="form.recordSeq" |
| | | placeholder="自动生成" |
| | | disabled |
| | | /> |
| | | </el-col> |
| | | </el-row> |
| | | </el-form-item> |
| | | <el-form-item label="发文号" prop="inquiryNumber"> |
| | | <el-input v-model="form.inquiryNumber" placeholder="请输入发问号" disabled/> |
| | | </el-form-item> |
| | | <el-form-item label="建设项目名称" prop="projectName"> |
| | | <el-input v-model="form.projectName" placeholder="请输入建设项目名称" disabled/> |
| | | </el-form-item> |
| | | <div v-if="vis"> |
| | | <el-form-item label="案卷题名" prop="caseTitle"> |
| | | <el-input v-model="form.caseTitle" placeholder="请输入案卷题名" disabled/> |
| | | </el-form-item> |
| | | <el-form-item label="公开属性" prop="publicAttribute"> |
| | | <el-input v-model="form.publicAttribute" placeholder="请输入公开属性" disabled /> |
| | | </el-form-item> |
| | | <el-form-item label="编制单位" prop="preparationUnit"> |
| | | <el-input v-model="form.preparationUnit" placeholder="请输入编制单位" disabled/> |
| | | </el-form-item> |
| | | <el-form-item label="编制日期" prop="preparationDate"> |
| | | <el-date-picker clearable |
| | | v-model="form.preparationDate" |
| | | type="date" |
| | | disabled |
| | | |
| | | value-format="yyyy-MM-dd" |
| | | placeholder="请选择编制日期"> |
| | | </el-date-picker> |
| | | </el-form-item> |
| | | <el-form-item label="保管期限" prop="retentionPeriod"> |
| | | <el-input v-model="form.retentionPeriod" placeholder="请输入保管期限" disabled/> |
| | | </el-form-item> |
| | | <el-form-item label="密级" prop="securityClassification"> |
| | | <el-input v-model="form.securityClassification" placeholder="请输入密级" disabled/> |
| | | </el-form-item> |
| | | <el-form-item label="案卷页数" prop="pageCount"> |
| | | <el-input v-model="form.pageCount" placeholder="请输入案卷页数" disabled/> |
| | | </el-form-item> |
| | | <el-form-item label="立案号" prop="filingNumber"> |
| | | <el-input v-model="form.filingNumber" placeholder="请输入立案号" disabled/> |
| | | </el-form-item> |
| | | <el-form-item label="建设单位" prop="constructionUnit"> |
| | | <el-input v-model="form.constructionUnit" placeholder="请输入建设单位" disabled /> |
| | | </el-form-item> |
| | | <el-form-item label="建设地址" prop="constructionAddress"> |
| | | <el-input v-model="form.constructionAddress" placeholder="请输入建设地址" disabled/> |
| | | </el-form-item> |
| | | |
| | | <el-form-item label="项目编号" prop="projectNumber"> |
| | | <el-input v-model="form.projectNumber" placeholder="请输入项目编号" disabled/> |
| | | </el-form-item> |
| | | <el-form-item label="扫描加工公司" prop="scanningCompany"> |
| | | <el-input v-model="form.scanningCompany" placeholder="请输入扫描加工公司" disabled/> |
| | | </el-form-item> |
| | | <el-form-item label="档案管(室)号" prop="archiveRoomNumber"> |
| | | <el-input v-model="form.archiveRoomNumber" placeholder="请输入档案管(室)号" disabled/> |
| | | </el-form-item> |
| | | <el-form-item label="缩微号" prop="microfilmNumber"> |
| | | <el-input v-model="form.microfilmNumber" placeholder="请输入缩微号" disabled/> |
| | | </el-form-item> |
| | | <el-form-item label="备注" prop="remarks"> |
| | | <el-input v-model="form.remarks" type="textarea" placeholder="请输入内容" disabled/> |
| | | </el-form-item> |
| | | <el-form-item label="历史相关发文号" prop="historicalReferenceNumber"> |
| | | <el-input v-model="form.historicalReferenceNumber" placeholder="请输入历史相关发文号" disabled/> |
| | | </el-form-item> |
| | | </div> |
| | | </el-form> |
| | | |
| | | </el-dialog> |
| | | <!-- 添加或修改档案记录对话框 --> |
| | | <el-dialog :title="title" :visible.sync="open" width="900px" append-to-body> |
| | | <el-form ref="form" :model="form" :rules="rules" label-width="120px"> |
| | | <el-form-item label="档案号" prop="recordId"> |
| | | |
| | | <el-row :gutter="8"> |
| | | <el-col :span="6"> |
| | | <el-select |
| | | |
| | | v-model="form.recordType" |
| | | placeholder="选择档案类型" |
| | | @change="handleRecordTypeChange" |
| | | :disabled="userId!=1" > |
| | | <el-option |
| | | v-for="item in recordTypeOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-col> |
| | | |
| | | |
| | | <el-col :span="6"> |
| | | <el-select |
| | | |
| | | v-model="form.recordZone" |
| | | placeholder="选择地区" |
| | | @change="handleRecordTypeChange" |
| | | :disabled="userId!=1" > |
| | | <el-option |
| | | v-for="item in zoneTypeOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-col> |
| | | <el-col :span="4"> |
| | | <el-input |
| | | v-model="form.recordYear" |
| | | placeholder="输入年份" |
| | | @input="generateRecordId" |
| | | :disabled="userId!=1" |
| | | /> |
| | | </el-col> |
| | | <el-col :span="4"> |
| | | <el-input |
| | | v-model="form.recordSeq" |
| | | placeholder="自动生成" |
| | | disabled |
| | | /> |
| | | </el-col> |
| | | </el-row> |
| | | </el-form-item> |
| | | <el-form-item label="发文号" prop="inquiryNumber"> |
| | | <el-input v-model="form.inquiryNumber" placeholder="请输入发问号" :disabled="userId!=1" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="项目名称" prop="everyProjectName"> |
| | | <el-select |
| | | v-model="form.everyProjectName" |
| | | placeholder="请选择项目名称" |
| | | |
| | | :disabled="userId!=1" |
| | | > |
| | | <el-option |
| | | v-for="item in projectOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | |
| | | |
| | | |
| | | <div v-if="vis"> |
| | | <el-form-item label="案卷题名" prop="caseTitle"> |
| | | <el-input v-model="form.caseTitle" placeholder="请输入案卷题名" /> |
| | | </el-form-item> |
| | | <el-form-item label="公开属性" prop="publicAttribute"> |
| | | |
| | | |
| | | <el-select |
| | | v-model="form.publicAttribute" |
| | | placeholder="请选择公开属性" |
| | | clearable |
| | | > |
| | | <el-option |
| | | v-for="item in publicAttributeOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | |
| | | <el-form-item label="编制单位" prop="preparationUnit"> |
| | | <el-input v-model="form.preparationUnit" placeholder="请输入编制单位" /> |
| | | </el-form-item> |
| | | <el-form-item label="编制日期" prop="preparationDate"> |
| | | <el-date-picker clearable |
| | | v-model="form.preparationDate" |
| | | type="date" |
| | | value-format="yyyy-MM-dd" |
| | | placeholder="请选择编制日期"> |
| | | </el-date-picker> |
| | | </el-form-item> |
| | | <el-form-item label="保管期限" prop="retentionPeriod"> |
| | | <el-select |
| | | v-model="form.retentionPeriod" |
| | | placeholder="请选择保管期限" |
| | | clearable |
| | | > |
| | | <el-option |
| | | v-for="item in retentionPeriodOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="密级" prop="securityClassification"> |
| | | <el-select |
| | | v-model="form.securityClassification" |
| | | placeholder="请选择密级" |
| | | clearable |
| | | > |
| | | <el-option |
| | | v-for="item in securityLevelOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="案卷页数" prop="pageCount"> |
| | | <el-input v-model="form.pageCount" placeholder="请输入案卷页数" /> |
| | | </el-form-item> |
| | | <el-form-item label="立案号" prop="filingNumber"> |
| | | <el-input v-model="form.filingNumber" placeholder="请输入立案号" /> |
| | | </el-form-item> |
| | | <el-form-item label="建设单位" prop="constructionUnit"> |
| | | <el-input v-model="form.constructionUnit" placeholder="请输入建设单位" /> |
| | | </el-form-item> |
| | | <el-form-item label="建设地址" prop="constructionAddress"> |
| | | <el-input v-model="form.constructionAddress" placeholder="请输入建设地址" /> |
| | | </el-form-item> |
| | | <el-form-item label="建设项目名称" prop="projectName"> |
| | | <el-input v-model="form.projectName" placeholder="请输入建设项目名称" :disabled="userId!=1"/> |
| | | </el-form-item> |
| | | <el-form-item label="项目编号" prop="projectNumber"> |
| | | <el-input v-model="form.projectNumber" placeholder="请输入项目编号" /> |
| | | </el-form-item> |
| | | <el-form-item label="扫描加工公司" prop="scanningCompany"> |
| | | <el-input v-model="form.scanningCompany" placeholder="请输入扫描加工公司" /> |
| | | </el-form-item> |
| | | <el-form-item label="档案管(室)号" prop="archiveRoomNumber"> |
| | | <el-input v-model="form.archiveRoomNumber" placeholder="请输入档案管(室)号" /> |
| | | </el-form-item> |
| | | <el-form-item label="缩微号" prop="microfilmNumber"> |
| | | <el-input v-model="form.microfilmNumber" placeholder="请输入缩微号" /> |
| | | </el-form-item> |
| | | <el-form-item label="备注" prop="remarks"> |
| | | <el-input v-model="form.remarks" type="textarea" placeholder="请输入内容" /> |
| | | </el-form-item> |
| | | <el-form-item label="历史相关发文号" prop="historicalReferenceNumber"> |
| | | <el-input v-model="form.historicalReferenceNumber" placeholder="请输入历史相关发文号" /> |
| | | </el-form-item> |
| | | </div> |
| | | </el-form> |
| | | <div slot="footer" class="dialog-footer"> |
| | | <el-button type="primary" @click="submitForm">确 定</el-button> |
| | | <el-button @click="cancel">取 消</el-button> |
| | | </div> |
| | | </el-dialog> |
| | | </div> |
| | | </template> |
| | | |
| | | <script> |
| | | import { listRecords,getMaxId, getRecords, delRecords, addRecords, updateRecords } from "@/api/system/records" |
| | | import { listAllCategory } from "@/api/system/category" |
| | | import { listName } from "@/api/system/projectName" |
| | | import { listPlaceName } from "@/api/system/placeName" |
| | | import { archiveAllExport } from "@/api/system/archiveEx" |
| | | export default { |
| | | name: "Records", |
| | | data() { |
| | | return { |
| | | open_check: false, |
| | | securityLevelOptions: [ |
| | | { value: '秘密', label: '秘密' }, |
| | | { value: '普通', label: '普通' } |
| | | ], |
| | | maxId: 0, |
| | | // 项目名称选项 |
| | | projectOptions: [], |
| | | // 档案类型选项 |
| | | recordTypeOptions: [], |
| | | //地区类型 |
| | | zoneTypeOptions: [], |
| | | // 保管期限选项 |
| | | retentionPeriodOptions: [ |
| | | { value: "10年", label: "10年" }, |
| | | { value: "30年", label: "30年" }, |
| | | { value: "永久", label: "永久" } |
| | | ], |
| | | // 公开属性选项 |
| | | publicAttributeOptions: [ |
| | | { value: "主动公开", label: "主动公开" }, |
| | | { value: "依申请公开", label: "依申请公开" }, |
| | | { value: "免予公开", label: "免予公开" } |
| | | ], |
| | | amio: false, |
| | | userId: null, |
| | | vis: true, |
| | | // 遮罩层 |
| | | loading: true, |
| | | // 选中数组 |
| | | ids: [], |
| | | // 非单个禁用 |
| | | single: true, |
| | | // 非多个禁用 |
| | | multiple: true, |
| | | // 显示搜索条件 |
| | | showSearch: true, |
| | | // 总条数 |
| | | total: 0, |
| | | // 档案记录表格数据 |
| | | recordsList: [], |
| | | // 弹出层标题 |
| | | title: "", |
| | | // 是否显示弹出层 |
| | | open: false, |
| | | // 查询参数 |
| | | queryParams: { |
| | | pageNum: 1, |
| | | pageSize: 10, |
| | | recordId: null, |
| | | inquiryNumber: null, |
| | | everyProjectName: null, |
| | | caseTitle: null, |
| | | publicAttribute: null, |
| | | preparationUnit: null, |
| | | preparationDate: null, |
| | | retentionPeriod: null, |
| | | securityClassification: null, |
| | | pageCount: null, |
| | | filingNumber: null, |
| | | constructionUnit: null, |
| | | constructionAddress: null, |
| | | projectName: null, |
| | | projectNumber: null, |
| | | scanningCompany: null, |
| | | archiveRoomNumber: null, |
| | | microfilmNumber: null, |
| | | remarks: null, |
| | | historicalReferenceNumber: null, |
| | | recordStatus: null |
| | | }, |
| | | // 表单参数 |
| | | form: { |
| | | recordSeq: '', |
| | | }, |
| | | // 表单校验 |
| | | rules: { |
| | | recordId: [ |
| | | { required: true, message: "档案号不能为空", trigger: "blur" } |
| | | ], |
| | | inquiryNumber: [ |
| | | { required: true, message: "发问号不能为空", trigger: "blur" } |
| | | ], |
| | | everyProjectName: [ |
| | | { required: true, message: "项目名称不能为空", trigger: ['change', 'blur']} |
| | | ], |
| | | } |
| | | } |
| | | }, |
| | | created() { |
| | | |
| | | this.userId = this.$store.state.user.id; |
| | | |
| | | // 获取用户角色 |
| | | this.getId() |
| | | this.getRecordTypes() |
| | | this.getZoneOptions() |
| | | this.fetchProjectOptions() |
| | | this.getList() |
| | | }, |
| | | methods: { |
| | | handleExportInfo(row) { |
| | | alert(row.id) |
| | | alert(row.recordId) |
| | | // alert(row.docum) |
| | | // archiveAllExport({'id':row.id}).then(response => { |
| | | // console.log(response) |
| | | // }) |
| | | var qu = {'id':row.id} |
| | | var id = row.id |
| | | this.download('system/archiveAllExport/export/'+id, '',`records_${new Date().getTime()}.zip`) |
| | | }, |
| | | getId() |
| | | { |
| | | var _this = this; |
| | | getMaxId().then(response=>{ |
| | | // alert(213) |
| | | console.log(response) |
| | | _this.maxId = String(response.data).padStart(4, '0') |
| | | |
| | | _this.$set(_this.form, 'recordSeq', _this.maxId) // |
| | | |
| | | // alert(this.maxId) |
| | | }) |
| | | }, |
| | | async getZoneOptions() |
| | | { |
| | | try { |
| | | const response = await listPlaceName() |
| | | console.log(response) |
| | | // alert(134) |
| | | this.zoneTypeOptions = response.data.data.map(item => ({ |
| | | value: item.nnumber, |
| | | label: item.name |
| | | })) |
| | | } catch (error) { |
| | | console.error('获取项目名称列表失败:', error) |
| | | } |
| | | }, |
| | | async fetchProjectOptions() { |
| | | try { |
| | | const response = await listName() |
| | | console.log(response) |
| | | this.projectOptions = response.data.data.map(item => ({ |
| | | value: item.name, |
| | | label: item.name |
| | | })) |
| | | } catch (error) { |
| | | console.error('获取项目名称列表失败:', error) |
| | | } |
| | | }, |
| | | /** 获取档案类型列表 */ |
| | | getRecordTypes() { |
| | | return new Promise((resolve) => { |
| | | listAllCategory().then(response => { |
| | | this.recordTypeOptions = response.data.map(item => ({ |
| | | value: item.numb, |
| | | label: item.nname |
| | | })) |
| | | resolve() |
| | | }) |
| | | }) |
| | | }, |
| | | |
| | | /** 档案类型变更处理 */ |
| | | handleRecordTypeChange() { |
| | | this.generateRecordId() |
| | | }, |
| | | |
| | | /** 生成档案号 */ |
| | | generateRecordId() { |
| | | |
| | | if (this.form.recordType && this.form.recordZone && this.form.recordYear) { |
| | | |
| | | // getNextRecordId({ |
| | | // type: this.form.recordType, |
| | | // year: this.form.recordYear |
| | | // }).then(response => { |
| | | // this.form.recordSeq = response.data.seq |
| | | this.form.recordId = `${this.form.recordType}-${this.form.recordZone}-${this.form.recordYear}-${this.form.recordSeq}` |
| | | // }) |
| | | } |
| | | }, |
| | | /** 查询档案记录列表 */ |
| | | getList() { |
| | | this.loading = true |
| | | console.log(this.queryParams) |
| | | console.log("--------------") |
| | | this.queryParams.recordStatus = '录入完成' |
| | | listRecords(this.queryParams).then(response => { |
| | | |
| | | console.log(response) |
| | | this.recordsList = response.data.data |
| | | this.total = response.data.total |
| | | this.loading = false |
| | | }) |
| | | }, |
| | | // 取消按钮 |
| | | cancel() { |
| | | this.open = false |
| | | this.reset() |
| | | }, |
| | | // 表单重置 |
| | | reset() { |
| | | this.form = { |
| | | id: null, |
| | | recordId: null, |
| | | inquiryNumber: null, |
| | | everyProjectName: null, |
| | | caseTitle: null, |
| | | publicAttribute: null, |
| | | preparationUnit: null, |
| | | preparationDate: null, |
| | | retentionPeriod: null, |
| | | securityClassification: null, |
| | | pageCount: null, |
| | | filingNumber: null, |
| | | constructionUnit: null, |
| | | constructionAddress: null, |
| | | projectName: null, |
| | | projectNumber: null, |
| | | scanningCompany: null, |
| | | archiveRoomNumber: null, |
| | | microfilmNumber: null, |
| | | remarks: null, |
| | | historicalReferenceNumber: null, |
| | | recordSeq:null |
| | | } |
| | | this.resetForm("form") |
| | | }, |
| | | /** 搜索按钮操作 */ |
| | | handleQuery() { |
| | | this.queryParams.pageNum = 1 |
| | | this.getList() |
| | | }, |
| | | /** 重置按钮操作 */ |
| | | resetQuery() { |
| | | this.resetForm("queryForm") |
| | | this.handleQuery() |
| | | }, |
| | | // 多选框选中数据 |
| | | handleSelectionChange(selection) { |
| | | this.ids = selection.map(item => item.id) |
| | | this.single = selection.length!==1 |
| | | this.multiple = !selection.length |
| | | }, |
| | | /** 新增按钮操作 */ |
| | | handleAdd() { |
| | | this.reset() |
| | | this.form.recordSeq = this.maxId |
| | | this.open = true |
| | | this.vis = false; |
| | | this.title = "添加档案记录" |
| | | }, |
| | | /*查看详情*/ |
| | | handleInfo(row) |
| | | { |
| | | |
| | | var mid = row.id |
| | | const roleId = 2 |
| | | // alert(mid) |
| | | var recordId = mid |
| | | // this.$router.push("/archiveManager/infoManagerAu/user/" + roleId+"/"+recordId) |
| | | this.$router.push("/archiveManager/infoManagerAu/archiveMaterialManager/" + recordId) |
| | | |
| | | }, |
| | | /** 修改按钮操作 */ |
| | | handleUpdate(row) { |
| | | |
| | | this.reset() |
| | | if(this.userId===1) |
| | | this.vis = false; |
| | | const id = row.id || this.ids |
| | | getRecords(id).then(response => { |
| | | console.log(response) |
| | | console.log("----=============--------------") |
| | | this.form = response.data |
| | | // 确保recordTypeOptions已加载 |
| | | if(this.recordTypeOptions.length > 0) { |
| | | const recordParts = response.data.recordId.split('-') |
| | | this.$set(this.form, 'recordType', recordParts[0]) |
| | | this.$set(this.form, 'recordZone', recordParts[1]) |
| | | |
| | | this.$set(this.form, 'recordYear', recordParts[2]) |
| | | this.$set(this.form, 'recordSeq', recordParts[3]) |
| | | } |
| | | this.open = true |
| | | this.title = "修改档案记录" |
| | | }) |
| | | }, |
| | | /** 修改按钮操作 */ |
| | | handleCheck(row) { |
| | | |
| | | this.vis = true; |
| | | const id = row.id || this.ids |
| | | getRecords(id).then(response => { |
| | | console.log(response) |
| | | console.log("----=============--------------") |
| | | this.form = response.data |
| | | if(this.recordTypeOptions.length > 0) { |
| | | const recordParts = response.data.recordId.split('-') |
| | | this.$set(this.form, 'recordType', recordParts[0]) |
| | | this.$set(this.form, 'recordZone', recordParts[1]) |
| | | |
| | | this.$set(this.form, 'recordYear', recordParts[2]) |
| | | this.$set(this.form, 'recordSeq', recordParts[3]) |
| | | } |
| | | this.open_check = true |
| | | this.title = "查看档案记录" |
| | | }) |
| | | }, |
| | | |
| | | /** 提交按钮 */ |
| | | submitForm() { |
| | | this.$refs["form"].validate(valid => { |
| | | if (valid) { |
| | | if (this.form.id != null) { |
| | | updateRecords(this.form).then(response => { |
| | | this.$modal.msgSuccess("修改成功") |
| | | this.open = false |
| | | this.getList() |
| | | }) |
| | | } else { |
| | | console.log(this.form) |
| | | addRecords(this.form).then(response => { |
| | | this.$modal.msgSuccess("新增成功") |
| | | this.open = false |
| | | this.getId() |
| | | this.getList() |
| | | |
| | | |
| | | }) |
| | | } |
| | | } |
| | | }) |
| | | }, |
| | | // 更多操作触发 |
| | | handleCommand(command, row) { |
| | | |
| | | switch (command) { |
| | | case "handleDataScope": |
| | | this.handleDataScope(row) |
| | | break |
| | | case "handleAuthUser": |
| | | this.handleAuthUser(row) |
| | | break |
| | | default: |
| | | break |
| | | } |
| | | }, |
| | | /** 分配用户操作 */ |
| | | handleAuthUser: function(row) { |
| | | const roleId = 2 |
| | | var archiveRecordsId = row.recordId |
| | | // alert(roleId) |
| | | this.$router.push("/archiveManager/infoManagerAu/user/" + roleId+"/"+archiveRecordsId) |
| | | }, |
| | | /** 删除按钮操作 */ |
| | | handleDelete(row) { |
| | | const ids = row.id || this.ids |
| | | this.$modal.confirm('是否确认删除档案记录编号为"' + ids + '"的数据项?').then(function() { |
| | | return delRecords(ids) |
| | | }).then(() => { |
| | | this.getList() |
| | | this.$modal.msgSuccess("删除成功") |
| | | }).catch(() => {}) |
| | | }, |
| | | /** 导出按钮操作 */ |
| | | handleExport(row) { |
| | | alert(232) |
| | | const ids = row.id || this.ids |
| | | alert(ids) |
| | | if(ids=='') |
| | | { |
| | | this.$modal.msgError("请选择档案记录") |
| | | return |
| | | } |
| | | this.download('system/archiveAllExport/exportChooseArchive/'+ids, '', `records_${new Date().getTime()}.zip`) |
| | | } |
| | | } |
| | | } |
| | | </script> |
| | |
| | | <template> |
| | | <div class="app-container"> |
| | | <h2 class="title-border">添加案卷详细记录</h2> |
| | | <el-form ref="form" :model="form" :rules="rules" label-width="100px"> |
| | | <el-row> |
| | | <el-col :span="8"> |
| | | <el-form-item label="责任者" prop="creator"> |
| | | <el-input v-model="form.creator" placeholder="请输入责任者" /> |
| | | </el-form-item> |
| | | </el-col> |
| | | </el-row> |
| | | <el-row> |
| | | |
| | | <el-col :span="8"> |
| | | <el-form-item label="文件题名" prop="title"> |
| | | <el-input v-model="form.title" placeholder="请输入文件题名" /> |
| | | </el-form-item> |
| | | </el-col> |
| | | </el-row> |
| | | <el-form-item label="日期" prop="date"> |
| | | <!-- <el-date-picker clearable |
| | | v-model="form.date" |
| | | type="date" |
| | | value-format="yyyy-MM-dd" |
| | | placeholder="请选择日期"> |
| | | </el-date-picker> --> |
| | | <el-col :span="8"> |
| | | <el-input v-model="form.date" placeholder="请输入日期" /> |
| | | </el-col> |
| | | </el-form-item> |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | <!-- <el-form-item label="页次" prop="pageOrder"> |
| | | <el-input v-model="form.pageOrder" placeholder="请输入页次" /> |
| | | </el-form-item> --> |
| | | <el-form-item label="材料类型" prop="fileStyle"> |
| | | <el-select |
| | | v-model="form.fileStyle" |
| | | placeholder="请选择材料类型" |
| | | > |
| | | <el-option |
| | | v-for="item in fileStyleOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | |
| | | </el-form-item> |
| | | <el-form-item |
| | | label="页号" |
| | | prop="pageNumber" |
| | | v-if=" form.fileStyle !== '其他材料'" |
| | | > |
| | | <el-col :span="8"> |
| | | <el-input |
| | | v-model="form.pageNumber" |
| | | placeholder="请输入页号" |
| | | /></el-col> |
| | | </el-form-item> |
| | | <el-form-item label="所处阶段" prop="stage"> |
| | | <el-select |
| | | v-model="form.stage" |
| | | placeholder="请选择所处阶段" |
| | | > |
| | | <el-option |
| | | v-for="item in stageOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="公开属性" prop="publicity"> |
| | | <el-select |
| | | v-model="form.publicity" |
| | | placeholder="请选择公开属性" |
| | | > |
| | | <el-option |
| | | v-for="item in publicityOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | |
| | | <el-form-item label="是否为附件" prop="isAttachment"> |
| | | <el-select |
| | | v-model="form.isAttachment" |
| | | placeholder="请选择是否为附件" |
| | | > |
| | | <el-option |
| | | v-for="item in isAttachmentOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | |
| | | <el-form-item label="保管期限" prop="retentionPeriod"> |
| | | <el-select |
| | | v-model="form.retentionPeriod" |
| | | placeholder="请选择保管期限" |
| | | > |
| | | <el-option |
| | | v-for="item in retentionPeriodOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | |
| | | <!-- 对话框表单中的密级 --> |
| | | <el-form-item label="密级" prop="securityLevel"> |
| | | <el-select |
| | | v-model="form.securityLevel" |
| | | placeholder="请选择密级" |
| | | > |
| | | <el-option |
| | | v-for="item in securityLevelOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | |
| | | |
| | | |
| | | <el-form-item label="是否敏感" prop="isSensitive"> |
| | | <el-select |
| | | v-model="form.isSensitive" |
| | | placeholder="请输入是否敏感" |
| | | > |
| | | <el-option |
| | | v-for="item in isAttachmentOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="是否注销" prop="isCanceled"> |
| | | <el-select |
| | | v-model="form.isCanceled" |
| | | placeholder="请输入是否注销" |
| | | > |
| | | <el-option |
| | | v-for="item in isAttachmentOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | |
| | | |
| | | </el-form> |
| | | <div slot="footer" class="dialog-footer" @keydown.enter="submitForm"> |
| | | <el-button type="primary" @click="submitForm">确 定</el-button> |
| | | <el-button type="primary" @click="resetForms">重置</el-button> |
| | | |
| | | <el-button @click="cancel">取 消</el-button> |
| | | </div> |
| | | |
| | | |
| | | |
| | | <div class="title-border"></div> |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | <el-row :gutter="10" class="mb8"> |
| | | <el-col :span="1.5"> |
| | | <el-button |
| | | type="primary" |
| | | plain |
| | | icon="el-icon-plus" |
| | | size="mini" |
| | | @click="handleAdd" |
| | | v-hasPermi="['system:materials:add']" |
| | | >搜索</el-button> |
| | | </el-col> |
| | | <el-col :span="1.5"> |
| | | <el-button |
| | | type="success" |
| | | plain |
| | | icon="el-icon-edit" |
| | | size="mini" |
| | | :disabled="single" |
| | | @click="handleUpdate" |
| | | v-hasPermi="['system:materials:edit']" |
| | | >修改</el-button> |
| | | </el-col> |
| | | <el-col :span="1.5"> |
| | | <el-button |
| | | type="danger" |
| | | plain |
| | | icon="el-icon-delete" |
| | | size="mini" |
| | | :disabled="multiple" |
| | | @click="handleDelete" |
| | | v-hasPermi="['system:materials:remove']" |
| | | >删除</el-button> |
| | | </el-col> |
| | | <el-col :span="1.5"> |
| | | <el-button |
| | | type="warning" |
| | | plain |
| | | icon="el-icon-download" |
| | | size="mini" |
| | | @click="handleExport" |
| | | v-hasPermi="['system:materials:export']" |
| | | >导出</el-button> |
| | | <el-col :span="1.5"> |
| | | <el-button |
| | | type="success" |
| | | plain |
| | | icon="el-icon-edit" |
| | | size="mini" |
| | | @click="handleImport" |
| | | v-hasPermi="['system:materials:edit']" |
| | | >全部附件导入</el-button> |
| | | <!-- 在按钮下方添加导入对话框 --> |
| | | <el-dialog title="批量导入附件" :visible.sync="importDialogVisible" width="50%"> |
| | | <el-upload |
| | | class="upload-demo" |
| | | ref="upload" |
| | | :action="uploadUrl" |
| | | :headers="headers" |
| | | :data="uploadParams" |
| | | :on-success="handleSuccess" |
| | | :on-error="handleError" |
| | | :on-preview="handlePreview" |
| | | :on-remove="handleRemove" |
| | | :file-list="fileList" |
| | | :auto-upload="false" |
| | | multiple |
| | | accept=".jpg,.png" |
| | | > |
| | | <el-button slot="trigger" size="small" type="primary">选择文件</el-button> |
| | | <el-button style="margin-left: 10px;" size="small" type="success" @click="submitUpload">上传到服务器</el-button> |
| | | <div slot="tip" class="el-upload__tip">可上传PDF/DOC/XLS/JPG等格式文件,单个文件不超过50MB</div> |
| | | </el-upload> |
| | | </el-dialog> |
| | | </el-col> |
| | | |
| | | </el-col> |
| | | <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar> |
| | | </el-row> |
| | | |
| | | <el-table v-loading="loading" :data="materialsList" @selection-change="handleSelectionChange"> |
| | | <el-table-column type="selection" width="55" align="center" /> |
| | | <el-table-column label="文件材料序号" align="center" prop="fileNumber" /> |
| | | |
| | | <el-table-column label="责任者" align="center" prop="creator" /> |
| | | <el-table-column label="文件题名" align="center" prop="title" /> |
| | | <el-table-column label="日期" align="center" prop="date" width="180"> |
| | | <template slot-scope="scope"> |
| | | <span>{{ parseTime(scope.row.date, '{y}-{m}-{d}') }}</span> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column label="页号" sortable align="center" prop="pageNumber" /> |
| | | <el-table-column label="页次" sortable align="center" prop="pageOrder" /> |
| | | |
| | | <el-table-column label="所处阶段" sortable align="center" prop="stage" /> |
| | | <el-table-column label="公开属性" sortable align="center" prop="publicity" /> |
| | | <el-table-column label="是否为附图及附件" align="center" prop="isAttachment" /> |
| | | |
| | | <el-table-column label="保管期限" align="center" prop="retentionPeriod" /> |
| | | <el-table-column label="密级" align="center" prop="securityLevel" /> |
| | | <el-table-column label="是否涉密及敏感信息" align="center" prop="isSensitive" /> |
| | | <el-table-column label="是否注销" align="center" prop="isCanceled" /> |
| | | <el-table-column label="格式" align="center" prop="format" /> |
| | | <el-table-column label="幅面" align="center" prop="sizeType" /> |
| | | <el-table-column label="水平分辨率" align="center" prop="horizontalResolution" /> |
| | | <el-table-column label="垂直分辨率" align="center" prop="verticalResolution" /> |
| | | <el-table-column label="宽度" align="center" prop="width" /> |
| | | <el-table-column label="高度" align="center" prop="height" /> |
| | | <el-table-column label="大小" align="center" prop="fileSize" /> |
| | | <el-table-column label="附件及历史发问号" align="center" prop="attachmentHistoryNumbers" /> |
| | | |
| | | <el-table-column label="操作" align="center" width="160" class-name="small-padding "> |
| | | <template slot-scope="scope"> |
| | | <el-button |
| | | size="mini" |
| | | type="text" |
| | | icon="el-icon-edit" |
| | | @click="handleUpdate(scope.row)" |
| | | v-hasPermi="['system:materials:edit']" |
| | | >修改</el-button> |
| | | <el-button |
| | | size="mini" |
| | | type="text" |
| | | icon="el-icon-edit" |
| | | @click="handleUpdate(scope.row)" |
| | | v-hasPermi="['system:materials:edit']" |
| | | >导入附件</el-button> |
| | | <el-button |
| | | size="mini" |
| | | type="text" |
| | | icon="el-icon-delete" |
| | | @click="handleDelete(scope.row)" |
| | | v-hasPermi="['system:materials:remove']" |
| | | >删除</el-button> |
| | | </template> |
| | | </el-table-column> |
| | | </el-table> |
| | | |
| | | <pagination |
| | | v-show="total>0" |
| | | :total="total" |
| | | :page.sync="queryParams.pageNum" |
| | | :limit.sync="queryParams.pageSize" |
| | | @pagination="getList" |
| | | /> |
| | | <el-dialog :title="title" :visible.sync="open" width="800px" append-to-body> |
| | | |
| | | <el-form ref="forms" :model="forms" :rules="rules" label-width="100px"> |
| | | <el-row> |
| | | <el-col :span="8"> |
| | | 8<el-form-item label="责任者" prop="creator"> |
| | | <el-input v-model="forms.creator" placeholder="请输入责任者" /> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="8"> |
| | | <el-form-item label="文件题名" prop="title"> |
| | | <el-input v-model="forms.title" placeholder="请输入文件题名" /> |
| | | </el-form-item> |
| | | </el-col> |
| | | </el-row> |
| | | <el-form-item label="日期" prop="date"> |
| | | <!-- <el-date-picker clearable |
| | | v-model="forms.date" |
| | | type="date" |
| | | value-format="yyyy-MM-dd" |
| | | placeholder="请选择日期"> |
| | | </el-date-picker> --> |
| | | |
| | | <el-input v-model="forms.date" placeholder="请输入日期" prop="date"/> |
| | | |
| | | </el-form-item> |
| | | <!-- <el-form-item label="页次" prop="pageOrder"> |
| | | <el-input v-model="forms.pageOrder" placeholder="请输入页次" /> |
| | | </el-form-item> --> |
| | | <el-form-item label="文字材料" prop="fileStyle"> |
| | | <el-select |
| | | v-model="forms.fileStyle" |
| | | |
| | | placeholder="请选择文字材料" |
| | | clearable |
| | | > |
| | | <el-option |
| | | v-for="item in fileStyleOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | |
| | | |
| | | <el-form-item label="所处阶段" prop="stage"> |
| | | <el-select |
| | | v-model="forms.stage" |
| | | placeholder="请选择所处阶段" |
| | | > |
| | | <el-option |
| | | v-for="item in stageOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="公开属性" prop="publicity"> |
| | | <el-select |
| | | v-model="forms.publicity" |
| | | placeholder="请选择公开属性" |
| | | > |
| | | <el-option |
| | | v-for="item in publicityOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | |
| | | <el-form-item label="是否为附件" prop="isAttachment"> |
| | | <el-select |
| | | v-model="forms.isAttachment" |
| | | placeholder="请选择是否为附件" |
| | | > |
| | | <el-option |
| | | v-for="item in isAttachmentOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | |
| | | <el-form-item label="保管期限" prop="retentionPeriod"> |
| | | <el-select |
| | | v-model="forms.retentionPeriod" |
| | | placeholder="请选择保管期限" |
| | | > |
| | | <el-option |
| | | v-for="item in retentionPeriodOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | |
| | | <!-- 对话框表单中的密级 --> |
| | | <el-form-item label="密级" prop="securityLevel"> |
| | | <el-select |
| | | v-model="forms.securityLevel" |
| | | placeholder="请选择密级" |
| | | > |
| | | <el-option |
| | | v-for="item in securityLevelOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | |
| | | |
| | | |
| | | <el-form-item label="是否敏感" prop="isSensitive"> |
| | | <el-select |
| | | v-model="forms.isSensitive" |
| | | placeholder="请输入是否敏感" |
| | | > |
| | | <el-option |
| | | v-for="item in isAttachmentOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="是否注销" prop="isCanceled"> |
| | | <el-select |
| | | v-model="forms.isCanceled" |
| | | placeholder="请输入是否注销" |
| | | > |
| | | <el-option |
| | | v-for="item in isAttachmentOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | |
| | | |
| | | </el-form> |
| | | <div slot="footer" class="dialog-footer"> |
| | | <el-button type="primary" @click="submitForms">确 定</el-button> |
| | | <el-button @click="cancel">取 消</el-button> |
| | | </div> |
| | | |
| | | |
| | | |
| | | |
| | | </el-dialog> |
| | | <!-- 添加或修改【请填写功能名称】对话框 --> |
| | | <el-dialog :title="titles" :visible.sync="opens" width="800px" append-to-body> |
| | | |
| | | |
| | | |
| | | <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px"> |
| | | <el-form-item label="责任者" prop="creator"> |
| | |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="文字材料" prop="fileStyle"> |
| | | <el-select |
| | | v-model="queryParams.fileStyle" |
| | | |
| | | placeholder="请选择文字材料" |
| | | clearable |
| | | > |
| | | <el-option |
| | | v-for="item in fileStyleOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | |
| | | |
| | | <el-form-item label="所处阶段" prop="stage"> |
| | | <el-select |
| | | v-model="queryParams.stage" |
| | |
| | | </el-form-item> |
| | | </el-form> |
| | | |
| | | <el-row :gutter="10" class="mb8"> |
| | | <el-col :span="1.5"> |
| | | <el-button |
| | | type="primary" |
| | | plain |
| | | icon="el-icon-plus" |
| | | size="mini" |
| | | @click="handleAdd" |
| | | v-hasPermi="['system:materials:add']" |
| | | >新增</el-button> |
| | | </el-col> |
| | | <el-col :span="1.5"> |
| | | <el-button |
| | | type="success" |
| | | plain |
| | | icon="el-icon-edit" |
| | | size="mini" |
| | | :disabled="single" |
| | | @click="handleUpdate" |
| | | v-hasPermi="['system:materials:edit']" |
| | | >修改</el-button> |
| | | </el-col> |
| | | <el-col :span="1.5"> |
| | | <el-button |
| | | type="danger" |
| | | plain |
| | | icon="el-icon-delete" |
| | | size="mini" |
| | | :disabled="multiple" |
| | | @click="handleDelete" |
| | | v-hasPermi="['system:materials:remove']" |
| | | >删除</el-button> |
| | | </el-col> |
| | | <el-col :span="1.5"> |
| | | <el-button |
| | | type="warning" |
| | | plain |
| | | icon="el-icon-download" |
| | | size="mini" |
| | | @click="handleExport" |
| | | v-hasPermi="['system:materials:export']" |
| | | >导出</el-button> |
| | | <el-col :span="1.5"> |
| | | <el-button |
| | | type="success" |
| | | plain |
| | | icon="el-icon-edit" |
| | | size="mini" |
| | | :disabled="single" |
| | | @click="handleUpdate" |
| | | v-hasPermi="['system:materials:edit']" |
| | | >全部附件导入</el-button> |
| | | </el-col> |
| | | </el-col> |
| | | <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar> |
| | | </el-row> |
| | | |
| | | <el-table v-loading="loading" :data="materialsList" @selection-change="handleSelectionChange"> |
| | | <el-table-column type="selection" width="55" align="center" /> |
| | | <el-table-column label="责任者" align="center" prop="creator" /> |
| | | <el-table-column label="文件题名" align="center" prop="title" /> |
| | | <el-table-column label="日期" align="center" prop="date" width="180"> |
| | | <template slot-scope="scope"> |
| | | <span>{{ parseTime(scope.row.date, '{y}-{m}-{d}') }}</span> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column label="页号" align="center" prop="pageNumber" /> |
| | | <el-table-column label="页次" align="center" prop="pageOrder" /> |
| | | <el-table-column label="所处阶段" align="center" prop="stage" /> |
| | | <el-table-column label="公开属性" align="center" prop="publicity" /> |
| | | <el-table-column label="是否为附图及附件" align="center" prop="isAttachment" /> |
| | | |
| | | <el-table-column label="保管期限" align="center" prop="retentionPeriod" /> |
| | | <el-table-column label="密级" align="center" prop="securityLevel" /> |
| | | <el-table-column label="是否涉密及敏感信息" align="center" prop="isSensitive" /> |
| | | <el-table-column label="是否注销" align="center" prop="isCanceled" /> |
| | | <el-table-column label="格式" align="center" prop="format" /> |
| | | <el-table-column label="幅面" align="center" prop="sizeType" /> |
| | | <el-table-column label="水平分辨率" align="center" prop="horizontalResolution" /> |
| | | <el-table-column label="垂直分辨率" align="center" prop="verticalResolution" /> |
| | | <el-table-column label="宽度" align="center" prop="width" /> |
| | | <el-table-column label="高度" align="center" prop="height" /> |
| | | <el-table-column label="大小" align="center" prop="fileSize" /> |
| | | <el-table-column label="附件及历史发问号" align="center" prop="attachmentHistoryNumbers" /> |
| | | |
| | | <el-table-column label="操作" align="center" width="160" class-name="small-padding "> |
| | | <template slot-scope="scope"> |
| | | <el-button |
| | | size="mini" |
| | | type="text" |
| | | icon="el-icon-edit" |
| | | @click="handleUpdate(scope.row)" |
| | | v-hasPermi="['system:materials:edit']" |
| | | >修改</el-button> |
| | | <el-button |
| | | size="mini" |
| | | type="text" |
| | | icon="el-icon-edit" |
| | | @click="handleUpdate(scope.row)" |
| | | v-hasPermi="['system:materials:edit']" |
| | | >导入附件</el-button> |
| | | <el-button |
| | | size="mini" |
| | | type="text" |
| | | icon="el-icon-delete" |
| | | @click="handleDelete(scope.row)" |
| | | v-hasPermi="['system:materials:remove']" |
| | | >删除</el-button> |
| | | </template> |
| | | </el-table-column> |
| | | </el-table> |
| | | |
| | | <pagination |
| | | v-show="total>0" |
| | | :total="total" |
| | | :page.sync="queryParams.pageNum" |
| | | :limit.sync="queryParams.pageSize" |
| | | @pagination="getList" |
| | | /> |
| | | |
| | | <!-- 添加或修改【请填写功能名称】对话框 --> |
| | | <el-dialog :title="title" :visible.sync="open" width="800px" append-to-body> |
| | | <el-form ref="form" :model="form" :rules="rules" label-width="80px"> |
| | | <el-form-item label="责任者" prop="creator"> |
| | | <el-input v-model="form.creator" placeholder="请输入责任者" /> |
| | | </el-form-item> |
| | | <el-form-item label="文件题名" prop="title"> |
| | | <el-input v-model="form.title" placeholder="请输入文件题名" /> |
| | | </el-form-item> |
| | | <el-form-item label="日期" prop="date"> |
| | | <el-date-picker clearable |
| | | v-model="form.date" |
| | | type="date" |
| | | value-format="yyyy-MM-dd" |
| | | placeholder="请选择日期"> |
| | | </el-date-picker> |
| | | </el-form-item> |
| | | <el-form-item label="页号" prop="pageNumber"> |
| | | <el-input v-model="form.pageNumber" placeholder="请输入页号" /> |
| | | </el-form-item> |
| | | <el-form-item label="页次" prop="pageOrder"> |
| | | <el-input v-model="form.pageOrder" placeholder="请输入页次" /> |
| | | </el-form-item> |
| | | <el-form-item label="所处阶段" prop="stage"> |
| | | <el-select |
| | | v-model="form.stage" |
| | | placeholder="请选择所处阶段" |
| | | > |
| | | <el-option |
| | | v-for="item in stageOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="公开属性" prop="publicity"> |
| | | <el-select |
| | | v-model="form.publicity" |
| | | placeholder="请选择公开属性" |
| | | > |
| | | <el-option |
| | | v-for="item in publicityOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | |
| | | <el-form-item label="是否为附件" prop="isAttachment"> |
| | | <el-select |
| | | v-model="form.isAttachment" |
| | | placeholder="请选择是否为附件" |
| | | > |
| | | <el-option |
| | | v-for="item in isAttachmentOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | |
| | | <el-form-item label="保管期限" prop="retentionPeriod"> |
| | | <el-select |
| | | v-model="form.retentionPeriod" |
| | | placeholder="请选择保管期限" |
| | | > |
| | | <el-option |
| | | v-for="item in retentionPeriodOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | |
| | | <!-- 对话框表单中的密级 --> |
| | | <el-form-item label="密级" prop="securityLevel"> |
| | | <el-select |
| | | v-model="form.securityLevel" |
| | | placeholder="请选择密级" |
| | | > |
| | | <el-option |
| | | v-for="item in securityLevelOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | |
| | | |
| | | |
| | | <el-form-item label="是否敏感" prop="isSensitive"> |
| | | <el-select |
| | | v-model="form.isSensitive" |
| | | placeholder="请输入是否敏感" |
| | | > |
| | | <el-option |
| | | v-for="item in isAttachmentOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="是否注销" prop="isCanceled"> |
| | | <el-select |
| | | v-model="form.isCanceled" |
| | | placeholder="请输入是否注销" |
| | | > |
| | | <el-option |
| | | v-for="item in isAttachmentOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | |
| | | |
| | | </el-form> |
| | | <div slot="footer" class="dialog-footer"> |
| | | <el-button type="primary" @click="submitForm">确 定</el-button> |
| | | <el-button @click="cancel">取 消</el-button> |
| | | </div> |
| | | </el-dialog> |
| | | </div> |
| | | </template> |
| | | |
| | | <script> |
| | | import { listMaterials, getMaterials, delMaterials, addMaterials, updateMaterials } from "@/api/system/materials" |
| | | import { getToken } from '@/utils/auth' |
| | | |
| | | export default { |
| | | name: "Materials", |
| | | data() { |
| | | return { |
| | | importDialogVisible: false, |
| | | fileList: [], |
| | | uploadUrl: process.env.VUE_APP_BASE_API +'/system/materials/upload', // 替换为实际的上传接口 |
| | | headers: { |
| | | Authorization: 'Bearer ' + getToken() |
| | | }, |
| | | uploadParams: { |
| | | type: 'material' // 自定义上传类型 |
| | | }, |
| | | // 添加材料类型选项 |
| | | fileStyleOptions: [ |
| | | { value: '文字材料', label: '文字材料' }, |
| | | { value: '图样材料', label: '图样材料' }, |
| | | { value: '照片材料', label: '照片材料' }, |
| | | { value: '其他材料', label: '其他材料' }, |
| | | ], |
| | | |
| | | // 添加密级选项 |
| | | securityLevelOptions: [ |
| | | { value: '秘密', label: '秘密' }, |
| | |
| | | { value: '02-办案过程材料', label: '02-办案过程材料' }, |
| | | { value: '03-结论性文件', label: '03-结论性文件' }, |
| | | { value: '04-其他材料', label: '04-其他材料' }, |
| | | { value: '05-档案变更材料', label: '05-档案变更材料' } |
| | | { value: '05-档案变更材料', label: '05-档案变更材料' }, |
| | | { value: '06-业务数据', label: '06-业务数据' }, |
| | | ], |
| | | recordId: null, |
| | | // 遮罩层 |
| | |
| | | title: "", |
| | | // 是否显示弹出层 |
| | | open: false, |
| | | titles: "", |
| | | opens: false, |
| | | // 查询参数 |
| | | queryParams: { |
| | | pageNum: 1, |
| | |
| | | // ... 其他form属性保持不变 ... |
| | | securityLevel: '普通' // 设置对话框表单默认值 |
| | | }, |
| | | forms: |
| | | {}, |
| | | // 表单校验 |
| | | rules: { |
| | | creator: [ |
| | | { required: true, message: "$comment不能为空", trigger: "blur" } |
| | | { required: true, message: "创建者不能为空", trigger: "blur" } |
| | | ], |
| | | title: [ |
| | | { required: true, message: "$comment不能为空", trigger: "blur" } |
| | | { required: true, message: "案卷题名不能为空", trigger: "blur" } |
| | | ], |
| | | date: [ |
| | | { required: true, message: "$comment不能为空", trigger: "blur" } |
| | | { required: true, message: "日期不能为空", trigger: "blur" } |
| | | ], |
| | | } |
| | | } |
| | | }, |
| | | mounted() { |
| | | // 改为监听keydown事件 |
| | | document.addEventListener('keydown', this.handleKeyDown) |
| | | }, |
| | | beforeDestroy() { |
| | | document.removeEventListener('keydown', this.handleKeyDown) |
| | | }, |
| | | created() { |
| | | //const roleId = this.$route.params && this.$route.params.roleId |
| | | const recordId = this.$route.params && this.$route.params.recordId |
| | | alert(recordId) |
| | | //alert(recordId) |
| | | this.recordId = recordId; |
| | | |
| | | // alert('Bearer ' + getToken()) |
| | | this.reset() |
| | | this.form.securityLevel = '普通' // 设置对话框表单默认值 |
| | | this.form.isSensitive = '否' // 设置对话框表单默认值 |
| | | this.form.isCanceled = '否' // 设置对话框表单默认值 |
| | | this.form.isAttachment = '否' // 设置对话框表单默认值 |
| | | this.form.isDiagram = '否' // 设置对话框表单默认值 |
| | | this.form.retentionPeriod = '永久' // 设置对话框表单默认值 |
| | | if (recordId) { |
| | | |
| | | this.queryParams.recordId = recordId |
| | |
| | | } |
| | | }, |
| | | methods: { |
| | | // 上传失败回调 |
| | | handleError(err, file, fileList) { |
| | | this.$modal.msgError("上传失败: " + err.message) |
| | | // 清除上传列表 |
| | | this.$refs.upload.clearFiles(); |
| | | }, |
| | | // 上传成功回调 |
| | | handleSuccess(response, file, fileList) { |
| | | if (response.code === 200) { |
| | | this.$modal.msgSuccess("上传成功") |
| | | // 清除上传列表 |
| | | this.$refs.upload.clearFiles(); |
| | | // 关闭上传对话框 |
| | | this.importDialogVisible = false; |
| | | // 刷新列表数据 |
| | | this.getList(); // 这里可以调用接口关联上传的文件和当前记录 |
| | | } else { |
| | | // alert(234) |
| | | console.log(response) |
| | | this.$modal.msgError(response.msg) |
| | | } |
| | | }, |
| | | // 打开导入对话框 |
| | | handleImport() { |
| | | this.importDialogVisible = true |
| | | }, |
| | | // 文件移除 |
| | | handleRemove(file, fileList) { |
| | | this.fileList = fileList |
| | | }, |
| | | // 文件预览 |
| | | handlePreview(file) { |
| | | console.log(file) |
| | | }, |
| | | // 提交上传 |
| | | submitUpload() { |
| | | this.$refs.upload.submit() |
| | | }, |
| | | handleKeyDown(e) { |
| | | // 在keydown事件中更早地阻止默认行为 |
| | | if ((e.ctrlKey || e.metaKey) && e.key === 's') { |
| | | e.preventDefault() |
| | | this.$refs.form.validate(valid => { |
| | | if (valid) { |
| | | this.submitForm(); |
| | | } else { |
| | | this.$message.error('请填写所有必填字段'); |
| | | } |
| | | }); |
| | | } |
| | | // 新增Ctrl+D快捷键 |
| | | if ((e.ctrlKey || e.metaKey) && e.key === 'd') { |
| | | e.preventDefault(); |
| | | this.resetForms(); |
| | | } |
| | | }, |
| | | /** 查询【请填写功能名称】列表 */ |
| | | getList() { |
| | | this.loading = true |
| | |
| | | cancel() { |
| | | this.open = false |
| | | this.reset() |
| | | }, |
| | | resets() { |
| | | this.forms = { |
| | | materialId: null, |
| | | creator: null, |
| | | title: null, |
| | | date: null, |
| | | pageNumber: null, |
| | | pageOrder: null, |
| | | stage: null, |
| | | publicity: null, |
| | | isAttachment: null, |
| | | isDiagram: null, |
| | | retentionPeriod: null, |
| | | securityLevel: null, |
| | | isSensitive: null, |
| | | isCanceled: null, |
| | | format: null, |
| | | sizeType: null, |
| | | horizontalResolution: null, |
| | | verticalResolution: null, |
| | | width: null, |
| | | height: null, |
| | | fileSize: null, |
| | | attachmentHistoryNumbers: null, |
| | | remarks: null, |
| | | createdAt: null, |
| | | updatedAt: null, |
| | | recordId: null |
| | | } |
| | | this.resetForm("forms") |
| | | }, |
| | | // 表单重置 |
| | | reset() { |
| | |
| | | }, |
| | | /** 新增按钮操作 */ |
| | | handleAdd() { |
| | | |
| | | this.opens = true |
| | | this.titles = "搜索案卷详细信息" |
| | | }, |
| | | /** 修改按钮操作 */ |
| | | handleUpdate(row) { |
| | | this.resets() |
| | | const materialId = row.materialId || this.ids |
| | | getMaterials(materialId).then(response => { |
| | | this.forms = response.data |
| | | this.open = true |
| | | this.title = "修改案卷详细信息" |
| | | }) |
| | | }, |
| | | resetForms() |
| | | { |
| | | this.reset() |
| | | this.form.securityLevel = '普通' // 设置对话框表单默认值 |
| | | this.form.isSensitive = '否' // 设置对话框表单默认值 |
| | |
| | | this.form.isAttachment = '否' // 设置对话框表单默认值 |
| | | this.form.isDiagram = '否' // 设置对话框表单默认值 |
| | | this.form.retentionPeriod = '永久' // 设置对话框表单默认值 |
| | | this.open = true |
| | | this.title = "添加案卷详细信息" |
| | | }, |
| | | /** 修改按钮操作 */ |
| | | handleUpdate(row) { |
| | | this.reset() |
| | | const materialId = row.materialId || this.ids |
| | | getMaterials(materialId).then(response => { |
| | | this.form = response.data |
| | | this.open = true |
| | | this.title = "修改案卷详细信息" |
| | | }) |
| | | }, |
| | | /** 提交按钮 */ |
| | | submitForm() { |
| | | this.$refs["form"].validate(valid => { |
| | | if (valid) { |
| | | if (this.form.materialId != null) { |
| | | updateMaterials(this.form).then(response => { |
| | | this.$modal.msgSuccess("修改成功") |
| | | this.open = false |
| | | this.getList() |
| | | }) |
| | | } else { |
| | | submitForm() |
| | | { |
| | | console.log(this.form) |
| | | this.form.recordId = this.recordId |
| | | console.log("==============+++++++++++++++============") |
| | | addMaterials(this.form).then(response => { |
| | | this.$modal.msgSuccess("新增成功") |
| | | // this.opens = false |
| | | |
| | | this.getList() |
| | | }) |
| | | }, |
| | | /** 提交按钮 */ |
| | | submitForms() { |
| | | this.$refs["forms"].validate(valid => { |
| | | if (valid) { |
| | | if (this.forms.materialId != null) { |
| | | updateMaterials(this.forms).then(response => { |
| | | this.$modal.msgSuccess("修改成功") |
| | | this.open = false |
| | | this.getList() |
| | | }) |
| | | } else { |
| | | |
| | | } |
| | | } |
| | | }) |
| | |
| | | } |
| | | } |
| | | </script> |
| | | <style scoped> |
| | | .title-border { |
| | | border-bottom: 1px solid #dcdfe6; |
| | | padding-bottom: 10px; |
| | | margin-bottom: 20px; |
| | | } |
| | | </style> |
| | |
| | | <!-- <el-table-column label="${comment}" align="center" prop="id" /> --> |
| | | <el-table-column label="档案号" align="center" prop="recordId" /> |
| | | <el-table-column label="发文号" align="center" prop="inquiryNumber" /> |
| | | <el-table-column label="案卷题名" align="center" prop="caseTitle" /> |
| | | <el-table-column label="项目名称" align="center" prop="everyProjectName" /> |
| | | |
| | | <el-table-column label="案卷题名" align="center" prop="caseTitle" show-overflow-tooltip /> |
| | | <el-table-column label="公开属性" align="center" prop="publicAttribute" /> |
| | | <el-table-column label="编制单位" align="center" prop="preparationUnit" /> |
| | | <el-table-column label="编制日期" align="center" prop="preparationDate" width="180"> |
| | |
| | | <el-table-column label="缩微号" align="center" prop="microfilmNumber" /> |
| | | <el-table-column label="备注" align="center" prop="remarks" /> |
| | | <el-table-column label="历史相关发文号" align="center" prop="historicalReferenceNumber" /> |
| | | |
| | | <el-table-column label="状态" align="center" prop="recordStatus"> |
| | | <template slot-scope="scope"> |
| | | <el-button :type="scope.row.recordStatus === '未录入' ? 'danger' : 'success'" size="mini"> |
| | | {{ scope.row.recordStatus }} |
| | | </el-button> |
| | | </template> |
| | | </el-table-column> |
| | | |
| | | |
| | | <el-table-column label="操作" align="center" width="190" class-name="small-padding fixed-width"> |
| | | <template slot-scope="scope"> |
| | | <el-button |
| | |
| | | >案卷详细信息</el-button> |
| | | |
| | | <el-button |
| | | |
| | | |
| | | size="mini" |
| | | type="text" |
| | | icon="el-icon-edit" |
| | | @click="handleCheck(scope.row)" |
| | | >查看</el-button> |
| | | <el-button |
| | | v-if="userId!==1" |
| | | |
| | | size="mini" |
| | | type="text" |
| | | icon="el-icon-edit" |
| | | @click="handleSubmit(scope.row)" |
| | | v-hasPermi="['system:records:edit']" |
| | | >提交案卷</el-button> |
| | | <el-button |
| | | v-if="scope.row.ownData||userId===1" |
| | | |
| | |
| | | <!-- 添加或修改档案记录对话框 --> |
| | | <el-dialog :title="title" :visible.sync="open" width="900px" append-to-body> |
| | | <el-form ref="form" :model="form" :rules="rules" label-width="120px"> |
| | | <el-form-item label="档案号" > |
| | | <el-form-item label="档案号" prop="recordId"> |
| | | |
| | | <el-row :gutter="8"> |
| | | <el-col :span="6"> |
| | |
| | | /> |
| | | </el-select> |
| | | </el-col> |
| | | |
| | | |
| | | <el-col :span="6"> |
| | | <el-select |
| | | |
| | | v-model="form.recordZone" |
| | | placeholder="选择地区" |
| | | @change="handleRecordTypeChange" |
| | | :disabled="userId!=1" > |
| | | <el-option |
| | | v-for="item in zoneTypeOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-col> |
| | | <el-col :span="4"> |
| | | <el-input |
| | | v-model="form.recordYear" |
| | | placeholder="输入年份" |
| | |
| | | :disabled="userId!=1" |
| | | /> |
| | | </el-col> |
| | | <el-col :span="6"> |
| | | <el-col :span="4"> |
| | | <el-input |
| | | v-model="form.recordSeq" |
| | | placeholder="自动生成" |
| | |
| | | <el-input v-model="form.inquiryNumber" placeholder="请输入发问号" :disabled="userId!=1" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="建设项目名称" prop="projectName"> |
| | | <el-input v-model="form.projectName" placeholder="请输入建设项目名称" :disabled="userId!=1"/> |
| | | <el-form-item label="项目名称" prop="everyProjectName"> |
| | | <el-select |
| | | v-model="form.everyProjectName" |
| | | placeholder="请选择项目名称" |
| | | |
| | | :disabled="userId!=1" |
| | | > |
| | | <el-option |
| | | v-for="item in projectOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | |
| | | |
| | | |
| | | <div v-if="vis"> |
| | | <el-form-item label="案卷题名" prop="caseTitle"> |
| | | <el-input v-model="form.caseTitle" placeholder="请输入案卷题名" /> |
| | |
| | | <el-form-item label="建设地址" prop="constructionAddress"> |
| | | <el-input v-model="form.constructionAddress" placeholder="请输入建设地址" /> |
| | | </el-form-item> |
| | | |
| | | <el-form-item label="建设项目名称" prop="projectName"> |
| | | <el-input v-model="form.projectName" placeholder="请输入建设项目名称" :disabled="userId!=1"/> |
| | | </el-form-item> |
| | | <el-form-item label="项目编号" prop="projectNumber"> |
| | | <el-input v-model="form.projectNumber" placeholder="请输入项目编号" /> |
| | | </el-form-item> |
| | |
| | | </template> |
| | | |
| | | <script> |
| | | import { listRecords,getMaxId, getRecords, delRecords, addRecords, updateRecords } from "@/api/system/records" |
| | | import { updateStatusById,listRecords,getMaxId, getRecords, delRecords, addRecords, updateRecords } from "@/api/system/records" |
| | | import { listAllCategory } from "@/api/system/category" |
| | | |
| | | import { listName } from "@/api/system/projectName" |
| | | import { listPlaceName } from "@/api/system/placeName" |
| | | export default { |
| | | name: "Records", |
| | | data() { |
| | |
| | | { value: '普通', label: '普通' } |
| | | ], |
| | | maxId: 0, |
| | | // 项目名称选项 |
| | | projectOptions: [], |
| | | // 档案类型选项 |
| | | recordTypeOptions: [], |
| | | //地区类型 |
| | | zoneTypeOptions: [], |
| | | // 保管期限选项 |
| | | retentionPeriodOptions: [ |
| | | { value: "10年", label: "10年" }, |
| | |
| | | pageSize: 10, |
| | | recordId: null, |
| | | inquiryNumber: null, |
| | | everyProjectName: null, |
| | | caseTitle: null, |
| | | publicAttribute: null, |
| | | preparationUnit: null, |
| | |
| | | inquiryNumber: [ |
| | | { required: true, message: "发问号不能为空", trigger: "blur" } |
| | | ], |
| | | projectName: [ |
| | | { required: true, message: "项目名称不能为空", trigger: "blur" } |
| | | everyProjectName: [ |
| | | { required: true, message: "项目名称不能为空", trigger: ['change', 'blur']} |
| | | ], |
| | | } |
| | | } |
| | | }, |
| | | created() { |
| | | this.getList() |
| | | |
| | | this.userId = this.$store.state.user.id; |
| | | |
| | | // 获取用户角色 |
| | | this.getId() |
| | | this.getRecordTypes() |
| | | |
| | | |
| | | this.getZoneOptions() |
| | | this.fetchProjectOptions() |
| | | this.getList() |
| | | }, |
| | | methods: { |
| | | getId() |
| | |
| | | getMaxId().then(response=>{ |
| | | // alert(213) |
| | | console.log(response) |
| | | _this.maxId = String(response.data).padStart(5, '0') |
| | | _this.maxId = String(response.data).padStart(4, '0') |
| | | |
| | | _this.$set(_this.form, 'recordSeq', _this.maxId) // |
| | | |
| | | // alert(this.maxId) |
| | | }) |
| | | }, |
| | | async getZoneOptions() |
| | | { |
| | | try { |
| | | const response = await listPlaceName() |
| | | console.log(response) |
| | | // alert(134) |
| | | this.zoneTypeOptions = response.data.data.map(item => ({ |
| | | value: item.nnumber, |
| | | label: item.name |
| | | })) |
| | | } catch (error) { |
| | | console.error('获取项目名称列表失败:', error) |
| | | } |
| | | }, |
| | | async fetchProjectOptions() { |
| | | try { |
| | | const response = await listName() |
| | | console.log(response) |
| | | this.projectOptions = response.data.data.map(item => ({ |
| | | value: item.name, |
| | | label: item.name |
| | | })) |
| | | } catch (error) { |
| | | console.error('获取项目名称列表失败:', error) |
| | | } |
| | | }, |
| | | /** 获取档案类型列表 */ |
| | | getRecordTypes() { |
| | |
| | | /** 生成档案号 */ |
| | | generateRecordId() { |
| | | |
| | | if (this.form.recordType && this.form.recordYear) { |
| | | if (this.form.recordType && this.form.recordZone && this.form.recordYear) { |
| | | |
| | | // getNextRecordId({ |
| | | // type: this.form.recordType, |
| | | // year: this.form.recordYear |
| | | // }).then(response => { |
| | | // this.form.recordSeq = response.data.seq |
| | | this.form.recordId = `${this.form.recordType}-${this.form.recordYear}-${this.form.recordSeq}` |
| | | this.form.recordId = `${this.form.recordType}-${this.form.recordZone}-${this.form.recordYear}-${this.form.recordSeq}` |
| | | // }) |
| | | } |
| | | }, |
| | |
| | | id: null, |
| | | recordId: null, |
| | | inquiryNumber: null, |
| | | everyProjectName: null, |
| | | caseTitle: null, |
| | | publicAttribute: null, |
| | | preparationUnit: null, |
| | |
| | | this.$router.push("/archiveManager/infoManagerAu/archiveMaterialManager/" + recordId) |
| | | |
| | | }, |
| | | // |
| | | handleSubmit(row) |
| | | { |
| | | alert(row.id) |
| | | var id = row.id |
| | | updateStatusById(id).then(response=>{ |
| | | this.$modal.msgSuccess("提交成功") |
| | | this.getList() |
| | | }) |
| | | }, |
| | | /** 修改按钮操作 */ |
| | | handleUpdate(row) { |
| | | |
| | |
| | | if(this.recordTypeOptions.length > 0) { |
| | | const recordParts = response.data.recordId.split('-') |
| | | this.$set(this.form, 'recordType', recordParts[0]) |
| | | this.$set(this.form, 'recordYear', recordParts[1]) |
| | | this.$set(this.form, 'recordSeq', recordParts[2]) |
| | | this.$set(this.form, 'recordZone', recordParts[1]) |
| | | |
| | | this.$set(this.form, 'recordYear', recordParts[2]) |
| | | this.$set(this.form, 'recordSeq', recordParts[3]) |
| | | } |
| | | this.open = true |
| | | this.title = "修改档案记录" |
| | |
| | | if(this.recordTypeOptions.length > 0) { |
| | | const recordParts = response.data.recordId.split('-') |
| | | this.$set(this.form, 'recordType', recordParts[0]) |
| | | this.$set(this.form, 'recordYear', recordParts[1]) |
| | | this.$set(this.form, 'recordSeq', recordParts[2]) |
| | | this.$set(this.form, 'recordZone', recordParts[1]) |
| | | |
| | | this.$set(this.form, 'recordYear', recordParts[2]) |
| | | this.$set(this.form, 'recordSeq', recordParts[3]) |
| | | } |
| | | this.open_check = true |
| | | this.title = "查看档案记录" |
| | |
| | | this.getList() |
| | | }) |
| | | } else { |
| | | console.log(this.form) |
| | | addRecords(this.form).then(response => { |
| | | this.$modal.msgSuccess("新增成功") |
| | | this.open = false |
| | | this.getList() |
| | | this.getId() |
| | | this.getList() |
| | | |
| | | |
| | | }) |
| | | } |
| | |
| | | </el-form-item> |
| | | </el-form> |
| | | <el-row> |
| | | <el-table @row-click="clickRow" ref="table" :data="userList" @selection-change="handleSelectionChange" height="260px"> |
| | | <el-table @row-click="clickRow" ref="table" :data="userList" @selection-change="handleSingleSelection" |
| | | height="260px"> |
| | | <el-table-column type="selection" width="55"></el-table-column> |
| | | <el-table-column label="用户名称" prop="userName" :show-overflow-tooltip="true" /> |
| | | <el-table-column label="用户昵称" prop="nickName" :show-overflow-tooltip="true" /> |
| | |
| | | } |
| | | }, |
| | | methods: { |
| | | // 替换原有的handleSelectionChange方法 |
| | | handleSingleSelection(selection) { |
| | | if (selection.length > 1) { |
| | | this.$refs.table.clearSelection(); |
| | | this.$refs.table.toggleRowSelection(selection[selection.length - 1]); |
| | | } |
| | | else |
| | | this.userIds = selection.map(item => item.userId); |
| | | }, |
| | | // 显示弹框 |
| | | show(archiveRecordsId) { |
| | | if (archiveRecordsId) { |
| | |
| | | this.visible = true |
| | | }, |
| | | clickRow(row) { |
| | | this.$refs.table.toggleRowSelection(row) |
| | | this.$refs.table.clearSelection(); |
| | | this.$refs.table.toggleRowSelection(row); |
| | | }, |
| | | // 多选框选中数据 |
| | | handleSelectionChange(selection) { |
| | |
| | | <template> |
| | | <div class="app-container"> |
| | | <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px"> |
| | | <el-form-item label="档案号1" prop="recordId"> |
| | | <el-input |
| | | v-model="queryParams.recordId" |
| | | placeholder="请输入档案号" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="发文号" prop="inquiryNumber"> |
| | | <el-input |
| | | v-model="queryParams.inquiryNumber" |
| | | placeholder="请输入发文号" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="案卷题名" prop="caseTitle"> |
| | | <el-input |
| | | v-model="queryParams.caseTitle" |
| | | placeholder="请输入案卷题名" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="公开属性" prop="publicAttribute"> |
| | | <el-select |
| | | v-model="queryParams.publicAttribute" |
| | | placeholder="请选择公开属性" |
| | | clearable |
| | | > |
| | | <el-option |
| | | v-for="item in publicAttributeOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="编制单位" prop="preparationUnit"> |
| | | <el-input |
| | | v-model="queryParams.preparationUnit" |
| | | placeholder="请输入编制单位" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="编制日期" prop="preparationDate"> |
| | | <el-date-picker clearable |
| | | v-model="queryParams.preparationDate" |
| | | type="date" |
| | | value-format="yyyy-MM-dd" |
| | | placeholder="请选择编制日期"> |
| | | </el-date-picker> |
| | | </el-form-item> |
| | | <el-form-item label="保管期限" prop="retentionPeriod"> |
| | | <el-select |
| | | v-model="queryParams.retentionPeriod" |
| | | placeholder="请选择保管期限" |
| | | clearable |
| | | > |
| | | <el-option |
| | | v-for="item in retentionPeriodOptions" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | /> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="密级" prop="securityClassification"> |
| | | <el-input |
| | | v-model="queryParams.securityClassification" |
| | | placeholder="请输入密级" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="案卷页数" prop="pageCount"> |
| | | <el-input |
| | | v-model="queryParams.pageCount" |
| | | placeholder="请输入案卷页数" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="立案号" prop="filingNumber"> |
| | | <el-input |
| | | v-model="queryParams.filingNumber" |
| | | placeholder="请输入立案号" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="建设单位" prop="constructionUnit"> |
| | | <el-input |
| | | v-model="queryParams.constructionUnit" |
| | | placeholder="请输入建设单位" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="建设地址" prop="constructionAddress"> |
| | | <el-input |
| | | v-model="queryParams.constructionAddress" |
| | | placeholder="请输入建设地址" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="建设项目名称" prop="projectName"> |
| | | <el-input |
| | | v-model="queryParams.projectName" |
| | | placeholder="请输入建设项目名称" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="项目编号" prop="projectNumber"> |
| | | <el-input |
| | | v-model="queryParams.projectNumber" |
| | | placeholder="请输入项目编号" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="扫描加工公司" prop="scanningCompany"> |
| | | <el-input |
| | | v-model="queryParams.scanningCompany" |
| | | placeholder="请输入扫描加工公司" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="档案管(室)号" prop="archiveRoomNumber"> |
| | | <el-input |
| | | v-model="queryParams.archiveRoomNumber" |
| | | placeholder="请输入档案管(室)号" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="缩微号" prop="microfilmNumber"> |
| | | <el-input |
| | | v-model="queryParams.microfilmNumber" |
| | | placeholder="请输入缩微号" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="历史相关发文号" prop="historicalReferenceNumber"> |
| | | <el-input |
| | | v-model="queryParams.historicalReferenceNumber" |
| | | placeholder="请输入历史相关发文号" |
| | | clearable |
| | | @keyup.enter.native="handleQuery" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item> |
| | | <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button> |
| | | <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button> |
| | | </el-form-item> |
| | | </el-form> |
| | | |
| | | |
| | | <el-row :gutter="10" class="mb8"> |
| | | <el-col :span="1.5"> |
| | |
| | | <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar> |
| | | </el-row> |
| | | |
| | | <el-table v-loading="loading" :data="recordsList" @selection-change="handleSelectionChange"> |
| | | <el-table-column type="selection" width="55" align="center" /> |
| | | <el-table v-loading="loading" :data="recordsList" @row-click="handleRowClick"> |
| | | <!-- <el-table-column type="selection" width="55" align="center" /> --> |
| | | <!-- <el-table-column label="${comment}" align="center" prop="id" /> --> |
| | | <el-table-column label="档案号" align="center" prop="recordId" /> |
| | | <el-table-column label="发文号" align="center" prop="inquiryNumber" /> |
| | | <el-table-column label="案卷题名" align="center" prop="caseTitle" /> |
| | | <el-table-column label="项目名称" align="center" prop="everyProjectName" /> |
| | | <el-table-column label="项目内案卷总数" align="center" prop="cnt" /> |
| | | |
| | | <el-table-column label="完成案卷数" align="center" prop="finished" /> |
| | | |
| | | |
| | | |
| | | <el-table-column label="建设地址" align="center" prop="constructionAddress" /> |
| | | <el-table-column label="建设项目名称" align="center" prop="projectName" /> |
| | | <el-table-column label="状态" align="center" prop="projectName" /> |
| | | |
| | | <el-table-column label="未完成案卷数" align="center" prop="unfinished" /> |
| | | <el-table-column label="完成百分比" align="center"> |
| | | <template slot-scope="scope"> |
| | | <el-progress |
| | | :percentage="Math.round((scope.row.finished / scope.row.cnt) * 100)" |
| | | :status="scope.row.finished === scope.row.cnt ? 'success' : 'warning'"> |
| | | </el-progress> |
| | | <span>{{ scope.row.finished }}/{{ scope.row.cnt }} ({{ Math.round((scope.row.finished / scope.row.cnt) * 100) }}%)</span> |
| | | </template> |
| | | </el-table-column> |
| | | |
| | | </el-table> |
| | | |
| | |
| | | <el-button @click="cancel">取 消</el-button> |
| | | </div> |
| | | </el-dialog> |
| | | |
| | | |
| | | |
| | | <el-dialog |
| | | title="完成情况统计" |
| | | :visible.sync="dialogVisible" |
| | | width="60%"> |
| | | <div ref="chartContainer" style="width: 100%; height: 400px; display: flex; justify-content: center; align-items: center;"></div> |
| | | </el-dialog> |
| | | </div> |
| | | </template> |
| | | |
| | | <script> |
| | | import { listRecords,getMaxId, getRecords, delRecords, addRecords, updateRecords } from "@/api/system/records" |
| | | import { statisticInfo,listRecords,getMaxId, getRecords, delRecords, addRecords, updateRecords } from "@/api/system/records" |
| | | import { listAllCategory } from "@/api/system/category" |
| | | |
| | | export default { |
| | | name: "Records", |
| | | data() { |
| | | return { |
| | | dialogVisible: false, |
| | | chartInstance: null, |
| | | maxId: 0, |
| | | // 档案类型选项 |
| | | recordTypeOptions: [], |
| | |
| | | created() { |
| | | this.getList() |
| | | |
| | | this.getId() |
| | | this.getRecordTypes() |
| | | // this.getId() |
| | | // this.getRecordTypes() |
| | | |
| | | |
| | | }, |
| | | beforeDestroy() { |
| | | if (this.chartInstance) { |
| | | this.chartInstance.dispose(); |
| | | } |
| | | }, |
| | | methods: { |
| | | handleRowClick(row) { |
| | | this.dialogVisible = true; |
| | | this.$nextTick(() => { |
| | | this.chartInstance = this.$echarts.init(this.$refs.chartContainer); |
| | | const option = { |
| | | tooltip: { |
| | | trigger: 'item', |
| | | formatter: '{a} <br/>{b}: {c} ({d}%)' |
| | | }, |
| | | legend: { |
| | | orient: 'vertical', |
| | | right: 10, |
| | | top: 'center' |
| | | }, |
| | | color: ['#67C23A', '#F56C6C'], |
| | | series: [{ |
| | | name: '完成情况', |
| | | type: 'pie', |
| | | radius: ['50%', '70%'], |
| | | avoidLabelOverlap: false, |
| | | itemStyle: { |
| | | borderRadius: 10, |
| | | borderColor: '#fff', |
| | | borderWidth: 2 |
| | | }, |
| | | label: { |
| | | show: true, |
| | | formatter: '{b}: {d}%' |
| | | }, |
| | | emphasis: { |
| | | label: { |
| | | show: true, |
| | | fontSize: '18', |
| | | fontWeight: 'bold' |
| | | } |
| | | }, |
| | | labelLine: { |
| | | show: true |
| | | }, |
| | | data: row.cnt === 0 ? |
| | | [{ value: 1, name: '暂无数据', itemStyle: { color: '#909399' }}] : |
| | | [ |
| | | { value: row.finished, name: '已完成' }, |
| | | { value: row.cnt - row.finished, name: '未完成' } |
| | | ] |
| | | }] |
| | | }; |
| | | this.chartInstance.setOption(option); |
| | | }); |
| | | }, |
| | | getId() |
| | | { |
| | | var _this = this; |
| | |
| | | this.loading = true |
| | | console.log(this.queryParams) |
| | | console.log("--------------") |
| | | listRecords(this.queryParams).then(response => { |
| | | statisticInfo().then(response => { |
| | | |
| | | console.log(response) |
| | | this.recordsList = response.data.data |
| | | this.total = response.data.total |
| | | this.recordsList = response.data |
| | | this.total = response.data.length |
| | | this.loading = false |
| | | }) |
| | | }, |
| | |
| | | } |
| | | } |
| | | </script> |
| | | <style scoped> |
| | | .force-width { |
| | | width: 900px !important; /* 设置固定宽度 */ |
| | | } |
| | | |
| | | body .el-message-box.force-width { |
| | | width: 800px !important; |
| | | } |
| | | </style> |
New file |
| | |
| | | <template> |
| | | <div class="app-container"> |
| | | |
| | | |
| | | <el-row :gutter="10" class="mb8"> |
| | | |
| | | <el-col :span="1.5"> |
| | | <el-button |
| | | type="warning" |
| | | plain |
| | | icon="el-icon-download" |
| | | size="mini" |
| | | @click="handleExport" |
| | | v-hasPermi="['system:records:export']" |
| | | >导出</el-button> |
| | | </el-col> |
| | | <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar> |
| | | </el-row> |
| | | |
| | | <el-table v-loading="loading" :data="recordsList" @row-click="handleRowClick"> |
| | | <!-- <el-table-column type="selection" width="55" align="center" /> --> |
| | | <!-- <el-table-column label="${comment}" align="center" prop="id" /> --> |
| | | <el-table-column label="用户名称" align="center" prop="userName" /> |
| | | <el-table-column label="被分配案卷总数" align="center" prop="cnt" /> |
| | | |
| | | <el-table-column label="完成案卷数" align="center" prop="ylr" /> |
| | | |
| | | |
| | | |
| | | |
| | | <el-table-column label="未完成案卷数" align="center" prop="swlr" /> |
| | | <el-table-column label="完成百分比" align="center"> |
| | | <template slot-scope="scope"> |
| | | <el-progress |
| | | :percentage="Math.round((scope.row.ylr / scope.row.cnt) * 100)" |
| | | :status="scope.row.ylr === scope.row.cnt ? 'success' : 'warning'"> |
| | | </el-progress> |
| | | <span>{{ scope.row.ylr }}/{{ scope.row.cnt }} ({{ Math.round((scope.row.ylr / scope.row.cnt) * 100) }}%)</span> |
| | | </template> |
| | | </el-table-column> |
| | | |
| | | </el-table> |
| | | |
| | | <pagination |
| | | v-show="total>0" |
| | | :total="total" |
| | | :page.sync="queryParams.pageNum" |
| | | :limit.sync="queryParams.pageSize" |
| | | @pagination="getList" |
| | | /> |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | <el-dialog |
| | | title="完成情况统计" |
| | | :visible.sync="dialogVisible" |
| | | width="60%"> |
| | | <div ref="chartContainer" style="width: 100%; height: 400px; display: flex; justify-content: center; align-items: center;"></div> |
| | | </el-dialog> |
| | | </div> |
| | | </template> |
| | | |
| | | <script> |
| | | // import { statisticInfo,listRecords,getMaxId, getRecords, delRecords, addRecords, updateRecords } from "@/api/system/records" |
| | | import { listAllCategory } from "@/api/system/category" |
| | | import { listArchiverecordstouserStatistic } from "@/api/system/archiverecordstouser" |
| | | |
| | | export default { |
| | | name: "Records", |
| | | data() { |
| | | return { |
| | | dialogVisible: false, |
| | | chartInstance: null, |
| | | maxId: 0, |
| | | // 档案类型选项 |
| | | recordTypeOptions: [], |
| | | // 保管期限选项 |
| | | retentionPeriodOptions: [ |
| | | { value: "10年", label: "10年" }, |
| | | { value: "30年", label: "30年" }, |
| | | { value: "永久", label: "永久" } |
| | | ], |
| | | // 公开属性选项 |
| | | publicAttributeOptions: [ |
| | | { value: "主动公开", label: "主动公开" }, |
| | | { value: "依申请公开", label: "依申请公开" }, |
| | | { value: "免予公开", label: "免予公开" } |
| | | ], |
| | | amio: false, |
| | | vis: false, |
| | | // 遮罩层 |
| | | loading: true, |
| | | // 选中数组 |
| | | ids: [], |
| | | // 非单个禁用 |
| | | single: true, |
| | | // 非多个禁用 |
| | | multiple: true, |
| | | // 显示搜索条件 |
| | | showSearch: true, |
| | | // 总条数 |
| | | total: 0, |
| | | // 档案记录表格数据 |
| | | recordsList: [], |
| | | // 弹出层标题 |
| | | title: "", |
| | | // 是否显示弹出层 |
| | | open: false, |
| | | // 查询参数 |
| | | queryParams: { |
| | | pageNum: 1, |
| | | pageSize: 10, |
| | | userName: null |
| | | }, |
| | | // 表单参数 |
| | | form: { |
| | | recordSeq: '', |
| | | }, |
| | | // 表单校验 |
| | | rules: { |
| | | recordId: [ |
| | | { required: true, message: "档案号不能为空", trigger: "blur" } |
| | | ], |
| | | inquiryNumber: [ |
| | | { required: true, message: "发问号不能为空", trigger: "blur" } |
| | | ], |
| | | projectName: [ |
| | | { required: true, message: "项目名称不能为空", trigger: "blur" } |
| | | ], |
| | | } |
| | | } |
| | | }, |
| | | created() { |
| | | this.getList() |
| | | |
| | | // this.getId() |
| | | // this.getRecordTypes() |
| | | |
| | | |
| | | }, |
| | | beforeDestroy() { |
| | | if (this.chartInstance) { |
| | | this.chartInstance.dispose(); |
| | | } |
| | | }, |
| | | methods: { |
| | | handleRowClick(row) { |
| | | this.dialogVisible = true; |
| | | this.$nextTick(() => { |
| | | this.chartInstance = this.$echarts.init(this.$refs.chartContainer); |
| | | const option = { |
| | | tooltip: { |
| | | trigger: 'item', |
| | | formatter: '{a} <br/>{b}: {c} ({d}%)' |
| | | }, |
| | | legend: { |
| | | orient: 'vertical', |
| | | right: 10, |
| | | top: 'center' |
| | | }, |
| | | color: ['#67C23A', '#F56C6C'], |
| | | series: [{ |
| | | name: '完成情况', |
| | | type: 'pie', |
| | | radius: ['50%', '70%'], |
| | | avoidLabelOverlap: false, |
| | | itemStyle: { |
| | | borderRadius: 10, |
| | | borderColor: '#fff', |
| | | borderWidth: 2 |
| | | }, |
| | | label: { |
| | | show: true, |
| | | formatter: '{b}: {d}%' |
| | | }, |
| | | emphasis: { |
| | | label: { |
| | | show: true, |
| | | fontSize: '18', |
| | | fontWeight: 'bold' |
| | | } |
| | | }, |
| | | labelLine: { |
| | | show: true |
| | | }, |
| | | data: row.cnt === 0 ? |
| | | [{ value: 1, name: '暂无数据', itemStyle: { color: '#909399' }}] : |
| | | [ |
| | | { value: row.ylr, name: '已完成' }, |
| | | { value: row.cnt - row.ylr, name: '未完成' } |
| | | ] |
| | | }] |
| | | }; |
| | | this.chartInstance.setOption(option); |
| | | }); |
| | | }, |
| | | |
| | | |
| | | |
| | | /** 档案类型变更处理 */ |
| | | |
| | | /** 查询档案记录列表 */ |
| | | getList() { |
| | | this.loading = true |
| | | console.log(this.queryParams) |
| | | console.log("--------------") |
| | | alert(123) |
| | | listArchiverecordstouserStatistic(this.queryParams).then(response => { |
| | | |
| | | console.log(response) |
| | | this.recordsList = response.data.data |
| | | this.total = response.data.total |
| | | this.loading = false |
| | | }) |
| | | }, |
| | | // 取消按钮 |
| | | cancel() { |
| | | this.open = false |
| | | this.reset() |
| | | }, |
| | | // 表单重置 |
| | | reset() { |
| | | this.form = { |
| | | id: null, |
| | | recordId: null, |
| | | inquiryNumber: null, |
| | | caseTitle: null, |
| | | publicAttribute: null, |
| | | preparationUnit: null, |
| | | preparationDate: null, |
| | | retentionPeriod: null, |
| | | securityClassification: null, |
| | | pageCount: null, |
| | | filingNumber: null, |
| | | constructionUnit: null, |
| | | constructionAddress: null, |
| | | projectName: null, |
| | | projectNumber: null, |
| | | scanningCompany: null, |
| | | archiveRoomNumber: null, |
| | | microfilmNumber: null, |
| | | remarks: null, |
| | | historicalReferenceNumber: null, |
| | | recordSeq:null |
| | | } |
| | | this.resetForm("form") |
| | | }, |
| | | /** 搜索按钮操作 */ |
| | | handleQuery() { |
| | | this.queryParams.pageNum = 1 |
| | | this.getList() |
| | | }, |
| | | /** 重置按钮操作 */ |
| | | resetQuery() { |
| | | this.resetForm("queryForm") |
| | | this.handleQuery() |
| | | }, |
| | | // 多选框选中数据 |
| | | handleSelectionChange(selection) { |
| | | this.ids = selection.map(item => item.id) |
| | | this.single = selection.length!==1 |
| | | this.multiple = !selection.length |
| | | }, |
| | | /** 新增按钮操作 */ |
| | | handleAdd() { |
| | | this.reset() |
| | | this.form.recordSeq = this.maxId |
| | | this.open = true |
| | | this.vis = false; |
| | | this.title = "添加档案记录" |
| | | }, |
| | | /*查看详情*/ |
| | | handleInfo(row) |
| | | { |
| | | |
| | | var mid = row.id |
| | | const roleId = 2 |
| | | alert(mid) |
| | | var recordId = mid |
| | | // this.$router.push("/archiveManager/infoManagerAu/user/" + roleId+"/"+recordId) |
| | | this.$router.push("/archiveManager/infoManagerAu/archiveMaterialManager/" + recordId) |
| | | |
| | | }, |
| | | /** 修改按钮操作 */ |
| | | handleUpdate(row) { |
| | | |
| | | this.reset() |
| | | this.vis = true; |
| | | const id = row.id || this.ids |
| | | getRecords(id).then(response => { |
| | | console.log(response) |
| | | console.log("----=============--------------") |
| | | this.form = response.data |
| | | this.open = true |
| | | this.title = "修改档案记录" |
| | | }) |
| | | }, |
| | | /** 提交按钮 */ |
| | | submitForm() { |
| | | this.$refs["form"].validate(valid => { |
| | | if (valid) { |
| | | if (this.form.id != null) { |
| | | updateRecords(this.form).then(response => { |
| | | this.$modal.msgSuccess("修改成功") |
| | | this.open = false |
| | | this.getList() |
| | | }) |
| | | } else { |
| | | addRecords(this.form).then(response => { |
| | | this.$modal.msgSuccess("新增成功") |
| | | this.open = false |
| | | this.getList() |
| | | }) |
| | | } |
| | | } |
| | | }) |
| | | }, |
| | | // 更多操作触发 |
| | | handleCommand(command, row) { |
| | | |
| | | switch (command) { |
| | | case "handleDataScope": |
| | | this.handleDataScope(row) |
| | | break |
| | | case "handleAuthUser": |
| | | this.handleAuthUser(row) |
| | | break |
| | | default: |
| | | break |
| | | } |
| | | }, |
| | | /** 分配用户操作 */ |
| | | handleAuthUser: function(row) { |
| | | const roleId = 2 |
| | | var archiveRecordsId = row.recordId |
| | | // alert(roleId) |
| | | this.$router.push("/archiveManager/infoManagerAu/user/" + roleId+"/"+archiveRecordsId) |
| | | }, |
| | | /** 删除按钮操作 */ |
| | | handleDelete(row) { |
| | | const ids = row.id || this.ids |
| | | this.$modal.confirm('是否确认删除档案记录编号为"' + ids + '"的数据项?').then(function() { |
| | | return delRecords(ids) |
| | | }).then(() => { |
| | | this.getList() |
| | | this.$modal.msgSuccess("删除成功") |
| | | }).catch(() => {}) |
| | | }, |
| | | /** 导出按钮操作 */ |
| | | handleExport() { |
| | | this.download('system/records/export', { |
| | | ...this.queryParams |
| | | }, `records_${new Date().getTime()}.xlsx`) |
| | | } |
| | | } |
| | | } |
| | | </script> |
| | | <style scoped> |
| | | .force-width { |
| | | width: 900px !important; /* 设置固定宽度 */ |
| | | } |
| | | |
| | | body .el-message-box.force-width { |
| | | width: 800px !important; |
| | | } |
| | | </style> |
| | |
| | | <div class="app-container home"> |
| | | |
| | | |
| | | <h1>档案管理系统</h1> |
| | | <h1>城市建设档案管理系统</h1> |
| | | |
| | | |
| | | </div> |
| | |
| | | <el-dropdown size="mini" @command="(command) => handleCommand(command, scope.row)" v-hasPermi="['system:role:edit']"> |
| | | <el-button size="mini" type="text" icon="el-icon-d-arrow-right">更多</el-button> |
| | | <el-dropdown-menu slot="dropdown"> |
| | | <el-dropdown-item command="handleDataScope" icon="el-icon-circle-check" |
| | | v-hasPermi="['system:role:edit']">数据权限</el-dropdown-item> |
| | | <!-- <el-dropdown-item command="handleDataScope" icon="el-icon-circle-check" |
| | | v-hasPermi="['system:role:edit']">数据权限</el-dropdown-item> --> |
| | | <el-dropdown-item command="handleAuthUser" icon="el-icon-user" |
| | | v-hasPermi="['system:role:edit']">分配用户</el-dropdown-item> |
| | | </el-dropdown-menu> |
| | |
| | | <el-table-column label="用户编号" align="center" key="userId" prop="userId" v-if="columns[0].visible" /> |
| | | <el-table-column label="用户名称" align="center" key="userName" prop="userName" v-if="columns[1].visible" :show-overflow-tooltip="true" /> |
| | | <el-table-column label="用户昵称" align="center" key="nickName" prop="nickName" v-if="columns[2].visible" :show-overflow-tooltip="true" /> |
| | | <el-table-column label="部门" align="center" key="deptName" prop="dept.deptName" v-if="columns[3].visible" :show-overflow-tooltip="true" /> |
| | | <!-- <el-table-column label="部门" align="center" key="deptName" prop="dept.deptName" v-if="columns[3].visible" :show-overflow-tooltip="true" /> --> |
| | | <el-table-column label="手机号码" align="center" key="phonenumber" prop="phonenumber" v-if="columns[4].visible" width="120" /> |
| | | <el-table-column label="状态" align="center" key="status" v-if="columns[5].visible"> |
| | | <template slot-scope="scope"> |
| | |
| | | <svg-icon icon-class="email" />用户邮箱 |
| | | <div class="pull-right">{{ user.email }}</div> |
| | | </li> |
| | | <li class="list-group-item"> |
| | | <svg-icon icon-class="tree" />所属部门 |
| | | <div class="pull-right" v-if="user.dept">{{ user.dept.deptName }} / {{ postGroup }}</div> |
| | | </li> |
| | | |
| | | <li class="list-group-item"> |
| | | <svg-icon icon-class="peoples" />所属角色 |
| | | <div class="pull-right">{{ roleGroup }}</div> |
| | |
| | | <template> |
| | | <el-form ref="form" :model="form" :rules="rules" label-width="80px"> |
| | | <el-form-item label="用户昵称" prop="nickName"> |
| | | <el-form-item label="用户名称" prop="nickName"> |
| | | <el-input v-model="form.nickName" maxlength="30" /> |
| | | </el-form-item> |
| | | <el-form-item label="手机号码" prop="phonenumber"> |