200 lines
6.4 KiB
Go
200 lines
6.4 KiB
Go
package repositories
|
|
|
|
import (
|
|
"fmt"
|
|
"nearle/models"
|
|
"strconv"
|
|
|
|
"gorm.io/gorm"
|
|
)
|
|
|
|
type PartnerRepository interface {
|
|
GetActiveRiders(partnerid, aid, uid, tid int) ([]models.RiderInfo, error)
|
|
GetPartners(aid, pid, uid int) ([]models.Partnerinfo, error)
|
|
GetRiderShifts(aid int) ([]models.Ridershifts, error)
|
|
GetLocationConfig(uid, cid int) ([]models.Locationconfigs, error)
|
|
GetRiderLogs(pid, aid int, fdate, tdate string) ([]models.RiderlogDetails, error)
|
|
GetRiderInfo(userid int) (models.RiderInfo, error)
|
|
}
|
|
|
|
type partnerRepository struct {
|
|
db *gorm.DB
|
|
}
|
|
|
|
func NewPartnerRepository(db *gorm.DB) PartnerRepository {
|
|
return &partnerRepository{db: db}
|
|
}
|
|
|
|
func (r *partnerRepository) GetActiveRiders(partnerid, aid, uid, tid int) ([]models.RiderInfo, error) {
|
|
var data []models.RiderInfo
|
|
var q1 string
|
|
|
|
const riders = `SELECT DISTINCT b.poolid, a.userid, a.firstname, a.lastname,CONCAT(a.firstname, ' ', a.lastname) AS fullname,a.contactno, a.userfcmtoken, a.partnerid, a.applocationid,
|
|
c.identificationno, c.registrationno, c.licenseno, c.vehiclename, c.vehicleno,d.shiftid, d.starttime, d.endtime, d.shifthours, d.basefare, d.fuelcharge,e.logdate,
|
|
e.login, e.logout, e.workhours, e.shorthours, e.logstatus, a.status,f.locationname AS applocation
|
|
FROM app_users a
|
|
INNER JOIN app_userpools b ON a.userid = b.userid
|
|
INNER JOIN ridersettings c ON a.userid = c.userid
|
|
INNER JOIN ridershifts d ON c.shiftid = d.shiftid
|
|
INNER JOIN (
|
|
SELECT r1.*
|
|
FROM riderlogs r1
|
|
INNER JOIN (
|
|
SELECT userid, MAX(logdate) AS max_logdate
|
|
FROM riderlogs
|
|
WHERE logdate::date = CURRENT_DATE
|
|
GROUP BY userid
|
|
) r2 ON r1.userid = r2.userid AND r1.logdate = r2.max_logdate
|
|
) e ON a.userid = e.userid
|
|
INNER JOIN app_location f ON a.applocationid = f.applocationid
|
|
INNER JOIN app_locationconfig g ON g.applocationid = f.applocationid`
|
|
|
|
if aid != 0 {
|
|
q1 = riders + ` WHERE a.configid = 6 AND a.status = 'Active' AND b.onduty = 1
|
|
AND e.logdate::date = CURRENT_DATE AND e.logstatus = 0 AND a.applocationid = ` + strconv.Itoa(aid)
|
|
} else if partnerid != 0 {
|
|
q1 = riders + ` WHERE a.configid = 6 AND a.status = 'Active' AND b.onduty = 1
|
|
AND e.logdate::date = CURRENT_DATE AND e.logstatus = 0 AND a.partnerid = ` + strconv.Itoa(partnerid)
|
|
} else if tid != 0 {
|
|
q1 = riders + ` WHERE a.configid = 6 AND a.status = 'Active' AND b.onduty = 1
|
|
AND e.logdate::date = CURRENT_DATE AND e.logstatus = 0 AND a.tenantid = ` + strconv.Itoa(tid)
|
|
} else {
|
|
q1 = riders + ` WHERE g.status = 'Active' AND a.configid = 6 AND a.status = 'Active'
|
|
AND b.onduty = 1 AND e.logdate::date = CURRENT_DATE AND e.logstatus = 0 AND g.userid = ` + strconv.Itoa(uid)
|
|
}
|
|
|
|
err := r.db.Raw(q1).Find(&data).Error
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return data, nil
|
|
}
|
|
|
|
func (r *partnerRepository) GetPartners(aid, pid, uid int) ([]models.Partnerinfo, error) {
|
|
var data []models.Partnerinfo
|
|
var q1 string
|
|
var args []interface{}
|
|
|
|
if pid != 0 {
|
|
q1 = `select partnerid,applocationid,partnertypeid,partnername,primarycontact,primaryemail,
|
|
contactno,address,suburb,state,city,partnerimage
|
|
from partnerinfo where status='Active' and partnerid=?`
|
|
args = append(args, pid)
|
|
|
|
} else if aid != 0 {
|
|
q1 = `select partnerid,applocationid,partnertypeid,partnername,primarycontact,primaryemail,
|
|
contactno,address,suburb,state,city,partnerimage
|
|
from partnerinfo where status='Active' and applocationid=?`
|
|
args = append(args, aid)
|
|
|
|
} else {
|
|
q1 = `select partnerid,applocationid,partnertypeid,partnername,primarycontact,primaryemail,
|
|
contactno,address,suburb,state,city,partnerimage
|
|
from partnerinfo where status='Active'`
|
|
}
|
|
|
|
err := r.db.Raw(q1, args...).Find(&data).Error
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
print(q1)
|
|
return data, nil
|
|
}
|
|
|
|
func (r *partnerRepository) GetRiderShifts(aid int) ([]models.Ridershifts, error) {
|
|
|
|
var data []models.Ridershifts
|
|
|
|
q1 := `Select a.*,concat(a.starttime,'-',a.endtime) as shiftname from ridershifts a where a.applocationid=` + strconv.Itoa(aid)
|
|
|
|
err := r.db.Raw(q1).Find(&data).Error
|
|
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
print(q1)
|
|
|
|
return data, nil
|
|
}
|
|
|
|
func (r *partnerRepository) GetLocationConfig(uid, cid int) ([]models.Locationconfigs, error) {
|
|
|
|
var data []models.Locationconfigs
|
|
|
|
q1 := fmt.Sprintf(`SELECT a.applocationid,a.locationname FROM app_location a
|
|
inner join app_locationconfig b ON a.applocationid=b.applocationid
|
|
WHERE b.status='Active' and b.userid=%d`, uid)
|
|
|
|
err := r.db.Raw(q1).Find(&data).Error
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
print(q1)
|
|
return data, nil
|
|
}
|
|
|
|
func (r *partnerRepository) GetRiderLogs(pid, aid int, fdate, tdate string) ([]models.RiderlogDetails, error) {
|
|
var data []models.RiderlogDetails
|
|
var args []interface{}
|
|
|
|
baseQuery := `
|
|
SELECT a.*, b.*, CONCAT(b.firstname,' ',b.lastname) AS username,
|
|
COALESCE(SUM(c.breakhours),0) AS breakhours
|
|
FROM riderlogs a
|
|
INNER JOIN app_users b ON a.userid = b.userid
|
|
LEFT JOIN riderbreaks c ON a.logid = c.logid AND a.userid = c.userid
|
|
WHERE 1=1
|
|
`
|
|
|
|
if pid != 0 {
|
|
baseQuery += " AND a.partnerid = ?"
|
|
args = append(args, pid)
|
|
}
|
|
|
|
if aid != 0 {
|
|
baseQuery += " AND b.applocationid = ?"
|
|
args = append(args, aid)
|
|
}
|
|
|
|
if fdate != "" && tdate != "" {
|
|
baseQuery += " AND logdate::date BETWEEN ? AND ?"
|
|
args = append(args, fdate, tdate)
|
|
} else {
|
|
baseQuery += " AND a.logdate::date = CURRENT_DATE"
|
|
}
|
|
|
|
baseQuery += " GROUP BY a.userid ORDER BY logid ASC"
|
|
|
|
if err := r.db.Raw(baseQuery, args...).Find(&data).Error; err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return data, nil
|
|
}
|
|
|
|
func (r *partnerRepository) GetRiderInfo(userid int) (models.RiderInfo, error) {
|
|
var data models.RiderInfo
|
|
|
|
q1 := `SELECT a.userid,a.firstname,a.lastname, CONCAT(a.firstname,' ',a.lastname) as fullname,
|
|
a.partnerid,a.configid,a.contactno,
|
|
a.address,a.suburb,a.city,a.state,a.postcode,a.latitude,a.longitude,
|
|
b.identificationno,b.vehicleno,b.vehiclename,b.licenseno,b.insuranceno,b.insurancedate,
|
|
c.shiftid,c.starttime,c.endtime,c.shifthours,c.basefare,c.additionalcharges,c.orders,c.fuelcharge,a.status,
|
|
a.applocationid,d.locationname as applocation,d.logseconds
|
|
FROM app_users a
|
|
INNER JOIN ridersettings b ON a.userid=b.userid
|
|
INNER JOIN ridershifts c ON b.shiftid=c.shiftid
|
|
INNER JOIN app_location d ON a.applocationid=d.applocationid
|
|
WHERE a.userid = ?`
|
|
|
|
if err := r.db.Raw(q1, userid).Scan(&data).Error; err != nil {
|
|
return models.RiderInfo{}, err
|
|
}
|
|
|
|
return data, nil
|
|
}
|