2025-01-05 14:14:00 +01:00
|
|
|
import { dataSource } from "../../../data-source";
|
|
|
|
import { membership } from "../../../entity/club/member/membership";
|
2025-01-29 09:42:22 +01:00
|
|
|
import DatabaseActionException from "../../../exceptions/databaseActionException";
|
2025-01-05 14:14:00 +01:00
|
|
|
import InternalException from "../../../exceptions/internalException";
|
2025-05-30 15:13:38 +02:00
|
|
|
import { membershipTotalView, membershipView } from "../../../views/membershipsView";
|
2024-09-16 15:55:41 +02:00
|
|
|
|
2024-09-16 16:00:05 +02:00
|
|
|
export default abstract class MembershipService {
|
2024-09-16 15:55:41 +02:00
|
|
|
/**
|
|
|
|
* @description get all by member id
|
2025-01-29 08:53:49 +01:00
|
|
|
* @param {string} memberId
|
2024-09-16 15:55:41 +02:00
|
|
|
* @returns {Promise<Array<membership>>}
|
|
|
|
*/
|
2025-01-29 08:53:49 +01:00
|
|
|
static async getAll(memberId: string): Promise<Array<membership>> {
|
2024-09-16 15:55:41 +02:00
|
|
|
return await dataSource
|
|
|
|
.getRepository(membership)
|
|
|
|
.createQueryBuilder("membership")
|
2024-09-17 16:44:39 +02:00
|
|
|
.leftJoinAndSelect("membership.status", "membershipStatus")
|
2024-09-16 15:55:41 +02:00
|
|
|
.where("membership.memberId = :memberId", { memberId: memberId })
|
2025-01-02 17:08:53 +01:00
|
|
|
.orderBy("membership.start", "DESC")
|
2024-09-16 15:55:41 +02:00
|
|
|
.getMany()
|
|
|
|
.then((res) => {
|
|
|
|
return res;
|
|
|
|
})
|
|
|
|
.catch((err) => {
|
2025-01-29 09:42:22 +01:00
|
|
|
throw new DatabaseActionException("SELECT", "membershis", err);
|
2024-09-16 15:55:41 +02:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @description get by memberId and recordId
|
2025-01-29 08:53:49 +01:00
|
|
|
* @param {string} memberId
|
2024-09-16 15:55:41 +02:00
|
|
|
* @param {number} recordId
|
|
|
|
* @returns {Promise<Array<member>>}
|
|
|
|
*/
|
2025-01-29 08:53:49 +01:00
|
|
|
static async getById(memberId: string, recordId: number): Promise<membership> {
|
2024-09-16 15:55:41 +02:00
|
|
|
return await dataSource
|
|
|
|
.getRepository(membership)
|
|
|
|
.createQueryBuilder("membership")
|
2024-09-17 16:44:39 +02:00
|
|
|
.leftJoinAndSelect("membership.status", "membershipStatus")
|
2024-09-16 15:55:41 +02:00
|
|
|
.where("membership.memberId = :memberId", { memberId: memberId })
|
|
|
|
.andWhere("membership.id = :recordId", { recordId: recordId })
|
|
|
|
.getOneOrFail()
|
|
|
|
.then((res) => {
|
|
|
|
return res;
|
|
|
|
})
|
|
|
|
.catch((err) => {
|
2025-01-29 09:42:22 +01:00
|
|
|
throw new DatabaseActionException("SELECT", "membership", err);
|
2024-09-16 15:55:41 +02:00
|
|
|
});
|
|
|
|
}
|
2025-01-21 14:49:14 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @description get membership statistics by memberId
|
2025-01-29 08:53:49 +01:00
|
|
|
* @param {string} memberId
|
2025-01-22 08:59:38 +01:00
|
|
|
* @returns {Promise<Array<membershipView>>}
|
2025-01-21 14:49:14 +01:00
|
|
|
*/
|
2025-01-29 08:53:49 +01:00
|
|
|
static async getStatisticsById(memberId: string): Promise<Array<membershipView>> {
|
2025-01-21 14:49:14 +01:00
|
|
|
return await dataSource
|
|
|
|
.getRepository(membershipView)
|
|
|
|
.createQueryBuilder("membershipView")
|
|
|
|
.where("membershipView.memberId = :memberId", { memberId: memberId })
|
2025-01-22 08:59:38 +01:00
|
|
|
.getMany()
|
2025-01-21 14:49:14 +01:00
|
|
|
.then((res) => {
|
|
|
|
return res;
|
|
|
|
})
|
|
|
|
.catch((err) => {
|
2025-01-29 09:42:22 +01:00
|
|
|
throw new DatabaseActionException("SELECT", "membershipView", err);
|
2025-01-21 14:49:14 +01:00
|
|
|
});
|
|
|
|
}
|
2025-05-30 15:13:38 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @description get membership total statistics by memberId
|
|
|
|
* @param {string} memberId
|
|
|
|
* @returns {Promise<Array<membershipTotalView>>}
|
|
|
|
*/
|
|
|
|
static async getTotalStatisticsById(memberId: string): Promise<membershipTotalView> {
|
|
|
|
return await dataSource
|
|
|
|
.getRepository(membershipTotalView)
|
|
|
|
.createQueryBuilder("membershipTotalView")
|
|
|
|
.where("membershipTotalView.memberId = :memberId", { memberId: memberId })
|
|
|
|
.getOneOrFail()
|
|
|
|
.then((res) => {
|
|
|
|
return res;
|
|
|
|
})
|
|
|
|
.catch((err) => {
|
|
|
|
throw new DatabaseActionException("SELECT", "membershipTotalView", err);
|
|
|
|
});
|
|
|
|
}
|
2024-09-16 15:55:41 +02:00
|
|
|
}
|