@open-mercato/core 0.6.4-develop.4339.1.fad812f76f → 0.6.4-develop.4358.1.233d5675c7

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 (25) hide show
  1. package/dist/modules/customers/components/detail/ConfirmDealLostDialog.js +15 -10
  2. package/dist/modules/customers/components/detail/ConfirmDealLostDialog.js.map +2 -2
  3. package/dist/modules/customers/components/detail/ScheduleActivityDialog.js +2 -6
  4. package/dist/modules/customers/components/detail/ScheduleActivityDialog.js.map +2 -2
  5. package/dist/modules/sales/components/documents/AdjustmentDialog.js +10 -12
  6. package/dist/modules/sales/components/documents/AdjustmentDialog.js.map +2 -2
  7. package/dist/modules/sales/components/documents/LineItemDialog.js +10 -10
  8. package/dist/modules/sales/components/documents/LineItemDialog.js.map +2 -2
  9. package/dist/modules/sales/components/documents/PaymentDialog.js +8 -15
  10. package/dist/modules/sales/components/documents/PaymentDialog.js.map +2 -2
  11. package/dist/modules/sales/components/documents/ShipmentDialog.js +10 -14
  12. package/dist/modules/sales/components/documents/ShipmentDialog.js.map +2 -2
  13. package/dist/modules/workflows/components/EdgeEditDialog.js +3 -9
  14. package/dist/modules/workflows/components/EdgeEditDialog.js.map +2 -2
  15. package/dist/modules/workflows/components/NodeEditDialog.js +3 -9
  16. package/dist/modules/workflows/components/NodeEditDialog.js.map +2 -2
  17. package/package.json +7 -7
  18. package/src/modules/customers/components/detail/ConfirmDealLostDialog.tsx +15 -10
  19. package/src/modules/customers/components/detail/ScheduleActivityDialog.tsx +2 -6
  20. package/src/modules/sales/components/documents/AdjustmentDialog.tsx +11 -12
  21. package/src/modules/sales/components/documents/LineItemDialog.tsx +11 -10
  22. package/src/modules/sales/components/documents/PaymentDialog.tsx +9 -16
  23. package/src/modules/sales/components/documents/ShipmentDialog.tsx +10 -14
  24. package/src/modules/workflows/components/EdgeEditDialog.tsx +3 -9
  25. package/src/modules/workflows/components/NodeEditDialog.tsx +3 -9
@@ -9,6 +9,7 @@ import { collectCustomFieldValues } from "@open-mercato/ui/backend/utils/customF
9
9
  import { createCrud, updateCrud } from "@open-mercato/ui/backend/utils/crud";
10
10
  import { createCrudFormError } from "@open-mercato/ui/backend/utils/serverErrors";
11
11
  import { Dialog, DialogContent, DialogHeader, DialogTitle } from "@open-mercato/ui/primitives/dialog";
12
+ import { useDialogKeyHandler } from "@open-mercato/ui/hooks/useDialogKeyHandler";
12
13
  import { Input } from "@open-mercato/ui/primitives/input";
13
14
  import { Spinner } from "@open-mercato/ui/primitives/spinner";
14
15
  import { E } from "../../../../generated/entities.ids.generated.js";
@@ -441,28 +442,20 @@ function PaymentDialog({
441
442
  },
442
443
  [currencyCode, mode, onOpenChange, onSaved, orderId, organizationId, payment?.id, t, tenantId]
443
444
  );
444
- const handleShortcutSubmit = React.useCallback(
445
- (event) => {
446
- if ((event.metaKey || event.ctrlKey) && event.key === "Enter") {
447
- event.preventDefault();
448
- const form = dialogContentRef.current?.querySelector("form");
449
- form?.requestSubmit();
450
- }
451
- },
445
+ const handleSubmitForm = React.useCallback(
446
+ () => dialogContentRef.current?.querySelector("form")?.requestSubmit(),
452
447
  []
453
448
  );
449
+ const handleKeyDown = useDialogKeyHandler({
450
+ onConfirm: handleSubmitForm,
451
+ onCancel: () => onOpenChange(false)
452
+ });
454
453
  return /* @__PURE__ */ jsx(Dialog, { open, onOpenChange, children: /* @__PURE__ */ jsxs(
455
454
  DialogContent,
456
455
  {
457
456
  ref: dialogContentRef,
458
457
  className: "sm:max-w-5xl",
459
- onKeyDown: (event) => {
460
- if (event.key === "Escape") {
461
- event.preventDefault();
462
- onOpenChange(false);
463
- }
464
- handleShortcutSubmit(event);
465
- },
458
+ onKeyDown: handleKeyDown,
466
459
  children: [
467
460
  /* @__PURE__ */ jsx(DialogHeader, { children: /* @__PURE__ */ jsx(DialogTitle, { children: mode === "edit" ? t("sales.documents.payments.edit", "Edit payment") : t("sales.documents.payments.add", "Add payment") }) }),
468
461
  /* @__PURE__ */ jsx(
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../src/modules/sales/components/documents/PaymentDialog.tsx"],
4
- "sourcesContent": ["\"use client\"\n\nimport * as React from 'react'\nimport { CreditCard } from 'lucide-react'\nimport { CrudForm, type CrudField, type CrudFormGroup } from '@open-mercato/ui/backend/CrudForm'\nimport { LookupSelect, type LookupSelectItem } from '@open-mercato/ui/backend/inputs'\nimport { apiCall } from '@open-mercato/ui/backend/utils/apiCall'\nimport { collectCustomFieldValues } from '@open-mercato/ui/backend/utils/customFieldValues'\nimport { createCrud, updateCrud } from '@open-mercato/ui/backend/utils/crud'\nimport { createCrudFormError } from '@open-mercato/ui/backend/utils/serverErrors'\nimport { Dialog, DialogContent, DialogHeader, DialogTitle } from '@open-mercato/ui/primitives/dialog'\nimport { Input } from '@open-mercato/ui/primitives/input'\nimport { Spinner } from '@open-mercato/ui/primitives/spinner'\nimport { E } from '#generated/entities.ids.generated'\nimport { useT } from '@open-mercato/shared/lib/i18n/context'\nimport { normalizeCustomFieldSubmitValue, extractCustomFieldValues } from './customFieldHelpers'\n\nexport type PaymentTotals = {\n paidTotalAmount?: number | null\n refundedTotalAmount?: number | null\n outstandingAmount?: number | null\n}\n\nexport type PaymentFormData = {\n id?: string | null\n amount?: number | string | null\n paymentMethodId?: string | null\n paymentReference?: string | null\n receivedAt?: string | null\n currencyCode?: string | null\n statusEntryId?: string | null\n customValues?: Record<string, unknown> | null\n customFieldSetId?: string | null\n}\n\ntype PaymentMethodOption = {\n id: string\n name: string\n code: string\n}\n\ntype StatusOption = {\n id: string\n value: string\n label: string\n color: string | null\n}\n\ntype PaymentDialogProps = {\n open: boolean\n mode: 'create' | 'edit'\n payment?: PaymentFormData | null\n currencyCode: string | null | undefined\n orderId: string\n organizationId: string | null\n tenantId: string | null\n onOpenChange: (open: boolean) => void\n onSaved?: (totals?: PaymentTotals | null) => void | Promise<void>\n}\n\nconst normalizeNumber = (value: unknown): number => {\n if (typeof value === 'number' && Number.isFinite(value)) return value\n if (typeof value === 'string' && value.trim().length) {\n const parsed = Number(value)\n if (!Number.isNaN(parsed)) return parsed\n }\n return 0\n}\n\nexport function PaymentDialog({\n open,\n mode,\n payment,\n currencyCode,\n orderId,\n organizationId,\n tenantId,\n onOpenChange,\n onSaved,\n}: PaymentDialogProps) {\n const t = useT()\n const dialogContentRef = React.useRef<HTMLDivElement | null>(null)\n const [formResetKey, setFormResetKey] = React.useState(0)\n const [paymentMethods, setPaymentMethods] = React.useState<PaymentMethodOption[]>([])\n const [methodsLoading, setMethodsLoading] = React.useState(false)\n const [paymentStatuses, setPaymentStatuses] = React.useState<StatusOption[]>([])\n const [paymentStatusLoading, setPaymentStatusLoading] = React.useState(false)\n const [documentStatuses, setDocumentStatuses] = React.useState<StatusOption[]>([])\n const [documentStatusLoading, setDocumentStatusLoading] = React.useState(false)\n\n const currencyLabel = React.useMemo(() => {\n const code = currencyCode ? currencyCode.toUpperCase() : ''\n if (!code) return t('sales.documents.detail.empty', 'Not set')\n return code\n }, [currencyCode, t])\n\n const initialValues = React.useMemo(\n () => ({\n amount: payment?.amount ?? '',\n paymentMethodId: payment?.paymentMethodId ?? '',\n paymentReference: payment?.paymentReference ?? '',\n receivedAt: payment?.receivedAt ? payment.receivedAt.slice(0, 10) : '',\n statusEntryId: payment?.statusEntryId ?? '',\n documentStatusEntryId: '',\n customFieldSetId: payment?.customFieldSetId ?? '',\n ...extractCustomFieldValues(payment),\n }),\n [\n payment?.amount,\n payment?.customFieldSetId,\n payment?.customValues,\n payment?.paymentMethodId,\n payment?.paymentReference,\n payment?.receivedAt,\n payment?.statusEntryId,\n ],\n )\n\n const loadPaymentMethods = React.useCallback(\n async (query?: string): Promise<PaymentMethodOption[]> => {\n setMethodsLoading(true)\n try {\n const params = new URLSearchParams({ page: '1', pageSize: '100', isActive: 'true' })\n if (query && query.trim().length) params.set('search', query.trim())\n const response = await apiCall<{ items?: Array<Record<string, unknown>> }>(\n `/api/sales/payment-methods?${params.toString()}`,\n undefined,\n { fallback: { items: [] } }\n )\n if (response.ok && Array.isArray(response.result?.items)) {\n const options = response.result.items\n .map((item) => {\n const id = typeof item.id === 'string' ? item.id : null\n if (!id) return null\n const name = typeof item.name === 'string' ? item.name : null\n const code = typeof item.code === 'string' ? item.code : null\n return {\n id,\n name: name ?? code ?? id,\n code: code ?? id,\n }\n })\n .filter((entry): entry is PaymentMethodOption => !!entry)\n if (!query) setPaymentMethods(options)\n return options\n }\n if (!query) setPaymentMethods([])\n return []\n } catch (err) {\n console.error('sales.payments.methods.load', err)\n return []\n } finally {\n setMethodsLoading(false)\n }\n },\n []\n )\n\n const fetchPaymentMethodItems = React.useCallback(\n async (query?: string): Promise<LookupSelectItem[]> => {\n const options =\n paymentMethods.length && !query\n ? paymentMethods\n : await loadPaymentMethods(query)\n const term = query?.trim().toLowerCase() ?? ''\n return options\n .filter(\n (option) =>\n !term.length ||\n option.name.toLowerCase().includes(term) ||\n option.code.toLowerCase().includes(term)\n )\n .map<LookupSelectItem>((option) => ({\n id: option.id,\n title: option.name,\n subtitle: option.code,\n icon: <CreditCard className=\"h-4 w-4 text-muted-foreground\" />,\n }))\n },\n [loadPaymentMethods, paymentMethods]\n )\n\n const shortcutLabel = t('sales.documents.payments.saveShortcut', 'Save \u2318\u23CE / Ctrl+Enter')\n const renderStatusIcon = React.useCallback(\n (color?: string | null) => (\n <span\n className=\"h-2.5 w-2.5 rounded-full border border-border/70\"\n style={color ? { backgroundColor: color, borderColor: color } : undefined}\n />\n ),\n [],\n )\n\n const loadDocumentStatuses = React.useCallback(async (): Promise<StatusOption[]> => {\n setDocumentStatusLoading(true)\n try {\n const params = new URLSearchParams({ page: '1', pageSize: '100' })\n const response = await apiCall<{ items?: Array<Record<string, unknown>> }>(\n `/api/sales/order-statuses?${params.toString()}`,\n undefined,\n { fallback: { items: [] } },\n )\n const items = Array.isArray(response.result?.items) ? response.result.items : []\n const mapped = items\n .map((entry) => {\n const id = typeof entry.id === 'string' ? entry.id : null\n const value = typeof entry.value === 'string' ? entry.value : null\n if (!id || !value) return null\n const label =\n typeof entry.label === 'string' && entry.label.trim().length\n ? entry.label\n : value\n const color =\n typeof entry.color === 'string' && entry.color.trim().length ? entry.color : null\n return { id, value, label, color }\n })\n .filter((entry): entry is StatusOption => Boolean(entry))\n setDocumentStatuses(mapped)\n return mapped\n } catch (err) {\n console.error('sales.payments.statuses.load', err)\n setDocumentStatuses([])\n return []\n } finally {\n setDocumentStatusLoading(false)\n }\n }, [])\n\n const loadPaymentStatuses = React.useCallback(async (): Promise<StatusOption[]> => {\n setPaymentStatusLoading(true)\n try {\n const params = new URLSearchParams({ page: '1', pageSize: '100' })\n const response = await apiCall<{ items?: Array<Record<string, unknown>> }>(\n `/api/sales/payment-statuses?${params.toString()}`,\n undefined,\n { fallback: { items: [] } },\n )\n const items = Array.isArray(response.result?.items) ? response.result.items : []\n const mapped = items\n .map((entry) => {\n const id = typeof entry.id === 'string' ? entry.id : null\n const value = typeof entry.value === 'string' ? entry.value : null\n if (!id || !value) return null\n const label =\n typeof entry.label === 'string' && entry.label.trim().length\n ? entry.label\n : value\n const color =\n typeof entry.color === 'string' && entry.color.trim().length ? entry.color : null\n return { id, value, label, color }\n })\n .filter((entry): entry is StatusOption => Boolean(entry))\n setPaymentStatuses(mapped)\n return mapped\n } catch (err) {\n console.error('sales.payments.statuses.load', err)\n setPaymentStatuses([])\n return []\n } finally {\n setPaymentStatusLoading(false)\n }\n }, [])\n\n React.useEffect(() => {\n if (!open) return\n setFormResetKey((prev) => prev + 1)\n if (!paymentMethods.length) {\n void loadPaymentMethods()\n }\n if (!paymentStatuses.length) {\n void loadPaymentStatuses()\n }\n if (mode === 'create') {\n if (!documentStatuses.length) {\n void loadDocumentStatuses()\n }\n }\n }, [\n documentStatuses.length,\n loadDocumentStatuses,\n loadPaymentStatuses,\n loadPaymentMethods,\n mode,\n open,\n payment?.id,\n paymentStatuses.length,\n paymentMethods.length,\n ])\n\n const fetchDocumentStatusItems = React.useCallback(\n async (query?: string): Promise<LookupSelectItem[]> => {\n const options =\n documentStatuses.length && !query ? documentStatuses : await loadDocumentStatuses()\n const term = query?.trim().toLowerCase() ?? ''\n return options\n .filter(\n (option) =>\n !term.length ||\n option.label.toLowerCase().includes(term) ||\n option.value.toLowerCase().includes(term),\n )\n .map<LookupSelectItem>((option) => ({\n id: option.id,\n title: option.label,\n subtitle: option.value,\n icon: renderStatusIcon(option.color),\n }))\n },\n [documentStatuses, loadDocumentStatuses, renderStatusIcon],\n )\n\n const fetchPaymentStatusItems = React.useCallback(\n async (query?: string): Promise<LookupSelectItem[]> => {\n const options =\n paymentStatuses.length && !query ? paymentStatuses : await loadPaymentStatuses()\n const term = query?.trim().toLowerCase() ?? ''\n return options\n .filter(\n (option) =>\n !term.length ||\n option.label.toLowerCase().includes(term) ||\n option.value.toLowerCase().includes(term),\n )\n .map<LookupSelectItem>((option) => ({\n id: option.id,\n title: option.label,\n subtitle: option.value,\n icon: renderStatusIcon(option.color),\n }))\n },\n [loadPaymentStatuses, paymentStatuses, renderStatusIcon],\n )\n\n const fields = React.useMemo<CrudField[]>(\n () => [\n {\n id: 'amount',\n label: t('sales.documents.payments.amount', 'Amount'),\n type: 'custom',\n required: true,\n component: ({ value, setValue }) => {\n const normalized = typeof value === 'number' ? value : typeof value === 'string' ? value : ''\n return (\n <div className=\"flex items-center gap-2\">\n <Input\n type=\"number\"\n inputMode=\"decimal\"\n step=\"0.01\"\n value={normalized as string | number}\n onChange={(event) => setValue(event.target.value)}\n placeholder=\"0.00\"\n />\n <span className=\"rounded-full border border-border/70 bg-muted/50 px-3 py-1 text-xs font-semibold uppercase text-foreground\">\n {currencyLabel}\n </span>\n </div>\n )\n },\n },\n {\n id: 'paymentMethodId',\n label: t('sales.documents.payments.method', 'Method'),\n type: 'custom',\n component: ({ value, setValue }) => {\n const currentValue = typeof value === 'string' && value.length ? value : null\n return (\n <LookupSelect\n value={currentValue}\n onChange={(next) => setValue(next ?? '')}\n fetchItems={fetchPaymentMethodItems}\n searchPlaceholder={t('sales.documents.payments.methodPlaceholder', 'Search payment method')}\n emptyLabel={t('sales.documents.payments.methodsEmpty', 'No payment methods')}\n loadingLabel={t('sales.documents.payments.loadingMethods', 'Loading payment methods\u2026')}\n selectedHintLabel={(id) =>\n t('sales.documents.payments.methodSelected', 'Selected method: {{id}}', { id })\n }\n minQuery={0}\n />\n )\n },\n },\n {\n id: 'statusEntryId',\n label: t('sales.documents.payments.status', 'Status'),\n type: 'custom',\n component: ({ value, setValue }) => {\n const currentValue = typeof value === 'string' && value.length ? value : null\n return (\n <LookupSelect\n value={currentValue}\n onChange={(next) => setValue(next ?? '')}\n fetchItems={fetchPaymentStatusItems}\n placeholder={t('sales.documents.payments.statusPlaceholder', 'Select status')}\n loading={paymentStatusLoading}\n minQuery={0}\n />\n )\n },\n },\n ...(mode === 'create'\n ? ([\n {\n id: 'documentStatusEntryId',\n label: t('sales.documents.status.changeDocument', 'Change order/quote status'),\n type: 'custom',\n component: ({ value, setValue }) => {\n const currentValue = typeof value === 'string' && value.length ? value : null\n return (\n <LookupSelect\n value={currentValue}\n onChange={(next) => setValue(next ?? '')}\n fetchItems={fetchDocumentStatusItems}\n placeholder={t(\n 'sales.documents.status.documentPlaceholder',\n 'Select new order/quote status',\n )}\n loading={documentStatusLoading}\n minQuery={0}\n />\n )\n },\n },\n ] as CrudField[])\n : []),\n {\n id: 'paymentReference',\n label: t('sales.documents.payments.reference', 'Reference'),\n type: 'text',\n placeholder: t('sales.documents.payments.referencePlaceholder', 'External reference or note'),\n },\n {\n id: 'receivedAt',\n label: t('sales.documents.payments.receivedAt', 'Received at'),\n type: 'date',\n },\n ],\n [\n currencyLabel,\n documentStatusLoading,\n fetchPaymentStatusItems,\n fetchDocumentStatusItems,\n fetchPaymentMethodItems,\n paymentStatusLoading,\n mode,\n t,\n ],\n )\n\n const groups = React.useMemo<CrudFormGroup[]>(\n () => {\n const base: CrudFormGroup[] = [\n {\n id: 'paymentDetails',\n title: t('sales.documents.payments.form.title', 'Payment details'),\n column: 1,\n fields: ['amount', 'paymentMethodId', 'statusEntryId'],\n },\n ]\n if (mode === 'create') {\n base.push({\n id: 'statusChanges',\n title: t('sales.documents.status.sectionTitle', 'Status changes'),\n column: 1,\n fields: ['documentStatusEntryId'],\n })\n }\n base.push({\n id: 'paymentReference',\n title: t('sales.documents.payments.reference', 'Reference'),\n column: 2,\n fields: ['paymentReference', 'receivedAt'],\n })\n base.push({\n id: 'paymentCustomFields',\n title: t('entities.customFields.title', 'Custom fields'),\n column: 2,\n kind: 'customFields',\n })\n return base\n },\n [mode, t],\n )\n\n const handleSubmit = React.useCallback(\n async (values: Record<string, unknown>) => {\n const resolvedCurrency = currencyCode ? currencyCode.toUpperCase() : ''\n const amountValue = normalizeNumber(values.amount)\n if (!resolvedCurrency.trim()) {\n throw createCrudFormError(t('sales.documents.payments.currencyRequired', 'Currency is required.'))\n }\n if (amountValue <= 0) {\n throw createCrudFormError(t('sales.documents.payments.amountRequired', 'Enter a positive amount.'), {\n amount: t('sales.documents.payments.amountRequired', 'Enter a positive amount.'),\n })\n }\n\n const payload: Record<string, unknown> = {\n orderId,\n amount: amountValue,\n currencyCode: resolvedCurrency,\n paymentReference:\n typeof values.paymentReference === 'string' && values.paymentReference.trim().length\n ? values.paymentReference.trim()\n : undefined,\n paymentMethodId:\n typeof values.paymentMethodId === 'string' && values.paymentMethodId.trim().length\n ? values.paymentMethodId\n : undefined,\n statusEntryId:\n typeof values.statusEntryId === 'string' && values.statusEntryId.trim().length\n ? values.statusEntryId\n : undefined,\n customFieldSetId:\n typeof values.customFieldSetId === 'string' && values.customFieldSetId.trim().length\n ? values.customFieldSetId.trim()\n : undefined,\n organizationId: organizationId ?? undefined,\n tenantId: tenantId ?? undefined,\n }\n const documentStatusEntryId =\n typeof values.documentStatusEntryId === 'string' && values.documentStatusEntryId.trim().length\n ? values.documentStatusEntryId\n : null\n if (documentStatusEntryId) {\n payload.documentStatusEntryId = documentStatusEntryId\n }\n if (typeof values.receivedAt === 'string' && values.receivedAt.trim().length) {\n payload.receivedAt = new Date(values.receivedAt)\n }\n const customFields = collectCustomFieldValues(values, {\n transform: normalizeCustomFieldSubmitValue,\n })\n if (Object.keys(customFields).length) payload.customFields = customFields\n\n const action = payment?.id ? updateCrud : createCrud\n const result = await action(\n 'sales/payments',\n payment?.id ? { id: payment.id, ...payload } : payload,\n {\n errorMessage: t('sales.documents.payments.errorSave', 'Failed to save payment.'),\n }\n )\n if (result.ok) {\n const totals = (result.result as any)?.orderTotals as PaymentTotals | undefined\n if (onSaved) {\n await onSaved(totals ?? null)\n }\n setFormResetKey((prev) => prev + 1)\n onOpenChange(false)\n }\n },\n [currencyCode, mode, onOpenChange, onSaved, orderId, organizationId, payment?.id, t, tenantId]\n )\n\n const handleShortcutSubmit = React.useCallback(\n (event: React.KeyboardEvent<HTMLDivElement>) => {\n if ((event.metaKey || event.ctrlKey) && event.key === 'Enter') {\n event.preventDefault()\n const form = dialogContentRef.current?.querySelector('form')\n form?.requestSubmit()\n }\n },\n []\n )\n\n return (\n <Dialog open={open} onOpenChange={onOpenChange}>\n <DialogContent\n ref={dialogContentRef}\n className=\"sm:max-w-5xl\"\n onKeyDown={(event) => {\n if (event.key === 'Escape') {\n event.preventDefault()\n onOpenChange(false)\n }\n handleShortcutSubmit(event)\n }}\n >\n <DialogHeader>\n <DialogTitle>\n {mode === 'edit'\n ? t('sales.documents.payments.edit', 'Edit payment')\n : t('sales.documents.payments.add', 'Add payment')}\n </DialogTitle>\n </DialogHeader>\n <CrudForm\n key={formResetKey}\n embedded\n entityId={E.sales.sales_payment}\n fields={fields}\n groups={groups}\n initialValues={initialValues}\n customFieldsetBindings={{ [E.sales.sales_payment]: { valueKey: 'customFieldSetId' } }}\n submitLabel={shortcutLabel}\n onSubmit={handleSubmit}\n loadingMessage={t('sales.documents.payments.loading', 'Loading payments\u2026')}\n customFieldsLoadingMessage={t('ui.forms.loading', 'Loading data...')}\n contentHeader={\n methodsLoading ? (\n <p className=\"flex items-center gap-2 text-xs text-muted-foreground\">\n <Spinner className=\"h-3.5 w-3.5 animate-spin\" />\n {t('sales.documents.payments.loadingMethods', 'Loading payment methods\u2026')}\n </p>\n ) : null\n }\n />\n </DialogContent>\n </Dialog>\n )\n}\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["\"use client\"\n\nimport * as React from 'react'\nimport { CreditCard } from 'lucide-react'\nimport { CrudForm, type CrudField, type CrudFormGroup } from '@open-mercato/ui/backend/CrudForm'\nimport { LookupSelect, type LookupSelectItem } from '@open-mercato/ui/backend/inputs'\nimport { apiCall } from '@open-mercato/ui/backend/utils/apiCall'\nimport { collectCustomFieldValues } from '@open-mercato/ui/backend/utils/customFieldValues'\nimport { createCrud, updateCrud } from '@open-mercato/ui/backend/utils/crud'\nimport { createCrudFormError } from '@open-mercato/ui/backend/utils/serverErrors'\nimport { Dialog, DialogContent, DialogHeader, DialogTitle } from '@open-mercato/ui/primitives/dialog'\nimport { useDialogKeyHandler } from '@open-mercato/ui/hooks/useDialogKeyHandler'\nimport { Input } from '@open-mercato/ui/primitives/input'\nimport { Spinner } from '@open-mercato/ui/primitives/spinner'\nimport { E } from '#generated/entities.ids.generated'\nimport { useT } from '@open-mercato/shared/lib/i18n/context'\nimport { normalizeCustomFieldSubmitValue, extractCustomFieldValues } from './customFieldHelpers'\n\nexport type PaymentTotals = {\n paidTotalAmount?: number | null\n refundedTotalAmount?: number | null\n outstandingAmount?: number | null\n}\n\nexport type PaymentFormData = {\n id?: string | null\n amount?: number | string | null\n paymentMethodId?: string | null\n paymentReference?: string | null\n receivedAt?: string | null\n currencyCode?: string | null\n statusEntryId?: string | null\n customValues?: Record<string, unknown> | null\n customFieldSetId?: string | null\n}\n\ntype PaymentMethodOption = {\n id: string\n name: string\n code: string\n}\n\ntype StatusOption = {\n id: string\n value: string\n label: string\n color: string | null\n}\n\ntype PaymentDialogProps = {\n open: boolean\n mode: 'create' | 'edit'\n payment?: PaymentFormData | null\n currencyCode: string | null | undefined\n orderId: string\n organizationId: string | null\n tenantId: string | null\n onOpenChange: (open: boolean) => void\n onSaved?: (totals?: PaymentTotals | null) => void | Promise<void>\n}\n\nconst normalizeNumber = (value: unknown): number => {\n if (typeof value === 'number' && Number.isFinite(value)) return value\n if (typeof value === 'string' && value.trim().length) {\n const parsed = Number(value)\n if (!Number.isNaN(parsed)) return parsed\n }\n return 0\n}\n\nexport function PaymentDialog({\n open,\n mode,\n payment,\n currencyCode,\n orderId,\n organizationId,\n tenantId,\n onOpenChange,\n onSaved,\n}: PaymentDialogProps) {\n const t = useT()\n const dialogContentRef = React.useRef<HTMLDivElement | null>(null)\n const [formResetKey, setFormResetKey] = React.useState(0)\n const [paymentMethods, setPaymentMethods] = React.useState<PaymentMethodOption[]>([])\n const [methodsLoading, setMethodsLoading] = React.useState(false)\n const [paymentStatuses, setPaymentStatuses] = React.useState<StatusOption[]>([])\n const [paymentStatusLoading, setPaymentStatusLoading] = React.useState(false)\n const [documentStatuses, setDocumentStatuses] = React.useState<StatusOption[]>([])\n const [documentStatusLoading, setDocumentStatusLoading] = React.useState(false)\n\n const currencyLabel = React.useMemo(() => {\n const code = currencyCode ? currencyCode.toUpperCase() : ''\n if (!code) return t('sales.documents.detail.empty', 'Not set')\n return code\n }, [currencyCode, t])\n\n const initialValues = React.useMemo(\n () => ({\n amount: payment?.amount ?? '',\n paymentMethodId: payment?.paymentMethodId ?? '',\n paymentReference: payment?.paymentReference ?? '',\n receivedAt: payment?.receivedAt ? payment.receivedAt.slice(0, 10) : '',\n statusEntryId: payment?.statusEntryId ?? '',\n documentStatusEntryId: '',\n customFieldSetId: payment?.customFieldSetId ?? '',\n ...extractCustomFieldValues(payment),\n }),\n [\n payment?.amount,\n payment?.customFieldSetId,\n payment?.customValues,\n payment?.paymentMethodId,\n payment?.paymentReference,\n payment?.receivedAt,\n payment?.statusEntryId,\n ],\n )\n\n const loadPaymentMethods = React.useCallback(\n async (query?: string): Promise<PaymentMethodOption[]> => {\n setMethodsLoading(true)\n try {\n const params = new URLSearchParams({ page: '1', pageSize: '100', isActive: 'true' })\n if (query && query.trim().length) params.set('search', query.trim())\n const response = await apiCall<{ items?: Array<Record<string, unknown>> }>(\n `/api/sales/payment-methods?${params.toString()}`,\n undefined,\n { fallback: { items: [] } }\n )\n if (response.ok && Array.isArray(response.result?.items)) {\n const options = response.result.items\n .map((item) => {\n const id = typeof item.id === 'string' ? item.id : null\n if (!id) return null\n const name = typeof item.name === 'string' ? item.name : null\n const code = typeof item.code === 'string' ? item.code : null\n return {\n id,\n name: name ?? code ?? id,\n code: code ?? id,\n }\n })\n .filter((entry): entry is PaymentMethodOption => !!entry)\n if (!query) setPaymentMethods(options)\n return options\n }\n if (!query) setPaymentMethods([])\n return []\n } catch (err) {\n console.error('sales.payments.methods.load', err)\n return []\n } finally {\n setMethodsLoading(false)\n }\n },\n []\n )\n\n const fetchPaymentMethodItems = React.useCallback(\n async (query?: string): Promise<LookupSelectItem[]> => {\n const options =\n paymentMethods.length && !query\n ? paymentMethods\n : await loadPaymentMethods(query)\n const term = query?.trim().toLowerCase() ?? ''\n return options\n .filter(\n (option) =>\n !term.length ||\n option.name.toLowerCase().includes(term) ||\n option.code.toLowerCase().includes(term)\n )\n .map<LookupSelectItem>((option) => ({\n id: option.id,\n title: option.name,\n subtitle: option.code,\n icon: <CreditCard className=\"h-4 w-4 text-muted-foreground\" />,\n }))\n },\n [loadPaymentMethods, paymentMethods]\n )\n\n const shortcutLabel = t('sales.documents.payments.saveShortcut', 'Save \u2318\u23CE / Ctrl+Enter')\n const renderStatusIcon = React.useCallback(\n (color?: string | null) => (\n <span\n className=\"h-2.5 w-2.5 rounded-full border border-border/70\"\n style={color ? { backgroundColor: color, borderColor: color } : undefined}\n />\n ),\n [],\n )\n\n const loadDocumentStatuses = React.useCallback(async (): Promise<StatusOption[]> => {\n setDocumentStatusLoading(true)\n try {\n const params = new URLSearchParams({ page: '1', pageSize: '100' })\n const response = await apiCall<{ items?: Array<Record<string, unknown>> }>(\n `/api/sales/order-statuses?${params.toString()}`,\n undefined,\n { fallback: { items: [] } },\n )\n const items = Array.isArray(response.result?.items) ? response.result.items : []\n const mapped = items\n .map((entry) => {\n const id = typeof entry.id === 'string' ? entry.id : null\n const value = typeof entry.value === 'string' ? entry.value : null\n if (!id || !value) return null\n const label =\n typeof entry.label === 'string' && entry.label.trim().length\n ? entry.label\n : value\n const color =\n typeof entry.color === 'string' && entry.color.trim().length ? entry.color : null\n return { id, value, label, color }\n })\n .filter((entry): entry is StatusOption => Boolean(entry))\n setDocumentStatuses(mapped)\n return mapped\n } catch (err) {\n console.error('sales.payments.statuses.load', err)\n setDocumentStatuses([])\n return []\n } finally {\n setDocumentStatusLoading(false)\n }\n }, [])\n\n const loadPaymentStatuses = React.useCallback(async (): Promise<StatusOption[]> => {\n setPaymentStatusLoading(true)\n try {\n const params = new URLSearchParams({ page: '1', pageSize: '100' })\n const response = await apiCall<{ items?: Array<Record<string, unknown>> }>(\n `/api/sales/payment-statuses?${params.toString()}`,\n undefined,\n { fallback: { items: [] } },\n )\n const items = Array.isArray(response.result?.items) ? response.result.items : []\n const mapped = items\n .map((entry) => {\n const id = typeof entry.id === 'string' ? entry.id : null\n const value = typeof entry.value === 'string' ? entry.value : null\n if (!id || !value) return null\n const label =\n typeof entry.label === 'string' && entry.label.trim().length\n ? entry.label\n : value\n const color =\n typeof entry.color === 'string' && entry.color.trim().length ? entry.color : null\n return { id, value, label, color }\n })\n .filter((entry): entry is StatusOption => Boolean(entry))\n setPaymentStatuses(mapped)\n return mapped\n } catch (err) {\n console.error('sales.payments.statuses.load', err)\n setPaymentStatuses([])\n return []\n } finally {\n setPaymentStatusLoading(false)\n }\n }, [])\n\n React.useEffect(() => {\n if (!open) return\n setFormResetKey((prev) => prev + 1)\n if (!paymentMethods.length) {\n void loadPaymentMethods()\n }\n if (!paymentStatuses.length) {\n void loadPaymentStatuses()\n }\n if (mode === 'create') {\n if (!documentStatuses.length) {\n void loadDocumentStatuses()\n }\n }\n }, [\n documentStatuses.length,\n loadDocumentStatuses,\n loadPaymentStatuses,\n loadPaymentMethods,\n mode,\n open,\n payment?.id,\n paymentStatuses.length,\n paymentMethods.length,\n ])\n\n const fetchDocumentStatusItems = React.useCallback(\n async (query?: string): Promise<LookupSelectItem[]> => {\n const options =\n documentStatuses.length && !query ? documentStatuses : await loadDocumentStatuses()\n const term = query?.trim().toLowerCase() ?? ''\n return options\n .filter(\n (option) =>\n !term.length ||\n option.label.toLowerCase().includes(term) ||\n option.value.toLowerCase().includes(term),\n )\n .map<LookupSelectItem>((option) => ({\n id: option.id,\n title: option.label,\n subtitle: option.value,\n icon: renderStatusIcon(option.color),\n }))\n },\n [documentStatuses, loadDocumentStatuses, renderStatusIcon],\n )\n\n const fetchPaymentStatusItems = React.useCallback(\n async (query?: string): Promise<LookupSelectItem[]> => {\n const options =\n paymentStatuses.length && !query ? paymentStatuses : await loadPaymentStatuses()\n const term = query?.trim().toLowerCase() ?? ''\n return options\n .filter(\n (option) =>\n !term.length ||\n option.label.toLowerCase().includes(term) ||\n option.value.toLowerCase().includes(term),\n )\n .map<LookupSelectItem>((option) => ({\n id: option.id,\n title: option.label,\n subtitle: option.value,\n icon: renderStatusIcon(option.color),\n }))\n },\n [loadPaymentStatuses, paymentStatuses, renderStatusIcon],\n )\n\n const fields = React.useMemo<CrudField[]>(\n () => [\n {\n id: 'amount',\n label: t('sales.documents.payments.amount', 'Amount'),\n type: 'custom',\n required: true,\n component: ({ value, setValue }) => {\n const normalized = typeof value === 'number' ? value : typeof value === 'string' ? value : ''\n return (\n <div className=\"flex items-center gap-2\">\n <Input\n type=\"number\"\n inputMode=\"decimal\"\n step=\"0.01\"\n value={normalized as string | number}\n onChange={(event) => setValue(event.target.value)}\n placeholder=\"0.00\"\n />\n <span className=\"rounded-full border border-border/70 bg-muted/50 px-3 py-1 text-xs font-semibold uppercase text-foreground\">\n {currencyLabel}\n </span>\n </div>\n )\n },\n },\n {\n id: 'paymentMethodId',\n label: t('sales.documents.payments.method', 'Method'),\n type: 'custom',\n component: ({ value, setValue }) => {\n const currentValue = typeof value === 'string' && value.length ? value : null\n return (\n <LookupSelect\n value={currentValue}\n onChange={(next) => setValue(next ?? '')}\n fetchItems={fetchPaymentMethodItems}\n searchPlaceholder={t('sales.documents.payments.methodPlaceholder', 'Search payment method')}\n emptyLabel={t('sales.documents.payments.methodsEmpty', 'No payment methods')}\n loadingLabel={t('sales.documents.payments.loadingMethods', 'Loading payment methods\u2026')}\n selectedHintLabel={(id) =>\n t('sales.documents.payments.methodSelected', 'Selected method: {{id}}', { id })\n }\n minQuery={0}\n />\n )\n },\n },\n {\n id: 'statusEntryId',\n label: t('sales.documents.payments.status', 'Status'),\n type: 'custom',\n component: ({ value, setValue }) => {\n const currentValue = typeof value === 'string' && value.length ? value : null\n return (\n <LookupSelect\n value={currentValue}\n onChange={(next) => setValue(next ?? '')}\n fetchItems={fetchPaymentStatusItems}\n placeholder={t('sales.documents.payments.statusPlaceholder', 'Select status')}\n loading={paymentStatusLoading}\n minQuery={0}\n />\n )\n },\n },\n ...(mode === 'create'\n ? ([\n {\n id: 'documentStatusEntryId',\n label: t('sales.documents.status.changeDocument', 'Change order/quote status'),\n type: 'custom',\n component: ({ value, setValue }) => {\n const currentValue = typeof value === 'string' && value.length ? value : null\n return (\n <LookupSelect\n value={currentValue}\n onChange={(next) => setValue(next ?? '')}\n fetchItems={fetchDocumentStatusItems}\n placeholder={t(\n 'sales.documents.status.documentPlaceholder',\n 'Select new order/quote status',\n )}\n loading={documentStatusLoading}\n minQuery={0}\n />\n )\n },\n },\n ] as CrudField[])\n : []),\n {\n id: 'paymentReference',\n label: t('sales.documents.payments.reference', 'Reference'),\n type: 'text',\n placeholder: t('sales.documents.payments.referencePlaceholder', 'External reference or note'),\n },\n {\n id: 'receivedAt',\n label: t('sales.documents.payments.receivedAt', 'Received at'),\n type: 'date',\n },\n ],\n [\n currencyLabel,\n documentStatusLoading,\n fetchPaymentStatusItems,\n fetchDocumentStatusItems,\n fetchPaymentMethodItems,\n paymentStatusLoading,\n mode,\n t,\n ],\n )\n\n const groups = React.useMemo<CrudFormGroup[]>(\n () => {\n const base: CrudFormGroup[] = [\n {\n id: 'paymentDetails',\n title: t('sales.documents.payments.form.title', 'Payment details'),\n column: 1,\n fields: ['amount', 'paymentMethodId', 'statusEntryId'],\n },\n ]\n if (mode === 'create') {\n base.push({\n id: 'statusChanges',\n title: t('sales.documents.status.sectionTitle', 'Status changes'),\n column: 1,\n fields: ['documentStatusEntryId'],\n })\n }\n base.push({\n id: 'paymentReference',\n title: t('sales.documents.payments.reference', 'Reference'),\n column: 2,\n fields: ['paymentReference', 'receivedAt'],\n })\n base.push({\n id: 'paymentCustomFields',\n title: t('entities.customFields.title', 'Custom fields'),\n column: 2,\n kind: 'customFields',\n })\n return base\n },\n [mode, t],\n )\n\n const handleSubmit = React.useCallback(\n async (values: Record<string, unknown>) => {\n const resolvedCurrency = currencyCode ? currencyCode.toUpperCase() : ''\n const amountValue = normalizeNumber(values.amount)\n if (!resolvedCurrency.trim()) {\n throw createCrudFormError(t('sales.documents.payments.currencyRequired', 'Currency is required.'))\n }\n if (amountValue <= 0) {\n throw createCrudFormError(t('sales.documents.payments.amountRequired', 'Enter a positive amount.'), {\n amount: t('sales.documents.payments.amountRequired', 'Enter a positive amount.'),\n })\n }\n\n const payload: Record<string, unknown> = {\n orderId,\n amount: amountValue,\n currencyCode: resolvedCurrency,\n paymentReference:\n typeof values.paymentReference === 'string' && values.paymentReference.trim().length\n ? values.paymentReference.trim()\n : undefined,\n paymentMethodId:\n typeof values.paymentMethodId === 'string' && values.paymentMethodId.trim().length\n ? values.paymentMethodId\n : undefined,\n statusEntryId:\n typeof values.statusEntryId === 'string' && values.statusEntryId.trim().length\n ? values.statusEntryId\n : undefined,\n customFieldSetId:\n typeof values.customFieldSetId === 'string' && values.customFieldSetId.trim().length\n ? values.customFieldSetId.trim()\n : undefined,\n organizationId: organizationId ?? undefined,\n tenantId: tenantId ?? undefined,\n }\n const documentStatusEntryId =\n typeof values.documentStatusEntryId === 'string' && values.documentStatusEntryId.trim().length\n ? values.documentStatusEntryId\n : null\n if (documentStatusEntryId) {\n payload.documentStatusEntryId = documentStatusEntryId\n }\n if (typeof values.receivedAt === 'string' && values.receivedAt.trim().length) {\n payload.receivedAt = new Date(values.receivedAt)\n }\n const customFields = collectCustomFieldValues(values, {\n transform: normalizeCustomFieldSubmitValue,\n })\n if (Object.keys(customFields).length) payload.customFields = customFields\n\n const action = payment?.id ? updateCrud : createCrud\n const result = await action(\n 'sales/payments',\n payment?.id ? { id: payment.id, ...payload } : payload,\n {\n errorMessage: t('sales.documents.payments.errorSave', 'Failed to save payment.'),\n }\n )\n if (result.ok) {\n const totals = (result.result as any)?.orderTotals as PaymentTotals | undefined\n if (onSaved) {\n await onSaved(totals ?? null)\n }\n setFormResetKey((prev) => prev + 1)\n onOpenChange(false)\n }\n },\n [currencyCode, mode, onOpenChange, onSaved, orderId, organizationId, payment?.id, t, tenantId]\n )\n\n const handleSubmitForm = React.useCallback(\n () => dialogContentRef.current?.querySelector('form')?.requestSubmit(),\n [],\n )\n const handleKeyDown = useDialogKeyHandler({\n onConfirm: handleSubmitForm,\n onCancel: () => onOpenChange(false),\n })\n\n return (\n <Dialog open={open} onOpenChange={onOpenChange}>\n <DialogContent\n ref={dialogContentRef}\n className=\"sm:max-w-5xl\"\n onKeyDown={handleKeyDown}\n >\n <DialogHeader>\n <DialogTitle>\n {mode === 'edit'\n ? t('sales.documents.payments.edit', 'Edit payment')\n : t('sales.documents.payments.add', 'Add payment')}\n </DialogTitle>\n </DialogHeader>\n <CrudForm\n key={formResetKey}\n embedded\n entityId={E.sales.sales_payment}\n fields={fields}\n groups={groups}\n initialValues={initialValues}\n customFieldsetBindings={{ [E.sales.sales_payment]: { valueKey: 'customFieldSetId' } }}\n submitLabel={shortcutLabel}\n onSubmit={handleSubmit}\n loadingMessage={t('sales.documents.payments.loading', 'Loading payments\u2026')}\n customFieldsLoadingMessage={t('ui.forms.loading', 'Loading data...')}\n contentHeader={\n methodsLoading ? (\n <p className=\"flex items-center gap-2 text-xs text-muted-foreground\">\n <Spinner className=\"h-3.5 w-3.5 animate-spin\" />\n {t('sales.documents.payments.loadingMethods', 'Loading payment methods\u2026')}\n </p>\n ) : null\n }\n />\n </DialogContent>\n </Dialog>\n )\n}\n"],
5
+ "mappings": "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",
6
6
  "names": []
7
7
  }
@@ -3,6 +3,7 @@ import { jsx, jsxs } from "react/jsx-runtime";
3
3
  import * as React from "react";
4
4
  import { MapPin, Truck } from "lucide-react";
5
5
  import { Dialog, DialogContent, DialogHeader, DialogTitle } from "@open-mercato/ui/primitives/dialog";
6
+ import { useDialogKeyHandler } from "@open-mercato/ui/hooks/useDialogKeyHandler";
6
7
  import { Input } from "@open-mercato/ui/primitives/input";
7
8
  import { Textarea } from "@open-mercato/ui/primitives/textarea";
8
9
  import { Label } from "@open-mercato/ui/primitives/label";
@@ -841,13 +842,14 @@ function ShipmentDialog({
841
842
  validateItems
842
843
  ]
843
844
  );
844
- const handleShortcutSubmit = React.useCallback((event) => {
845
- if ((event.metaKey || event.ctrlKey) && event.key === "Enter") {
846
- event.preventDefault();
847
- const form = dialogContentRef.current?.querySelector("form");
848
- form?.requestSubmit();
849
- }
850
- }, []);
845
+ const handleSubmitForm = React.useCallback(
846
+ () => dialogContentRef.current?.querySelector("form")?.requestSubmit(),
847
+ []
848
+ );
849
+ const handleKeyDown = useDialogKeyHandler({
850
+ onConfirm: handleSubmitForm,
851
+ onCancel: onClose
852
+ });
851
853
  const fields = React.useMemo(() => {
852
854
  const shippingAdjustmentLabel = t(
853
855
  "sales.documents.shipments.addShippingAdjustment",
@@ -1234,13 +1236,7 @@ function ShipmentDialog({
1234
1236
  {
1235
1237
  ref: dialogContentRef,
1236
1238
  className: "sm:max-w-5xl",
1237
- onKeyDown: (event) => {
1238
- if (event.key === "Escape") {
1239
- event.preventDefault();
1240
- onClose();
1241
- }
1242
- handleShortcutSubmit(event);
1243
- },
1239
+ onKeyDown: handleKeyDown,
1244
1240
  children: [
1245
1241
  /* @__PURE__ */ jsx(DialogHeader, { children: /* @__PURE__ */ jsx(DialogTitle, { children: mode === "edit" ? t("sales.documents.shipments.editTitle", "Edit shipment") : t("sales.documents.shipments.addTitle", "Add shipment") }) }),
1246
1242
  /* @__PURE__ */ jsx(