@open-mercato/core 0.4.6-develop-9ff1d4a9a2 → 0.4.6-develop-219dae16c5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (107) hide show
  1. package/dist/modules/currencies/backend/exchange-rates/[id]/page.js +17 -154
  2. package/dist/modules/currencies/backend/exchange-rates/[id]/page.js.map +3 -3
  3. package/dist/modules/currencies/backend/exchange-rates/create/page.js +14 -152
  4. package/dist/modules/currencies/backend/exchange-rates/create/page.js.map +2 -2
  5. package/dist/modules/currencies/lib/exchangeRateFormConfig.js +167 -0
  6. package/dist/modules/currencies/lib/exchangeRateFormConfig.js.map +7 -0
  7. package/dist/modules/customers/api/dashboard/widgets/utils.js +1 -34
  8. package/dist/modules/customers/api/dashboard/widgets/utils.js.map +2 -2
  9. package/dist/modules/customers/commands/activities.js +3 -8
  10. package/dist/modules/customers/commands/activities.js.map +2 -2
  11. package/dist/modules/customers/commands/comments.js +2 -8
  12. package/dist/modules/customers/commands/comments.js.map +2 -2
  13. package/dist/modules/dashboards/lib/widgetScope.js +38 -0
  14. package/dist/modules/dashboards/lib/widgetScope.js.map +7 -0
  15. package/dist/modules/entities/lib/makeActivityRoute.js +265 -0
  16. package/dist/modules/entities/lib/makeActivityRoute.js.map +7 -0
  17. package/dist/modules/resources/api/activities.js +24 -232
  18. package/dist/modules/resources/api/activities.js.map +2 -2
  19. package/dist/modules/resources/commands/activities.js +3 -8
  20. package/dist/modules/resources/commands/activities.js.map +2 -2
  21. package/dist/modules/resources/commands/comments.js +2 -8
  22. package/dist/modules/resources/commands/comments.js.map +2 -2
  23. package/dist/modules/sales/api/dashboard/widgets/new-orders/route.js +27 -182
  24. package/dist/modules/sales/api/dashboard/widgets/new-orders/route.js.map +2 -2
  25. package/dist/modules/sales/api/dashboard/widgets/new-quotes/route.js +28 -183
  26. package/dist/modules/sales/api/dashboard/widgets/new-quotes/route.js.map +2 -2
  27. package/dist/modules/sales/api/order-line-statuses/route.js +15 -194
  28. package/dist/modules/sales/api/order-line-statuses/route.js.map +2 -2
  29. package/dist/modules/sales/api/order-lines/route.js +15 -281
  30. package/dist/modules/sales/api/order-lines/route.js.map +2 -2
  31. package/dist/modules/sales/api/order-statuses/route.js +15 -194
  32. package/dist/modules/sales/api/order-statuses/route.js.map +2 -2
  33. package/dist/modules/sales/api/payment-statuses/route.js +15 -194
  34. package/dist/modules/sales/api/payment-statuses/route.js.map +2 -2
  35. package/dist/modules/sales/api/quote-lines/route.js +15 -279
  36. package/dist/modules/sales/api/quote-lines/route.js.map +2 -2
  37. package/dist/modules/sales/api/shipment-statuses/route.js +15 -194
  38. package/dist/modules/sales/api/shipment-statuses/route.js.map +2 -2
  39. package/dist/modules/sales/components/PaymentMethodsSettings.js +3 -84
  40. package/dist/modules/sales/components/PaymentMethodsSettings.js.map +2 -2
  41. package/dist/modules/sales/components/ProviderFieldInput.js +86 -0
  42. package/dist/modules/sales/components/ProviderFieldInput.js.map +7 -0
  43. package/dist/modules/sales/components/ShippingMethodsSettings.js +3 -82
  44. package/dist/modules/sales/components/ShippingMethodsSettings.js.map +2 -2
  45. package/dist/modules/sales/lib/makeSalesLineRoute.js +308 -0
  46. package/dist/modules/sales/lib/makeSalesLineRoute.js.map +7 -0
  47. package/dist/modules/sales/lib/makeStatusDictionaryRoute.js +206 -0
  48. package/dist/modules/sales/lib/makeStatusDictionaryRoute.js.map +7 -0
  49. package/dist/modules/sales/widgets/dashboard/makeDashboardWidgetRoute.js +178 -0
  50. package/dist/modules/sales/widgets/dashboard/makeDashboardWidgetRoute.js.map +7 -0
  51. package/dist/modules/sales/widgets/dashboard/new-orders/widget.client.js +1 -39
  52. package/dist/modules/sales/widgets/dashboard/new-orders/widget.client.js.map +2 -2
  53. package/dist/modules/sales/widgets/dashboard/new-quotes/widget.client.js +1 -39
  54. package/dist/modules/sales/widgets/dashboard/new-quotes/widget.client.js.map +2 -2
  55. package/dist/modules/sales/widgets/dashboard/shared.js +46 -0
  56. package/dist/modules/sales/widgets/dashboard/shared.js.map +7 -0
  57. package/dist/modules/staff/api/activities.js +24 -232
  58. package/dist/modules/staff/api/activities.js.map +2 -2
  59. package/dist/modules/staff/backend/staff/leave-requests/[id]/page.js +14 -34
  60. package/dist/modules/staff/backend/staff/leave-requests/[id]/page.js.map +2 -2
  61. package/dist/modules/staff/backend/staff/my-leave-requests/[id]/page.js +15 -34
  62. package/dist/modules/staff/backend/staff/my-leave-requests/[id]/page.js.map +2 -2
  63. package/dist/modules/staff/commands/activities.js +3 -8
  64. package/dist/modules/staff/commands/activities.js.map +2 -2
  65. package/dist/modules/staff/commands/comments.js +2 -8
  66. package/dist/modules/staff/commands/comments.js.map +2 -2
  67. package/dist/modules/staff/lib/leaveRequestHelpers.js +41 -0
  68. package/dist/modules/staff/lib/leaveRequestHelpers.js.map +7 -0
  69. package/package.json +2 -2
  70. package/src/modules/currencies/backend/exchange-rates/[id]/page.tsx +20 -180
  71. package/src/modules/currencies/backend/exchange-rates/create/page.tsx +16 -175
  72. package/src/modules/currencies/lib/exchangeRateFormConfig.ts +200 -0
  73. package/src/modules/customers/api/dashboard/widgets/utils.ts +1 -53
  74. package/src/modules/customers/commands/activities.ts +2 -8
  75. package/src/modules/customers/commands/comments.ts +2 -8
  76. package/src/modules/dashboards/i18n/de.json +3 -0
  77. package/src/modules/dashboards/i18n/en.json +3 -0
  78. package/src/modules/dashboards/i18n/es.json +3 -0
  79. package/src/modules/dashboards/i18n/pl.json +3 -0
  80. package/src/modules/dashboards/lib/widgetScope.ts +53 -0
  81. package/src/modules/entities/lib/makeActivityRoute.ts +327 -0
  82. package/src/modules/resources/api/activities.ts +25 -269
  83. package/src/modules/resources/commands/activities.ts +2 -7
  84. package/src/modules/resources/commands/comments.ts +2 -8
  85. package/src/modules/sales/api/dashboard/widgets/new-orders/route.ts +29 -244
  86. package/src/modules/sales/api/dashboard/widgets/new-quotes/route.ts +30 -245
  87. package/src/modules/sales/api/order-line-statuses/route.ts +16 -209
  88. package/src/modules/sales/api/order-lines/route.ts +16 -300
  89. package/src/modules/sales/api/order-statuses/route.ts +16 -209
  90. package/src/modules/sales/api/payment-statuses/route.ts +16 -209
  91. package/src/modules/sales/api/quote-lines/route.ts +16 -298
  92. package/src/modules/sales/api/shipment-statuses/route.ts +16 -209
  93. package/src/modules/sales/components/PaymentMethodsSettings.tsx +3 -88
  94. package/src/modules/sales/components/ProviderFieldInput.tsx +85 -0
  95. package/src/modules/sales/components/ShippingMethodsSettings.tsx +3 -86
  96. package/src/modules/sales/lib/makeSalesLineRoute.ts +345 -0
  97. package/src/modules/sales/lib/makeStatusDictionaryRoute.ts +229 -0
  98. package/src/modules/sales/widgets/dashboard/makeDashboardWidgetRoute.ts +247 -0
  99. package/src/modules/sales/widgets/dashboard/new-orders/widget.client.tsx +7 -50
  100. package/src/modules/sales/widgets/dashboard/new-quotes/widget.client.tsx +7 -49
  101. package/src/modules/sales/widgets/dashboard/shared.ts +44 -0
  102. package/src/modules/staff/api/activities.ts +25 -269
  103. package/src/modules/staff/backend/staff/leave-requests/[id]/page.tsx +15 -69
  104. package/src/modules/staff/backend/staff/my-leave-requests/[id]/page.tsx +16 -65
  105. package/src/modules/staff/commands/activities.ts +2 -7
  106. package/src/modules/staff/commands/comments.ts +2 -8
  107. package/src/modules/staff/lib/leaveRequestHelpers.ts +78 -0
@@ -1,201 +1,22 @@
1
- import { z } from "zod";
2
- import { makeCrudRoute } from "@open-mercato/shared/lib/crud/factory";
3
- import { resolveTranslations } from "@open-mercato/shared/lib/i18n/server";
4
- import { CrudHttpError } from "@open-mercato/shared/lib/crud/errors";
5
- import { Dictionary, DictionaryEntry } from "@open-mercato/core/modules/dictionaries/data/entities";
6
1
  import { E } from "../../../../generated/entities.ids.generated.js";
7
2
  import * as F from "../../../../generated/entities/dictionary_entry/index.js";
8
- import { statusDictionaryCreateSchema, statusDictionaryUpdateSchema } from "../../data/validators.js";
9
- import { getSalesDictionaryDefinition, ensureSalesDictionary } from "../../lib/dictionaries.js";
10
- import { parseScopedCommandInput, resolveCrudRecordId } from "../utils.js";
11
- import {
12
- createPagedListResponseSchema,
13
- createSalesCrudOpenApi,
14
- defaultDeleteRequestSchema
15
- } from "../openapi.js";
16
- import { escapeLikePattern } from "@open-mercato/shared/lib/db/escapeLikePattern";
17
- const rawBodySchema = z.object({}).passthrough();
18
- const listSchema = z.object({
19
- page: z.coerce.number().min(1).default(1),
20
- pageSize: z.coerce.number().min(1).max(100).default(50),
21
- search: z.string().optional(),
22
- sortField: z.string().optional(),
23
- sortDir: z.enum(["asc", "desc"]).optional()
24
- }).passthrough();
25
- const kind = "payment-status";
26
- const definition = getSalesDictionaryDefinition(kind);
27
- const metadata = {
28
- GET: { requireAuth: true, requireFeatures: ["sales.settings.manage"] },
29
- POST: { requireAuth: true, requireFeatures: ["sales.settings.manage"] },
30
- PUT: { requireAuth: true, requireFeatures: ["sales.settings.manage"] },
31
- DELETE: { requireAuth: true, requireFeatures: ["sales.settings.manage"] }
32
- };
33
- const dictionaryItemSchema = z.object({
34
- id: z.string().uuid(),
35
- value: z.string(),
36
- label: z.string().nullable(),
37
- color: z.string().nullable(),
38
- icon: z.string().nullable(),
39
- organizationId: z.string().uuid().nullable(),
40
- tenantId: z.string().uuid().nullable(),
41
- createdAt: z.string(),
42
- updatedAt: z.string()
43
- });
44
- const dictionaryListResponseSchema = createPagedListResponseSchema(dictionaryItemSchema);
45
- const normalizeId = (value) => {
46
- if (typeof value !== "string") return null;
47
- const trimmed = value.trim();
48
- return trimmed.length > 0 ? trimmed : null;
49
- };
50
- async function resolveDictionaryContext(ctx) {
51
- if (!ctx.auth || !ctx.auth.tenantId) {
52
- throw new CrudHttpError(401, { error: "Tenant context is required." });
53
- }
54
- const em = ctx.container.resolve("em");
55
- const tenantId = ctx.auth.tenantId;
56
- const candidateOrgIds = /* @__PURE__ */ new Set();
57
- const pushCandidate = (value) => {
58
- const normalized = normalizeId(value);
59
- if (normalized) candidateOrgIds.add(normalized);
60
- };
61
- pushCandidate(ctx.selectedOrganizationId);
62
- pushCandidate(ctx.auth.orgId ?? null);
63
- const scope = ctx.organizationScope;
64
- if (scope) {
65
- if (Array.isArray(scope.filterIds)) {
66
- for (const id of scope.filterIds) pushCandidate(id);
67
- }
68
- if (Array.isArray(scope.allowedIds)) {
69
- for (const id of scope.allowedIds) pushCandidate(id);
70
- }
71
- }
72
- for (const orgId of candidateOrgIds) {
73
- const dictionary = await ensureSalesDictionary({
74
- em,
75
- tenantId,
76
- organizationId: orgId,
77
- kind
78
- });
79
- if (dictionary) {
80
- return { dictionaryId: dictionary.id, organizationId: orgId };
81
- }
3
+ import { makeStatusDictionaryRoute } from "../../lib/makeStatusDictionaryRoute.js";
4
+ const route = makeStatusDictionaryRoute({
5
+ kind: "payment-status",
6
+ entityId: E.dictionaries.dictionary_entry,
7
+ fieldConstants: F,
8
+ openApi: {
9
+ resourceName: "Payment status",
10
+ pluralName: "Payment statuses",
11
+ description: "Manage the lifecycle states available for payments."
82
12
  }
83
- const fallback = await em.findOne(
84
- Dictionary,
85
- {
86
- tenantId,
87
- key: definition.key,
88
- deletedAt: null
89
- },
90
- { orderBy: { createdAt: "asc" } }
91
- );
92
- if (fallback) {
93
- return { dictionaryId: fallback.id, organizationId: fallback.organizationId };
94
- }
95
- throw new CrudHttpError(400, { error: "Organization context is required." });
96
- }
97
- const crud = makeCrudRoute({
98
- metadata,
99
- orm: {
100
- entity: DictionaryEntry,
101
- idField: "id",
102
- orgField: "organizationId",
103
- tenantField: "tenantId",
104
- softDeleteField: null
105
- },
106
- list: {
107
- schema: listSchema,
108
- entityId: E.dictionaries.dictionary_entry,
109
- fields: [
110
- F.id,
111
- F.value,
112
- F.label,
113
- F.color,
114
- F.icon,
115
- F.organization_id,
116
- F.tenant_id,
117
- F.created_at,
118
- F.updated_at
119
- ],
120
- sortFieldMap: {
121
- id: F.id,
122
- value: F.value,
123
- label: F.label,
124
- createdAt: F.created_at,
125
- updatedAt: F.updated_at
126
- },
127
- buildFilters: async (query, ctx) => {
128
- const { dictionaryId } = await resolveDictionaryContext(ctx);
129
- const filters = {
130
- dictionary_id: dictionaryId
131
- };
132
- if (query.search && query.search.trim().length > 0) {
133
- const term = `%${escapeLikePattern(query.search.trim())}%`;
134
- filters.$or = [
135
- { [F.value]: { $ilike: term } },
136
- { [F.label]: { $ilike: term } }
137
- ];
138
- }
139
- return filters;
140
- },
141
- transformItem: (item) => ({
142
- id: item.id,
143
- value: item.value,
144
- label: item.label,
145
- color: item.color ?? null,
146
- icon: item.icon ?? null,
147
- organizationId: item.organization_id ?? null,
148
- tenantId: item.tenant_id ?? null,
149
- createdAt: item.created_at,
150
- updatedAt: item.updated_at
151
- })
152
- },
153
- actions: {
154
- create: {
155
- commandId: `${definition.commandPrefix}.create`,
156
- schema: rawBodySchema,
157
- mapInput: async ({ raw, ctx }) => {
158
- const { translate } = await resolveTranslations();
159
- return parseScopedCommandInput(statusDictionaryCreateSchema, raw ?? {}, ctx, translate);
160
- },
161
- response: ({ result }) => ({ id: result?.entryId ?? null }),
162
- status: 201
163
- },
164
- update: {
165
- commandId: `${definition.commandPrefix}.update`,
166
- schema: rawBodySchema,
167
- mapInput: async ({ raw, ctx }) => {
168
- const { translate } = await resolveTranslations();
169
- return parseScopedCommandInput(statusDictionaryUpdateSchema, raw ?? {}, ctx, translate);
170
- },
171
- response: () => ({ ok: true })
172
- },
173
- delete: {
174
- commandId: `${definition.commandPrefix}.delete`,
175
- schema: rawBodySchema,
176
- mapInput: async ({ parsed, ctx }) => {
177
- const { translate } = await resolveTranslations();
178
- const id = resolveCrudRecordId(parsed, ctx, translate);
179
- return { id };
180
- },
181
- response: () => ({ ok: true })
182
- }
183
- }
184
- });
185
- const openApi = createSalesCrudOpenApi({
186
- resourceName: "Payment status",
187
- pluralName: "Payment statuses",
188
- description: "Manage the lifecycle states available for payments.",
189
- querySchema: listSchema,
190
- listResponseSchema: dictionaryListResponseSchema,
191
- create: { schema: statusDictionaryCreateSchema },
192
- update: { schema: statusDictionaryUpdateSchema },
193
- del: { schema: defaultDeleteRequestSchema }
194
13
  });
195
- const GET = crud.GET;
196
- const POST = crud.POST;
197
- const PUT = crud.PUT;
198
- const DELETE = crud.DELETE;
14
+ const metadata = route.metadata;
15
+ const openApi = route.openApi;
16
+ const GET = route.GET;
17
+ const POST = route.POST;
18
+ const PUT = route.PUT;
19
+ const DELETE = route.DELETE;
199
20
  export {
200
21
  DELETE,
201
22
  GET,
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../src/modules/sales/api/payment-statuses/route.ts"],
4
- "sourcesContent": ["import { z } from 'zod'\nimport { makeCrudRoute } from '@open-mercato/shared/lib/crud/factory'\nimport type { EntityManager } from '@mikro-orm/postgresql'\nimport { resolveTranslations } from '@open-mercato/shared/lib/i18n/server'\nimport { CrudHttpError } from '@open-mercato/shared/lib/crud/errors'\nimport { Dictionary, DictionaryEntry } from '@open-mercato/core/modules/dictionaries/data/entities'\nimport { E } from '#generated/entities.ids.generated'\nimport * as F from '#generated/entities/dictionary_entry'\nimport { statusDictionaryCreateSchema, statusDictionaryUpdateSchema } from '../../data/validators'\nimport { getSalesDictionaryDefinition, ensureSalesDictionary, type SalesDictionaryKind } from '../../lib/dictionaries'\nimport { parseScopedCommandInput, resolveCrudRecordId } from '../utils'\nimport {\n createPagedListResponseSchema,\n createSalesCrudOpenApi,\n defaultDeleteRequestSchema,\n} from '../openapi'\nimport { escapeLikePattern } from '@open-mercato/shared/lib/db/escapeLikePattern'\n\nconst rawBodySchema = z.object({}).passthrough()\n\nconst listSchema = z\n .object({\n page: z.coerce.number().min(1).default(1),\n pageSize: z.coerce.number().min(1).max(100).default(50),\n search: z.string().optional(),\n sortField: z.string().optional(),\n sortDir: z.enum(['asc', 'desc']).optional(),\n })\n .passthrough()\n\nconst kind: SalesDictionaryKind = 'payment-status'\nconst definition = getSalesDictionaryDefinition(kind)\n\nexport const metadata = {\n GET: { requireAuth: true, requireFeatures: ['sales.settings.manage'] },\n POST: { requireAuth: true, requireFeatures: ['sales.settings.manage'] },\n PUT: { requireAuth: true, requireFeatures: ['sales.settings.manage'] },\n DELETE: { requireAuth: true, requireFeatures: ['sales.settings.manage'] },\n}\n\nconst dictionaryItemSchema = z.object({\n id: z.string().uuid(),\n value: z.string(),\n label: z.string().nullable(),\n color: z.string().nullable(),\n icon: z.string().nullable(),\n organizationId: z.string().uuid().nullable(),\n tenantId: z.string().uuid().nullable(),\n createdAt: z.string(),\n updatedAt: z.string(),\n})\n\nconst dictionaryListResponseSchema = createPagedListResponseSchema(dictionaryItemSchema)\n\nconst normalizeId = (value: unknown): string | null => {\n if (typeof value !== 'string') return null\n const trimmed = value.trim()\n return trimmed.length > 0 ? trimmed : null\n}\n\nasync function resolveDictionaryContext(ctx: any): Promise<{ dictionaryId: string; organizationId: string | null }> {\n if (!ctx.auth || !ctx.auth.tenantId) {\n throw new CrudHttpError(401, { error: 'Tenant context is required.' })\n }\n const em = ctx.container.resolve('em') as EntityManager\n const tenantId: string = ctx.auth.tenantId\n const candidateOrgIds = new Set<string>()\n const pushCandidate = (value: unknown) => {\n const normalized = normalizeId(value)\n if (normalized) candidateOrgIds.add(normalized)\n }\n pushCandidate(ctx.selectedOrganizationId)\n pushCandidate(ctx.auth.orgId ?? null)\n const scope = ctx.organizationScope\n if (scope) {\n if (Array.isArray(scope.filterIds)) {\n for (const id of scope.filterIds) pushCandidate(id)\n }\n if (Array.isArray(scope.allowedIds)) {\n for (const id of scope.allowedIds) pushCandidate(id)\n }\n }\n\n for (const orgId of candidateOrgIds) {\n const dictionary = await ensureSalesDictionary({\n em,\n tenantId,\n organizationId: orgId,\n kind,\n })\n if (dictionary) {\n return { dictionaryId: dictionary.id, organizationId: orgId }\n }\n }\n\n const fallback = await em.findOne(\n Dictionary,\n {\n tenantId,\n key: definition.key,\n deletedAt: null,\n },\n { orderBy: { createdAt: 'asc' } },\n )\n if (fallback) {\n return { dictionaryId: fallback.id, organizationId: fallback.organizationId }\n }\n throw new CrudHttpError(400, { error: 'Organization context is required.' })\n}\n\nconst crud = makeCrudRoute({\n metadata,\n orm: {\n entity: DictionaryEntry,\n idField: 'id',\n orgField: 'organizationId',\n tenantField: 'tenantId',\n softDeleteField: null,\n },\n list: {\n schema: listSchema,\n entityId: E.dictionaries.dictionary_entry,\n fields: [\n F.id,\n F.value,\n F.label,\n F.color,\n F.icon,\n F.organization_id,\n F.tenant_id,\n F.created_at,\n F.updated_at,\n ],\n sortFieldMap: {\n id: F.id,\n value: F.value,\n label: F.label,\n createdAt: F.created_at,\n updatedAt: F.updated_at,\n },\n buildFilters: async (query, ctx) => {\n const { dictionaryId } = await resolveDictionaryContext(ctx)\n const filters: Record<string, unknown> = {\n dictionary_id: dictionaryId,\n }\n if (query.search && query.search.trim().length > 0) {\n const term = `%${escapeLikePattern(query.search.trim())}%`\n filters.$or = [\n { [F.value]: { $ilike: term } },\n { [F.label]: { $ilike: term } },\n ]\n }\n return filters\n },\n transformItem: (item: any) => ({\n id: item.id,\n value: item.value,\n label: item.label,\n color: item.color ?? null,\n icon: item.icon ?? null,\n organizationId: item.organization_id ?? null,\n tenantId: item.tenant_id ?? null,\n createdAt: item.created_at,\n updatedAt: item.updated_at,\n }),\n },\n actions: {\n create: {\n commandId: `${definition.commandPrefix}.create`,\n schema: rawBodySchema,\n mapInput: async ({ raw, ctx }) => {\n const { translate } = await resolveTranslations()\n return parseScopedCommandInput(statusDictionaryCreateSchema, raw ?? {}, ctx, translate)\n },\n response: ({ result }) => ({ id: result?.entryId ?? null }),\n status: 201,\n },\n update: {\n commandId: `${definition.commandPrefix}.update`,\n schema: rawBodySchema,\n mapInput: async ({ raw, ctx }) => {\n const { translate } = await resolveTranslations()\n return parseScopedCommandInput(statusDictionaryUpdateSchema, raw ?? {}, ctx, translate)\n },\n response: () => ({ ok: true }),\n },\n delete: {\n commandId: `${definition.commandPrefix}.delete`,\n schema: rawBodySchema,\n mapInput: async ({ parsed, ctx }) => {\n const { translate } = await resolveTranslations()\n const id = resolveCrudRecordId(parsed, ctx, translate)\n return { id }\n },\n response: () => ({ ok: true }),\n },\n },\n})\n\nexport const openApi = createSalesCrudOpenApi({\n resourceName: 'Payment status',\n pluralName: 'Payment statuses',\n description: 'Manage the lifecycle states available for payments.',\n querySchema: listSchema,\n listResponseSchema: dictionaryListResponseSchema,\n create: { schema: statusDictionaryCreateSchema },\n update: { schema: statusDictionaryUpdateSchema },\n del: { schema: defaultDeleteRequestSchema },\n})\n\nexport const GET = crud.GET\nexport const POST = crud.POST\nexport const PUT = crud.PUT\nexport const DELETE = crud.DELETE\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["import { E } from '#generated/entities.ids.generated'\nimport * as F from '#generated/entities/dictionary_entry'\nimport { makeStatusDictionaryRoute } from '../../lib/makeStatusDictionaryRoute'\n\nconst route = makeStatusDictionaryRoute({\n kind: 'payment-status',\n entityId: E.dictionaries.dictionary_entry,\n fieldConstants: F,\n openApi: {\n resourceName: 'Payment status',\n pluralName: 'Payment statuses',\n description: 'Manage the lifecycle states available for payments.',\n },\n})\n\nexport const metadata = route.metadata\nexport const openApi = route.openApi\nexport const GET = route.GET\nexport const POST = route.POST\nexport const PUT = route.PUT\nexport const DELETE = route.DELETE\n"],
5
+ "mappings": "AAAA,SAAS,SAAS;AAClB,YAAY,OAAO;AACnB,SAAS,iCAAiC;AAE1C,MAAM,QAAQ,0BAA0B;AAAA,EACtC,MAAM;AAAA,EACN,UAAU,EAAE,aAAa;AAAA,EACzB,gBAAgB;AAAA,EAChB,SAAS;AAAA,IACP,cAAc;AAAA,IACd,YAAY;AAAA,IACZ,aAAa;AAAA,EACf;AACF,CAAC;AAEM,MAAM,WAAW,MAAM;AACvB,MAAM,UAAU,MAAM;AACtB,MAAM,MAAM,MAAM;AAClB,MAAM,OAAO,MAAM;AACnB,MAAM,MAAM,MAAM;AAClB,MAAM,SAAS,MAAM;",
6
6
  "names": []
7
7
  }
@@ -1,288 +1,24 @@
1
- import { z } from "zod";
2
- import { makeCrudRoute } from "@open-mercato/shared/lib/crud/factory";
3
- import { resolveTranslations } from "@open-mercato/shared/lib/i18n/server";
4
- import { CrudHttpError } from "@open-mercato/shared/lib/crud/errors";
5
- import {
6
- buildCustomFieldFiltersFromQuery,
7
- extractAllCustomFieldEntries
8
- } from "@open-mercato/shared/lib/crud/custom-fields";
9
1
  import { SalesQuoteLine } from "../../data/entities.js";
10
2
  import { quoteLineCreateSchema } from "../../data/validators.js";
11
- import {
12
- createPagedListResponseSchema,
13
- createSalesCrudOpenApi,
14
- defaultOkResponseSchema
15
- } from "../openapi.js";
16
- import { withScopedPayload } from "../utils.js";
17
3
  import { E } from "../../../../generated/entities.ids.generated.js";
18
4
  import * as F from "../../../../generated/entities/sales_quote_line/index.js";
19
- import { canonicalizeUnitCode, REFERENCE_UNIT_CODES } from "@open-mercato/shared/lib/units/unitCodes";
20
- const rawBodySchema = z.object({}).passthrough();
21
- const resolveRawBody = (raw) => {
22
- if (!raw || typeof raw !== "object") return {};
23
- if ("body" in raw) {
24
- const payload = raw;
25
- if (payload.body && typeof payload.body === "object") {
26
- return payload.body;
27
- }
28
- }
29
- return raw;
30
- };
31
- const listSchema = z.object({
32
- page: z.coerce.number().min(1).default(1),
33
- pageSize: z.coerce.number().min(1).max(100).default(50),
34
- id: z.string().uuid().optional(),
35
- quoteId: z.string().uuid().optional(),
36
- sortField: z.string().optional(),
37
- sortDir: z.enum(["asc", "desc"]).optional()
38
- }).passthrough();
39
- const routeMetadata = {
40
- GET: { requireAuth: true, requireFeatures: ["sales.quotes.view"] },
41
- POST: { requireAuth: true, requireFeatures: ["sales.quotes.manage"] },
42
- PUT: { requireAuth: true, requireFeatures: ["sales.quotes.manage"] },
43
- DELETE: { requireAuth: true, requireFeatures: ["sales.quotes.manage"] }
44
- };
45
- const upsertSchema = quoteLineCreateSchema.extend({
46
- id: z.string().uuid().optional()
47
- });
48
- const deleteSchema = z.object({
49
- id: z.string().uuid(),
50
- quoteId: z.string().uuid()
51
- });
52
- const crud = makeCrudRoute({
53
- metadata: routeMetadata,
54
- orm: {
55
- entity: SalesQuoteLine,
56
- idField: "id",
57
- orgField: "organizationId",
58
- tenantField: "tenantId",
59
- softDeleteField: "deletedAt"
60
- },
61
- indexer: {
62
- entityType: E.sales.sales_quote_line
63
- },
64
- list: {
65
- schema: listSchema,
66
- entityId: E.sales.sales_quote_line,
67
- fields: [
68
- F.id,
69
- "quote_id",
70
- F.line_number,
71
- F.kind,
72
- F.status_entry_id,
73
- F.status,
74
- F.product_id,
75
- F.product_variant_id,
76
- F.catalog_snapshot,
77
- F.name,
78
- F.description,
79
- F.comment,
80
- F.quantity,
81
- F.quantity_unit,
82
- F.normalized_quantity,
83
- F.normalized_unit,
84
- F.uom_snapshot,
85
- F.currency_code,
86
- F.unit_price_net,
87
- F.unit_price_gross,
88
- F.discount_amount,
89
- F.discount_percent,
90
- F.tax_rate,
91
- F.tax_amount,
92
- F.total_net_amount,
93
- F.total_gross_amount,
94
- F.configuration,
95
- F.promotion_code,
96
- F.promotion_snapshot,
97
- F.metadata,
98
- F.custom_field_set_id,
99
- F.created_at,
100
- F.updated_at
101
- ],
102
- sortFieldMap: {
103
- createdAt: F.created_at,
104
- updatedAt: F.updated_at,
105
- lineNumber: F.line_number
106
- },
107
- buildFilters: async (query, ctx) => {
108
- const filters = {};
109
- if (query.id) filters.id = { $eq: query.id };
110
- if (query.quoteId) filters.quote_id = { $eq: query.quoteId };
111
- try {
112
- const em = ctx.container.resolve("em");
113
- const cfFilters = await buildCustomFieldFiltersFromQuery({
114
- entityId: E.sales.sales_quote_line,
115
- query,
116
- em,
117
- tenantId: ctx.auth?.tenantId ?? null
118
- });
119
- Object.assign(filters, cfFilters);
120
- } catch {
121
- }
122
- return filters;
123
- },
124
- transformItem: (item) => {
125
- if (!item) return item;
126
- const normalized = { ...item };
127
- const cfEntries = extractAllCustomFieldEntries(item);
128
- for (const key of Object.keys(normalized)) {
129
- if (key.startsWith("cf:")) delete normalized[key];
130
- }
131
- const quantityUnit = canonicalizeUnitCode(
132
- normalized["quantity_unit"] ?? normalized["quantityUnit"]
133
- );
134
- const normalizedUnit = canonicalizeUnitCode(
135
- normalized["normalized_unit"] ?? normalized["normalizedUnit"]
136
- ) ?? quantityUnit;
137
- return {
138
- ...normalized,
139
- quantity_unit: quantityUnit,
140
- normalized_unit: normalizedUnit,
141
- ...cfEntries
142
- };
143
- }
144
- },
145
- actions: {
146
- create: {
147
- commandId: "sales.quotes.lines.upsert",
148
- schema: rawBodySchema,
149
- mapInput: async ({ raw, ctx }) => {
150
- const { translate } = await resolveTranslations();
151
- const payload = upsertSchema.parse(
152
- withScopedPayload(resolveRawBody(raw) ?? {}, ctx, translate)
153
- );
154
- return { body: payload };
155
- },
156
- response: ({ result }) => ({
157
- id: result?.lineId ?? null,
158
- quoteId: result?.quoteId ?? null
159
- }),
160
- status: 201
161
- },
162
- update: {
163
- commandId: "sales.quotes.lines.upsert",
164
- schema: rawBodySchema,
165
- mapInput: async ({ raw, ctx }) => {
166
- const { translate } = await resolveTranslations();
167
- const payload = upsertSchema.parse(
168
- withScopedPayload(resolveRawBody(raw) ?? {}, ctx, translate)
169
- );
170
- return { body: payload };
171
- },
172
- response: ({ result }) => ({
173
- id: result?.lineId ?? null,
174
- quoteId: result?.quoteId ?? null
175
- })
176
- },
177
- delete: {
178
- commandId: "sales.quotes.lines.delete",
179
- schema: rawBodySchema,
180
- mapInput: async ({ raw, ctx }) => {
181
- const { translate } = await resolveTranslations();
182
- const payload = deleteSchema.parse(
183
- withScopedPayload(resolveRawBody(raw) ?? {}, ctx, translate)
184
- );
185
- if (!payload.id || !payload.quoteId) {
186
- throw new CrudHttpError(400, {
187
- error: translate(
188
- "sales.documents.detail.error",
189
- "Document not found or inaccessible."
190
- )
191
- });
192
- }
193
- return { body: payload };
194
- },
195
- response: () => ({ ok: true })
196
- }
197
- }
198
- });
199
- const { GET, POST, PUT, DELETE } = crud;
200
- const uomSnapshotOpenApiSchema = z.object({
201
- version: z.literal(1),
202
- productId: z.string().nullable(),
203
- productVariantId: z.string().nullable(),
204
- baseUnitCode: z.string().nullable(),
205
- enteredUnitCode: z.string().nullable(),
206
- enteredQuantity: z.string(),
207
- toBaseFactor: z.string(),
208
- normalizedQuantity: z.string(),
209
- rounding: z.object({
210
- mode: z.enum(["half_up", "down", "up"]),
211
- scale: z.number().int()
212
- }),
213
- source: z.object({
214
- conversionId: z.string().nullable(),
215
- resolvedAt: z.string()
216
- }),
217
- unitPriceReference: z.object({
218
- enabled: z.boolean(),
219
- referenceUnitCode: z.enum(REFERENCE_UNIT_CODES).nullable(),
220
- baseQuantity: z.string().nullable(),
221
- grossPerReference: z.string().nullable().optional(),
222
- netPerReference: z.string().nullable().optional()
223
- }).optional()
224
- }).nullable().optional();
225
- const quoteLineSchema = z.object({
226
- id: z.string().uuid(),
227
- quote_id: z.string().uuid(),
228
- line_number: z.number(),
229
- kind: z.string(),
230
- status_entry_id: z.string().uuid().nullable().optional(),
231
- status: z.string().nullable().optional(),
232
- product_id: z.string().uuid().nullable().optional(),
233
- product_variant_id: z.string().uuid().nullable().optional(),
234
- catalog_snapshot: z.record(z.string(), z.unknown()).nullable().optional(),
235
- name: z.string().nullable().optional(),
236
- description: z.string().nullable().optional(),
237
- comment: z.string().nullable().optional(),
238
- quantity: z.number(),
239
- quantity_unit: z.string().nullable().optional(),
240
- normalized_quantity: z.number(),
241
- normalized_unit: z.string().nullable().optional(),
242
- uom_snapshot: uomSnapshotOpenApiSchema,
243
- currency_code: z.string(),
244
- unit_price_net: z.number(),
245
- unit_price_gross: z.number(),
246
- discount_amount: z.number(),
247
- discount_percent: z.number(),
248
- tax_rate: z.number(),
249
- tax_amount: z.number(),
250
- total_net_amount: z.number(),
251
- total_gross_amount: z.number(),
252
- configuration: z.record(z.string(), z.unknown()).nullable().optional(),
253
- promotion_code: z.string().nullable().optional(),
254
- promotion_snapshot: z.record(z.string(), z.unknown()).nullable().optional(),
255
- metadata: z.record(z.string(), z.unknown()).nullable().optional(),
256
- custom_field_set_id: z.string().uuid().nullable().optional(),
257
- created_at: z.string(),
258
- updated_at: z.string()
259
- });
260
- const openApi = createSalesCrudOpenApi({
261
- resourceName: "Quote line",
262
- querySchema: listSchema,
263
- listResponseSchema: createPagedListResponseSchema(quoteLineSchema),
264
- create: {
265
- schema: upsertSchema,
266
- responseSchema: z.object({
267
- id: z.string().uuid().nullable(),
268
- quoteId: z.string().uuid().nullable()
269
- }),
270
- description: "Creates a quote line and recalculates totals."
271
- },
272
- update: {
273
- schema: upsertSchema,
274
- responseSchema: z.object({
275
- id: z.string().uuid().nullable(),
276
- quoteId: z.string().uuid().nullable()
277
- }),
278
- description: "Updates a quote line and recalculates totals."
279
- },
280
- del: {
281
- schema: deleteSchema,
282
- responseSchema: defaultOkResponseSchema,
283
- description: "Deletes a quote line and recalculates totals."
5
+ import { makeSalesLineRoute } from "../../lib/makeSalesLineRoute.js";
6
+ const route = makeSalesLineRoute({
7
+ entity: SalesQuoteLine,
8
+ entityId: E.sales.sales_quote_line,
9
+ fieldConstants: F,
10
+ parentFkColumn: "quote_id",
11
+ parentFkParam: "quoteId",
12
+ createSchema: quoteLineCreateSchema,
13
+ features: { view: "sales.quotes.view", manage: "sales.quotes.manage" },
14
+ commandPrefix: "sales.quotes.lines",
15
+ openApi: {
16
+ resourceName: "Quote line",
17
+ description: "a quote line and recalculates totals"
284
18
  }
285
19
  });
20
+ const { GET, POST, PUT, DELETE } = route;
21
+ const openApi = route.openApi;
286
22
  export {
287
23
  DELETE,
288
24
  GET,
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../src/modules/sales/api/quote-lines/route.ts"],
4
- "sourcesContent": ["import { z } from \"zod\";\nimport { makeCrudRoute } from \"@open-mercato/shared/lib/crud/factory\";\nimport { resolveTranslations } from \"@open-mercato/shared/lib/i18n/server\";\nimport { CrudHttpError } from \"@open-mercato/shared/lib/crud/errors\";\nimport {\n buildCustomFieldFiltersFromQuery,\n extractAllCustomFieldEntries,\n} from \"@open-mercato/shared/lib/crud/custom-fields\";\nimport { SalesQuoteLine } from \"../../data/entities\";\nimport { quoteLineCreateSchema } from \"../../data/validators\";\nimport {\n createPagedListResponseSchema,\n createSalesCrudOpenApi,\n defaultOkResponseSchema,\n} from \"../openapi\";\nimport { withScopedPayload } from \"../utils\";\nimport { E } from \"#generated/entities.ids.generated\";\nimport * as F from \"#generated/entities/sales_quote_line\";\nimport { canonicalizeUnitCode, REFERENCE_UNIT_CODES } from \"@open-mercato/shared/lib/units/unitCodes\";\n\nconst rawBodySchema = z.object({}).passthrough();\nconst resolveRawBody = (raw: unknown): Record<string, unknown> => {\n if (!raw || typeof raw !== \"object\") return {};\n if (\"body\" in raw) {\n const payload = raw as { body?: unknown };\n if (payload.body && typeof payload.body === \"object\") {\n return payload.body as Record<string, unknown>;\n }\n }\n return raw as Record<string, unknown>;\n};\n\nconst listSchema = z\n .object({\n page: z.coerce.number().min(1).default(1),\n pageSize: z.coerce.number().min(1).max(100).default(50),\n id: z.string().uuid().optional(),\n quoteId: z.string().uuid().optional(),\n sortField: z.string().optional(),\n sortDir: z.enum([\"asc\", \"desc\"]).optional(),\n })\n .passthrough();\n\nconst routeMetadata = {\n GET: { requireAuth: true, requireFeatures: [\"sales.quotes.view\"] },\n POST: { requireAuth: true, requireFeatures: [\"sales.quotes.manage\"] },\n PUT: { requireAuth: true, requireFeatures: [\"sales.quotes.manage\"] },\n DELETE: { requireAuth: true, requireFeatures: [\"sales.quotes.manage\"] },\n};\n\nconst upsertSchema = quoteLineCreateSchema.extend({\n id: z.string().uuid().optional(),\n});\nconst deleteSchema = z.object({\n id: z.string().uuid(),\n quoteId: z.string().uuid(),\n});\n\nconst crud = makeCrudRoute({\n metadata: routeMetadata,\n orm: {\n entity: SalesQuoteLine,\n idField: \"id\",\n orgField: \"organizationId\",\n tenantField: \"tenantId\",\n softDeleteField: \"deletedAt\",\n },\n indexer: {\n entityType: E.sales.sales_quote_line,\n },\n list: {\n schema: listSchema,\n entityId: E.sales.sales_quote_line,\n fields: [\n F.id,\n \"quote_id\",\n F.line_number,\n F.kind,\n F.status_entry_id,\n F.status,\n F.product_id,\n F.product_variant_id,\n F.catalog_snapshot,\n F.name,\n F.description,\n F.comment,\n F.quantity,\n F.quantity_unit,\n F.normalized_quantity,\n F.normalized_unit,\n F.uom_snapshot,\n F.currency_code,\n F.unit_price_net,\n F.unit_price_gross,\n F.discount_amount,\n F.discount_percent,\n F.tax_rate,\n F.tax_amount,\n F.total_net_amount,\n F.total_gross_amount,\n F.configuration,\n F.promotion_code,\n F.promotion_snapshot,\n F.metadata,\n F.custom_field_set_id,\n F.created_at,\n F.updated_at,\n ],\n sortFieldMap: {\n createdAt: F.created_at,\n updatedAt: F.updated_at,\n lineNumber: F.line_number,\n },\n buildFilters: async (query, ctx) => {\n const filters: Record<string, unknown> = {};\n if (query.id) filters.id = { $eq: query.id };\n if (query.quoteId) filters.quote_id = { $eq: query.quoteId };\n try {\n const em = ctx.container.resolve(\"em\");\n const cfFilters = await buildCustomFieldFiltersFromQuery({\n entityId: E.sales.sales_quote_line,\n query,\n em,\n tenantId: ctx.auth?.tenantId ?? null,\n });\n Object.assign(filters, cfFilters);\n } catch {\n // ignore\n }\n return filters;\n },\n transformItem: (item: Record<string, unknown> | null | undefined) => {\n if (!item) return item;\n const normalized = { ...item };\n const cfEntries = extractAllCustomFieldEntries(item);\n for (const key of Object.keys(normalized)) {\n if (key.startsWith(\"cf:\")) delete normalized[key];\n }\n const quantityUnit = canonicalizeUnitCode(\n normalized[\"quantity_unit\"] ?? normalized[\"quantityUnit\"],\n );\n const normalizedUnit =\n canonicalizeUnitCode(\n normalized[\"normalized_unit\"] ?? normalized[\"normalizedUnit\"],\n ) ?? quantityUnit;\n return {\n ...normalized,\n quantity_unit: quantityUnit,\n normalized_unit: normalizedUnit,\n ...cfEntries,\n };\n },\n },\n actions: {\n create: {\n commandId: \"sales.quotes.lines.upsert\",\n schema: rawBodySchema,\n mapInput: async ({ raw, ctx }) => {\n const { translate } = await resolveTranslations();\n const payload = upsertSchema.parse(\n withScopedPayload(resolveRawBody(raw) ?? {}, ctx, translate),\n );\n return { body: payload };\n },\n response: ({ result }) => ({\n id: result?.lineId ?? null,\n quoteId: result?.quoteId ?? null,\n }),\n status: 201,\n },\n update: {\n commandId: \"sales.quotes.lines.upsert\",\n schema: rawBodySchema,\n mapInput: async ({ raw, ctx }) => {\n const { translate } = await resolveTranslations();\n const payload = upsertSchema.parse(\n withScopedPayload(resolveRawBody(raw) ?? {}, ctx, translate),\n );\n return { body: payload };\n },\n response: ({ result }) => ({\n id: result?.lineId ?? null,\n quoteId: result?.quoteId ?? null,\n }),\n },\n delete: {\n commandId: \"sales.quotes.lines.delete\",\n schema: rawBodySchema,\n mapInput: async ({ raw, ctx }) => {\n const { translate } = await resolveTranslations();\n const payload = deleteSchema.parse(\n withScopedPayload(resolveRawBody(raw) ?? {}, ctx, translate),\n );\n if (!payload.id || !payload.quoteId) {\n throw new CrudHttpError(400, {\n error: translate(\n \"sales.documents.detail.error\",\n \"Document not found or inaccessible.\",\n ),\n });\n }\n return { body: payload };\n },\n response: () => ({ ok: true }),\n },\n },\n});\n\nconst { GET, POST, PUT, DELETE } = crud;\n\nexport { GET, POST, PUT, DELETE };\n\nconst uomSnapshotOpenApiSchema = z\n .object({\n version: z.literal(1),\n productId: z.string().nullable(),\n productVariantId: z.string().nullable(),\n baseUnitCode: z.string().nullable(),\n enteredUnitCode: z.string().nullable(),\n enteredQuantity: z.string(),\n toBaseFactor: z.string(),\n normalizedQuantity: z.string(),\n rounding: z.object({\n mode: z.enum([\"half_up\", \"down\", \"up\"]),\n scale: z.number().int(),\n }),\n source: z.object({\n conversionId: z.string().nullable(),\n resolvedAt: z.string(),\n }),\n unitPriceReference: z\n .object({\n enabled: z.boolean(),\n referenceUnitCode: z.enum(REFERENCE_UNIT_CODES).nullable(),\n baseQuantity: z.string().nullable(),\n grossPerReference: z.string().nullable().optional(),\n netPerReference: z.string().nullable().optional(),\n })\n .optional(),\n })\n .nullable()\n .optional();\n\nconst quoteLineSchema = z.object({\n id: z.string().uuid(),\n quote_id: z.string().uuid(),\n line_number: z.number(),\n kind: z.string(),\n status_entry_id: z.string().uuid().nullable().optional(),\n status: z.string().nullable().optional(),\n product_id: z.string().uuid().nullable().optional(),\n product_variant_id: z.string().uuid().nullable().optional(),\n catalog_snapshot: z.record(z.string(), z.unknown()).nullable().optional(),\n name: z.string().nullable().optional(),\n description: z.string().nullable().optional(),\n comment: z.string().nullable().optional(),\n quantity: z.number(),\n quantity_unit: z.string().nullable().optional(),\n normalized_quantity: z.number(),\n normalized_unit: z.string().nullable().optional(),\n uom_snapshot: uomSnapshotOpenApiSchema,\n currency_code: z.string(),\n unit_price_net: z.number(),\n unit_price_gross: z.number(),\n discount_amount: z.number(),\n discount_percent: z.number(),\n tax_rate: z.number(),\n tax_amount: z.number(),\n total_net_amount: z.number(),\n total_gross_amount: z.number(),\n configuration: z.record(z.string(), z.unknown()).nullable().optional(),\n promotion_code: z.string().nullable().optional(),\n promotion_snapshot: z.record(z.string(), z.unknown()).nullable().optional(),\n metadata: z.record(z.string(), z.unknown()).nullable().optional(),\n custom_field_set_id: z.string().uuid().nullable().optional(),\n created_at: z.string(),\n updated_at: z.string(),\n});\n\nexport const openApi = createSalesCrudOpenApi({\n resourceName: \"Quote line\",\n querySchema: listSchema,\n listResponseSchema: createPagedListResponseSchema(quoteLineSchema),\n create: {\n schema: upsertSchema,\n responseSchema: z.object({\n id: z.string().uuid().nullable(),\n quoteId: z.string().uuid().nullable(),\n }),\n description: \"Creates a quote line and recalculates totals.\",\n },\n update: {\n schema: upsertSchema,\n responseSchema: z.object({\n id: z.string().uuid().nullable(),\n quoteId: z.string().uuid().nullable(),\n }),\n description: \"Updates a quote line and recalculates totals.\",\n },\n del: {\n schema: deleteSchema,\n responseSchema: defaultOkResponseSchema,\n description: \"Deletes a quote line and recalculates totals.\",\n },\n});\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["import { SalesQuoteLine } from \"../../data/entities\";\nimport { quoteLineCreateSchema } from \"../../data/validators\";\nimport { E } from \"#generated/entities.ids.generated\";\nimport * as F from \"#generated/entities/sales_quote_line\";\nimport { makeSalesLineRoute } from \"../../lib/makeSalesLineRoute\";\n\nconst route = makeSalesLineRoute({\n entity: SalesQuoteLine,\n entityId: E.sales.sales_quote_line,\n fieldConstants: F,\n parentFkColumn: \"quote_id\",\n parentFkParam: \"quoteId\",\n createSchema: quoteLineCreateSchema,\n features: { view: \"sales.quotes.view\", manage: \"sales.quotes.manage\" },\n commandPrefix: \"sales.quotes.lines\",\n openApi: {\n resourceName: \"Quote line\",\n description: \"a quote line and recalculates totals\",\n },\n});\n\nexport const { GET, POST, PUT, DELETE } = route;\nexport const openApi = route.openApi;\n"],
5
+ "mappings": "AAAA,SAAS,sBAAsB;AAC/B,SAAS,6BAA6B;AACtC,SAAS,SAAS;AAClB,YAAY,OAAO;AACnB,SAAS,0BAA0B;AAEnC,MAAM,QAAQ,mBAAmB;AAAA,EAC/B,QAAQ;AAAA,EACR,UAAU,EAAE,MAAM;AAAA,EAClB,gBAAgB;AAAA,EAChB,gBAAgB;AAAA,EAChB,eAAe;AAAA,EACf,cAAc;AAAA,EACd,UAAU,EAAE,MAAM,qBAAqB,QAAQ,sBAAsB;AAAA,EACrE,eAAe;AAAA,EACf,SAAS;AAAA,IACP,cAAc;AAAA,IACd,aAAa;AAAA,EACf;AACF,CAAC;AAEM,MAAM,EAAE,KAAK,MAAM,KAAK,OAAO,IAAI;AACnC,MAAM,UAAU,MAAM;",
6
6
  "names": []
7
7
  }