zengyicheng 1 ano atrás
pai
commit
4fa3d59b7d

Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/css/666.c99b1469.css


Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/css/876.8e06e1be.css


Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/css/955.7669d2a6.css


+ 1 - 1
dist/index.html

@@ -1 +1 @@
-<!doctype html><html lang=""><head><meta charset="utf-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width,initial-scale=1"><title>双创学院管理系统</title><script defer="defer" src="/js/chunk-vendors.c0eb00f6.js"></script><script defer="defer" src="/js/app.f521c156.js"></script><link href="/css/chunk-vendors.0225060a.css" rel="stylesheet"><link href="/css/app.3ebe307b.css" rel="stylesheet"></head><body><div id="app"></div></body></html>
+<!doctype html><html lang=""><head><meta charset="utf-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width,initial-scale=1"><title>双创学院管理系统</title><script defer="defer" src="/js/chunk-vendors.c0eb00f6.js"></script><script defer="defer" src="/js/app.2b7543f6.js"></script><link href="/css/chunk-vendors.0225060a.css" rel="stylesheet"><link href="/css/app.3ebe307b.css" rel="stylesheet"></head><body><div id="app"></div></body></html>

Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/js/255.f85ee7ed.js


Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/js/255.f85ee7ed.js.map


Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/js/3.1e699590.js


Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/js/3.1e699590.js.map


Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/js/3.7ececa7b.js.map


Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/js/666.73a16d6c.js


Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/js/666.73a16d6c.js.map


Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/js/876.f7215333.js


Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/js/876.f7215333.js.map


Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/js/955.5e5ecc8d.js


Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/js/955.5e5ecc8d.js.map


Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/js/app.2b7543f6.js


Diferenças do arquivo suprimidas por serem muito extensas
+ 0 - 0
dist/js/app.2b7543f6.js.map


+ 6 - 18
package-lock.json

@@ -1726,9 +1726,9 @@
       "dev": true
     },
     "@types/raf": {
-      "version": "3.4.0",
-      "resolved": "https://registry.npmmirror.com/@types/raf/-/raf-3.4.0.tgz",
-      "integrity": "sha512-taW5/WYqo36N7V39oYyHP9Ipfd5pNFvGTIQsNGj86xV88YQ7GnI30/yMfKDF7Zgin0m3e+ikX88FvImnK4RjGw==",
+      "version": "3.4.3",
+      "resolved": "https://registry.npmmirror.com/@types/raf/-/raf-3.4.3.tgz",
+      "integrity": "sha512-c4YAvMedbPZ5tEyxzQdMoOhhJ4RD3rngZIdwC2/qDN3d7JpEhB6fiBRKVY1lg5B7Wk+uPBjn5f39j1/2MY1oOw==",
       "optional": true
     },
     "@types/range-parser": {
@@ -4126,9 +4126,9 @@
       }
     },
     "dompurify": {
-      "version": "2.4.5",
-      "resolved": "https://registry.npmmirror.com/dompurify/-/dompurify-2.4.5.tgz",
-      "integrity": "sha512-jggCCd+8Iqp4Tsz0nIvpcb22InKEBrGz5dw3EQJMs8HPJDsKbFIO3STYtAvCfDx26Muevn1MHVI0XxjgFfmiSA==",
+      "version": "2.4.7",
+      "resolved": "https://registry.npmmirror.com/dompurify/-/dompurify-2.4.7.tgz",
+      "integrity": "sha512-kxxKlPEDa6Nc5WJi+qRgPbOAbgTpSULL+vI3NUXsZMlkJxTqYI9wg5ZTay2sFrdZRWHPWNi+EdAhcJf81WtoMQ==",
       "optional": true
     },
     "domutils": {
@@ -5554,18 +5554,6 @@
         "dompurify": "^2.2.0",
         "fflate": "^0.4.8",
         "html2canvas": "^1.0.0-rc.5"
-      },
-      "dependencies": {
-        "html2canvas": {
-          "version": "1.4.1",
-          "resolved": "https://registry.npmmirror.com/html2canvas/-/html2canvas-1.4.1.tgz",
-          "integrity": "sha512-fPU6BHNpsyIhr8yyMpTLLxAbkaK8ArIBcmZIRiBLiDhjeqvXolaEmDGmELFuX9I4xDcaKKcJl+TKZLqruBbmWA==",
-          "optional": true,
-          "requires": {
-            "css-line-break": "^2.1.0",
-            "text-segmentation": "^1.0.3"
-          }
-        }
       }
     },
     "jszip": {

+ 39 - 39
src/components/tool/pdf.js

@@ -1,26 +1,26 @@
 import html2canvas from "html2canvas";
 import jsPDF from "jspdf";
 
-export const downloadPDF = (page,fileName='test') => {
+export const downloadPDF = (page, fileName = 'test') => {
 
-  html2canvas(page).then(function(canvas) {
-    canvas2PDF(canvas,fileName);
-  });
+    html2canvas(page).then(function(canvas) {
+        canvas2PDF(canvas, fileName);
+    });
 };
-const canvas2PDF = (canvas,fileName) => {
+const canvas2PDF = (canvas, fileName) => {
     let contentWidth = canvas.width;
     console.log(contentWidth);
     let contentHeight = canvas.height;
-      // 一页pdf显示html页面生成的canvas高度;
-    let pageHeight = contentWidth / 592.28 * 841.89 ;
+    // 一页pdf显示html页面生成的canvas高度;
+    let pageHeight = contentWidth / 592.28 * 841.89;
     // let pageHeight = 841.89;
 
-      // 未生成pdf的html页面高度
+    // 未生成pdf的html页面高度
     let leftHeight = contentHeight;
-      // 页面偏移
-    let position = 0;
-      // html页面生成的canvas在pdf中图片的宽高(本例为:横向a4纸[841.89,592.28],纵向需调换尺寸)
-    let imgWidth = 592.28;
+    // 页面偏移
+    let position = 100;
+    // html页面生成的canvas在pdf中图片的宽高(本例为:横向a4纸[841.89,592.28],纵向需调换尺寸)
+    let imgWidth = 550;
     let imgHeight = 592.28 / contentWidth * contentHeight;
     // let imgHeight = 841.89;
 
@@ -29,17 +29,17 @@ const canvas2PDF = (canvas,fileName) => {
     // 两个高度需要区分: 一个是html页面的实际高度,和生成pdf的页面高度
     // 当内容未超过pdf一页显示的范围,无需分页
     if (leftHeight < pageHeight) {
-      PDF.addImage(pageData, 'JPEG', 0, 0, imgWidth, imgHeight)
+        PDF.addImage(pageData, 'JPEG', 20, 0, imgWidth, imgHeight)
     } else {
-      while (leftHeight > 0) {
-        PDF.addImage(pageData, 'JPEG', 0, position, imgWidth, imgHeight)
-        leftHeight -= pageHeight;
-        position -= 841.89;
-        // 避免添加空白页
-        if (leftHeight > 0) {
-          PDF.addPage();
+        while (leftHeight > 0) {
+            PDF.addImage(pageData, 'JPEG', 20, position, imgWidth, imgHeight)
+            leftHeight -= pageHeight;
+            position -= 841.89;
+            // 避免添加空白页
+            if (leftHeight > 0) {
+                PDF.addPage();
+            }
         }
-      }
     }
     PDF.save(fileName + '.pdf')
 
@@ -50,23 +50,23 @@ const canvas2PDF = (canvas,fileName) => {
 
 
 
-  // let contentWidth = canvas.width;
-  // let contentHeight = canvas.height;
-  // console.log(contentWidth,contentHeight);
-  // let imgHeight = contentHeight;
-  // let imgWidth = contentWidth/2;
+    // let contentWidth = canvas.width;
+    // let contentHeight = canvas.height;
+    // console.log(contentWidth,contentHeight);
+    // let imgHeight = contentHeight;
+    // let imgWidth = contentWidth/2;
 
-  // // 第一个参数: l:横向  p:纵向
-  // // 第二个参数:测量单位("pt","mm", "cm", "m", "in" or "px")
-  // let pdf = new jsPDF('l', 'pt', 'a4');
+    // // 第一个参数: l:横向  p:纵向
+    // // 第二个参数:测量单位("pt","mm", "cm", "m", "in" or "px")
+    // let pdf = new jsPDF('l', 'pt', 'a4');
 
-  // pdf.addImage(
-  //   canvas.toDataURL("image/jpeg", 1.0),
-  //   "JPEG",
-  //   0,
-  //   0,
-  //   imgWidth,
-  //   imgHeight
-  // );
-  // pdf.save("导出.pdf");
-};
+    // pdf.addImage(
+    //   canvas.toDataURL("image/jpeg", 1.0),
+    //   "JPEG",
+    //   0,
+    //   0,
+    //   imgWidth,
+    //   imgHeight
+    // );
+    // pdf.save("导出.pdf");
+};

+ 43 - 7
src/views/projectManage/ProjectManagement.vue

@@ -426,6 +426,7 @@
         ref="finalClo"
         :myArrayProp="myArrayProp"
         :iid="iid"
+        :isDownPdf="isDownPdf"
       ></Closingstatement>
 
       <div
@@ -436,12 +437,12 @@
         <el-button type="primary" @click="ending" class="AllDialogBtn"
           >确认</el-button
         >
-        <el-button @click="endDialog = false" class="AllDialogBtn"
-          >取消</el-button
-        >
         <el-button type="primary" @click="getWord" class="AllDialogBtn"
           >下载表格</el-button
         >
+        <el-button @click="endDialog = false" class="AllDialogBtn"
+          >取消</el-button
+        >
       </div>
     </el-dialog>
     <!-- 结项书结束 -->
@@ -470,6 +471,7 @@ export default {
   components: { beUpload, Closingstatement },
   data() {
     return {
+      isDownPdf: false,
       accept: "*",
       iid: "",
       selectText: "", //文字搜素框数据
@@ -934,10 +936,44 @@ export default {
         );
     },
     getWord() {
-      downloadPDF(
-        this.$refs.finalClo.$refs.downPDF,
-        this.myArrayProp[0].title + "申报书"
-      );
+      this.isDownPdf = true;
+      this.$forceUpdate();
+      setTimeout(() => {
+        downloadPDF(
+          this.$refs.finalClo.$refs.downPDF,
+          this.myArrayProp[0].title + "申报书"
+        );
+        setTimeout(() => {
+          this.isDownPdf = false;
+          this.$forceUpdate();
+        }, 500);
+      }, 500);
+
+      // const content = this.$refs.finalClo.$refs.downPDF;
+      // const contentWidth = content.offsetWidth;
+      // const contentHeight = content.offsetHeight;
+
+      // const pdf = new jsPDF("p", "px", [contentWidth, contentHeight]);
+      // let position = 0;
+      // const imgWidth = pdf.internal.pageSize.getWidth();
+      // const imgHeight = pdf.internal.pageSize.getHeight();
+
+      // const canvas = await html2canvas(content, {
+      //   scrollY: -window.scrollY,
+      //   windowWidth: document.documentElement.offsetWidth,
+      // });
+      // const imgData = canvas.toDataURL("image/png");
+
+      // pdf.addImage(imgData, "PNG", 0, position, imgWidth, imgHeight);
+      // position -= imgHeight;
+
+      // while (position > -contentHeight) {
+      //   pdf.addPage();
+      //   pdf.addImage(imgData, "PNG", 0, position, imgWidth, imgHeight);
+      //   position -= imgHeight;
+      // }
+
+      // pdf.save("exported.pdf");
     },
   },
 

+ 8 - 4
src/views/projectManage/ProjectManagementMain.vue

@@ -25,11 +25,12 @@
         <!-- 活动开展 -->
         <!-- <ProjectManagementActivity :changeShow="goto" v-if="show==1"/> -->
         <!-- 活动开展详细 -->
-        <ProjectManagementActivityDetail :AidShow="AidShow" v-if="show==5 && $route.query['pid']"/>
+        <!-- <ProjectManagementActivityDetail :AidShow="AidShow" v-if="show==5 && $route.query['pid']"/> -->
         <!-- 项目结题文件 -->
-        <ProjectManagementEndProjectFile v-if="show==2"/>
+        <ProjectManagementEndProjectFile v-if="show==1"/>
         <!-- 上传附件 -->
-        <ProjectManagementProjectFile v-if="show==3"/>
+        <ProjectManagementProjectFile v-if="show==2"/>
+        <ProjectManagementOtherFile v-if="show==3"/>
     </div>
 </template>
 
@@ -39,6 +40,7 @@
     import ProjectManagementActivityDetail from './components/ProjectManagementActivityDetail.vue'
     import ProjectManagementEndProjectFile from './components/ProjectManagementEndProjectFile.vue'
     import ProjectManagementProjectFile from './components/ProjectManagementProjectFile.vue'
+    import ProjectManagementOtherFile from './components/ProjectManagementOtherFile.vue'
     // //特色创客空间建设
     import MakerSpaceWordShow from './components/MakerSpaceWordShow.vue'
     //创客空间
@@ -53,6 +55,7 @@
             ProjectManagementEndProjectFile,
             ProjectManagementProjectFile,
             studentProjectWordShow,
+            ProjectManagementOtherFile,
         },
         data() {
             return {
@@ -61,7 +64,8 @@
                 items:[
                     {tit:'项目详细',cl:'pr1TitBass'},
                     // {tit:'活动开展',cl:'pr1TitBass'},
-                    {tit:'项目结题附件',cl:'pr1TitBass'},
+                    {tit:'项目结题书',cl:'pr1TitBass'},
+                    {tit:'专家审核结果',cl:'pr1TitBass'},
                     {tit:'上传附件',cl:'pr1TitBass'},
                 ]
             }

+ 214 - 158
src/views/projectManage/components/Closingstatement.vue

@@ -1,57 +1,54 @@
 <template>
   <!-- 结项书组件 -->
   <div ref="downPDF">
-    <table border="1" cellspacing="0">
-      <div class="onePage">
-        <div class="titSchool">深圳技师学院</div>
-        <div class="title">校级创客项目结题申请书</div>
-        <div class="basicInformation">
-          <span>项目名称</span>
-          <div class="line">{{ myArrayProp[0].title }}</div>
-        </div>
-        <div class="basicInformation">
-          <span>负责人</span>
-          <div class="line">{{ myArrayProp[0].pro_leader }}</div>
-        </div>
-        <div class="basicInformation" style="color: red">
-          <span>指导教师</span>
-          <div class="line" style="position: relative">
-            <span
-              v-for="(item, index) in myArrayProp[0].course_teacher"
-              :key="index"
-              >{{ item.name }}</span
-            >
-            <span style="position: absolute; right: -100px"
-              >{{ myArrayProp[0].course_teacher.length }}(人)</span
-            >
-          </div>
-        </div>
-        <div class="basicInformation">
-          <span>申请部门</span>
-          <div class="line">{{ myArrayProp[0].name }}</div>
-        </div>
-        <div class="basicInformation">
-          <span>申请日期</span>
-          <div class="line">{{ myArrayProp[0].applyProjectTime }}</div>
-        </div>
-
-        <div
-          style="
-            font-size: 22px;
-            font-family: \4eff\5b8b;
-            font-weight: bold;
-            margin-bottom: 10px;
-          "
-        >
-          创新创业学院制
-        </div>
-        <div
-          style="font-size: 22px; font-family: \4eff\5b8b; font-weight: bold"
-        >
-          {{ nowTime }}
+    <div class="onePage">
+      <div class="titSchool">深圳技师学院</div>
+      <div class="title">校级创客项目结题申请书</div>
+      <div class="basicInformation">
+        <span>项目名称</span>
+        <div class="line">{{ myArrayProp[0].title }}</div>
+      </div>
+      <div class="basicInformation">
+        <span>负责人</span>
+        <div class="line">{{ myArrayProp[0].pro_leader }}</div>
+      </div>
+      <div class="basicInformation">
+        <span>指导教师</span>
+        <div class="line" style="position: relative">
+          <span
+            v-for="(item, index) in myArrayProp[0].course_teacher"
+            :key="index"
+            >{{ item.name }}</span
+          >
+          <span style="position: absolute; right: -100px"
+            >{{ myArrayProp[0].course_teacher.length }}(人)</span
+          >
         </div>
       </div>
+      <div class="basicInformation">
+        <span>申请部门</span>
+        <div class="line">{{ myArrayProp[0].name }}</div>
+      </div>
+      <div class="basicInformation">
+        <span>申请日期</span>
+        <div class="line">{{ myArrayProp[0].applyProjectTime }}</div>
+      </div>
 
+      <div
+        style="
+          font-size: 22px;
+          font-family: \4eff\5b8b;
+          font-weight: bold;
+          margin-bottom: 10px;
+        "
+      >
+        创新创业学院制
+      </div>
+      <div style="font-size: 22px; font-family: \4eff\5b8b; font-weight: bold">
+        {{ nowTime }}
+      </div>
+    </div>
+    <table border="1" cellspacing="0">
       <tr v-show="false">
         <td v-for="i in 8" :key="i">i</td>
       </tr>
@@ -64,15 +61,7 @@
       <tr>
         <td colspan="2">项目类型</td>
         <td>学生申报</td>
-        <td
-          colspan="2"
-          style="
-            text-align: justify;
-            text-align-last: justify;
-            padding: 0 30px;
-            box-sizing: border-box;
-          "
-        >
+        <td colspan="2" style="padding: 0 30px; box-sizing: border-box">
           <span
             >{{
               (myArrayProp[0].typeName = "f3068e26-f51d-11ed-a3f6-509a4c5b67cf"
@@ -80,7 +69,7 @@
                 : "□")
             }}创意组</span
           >
-          <span
+          <span style="margin-left: 15px"
             >{{
               (myArrayProp[0].typeName = "f3068e26-f51d-11ed-a3f6-509a4c5b67cf"
                 ? "□"
@@ -91,17 +80,16 @@
         <td>学院申报</td>
         <td colspan="2"><span>□创客空间建设</span></td>
       </tr>
-      <tr style="color: red">
+      <tr>
         <td colspan="2">项目级别</td>
         <td colspan="8">
           □ 一般资助项目   □ 重点资助项目    □ 特别申报项目
         </td>
       </tr>
       <tr>
-        <td colspan="2" style="color: red">项目类别</td>
+        <td colspan="2">项目类别</td>
         <td colspan="8">
-          □技术创新项目    □ 公益创新项目    □ 非遗文创项目    □
-          乡村振兴项目
+          □技术创新项目  □ 公益创新项目  □ 非遗文创项目  □ 乡村振兴项目
         </td>
       </tr>
       <tr>
@@ -142,7 +130,8 @@
         </td>
         <td>所在学院</td>
         <td>
-          <el-input
+          <div v-html="myArrayProp[0].name"></div>
+          <!-- <el-input
             type="textarea"
             autosize
             style="width: 100%"
@@ -150,7 +139,7 @@
             placeholder=""
             v-model="myArrayProp[0].name"
           >
-          </el-input>
+          </el-input> -->
         </td>
         <td>联系电话</td>
         <td>
@@ -172,10 +161,10 @@
         <td>{{ myArrayProp[0].course_teacher.length }}</td>
       </tr>
       <tr>
-        <td colspan="2">项目起始时间</td>
-        <td>{{ myArrayProp[0].begin_at }}</td>
-        <td colspan="2">项目完成时间</td>
-        <td>{{ myArrayProp[0].plannedEnd_at }}</td>
+        <td style="font-size: 21px;">项目起始时间</td>
+        <td colspan="2">{{ myArrayProp[0].begin_at }}</td>
+        <td style="font-size: 21px;">项目完成时间</td>
+        <td colspan="2">{{ myArrayProp[0].plannedEnd_at }}</td>
         <td>预算经费</td>
         <td>元</td>
       </tr>
@@ -188,8 +177,8 @@
           团 <br />队 <br />成 <br />员
         </td>
         <td>姓名</td>
-        <td>所在学院及专业</td>
-        <td colspan="5">项目分工</td>
+        <td colspan="2">所在学院及专业</td>
+        <td colspan="4">项目分工</td>
       </tr>
       <tr
         v-for="(item, index) in myArrayProp[0].course_student"
@@ -197,8 +186,8 @@
         v-show="myArrayProp[0].typeid == '5e21b204-c206-11ed-a4cd-509a4c5b67cf'"
       >
         <td><span v-text="item.name"></span></td>
-        <td><span v-html="item.collage"></span></td>
-        <td colspan="5"><span v-text="item.work"></span></td>
+        <td colspan="2"><span v-html="item.collage"></span></td>
+        <td colspan="4"><span v-text="item.work"></span></td>
       </tr>
 
       <tr
@@ -215,8 +204,8 @@
         v-show="myArrayProp[0].typeid == '5e21b204-c206-11ed-a4cd-509a4c5b67cf'"
       >
         <td><span v-text="item.name"></span></td>
-        <td><span v-html="item.collage"></span></td>
-        <td colspan="5"><span v-text="item.work"></span></td>
+        <td colspan="2"><span v-html="item.collage"></span></td>
+        <td colspan="4"><span v-text="item.work"></span></td>
       </tr>
       <!-- 特色创客空间建设项目 -->
       <tr
@@ -278,8 +267,11 @@
       <tr>
         <td colspan="7" style="text-align: left; height: auto">
           <p>一、项目研发内容简介(200字以内)</p>
-          <!-- <div class="textCss" v-html="myArrayProp[0].brief"></div> -->
-          <el-input
+          <div
+            class="textCss"
+            v-html="myArrayProp[0].brief.replace(/ /g, '&nbsp;')"
+          ></div>
+          <!-- <el-input
             type="textarea"
             maxlength="200"
             show-word-limit
@@ -287,68 +279,91 @@
             placeholder="请输入内容"
             v-model="myArrayProp[0].brief"
           >
-          </el-input>
+          </el-input> -->
         </td>
       </tr>
       <tr>
         <td colspan="7" style="text-align: left; height: auto">
           <p>目标计划:</p>
-          <!-- <div class="textCss" v-html="myArrayProp[0]['ClosingstatementData'].plan.replace(/ /g, '&nbsp;')"></div> -->
-          <el-input
+          <div
+            class="textCss"
+            v-html="
+              myArrayProp[0]['ClosingstatementData'].plan.replace(
+                / /g,
+                '&nbsp;'
+              )
+            "
+          ></div>
+          <!-- <el-input
             type="textarea"
             :autosize="{ minRows: 6 }"
             placeholder="请输入内容"
             v-model="myArrayProp[0]['ClosingstatementData'].plan"
           >
-          </el-input>
+          </el-input> -->
         </td>
       </tr>
       <tr>
         <td colspan="7" style="text-align: left; height: auto">
           <p>二、拟解决的关键技术问题</p>
-          <!-- <div
+          <div
             class="textCss"
-            v-html="myArrayProp[0]['ClosingstatementData'].technology.replace(/ /g, '&nbsp;')"
-          ></div> -->
-          <el-input
+            v-html="
+              myArrayProp[0]['ClosingstatementData'].technology.replace(
+                / /g,
+                '&nbsp;'
+              )
+            "
+          ></div>
+          <!-- <el-input
             type="textarea"
             :autosize="{ minRows: 6 }"
             placeholder="请输入内容"
             v-model="myArrayProp[0]['ClosingstatementData'].technology"
           >
-          </el-input>
+          </el-input> -->
         </td>
       </tr>
       <tr>
         <td colspan="7" style="text-align: left; height: auto">
           <p>三、项目的商业(公益)价值评估</p>
-          <!-- <div
+          <div
             class="textCss"
-            v-html="myArrayProp[0]['ClosingstatementData'].business.replace(/ /g, '&nbsp;')"
-          ></div> -->
-          <el-input
+            v-html="
+              myArrayProp[0]['ClosingstatementData'].business.replace(
+                / /g,
+                '&nbsp;'
+              )
+            "
+          ></div>
+          <!-- <el-input
             type="textarea"
             :autosize="{ minRows: 6 }"
             placeholder="请输入内容"
             v-model="myArrayProp[0]['ClosingstatementData'].business"
           >
-          </el-input>
+          </el-input> -->
         </td>
       </tr>
       <tr>
         <td colspan="7" style="text-align: left; height: auto">
           <p>四、项目创新点评估</p>
-          <!-- <div
+          <div
             class="textCss"
-            v-html="myArrayProp[0]['ClosingstatementData'].innovate.replace(/ /g, '&nbsp;')"
-          ></div> -->
-          <el-input
+            v-html="
+              myArrayProp[0]['ClosingstatementData'].innovate.replace(
+                / /g,
+                '&nbsp;'
+              )
+            "
+          ></div>
+          <!-- <el-input
             type="textarea"
             :autosize="{ minRows: 6 }"
             placeholder="请输入内容"
             v-model="myArrayProp[0]['ClosingstatementData'].innovate"
           >
-          </el-input>
+          </el-input> -->
         </td>
       </tr>
 
@@ -362,6 +377,7 @@
           <p>一、成果(名称、数量及形式,开发产品及取得的专利等)</p>
           <p>专利证书获得(提供专利申请或成果证书附件):</p>
           <beUpload
+            v-show="!isDownPdf"
             style="position: absolute; right: 10px; top: 5px"
             @getFile="getFile"
             :navName="'上传文件'"
@@ -414,6 +430,7 @@
         <td colspan="7" style="height: 200px">
           <p>企业应用实证(提供企业证明或合作协议证明等附件):</p>
           <beUpload
+            v-show="!isDownPdf"
             style="position: absolute; right: 10px; top: 5px"
             @getFile="getfirmAccessory"
             :navName="'上传文件'"
@@ -467,6 +484,7 @@
         <td colspan="7" style="height: 200px">
           <p>双创竞赛成绩(提供参加师生名单、比赛取得的成绩等附件):</p>
           <beUpload
+            v-show="!isDownPdf"
             style="position: absolute; right: 10px; top: 5px"
             @getFile="getcompetitionAccessory"
             :navName="'上传文件'"
@@ -514,6 +532,7 @@
         <td colspan="7" style="height: 200px">
           <p>参展或交流活动(提供参加师生名单、活动方案及照片等附件):</p>
           <beUpload
+            v-show="!isDownPdf"
             style="position: absolute; right: 10px; top: 5px"
             @getFile="getexchangeAccessory"
             :navName="'上传文件'"
@@ -561,6 +580,7 @@
         <td colspan="7" style="height: 200px">
           <p>创业公司转化(提供公司注册资料、营业执照等附件):</p>
           <beUpload
+            v-show="!isDownPdf"
             style="position: absolute; right: 10px; top: 5px"
             @getFile="getconversionAccessory"
             :navName="'上传文件'"
@@ -608,6 +628,7 @@
         <td colspan="7" style="height: 200px">
           <p>二、创客人才培养(提供成果、数量、学生名单等附件)</p>
           <beUpload
+            v-show="!isDownPdf"
             style="position: absolute; right: 10px; top: 5px"
             @getFile="gettalentsAccessory"
             :navName="'上传文件'"
@@ -653,17 +674,22 @@
       <tr>
         <td colspan="7" style="text-align: left; height: auto">
           <p>目标计划:</p>
-          <!-- <div
+          <div
             class="textCss"
-            v-html="myArrayProp[0]['ClosingstatementData'].targetPlan.replace(/ /g, '&nbsp;')"
-          ></div> -->
-          <el-input
+            v-html="
+              myArrayProp[0]['ClosingstatementData'].targetPlan.replace(
+                / /g,
+                '&nbsp;'
+              )
+            "
+          ></div>
+          <!-- <el-input
             type="textarea"
             :autosize="{ minRows: 6 }"
             placeholder="请输入内容"
             v-model="myArrayProp[0]['ClosingstatementData'].targetPlan"
           >
-          </el-input>
+          </el-input> -->
         </td>
       </tr>
       <tr>
@@ -696,6 +722,7 @@
         <td colspan="7" style="height: 200px">
           <p>附:课题研究报告、用户评价意见或专家鉴定意见、其它附件等等</p>
           <beUpload
+            v-show="!isDownPdf"
             style="position: absolute; right: 10px; top: 5px"
             @getFile="gettaskAccessory"
             :navName="'上传文件'"
@@ -770,9 +797,11 @@
         <td>-</td>
         <td>
           <el-input
+            v-if="!isDownPdf"
             v-model="myArrayProp[0]['money'].device"
             @change="getPrice"
           ></el-input>
+          <div v-else>{{ myArrayProp[0]["money"].device }}</div>
         </td>
         <td colspan="3">
           项目开展所需的小型专用仪器设备、工具、配件购置或租赁费用。
@@ -783,9 +812,11 @@
         <td>-</td>
         <td>
           <el-input
+            v-if="!isDownPdf"
             v-model="myArrayProp[0]['money'].Material"
             @change="getPrice"
           ></el-input>
+          <div v-else>{{ myArrayProp[0]["money"].Material }}</div>
         </td>
         <td colspan="3">
           项目开展需消耗的各种原材料、辅助材料等低值易耗品的采购费用。
@@ -796,9 +827,11 @@
         <td>-</td>
         <td>
           <el-input
+            v-if="!isDownPdf"
             v-model="myArrayProp[0]['money'].processing"
             @change="getPrice"
           ></el-input>
+          <div v-else>{{ myArrayProp[0]["money"].processing }}</div>
         </td>
         <td colspan="3">
           项目开展过程中支付给外单位的检验、测试、化验、计算、分析及加工费等费用。
@@ -809,9 +842,11 @@
         <td>-</td>
         <td>
           <el-input
+            v-if="!isDownPdf"
             v-model="myArrayProp[0]['money'].Collaboration"
             @change="getPrice"
           ></el-input>
+          <div v-else>{{ myArrayProp[0]["money"].Collaboration }}</div>
         </td>
         <td colspan="3">按合同规定支付给协作单位的费用</td>
       </tr>
@@ -823,9 +858,11 @@
         <td>-</td>
         <td>
           <el-input
+            v-if="!isDownPdf"
             v-model="myArrayProp[0]['money'].APPRAISAL"
             @change="getPrice"
           ></el-input>
+          <div v-else>{{ myArrayProp[0]["money"].APPRAISAL }}</div>
         </td>
         <td colspan="3">学术会务费、评审费、鉴定费、成果集制作费等费用。</td>
       </tr>
@@ -834,9 +871,11 @@
         <td>-</td>
         <td>
           <el-input
+            v-if="!isDownPdf"
             v-model="myArrayProp[0]['money'].entery"
             @change="getPrice"
           ></el-input>
+          <div v-else>{{ myArrayProp[0]["money"].entery }}</div>
         </td>
         <td colspan="3">
           参加创客展会、竞赛等所需的报名费、展位费、布展费、宣传推广费及差旅费等费用。
@@ -847,9 +886,11 @@
         <td>-</td>
         <td>
           <el-input
+            v-if="!isDownPdf"
             v-model="myArrayProp[0]['money'].activities"
             @change="getPrice"
           ></el-input>
+          <div v-else>{{ myArrayProp[0]["money"].activities }}</div>
         </td>
         <td colspan="3">
           创客交流活动中支付给校外专家的指导费、咨询费、授课费等费用。
@@ -860,9 +901,11 @@
         <td>-</td>
         <td>
           <el-input
+            v-if="!isDownPdf"
             v-model="myArrayProp[0]['money'].Transaction"
             @change="getPrice"
           ></el-input>
+          <div v-else>{{ myArrayProp[0]["money"].Transaction }}</div>
         </td>
         <td colspan="3">论文版面费、专利及其他知识产权事务等费用。</td>
       </tr>
@@ -916,13 +959,13 @@
           </div>
         </td>
       </tr>
-      <div class="ending">
-        <p>备注:1、本表一式三份,专家验收后交双创学院</p>
-        <p style="text-indent: 3em">
-          2、各栏目若不够填写,可自行加页,加页需紧附该栏目之后。
-        </p>
-      </div>
     </table>
+    <div class="ending">
+      <p>备注:1、本表一式三份,专家验收后交双创学院</p>
+      <p style="text-indent: 3em">
+        2、各栏目若不够填写,可自行加页,加页需紧附该栏目之后。
+      </p>
+    </div>
 
     <!-- 展示文档开始 -->
     <el-dialog
@@ -988,6 +1031,10 @@ export default {
       type: String,
       required: true,
     },
+    isDownPdf: {
+      type: Boolean,
+      required: true,
+    },
   },
   components: { beUpload, vpdf, vword },
   data() {
@@ -1383,6 +1430,16 @@ export default {
         );
     },
   },
+  watch: {
+    isDownPdf: {
+      handler(newVal) {
+        if (newVal) {
+          this.isDownPdf = newVal;
+        }
+      },
+      deep: true,
+    },
+  },
   mounted() {
     // console.log(this.myArrayProp);
     //    this.getData();
@@ -1392,56 +1449,56 @@ export default {
 </script>
 
 <style lang="less" scoped>
+.onePage {
+  height: 300px;
+  width: 100%;
+  // position: absolute;
+  text-align: center;
+  // top: -750px;
+  .titSchool {
+    font-weight: 600;
+    font-size: 25px;
+    margin-bottom: 30px;
+    font-family: \6977\4f53;
+  }
+  .title {
+    font-weight: 600;
+    font-size: 32px;
+    margin-bottom: 30px;
+    font-family: \9ed1\4f53;
+    margin-bottom: 100px;
+  }
+  .line {
+    width: 300px;
+    border-bottom: 1px black solid;
+  }
+  .basicInformation {
+    display: flex;
+    justify-content: center;
+    font-size: 22px;
+    font-family: \4eff\5b8b;
+    font-weight: bold;
+    margin-bottom: 50px;
+
+    span {
+      width: 100px;
+      text-align: justify;
+      text-align-last: justify;
+      /*兼容ie*/
+      text-justify: distribute-all-lines;
+      margin-right: 10px;
+    }
+  }
+}
 table {
   position: relative;
   color: black;
   width: 1200px;
   margin: 0 auto;
-  margin-top: 800px;
-  margin-bottom: 100px;
-  font-size: 16px;
+  margin-top: 400px;
+  margin-bottom: 20px;
+  font-size: 22px;
   font-family: \5b8b\4f53;
-  .onePage {
-    height: 300px;
-    width: 100%;
-    position: absolute;
-    text-align: center;
-    top: -750px;
-    .titSchool {
-      font-weight: 600;
-      font-size: 25px;
-      margin-bottom: 30px;
-      font-family: \6977\4f53;
-    }
-    .title {
-      font-weight: 600;
-      font-size: 32px;
-      margin-bottom: 30px;
-      font-family: \9ed1\4f53;
-      margin-bottom: 100px;
-    }
-    .line {
-      width: 300px;
-      border-bottom: 1px black solid;
-    }
-    .basicInformation {
-      display: flex;
-      justify-content: center;
-      font-size: 22px;
-      font-family: \4eff\5b8b;
-      font-weight: bold;
-      margin-bottom: 50px;
-
-      span {
-        width: 100px;
-        text-align: justify;
-        text-align-last: justify;
-        /*兼容ie*/
-        text-justify: distribute-all-lines;
-        margin-right: 10px;
-      }
-    }
-  }
   tr {
     width: 100%;
     border: none;
@@ -1453,9 +1510,10 @@ table {
     box-sizing: border-box;
     padding: 10px;
     position: relative;
-    .textCss{
+    .textCss {
       word-break: break-word;
       white-space: pre-line;
+      line-height: 40px;
     }
     // :deep(.el-textarea.is-disabled .el-textarea__inner) {
     //   background-color: unset;
@@ -1570,13 +1628,11 @@ table {
       font-size: 18px;
     }
   }
-  .ending {
-    position: absolute;
-    left: 0;
-    bottom: -60px;
-    p {
-      line-height: 1.5em;
-    }
+}
+.ending {
+  margin-left: 30px;
+  p {
+    line-height: 1.5em;
   }
 }
 </style>

+ 1 - 2
src/views/projectManage/components/ProjectManagementEndProjectFile.vue

@@ -268,7 +268,7 @@ export default {
         .then((res) => {
           this.tableData.splice(index, 1);
           this.ajax
-            .post(this.$store.state.api + "/UpdateProjectEndFile", {
+            .post(this.$store.state.api + "/updateEndAllFile", {
               uid: this.$store.state.userInfo.userid,
               pid: this.$route.query["pid"],
               file: JSON.stringify(this.tableData),
@@ -425,7 +425,6 @@ export default {
         .then(
           (res) => {
             console.log(res);
-
             this.state = res.data[0][0].isupload;
             let file = JSON.parse(res.data[0][0]["endFile"]);
             this.tableData = file;

+ 566 - 0
src/views/projectManage/components/ProjectManagementOtherFile.vue

@@ -0,0 +1,566 @@
+<template>
+  <!-- 项目管理 项目结题附件 -->
+  <div class="ProjectManagement5" v-loading="loading" ref="fileProject">
+    <div class="pmInp">
+      <beUpload
+        @getFile="getFile"
+        v-show="state !== 4"
+        :navName="'上传文件'"
+        :accept="accept"
+        :progress="progress"
+      ></beUpload>
+      <el-button
+        v-show="state == 4"
+        style="
+          background: #ccc !important;
+          cursor: no-drop;
+          color: #fff !important;
+          border: 0;
+          font-size: 16px;
+        "
+        >上传文件</el-button
+      >
+    </div>
+    <el-progress
+      v-show="progress.show"
+      :percentage="progress.value"
+      :format="ProgressFormat"
+    ></el-progress>
+
+    <!-- 表格部分开始 -->
+    <el-table
+      :data="tableData"
+      tooltip-effect="dark"
+      stripe
+      class="fontSize"
+      :header-cell-style="{ background: '#f2f2f2', color: '#000' }"
+    >
+      <!-- <el-table-column
+          prop="projectTitle"
+          label="项目名称"
+          align="center"
+         >
+          <template>
+            <span>{{ title }}</span>
+          </template>
+        </el-table-column> -->
+
+      <el-table-column prop="fileName" label="文件名称" align="center">
+      </el-table-column>
+
+      <el-table-column prop="size" label="大小" align="center">
+      </el-table-column>
+
+      <el-table-column prop="uploadTime" label="上传时间" align="center">
+      </el-table-column>
+
+      <el-table-column prop="operation" align="center" label="操作" width="200">
+        <template #default="scope">
+          <div class="operations">
+            <el-button
+              type="primary"
+              size="mini"
+              @click="checkFile(scope.row.url)"
+              style="background: #477edd"
+              >明细查看</el-button
+            >
+            <el-button
+              type="primary"
+              v-show="state != 4"
+              size="mini"
+              @click="DelFile(scope.$index)"
+              style="background: #477edd"
+              >删除</el-button
+            >
+          </div>
+        </template>
+      </el-table-column>
+    </el-table>
+
+    <!-- 展示文档开始 -->
+    <el-dialog
+      title="展示文件"
+      :visible.sync="showFile"
+      top="1vh"
+      width="80vw"
+      class="addDialog showDialog"
+    >
+      <div class="showFileArea" style="height: 80vh">
+        <!-- <vpdf v-if="/^\s*$/g.test(showFileUrl)&&showFileUrl.split('.')[showFileUrl.split('.').length-1]=='pdf'" :pdfUrl="showFileUrl"></vpdf> -->
+        <div
+          class="workd_media"
+          style="width: 90%; height: 90%"
+          v-if="videoDetail.sources"
+        >
+          <video-player
+            class="video-player vjs-custom-skin"
+            :playsinline="true"
+            :options="videoDetail"
+            @play="onPlayerPlay($event)"
+            style="width: 90%; height: 90%; margin: 0 auto"
+          ></video-player>
+        </div>
+        <vword
+          style="width: 100%; height: 100%; overflow: auto"
+          class="fullStyle"
+          v-else-if="Wordss['type'] != 'pdf' && Wordss['name'] != '图片'"
+          :pdfUrl="
+            'https://view.officeapps.live.com/op/view.aspx?src=' + showFileUrl
+          "
+        ></vword>
+        <vpdf
+          style="width: 100%; height: 100%; overflow: auto"
+          class="fullStyle"
+          :pdfUrl="showFileUrl"
+          v-else-if="Wordss['type'] == 'pdf'"
+        ></vpdf>
+        <img
+          :src="showFileUrl"
+          alt="图片哦"
+          v-else-if="Wordss['name'] == '图片'"
+          style="width: auto; height: auto; max-width: 100%; max-height: 100%"
+        />
+      </div>
+    </el-dialog>
+    <!-- 分页 -->
+    <!-- <el-pagination
+            @current-change="handleCurrentChange"
+            :current-page="table.currentPage"
+            :page-size="table.packageSize"
+            layout=" prev, pager, next"
+            background
+            class="paginations"
+            :total="table.total">
+          </el-pagination> -->
+    <!-- 分页结束 -->
+  </div>
+</template>
+  
+  <script>
+import beUpload from "@/components/tool/beUpload";
+import vpdf from "@/components/vpdf.vue";
+import vword from "@/components/vword.vue";
+export default {
+  components: { beUpload, vpdf, vword },
+  data() {
+    return {
+      accept: "*",
+      // table:{         // 分页数据
+      //   total:0,
+      //   packageSize:8,
+      //   currentPage:1
+      // },
+      loading: false,
+      state: 0,
+      showFile: false,
+      showFileType: 0,
+      showFileUrl: "",
+      Wordss: { type: "", name: "" },
+      canonical: {
+        Image:
+          /^https?:\/\/(.+\/)+.+(\.(gif|png|jpg|jpeg|webp|svg|psd|bmp|tif))$/i,
+        File: /^https?:\/\/(.+\/)+.+(\.(docx|xlsx|ppt|pdf))$/i,
+      },
+      title: "",
+      tableData: [], //附件列表
+      file: "",
+      progress: {
+        value: 0,
+        show: false,
+      },
+      word: [
+        "DOC",
+        "DOCX",
+        "DOCM",
+        "DOTM",
+        "DOTX",
+        "PPTX",
+        "PPSX",
+        "PPT",
+        "PPS",
+        "PPTM",
+        "POTM",
+        "PPAM",
+        "POTX",
+        "PPSM",
+        "XLSX",
+        "XLS",
+      ],
+      pdf: ["PDF"],
+      image: [
+        "BMP",
+        "PJP",
+        "APNG",
+        "PNG",
+        "JPG",
+        "GIF",
+        "SVG",
+        "JPEG",
+        "JPG",
+        "ICO",
+        "PGPEG",
+        "AVIF",
+      ],
+      vedio: [
+        "AVI",
+        "NAVI",
+        "MPEG",
+        "ASF",
+        "MOV",
+        "WMV",
+        "3GP",
+        "RM",
+        "RMVB",
+        "FLV",
+        "F4V",
+        "H.264",
+        "H.265",
+        "REAL VIDEO",
+        "MKV",
+        "WebM",
+        "HDDVD",
+        "MP4",
+        "MPG",
+        "M4V",
+        "MGV",
+        "OGV",
+        "QTM",
+        "STR",
+        "AMC",
+        "DVX",
+        "EVO",
+        "DAT",
+        "OGG",
+        "OGM",
+      ],
+      playerOptions: {
+        playbackRates: [0.7, 1.0, 1.5, 2.0], //播放速度
+        autoplay: false, //如果true,浏览器准备好时开始回放。
+        muted: false, // 默认情况下将会消除任何音频。
+        loop: false, // 导致视频一结束就重新开始。
+        preload: "auto", // 建议浏览器在<video>加载元素后是否应该开始下载视频数据。auto浏览器选择最佳行为,立即开始加载视频(如果浏览器支持)
+        language: "zh-CN",
+        aspectRatio: "16:9", // 将播放器置于流畅模式,并在计算播放器的动态大小时使用该值。值应该代表一个比例 - 用冒号分隔的两个数字(例如"16:9"或"4:3")
+        fluid: true, // 当true时,Video.js player将拥有流体大小。换句话说,它将按比例缩放以适应其容器。
+        sources: [
+          {
+            type: "video/mp4", //这里的种类支持很多种:基本视频格式、直播、流媒体等,具体可以参看git网址项目   || "video/ogg"|| "video/webm"
+            src: "", //url地址require("../../assets/media/aaa.mp4")
+          },
+        ],
+        // poster: require("../../assets/tu31.png"), //你的封面地址
+        // poster: dataRes.imgUrl, //你的封面地址
+        notSupportedMessage: "此视频暂无法播放,请稍后再试", //允许覆盖Video.js无法播放媒体源时显示的默认信息。
+        controlBar: {
+          timeDivider: true, //当前时间和持续时间的分隔符
+          durationDisplay: true, //显示持续时间
+          remainingTimeDisplay: false, //是否显示剩余时间功能
+          fullscreenToggle: true, //全屏按钮
+        },
+      },
+      playerO: {},
+      videoDetail: {},
+    };
+  },
+  methods: {
+    DelFile(index) {
+      this.$confirm("你确定要删除该文件吗?", "确定文件删除")
+        .then((res) => {
+          this.tableData.splice(index, 1);
+          this.ajax
+            .post(this.$store.state.api + "/updateOtherAllFile", {
+              uid: this.$store.state.userInfo.userid,
+              pid: this.$route.query["pid"],
+              file: JSON.stringify(this.tableData),
+            })
+            .then((res) => {
+              console.log(res);
+              if (res.data == 1) {
+                this.$message.success("删除文件成功");
+              } else {
+                this.$message.error("删除文件失败");
+              }
+              this.getData();
+            });
+        })
+        .catch((err) => {
+          console.log("取消删除文件");
+        });
+    },
+    ProgressFormat(value) {
+      //进度条
+      return value == 100 ? "100%" : `${value}%`;
+    },
+    //下载文件
+    downFile(f) {
+      var credentials = {
+        accessKeyId: "AKIATLPEDU37QV5CHLMH",
+        secretAccessKey: "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",
+      }; //秘钥形式的登录上传
+      window.AWS.config.update(credentials);
+      window.AWS.config.region = "cn-northwest-1"; //设置区域
+      let url2 = f;
+      let _url2 = "";
+      if (
+        url2.indexOf("https://view.officeapps.live.com/op/view.aspx?src=") != -1
+      ) {
+        _url2 = url2.split(
+          "https://view.officeapps.live.com/op/view.aspx?src="
+        )[1];
+      } else {
+        _url2 = url2;
+      }
+      var s3 = new window.AWS.S3({ params: { Bucket: "ccrb" } });
+      let name = decodeURIComponent(
+        _url2.split("https://ccrb.s3.cn-northwest-1.amazonaws.com.cn/")[1]
+      );
+      var params = {
+        Bucket: "ccrb",
+        Key: name,
+      };
+      s3.getObject(params, function (err, data) {
+        if (err) console.log(err, err.stack); // an error occurred
+        else {
+          let url = window.URL.createObjectURL(new Blob([data.Body]));
+          let a = document.createElement("a");
+          a.name = name;
+          a.href = url;
+          a.download = name;
+          a.click();
+          console.log(data);
+        } // sxuccessful response
+      });
+
+      return;
+    },
+    //展示文件
+    checkFile(url) {
+      this.videoDetail = {};
+      if (
+        this.vedio.indexOf(
+          url.split(".")[url.split(".").length - 1].toLocaleUpperCase()
+        ) != -1
+      ) {
+        this.playerOptions.sources[0].src = url;
+        this.videoDetail = this.playerOptions;
+        this.showFile = true;
+      } else {
+        if (
+          this.word.indexOf(
+            url.split(".")[url.split(".").length - 1].toLocaleUpperCase()
+          ) == -1 &&
+          this.pdf.indexOf(
+            url.split(".")[url.split(".").length - 1].toLocaleUpperCase()
+          ) == -1 &&
+          this.image.indexOf(
+            url.split(".")[url.split(".").length - 1].toLocaleUpperCase()
+          ) == -1
+        ) {
+          this.downFile(url);
+          return;
+        }
+        this.showFileUrl = url;
+        this.showFile = true;
+        if (typeof url == "undefined") return { type: "", name: "" };
+        let urlSplit = url.split(".");
+        const type = urlSplit[urlSplit.length - 1];
+        if (this.canonical.Image.test(url)) {
+          this.Wordss = { type: type, name: "图片" };
+          return console.log(this.Wordss);
+        }
+        if (this.canonical.File.test(url)) {
+          this.Wordss = { type: type, name: "文档" };
+          return console.log(this.Wordss);
+        } else return (this.Wordss = { type: type, name: type });
+      }
+    },
+    onPlayerPlay() {},
+    getFile(val) {
+      //上传文件
+      this.file = val;
+      // return console.log(val);
+      let oldData = [];
+      if (this.tableData != null) {
+        this.tableData.forEach((item) => oldData.push(item));
+        oldData.push(val);
+      } else {
+        oldData.push(val);
+      }
+      let param = {
+        uid: this.$store.state.userInfo.userid,
+        cid: this.$route.query["pid"],
+        projectFile: JSON.stringify(oldData),
+      };
+      this.ajax.post(this.$store.state.api + "/AddOtherFile", param).then(
+        (res) => {
+          if (res.data == 1) {
+            this.getData();
+            this.$message.success("上传成功");
+            this.progress.show = false;
+          } else {
+            this.$message.error("上传失败");
+          }
+        },
+        (err) => {
+          console.log(err);
+        }
+      );
+    },
+
+    getData() {
+      //获取基础信息
+      this.loading = true;
+      let param = {
+        uid: this.$store.state.userInfo.userid,
+        pid: this.$route.query["pid"],
+      };
+      // console.log(param);
+      this.ajax.get(this.$store.state.api + "/selectOtherFile", param).then(
+        (res) => {
+          // console.log(res);
+          let data = res.data[0][0];
+          console.log(data);
+          let file = "";
+          this.state = data.isupload;
+          if (data["otherFile"] != null && data["otherFile"] != "") {
+            console.log(111);
+            file = JSON.parse(data["otherFile"]);
+            this.tableData = file;
+          }
+          this.loading = false;
+        },
+        (err) => {
+          console.log(err);
+        }
+      );
+    },
+    back() {
+      this.$router.push("/ProjectManagement");
+    },
+  },
+  mounted() {
+    this.getData();
+  },
+};
+</script>
+  
+  <style lang="less">
+.ProjectManagement5 {
+  .pagination {
+    float: right;
+    margin: 20px 55px 10px;
+  }
+  .addDialog {
+    font-size: 18px;
+    .el-dialog {
+      border-radius: 5px;
+      overflow: hidden;
+    }
+    .deleteContent {
+      width: 100%;
+      margin: 30px 0;
+      font-size: 22px;
+      color: #000;
+    }
+    .addDialogLogo {
+      width: 60px;
+      height: 30px;
+      display: flex;
+      justify-content: center;
+      line-height: 30px;
+      border-radius: 5px;
+      background: #f2f2f2;
+      position: absolute;
+      left: 20px;
+      top: 15px;
+    }
+    .el-dialog__header {
+      display: flex;
+      justify-content: center;
+      background: #32455b;
+    }
+    .el-dialog__title {
+      color: #fff;
+      display: flex;
+      justify-content: center;
+      font-size: 18px;
+      position: relative;
+      top: -2px;
+    }
+    .addDialogMid {
+      box-sizing: border-box;
+      padding: 0 60px 0 10px;
+      .addDialogTit {
+        display: flex;
+        span {
+          width: 80px;
+          font-size: 16px;
+          line-height: 40px;
+          text-align: left;
+        }
+      }
+      .addDialogTit1 {
+        display: flex;
+        justify-content: space-between;
+        margin-bottom: 15px;
+      }
+      .addDialogTit2 {
+        margin-top: 10px;
+        font-size: 16px;
+        color: #000;
+        text-indent: 2em;
+      }
+      .addDialogCon {
+        margin-top: 20px;
+      }
+    }
+    .dialog-footer {
+      display: flex;
+      justify-content: center;
+      box-sizing: border-box;
+      // .btn5 {
+      //   font-size: 16px;
+      // }
+    }
+  }
+
+  .pm5footer {
+    float: right;
+    margin-top: 30px;
+
+    .backBtn {
+      background: #169bd5;
+      float: right;
+      width: 100px;
+    }
+  }
+
+  .pm1Tit {
+    display: flex;
+    margin-left: 20px;
+    div {
+      width: 130px;
+      cursor: pointer;
+      font-weight: 550;
+    }
+    .pr1TitBass {
+      height: 2px;
+      width: 100%;
+      background: #3d67bc;
+    }
+  }
+  .pmInp {
+    width: 100%;
+    margin: 10px 0 10px 0;
+    display: flex;
+    justify-content: flex-end;
+    // .btn{
+    //   width: 120px;
+    //   font-size: 16px;
+    //   border: none;
+
+    //   // margin-left: 10px;
+    // }
+  }
+}
+</style>

+ 1 - 2
src/views/projectManage/components/ProjectManagementProjectFile.vue

@@ -268,7 +268,7 @@ export default {
         .then((res) => {
           this.tableData.splice(index, 1);
           this.ajax
-            .post(this.$store.state.api + "/UpdateProjectEndFile", {
+            .post(this.$store.state.api + "/updateProjectAllFile", {
               uid: this.$store.state.userInfo.userid,
               pid: this.$route.query["pid"],
               file: JSON.stringify(this.tableData),
@@ -335,7 +335,6 @@ export default {
     },
     //展示文件
     checkFile(url) {
-      debugger
       this.videoDetail = {};
       if (
         this.vedio.indexOf(

+ 515 - 412
src/views/projectManage/components/studentProjectWordShow.vue

@@ -1,173 +1,278 @@
 <template>
-    <div id="studentProjectWord" ref="downPDF">
-        
-        <table border="1" cellspacing="0" class="table">
-          <div id="title">
-              <div class="school">深圳技师学院</div>
-              <div class="wordTitle">学 生 创 客 项 目 申 报 书</div>
-              <div class="date">申请日期:{{downWordData.applyProjectTime}}</div>
-          </div>
+  <div id="studentProjectWord" ref="downPDF">
+    <table border="1" cellspacing="0" class="table">
+      <div id="title">
+        <div class="school">深圳技师学院</div>
+        <div class="wordTitle">学 生 创 客 项 目 申 报 书</div>
+        <div class="date">申请日期:{{ downWordData.applyProjectTime }}</div>
+      </div>
 
-          <tr id="projectName">
-            <td colspan="2" ref="projectName">项目名称</td><td colspan="5" v-text='downWordData.projectName'></td>
-          </tr>
-          <tr id="radio">
-            <td rowspan="2" colspan="2" ref="radio">项目分组</td><td v-text="downWordData.radio=='ed917c55-f51d-11ed-a3f6-509a4c5b67cf'?'√ 创意组':'□ 创意组'">
-            </td>
-            <td colspan="4">立项项目为新立项项目,项目成果应具有较好的创意和较为成型的产品原型或能提供较好的商业模式,产生较好的社会效益。</td>
-          </tr> 
-          <tr>
-            <td v-text="downWordData.radio=='ed917c55-f51d-11ed-a3f6-509a4c5b67cf'?'□ 初创组':'√ 初创组'">
-            </td>
-            <td colspan="4">立项项目为学校已结题学生创客项目或已入驻学校创业孵化基地的学生初创企业项目(毕业两年内),项目成果应为原结题项目基础上的技术升级、企业注册、规模扩张。</td>
-          </tr> 
-          <tr id="checkList" class="checkArea">
-            <td colspan="2" ref="checkList">优先支持项目(可多选)</td> <td colspan="5">
-              
-
-              <span><span>{{ downWordData['checkList'].includes('1')?'√ ':'□' }}大赛选拔项目</span></span>
-              <span><span>{{ downWordData['checkList'].includes('2')?'√ ':'□' }}落地注册项目</span></span>
-              <span><span>{{ downWordData['checkList'].includes('3')?'√ ':'□' }}社会征集项目</span></span>
-              <span><span>{{ downWordData['checkList'].includes('4')?'√ ':'□' }}产业命题项目</span></span>
-            </td>
-          </tr>
-          <tr id="schoolRadio" class="checkArea">
-            <td colspan="2" ref="schoolRadio">美丽校园改造项目(特色项目)</td> <td colspan="5">
-              <span><span v-text="downWordData['schoolRadio']=='1'?'√ ':'□ '"></span><span>校园安全项目</span></span>
-              <span><span v-text="downWordData['schoolRadio']=='2'?'√ ':'□ '"></span><span>环境治理项目</span></span>
-              <span><span v-text="downWordData['schoolRadio']=='3'?'√ ':'□ '"></span><span>校园服务项目</span></span>
-              <span><span v-text="downWordData['schoolRadio']=='4'?'√ ':'□ '"></span><span>文创装置项目</span></span>
-            </td>
-          </tr>
-          <tr id="applyParsonRadio">
-            <td colspan="2" ref="applyParsonRadio" >项 目 申 请 人</td><td colspan="2">
-              <span v-text="downWordData['applyParsonRadio']=='1'?'√ ':'□ '"></span><span>在校学生</span>
-              <!-- <el-radio v-model="downWordData.applyParsonRadio" label="1">在校学生</el-radio> -->
-            </td><td colspan="3">
-              <span v-text="downWordData['applyParsonRadio']=='2'?'√ ':'□ '"></span><span>入驻学校孵化基地的初创企业法人</span>
-              <!-- <el-radio v-model="downWordData.applyParsonRadio" label="2">入驻学校孵化基地的初创企业法人</el-radio> -->
-            </td>
-          </tr>
-          <tr id="applyParsonName">
-            <td colspan="2" ref="applyParsonName">申 请 人 姓 名</td><td colspan="1" v-text="downWordData.applyParsonName">
-            </td>
-            <td ref="college">参与学院/公司</td><td v-text="downWordData.dp">
-            </td><td ref="tel">联系电话</td><td v-text="downWordData.tel"></td>
-          </tr>
-          <tr id="beginTime">
-            <td colspan="2" ref="beginTime">项 目 起 始 时 间</td><td colspan="2" v-text="downWordData.beginTime.split(' ')[0]"></td>
-            <td ref="endTime">计划完成时间</td><td colspan="2" v-text="downWordData.endTime.split(' ')[0]"></td>
-          </tr>
-          <tr>
-            <td colspan="2">项 目 组 人 数</td><td v-text="downWordData.studentS.length + downWordData.teacherS.length"></td>
-            <td>参与学生人数</td><td v-text='downWordData.studentS.length'> </td>
-            <td>参与教师人数</td><td v-text="downWordData.teacherS.length"></td>
-          </tr>
-          <tr id="studentS">
-            <td :rowspan="downWordData.studentS.length+1" ref="studentS">项目组学生成员(至少2个学院以上学生构成,团队5人以上)</td><td>姓名</td><td colspan="2">所在学院/部门/专业</td><td colspan="3">项目组角色分工</td>
-          </tr>
-          <tr style="position: relative;" v-for="(item,index) in downWordData.studentS" :key="index+'a'">
-            <td v-text="item.name"></td>
-            <td colspan="2" v-text="item.collage"></td>
-            <td colspan="3" v-text="item.work"></td>
-          </tr>
-          <tr id="teacherS">
-            <td :rowspan="downWordData.teacherS.length+1" ref="teacherS">项目组指导教师(2个学院以上,团队2-3人)</td><td>姓名</td><td colspan="2">所在学院/部门/专业</td><td colspan="3">项目组角色分工</td>
-          </tr>
-          <tr style="position: relative !important;" v-for="(item,index) in downWordData.teacherS" :key="index+'b'">
-            <td v-text="item.name"></td>
-            <td colspan="2" v-text="item.collage"></td>
-            <td colspan="3" v-text="item.work"></td>
-          </tr>
-          <tr id="brief">
-            <td rowspan="5" ref="brief">研发内容</td><td colspan="6" class="textLeft">
-              <p>项目简介(200-300字)</p>
-              <span>
-                {{ downWordData.brief }}
-              </span>
-            </td>
-          </tr>
-          <tr>
-            <td style="text-align: left;" colspan="6" class="textLeft">
-              <p>项目研发背景</p>
-              <span v-html="downWordData.introduce.back"></span>
-            </td>
-          </tr>
-          <tr>
-            <td style="text-align: left;" colspan="6" class="textLeft">
-              <p>项目创新点</p>
-              <span v-html="downWordData.introduce.innovate"></span>
-            </td>
-          </tr>
-          <tr>
-            <td style="text-align: left;" colspan="6" class="textLeft">
-              <p>技术研发路线</p>
-              <span v-html="downWordData.introduce.path"></span>
-            </td>
-          </tr>
-          <tr>
-            <td style="text-align: left;" colspan="6" class="textLeft">
-              <p>项目应用场景 </p>
-              <span v-html="downWordData.introduce.scene"></span>
-            </td>
-          </tr>
-          <tr>
-            <td>商业模式及社会价值</td>
-            <td style="text-align: left;" colspan="6" class="textLeft">
-              <p>项目商业模式/社会价值</p>
-              <span v-html="downWordData.introduce.worth"></span>
-            </td>
-          </tr>
-          <tr>
-            <td>团队优势</td>
-            <td style="text-align: left;" colspan="6" class="textLeft">
-              <p>团队构成及优势</p>
-              <span v-html='downWordData.introduce.team'></span>
-            </td>
-          </tr>
-          <tr>
-            <td>研发成本</td>
-            <td style="text-align: left;" colspan="6" class="textLeft">
-              <p>研发成本来源及构成</p>
-              <span v-html="downWordData.introduce.cost"></span>
-            </td>
-          </tr>
-          <tr>
-            <td rowspan="3">预期成果</td>
-            <td style="text-align: left;" colspan="6" class="textLeft">
-              <p>项目预期成果、数量及形式(产品原型/发明专利/双创竞赛/成果转化/社会效益)</p>
-              <span v-html="downWordData.introduce.expectResults"></span>
-            </td>
-          </tr>
-          <tr class="textLeft">
-            <td style="text-align: left;" colspan="6">
-              <p>学生创客人才培养预期成果、数量(教师填写)</p>
-              <span v-html="downWordData.introduce.expectResultsTeacher"></span>
-            </td>
-          </tr>
-          <tr class="textLeft">
-            <td style="text-align: left;" colspan="6">
-              <p>项目预期孵化、转化创业项目情况</p>
-              <span v-html="downWordData.introduce.expectConversion"></span>
-            </td>
-          </tr>
-          <tr>
-            <td>实施计划</td>
-            <td style="text-align: left;" colspan="6" class="textLeft">
-              <span v-html="downWordData.introduce.plan"></span>
-            </td>
-          </tr>
-          <tr id="fund">
-            <td rowspan="12" ref="fund">预算经费</td><td>总经费</td><td colspan="5" v-text="reversedMessage==0?'':reversedMessage"></td>
-          </tr>
-          <tr>
-            <td>支出类别</td><td colspan="2">支出项目</td><td>金额(元)</td><td colspan="4">备 注</td>
-          </tr>
-          <tr>
-            <td rowspan="5">直接费用</td>
-          </tr>
-          <tr>
-            <!-- device:"",
+      <tr id="projectName">
+        <td colspan="2" ref="projectName">项目名称</td>
+        <td colspan="5" v-text="downWordData.projectName"></td>
+      </tr>
+      <tr id="radio">
+        <td rowspan="2" colspan="2" ref="radio">项目分组</td>
+        <td
+          v-text="
+            downWordData.radio == 'ed917c55-f51d-11ed-a3f6-509a4c5b67cf'
+              ? '√ 创意组'
+              : '□ 创意组'
+          "
+        ></td>
+        <td colspan="4">
+          立项项目为新立项项目,项目成果应具有较好的创意和较为成型的产品原型或能提供较好的商业模式,产生较好的社会效益。
+        </td>
+      </tr>
+      <tr>
+        <td
+          v-text="
+            downWordData.radio == 'ed917c55-f51d-11ed-a3f6-509a4c5b67cf'
+              ? '□ 初创组'
+              : '√ 初创组'
+          "
+        ></td>
+        <td colspan="4">
+          立项项目为学校已结题学生创客项目或已入驻学校创业孵化基地的学生初创企业项目(毕业两年内),项目成果应为原结题项目基础上的技术升级、企业注册、规模扩张。
+        </td>
+      </tr>
+      <tr id="checkList" class="checkArea" v-if="downWordData['checkList'].length > 0">
+        <td colspan="2" ref="checkList">优先支持项目(可多选)</td>
+        <td colspan="5">
+          <span
+            ><span
+              >{{
+                downWordData["checkList"].indexOf("1") != -1 ? "√ " : "□"
+              }}大赛选拔项目</span
+            ></span
+          >
+          <span
+            ><span
+              >{{
+                downWordData["checkList"].indexOf("2") != -1 ? "√ " : "□"
+              }}落地注册项目</span
+            ></span
+          >
+          <span
+            ><span
+              >{{
+                downWordData["checkList"].indexOf("3") != -1 ? "√ " : "□"
+              }}社会征集项目</span
+            ></span
+          >
+          <span
+            ><span
+              >{{
+                downWordData["checkList"].indexOf("4") != -1 ? "√ " : "□"
+              }}产业命题项目</span
+            ></span
+          >
+        </td>
+      </tr>
+      <tr id="schoolRadio" class="checkArea" v-if="downWordData['schoolRadio'].length > 0">
+        <td colspan="2" ref="schoolRadio">美丽校园改造项目(特色项目)</td>
+        <td colspan="5">
+          <span
+            ><span
+              v-text="downWordData['schoolRadio'].indexOf('1') != -1 ? '√ ' : '□ '"
+            ></span
+            ><span>校园安全项目</span></span
+          >
+          <span
+            ><span
+              v-text="downWordData['schoolRadio'].indexOf('2') != -1 ? '√ ' : '□ '"
+            ></span
+            ><span>环境治理项目</span></span
+          >
+          <span
+            ><span
+              v-text="downWordData['schoolRadio'].indexOf('3') != -1 ? '√ ' : '□ '"
+            ></span
+            ><span>校园服务项目</span></span
+          >
+          <span
+            ><span
+              v-text="downWordData['schoolRadio'].indexOf('4') != -1 ? '√ ' : '□ '"
+            ></span
+            ><span>文创装置项目</span></span
+          >
+        </td>
+      </tr>
+      <tr id="applyParsonRadio" v-if="downWordData['applyParsonRadio'].length > 0">
+        <td colspan="2" ref="applyParsonRadio">项 目 申 请 人</td>
+        <td colspan="2">
+          <span
+            v-text="downWordData['applyParsonRadio'].indexOf('1') != -1 ? '√ ' : '□ '"
+          ></span
+          ><span>在校学生</span>
+          <!-- <el-radio v-model="downWordData.applyParsonRadio" label="1">在校学生</el-radio> -->
+        </td>
+        <td colspan="3">
+          <span
+            v-text="downWordData['applyParsonRadio'].indexOf('2') != -1 ? '√ ' : '□ '"
+          ></span
+          ><span>入驻学校孵化基地的初创企业法人</span>
+          <!-- <el-radio v-model="downWordData.applyParsonRadio" label="2">入驻学校孵化基地的初创企业法人</el-radio> -->
+        </td>
+      </tr>
+      <tr id="applyParsonName">
+        <td colspan="2" ref="applyParsonName">申 请 人 姓 名</td>
+        <td colspan="1" v-text="downWordData.applyParsonName"></td>
+        <td ref="college">参与学院/公司</td>
+        <td v-text="downWordData.dp"></td>
+        <td ref="tel">联系电话</td>
+        <td v-text="downWordData.tel"></td>
+      </tr>
+      <tr id="beginTime">
+        <td colspan="2" ref="beginTime">项 目 起 始 时 间</td>
+        <td colspan="2" v-text="downWordData.beginTime.split(' ')[0]"></td>
+        <td ref="endTime">计划完成时间</td>
+        <td colspan="2" v-text="downWordData.endTime.split(' ')[0]"></td>
+      </tr>
+      <tr>
+        <td colspan="2">项 目 组 人 数</td>
+        <td
+          v-text="downWordData.studentS.length + downWordData.teacherS.length"
+        ></td>
+        <td>参与学生人数</td>
+        <td v-text="downWordData.studentS.length"></td>
+        <td>参与教师人数</td>
+        <td v-text="downWordData.teacherS.length"></td>
+      </tr>
+      <tr id="studentS">
+        <td :rowspan="downWordData.studentS.length + 1" ref="studentS">
+          项目组学生成员(至少2个学院以上学生构成,团队5人以上)
+        </td>
+        <td>姓名</td>
+        <td colspan="2">所在学院/部门/专业</td>
+        <td colspan="3">项目组角色分工</td>
+      </tr>
+      <tr
+        style="position: relative"
+        v-for="(item, index) in downWordData.studentS"
+        :key="index + 'a'"
+      >
+        <td v-text="item.name"></td>
+        <td colspan="2" v-text="item.collage"></td>
+        <td colspan="3" v-text="item.work"></td>
+      </tr>
+      <tr id="teacherS">
+        <td :rowspan="downWordData.teacherS.length + 1" ref="teacherS">
+          项目组指导教师(2个学院以上,团队2-3人)
+        </td>
+        <td>姓名</td>
+        <td colspan="2">所在学院/部门/专业</td>
+        <td colspan="3">项目组角色分工</td>
+      </tr>
+      <tr
+        style="position: relative !important"
+        v-for="(item, index) in downWordData.teacherS"
+        :key="index + 'b'"
+      >
+        <td v-text="item.name"></td>
+        <td colspan="2" v-text="item.collage"></td>
+        <td colspan="3" v-text="item.work"></td>
+      </tr>
+      <tr id="brief">
+        <td rowspan="5" ref="brief">研发内容</td>
+        <td colspan="6" class="textLeft">
+          <p>项目简介(200-300字)</p>
+          <span>
+            {{ downWordData.brief }}
+          </span>
+        </td>
+      </tr>
+      <tr>
+        <td style="text-align: left" colspan="6" class="textLeft">
+          <p>项目研发背景</p>
+          <span v-html="downWordData.introduce.back"></span>
+        </td>
+      </tr>
+      <tr>
+        <td style="text-align: left" colspan="6" class="textLeft">
+          <p>项目创新点</p>
+          <span v-html="downWordData.introduce.innovate"></span>
+        </td>
+      </tr>
+      <tr>
+        <td style="text-align: left" colspan="6" class="textLeft">
+          <p>技术研发路线</p>
+          <span v-html="downWordData.introduce.path"></span>
+        </td>
+      </tr>
+      <tr>
+        <td style="text-align: left" colspan="6" class="textLeft">
+          <p>项目应用场景</p>
+          <span v-html="downWordData.introduce.scene"></span>
+        </td>
+      </tr>
+      <tr>
+        <td>商业模式及社会价值</td>
+        <td style="text-align: left" colspan="6" class="textLeft">
+          <p>项目商业模式/社会价值</p>
+          <span v-html="downWordData.introduce.worth"></span>
+        </td>
+      </tr>
+      <tr>
+        <td>团队优势</td>
+        <td style="text-align: left" colspan="6" class="textLeft">
+          <p>团队构成及优势</p>
+          <span v-html="downWordData.introduce.team"></span>
+        </td>
+      </tr>
+      <tr>
+        <td>研发成本</td>
+        <td style="text-align: left" colspan="6" class="textLeft">
+          <p>研发成本来源及构成</p>
+          <span v-html="downWordData.introduce.cost"></span>
+        </td>
+      </tr>
+      <tr>
+        <td rowspan="3">预期成果</td>
+        <td style="text-align: left" colspan="6" class="textLeft">
+          <p>
+            项目预期成果、数量及形式(产品原型/发明专利/双创竞赛/成果转化/社会效益)
+          </p>
+          <span v-html="downWordData.introduce.expectResults"></span>
+        </td>
+      </tr>
+      <tr class="textLeft">
+        <td style="text-align: left" colspan="6">
+          <p>学生创客人才培养预期成果、数量(教师填写)</p>
+          <span v-html="downWordData.introduce.expectResultsTeacher"></span>
+        </td>
+      </tr>
+      <tr class="textLeft">
+        <td style="text-align: left" colspan="6">
+          <p>项目预期孵化、转化创业项目情况</p>
+          <span v-html="downWordData.introduce.expectConversion"></span>
+        </td>
+      </tr>
+      <tr>
+        <td>实施计划</td>
+        <td style="text-align: left" colspan="6" class="textLeft">
+          <span v-html="downWordData.introduce.plan"></span>
+        </td>
+      </tr>
+      <tr id="fund">
+        <td rowspan="12" ref="fund">预算经费</td>
+        <td>总经费</td>
+        <td
+          colspan="5"
+          v-text="reversedMessage == 0 ? '' : reversedMessage"
+        ></td>
+      </tr>
+      <tr>
+        <td>支出类别</td>
+        <td colspan="2">支出项目</td>
+        <td>金额(元)</td>
+        <td colspan="4">备 注</td>
+      </tr>
+      <tr>
+        <td rowspan="5">直接费用</td>
+      </tr>
+      <tr>
+        <!-- device:"",
                 Material:"",
                 processing:"",
                 Collaboration:"",
@@ -175,59 +280,60 @@
                 entery:"",
                 activities:"",
                 Transaction:"", -->
-            <td colspan="2">小型仪器设备费</td>
-            <td v-text="downWordData.fund.device">
-            </td><td colspan="2">
-              项目开展所需的小型专用仪器设备、工具、配件购置或租赁费用。
-            </td>
-          </tr>
-          <tr>
-            <td colspan="2">材料费</td><td v-text="downWordData.fund.Material">
-            </td><td colspan="2">
-              项目开展需消耗的各种原材料、辅助材料等低值易耗品的采购费用。
-            </td>
-          </tr>
-          <tr>
-            <td colspan="2">测试化验加工费</td><td v-text="downWordData.fund.processing">
-            </td><td colspan="2">
-              项目开展过程中支付给外单位的检验、测试、化验、计算、分析及加工费等费用。
-            </td>
-          </tr>
-          <tr>
-            <td colspan="2">项目协作费</td><td v-text="downWordData.fund.Collaboration">
-            </td><td colspan="2">
-              按合同规定支付给协作单位的费用
-            </td>
-          </tr>
-    
-          <tr>
-            <td rowspan="5">间接费用</td>
-          </tr>
-          <tr>
-            <td colspan="2">项目成果鉴定费</td><td v-text="downWordData.fund.APPRAISAL">
-            </td><td colspan="2">
-              学术会务费、评审费、鉴定费、成果集制作费等费用。
-            </td>
-          </tr>
-          <tr>
-            <td colspan="2">参展参赛费</td><td v-text="downWordData.fund.entery">
-            </td><td colspan="2">
-              参加创客展会、竞赛等所需的报名费、展位费、布展费、宣传推广费及差旅费等费用。
-            </td>
-          </tr>
-          <tr>
-            <td colspan="2">创客交流活动费</td><td v-text="downWordData.fund.activities">
-            </td><td colspan="2">
-              创客交流活动中支付给校外专家的指导费、咨询费、授课费等费用。
-            </td>
-          </tr>
-          <tr>
-            <td colspan="2">知识产权事务费</td><td v-text="downWordData.fund.Transaction">
-            </td><td colspan="2">
-              论文版面费、专利及其他知识产权事务等费用。
-            </td>
-          </tr>
-          <!-- <tr>
+        <td colspan="2">小型仪器设备费</td>
+        <td v-text="downWordData.fund.device"></td>
+        <td colspan="2">
+          项目开展所需的小型专用仪器设备、工具、配件购置或租赁费用。
+        </td>
+      </tr>
+      <tr>
+        <td colspan="2">材料费</td>
+        <td v-text="downWordData.fund.Material"></td>
+        <td colspan="2">
+          项目开展需消耗的各种原材料、辅助材料等低值易耗品的采购费用。
+        </td>
+      </tr>
+      <tr>
+        <td colspan="2">测试化验加工费</td>
+        <td v-text="downWordData.fund.processing"></td>
+        <td colspan="2">
+          项目开展过程中支付给外单位的检验、测试、化验、计算、分析及加工费等费用。
+        </td>
+      </tr>
+      <tr>
+        <td colspan="2">项目协作费</td>
+        <td v-text="downWordData.fund.Collaboration"></td>
+        <td colspan="2">按合同规定支付给协作单位的费用</td>
+      </tr>
+
+      <tr>
+        <td rowspan="5">间接费用</td>
+      </tr>
+      <tr>
+        <td colspan="2">项目成果鉴定费</td>
+        <td v-text="downWordData.fund.APPRAISAL"></td>
+        <td colspan="2">学术会务费、评审费、鉴定费、成果集制作费等费用。</td>
+      </tr>
+      <tr>
+        <td colspan="2">参展参赛费</td>
+        <td v-text="downWordData.fund.entery"></td>
+        <td colspan="2">
+          参加创客展会、竞赛等所需的报名费、展位费、布展费、宣传推广费及差旅费等费用。
+        </td>
+      </tr>
+      <tr>
+        <td colspan="2">创客交流活动费</td>
+        <td v-text="downWordData.fund.activities"></td>
+        <td colspan="2">
+          创客交流活动中支付给校外专家的指导费、咨询费、授课费等费用。
+        </td>
+      </tr>
+      <tr>
+        <td colspan="2">知识产权事务费</td>
+        <td v-text="downWordData.fund.Transaction"></td>
+        <td colspan="2">论文版面费、专利及其他知识产权事务等费用。</td>
+      </tr>
+      <!-- <tr>
             <td>所在学院/部门意见</td><td colspan="6" class="textLeft" style="height:200px">
               <div style="height:200px"></div>
                 <div style="text-align: right;font-size: 18px;width: 80%;margin-bottom: 20px;">负责人签章:</div>
@@ -248,208 +354,205 @@
                 <div style="text-align: right;font-size: 18px;width: 90%;">年&nbsp;&nbsp;&nbsp; 月 &nbsp;&nbsp;&nbsp;日</div>
             </td>
           </tr> -->
-          <div class="notes">
-            <span>备注:</span>
-            <span>1.表格可顺延或另附页。</span>
-            <span>2.优先支持项目需提供与研发项目相关的实证材料并查看原件。</span>
-            <span>3.初创组已结题项目申请需提供结题验收证明、初创企业申请需提供入驻学校孵化基地协议书及公司营业执照。</span>
-          </div>
-        </table>
-          
-          <!-- <el-button style="margin-top:20px" type="primary" @click="work">下载表格</el-button> -->
-    </div>
-    </template>
+      <div class="notes">
+        <span>备注:</span>
+        <span>1.表格可顺延或另附页。</span>
+        <span>2.优先支持项目需提供与研发项目相关的实证材料并查看原件。</span>
+        <span
+          >3.初创组已结题项目申请需提供结题验收证明、初创企业申请需提供入驻学校孵化基地协议书及公司营业执照。</span
+        >
+      </div>
+    </table>
+
+    <!-- <el-button style="margin-top:20px" type="primary" @click="work">下载表格</el-button> -->
+  </div>
+</template>
       
     <script>
-      import {getWord} from '@/components/tool/getWord'
-      export default {
-        data() {
-          return {
-              downWordData:{
-                
-              },
-              
-            }
-        },
-        methods: {
-          work(){
-            this.$message.info("正在下载表格")
-            getWord(this.downWordData)
-          },
-          getData(){
-              let param={
-                  uid:this.$store.state.userInfo.userid,
-                  pid:this.$route.query['pid']
-              }
-              this.ajax
-              .get(this.$store.state.api+'/studentProjectData',param)
-              .then(res=>{
-                  let data=res.data[0][0];
-                  console.log(data);
-                  let wordData={}
-                  wordData.projectName=data.title;
-                  wordData.applyProjectTime=data.applyProjectTime;
-                  wordData.radio=data.typeName;
-                  wordData.checkList=JSON.parse(data.multiSelectProject);
-                  wordData.schoolRadio=data.schoolRemould;
-                  wordData.applyParsonRadio=data.projectApplyperson;
-                  wordData.applyParsonName=data.pro_leader;
-                  wordData.college=data.classid;
-                  wordData.tel=data.phone;
-                  wordData.beginTime=data.bTime;
-                  wordData.endTime=data.eTime;
-                  wordData.studentS=JSON.parse(data.course_student);
-                  wordData.teacherS=JSON.parse(data.course_teacher);
-                  wordData.brief=data.brief;
-                  wordData.introduce=JSON.parse(data.chapters)
-                  wordData.fund=JSON.parse(data.money)
-                  wordData.dp=data.className
-
-                  this.downWordData=wordData
+import { getWord } from "@/components/tool/getWord";
+export default {
+  data() {
+    return {
+      downWordData: {},
+    };
+  },
+  methods: {
+    work() {
+      this.$message.info("正在下载表格");
+      getWord(this.downWordData);
+    },
+    getData() {
+      let param = {
+        uid: this.$store.state.userInfo.userid,
+        pid: this.$route.query["pid"],
+      };
+      this.ajax.get(this.$store.state.api + "/studentProjectData", param).then(
+        (res) => {
+          let data = res.data[0][0];
+          console.log(data);
+          let wordData = {};
+          wordData.projectName = data.title;
+          wordData.applyProjectTime = data.applyProjectTime;
+          wordData.radio = data.typeName;
+          wordData.checkList = JSON.parse(data.multiSelectProject);
+          wordData.schoolRadio = JSON.parse(data.schoolRemould);
+          wordData.applyParsonRadio = JSON.parse(data.projectApplyperson);
+          wordData.applyParsonName = data.pro_leader;
+          wordData.college = data.classid;
+          wordData.tel = data.phone;
+          wordData.beginTime = data.bTime;
+          wordData.endTime = data.eTime;
+          wordData.studentS = JSON.parse(data.course_student);
+          wordData.teacherS = JSON.parse(data.course_teacher);
+          wordData.brief = data.brief;
+          wordData.introduce = JSON.parse(data.chapters);
+          wordData.fund = JSON.parse(data.money);
+          wordData.dp = data.className;
 
+          this.downWordData = wordData;
 
-                  console.log(this.downWordData);
-              },err=>{
-                  console.log(err);
-              })
-          },
+          console.log(this.downWordData);
         },
-        computed:{   //经费总合
-          reversedMessage: function () {
-            let num = 0;
-            for(let i in this.downWordData.fund)num+=Number(this.downWordData.fund[i]);
-            return num;
-          }
-        },
-        mounted(){
-          this.getData();
+        (err) => {
+          console.log(err);
         }
-      };
-    </script>
+      );
+    },
+  },
+  computed: {
+    //经费总合
+    reversedMessage: function () {
+      let num = 0;
+      for (let i in this.downWordData.fund)
+        num += Number(this.downWordData.fund[i]);
+      return num;
+    },
+  },
+  mounted() {
+    this.getData();
+  },
+};
+</script>
       
     <style lang="less" scoped>
-    #studentProjectWord{
-        width: 100%;
-        display: flex;
-        flex-direction: column;
-        align-items: center;
-        background-color: #ffff;
-        margin: 0;
-        padding: 40px 100px;
-        box-sizing:border-box;
-        #title{
-            width: 100%;
-            position: absolute;
-            top: -170px;
-            .school{
-              text-align: center;
-                width: 100%;
-                font-size: 2.5em;
-                font-weight: bold;
-                letter-spacing: 20px;
-            }
-            .wordTitle{
-              text-align: center;
-                width: 100%;
-                font-size: 2em;
-                letter-spacing: .15em;
-                margin-bottom:40px ;
-            }
-            .date{
-                width: 90%;
-                text-align: right;
-                font-size: 1em;
-                font-weight: bold;
-            }
+#studentProjectWord {
+  width: 100%;
+  display: flex;
+  flex-direction: column;
+  align-items: center;
+  background-color: #ffff;
+  margin: 0;
+  padding: 40px 100px;
+  box-sizing: border-box;
+  #title {
+    width: 100%;
+    position: absolute;
+    top: -170px;
+    .school {
+      text-align: center;
+      width: 100%;
+      font-size: 2.5em;
+      font-weight: bold;
+      letter-spacing: 20px;
+    }
+    .wordTitle {
+      text-align: center;
+      width: 100%;
+      font-size: 2em;
+      letter-spacing: 0.15em;
+      margin-bottom: 40px;
+    }
+    .date {
+      width: 90%;
+      text-align: right;
+      font-size: 1em;
+      font-weight: bold;
+    }
+  }
+  .table {
+    border: none;
+    width: 1200px;
+    border-top: solid 1px black;
+    border-right: solid 1px black;
+    border-left: solid 1px black;
+    position: relative;
+    margin-top: 180px;
+    margin-bottom: 100px;
+    .textLeft {
+      text-align: left;
+      vertical-align: top;
+      position: relative;
+      max-width: 100%;
+      height: 200px;
+      // white-space: nowrap;
+      span {
+        // white-space: nowrap;
+        word-wrap: break-word;
+        word-break: break-all;
+      }
+      :deep(.el-textarea__inner) {
+        border: none;
+        border-radius: 0px;
+        text-align: left !important;
+        font-size: 16px;
+      }
+    }
+    tr {
+      position: relative;
+      td {
+        border: none;
+        border-bottom: solid 1px black;
+        border-right: solid 1px black;
+        height: 50px;
+        text-align: center;
+        line-height: 30px;
+        width: 70px;
+        box-sizing: border-box;
+        padding: 5px;
+        p {
+          font-weight: 600;
         }
-        .table{
-            border: none;
-            width: 1200px;
-            border-top: solid 1px black;
-            border-right:  solid 1px black;
-            border-left:  solid 1px black;
-            position: relative;
-            margin-top: 180px;
-            margin-bottom: 100px;
-            .textLeft{
-              text-align: left ;
-              vertical-align: top;
-              position: relative;
-              max-width:100% ;
-              height: 200px;
-              // white-space: nowrap;
-              span{
-                // white-space: nowrap;
-                word-wrap: break-word;
-                word-break: break-all;
-              }
-              :deep(.el-textarea__inner){
-                border: none ;
-                border-radius: 0px;
-                text-align: left !important;
-                font-size: 16px;
-              }
-            }
-            tr{
-              position: relative;
-              td{
-                border: none;
-                border-bottom: solid 1px black;
-                border-right: solid 1px black;
-                height: 50px;
-                text-align: center;
-                line-height: 30px;
-                width: 70px;
-                box-sizing: border-box;
-                padding: 5px;
-              p{
-                font-weight: 600;
-              }
-              :deep(.el-select .el-input .el-select__caret){
-                display: none;
-              }
-              :deep(.el-textarea__inner){
-                // padding: 0;
-                border: none ;
-                border-radius: 0px;
-                text-align: center;
-                font-size: 16px;
-              }
-              :deep(.el-input__inner){
-                border: none ;
-                border-radius: 0px;
-                text-align: center;
-                font-size: 16px;
-              }
-              :deep(input)::-webkit-outer-spin-button,
-              :deep(input)::-webkit-inner-spin-button {
-                -webkit-appearance: none;
-              }
-              :deep(input)[type="number"]{
-                  -moz-appearance: textfield;
-              }
-            }
-          }
-            
+        :deep(.el-select .el-input .el-select__caret) {
+          display: none;
         }
-        .notes{
-          position: absolute;
-          width: 100%;
-          display: flex;
-          flex-direction:column;
+        :deep(.el-textarea__inner) {
+          // padding: 0;
+          border: none;
+          border-radius: 0px;
+          text-align: center;
+          font-size: 16px;
         }
-        
-    }
-      .checkArea{
-        td{
-          span{
-          margin-left: 50px;
-          span{
-            margin: 0;
-          }
+        :deep(.el-input__inner) {
+          border: none;
+          border-radius: 0px;
+          text-align: center;
+          font-size: 16px;
         }
+        :deep(input)::-webkit-outer-spin-button,
+        :deep(input)::-webkit-inner-spin-button {
+          -webkit-appearance: none;
         }
-
+        :deep(input)[type="number"] {
+          -moz-appearance: textfield;
+        }
+      }
+    }
+  }
+  .notes {
+    position: absolute;
+    width: 100%;
+    display: flex;
+    flex-direction: column;
+  }
+}
+.checkArea {
+  td {
+    span {
+      margin-left: 50px;
+      span {
+        margin: 0;
       }
-    
-    </style>
+    }
+  }
+}
+</style>

Alguns arquivos não foram mostrados porque muitos arquivos mudaram nesse diff