pg_order_good_dao.go 3.8 KB
package dao

import (
	"fmt"
	pgTransaction "github.com/linmadan/egglib-go/transaction/pg"
	"gitlab.fjmaimaimai.com/allied-creation/allied-creation-cooperation/pkg/domain"
	"gitlab.fjmaimaimai.com/allied-creation/allied-creation-cooperation/pkg/infrastructure/pg/models"
)

type OrderGoodDao struct {
	transactionContext *pgTransaction.TransactionContext
}

// CooperationGoodsStatistics  共创产品统计数据
//
// queryOptions 查询参数
// 	- beginTime 开始时间
// 	- endTime 结束时间
// 	- companyId 企业Id
// 	- orgId     组织Id
func (dao *OrderGoodDao) CooperationGoodsStatistics(queryOptions map[string]interface{}) ([]*domain.CooperationGoodsStatisticsDto, error) {
	tx := dao.transactionContext.PgTx
	var goods []*domain.CooperationGoodsStatisticsDto
	var queryTime, queryLimit string
	if _, ok := queryOptions["beginTime"]; ok {
		queryTime = fmt.Sprintf("and created_at>='%v' and created_at<'%v'", queryOptions["beginTime"], queryOptions["endTime"])
	}
	if _, ok := queryOptions["limit"]; ok {
		queryLimit = fmt.Sprintf("limit %v", queryOptions["limit"])
	}
	sql := fmt.Sprintf(`select order_good_name good_name,sum(order_good_amount) good_amount from order_goods 
where company_id=? and org_id = ? and deleted_at is null %v
GROUP BY order_good_name
order by good_amount desc
%v 
`, queryTime, queryLimit)
	_, err := tx.Query(&goods, sql, queryOptions["companyId"], queryOptions["orgId"])
	return goods, err
}

// CooperationCompanyModeStatistics  共创模式统计
//
// queryOptions 查询参数
// 	- companyId 企业Id
// 	- orgId     组织Id
func (dao *OrderGoodDao) CooperationCompanyModeStatistics(queryOptions map[string]interface{}) ([]*domain.CooperationModeStatisticsDto, error) {
	tx := dao.transactionContext.PgTx
	var goods []*domain.CooperationModeStatisticsDto
	sql := fmt.Sprintf(`select count(0) cooperation_people,sum(a.actually_paid_amount) dividends_estimate,b.cooperation_mode_number,sum(good_amount_count) order_amount
from credit_accounts a inner join cooperation_contracts b on a.cooperation_contract_number = b.cooperation_contract_number
where a.company->>'companyId' = '?' and a.org->>'orgId' = '?' and a.deleted_at is null and b.status = 1
group by b.cooperation_mode_number
`)
	_, err := tx.Query(&goods, sql, queryOptions["companyId"], queryOptions["orgId"])
	return goods, err
}

// 共创用户模式统计
func (dao *OrderGoodDao) CooperationUserModeStatistics(queryOptions map[string]interface{}) ([]*domain.CooperationModeStatisticsDto, error) {
	tx := dao.transactionContext.PgTx
	var goods []*domain.CooperationModeStatisticsDto
	creditAccount := new(models.CreditAccount)
	query := tx.Model(creditAccount)
	query.ColumnExpr("count(0) cooperation_people")
	query.ColumnExpr("sum(actually_paid_amount) dividends_estimate")
	query.ColumnExpr("sum(good_amount_count) order_amount")
	query.ColumnExpr("sum(actually_paid_amount) settlement_amount")
	query.ColumnExpr("a.cooperation_mode_number cooperation_mode_number")
	query.Join("inner join cooperation_contracts as a").JoinOn("a.cooperation_contract_number = credit_account.cooperation_contract_number")
	if v, ok := queryOptions["userId"]; ok && v.(int64) > 0 {
		query.Where(fmt.Sprintf(`credit_account.participator->>'userId'='%v' `, v))
	}
	if v, ok := queryOptions["orgId"]; ok && v.(int64) > 0 {
		query.Where(fmt.Sprintf(` "credit_account".org->>'orgId'= '%v'`, v))
		query.Where(fmt.Sprintf(` a.org->>'orgId'= '%v'`, v))
	}
	query.Where("credit_account.deleted_at is null")
	query.Group("cooperation_mode_number")
	err := query.Select(&goods)
	return goods, err
}

func NewOrderGoodDao(transactionContext *pgTransaction.TransactionContext) (*OrderGoodDao, error) {
	if transactionContext == nil {
		return nil, fmt.Errorf("transactionContext参数不能为nil")
	} else {
		return &OrderGoodDao{
			transactionContext: transactionContext,
		}, nil
	}
}