liujiandao
2024-04-17 c6e4c58288053493fe62c9a390dfdf8cf1bedf98
controllers/operation.go
@@ -916,12 +916,12 @@
   readerCloser.Close()
   defer f.Close()
   f.SetCellValue("Sheet1", "C2", operation.CompanyName)
   f.SetCellValue("Sheet1", "H2", operation.OperationDate)
   f.SetCellValue("Sheet1", "O2", operation.Number)
   rowIndex := 5
   totalAmount := decimal.NewFromInt(0)
   //totalPrice := decimal.NewFromInt(0)
   for i, v := range operation.Details {
      //设置表单最多9条数据
      if i > 8 {
@@ -931,10 +931,57 @@
      f.SetCellValue("Sheet1", "B"+strconv.Itoa(rowIndex), v.Product.Type)
      f.SetCellValue("Sheet1", "C"+strconv.Itoa(rowIndex), v.Product.Unit)
      f.SetCellValue("Sheet1", "D"+strconv.Itoa(rowIndex), v.Amount.String())
      f.SetCellValue("Sheet1", "E"+strconv.Itoa(rowIndex), v.Product.PurchasePrice.String())
      if !v.Product.PurchasePrice.IsZero() {
         //totalPrice = totalPrice.Add(v.Product.PurchasePrice)
         price := v.Amount.Mul(v.Product.PurchasePrice).String()
         split := strings.Split(price, ".")
         if len(split) == 2 {
            for n, a := range split[1] {
               f.SetCellValue("Sheet1", string('M'+n)+strconv.Itoa(rowIndex), string(a))
            }
         } else {
            f.SetCellValue("Sheet1", "M"+strconv.Itoa(rowIndex), "0")
            f.SetCellValue("Sheet1", "N"+strconv.Itoa(rowIndex), "0")
         }
         s := split[0]
         n := 0
         for j := len(s) - 1; j >= 0; j-- {
            if n == 6 {
               f.SetCellValue("Sheet1", string('L'-n)+strconv.Itoa(rowIndex), s[:j])
               break
            }
            f.SetCellValue("Sheet1", string('L'-n)+strconv.Itoa(rowIndex), string(s[j]))
            n++
         }
      }
      rowIndex++
      totalAmount = totalAmount.Add(v.Amount)
   }
   f.SetCellValue("Sheet1", "D14", totalAmount)
   //合计
   //if !totalPrice.IsZero() {
   //   price := totalAmount.Mul(totalPrice).String()
   //   split := strings.Split(price, ".")
   //   if len(split) == 2 {
   //      for n, a := range split[1] {
   //         f.SetCellValue("Sheet1", string('M'+n)+"14", string(a))
   //      }
   //   }
   //   s := split[0]
   //   n := 0
   //   for j := len(s) - 1; j >= 0; j-- {
   //      if n == 6 {
   //         f.SetCellValue("Sheet1", string('L'-n)+"14", s[:j])
   //         break
   //      }
   //      f.SetCellValue("Sheet1", string('L'-n)+"14", string(s[j]))
   //      n++
   //   }
   //}
   //f.SetCellValue("Sheet1", "D14", totalAmount)
   //f.SetCellValue("Sheet1", "E14", totalPrice)
   f.SetCellValue("Sheet1", "B15", operation.Manager)
   f.SetCellValue("Sheet1", "D15", operation.Accountant)
   f.SetCellValue("Sheet1", "F15", operation.Custodian)