@voyantjs/bookings-ui 0.50.2 → 0.50.4

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.
package/README.md CHANGED
@@ -34,6 +34,7 @@ surfaces app-owned through typed slots:
34
34
  id={bookingId}
35
35
  slots={{
36
36
  actionBar: ({ booking }) => <button type="button">Assign {booking.bookingNumber}</button>,
37
+ bookingTab: ({ booking }) => <BookingOverviewPanel booking={booking} />,
37
38
  financeSidebar: ({ bookingId }) => <FinanceStatusCard bookingId={bookingId} />,
38
39
  legalTab: ({ bookingId }) => <ContractChecklist bookingId={bookingId} />,
39
40
  travelersTabExtensions: ({ bulkActions }) => (
@@ -46,7 +47,10 @@ surfaces app-owned through typed slots:
46
47
 
47
48
  Slot render functions receive the booking, active workspace section, section
48
49
  setter, and bulk-action state for traveler and finance selections. Use
49
- `bookingDetailSlots` to pass slots through to the mounted `BookingDetailPage`.
50
+ `bookingTab` when an app wants to use top-level finance, legal, traveler, or
51
+ activity tabs without nesting the default `BookingDetailPage` tabs. When
52
+ `bookingTab` is omitted, the workspace keeps mounting `BookingDetailPage`; use
53
+ `bookingDetailSlots` to pass slots through to that default detail page.
50
54
 
51
55
  ## I18n
52
56
 
@@ -32,6 +32,7 @@ export interface BookingWorkspacePageSlots {
32
32
  legalSidebar?: (context: BookingWorkspaceSlotContext) => ReactNode;
33
33
  travelersSidebar?: (context: BookingWorkspaceSlotContext) => ReactNode;
34
34
  activitySidebar?: (context: BookingWorkspaceSlotContext) => ReactNode;
35
+ bookingTab?: (context: BookingWorkspaceSlotContext) => ReactNode;
35
36
  financeTab?: (context: BookingWorkspaceSlotContext) => ReactNode;
36
37
  legalTab?: (context: BookingWorkspaceSlotContext) => ReactNode;
37
38
  travelersTabExtensions?: (context: BookingWorkspaceSlotContext) => ReactNode;
@@ -1 +1 @@
1
- {"version":3,"file":"booking-workspace-page.d.ts","sourceRoot":"","sources":["../../src/components/booking-workspace-page.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"booking-workspace-page.d.ts","sourceRoot":"","sources":["../../src/components/booking-workspace-page.tsx"],"names":[],"mappings":"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"}
@@ -61,7 +61,7 @@ export function BookingWorkspaceShell({ id, className, locale, defaultSection =
61
61
  const items = navigationItems ?? getDefaultNavigationItems(workspaceMessages.tabs);
62
62
  const sidebar = renderSidebar(activeSection, slots, context);
63
63
  const hasSidebar = Boolean(sidebar);
64
- return (_jsx(BookingWorkspaceBulkActionsContext.Provider, { value: bulkActions, children: _jsxs("div", { "data-slot": "booking-workspace-page", className: cn("flex flex-col gap-5 p-6", className), children: [_jsx(WorkspaceHeader, { title: booking.bookingNumber, description: workspaceMessages.description, onBack: onBack, actions: slots?.actionBar?.(context) }), slots?.bulkActionBar?.(context), _jsxs(Tabs, { value: activeSection, onValueChange: (value) => setActiveSection(value), className: "flex min-w-0 flex-col gap-5", children: [_jsx("div", { className: "overflow-x-auto", children: _jsx(TabsList, { className: "h-auto min-w-max justify-start", children: items.map((item) => (_jsxs(TabsTrigger, { value: item.value, disabled: item.disabled, className: "gap-2", children: [_jsx(WorkspaceTabIcon, { section: item.value }), _jsx("span", { children: item.label }), item.badge] }, item.value))) }) }), slots?.afterNavigation?.(context), _jsxs("div", { className: cn("grid min-w-0 gap-6", hasSidebar ? "xl:grid-cols-[minmax(0,1fr)_320px]" : "xl:grid-cols-1"), children: [_jsxs("div", { className: "min-w-0", children: [_jsx(TabsContent, { value: "booking", className: "mt-0", children: _jsx(BookingDetailPage, { id: bookingId, className: "p-0", locale: locale, onBack: onBack, onPersonOpen: onPersonOpen, onOrganizationOpen: onOrganizationOpen, onCollectPayment: onCollectPayment, slots: bookingDetailSlots }) }), _jsx(TabsContent, { value: "finance", className: "mt-0", children: renderTabSlot(slots?.financeTab, context, workspaceMessages.empty.finance) }), _jsx(TabsContent, { value: "legal", className: "mt-0", children: renderTabSlot(slots?.legalTab, context, workspaceMessages.empty.legal) }), _jsx(TabsContent, { value: "travelers", className: "mt-0", children: renderTabSlot(slots?.travelersTabExtensions, context, workspaceMessages.empty.travelers) }), _jsx(TabsContent, { value: "activity", className: "mt-0", children: renderTabSlot(slots?.activityTab, context, workspaceMessages.empty.activity) })] }), hasSidebar ? (_jsx("aside", { "data-slot": "booking-workspace-sidebar", className: "flex min-w-0 flex-col gap-4", children: sidebar })) : null] })] })] }) }));
64
+ return (_jsx(BookingWorkspaceBulkActionsContext.Provider, { value: bulkActions, children: _jsxs("div", { "data-slot": "booking-workspace-page", className: cn("flex flex-col gap-5 p-6", className), children: [_jsx(WorkspaceHeader, { title: booking.bookingNumber, description: workspaceMessages.description, onBack: onBack, actions: slots?.actionBar?.(context) }), slots?.bulkActionBar?.(context), _jsxs(Tabs, { value: activeSection, onValueChange: (value) => setActiveSection(value), className: "flex min-w-0 flex-col gap-5", children: [_jsx("div", { className: "overflow-x-auto", children: _jsx(TabsList, { className: "h-auto min-w-max justify-start", children: items.map((item) => (_jsxs(TabsTrigger, { value: item.value, disabled: item.disabled, className: "gap-2", children: [_jsx(WorkspaceTabIcon, { section: item.value }), _jsx("span", { children: item.label }), item.badge] }, item.value))) }) }), slots?.afterNavigation?.(context), _jsxs("div", { className: cn("grid min-w-0 gap-6", hasSidebar ? "xl:grid-cols-[minmax(0,1fr)_320px]" : "xl:grid-cols-1"), children: [_jsxs("div", { className: "min-w-0", children: [_jsx(TabsContent, { value: "booking", className: "mt-0", children: slots?.bookingTab ? (slots.bookingTab(context)) : (_jsx(BookingDetailPage, { id: bookingId, className: "p-0", locale: locale, onBack: onBack, onPersonOpen: onPersonOpen, onOrganizationOpen: onOrganizationOpen, onCollectPayment: onCollectPayment, slots: bookingDetailSlots })) }), _jsx(TabsContent, { value: "finance", className: "mt-0", children: renderTabSlot(slots?.financeTab, context, workspaceMessages.empty.finance) }), _jsx(TabsContent, { value: "legal", className: "mt-0", children: renderTabSlot(slots?.legalTab, context, workspaceMessages.empty.legal) }), _jsx(TabsContent, { value: "travelers", className: "mt-0", children: renderTabSlot(slots?.travelersTabExtensions, context, workspaceMessages.empty.travelers) }), _jsx(TabsContent, { value: "activity", className: "mt-0", children: renderTabSlot(slots?.activityTab, context, workspaceMessages.empty.activity) })] }), hasSidebar ? (_jsx("aside", { "data-slot": "booking-workspace-sidebar", className: "flex min-w-0 flex-col gap-4", children: sidebar })) : null] })] })] }) }));
65
65
  }
66
66
  function WorkspaceHeader({ title, description, onBack, actions, }) {
67
67
  return (_jsxs("div", { "data-slot": "booking-workspace-header", className: "flex flex-col gap-4 border-b pb-4 sm:flex-row sm:items-start sm:justify-between", children: [_jsxs("div", { className: "min-w-0 space-y-1", children: [_jsxs("div", { className: "flex min-w-0 items-center gap-2", children: [onBack ? (_jsxs(Button, { type: "button", variant: "ghost", size: "icon-sm", onClick: onBack, children: [_jsx(ArrowLeft, { className: "size-4", "aria-hidden": "true" }), _jsx("span", { className: "sr-only", children: "Back" })] })) : null, _jsx("h1", { className: "truncate text-2xl font-semibold tracking-tight", children: title })] }), description ? _jsx("p", { className: "text-sm text-muted-foreground", children: description }) : null] }), actions ? _jsx("div", { className: "flex flex-wrap items-center gap-2", children: actions }) : null] }));
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@voyantjs/bookings-ui",
3
- "version": "0.50.2",
3
+ "version": "0.50.4",
4
4
  "license": "Apache-2.0",
5
5
  "repository": {
6
6
  "type": "git",
@@ -51,20 +51,20 @@
51
51
  "react-dom": "^19.0.0",
52
52
  "react-hook-form": "^7.60.0",
53
53
  "zod": "^4.3.6",
54
- "@voyantjs/availability-react": "0.50.2",
55
- "@voyantjs/bookings-react": "0.50.2",
56
- "@voyantjs/catalog": "0.50.2",
57
- "@voyantjs/catalog-react": "0.50.2",
58
- "@voyantjs/crm-react": "0.50.2",
59
- "@voyantjs/crm-ui": "0.50.2",
60
- "@voyantjs/finance-react": "0.50.2",
61
- "@voyantjs/legal-react": "0.50.2",
62
- "@voyantjs/products-react": "0.50.2",
63
- "@voyantjs/suppliers-react": "0.50.2",
64
- "@voyantjs/ui": "0.50.2"
54
+ "@voyantjs/availability-react": "0.50.4",
55
+ "@voyantjs/bookings-react": "0.50.4",
56
+ "@voyantjs/catalog": "0.50.4",
57
+ "@voyantjs/catalog-react": "0.50.4",
58
+ "@voyantjs/crm-react": "0.50.4",
59
+ "@voyantjs/crm-ui": "0.50.4",
60
+ "@voyantjs/finance-react": "0.50.4",
61
+ "@voyantjs/legal-react": "0.50.4",
62
+ "@voyantjs/products-react": "0.50.4",
63
+ "@voyantjs/suppliers-react": "0.50.4",
64
+ "@voyantjs/ui": "0.50.4"
65
65
  },
66
66
  "dependencies": {
67
- "@voyantjs/i18n": "0.50.2"
67
+ "@voyantjs/i18n": "0.50.4"
68
68
  },
69
69
  "devDependencies": {
70
70
  "@tanstack/react-query": "^5.96.2",
@@ -77,18 +77,18 @@
77
77
  "typescript": "^6.0.2",
78
78
  "vitest": "^4.1.2",
79
79
  "zod": "^4.3.6",
80
- "@voyantjs/availability-react": "0.50.2",
81
- "@voyantjs/bookings-react": "0.50.2",
82
- "@voyantjs/catalog": "0.50.2",
83
- "@voyantjs/catalog-react": "0.50.2",
84
- "@voyantjs/crm-react": "0.50.2",
85
- "@voyantjs/crm-ui": "0.50.2",
86
- "@voyantjs/finance-react": "0.50.2",
87
- "@voyantjs/legal-react": "0.50.2",
88
- "@voyantjs/products-react": "0.50.2",
89
- "@voyantjs/suppliers-react": "0.50.2",
80
+ "@voyantjs/availability-react": "0.50.4",
81
+ "@voyantjs/bookings-react": "0.50.4",
82
+ "@voyantjs/catalog": "0.50.4",
83
+ "@voyantjs/catalog-react": "0.50.4",
84
+ "@voyantjs/crm-react": "0.50.4",
85
+ "@voyantjs/crm-ui": "0.50.4",
86
+ "@voyantjs/finance-react": "0.50.4",
87
+ "@voyantjs/legal-react": "0.50.4",
88
+ "@voyantjs/products-react": "0.50.4",
89
+ "@voyantjs/suppliers-react": "0.50.4",
90
90
  "@voyantjs/voyant-typescript-config": "0.1.0",
91
- "@voyantjs/ui": "0.50.2"
91
+ "@voyantjs/ui": "0.50.4"
92
92
  },
93
93
  "files": [
94
94
  "dist",