diff options
-rw-r--r-- | invoice/controller.go | 13 | ||||
-rw-r--r-- | invoice/service.go | 10 | ||||
-rw-r--r-- | main.go | 2 |
3 files changed, 24 insertions, 1 deletions
diff --git a/invoice/controller.go b/invoice/controller.go index 02bbaf5..7260834 100644 --- a/invoice/controller.go +++ b/invoice/controller.go @@ -101,6 +101,19 @@ func handleSaveInvoice (ctx *gin.Context) { userId := uId.(uint) invoice.UserID = userId + // if invoice number is 0, generate one! + if invoice.InvoiceNumber == 0 { + n, err := getNewInvoiceNumber(invoice.UserID) + + if err != nil { + ctx.Error(err) + ctx.Abort() + return + } + + invoice.InvoiceNumber = n + } + err := invoice.upsert() if err != nil { ctx.Error(err) diff --git a/invoice/service.go b/invoice/service.go index 099f6a0..3dcc5e2 100644 --- a/invoice/service.go +++ b/invoice/service.go @@ -21,6 +21,16 @@ import ( e "vidhukant.com/openbills/errors" ) +// returns greatest invoice number + 1 +func getNewInvoiceNumber(userId uint) (uint, error) { + var i uint + + row := db.Model(&Invoice{}).Where("user_id = ?", userId).Select("max(invoice_number)").Row() + err := row.Scan(&i) + + return i + 1, err +} + func getInvoice(invoice *Invoice, id uint) error { res := db.Preload("BillingAddress").Preload("ShippingAddress").Preload("Items").Find(&invoice, id) @@ -38,7 +38,7 @@ import ( "log" ) -const OPENBILLS_VERSION = "v0.1.0" +const OPENBILLS_VERSION = "v0.2.0" func init() { if !viper.GetBool("debug_mode") { |