book.vue 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277
  1. <template>
  2. <hc-new-card title="材料预付款报表手册">
  3. <template #extra>
  4. <el-button hc-btn type="primary" @click="addModalClick">
  5. <HcIcon name="add" />
  6. <span>新增</span>
  7. </el-button>
  8. </template>
  9. <hc-table :column="tableColumn" :datas="tableData" :loading="tableLoading" is-new :index-style="{ width: 60 }">
  10. <template #action="{ row }">
  11. <el-link type="primary" :disabled="!row.rawUrl" @click="rowViewRawPdf(row)">查看电签报表</el-link>
  12. <el-link type="primary" @click="viewPdf(row)">查看报表</el-link>
  13. <el-link type="primary" :disabled="row.approveStatus === 0" @click="eVisaRowClick(row)">查看电签流程</el-link>
  14. <el-link type="success" @click="editRow(row)">修改</el-link>
  15. <el-link type="danger" @click="delCilck(row)">删除</el-link>
  16. <el-link v-loading="row?.recalculateLoading" @click="recalculate(row)">重新计算</el-link>
  17. </template>
  18. </hc-table>
  19. <template #action>
  20. <hc-pages :pages="searchForm" @change="pageChange" />
  21. </template>
  22. <!-- 新增/修改 -->
  23. <hc-new-dialog v-model="formModalShow" is-to-body widths="30rem" :title="modalTitle" :loading="saveLoading" @save="formModalSave" @close="formModalClose">
  24. <el-form ref="formRef" class="p-4" :model="formModel" :rules="formRules" label-position="top">
  25. <el-form-item label="计量期:" prop="meterPeriodId">
  26. <el-select v-if="editType === 'add'" v-model="formModel.meterPeriodId" placeholder="选择计量期" filterable clearable block @change="selectPeriod">
  27. <el-option v-for="item in periodData" :key="item.id" :label="item.periodName" :value="item.id" />
  28. </el-select>
  29. <el-select v-if="editType === 'edit'" v-model="formModel.meterPeriodId" placeholder="选择计量期" disabled filterable clearable block @change="selectPeriod">
  30. <el-option v-for="item in key1Data" :key="item.id" :label="item.periodName" :value="item.id" />
  31. </el-select>
  32. </el-form-item>
  33. <el-form-item label="报表名称:" prop="statementName">
  34. <el-input v-model="formModel.statementName" />
  35. </el-form-item>
  36. <el-form-item label="报表期:">
  37. <el-input v-model="formModel.statementPeriod" disabled />
  38. </el-form-item>
  39. <el-form-item label="打印日期:">
  40. <el-date-picker v-model="formModel.printDate" class="block" format="YYYY-MM-DD" type="date" value-format="YYYY-MM-DD" />
  41. </el-form-item>
  42. <el-form-item label="请款理由:">
  43. <el-input v-model="formModel.repaymentCause" :autosize="{ minRows: 3, maxRows: 6 }" type="textarea" />
  44. </el-form-item>
  45. </el-form>
  46. </hc-new-dialog>
  47. <!-- 任务流程 -->
  48. <HcTaskModal v-model="isTaskModal" :ids="taskDataId" @close="taskDataId = ''" />
  49. </hc-new-card>
  50. </template>
  51. <script setup>
  52. import { onActivated, ref } from 'vue'
  53. import bookApi from '~api/debit-pay/material/book.js'
  54. import periodApi from '~api/debit-pay/material/periods.js'
  55. import { useAppStore } from '~src/store'
  56. import { formValidate, getArrValue, isNullES } from 'js-fast-way'
  57. import { toPdfPage } from '~uti/btn-auth'
  58. const useAppState = useAppStore()
  59. const contractId = ref(useAppState.getContractId)
  60. const projectId = ref(useAppState.getProjectId)
  61. import HcTaskModal from '~src/components/task-modal/task-modal.vue'
  62. import { HcDelMsg } from 'hc-vue3-ui'
  63. defineOptions({
  64. name: 'DebitPayMaterialBook',
  65. })
  66. //渲染完成
  67. onActivated(() => {
  68. getTableData()
  69. getPeriodData()
  70. getKey1Data()
  71. })
  72. //计量期
  73. const periodData = ref([])
  74. //未被引用的
  75. const getPeriodData = async ()=>{
  76. const { error, code, data } = await periodApi.conditionPeriod({
  77. contractId:contractId.value,
  78. type:1,
  79. })
  80. tableLoading.value = false
  81. if (!error && code === 200) {
  82. periodData.value = getArrValue(data)
  83. } else {
  84. periodData.value = []
  85. }
  86. }
  87. //所有计量期
  88. const key1Data = ref([])
  89. const getKey1Data = async ()=>{
  90. const { error, code, data } = await periodApi.allPeriod({
  91. contractId:contractId.value,
  92. type:1,
  93. })
  94. tableLoading.value = false
  95. if (!error && code === 200) {
  96. key1Data.value = getArrValue(data)
  97. } else {
  98. key1Data.value = []
  99. }
  100. }
  101. const selectPeriod = (val)=>{
  102. periodData.value.forEach((ele)=>{
  103. if (ele.id === val) {
  104. formModel.value.statementPeriod = ele.periodName
  105. formModel.value.printDate = ele.formPrintDate
  106. formModel.value.periodNumber = ele.periodNumber
  107. }
  108. })
  109. }
  110. //搜索表单
  111. const searchForm = ref({
  112. current: 1, size: 20, total: 0,
  113. })
  114. //分页
  115. const pageChange = ({ current, size }) => {
  116. searchForm.value.current = current
  117. searchForm.value.size = size
  118. getTableData()
  119. }
  120. //表格数据
  121. const tableLoading = ref(false)
  122. const tableColumn = ref([
  123. { key: 'periodNumber', name: '计量期' },
  124. { key: 'statementName', name: '报表名称' },
  125. { key: 'printDate', name: '打印日期' },
  126. { key: 'calculateDate', name: '重新计算时间' },
  127. { key: 'action', name: '操作', width: 400, align: 'center' },
  128. ])
  129. const tableData = ref([])
  130. const getTableData = async () => {
  131. tableLoading.value = true
  132. const { error, code, data } = await bookApi.getPage({
  133. ...searchForm.value,
  134. contractId:contractId.value,
  135. type:1,
  136. // meterPeriodId:searchForm.value.key1,
  137. })
  138. tableLoading.value = false
  139. if (!error && code === 200) {
  140. tableData.value = getArrValue(data['records'])
  141. searchForm.value.total = data['total']
  142. } else {
  143. tableData.value = []
  144. searchForm.value.total = 0
  145. }
  146. }
  147. //新增
  148. const formModalShow = ref(false)
  149. const editType = ref('')
  150. const modalTitle = ref('材料预付款报表新增')
  151. const addModalClick = () => {
  152. formModalShow.value = true
  153. formModel.value = {}
  154. editType.value = 'add'
  155. modalTitle.value = '材料预付款报表新增'
  156. }
  157. const editRow = (row)=>{
  158. formModalShow.value = true
  159. console.log(row, 'row')
  160. formModel.value = row
  161. editType.value = 'edit'
  162. modalTitle.value = '材料预付款报表修改'
  163. }
  164. const delCilck = (row)=>{
  165. HcDelMsg( async ( resolve) => {
  166. await removeProPay(row.id)
  167. resolve() //关闭弹窗的回调
  168. })
  169. }
  170. //查看报表
  171. const viewPdf = (row)=>{
  172. toPdfPage(row.rawUrl)
  173. }
  174. //重新计算
  175. const recalculate = async (row)=>{
  176. row.recalculateLoading = true
  177. const { error, code, msg } = await bookApi.meterPdfInfo({
  178. reportId:row.id,
  179. type:1,
  180. taskType:1,
  181. })
  182. row.recalculateLoading = false
  183. if (!error && code === 200) {
  184. window.$message.success('计算成功')
  185. getTableData()
  186. } else {
  187. window.$message.error(msg ?? '操作失败')
  188. }
  189. }
  190. const removeProPay = async (id) => {
  191. const { error, code, msg } = await bookApi.remove({
  192. ids: id,
  193. })
  194. if (!error && code === 200) {
  195. window?.$message?.success('删除成功')
  196. getTableData()
  197. } else {
  198. window.$message.error(msg ?? '操作失败')
  199. }
  200. }
  201. //表单
  202. const formRef = ref(null)
  203. const formModel = ref({})
  204. const formRules = {
  205. meterPeriodId: {
  206. required: true,
  207. trigger: 'blur',
  208. message: '请选择计量期',
  209. },
  210. statementName: {
  211. required: true,
  212. trigger: 'blur',
  213. message: '请输入报表名称',
  214. },
  215. }
  216. const saveLoading = ref(false)
  217. const formModalSave = async () => {
  218. const isValidate = await formValidate(formRef.value)
  219. if (!isValidate) return false
  220. saveLoading.value = true
  221. const { error, code, msg } = await bookApi.submit({
  222. ...formModel.value,
  223. contractId:contractId.value,
  224. projectId:projectId.value,
  225. type:1,
  226. })
  227. //判断状态
  228. saveLoading.value = false
  229. if (!error && code === 200) {
  230. window?.$message?.success(msg)
  231. } else {
  232. window.$message.error(msg ?? '操作失败')
  233. }
  234. formModalClose()
  235. }
  236. const formModalClose = () => {
  237. formModalShow.value = false
  238. getTableData()
  239. }
  240. const rowViewRawPdf = (row)=>{
  241. toPdfPage(row?.rawUrl)
  242. }
  243. //查看电签流程
  244. const isTaskModal = ref(false)
  245. const taskDataId = ref('')
  246. const eVisaRowClick = ({ taskId }) => {
  247. if (isNullES(taskId)) {
  248. window.$message.warning('暂无电签数据')
  249. return
  250. }
  251. taskDataId.value = taskId
  252. setTimeout(()=> {
  253. isTaskModal.value = true
  254. }, 200)
  255. }
  256. </script>
  257. <style scoped lang="scss">
  258. </style>