阅行客电子档案
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

158 lines
4.9 KiB

  1. <template>
  2. <div class="app-container row-container">
  3. <div class="connection-header collect-header">
  4. <div class="head-search">
  5. <date-range-picker v-model="blurryTime" class="date-item" />
  6. <rrOperation />
  7. </div>
  8. <crudOperation>
  9. <template v-slot:right>
  10. <el-button :loading="crud.downloadLoading" size="mini" :disabled="crud.selections.length === 0" @click="doExport(crud.selections)">
  11. <i class="iconfont icon-daochu" />
  12. 导出
  13. </el-button>
  14. </template>
  15. </crudOperation>
  16. </div>
  17. <el-table ref="table" v-loading="crud.loading" :data="crud.data" style="width: 100%;" height="calc(100vh - 330px)" @selection-change="crud.selectionChangeHandler" @row-dblclick="handleDetail">
  18. <el-table-column type="selection" align="center" width="55" />
  19. <el-table-column prop="dept" label="申请部门" />
  20. <el-table-column prop="create_by" label="申请人" />
  21. <el-table-column prop="category" label="档案门类" />
  22. <el-table-column prop="fonds" label="所属全宗" />
  23. <el-table-column prop="approval" label="审批单" width="260" />
  24. <el-table-column prop="status" label="审批状态" align="center">
  25. <template slot-scope="scope">
  26. <span v-if="scope.row.status===1" class="row-state end-state">已审批</span>
  27. <span v-else class="row-state ing-state">审批中</span>
  28. </template>
  29. </el-table-column>
  30. <el-table-column prop="create_time" label="申请时间">
  31. <template slot-scope="scope">
  32. <div>{{ scope.row.create_time | parseTime }}</div>
  33. </template>
  34. </el-table-column>
  35. </el-table>
  36. <!--分页组件-->
  37. <pagination v-if="crud.data.length !== 0" />
  38. <Detail ref="processDetail" :is-histroy="isHistroy" />
  39. </div>
  40. </template>
  41. <script>
  42. // import crudConnection from '@/api/system/role'
  43. import crudRoles from '@/api/system/role'
  44. import CRUD, { presenter, header, crud } from '@crud/crud'
  45. import DateRangePicker from '@/components/DateRangePicker'
  46. import rrOperation from '@crud/RR.operation'
  47. import crudOperation from '@crud/CRUD.operation'
  48. import pagination from '@crud/Pagination'
  49. // import { exportFile } from '@/utils/index'
  50. // import qs from 'qs'
  51. import { mapGetters } from 'vuex'
  52. import Detail from '@/views/system/processManage/runningProcess/module/detail'
  53. const data = [
  54. {
  55. 'id': '005E76FEC5A2AAB368CA1F',
  56. 'dept': '档案室',
  57. 'status': 1,
  58. 'category': '文书档案(案卷)',
  59. 'fonds': '全宗1',
  60. 'approval': '归档审批流程-admin-2016-09-21',
  61. 'create_time': 1687330805000,
  62. 'create_by': 'admin'
  63. },
  64. {
  65. 'id': '005E76FEC5A2AAB368CA1F',
  66. 'dept': '档案室',
  67. 'status': 0,
  68. 'category': '文书档案(案卷)',
  69. 'fonds': '全宗1',
  70. 'approval': '归档审批流程-admin-2016-09-21',
  71. 'create_time': 1687330805000,
  72. 'create_by': 'admin'
  73. }
  74. ]
  75. export default {
  76. name: 'FilingApprovalList',
  77. components: { Detail, DateRangePicker, rrOperation, crudOperation, pagination },
  78. cruds() {
  79. return [
  80. CRUD({
  81. title: '归档审批清单', url: 'api/role/initRoleList',
  82. crudMethod: { ...crudRoles },
  83. optShow: {
  84. add: false,
  85. edit: false,
  86. del: false,
  87. reset: true,
  88. download: false,
  89. group: false
  90. }
  91. })
  92. ]
  93. },
  94. mixins: [presenter(), header(), crud()],
  95. props: {
  96. },
  97. data() {
  98. return {
  99. blurryTime: null
  100. }
  101. },
  102. computed: {
  103. ...mapGetters([
  104. 'baseApi'
  105. ])
  106. },
  107. created() {
  108. },
  109. mounted() {
  110. },
  111. methods: {
  112. [CRUD.HOOK.beforeRefresh]() {
  113. if (this.blurryTime) {
  114. this.crud.query.startTime = this.blurryTime[0]
  115. this.crud.query.endTime = this.blurryTime[1]
  116. }
  117. },
  118. [CRUD.HOOK.afterRefresh]() {
  119. this.crud.data = data
  120. },
  121. handleDetail(row) {
  122. this.$refs.processDetail.detailVisible = true
  123. this.$refs.processDetail.selectRow = row
  124. this.$refs.processDetail.activeIndex = 0
  125. },
  126. doExport(data) {
  127. crud.downloadLoading = true
  128. this.$confirm('此操作将导出所选数据' + '<span>你是否还要继续?</span>', '提示', {
  129. confirmButtonText: '继续',
  130. cancelButtonText: '取消',
  131. type: 'warning',
  132. dangerouslyUseHTMLString: true
  133. }).then(() => {
  134. const ids = []
  135. data.forEach(val => {
  136. ids.push(val.id)
  137. })
  138. // const params = {
  139. // 'roleIds': ids
  140. // }
  141. // exportFile(this.baseApi + '/api/role/exportRole?' + qs.stringify(params, { indices: false }))
  142. }).catch(() => {
  143. })
  144. }
  145. }
  146. }
  147. </script>
  148. <style lang="scss" scoped>
  149. @import "~@/assets/styles/collect-reorganizi.scss";
  150. .connection-header{
  151. padding: 0 !important;
  152. }
  153. </style>