lishihai
2024-07-03 52c7dec820e88e4e3466a03b0f68796805ebbe28
下载导入物料/产品模板
2个文件已修改
46 ■■■■■ 已修改文件
controllers/product_controller.go 45 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
router/router.go 1 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
controllers/product_controller.go
@@ -6,7 +6,9 @@
    "github.com/gin-gonic/gin"
    "github.com/shopspring/decimal"
    "github.com/spf13/cast"
    "github.com/xuri/excelize/v2"
    "gorm.io/gorm"
    "net/url"
    "strconv"
    "time"
    "wms/constvar"
@@ -20,6 +22,7 @@
    "wms/request"
    "wms/response"
    "wms/service"
    "wms/utils/http"
)
type ProductController struct {
@@ -1036,8 +1039,8 @@
// InputProduct
//
//    @Tags        物料管理
//    @Summary    导入物料
//    @Tags        产品
//    @Summary    导入物料/产品
//
// @Accept multipart/form-data
// @Param file formData file true "file"
@@ -1063,3 +1066,41 @@
    resp.InputCount = insertCount
    util.ResponseFormat(c, code.Success, resp)
}
// DownloadInputFormat
//
//    @Tags        产品
//    @Summary    下载导入物料/产品模板
//
// @Param     Authorization    header string true "token"
//
//    @Success    200        {object}    util.Response     "成功"
//    @Router        /api-wms/v1/product/downloadInputFormat [get]
func (slf ProductController) DownloadInputFormat(c *gin.Context) {
    template, err := models.NewFileTemplateAttachmentSearch().SetCategory(7).First() //物料导入模板
    if err != nil {
        util.ResponseFormat(c, code.NoTemplateError, "获取模版记录失败:"+err.Error())
        return
    }
    readerCloser, err := http.HttpGetWithReadCloser(template.FileUrl)
    if err != nil {
        util.ResponseFormat(c, code.NoTemplateError, "获取模版记录失败:"+err.Error())
        return
    }
    f, err := excelize.OpenReader(readerCloser)
    if err != nil {
        util.ResponseFormat(c, code.NoTemplateError, "获取模版记录失败:"+err.Error())
        return
    }
    fileContentDisposition := "attachment;filename=\"" + url.QueryEscape("物料导入.xlsx") + "\""
    c.Writer.Header().Add("Content-Disposition", fileContentDisposition)
    c.Writer.Header().Add("Content-Type", "application/octet-stream")
    //c.Writer.Header().Add("Content-Type", "application/xlsx")
    if err = f.Write(c.Writer); err != nil {
        util.ResponseFormat(c, code.NoTemplateError, "数据导出异常:"+err.Error())
        return
    }
    readerCloser.Close()
    util.ResponseFormat(c, code.Success, "")
}
router/router.go
@@ -122,6 +122,7 @@
        productAPI.POST("updateProduct", productController.UpdateProduct)                                   // 修改产品详情
        productAPI.DELETE("deleteProduct/:id", productController.DeleteProduct)                             // 通过ID获删除产品
        productAPI.DELETE("deleteProductByBarCode/:barCode", productController.DeleteProductByBarCode)      // 通过条形码删除产品
        productAPI.GET("downloadInputFormat", productController.DownloadInputFormat)                        // 下载导入物料模板
        productAPI.POST("addProductCategory", productController.AddProductCategory)                  //添加产品类型
        productAPI.POST("getProductCategoryList", productController.GetProductCategoryList)          //获取产品类型列表