Explorar o código

企业生产报告管理

Memory_LG hai 1 ano
pai
achega
360482732c

+ 44 - 0
data-ui/src/api/data/housingconstruction/enterpriseproductionreport.js

@@ -0,0 +1,44 @@
+import request from '@/utils/request'
+
+// 查询企业生产报告列表
+export function listEnterpriseproductionreport(query) {
+  return request({
+    url: '/sooka-sponest-center-data/enterpriseproductionreport/list',
+    method: 'get',
+    params: query
+  })
+}
+
+// 查询企业生产报告详细
+export function getEnterpriseproductionreport(id) {
+  return request({
+    url: '/sooka-sponest-center-data/enterpriseproductionreport/' + id,
+    method: 'get'
+  })
+}
+
+// 新增企业生产报告
+export function addEnterpriseproductionreport(data) {
+  return request({
+    url: '/sooka-sponest-center-data/enterpriseproductionreport',
+    method: 'post',
+    data: data
+  })
+}
+
+// 修改企业生产报告
+export function updateEnterpriseproductionreport(data) {
+  return request({
+    url: '/sooka-sponest-center-data/enterpriseproductionreport',
+    method: 'put',
+    data: data
+  })
+}
+
+// 删除企业生产报告
+export function delEnterpriseproductionreport(id) {
+  return request({
+    url: '/sooka-sponest-center-data/enterpriseproductionreport/' + id,
+    method: 'delete'
+  })
+}

+ 332 - 0
data-ui/src/views/data/housingconstruction/enterpriseproductionreport/index.vue

@@ -0,0 +1,332 @@
+<template>
+  <div class="app-container">
+    <el-form :model="queryParams" ref="queryForm" :inline="true" v-show="showSearch" label-width="68px">
+      <el-form-item label="报告类型" prop="reportType">
+        <el-select v-model="queryParams.reportType" placeholder="请选择报告类型" clearable size="small">
+          <el-option
+            v-for="dict in dict.type.enterprise_production_report"
+            :key="dict.value"
+            :label="dict.label"
+            :value="dict.value"
+          />
+        </el-select>
+      </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="['housingconstruction:enterpriseproductionreport:add']"
+        >新增
+        </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="['housingconstruction:enterpriseproductionreport: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="['housingconstruction:enterpriseproductionreport:export']"
+        >导出
+        </el-button>
+      </el-col>
+      <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
+    </el-row>
+
+    <el-table v-loading="loading" :data="enterpriseproductionreportList" @selection-change="handleSelectionChange">
+      <el-table-column type="selection" width="55" align="center"/>
+      <el-table-column label="企业名称" align="center" prop="enterpriseName"/>
+      <el-table-column label="报告类型" align="center" prop="reportType">
+        <template slot-scope="scope">
+          <dict-tag :options="dict.type.enterprise_production_report" :value="scope.row.reportType"/>
+        </template>
+      </el-table-column>
+      <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
+        <template slot-scope="scope">
+          <el-button
+            size="mini"
+            type="text"
+            icon="el-icon-edit"
+            @click="handleUpdate(scope.row)"
+            v-hasPermi="['housingconstruction:enterpriseproductionreport:edit']"
+          >详情</el-button>
+          <el-button
+            size="mini"
+            type="text"
+            icon="el-icon-delete"
+            @click="handleDelete(scope.row)"
+            v-hasPermi="['housingconstruction:enterpriseproductionreport: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 class="form-style">
+      <el-form ref="form" :model="form" :rules="rules" label-width="80px">
+        <el-form-item label="所属企业" prop="enterpriseId">
+          <el-select v-model="form.enterpriseId" placeholder="请选择所属企业" @change="handleEnterpriseChange">
+            <el-option
+              v-for="data in enterpriseList"
+              :key="data.id"
+              :label="data.enterpriseName"
+              :value="data.id"
+            ></el-option>
+          </el-select>
+        </el-form-item>
+        <el-form-item label="报告类型" prop="reportType">
+          <el-select v-model="form.reportType" placeholder="请选择报告类型">
+            <el-option
+              v-for="dict in dict.type.enterprise_production_report"
+              :key="dict.value"
+              :label="dict.label"
+              :value="dict.value"
+            ></el-option>
+          </el-select>
+        </el-form-item>
+        <el-form-item label="报告文件" prop="fileUrl">
+          <fileUpload v-model="form.fileUrl" :setFileName="setFileName" :removeFileName="removeFileName"></fileUpload>
+        </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 {
+  addEnterpriseproductionreport,
+  delEnterpriseproductionreport,
+  getEnterpriseproductionreport,
+  listEnterpriseproductionreport,
+  updateEnterpriseproductionreport
+} from "@/api/data/housingconstruction/enterpriseproductionreport";
+import {getListAll} from "@/api/data/housingconstruction/enterprise";
+import FileUpload from "@/views/components/FileUpload/index.vue";
+
+export default {
+  name: "Enterpriseproductionreport",
+  components: {FileUpload},
+  dicts: ['enterprise_production_report'],
+  data() {
+    return {
+      // 遮罩层
+      loading: true,
+      // 选中数组
+      ids: [],
+      // 非单个禁用
+      single: true,
+      // 非多个禁用
+      multiple: true,
+      // 显示搜索条件
+      showSearch: true,
+      // 总条数
+      total: 0,
+      // 企业生产报告表格数据
+      enterpriseproductionreportList: [],
+      //企业信息列表
+      enterpriseList: [],
+      fileNames: [],
+      // 弹出层标题
+      title: "",
+      // 是否显示弹出层
+      open: false,
+      // 查询参数
+      queryParams: {
+        pageNum: 1,
+        pageSize: 10,
+        reportType: null,
+      },
+      // 表单参数
+      form: {
+        fileUrl: '',
+        fileName: '',
+        fileUrlList: [],
+        fileNameList: []
+      },
+      // 表单校验
+      rules: {
+        enterpriseId: [
+          {required: true, message: "企业不能为空", trigger: "blur"}
+        ],
+        reportType:[
+          {required: true, message: "报告类型不能为空", trigger: "blur"}
+        ],
+        fileUrl: [
+          {required: true, message: "报告文件不能为空", trigger: "blur"}
+        ],
+      }
+    };
+  },
+  created() {
+    this.getList();
+    this.getEnterpriseList();
+  },
+  methods: {
+    /** 附件:文件 **/
+    setFileName(fileName) {
+      let that = this
+      that.fileNames.push(fileName)
+    },
+    removeFileName(index) {
+      let that = this
+      that.fileNames.splice(index, 1);
+      let fileurls = that.form.fileUrl.split(",")
+      fileurls.splice(index, 1)
+      that.form.fileUrl = fileurls.toString()
+    },
+    handleEnterpriseChange(newId) {
+      const selectedEnterprise = this.enterpriseList.find(item => item.id === newId);
+      if (selectedEnterprise) {
+        this.form.enterpriseName = selectedEnterprise.enterpriseName;
+      } else {
+        this.form.enterpriseName = '';
+      }
+    },
+    getEnterpriseList(){
+      getListAll().then(res=>{
+        this.enterpriseList = res.data
+      })
+    },
+    /** 查询企业生产报告列表 */
+    getList() {
+      this.loading = true;
+      listEnterpriseproductionreport(this.queryParams).then(response => {
+        this.enterpriseproductionreportList = response.rows;
+        this.total = response.total;
+        this.loading = false;
+      });
+    },
+    // 取消按钮
+    cancel() {
+      this.open = false;
+      this.reset();
+    },
+    // 表单重置
+    reset() {
+      this.form = {
+        id: null,
+        enterpriseId: null,
+        enterpriseName: null,
+        reportType: null,
+        createTime: null,
+        createBy: null,
+        createName: null
+      };
+      this.fileNames = [];
+      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.open = true;
+      this.title = "添加企业生产报告";
+    },
+    /** 修改按钮操作 */
+    handleUpdate(row) {
+      this.reset();
+      const id = row.id || this.ids
+      getEnterpriseproductionreport(id).then(response => {
+        const list = response.data.fileUrl.split(',');
+        if (response.data.fileUrl != "") {
+          for (var a = 0; a < list.length; a++) {
+            let listurl = list[a].split('+')
+            this.fileNames.push(listurl[1])
+          }
+        }
+        this.form = response.data;
+        this.open = true;
+        this.title = "修改企业生产报告";
+      });
+    },
+    /** 提交按钮 */
+    submitForm() {
+      this.$refs["form"].validate(valid => {
+        if (valid) {
+          this.form.fileName = this.fileNames.toString()
+          if (this.form.id != null) {
+            updateEnterpriseproductionreport(this.form).then(response => {
+              this.$modal.msgSuccess("修改成功");
+              this.open = false;
+              this.getList();
+            });
+          } else {
+            addEnterpriseproductionreport(this.form).then(response => {
+              this.$modal.msgSuccess("新增成功");
+              this.open = false;
+              this.getList();
+            });
+          }
+        }
+      });
+    },
+    /** 删除按钮操作 */
+    handleDelete(row) {
+      const ids = row.id || this.ids;
+      this.$modal.confirm('是否确认删除企业生产报告编号为"' + ids + '"的数据项?').then(function () {
+        return delEnterpriseproductionreport(ids);
+      }).then(() => {
+        this.getList();
+        this.$modal.msgSuccess("删除成功");
+      }).catch(() => {
+      });
+    },
+    /** 导出按钮操作 */
+    handleExport() {
+      this.download('housingconstruction/enterpriseproductionreport/export', {
+        ...this.queryParams
+      }, `enterpriseproductionreport_${new Date().getTime()}.xlsx`)
+    }
+  }
+};
+</script>

+ 2 - 2
data-ui/src/views/data/housingconstruction/gassource/index.vue

@@ -238,11 +238,11 @@ import "@riophae/vue-treeselect/dist/vue-treeselect.css";
 import {treeselect} from "@/api/system/dept";
 import {getCarList} from "@/api/data/housingconstruction/car";
 import DataImageUpload from "@/components/ImageUpload/dataUpload.vue";
-import fileUpload from '@/views/components/FileUpload/index.vue'
+import FileUpload from '@/views/components/FileUpload/index.vue'
 
 export default {
   name: "Gassource",
-  components: {DataImageUpload, deptselector, Treeselect, fileUpload},
+  components: {DataImageUpload, deptselector, Treeselect, FileUpload},
   dicts: ['housingconstruction_component'],
   data() {
     return {

+ 91 - 0
src/main/java/com/sooka/sponest/data/housingconstruction/controller/CenterdataTHousingconstructionEnterpriseproductionreportController.java

@@ -0,0 +1,91 @@
+package com.sooka.sponest.data.housingconstruction.controller;
+
+import com.ruoyi.common.core.utils.poi.ExcelUtil;
+import com.ruoyi.common.core.web.controller.BaseController;
+import com.ruoyi.common.core.web.domain.AjaxResult;
+import com.ruoyi.common.core.web.page.TableDataInfo;
+import com.ruoyi.common.log.annotation.Log;
+import com.ruoyi.common.log.enums.BusinessType;
+import com.ruoyi.common.security.annotation.RequiresPermissions;
+import com.sooka.sponest.data.housingconstruction.domain.CenterdataTHousingconstructionEnterpriseproductionreport;
+import com.sooka.sponest.data.housingconstruction.service.ICenterdataTHousingconstructionEnterpriseproductionreportService;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.web.bind.annotation.*;
+
+import javax.servlet.http.HttpServletResponse;
+import java.util.List;
+
+/**
+ * 企业生产报告Controller
+ *
+ * @author ruoyi
+ * @date 2024-08-05
+ */
+@RestController
+@RequestMapping("/enterpriseproductionreport")
+public class CenterdataTHousingconstructionEnterpriseproductionreportController extends BaseController {
+    @Autowired
+    private ICenterdataTHousingconstructionEnterpriseproductionreportService centerdataTHousingconstructionEnterpriseproductionreportService;
+
+    /**
+     * 查询企业生产报告列表
+     */
+    @RequiresPermissions("housingconstruction:enterpriseproductionreport:list")
+    @GetMapping("/list")
+    public TableDataInfo list(CenterdataTHousingconstructionEnterpriseproductionreport centerdataTHousingconstructionEnterpriseproductionreport) {
+        startPage();
+        List<CenterdataTHousingconstructionEnterpriseproductionreport> list = centerdataTHousingconstructionEnterpriseproductionreportService.selectCenterdataTHousingconstructionEnterpriseproductionreportList(centerdataTHousingconstructionEnterpriseproductionreport);
+        return getDataTable(list);
+    }
+
+    /**
+     * 导出企业生产报告列表
+     */
+    @RequiresPermissions("housingconstruction:enterpriseproductionreport:export")
+    @Log(title = "企业生产报告", businessType = BusinessType.EXPORT)
+    @PostMapping("/export")
+    public void export(HttpServletResponse response, CenterdataTHousingconstructionEnterpriseproductionreport centerdataTHousingconstructionEnterpriseproductionreport) {
+        List<CenterdataTHousingconstructionEnterpriseproductionreport> list = centerdataTHousingconstructionEnterpriseproductionreportService.selectCenterdataTHousingconstructionEnterpriseproductionreportList(centerdataTHousingconstructionEnterpriseproductionreport);
+        ExcelUtil<CenterdataTHousingconstructionEnterpriseproductionreport> util = new ExcelUtil<CenterdataTHousingconstructionEnterpriseproductionreport>(CenterdataTHousingconstructionEnterpriseproductionreport.class);
+        util.exportExcel(response, list, "企业生产报告数据");
+    }
+
+    /**
+     * 获取企业生产报告详细信息
+     */
+    @RequiresPermissions("housingconstruction:enterpriseproductionreport:query")
+    @GetMapping(value = "/{id}")
+    public AjaxResult getInfo(@PathVariable("id") String id) {
+        return AjaxResult.success(centerdataTHousingconstructionEnterpriseproductionreportService.selectCenterdataTHousingconstructionEnterpriseproductionreportById(id));
+    }
+
+    /**
+     * 新增企业生产报告
+     */
+    @RequiresPermissions("housingconstruction:enterpriseproductionreport:add")
+    @Log(title = "企业生产报告", businessType = BusinessType.INSERT)
+    @PostMapping
+    public AjaxResult add(@RequestBody CenterdataTHousingconstructionEnterpriseproductionreport centerdataTHousingconstructionEnterpriseproductionreport) {
+        return toAjax(centerdataTHousingconstructionEnterpriseproductionreportService.insertCenterdataTHousingconstructionEnterpriseproductionreport(centerdataTHousingconstructionEnterpriseproductionreport));
+    }
+
+    /**
+     * 修改企业生产报告
+     */
+    @RequiresPermissions("housingconstruction:enterpriseproductionreport:edit")
+    @Log(title = "企业生产报告", businessType = BusinessType.UPDATE)
+    @PutMapping
+    public AjaxResult edit(@RequestBody CenterdataTHousingconstructionEnterpriseproductionreport centerdataTHousingconstructionEnterpriseproductionreport) {
+        return toAjax(centerdataTHousingconstructionEnterpriseproductionreportService.updateCenterdataTHousingconstructionEnterpriseproductionreport(centerdataTHousingconstructionEnterpriseproductionreport));
+    }
+
+    /**
+     * 删除企业生产报告
+     */
+    @RequiresPermissions("housingconstruction:enterpriseproductionreport:remove")
+    @Log(title = "企业生产报告", businessType = BusinessType.DELETE)
+    @DeleteMapping("/{ids}")
+    public AjaxResult remove(@PathVariable String[] ids) {
+        return toAjax(centerdataTHousingconstructionEnterpriseproductionreportService.deleteCenterdataTHousingconstructionEnterpriseproductionreportByIds(ids));
+    }
+}

+ 65 - 0
src/main/java/com/sooka/sponest/data/housingconstruction/domain/CenterdataTHousingconstructionEnterpriseproductionreport.java

@@ -0,0 +1,65 @@
+package com.sooka.sponest.data.housingconstruction.domain;
+
+import com.ruoyi.common.core.web.domain.BaseEntity;
+import lombok.AllArgsConstructor;
+import lombok.Getter;
+import lombok.NoArgsConstructor;
+import lombok.Setter;
+import org.apache.commons.lang3.builder.ToStringBuilder;
+import org.apache.commons.lang3.builder.ToStringStyle;
+
+/**
+ * 企业生产报告对象 centerdata_t_housingconstruction_enterpriseproductionreport
+ *
+ * @author ruoyi
+ * @date 2024-08-05
+ */
+@Getter
+@Setter
+@AllArgsConstructor
+@NoArgsConstructor
+public class CenterdataTHousingconstructionEnterpriseproductionreport extends BaseEntity {
+    private static final long serialVersionUID = 1L;
+
+    /**
+     * 数据id
+     */
+    private String id;
+
+    /**
+     * 企业id
+     */
+    private String enterpriseId;
+
+    /**
+     * 企业名称
+     */
+    private String enterpriseName;
+
+    /**
+     * 报告类型
+     */
+    private String reportType;
+
+    /**
+     * 创建人姓名
+     */
+    private String createName;
+
+    private String fileName;
+
+    private String fileUrl;
+
+    @Override
+    public String toString() {
+        return new ToStringBuilder(this, ToStringStyle.MULTI_LINE_STYLE)
+                .append("id", getId())
+                .append("enterpriseId", getEnterpriseId())
+                .append("enterpriseName", getEnterpriseName())
+                .append("reportType", getReportType())
+                .append("createTime", getCreateTime())
+                .append("createBy", getCreateBy())
+                .append("createName", getCreateName())
+                .toString();
+    }
+}

+ 61 - 0
src/main/java/com/sooka/sponest/data/housingconstruction/mapper/CenterdataTHousingconstructionEnterpriseproductionreportMapper.java

@@ -0,0 +1,61 @@
+package com.sooka.sponest.data.housingconstruction.mapper;
+
+import com.sooka.sponest.data.housingconstruction.domain.CenterdataTHousingconstructionEnterpriseproductionreport;
+
+import java.util.List;
+
+/**
+ * 企业生产报告Mapper接口
+ *
+ * @author ruoyi
+ * @date 2024-08-05
+ */
+public interface CenterdataTHousingconstructionEnterpriseproductionreportMapper {
+    /**
+     * 查询企业生产报告
+     *
+     * @param id 企业生产报告主键
+     * @return 企业生产报告
+     */
+    public CenterdataTHousingconstructionEnterpriseproductionreport selectCenterdataTHousingconstructionEnterpriseproductionreportById(String id);
+
+    /**
+     * 查询企业生产报告列表
+     *
+     * @param centerdataTHousingconstructionEnterpriseproductionreport 企业生产报告
+     * @return 企业生产报告集合
+     */
+    public List<CenterdataTHousingconstructionEnterpriseproductionreport> selectCenterdataTHousingconstructionEnterpriseproductionreportList(CenterdataTHousingconstructionEnterpriseproductionreport centerdataTHousingconstructionEnterpriseproductionreport);
+
+    /**
+     * 新增企业生产报告
+     *
+     * @param centerdataTHousingconstructionEnterpriseproductionreport 企业生产报告
+     * @return 结果
+     */
+    public int insertCenterdataTHousingconstructionEnterpriseproductionreport(CenterdataTHousingconstructionEnterpriseproductionreport centerdataTHousingconstructionEnterpriseproductionreport);
+
+    /**
+     * 修改企业生产报告
+     *
+     * @param centerdataTHousingconstructionEnterpriseproductionreport 企业生产报告
+     * @return 结果
+     */
+    public int updateCenterdataTHousingconstructionEnterpriseproductionreport(CenterdataTHousingconstructionEnterpriseproductionreport centerdataTHousingconstructionEnterpriseproductionreport);
+
+    /**
+     * 删除企业生产报告
+     *
+     * @param id 企业生产报告主键
+     * @return 结果
+     */
+    public int deleteCenterdataTHousingconstructionEnterpriseproductionreportById(String id);
+
+    /**
+     * 批量删除企业生产报告
+     *
+     * @param ids 需要删除的数据主键集合
+     * @return 结果
+     */
+    public int deleteCenterdataTHousingconstructionEnterpriseproductionreportByIds(String[] ids);
+}

+ 61 - 0
src/main/java/com/sooka/sponest/data/housingconstruction/service/ICenterdataTHousingconstructionEnterpriseproductionreportService.java

@@ -0,0 +1,61 @@
+package com.sooka.sponest.data.housingconstruction.service;
+
+import com.sooka.sponest.data.housingconstruction.domain.CenterdataTHousingconstructionEnterpriseproductionreport;
+
+import java.util.List;
+
+/**
+ * 企业生产报告Service接口
+ *
+ * @author ruoyi
+ * @date 2024-08-05
+ */
+public interface ICenterdataTHousingconstructionEnterpriseproductionreportService {
+    /**
+     * 查询企业生产报告
+     *
+     * @param id 企业生产报告主键
+     * @return 企业生产报告
+     */
+    public CenterdataTHousingconstructionEnterpriseproductionreport selectCenterdataTHousingconstructionEnterpriseproductionreportById(String id);
+
+    /**
+     * 查询企业生产报告列表
+     *
+     * @param centerdataTHousingconstructionEnterpriseproductionreport 企业生产报告
+     * @return 企业生产报告集合
+     */
+    public List<CenterdataTHousingconstructionEnterpriseproductionreport> selectCenterdataTHousingconstructionEnterpriseproductionreportList(CenterdataTHousingconstructionEnterpriseproductionreport centerdataTHousingconstructionEnterpriseproductionreport);
+
+    /**
+     * 新增企业生产报告
+     *
+     * @param centerdataTHousingconstructionEnterpriseproductionreport 企业生产报告
+     * @return 结果
+     */
+    public int insertCenterdataTHousingconstructionEnterpriseproductionreport(CenterdataTHousingconstructionEnterpriseproductionreport centerdataTHousingconstructionEnterpriseproductionreport);
+
+    /**
+     * 修改企业生产报告
+     *
+     * @param centerdataTHousingconstructionEnterpriseproductionreport 企业生产报告
+     * @return 结果
+     */
+    public int updateCenterdataTHousingconstructionEnterpriseproductionreport(CenterdataTHousingconstructionEnterpriseproductionreport centerdataTHousingconstructionEnterpriseproductionreport);
+
+    /**
+     * 批量删除企业生产报告
+     *
+     * @param ids 需要删除的企业生产报告主键集合
+     * @return 结果
+     */
+    public int deleteCenterdataTHousingconstructionEnterpriseproductionreportByIds(String[] ids);
+
+    /**
+     * 删除企业生产报告信息
+     *
+     * @param id 企业生产报告主键
+     * @return 结果
+     */
+    public int deleteCenterdataTHousingconstructionEnterpriseproductionreportById(String id);
+}

+ 131 - 0
src/main/java/com/sooka/sponest/data/housingconstruction/service/impl/CenterdataTHousingconstructionEnterpriseproductionreportServiceImpl.java

@@ -0,0 +1,131 @@
+package com.sooka.sponest.data.housingconstruction.service.impl;
+
+import com.ruoyi.common.core.utils.DateUtils;
+import com.ruoyi.common.core.utils.SpringUtils;
+import com.ruoyi.common.core.utils.StringUtils;
+import com.ruoyi.common.core.utils.uuid.IdUtils;
+import com.ruoyi.common.security.utils.SecurityUtils;
+import com.ruoyi.system.api.RemoteConfigService;
+import com.sooka.sponest.data.housingconstruction.domain.CenterdataTHousingconstructionAttach;
+import com.sooka.sponest.data.housingconstruction.domain.CenterdataTHousingconstructionEnterpriseproductionreport;
+import com.sooka.sponest.data.housingconstruction.mapper.CenterdataTHousingconstructionEnterpriseproductionreportMapper;
+import com.sooka.sponest.data.housingconstruction.service.ICenterdataTHousingconstructionAttachService;
+import com.sooka.sponest.data.housingconstruction.service.ICenterdataTHousingconstructionEnterpriseproductionreportService;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+
+import java.util.List;
+
+import static com.sooka.sponest.data.utils.DataConstants.DOWNLOAD_URL;
+
+/**
+ * 企业生产报告Service业务层处理
+ *
+ * @author ruoyi
+ * @date 2024-08-05
+ */
+@Service
+public class CenterdataTHousingconstructionEnterpriseproductionreportServiceImpl implements ICenterdataTHousingconstructionEnterpriseproductionreportService {
+    @Autowired
+    private CenterdataTHousingconstructionEnterpriseproductionreportMapper centerdataTHousingconstructionEnterpriseproductionreportMapper;
+
+    @Autowired
+    private ICenterdataTHousingconstructionAttachService attachService;
+
+    /**
+     * 查询企业生产报告
+     *
+     * @param id 企业生产报告主键
+     * @return 企业生产报告
+     */
+    @Override
+    public CenterdataTHousingconstructionEnterpriseproductionreport selectCenterdataTHousingconstructionEnterpriseproductionreportById(String id) {
+        CenterdataTHousingconstructionEnterpriseproductionreport report = centerdataTHousingconstructionEnterpriseproductionreportMapper.selectCenterdataTHousingconstructionEnterpriseproductionreportById(id);
+
+        List<CenterdataTHousingconstructionAttach> attachList = attachService.getAttachPathToEntityArray(id);
+        StringBuilder newDiles = new StringBuilder();
+
+        String fileurl = SpringUtils.getBean(RemoteConfigService.class).remotegetConfigKey(DOWNLOAD_URL).getData();
+
+        attachList.forEach(attach->{
+            if(report.getReportType().equals(attach.getDictValue())){
+                String filename = attach.getFileName(); //新建 Microsoft Excel 工作表 (2).xlsx
+                String url = attach.getAttachPath().substring(attach.getAttachPath().indexOf("group1"),attach.getAttachPath().length()); //group1/M00/00/84/wKgKEGawNfGAW7bwAAAxRySSUAM25.xlsx
+                String group = url.substring(0, url.indexOf('/')); //group1
+                newDiles.append(fileurl + "Download?fileName=" + filename + "&&group=" + group + "&&path=" + url.substring(url.indexOf('/') + 1) + "+" + filename + ",");
+            }
+        });
+        if(newDiles.length() > 0){
+            newDiles.deleteCharAt(newDiles.length() - 1);
+        }
+        report.setFileUrl(newDiles.toString());
+        return report;
+    }
+
+    /**
+     * 查询企业生产报告列表
+     *
+     * @param centerdataTHousingconstructionEnterpriseproductionreport 企业生产报告
+     * @return 企业生产报告
+     */
+    @Override
+    public List<CenterdataTHousingconstructionEnterpriseproductionreport> selectCenterdataTHousingconstructionEnterpriseproductionreportList(CenterdataTHousingconstructionEnterpriseproductionreport centerdataTHousingconstructionEnterpriseproductionreport) {
+        return centerdataTHousingconstructionEnterpriseproductionreportMapper.selectCenterdataTHousingconstructionEnterpriseproductionreportList(centerdataTHousingconstructionEnterpriseproductionreport);
+    }
+
+    /**
+     * 新增企业生产报告
+     *
+     * @param centerdataTHousingconstructionEnterpriseproductionreport 企业生产报告
+     * @return 结果
+     */
+    @Override
+    public int insertCenterdataTHousingconstructionEnterpriseproductionreport(CenterdataTHousingconstructionEnterpriseproductionreport centerdataTHousingconstructionEnterpriseproductionreport) {
+        String reportId = IdUtils.fastSimpleUUID();
+        centerdataTHousingconstructionEnterpriseproductionreport.setId(reportId);
+        centerdataTHousingconstructionEnterpriseproductionreport.setCreateTime(DateUtils.getNowDate());
+        centerdataTHousingconstructionEnterpriseproductionreport.setCreateBy(SecurityUtils.getUserId().toString());
+        centerdataTHousingconstructionEnterpriseproductionreport.setCreateName(SecurityUtils.getLoginUser().getSysUser().getNickName());
+        //附件-文件集合
+        String fileUrls = centerdataTHousingconstructionEnterpriseproductionreport.getFileUrl();
+        if(!StringUtils.isEmpty(fileUrls)){
+            String reportType = centerdataTHousingconstructionEnterpriseproductionreport.getReportType();
+            attachService.addAttach(fileUrls, reportId, reportType.substring(0, reportType.lastIndexOf("_")), centerdataTHousingconstructionEnterpriseproductionreport.getReportType(), centerdataTHousingconstructionEnterpriseproductionreport.getFileName());
+        }
+        return centerdataTHousingconstructionEnterpriseproductionreportMapper.insertCenterdataTHousingconstructionEnterpriseproductionreport(centerdataTHousingconstructionEnterpriseproductionreport);
+    }
+
+    /**
+     * 修改企业生产报告
+     *
+     * @param centerdataTHousingconstructionEnterpriseproductionreport 企业生产报告
+     * @return 结果
+     */
+    @Override
+    public int updateCenterdataTHousingconstructionEnterpriseproductionreport(CenterdataTHousingconstructionEnterpriseproductionreport centerdataTHousingconstructionEnterpriseproductionreport) {
+        return centerdataTHousingconstructionEnterpriseproductionreportMapper.updateCenterdataTHousingconstructionEnterpriseproductionreport(centerdataTHousingconstructionEnterpriseproductionreport);
+    }
+
+    /**
+     * 批量删除企业生产报告
+     *
+     * @param ids 需要删除的企业生产报告主键
+     * @return 结果
+     */
+    @Override
+    public int deleteCenterdataTHousingconstructionEnterpriseproductionreportByIds(String[] ids) {
+        return centerdataTHousingconstructionEnterpriseproductionreportMapper.deleteCenterdataTHousingconstructionEnterpriseproductionreportByIds(ids);
+    }
+
+    /**
+     * 删除企业生产报告信息
+     *
+     * @param id 企业生产报告主键
+     * @return 结果
+     */
+    @Override
+    public int deleteCenterdataTHousingconstructionEnterpriseproductionreportById(String id) {
+        attachService.delAttachByBusId(id);
+        return centerdataTHousingconstructionEnterpriseproductionreportMapper.deleteCenterdataTHousingconstructionEnterpriseproductionreportById(id);
+    }
+}

+ 93 - 0
src/main/resources/mapper/housingconstruction/CenterdataTHousingconstructionEnterpriseproductionreportMapper.xml

@@ -0,0 +1,93 @@
+<?xml version="1.0" encoding="UTF-8" ?>
+<!DOCTYPE mapper
+        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
+        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
+<mapper namespace="com.sooka.sponest.data.housingconstruction.mapper.CenterdataTHousingconstructionEnterpriseproductionreportMapper">
+
+    <resultMap type="CenterdataTHousingconstructionEnterpriseproductionreport"
+               id="CenterdataTHousingconstructionEnterpriseproductionreportResult">
+        <result property="id" column="id"/>
+        <result property="enterpriseId" column="enterprise_id"/>
+        <result property="enterpriseName" column="enterprise_name"/>
+        <result property="reportType" column="report_type"/>
+        <result property="createTime" column="create_time"/>
+        <result property="createBy" column="create_by"/>
+        <result property="createName" column="create_name"/>
+    </resultMap>
+
+    <sql id="selectCenterdataTHousingconstructionEnterpriseproductionreportVo">
+        select id, enterprise_id, enterprise_name, report_type, create_time, create_by, create_name
+        from centerdata_t_housingconstruction_enterpriseproductionreport
+    </sql>
+
+    <select id="selectCenterdataTHousingconstructionEnterpriseproductionreportList"
+            parameterType="CenterdataTHousingconstructionEnterpriseproductionreport"
+            resultMap="CenterdataTHousingconstructionEnterpriseproductionreportResult">
+        <include refid="selectCenterdataTHousingconstructionEnterpriseproductionreportVo"/>
+        <where>
+            <if test="enterpriseName != null and enterpriseName != ''">
+                enterprise_name like concat('%', #{enterpriseName}, '%')
+            </if>
+            <if test="reportType != null and reportType != ''">
+                report_type = #{reportType}
+            </if>
+        </where>
+        order by create_time desc
+    </select>
+
+    <select id="selectCenterdataTHousingconstructionEnterpriseproductionreportById" parameterType="String"
+            resultMap="CenterdataTHousingconstructionEnterpriseproductionreportResult">
+        <include refid="selectCenterdataTHousingconstructionEnterpriseproductionreportVo"/>
+        where id = #{id}
+    </select>
+
+    <insert id="insertCenterdataTHousingconstructionEnterpriseproductionreport"
+            parameterType="CenterdataTHousingconstructionEnterpriseproductionreport">
+        insert into centerdata_t_housingconstruction_enterpriseproductionreport
+        <trim prefix="(" suffix=")" suffixOverrides=",">
+            <if test="id != null">id,</if>
+            <if test="enterpriseId != null">enterprise_id,</if>
+            <if test="enterpriseName != null">enterprise_name,</if>
+            <if test="reportType != null">report_type,</if>
+            <if test="createTime != null">create_time,</if>
+            <if test="createBy != null">create_by,</if>
+            <if test="createName != null">create_name,</if>
+        </trim>
+        <trim prefix="values (" suffix=")" suffixOverrides=",">
+            <if test="id != null">#{id},</if>
+            <if test="enterpriseId != null">#{enterpriseId},</if>
+            <if test="enterpriseName != null">#{enterpriseName},</if>
+            <if test="reportType != null">#{reportType},</if>
+            <if test="createTime != null">#{createTime},</if>
+            <if test="createBy != null">#{createBy},</if>
+            <if test="createName != null">#{createName},</if>
+        </trim>
+    </insert>
+
+    <update id="updateCenterdataTHousingconstructionEnterpriseproductionreport"
+            parameterType="CenterdataTHousingconstructionEnterpriseproductionreport">
+        update centerdata_t_housingconstruction_enterpriseproductionreport
+        <trim prefix="SET" suffixOverrides=",">
+            <if test="enterpriseId != null">enterprise_id = #{enterpriseId},</if>
+            <if test="enterpriseName != null">enterprise_name = #{enterpriseName},</if>
+            <if test="reportType != null">report_type = #{reportType},</if>
+            <if test="createTime != null">create_time = #{createTime},</if>
+            <if test="createBy != null">create_by = #{createBy},</if>
+            <if test="createName != null">create_name = #{createName},</if>
+        </trim>
+        where id = #{id}
+    </update>
+
+    <delete id="deleteCenterdataTHousingconstructionEnterpriseproductionreportById" parameterType="String">
+        delete
+        from centerdata_t_housingconstruction_enterpriseproductionreport
+        where id = #{id}
+    </delete>
+
+    <delete id="deleteCenterdataTHousingconstructionEnterpriseproductionreportByIds" parameterType="String">
+        delete from centerdata_t_housingconstruction_enterpriseproductionreport where id in
+        <foreach item="id" collection="array" open="(" separator="," close=")">
+            #{id}
+        </foreach>
+    </delete>
+</mapper>