fei
2025-09-09 1a64a71d96069b92c84d781ce2e39dc29f630ada
新增了代码
3个文件已添加
16个文件已修改
19272 ■■■■■ 已修改文件
.env.development 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
.env.production 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
package-lock.json 16533 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
package.json 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/api/system/archiveEx.js 13 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/api/system/archiverecordstouser.js 13 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/api/system/records.js 17 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main.js 3 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/archiveExport/index.vue 898 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/archiveManager/archiveMaterial/index.vue 951 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/archiveManager/index.vue 165 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/archiveManager/seleUser.vue 15 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/archiveStatics/index.vue 275 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/archiveToUserStatistic/index.vue 368 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/index.vue 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/system/role/index.vue 4 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/system/user/index.vue 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/system/user/profile/index.vue 5 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/system/user/profile/userInfo.vue 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
.env.development
@@ -1,5 +1,5 @@
# 页面标题
VUE_APP_TITLE = 档案管理系统
VUE_APP_TITLE = 城市建设档案管理系统
# 开发环境配置
ENV = 'development'
.env.production
@@ -1,5 +1,5 @@
# 页面标题
VUE_APP_TITLE = 档案管理系统
VUE_APP_TITLE = 城市建设档案管理系统
# 生产环境配置
ENV = 'production'
package-lock.json
Diff too large
package.json
@@ -28,7 +28,7 @@
    "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",
src/api/system/archiveEx.js
New file
@@ -0,0 +1,13 @@
import request from '@/utils/request'
// 导出档案
export function archiveAllExport(query) {
  return request({
    url: '/system/archiveAllExport/export',
    method: 'post',
    params: query
  })
}
src/api/system/archiverecordstouser.js
@@ -1,5 +1,18 @@
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({
src/api/system/records.js
@@ -1,4 +1,21 @@
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) {
src/main.js
@@ -35,7 +35,10 @@
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
src/views/archiveExport/index.vue
New file
@@ -0,0 +1,898 @@
<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>
src/views/archiveManager/archiveMaterial/index.vue
@@ -1,5 +1,487 @@
<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">
@@ -42,6 +524,23 @@
          @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"
@@ -114,7 +613,7 @@
          </el-select>
      </el-form-item>
      <el-form-item label="是否敏感" prop="isSensitive">
        <el-select
@@ -131,7 +630,7 @@
          </el-select>
      </el-form-item>
      <el-form-item label="是否注销" prop="isCanceled">
        <el-select
            v-model="queryParams.isCanceled"
@@ -153,266 +652,36 @@
      </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: '普通', label: '普通' }
@@ -441,7 +710,8 @@
          { 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,
        // 遮罩层
@@ -462,6 +732,8 @@
        title: "",
        // 是否显示弹出层
        open: false,
        titles: "",
        opens: false,
        // 查询参数
        queryParams: {
          pageNum: 1,
@@ -497,25 +769,43 @@
            // ... 其他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
@@ -523,6 +813,62 @@
      }
    },
    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
@@ -537,6 +883,37 @@
      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() {
@@ -588,45 +965,54 @@
      },
      /** 新增按钮操作 */
      handleAdd() {
        this.reset()
        this.form.securityLevel = '普通' // 设置对话框表单默认值
        this.form.isSensitive = '否' // 设置对话框表单默认值
        this.form.isCanceled = '否' // 设置对话框表单默认值
        this.form.isAttachment = '否' // 设置对话框表单默认值
        this.form.isDiagram = '否' // 设置对话框表单默认值
        this.form.retentionPeriod = '永久' // 设置对话框表单默认值
        this.open = true
        this.title = "添加案卷详细信息"
        this.opens = true
        this.titles = "搜索案卷详细信息"
      },
      /** 修改按钮操作 */
      handleUpdate(row) {
        this.reset()
        this.resets()
        const materialId = row.materialId || this.ids
        getMaterials(materialId).then(response => {
          this.form = response.data
          this.forms = response.data
          this.open = true
          this.title = "修改案卷详细信息"
        })
      },
      resetForms()
      {
   this.reset()
          this.form.securityLevel = '普通' // 设置对话框表单默认值
          this.form.isSensitive = '否' // 设置对话框表单默认值
          this.form.isCanceled = '否' // 设置对话框表单默认值
          this.form.isAttachment = '否' // 设置对话框表单默认值
          this.form.isDiagram = '否' // 设置对话框表单默认值
          this.form.retentionPeriod = '永久' // 设置对话框表单默认值
      },
      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()
        })
      },
      /** 提交按钮 */
      submitForm() {
        this.$refs["form"].validate(valid => {
      submitForms() {
        this.$refs["forms"].validate(valid => {
          if (valid) {
            if (this.form.materialId != null) {
              updateMaterials(this.form).then(response => {
            if (this.forms.materialId != null) {
              updateMaterials(this.forms).then(response => {
                this.$modal.msgSuccess("修改成功")
                this.open = false
                this.getList()
              })
            } else {
              console.log(this.form)
              this.form.recordId = this.recordId
              console.log("==============+++++++++++++++============")
              addMaterials(this.form).then(response => {
                this.$modal.msgSuccess("新增成功")
                this.open = false
                this.getList()
              })
            }
          }
        })
@@ -650,3 +1036,10 @@
    }
  }
  </script>
<style scoped>
.title-border {
  border-bottom: 1px solid #dcdfe6;
  padding-bottom: 10px;
  margin-bottom: 20px;
}
</style>
src/views/archiveManager/index.vue
@@ -223,7 +223,9 @@
<!--      <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">
@@ -244,6 +246,16 @@
      <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
@@ -257,14 +269,20 @@
          >案卷详细信息</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"
@@ -411,12 +429,12 @@
    <!-- 添加或修改档案记录对话框 -->
    <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
              v-model="form.recordType"
              placeholder="选择档案类型"
              @change="handleRecordTypeChange"
@@ -429,7 +447,24 @@
              />
            </el-select>
          </el-col>
          <el-col :span="6">
            <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="输入年份"
@@ -437,7 +472,7 @@
:disabled="userId!=1"
            />
          </el-col>
          <el-col :span="6">
          <el-col :span="4">
            <el-input
              v-model="form.recordSeq"
              placeholder="自动生成"
@@ -450,15 +485,30 @@
          <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>
        <el-form-item label="公开属性" prop="publicAttribute">
          <el-select
            v-model="form.publicAttribute"
@@ -473,7 +523,7 @@
            />
          </el-select>
        </el-form-item>
        <el-form-item label="编制单位" prop="preparationUnit">
          <el-input v-model="form.preparationUnit" placeholder="请输入编制单位" />
        </el-form-item>
@@ -525,7 +575,9 @@
        <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>
@@ -555,9 +607,10 @@
</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() {
@@ -568,10 +621,14 @@
        { value: '普通', label: '普通' }
      ],
      maxId: 0,
            // 档案类型选项
            recordTypeOptions: [],
            // 保管期限选项
            retentionPeriodOptions: [
      // 项目名称选项
      projectOptions: [],
      // 档案类型选项
      recordTypeOptions: [],
      //地区类型
      zoneTypeOptions: [],
      // 保管期限选项
      retentionPeriodOptions: [
        { value: "10年", label: "10年" },
        { value: "30年", label: "30年" },
        { value: "永久", label: "永久" }
@@ -609,6 +666,7 @@
        pageSize: 10,
        recordId: null,
        inquiryNumber: null,
        everyProjectName: null,
        caseTitle: null,
        publicAttribute: null,
        preparationUnit: null,
@@ -639,21 +697,22 @@
        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()
@@ -662,12 +721,38 @@
      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() {
@@ -690,13 +775,14 @@
    /** 生成档案号 */
    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}`
        // })
      }
    },
@@ -724,6 +810,7 @@
        id: null,
        recordId: null,
        inquiryNumber: null,
        everyProjectName: null,
        caseTitle: null,
        publicAttribute: null,
        preparationUnit: null,
@@ -781,6 +868,16 @@
      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) {
@@ -796,8 +893,10 @@
  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 = "修改档案记录"
@@ -815,8 +914,10 @@
  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 = "查看档案记录"
@@ -834,11 +935,13 @@
              this.getList()
            })
          } else {
            console.log(this.form)
            addRecords(this.form).then(response => {
              this.$modal.msgSuccess("新增成功")
              this.open = false
              this.getList()
              this.getId()
              this.getList()
            })
          }
src/views/archiveManager/seleUser.vue
@@ -24,7 +24,8 @@
      </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" />
@@ -93,6 +94,15 @@
    }
  },
  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) {
@@ -105,7 +115,8 @@
      this.visible = true
    },
    clickRow(row) {
      this.$refs.table.toggleRowSelection(row)
      this.$refs.table.clearSelection();
    this.$refs.table.toggleRowSelection(row);
    },
    // 多选框选中数据
    handleSelectionChange(selection) {
src/views/archiveStatics/index.vue
@@ -1,167 +1,6 @@
<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">
@@ -209,18 +48,27 @@
      <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>
@@ -336,17 +184,28 @@
        <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: [],
@@ -427,12 +286,67 @@
  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;
@@ -481,11 +395,11 @@
      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
      })
    },
@@ -631,3 +545,12 @@
  }
}
</script>
<style scoped>
.force-width {
  width: 900px !important; /* 设置固定宽度 */
}
body .el-message-box.force-width {
  width: 800px !important;
}
</style>
src/views/archiveToUserStatistic/index.vue
New file
@@ -0,0 +1,368 @@
<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>
src/views/index.vue
@@ -2,7 +2,7 @@
  <div class="app-container home">
    <h1>档案管理系统</h1>
    <h1>城市建设档案管理系统</h1>
  </div>
src/views/system/role/index.vue
@@ -137,8 +137,8 @@
          <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>
src/views/system/user/index.vue
@@ -61,7 +61,7 @@
              <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">
src/views/system/user/profile/index.vue
@@ -23,10 +23,7 @@
                <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>
src/views/system/user/profile/userInfo.vue
@@ -1,6 +1,6 @@
<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">