| | |
| | | } |
| | | |
| | | var fileUrl string |
| | | companyName := conf.WebConf.CompanyName |
| | | if companyName == "" { |
| | | util.ResponseFormat(c, code.RequestParamError, "缺少工厂名称配置") |
| | | return |
| | | } |
| | | if operation.BaseOperationType == constvar.BaseOperationTypeIncoming { |
| | | if conf.WebConf.CompanyName == "jialian" { |
| | | fileUrl, err = JialianInputOperation(operation) |
| | | if companyName == "jialian" { |
| | | fileUrl, err = JialianOperation(constvar.FileTemplateCategory_JialianInput, operation) |
| | | if err != nil { |
| | | util.ResponseFormat(c, code.RequestParamError, err.Error()) |
| | | return |
| | | } |
| | | } else { |
| | | } else if companyName == "geruimi" { |
| | | fileUrl, err = ExportInputSelfmade(constvar.FileTemplateCategory_Selfmade, operation) |
| | | if err != nil { |
| | | util.ResponseFormat(c, code.RequestParamError, err.Error()) |
| | |
| | | } |
| | | } |
| | | } else if operation.BaseOperationType == constvar.BaseOperationTypeOutgoing { |
| | | fileUrl, err = ExportOutputOperation(constvar.FileTemplateCategory_Output, operation) |
| | | if err != nil { |
| | | util.ResponseFormat(c, code.RequestParamError, err.Error()) |
| | | return |
| | | if companyName == "jialian" { |
| | | fileUrl, err = JialianOperation(constvar.FileTemplateCategory_JialianOutput, operation) |
| | | if err != nil { |
| | | util.ResponseFormat(c, code.RequestParamError, err.Error()) |
| | | return |
| | | } |
| | | } else if companyName == "geruimi" { |
| | | fileUrl, err = ExportInputSelfmade(constvar.FileTemplateCategory_Output, operation) |
| | | if err != nil { |
| | | util.ResponseFormat(c, code.RequestParamError, err.Error()) |
| | | return |
| | | } |
| | | } |
| | | } else { |
| | | util.ResponseFormat(c, code.RequestParamError, "该记录不支持打印") |
| | | return |
| | | } |
| | | |
| | | util.ResponseFormat(c, code.Success, fileUrl) |
| | | m := make(map[string]string) |
| | | m["url"] = fileUrl |
| | | m["name"] = companyName |
| | | util.ResponseFormat(c, code.Success, m) |
| | | } |
| | | |
| | | func JialianInputOperation(operation *models.Operation) (string, error) { |
| | | template, err := models.NewFileTemplateAttachmentSearch().SetCategory(14).First() |
| | | func JialianOperation(category constvar.FileTemplateCategory, operation *models.Operation) (string, error) { |
| | | template, err := models.NewFileTemplateAttachmentSearch().SetCategory(category).First() |
| | | if err != nil { |
| | | return "", errors.New("获取模版记录失败:" + err.Error()) |
| | | } |
| | |
| | | |
| | | rowIndex := 5 |
| | | totalAmount := decimal.NewFromInt(0) |
| | | //totalPrice := decimal.NewFromInt(0) |
| | | totalPrice := decimal.NewFromInt(0) |
| | | for i, v := range operation.Details { |
| | | //设置表单最多9条数据 |
| | | if i > 8 { |
| | |
| | | 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() |
| | | f.SetCellValue("Sheet1", "E"+strconv.Itoa(rowIndex), v.Product.SalePrice.String()) |
| | | if !v.Product.SalePrice.IsZero() { |
| | | ap := v.Amount.Mul(v.Product.SalePrice) |
| | | totalPrice = totalPrice.Add(ap) |
| | | price := ap.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 |
| | |
| | | totalAmount = totalAmount.Add(v.Amount) |
| | | } |
| | | //合计 |
| | | //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) |
| | | if !totalPrice.IsZero() { |
| | | price := 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)) |
| | | } |
| | | } else { |
| | | f.SetCellValue("Sheet1", "M14", "0") |
| | | f.SetCellValue("Sheet1", "N14", "0") |
| | | } |
| | | 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", "B15", operation.Manager) |
| | | f.SetCellValue("Sheet1", "D15", operation.Accountant) |