246 lines
5.9 KiB
TypeScript
246 lines
5.9 KiB
TypeScript
import { BigNumberRawValue, DAL } from "@medusajs/types"
|
|
import {
|
|
BigNumber,
|
|
DALUtils,
|
|
MikroOrmBigNumberProperty,
|
|
createPsqlIndexStatementHelper,
|
|
generateEntityId,
|
|
} from "@medusajs/utils"
|
|
import {
|
|
BeforeCreate,
|
|
Entity,
|
|
Filter,
|
|
ManyToOne,
|
|
OnInit,
|
|
OptionalProps,
|
|
PrimaryKey,
|
|
Property,
|
|
Rel,
|
|
} from "@mikro-orm/core"
|
|
import OrderClaim from "./claim"
|
|
import OrderExchange from "./exchange"
|
|
import Order from "./order"
|
|
import OrderChange from "./order-change"
|
|
import Return from "./return"
|
|
|
|
type OptionalLineItemProps = DAL.ModelDateColumns
|
|
|
|
const OrderChangeIdIndex = createPsqlIndexStatementHelper({
|
|
tableName: "order_change_action",
|
|
columns: "order_change_id",
|
|
where: "deleted_at IS NOT NULL",
|
|
})
|
|
|
|
const OrderIdIndex = createPsqlIndexStatementHelper({
|
|
tableName: "order_change_action",
|
|
columns: "order_id",
|
|
where: "deleted_at IS NOT NULL",
|
|
})
|
|
|
|
const ReturnIdIndex = createPsqlIndexStatementHelper({
|
|
tableName: "order_change_action",
|
|
columns: "return_id",
|
|
where: "return_id IS NOT NULL AND deleted_at IS NOT NULL",
|
|
})
|
|
|
|
const OrderClaimIdIndex = createPsqlIndexStatementHelper({
|
|
tableName: "order_change_action",
|
|
columns: "claim_id",
|
|
where: "claim_id IS NOT NULL AND deleted_at IS NOT NULL",
|
|
})
|
|
|
|
const OrderExchangeIdIndex = createPsqlIndexStatementHelper({
|
|
tableName: "order_change_action",
|
|
columns: "exchange_id",
|
|
where: "exchange_id IS NOT NULL AND deleted_at IS NOT NULL",
|
|
})
|
|
|
|
const DeletedAtIndex = createPsqlIndexStatementHelper({
|
|
tableName: "order_change_action",
|
|
columns: "deleted_at",
|
|
where: "deleted_at IS NOT NULL",
|
|
})
|
|
|
|
const ActionOrderingIndex = createPsqlIndexStatementHelper({
|
|
tableName: "order_change_action",
|
|
columns: "ordering",
|
|
where: "deleted_at IS NOT NULL",
|
|
})
|
|
|
|
@Entity({ tableName: "order_change_action" })
|
|
@Filter(DALUtils.mikroOrmSoftDeletableFilterOptions)
|
|
export default class OrderChangeAction {
|
|
[OptionalProps]?: OptionalLineItemProps
|
|
|
|
@PrimaryKey({ columnType: "text" })
|
|
id: string
|
|
|
|
@Property({ columnType: "integer", autoincrement: true })
|
|
@ActionOrderingIndex.MikroORMIndex()
|
|
ordering: number
|
|
|
|
@ManyToOne({
|
|
entity: () => Order,
|
|
columnType: "text",
|
|
fieldName: "order_id",
|
|
onDelete: "cascade",
|
|
mapToPk: true,
|
|
nullable: true,
|
|
})
|
|
@OrderIdIndex.MikroORMIndex()
|
|
order_id: string | null = null
|
|
|
|
@ManyToOne(() => Order, {
|
|
persist: false,
|
|
nullable: true,
|
|
})
|
|
order: Rel<Order> | null = null
|
|
|
|
@ManyToOne({
|
|
entity: () => Return,
|
|
mapToPk: true,
|
|
fieldName: "return_id",
|
|
columnType: "text",
|
|
nullable: true,
|
|
})
|
|
@ReturnIdIndex.MikroORMIndex()
|
|
return_id: string | null = null
|
|
|
|
@ManyToOne(() => Return, {
|
|
persist: false,
|
|
nullable: true,
|
|
})
|
|
return: Return
|
|
|
|
@ManyToOne({
|
|
entity: () => OrderClaim,
|
|
mapToPk: true,
|
|
fieldName: "claim_id",
|
|
columnType: "text",
|
|
nullable: true,
|
|
})
|
|
@OrderClaimIdIndex.MikroORMIndex()
|
|
claim_id: string | null = null
|
|
|
|
@ManyToOne(() => OrderClaim, {
|
|
persist: false,
|
|
nullable: true,
|
|
})
|
|
claim: OrderClaim
|
|
|
|
@ManyToOne({
|
|
entity: () => OrderExchange,
|
|
mapToPk: true,
|
|
fieldName: "exchange_id",
|
|
columnType: "text",
|
|
nullable: true,
|
|
})
|
|
@OrderExchangeIdIndex.MikroORMIndex()
|
|
exchange_id: string | null = null
|
|
|
|
@ManyToOne(() => OrderExchange, {
|
|
persist: false,
|
|
nullable: true,
|
|
})
|
|
exchange: OrderExchange
|
|
|
|
@Property({ columnType: "integer", nullable: true })
|
|
version: number | null = null
|
|
|
|
@ManyToOne({
|
|
entity: () => OrderChange,
|
|
columnType: "text",
|
|
fieldName: "order_change_id",
|
|
onDelete: "cascade",
|
|
mapToPk: true,
|
|
nullable: true,
|
|
})
|
|
@OrderChangeIdIndex.MikroORMIndex()
|
|
order_change_id: string | null
|
|
|
|
@ManyToOne(() => OrderChange, {
|
|
persist: false,
|
|
nullable: true,
|
|
})
|
|
order_change: Rel<OrderChange> | null = null
|
|
|
|
@Property({
|
|
columnType: "text",
|
|
nullable: true,
|
|
})
|
|
reference: string | null = null
|
|
|
|
@Property({
|
|
columnType: "text",
|
|
nullable: true,
|
|
})
|
|
reference_id: string | null = null
|
|
|
|
@Property({ columnType: "text" })
|
|
action: string
|
|
|
|
@Property({ columnType: "jsonb" })
|
|
details: Record<string, unknown> = {}
|
|
|
|
@MikroOrmBigNumberProperty({ nullable: true })
|
|
amount: BigNumber | number | null = null
|
|
|
|
@Property({ columnType: "jsonb", nullable: true })
|
|
raw_amount: BigNumberRawValue | null = null
|
|
|
|
@Property({
|
|
columnType: "text",
|
|
nullable: true,
|
|
})
|
|
internal_note: string | null = null
|
|
|
|
@Property({
|
|
columnType: "boolean",
|
|
defaultRaw: "false",
|
|
})
|
|
applied: boolean = false
|
|
|
|
@Property({
|
|
onCreate: () => new Date(),
|
|
columnType: "timestamptz",
|
|
defaultRaw: "now()",
|
|
})
|
|
created_at: Date
|
|
|
|
@Property({
|
|
onCreate: () => new Date(),
|
|
onUpdate: () => new Date(),
|
|
columnType: "timestamptz",
|
|
defaultRaw: "now()",
|
|
})
|
|
updated_at: Date
|
|
|
|
@Property({ columnType: "timestamptz", nullable: true })
|
|
@DeletedAtIndex.MikroORMIndex()
|
|
deleted_at: Date | null = null
|
|
|
|
@BeforeCreate()
|
|
onCreate() {
|
|
this.id = generateEntityId(this.id, "ordchact")
|
|
this.order_id ??= this.order?.id ?? this.order_change?.order_id ?? null
|
|
this.return_id ??= this.return?.id ?? this.order_change?.return_id ?? null
|
|
this.claim_id ??= this.claim?.id ?? this.order_change?.claim_id ?? null
|
|
this.exchange_id ??=
|
|
this.exchange?.id ?? this.order_change?.exchange_id ?? null
|
|
this.order_change_id ??= this.order_change?.id ?? null
|
|
this.version ??= this.order_change?.version ?? null
|
|
}
|
|
|
|
@OnInit()
|
|
onInit() {
|
|
this.id = generateEntityId(this.id, "ordchact")
|
|
this.order_id ??= this.order?.id ?? this.order_change?.order_id ?? null
|
|
this.return_id ??= this.return?.id ?? this.order_change?.return_id ?? null
|
|
this.claim_id ??= this.claim?.id ?? this.order_change?.claim_id ?? null
|
|
this.exchange_id ??=
|
|
this.exchange?.id ?? this.order_change?.exchange_id ?? null
|
|
this.order_change_id ??= this.order_change?.id ?? null
|
|
this.version ??= this.order_change?.version ?? null
|
|
}
|
|
}
|