* ../../core/types/src/dml/index.ts * ../../core/types/src/dml/index.ts * fix: relationships mapping * handle nullable foreign keys types * handle nullable foreign keys types * handle nullable foreign keys types * continue to update product category repository * fix all product category repositories issues * fix product category service types * fix product module service types * fix product module service types * fix repository template type * refactor: use a singleton DMLToMikroORM factory instance Since the MikroORM MetadataStorage is global, we will also have to turn DML to MikroORM entities conversion use a global bucket as well * refactor: update product module to use DML in tests * wip: tests * WIP product linkable fixes * continue type fixing and start test fixing * test: fix more tests * fix repository * fix pivot table computaion + fix mikro orm repository * fix many to many management and configuration * fix many to many management and configuration * fix many to many management and configuration * update product tag relation configuration * Introduce experimental dml hooks to fix some issues with categories * more fixes * fix product tests * add missing id prefixes * fix product category handle management * test: fix more failing tests * test: make it all green * test: fix breaking tests * fix: build issues * fix: build issues * fix: more breaking tests * refactor: fix issues after merge * refactor: fix issues after merge * refactor: surpress types error * test: fix DML failing tests * improve many to many inference + tests * Wip fix columns from product entity * remove product model before create hook and manage handle validation and transformation at the service level * test: fix breaking unit tests * fix: product module service to not update handle on product update * fix define link and joiner config * test: fix joiner config test * test: fix joiner config test * fix joiner config primary keys * Fix joiner config builder * Fix joiner config builder * test: remove only modifier from test * refactor: remove hooks usage from product collection * refactor: remove hooks usage from product-option * refactor: remove hooks usage for computing category handle * refactor: remove hooks usage from productCategory model * refactor: remove hooks from DML * refactor: remove cruft * order dml * cleanup * re add foerign key indexes * wip * chore: remove unused types * wip * changes * rm raw * autoincrement * wip * rel * refactor: cleanup * migration and models configuration adjustments * cleanup * number searchable * fix random ordering * fix * test: fix product-category tests * test: update breaking DML tests * test: array assertion to not care about ordering * fix: temporarily apply id ordering for products * types * wip * WIP type improvements * update order models * partially fix types temporarely * rel * fix: recursive type issue * improve type inference breaks * improve type inference breaks * update models * rm nullable * default value * repository * update default value handling * fix unit tests * WIP * toMikroORM * fix relations * cascades * fix * experimental dml hooks * rm migration * serial * nullable autoincrement * fix model * model changes * fix one to one DML * order test * fix addresses * fix unit tests * Re align dml entity name inference * update model table name config * update model table name config * revert * update return relation * WIP * hasOne * models * fix * model * initial commit * cart service * order module * utils unit test * index engine * changeset * merge * fix hasOne with fk * update * free text filter per entity * tests * prod category * property string many to many * fix big number * link modules migration set names * merge * shipping option rules * serializer * unit test * fix test mikro orm init * fix test mikro orm init * Maintain merge object properties * fix test mikro orm init * prevent unit test from connecting to db * wip * fix test * fix test * link test * schema * models * auto increment * hook * model hooks * order * wip * orm version * request return field * fix return configuration on order model * workflows * core flows * unit test * test * base repo * test * base repo * test fix * inventory move * locking inventory * test * free text fix * rm timeout mock * migrate fulfillment values * v6.4.3 * cleanup * link-modules update sql * revert test * remove fake timers --------- Co-authored-by: adrien2p <adrien.deperetti@gmail.com> Co-authored-by: Harminder Virk <virk.officials@gmail.com> Co-authored-by: Oli Juhl <59018053+olivermrbl@users.noreply.github.com>
117 lines
3.2 KiB
TypeScript
117 lines
3.2 KiB
TypeScript
import { model, OrderStatus } from "@medusajs/framework/utils"
|
|
import { OrderAddress } from "./address"
|
|
import { OrderCreditLine } from "./credit-line"
|
|
import { OrderItem } from "./order-item"
|
|
import { OrderShipping } from "./order-shipping-method"
|
|
import { OrderSummary } from "./order-summary"
|
|
import { OrderTransaction } from "./transaction"
|
|
import { Return } from "@models"
|
|
|
|
const _Order = model
|
|
.define("Order", {
|
|
id: model.id({ prefix: "order" }).primaryKey(),
|
|
display_id: model.autoincrement(),
|
|
region_id: model.text().nullable(),
|
|
customer_id: model.text().nullable(),
|
|
version: model.number().default(1),
|
|
sales_channel_id: model.text().nullable(),
|
|
status: model.enum(OrderStatus).default(OrderStatus.PENDING),
|
|
is_draft_order: model.boolean().default(false),
|
|
email: model.text().searchable().nullable(),
|
|
currency_code: model.text(),
|
|
no_notification: model.boolean().nullable(),
|
|
metadata: model.json().nullable(),
|
|
canceled_at: model.dateTime().nullable(),
|
|
shipping_address: model
|
|
.hasOne<any>(() => OrderAddress, {
|
|
mappedBy: undefined,
|
|
foreignKey: true,
|
|
})
|
|
.nullable(),
|
|
billing_address: model
|
|
.hasOne<any>(() => OrderAddress, {
|
|
mappedBy: undefined,
|
|
foreignKey: true,
|
|
})
|
|
.nullable(),
|
|
summary: model.hasMany<any>(() => OrderSummary, {
|
|
mappedBy: "order",
|
|
}),
|
|
items: model.hasMany<any>(() => OrderItem, {
|
|
mappedBy: "order",
|
|
}),
|
|
shipping_methods: model.hasMany<any>(() => OrderShipping, {
|
|
mappedBy: "order",
|
|
}),
|
|
transactions: model.hasMany<any>(() => OrderTransaction, {
|
|
mappedBy: "order",
|
|
}),
|
|
credit_lines: model.hasMany<any>(() => OrderCreditLine, {
|
|
mappedBy: "order",
|
|
}),
|
|
returns: model.hasMany<any>(() => Return, {
|
|
mappedBy: "order",
|
|
}),
|
|
})
|
|
.cascades({
|
|
delete: ["summary", "items", "shipping_methods", "transactions"],
|
|
})
|
|
.indexes([
|
|
{
|
|
name: "IDX_order_display_id",
|
|
on: ["display_id"],
|
|
unique: false,
|
|
where: "deleted_at IS NOT NULL",
|
|
},
|
|
{
|
|
name: "IDX_order_region_id",
|
|
on: ["region_id"],
|
|
unique: false,
|
|
where: "deleted_at IS NOT NULL",
|
|
},
|
|
{
|
|
name: "IDX_order_customer_id",
|
|
on: ["customer_id"],
|
|
unique: false,
|
|
where: "deleted_at IS NOT NULL",
|
|
},
|
|
{
|
|
name: "IDX_order_sales_channel_id",
|
|
on: ["sales_channel_id"],
|
|
unique: false,
|
|
where: "deleted_at IS NOT NULL",
|
|
},
|
|
{
|
|
name: "IDX_order_deleted_at",
|
|
on: ["deleted_at"],
|
|
unique: false,
|
|
where: "deleted_at IS NOT NULL",
|
|
},
|
|
{
|
|
name: "IDX_order_currency_code",
|
|
on: ["currency_code"],
|
|
unique: false,
|
|
where: "deleted_at IS NOT NULL",
|
|
},
|
|
{
|
|
name: "IDX_order_shipping_address_id",
|
|
on: ["shipping_address_id"],
|
|
unique: false,
|
|
where: "deleted_at IS NOT NULL",
|
|
},
|
|
{
|
|
name: "IDX_order_billing_address_id",
|
|
on: ["billing_address_id"],
|
|
unique: false,
|
|
where: "deleted_at IS NOT NULL",
|
|
},
|
|
{
|
|
name: "IDX_order_is_draft_order",
|
|
on: ["is_draft_order"],
|
|
unique: false,
|
|
where: "deleted_at IS NOT NULL",
|
|
},
|
|
])
|
|
|
|
export const Order = _Order
|