liujt 11 часов назад
Родитель
Сommit
d7d92a54e9

+ 344 - 86
src/views/purchasingManage/purchaseOrder/returnGoods/components/print-template-ht.vue

@@ -1,88 +1,179 @@
 <template>
   <ele-modal
-    title="货单"
+    title="退货单"
     :visible.sync="QRvisible"
     v-if="QRvisible"
     width="90%"
   >
-    <div
-      id="printSection"
-      style="
-        display: flex;
-        align-items: center;
-        justify-content: center;
-        flex-direction: column;
-      "
-    >
-      <div>
+    <div id="printSection">
+      <div
+        style="
+          display: flex;
+          align-items: center;
+          justify-content: center;
+          flex-direction: column;
+        "
+      >
+        <div style="width: 100%;">
+          <div
+            style="
+              font-size: 20px;
+              font-weight: 800;
+              padding-right: 20px;
+              width: 400px;
+              margin: 0 auto;
+            "
+          >
+            {{ companyInfo?.name }}退货单
+          </div>
+        </div>
         <div
           style="
-            font-size: 20px;
-            font-weight: 800;
-            padding-right: 20px;
-            width: 400px;
-            margin: 0 auto;
+            width: 100%;
+            font-size: 13px;
+            display: flex;
+            justify-content: space-between;
+            margin-bottom: 10px;
+            margin-top: 20px;
+          "
+        >
+          <span style="width: 50%">供应商:{{ formData.supplierName }}</span>
+          <span style="width: 50%">单据日期:{{ formData.createTime ? formData.createTime.split(' ')[0] : '' }}</span>
+        </div>
+        <div
+          style="
+            width: 100%;
+            font-size: 13px;
+            display: flex;
+            justify-content: space-between;
+            margin-bottom: 10px;
+          "
+        >
+          <span style="width: 50%">收货单号:{{ formData.receiveNo }}</span>
+          <span style="width: 50%">退货单号:{{ formData.returnNo }}</span>
+        </div>
+        <table
+          cellspacing="0"
+          border
+          style="
+            width: 100%;
+            table-layout: fixed;
+            word-break: break-all;
+            word-wrap: break-word;
+            font-size: 12px;
           "
-          >{{ companyInfo?.name }}到货退厂单</div
         >
-      </div>
-      <!-- 表头信息 -->
-      <div style="width: 100%; margin-bottom: 10px; margin-top: 20px;">
-        <table cellspacing="0" style="width: 100%; font-size: 12px;">
           <tbody>
-            <tr>
-              <td style="text-align: right; padding: 3px;">供应商:</td>
-              <td style="padding: 3px; width: 150px;">{{ formData.supplierName || '' }}</td>
-              <td style="text-align: right; padding: 3px;">单据日期:</td>
-              <td style="padding: 3px; width: 150px;">{{ formData.createTime || '' }}</td>
-              <td style="text-align: right; padding: 3px;">单据编号:</td>
-              <td style="padding: 3px;">{{ formData.returnNo }}</td>
+            <tr align="center">
+              <td style="padding: 2px; width: 5%"> 序号 </td>
+              <td style="padding: 2px; width: 17%"> 名称 </td>
+              <td style="padding: 2px; width: 18%"> 型号 </td>
+              <td style="padding: 2px; width: 6%"> 单位</td>
+              <td style="padding: 2px; width: 8%"> 数量</td>
+              <td style="padding: 2px; width: 10%"> 单价</td>
+              <td style="padding: 2px; width: 8%"> 税率</td>
+              <td style="padding: 2px; width: 8%"> 金额</td>
+              <td style="padding: 2px; width: 8%"> 颜色 </td>
+              <td style="padding: 2px; width: 10%"> 备注</td>
+            </tr>
+
+            <tr align="center" v-for="(item, index) in formData.productList" :key="item.id">
+              <td style="padding: 2px"> {{ index + 1 }} </td>
+              <td style="padding: 2px"> {{ item.productName }} </td>
+              <td style="padding: 2px">
+                <!-- {{ item.specification }}/ -->
+                {{ item.modelType }}
+              </td>
+              <td style="padding: 2px"> {{ item.measuringUnit }}</td>
+              <td style="padding: 2px"> {{ item.totalCount ? '-' + item.totalCount : ''  }}</td>
+              <td style="padding: 2px"> {{ item.singlePrice }}</td>
+              <td style="padding: 2px"> {{ item.taxRate }}{{ item.taxRate ? '%' : '0%' }}</td>
+              <td style="padding: 2px"> {{ item.totalPrice? '-' + item.totalPrice : ''}}</td>
+              <td style="padding: 2px"> {{ item.colorKey }}</td>
+              <!-- <td style="padding: 5px"> {{ item.modelKey }}</td> -->
+              <td style="padding: 2px"> {{ item.remark }}</td>
+            </tr>
+            <tr align="center">
+              <td style="padding: 2px"> 合计 </td>
+              <td style="padding: 2px" colspan="2">{{ numberToChinese(getTotalValue(formData, 'totalPrice', 2)) }}</td>
+              <td style="padding: 2px"> </td>
+              <td style="padding: 2px">{{ getTotalValue(formData, 'totalCount', 2) ? '-' + getTotalValue(formData, 'totalCount', 2) : '' }} </td>
+              <td style="padding: 2px"> </td>
+              <td style="padding: 2px"> </td>
+              <td style="padding: 2px">{{ getTotalValue(formData, 'totalCount', 2) ? '-' + getTotalValue(formData, 'totalPrice', 2) : ''}}</td>
+              <td style="padding: 2px"> </td>
+              <td style="padding: 2px"> </td>
+              <!-- <td style="padding: 2px"> </td> -->
+              <!-- <td style="padding: 2px"> </td> -->
             </tr>
           </tbody>
         </table>
-      </div>
-      <table
-        cellspacing="0"
-        border
-        style="
-          width: 100%;
-          table-layout: fixed;
-          word-break: break-all;
-          word-wrap: break-word;
-          font-size: 12px;
-        "
-      >
-        <tbody>
-          <tr align="center">
-            <td style="padding: 5px; width: 100px"> 物料编码 </td>
-            <td style="padding: 5px"> 物料名称 </td>
-            <td style="padding: 5px"> 厂家批号/灭菌批号 </td>
-            <td style="padding: 5px;"> 物料批号 </td>
-            <td style="padding: 5px;"> 规格型号 </td>
-            <td style="padding: 5px;"> 单位 </td>
-            <td style="padding: 5px;"> 数量 </td>
-          </tr>
-
-          <tr align="center" v-for="(item, index) in formData.productList">
-            <td style="padding: 5px"> {{ item.productCode || '' }} </td>
-            <td style="padding: 5px"> {{ item.productName }} </td>
-            <td style="padding: 5px">  </td>
-            <td style="padding: 5px"> {{ item.batchNo || '' }}</td>
-            <td style="padding: 5px"> {{ item.specification }}/{{ item.modelType }}</td>
-            <td style="padding: 5px"> {{ item.measuringUnit }}</td>
-            <td style="padding: 5px"> {{ item.totalCount }} </td>
-          </tr>
-        </tbody>
-      </table>
-      <!-- 联系信息 -->
-      <div style="width: 100%; margin-top: 10px; font-size: 12px; display: flex; align-items: center;">
-        <div style="width: 33%;">制单:{{ formData.makerName }}</div>
-        <div style="width: 33%;">审核人:{{ formData.reviewerName }}</div>
-        <div style="width: 33%;">收货人:{{ formData.linkName }}</div>
+        <div
+          style="
+            width: 100%;
+            font-size: 13px;
+            display: flex;
+            justify-content: space-between;
+            margin-top: 10px;
+          "
+        >
+          <div style="flex: 1">
+            <div>业务员:{{ this.formData.salesmanName }}</div>
+          </div>
+          <div style="flex: 1">
+            <div>制单人:{{ this.formData.makerName }}</div>
+          </div>
+          <div style="flex: 1"> 核对人: {{ this.formData.reviewerName }}</div>
+          <div style="flex: 1"> 收货人: </div>
+        </div>
+        <div
+          style="
+            width: 100%;
+            font-size: 13px;
+            display: flex;
+            justify-content: space-between;
+            margin-top: 10px;
+          "
+        >
+          <!-- <div style="flex: 1">
+            <div>地址:{{ wrapperItem.partbAddress }}</div>
+          </div> -->
+          <div style="flex: 1">
+            <div>供应商签字:</div>
+          </div>
+        </div>
+        <!-- <div
+          style="
+            width: 100%;
+            font-size: 13px;
+            display: flex;
+            justify-content: space-between;
+            margin-top: 10px;
+          "
+        >
+          <div style="flex: 1">
+            <div>制单人:{{ formData.makerName }}</div>
+          </div>
+          <div style="flex: 1"> 核对人:{{ formData.reviewerName }}</div>
+        </div> -->
+        <div
+          style="
+            width: 100%;
+            font-size: 13px;
+            display: flex;
+            justify-content: space-between;
+            margin-top: 10px;
+          "
+        >
+          <div style="flex: 1">
+            <div>备注:{{ formData.remark }}</div>
+          </div>
+        </div>
       </div>
     </div>
 
     <div slot="footer">
+      <el-button type="primary" @click="exportExcel">导出</el-button>
       <el-button @click="print">打印预览</el-button>
       <el-button @click="close">关闭</el-button>
     </div>
@@ -92,7 +183,7 @@
 <script>
   import { getReturnSaleOrderrecordDetail } from '@/api/purchasingManage/returnGoods';
   import { mapGetters } from 'vuex';
-  import { convertToChinese as numToChinese } from '@/utils/util';
+  import { saveAs } from 'file-saver';
   export default {
     name: 'print',
     computed: {
@@ -106,37 +197,43 @@
       return {
         checked: '',
         QRvisible: false,
-        formData: {}
+        isPrintPrice: false,
+        formData: {
+          contactName: '',
+          createTime: '',
+          docNo: '',
+          partbAddress: '',
+          partbLinkName: '',
+          productList: [],
+          totalCount: 0
+        }
       };
     },
 
     methods: {
       async open(id) {
-        console.log('this.companyInfo',this.companyInfo)
         this.formData = await getReturnSaleOrderrecordDetail(id);
+        console.log('formData~~~', this.formData);
         this.QRvisible = true;
+
         //包装维度
       },
       close() {
         this.QRvisible = false;
       },
-      getTotalValue(key, num) {
-          let val = this.formData?.productList?.reduce((total, item) => {
-            return (total += Number(item[key] || 0));
-          }, 0);
+      getTotalValue(itemI,key, num) {
+        let val = itemI?.productList?.reduce((total, item) => {
+          return (total += Number(item[key]));
+        }, 0);
 
-          return (
-            (val &&
-              parseFloat(val)
-                .toFixed(num)
-                .replace(/\.?0+$/, '')) ||
-            0
-          );
-        },
-        // 将导入的函数添加到methods中,使其在模板中可用
-        convertToChinese(num) {
-          return numToChinese(num);
-        },
+        return (
+          (val &&
+            parseFloat(val)
+              .toFixed(num)
+              .replace(/\.?0+$/, '')) ||
+          0
+        );
+      },
       print() {
         const printSection = document.getElementById('printSection');
         // 创建打印任务
@@ -153,6 +250,167 @@
         printWindow.onload = function () {
           printWindow.print();
         };
+      },
+      numberToChinese(n) {
+        const num = Number(n);
+        if (!isFinite(num)) return '';
+        if (num === 0) return '零元整';
+        const digits = ['零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖'];
+        const intUnits = ['', '拾', '佰', '仟', '万', '拾', '佰', '仟', '亿', '拾', '佰', '仟'];
+        const decUnits = ['角', '分'];
+        const negative = num < 0 ? '负' : '';
+        const fixed = Math.abs(num).toFixed(2);
+        const [intPart, decPart] = fixed.split('.');
+        let intStr = '';
+        const intLen = intPart.length;
+        for (let i = 0; i < intLen; i++) {
+          const d = Number(intPart[i]);
+          const unit = intUnits[intLen - 1 - i];
+          if (d === 0) {
+            if (unit === '万' || unit === '亿') {
+              intStr = intStr.replace(/零+$/, '') + unit;
+            } else {
+              intStr += '零';
+            }
+          } else {
+            intStr += digits[d] + unit;
+          }
+        }
+        intStr = intStr.replace(/零+/g, '零').replace(/零+$/, '');
+        intStr = intStr.replace(/亿万/, '亿') || intStr;
+        intStr = (intStr || '零') + '元';
+        let decStr = '';
+        const jiao = Number(decPart[0]);
+        const fen = Number(decPart[1]);
+        if (jiao === 0 && fen === 0) {
+          decStr = '整';
+        } else {
+          if (jiao === 0) decStr = '零';
+          else decStr = digits[jiao] + decUnits[0];
+          if (fen !== 0) decStr += digits[fen] + decUnits[1];
+        }
+        return negative + intStr + decStr;
+      },
+      exportExcel() {
+        const list = this.formData.productList || [];
+        const totalCount = this.getTotalValue(this.formData, 'totalCount', 2);
+        const totalPrice = this.getTotalValue(this.formData, 'totalPrice', 2);
+        const totalChinese = this.numberToChinese(totalPrice);
+
+        const border =
+          'border-top:1px solid #000;border-right:1px solid #000;border-bottom:1px solid #000;border-left:1px solid #000;';
+        const cellBase = `${border}padding:4px;mso-number-format:"\\@";vertical-align:middle;text-align:center;mso-horizontal-align:center;`;
+        const th = `${cellBase}font-weight:bold;font-family:'宋体';font-size:12pt;`;
+        const td = `${cellBase}font-family:'宋体';font-size:11pt;`;
+        const labelLeft = `${border}padding:4px;mso-number-format:"\\@";vertical-align:middle;text-align:left;mso-horizontal-align:left;font-family:'宋体';font-size:11pt;`;
+
+        const colWidths = [55, 170, 170, 55, 70, 75, 65, 90, 70, 110];
+        const colGroup = colWidths
+          .map((w) => `<col width="${w}" style="width:${w}pt;" />`)
+          .join('');
+
+        const title = `${this.groupName || ''}退货单`;
+
+        const rows = list
+          .map(
+            (item, index) => `
+              <tr height="24" style="height:24pt;">
+                <td align="center" valign="middle" style="${td}">${index + 1}</td>
+                <td align="center" valign="middle" style="${td}">${item.productName || ''}</td>
+                <td align="center" valign="middle" style="${td}">${item.modelType || ''}</td>
+                <td align="center" valign="middle" style="${td}">${item.measuringUnit || ''}</td>
+                <td align="center" valign="middle" style="${td}">${item.totalCount ?? ''}</td>
+                <td align="center" valign="middle" style="${td}">${item.singlePrice ?? ''}</td>
+                <td align="center" valign="middle" style="${td}">${
+              item.taxRate ? item.taxRate + '%' : '0%'
+            }</td>
+                <td align="center" valign="middle" style="${td}">${item.totalPrice ?? ''}</td>
+                <td align="center" valign="middle" style="${td}">${item.colorKey || ''}</td>
+                <td align="center" valign="middle" style="${td}">${item.remark || ''}</td>
+              </tr>`
+          )
+          .join('');
+
+        const table = `
+          <table border="1" cellspacing="0" cellpadding="0" align="center"
+            style="border-collapse:collapse;border:1px solid #000;mso-border-alt:solid #000 0.5pt;font-family:'宋体';font-size:11pt;text-align:center;">
+            <colgroup>${colGroup}</colgroup>
+            <tr height="40" style="height:40pt;">
+              <td colspan="9" align="center" valign="middle" style="${border}padding:6px;text-align:center;font-family:'宋体';font-size:22pt;font-weight:bold;">${title}</td>
+            </tr>
+            <tr height="26" style="height:26pt;">
+              <td colspan="6" align="left" valign="middle" style="${labelLeft}">供应商:${this.formData.supplierName || ''}</td>
+              <td colspan="3" align="left" valign="middle" style="${labelLeft}">单据日期:${this.formData.createTime ? this.formData.createTime.split(' ')[0] : ''}</td>
+            </tr>
+            <tr height="26" style="height:26pt;">
+              <td colspan="6" align="left" valign="middle" style="${labelLeft}">收货单号:${this.formData.receiveNo || ''}</td>
+              <td colspan="3" align="left" valign="middle" style="${labelLeft}">退货单号:${this.formData.returnNo || ''}</td>
+            </tr>
+
+            <tr height="28" style="height:28pt;">
+              <td align="center" valign="middle" style="${th}">序号</td>
+              <td align="center" valign="middle" style="${th}">名称</td>
+              <td align="center" valign="middle" style="${th}">型号</td>
+              <td align="center" valign="middle" style="${th}">单位</td>
+              <td align="center" valign="middle" style="${th}">数量</td>
+              <td align="center" valign="middle" style="${th}">单价</td>
+              <td align="center" valign="middle" style="${th}">税率</td>
+              <td align="center" valign="middle" style="${th}">金额</td>
+              <td align="center" valign="middle" style="${th}">颜色</td>
+              <td align="center" valign="middle" style="${th}">备注</td>
+            </tr>
+            ${rows}
+            <tr height="26" style="height:26pt;">
+              <td align="center" valign="middle" style="${td};font-weight:bold;">合计</td>
+              <td colspan="2" align="center" valign="middle" style="${td};font-weight:bold;">${totalChinese}</td>
+              <td align="center" valign="middle" style="${td}"></td>
+              <td align="center" valign="middle" style="${td};font-weight:bold;">${totalCount}</td>
+              <td align="center" valign="middle" style="${td}"></td>
+              <td align="center" valign="middle" style="${td}"></td>
+              <td align="center" valign="middle" style="${td};font-weight:bold;">${totalPrice}</td>
+              <td align="center" valign="middle" style="${td}"></td>
+              <td align="center" valign="middle" style="${td}"></td>
+            </tr>
+            <tr height="28" style="height:28pt;">
+              <td colspan="3" align="left" valign="middle" style="${labelLeft}">业务员:${this.formData.salesmanName || ''}</td>
+              <td colspan="2" align="left" valign="middle" style="${labelLeft}">制单人:${this.formData.makerName || ''}</td>
+              <td colspan="2" align="left" valign="middle" style="${labelLeft}">核对人:${this.formData.reviewerName || ''}</td>
+              <td colspan="3" align="left" valign="middle" style="${labelLeft}">发货人:</td>
+            </tr>
+            <tr height="28" style="height:28pt;">
+              <td colspan="10" align="left" valign="middle" style="${labelLeft}">供应商签字:</td>
+            </tr>
+            <tr height="28" style="height:28pt;">
+              <td colspan="10" align="left" valign="middle" style="${labelLeft}">备注:${this.formData.remark || ''}</td>
+            </tr>
+          </table>`;
+
+        const html = `<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:x="urn:schemas-microsoft-com:office:excel" xmlns="http://www.w3.org/TR/REC-html40">
+        <head>
+        <meta charset="UTF-8" />
+        <style>
+          br { mso-data-placement: same-cell; }
+          table { mso-displayed-decimal-separator:"."; mso-displayed-thousand-separator:","; }
+          td { mso-ignore:padding; }
+        </style>
+        <!--[if gte mso 9]><xml>
+        <x:ExcelWorkbook><x:ExcelWorksheets><x:ExcelWorksheet>
+        <x:Name>${title}</x:Name>
+        <x:WorksheetOptions>
+          <x:DefaultRowHeight>260</x:DefaultRowHeight>
+          <x:Print><x:ValidPrinterInfo/><x:HorizontalResolution>600</x:HorizontalResolution><x:VerticalResolution>600</x:VerticalResolution></x:Print>
+          <x:Selected/>
+          <x:DoNotDisplayGridlines/>
+        </x:WorksheetOptions>
+        </x:ExcelWorksheet></x:ExcelWorksheets></x:ExcelWorkbook>
+        </xml><![endif]-->
+        </head>
+        <body>${table}</body></html>`;
+
+        const blob = new Blob(['' + html], {
+          type: 'application/vnd.ms-excel;charset=utf-8'
+        });
+        saveAs(blob, `${title}_${this.formData.returnNo || ''}.xls`);
       }
     }
   };

+ 18 - 2
src/views/purchasingManage/purchaseOrder/returnGoods/index.vue

@@ -43,13 +43,23 @@
             <el-button
               size="small"
               type="primary"
-              icon="el-icon-print"
+              icon="el-icon-printer"
               class="ele-btn-icon"
               v-if="$hasPermission('eom:purchaseorderreturn:print')"
               @click="handlePrint('printTemplateTrRef')"
             >
               打印
             </el-button>
+            <el-button
+              size="small"
+              type="primary"
+              icon="el-icon-printer"
+              class="ele-btn-icon"
+              v-if="$hasPermission('eom:purchaseorderreturn:printHt')"
+              @click="handlePrint('printTemplateHtRef')"
+            >
+              打印
+            </el-button>
           </template>
 
           <!-- 查看详情列 -->
@@ -154,6 +164,10 @@
       ref="printTemplateTrRef"
       :companyInfo="companyInfo"
     ></printTemplateTr>
+    <printTemplateHt
+      ref="printTemplateHtRef"
+      :companyInfo="companyInfo"
+    ></printTemplateHt>
   </div>
 </template>
 
@@ -175,6 +189,7 @@
   import processSubmitDialog from '@/BIZComponents/processSubmitDialog/processSubmitDialog.vue';
   import tabMixins from '@/mixins/tableColumnsMixin';
   import printTemplateTr from './components/print-template-tr.vue';
+  import printTemplateHt from './components/print-template-ht.vue';
   import { enterprisePage } from '@/api/contractManage/contractBook';
 
   export default {
@@ -187,7 +202,8 @@
       popModal,
       addReturnGoodsDialog,
       detailDialog,
-      printTemplateTr
+      printTemplateTr,
+      printTemplateHt
     },
     data() {
       return {