@object-ui/plugin-detail 3.0.3 → 3.1.0

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 (131) hide show
  1. package/.turbo/turbo-build.log +45 -8
  2. package/dist/AddressField-C07oUOY6.js +96 -0
  3. package/dist/AutoNumberField-BxnFqllo.js +8 -0
  4. package/dist/AvatarField-VThNABzo.js +82 -0
  5. package/dist/BooleanField-CGHKBzAi.js +37 -0
  6. package/dist/CodeField-Co_muhRR.js +21 -0
  7. package/dist/ColorField-DLid_tFz.js +42 -0
  8. package/dist/CurrencyField-Bw-LqANM.js +43 -0
  9. package/dist/DateField-BNHAzMB2.js +21 -0
  10. package/dist/DateTimeField-DjAyn_DQ.js +28 -0
  11. package/dist/EmailField-xoNcSppb.js +31 -0
  12. package/dist/FileField-DbNJwjU2.js +133 -0
  13. package/dist/FormulaField-CJkkwIK8.js +9 -0
  14. package/dist/GeolocationField-C1AnS6VV.js +123 -0
  15. package/dist/GridField-DATAHIKf.js +30 -0
  16. package/dist/ImageField-CEKJpyJp.js +90 -0
  17. package/dist/LocationField-jDWXjlpx.js +31 -0
  18. package/dist/LookupField-DQ08L9UQ.js +96 -0
  19. package/dist/MasterDetailField-Dbk529Ea.js +108 -0
  20. package/dist/NumberField-BVroN9aV.js +26 -0
  21. package/dist/ObjectField-CT3l_IHW.js +48 -0
  22. package/dist/PasswordField-DweVLEE0.js +38 -0
  23. package/dist/PercentField-ZpWUK97K.js +63 -0
  24. package/dist/PhoneField-mw-9fqZ_.js +31 -0
  25. package/dist/QRCodeField-Cbb9ck59.js +77 -0
  26. package/dist/RatingField-CSqgLS6t.js +47 -0
  27. package/dist/RichTextField-BpfBOd99.js +38 -0
  28. package/dist/SelectField-B9Ei-5jl.js +26 -0
  29. package/dist/SignatureField-DgGpHnQ8.js +85 -0
  30. package/dist/SliderField-C6HvOHd8.js +30 -0
  31. package/dist/SummaryField-ugYPYxjP.js +9 -0
  32. package/dist/TextAreaField-BK3RgzY3.js +39 -0
  33. package/dist/TextField-Bvzx3atT.js +32 -0
  34. package/dist/TimeField-Cuz9-Uai.js +21 -0
  35. package/dist/UrlField-B6XHTV73.js +33 -0
  36. package/dist/UserField-ooTul2d6.js +49 -0
  37. package/dist/VectorField-CKg9jdGa.js +25 -0
  38. package/dist/index-CnlyRfY_.js +59461 -0
  39. package/dist/index.js +30 -55026
  40. package/dist/index.umd.cjs +41 -30
  41. package/dist/plugin-detail.css +1 -1
  42. package/dist/src/ActivityTimeline.d.ts +20 -0
  43. package/dist/src/ActivityTimeline.d.ts.map +1 -0
  44. package/dist/src/CommentAttachment.d.ts +25 -0
  45. package/dist/src/CommentAttachment.d.ts.map +1 -0
  46. package/dist/src/CommentInput.d.ts +24 -0
  47. package/dist/src/CommentInput.d.ts.map +1 -0
  48. package/dist/src/DetailSection.d.ts +6 -0
  49. package/dist/src/DetailSection.d.ts.map +1 -1
  50. package/dist/src/DetailView.d.ts +4 -0
  51. package/dist/src/DetailView.d.ts.map +1 -1
  52. package/dist/src/DetailView.stories.d.ts +8 -0
  53. package/dist/src/DetailView.stories.d.ts.map +1 -1
  54. package/dist/src/DiffView.d.ts +24 -0
  55. package/dist/src/DiffView.d.ts.map +1 -0
  56. package/dist/src/FieldChangeItem.d.ts +21 -0
  57. package/dist/src/FieldChangeItem.d.ts.map +1 -0
  58. package/dist/src/InlineCreateRelated.d.ts +32 -0
  59. package/dist/src/InlineCreateRelated.d.ts.map +1 -0
  60. package/dist/src/MentionAutocomplete.d.ts +43 -0
  61. package/dist/src/MentionAutocomplete.d.ts.map +1 -0
  62. package/dist/src/PointInTimeRestore.d.ts +28 -0
  63. package/dist/src/PointInTimeRestore.d.ts.map +1 -0
  64. package/dist/src/ReactionPicker.d.ts +25 -0
  65. package/dist/src/ReactionPicker.d.ts.map +1 -0
  66. package/dist/src/RecordActivityTimeline.d.ts +49 -0
  67. package/dist/src/RecordActivityTimeline.d.ts.map +1 -0
  68. package/dist/src/RecordChatterPanel.d.ts +48 -0
  69. package/dist/src/RecordChatterPanel.d.ts.map +1 -0
  70. package/dist/src/RecordComments.d.ts +20 -0
  71. package/dist/src/RecordComments.d.ts.map +1 -0
  72. package/dist/src/RecordNavigationEnhanced.d.ts +18 -0
  73. package/dist/src/RecordNavigationEnhanced.d.ts.map +1 -0
  74. package/dist/src/RelatedList.d.ts +4 -0
  75. package/dist/src/RelatedList.d.ts.map +1 -1
  76. package/dist/src/RelationshipGraph.d.ts +23 -0
  77. package/dist/src/RelationshipGraph.d.ts.map +1 -0
  78. package/dist/src/RichTextCommentInput.d.ts +24 -0
  79. package/dist/src/RichTextCommentInput.d.ts.map +1 -0
  80. package/dist/src/SubscriptionToggle.d.ts +22 -0
  81. package/dist/src/SubscriptionToggle.d.ts.map +1 -0
  82. package/dist/src/ThreadedReplies.d.ts +26 -0
  83. package/dist/src/ThreadedReplies.d.ts.map +1 -0
  84. package/dist/src/autoLayout.d.ts +34 -0
  85. package/dist/src/autoLayout.d.ts.map +1 -0
  86. package/dist/src/index.d.ts +36 -0
  87. package/dist/src/index.d.ts.map +1 -1
  88. package/dist/src/useDetailTranslation.d.ts +34 -0
  89. package/dist/src/useDetailTranslation.d.ts.map +1 -0
  90. package/package.json +8 -7
  91. package/src/ActivityTimeline.tsx +184 -0
  92. package/src/CommentAttachment.tsx +192 -0
  93. package/src/CommentInput.tsx +81 -0
  94. package/src/DetailSection.tsx +74 -9
  95. package/src/DetailView.stories.tsx +76 -0
  96. package/src/DetailView.tsx +270 -27
  97. package/src/DiffView.tsx +231 -0
  98. package/src/FieldChangeItem.tsx +46 -0
  99. package/src/InlineCreateRelated.tsx +291 -0
  100. package/src/MentionAutocomplete.tsx +123 -0
  101. package/src/PointInTimeRestore.tsx +261 -0
  102. package/src/ReactionPicker.tsx +106 -0
  103. package/src/RecordActivityTimeline.tsx +429 -0
  104. package/src/RecordChatterPanel.tsx +202 -0
  105. package/src/RecordComments.tsx +215 -0
  106. package/src/RecordNavigationEnhanced.tsx +211 -0
  107. package/src/RelatedList.tsx +37 -8
  108. package/src/RelationshipGraph.tsx +286 -0
  109. package/src/RichTextCommentInput.tsx +348 -0
  110. package/src/SubscriptionToggle.tsx +60 -0
  111. package/src/ThreadedReplies.tsx +161 -0
  112. package/src/__tests__/ActivityTimeline.test.tsx +119 -0
  113. package/src/__tests__/ActivityTimelineFiltering.test.tsx +143 -0
  114. package/src/__tests__/CommentInput.test.tsx +57 -0
  115. package/src/__tests__/DetailSection.test.tsx +320 -0
  116. package/src/__tests__/DetailView.test.tsx +415 -1
  117. package/src/__tests__/FieldChangeItem.test.tsx +119 -0
  118. package/src/__tests__/MentionAutocomplete.test.tsx +97 -0
  119. package/src/__tests__/ReactionPicker.test.tsx +113 -0
  120. package/src/__tests__/RecordActivityTimeline.test.tsx +395 -0
  121. package/src/__tests__/RecordChatterPanel.test.tsx +227 -0
  122. package/src/__tests__/RecordComments.test.tsx +96 -0
  123. package/src/__tests__/RecordCommentsPinSearch.test.tsx +133 -0
  124. package/src/__tests__/RelatedList.test.tsx +66 -0
  125. package/src/__tests__/SubscriptionToggle.test.tsx +84 -0
  126. package/src/__tests__/ThreadedReplies.test.tsx +212 -0
  127. package/src/__tests__/autoLayout.test.ts +184 -0
  128. package/src/__tests__/phase12-features.test.tsx +583 -0
  129. package/src/autoLayout.ts +111 -0
  130. package/src/index.tsx +46 -0
  131. package/src/useDetailTranslation.ts +103 -0
package/src/index.tsx CHANGED
@@ -14,10 +14,46 @@ import { RelatedList } from './RelatedList';
14
14
  import type { DetailViewSchema } from '@object-ui/types';
15
15
 
16
16
  export { DetailView, DetailSection, DetailTabs, RelatedList };
17
+ export { inferDetailColumns, isWideFieldType, applyAutoSpan, applyDetailAutoLayout } from './autoLayout';
18
+ export { useDetailTranslation, DETAIL_DEFAULT_TRANSLATIONS, createSafeTranslationHook } from './useDetailTranslation';
19
+ export { RecordComments } from './RecordComments';
20
+ export { ActivityTimeline } from './ActivityTimeline';
21
+ export { InlineCreateRelated } from './InlineCreateRelated';
22
+ export { RichTextCommentInput } from './RichTextCommentInput';
23
+ export { DiffView } from './DiffView';
24
+ export { RecordNavigationEnhanced } from './RecordNavigationEnhanced';
25
+ export { RelationshipGraph } from './RelationshipGraph';
26
+ export { CommentAttachment } from './CommentAttachment';
27
+ export { PointInTimeRestore } from './PointInTimeRestore';
28
+ export { RecordActivityTimeline } from './RecordActivityTimeline';
29
+ export { RecordChatterPanel } from './RecordChatterPanel';
30
+ export { CommentInput } from './CommentInput';
31
+ export { FieldChangeItem } from './FieldChangeItem';
32
+ export { MentionAutocomplete, createMentionFromSuggestion } from './MentionAutocomplete';
33
+ export { SubscriptionToggle } from './SubscriptionToggle';
34
+ export { ReactionPicker } from './ReactionPicker';
35
+ export { ThreadedReplies } from './ThreadedReplies';
17
36
  export type { DetailViewProps } from './DetailView';
18
37
  export type { DetailSectionProps } from './DetailSection';
19
38
  export type { DetailTabsProps } from './DetailTabs';
20
39
  export type { RelatedListProps } from './RelatedList';
40
+ export type { RecordCommentsProps } from './RecordComments';
41
+ export type { ActivityTimelineProps, ActivityFilterType } from './ActivityTimeline';
42
+ export type { InlineCreateRelatedProps, RelatedFieldDefinition, RelatedRecordOption } from './InlineCreateRelated';
43
+ export type { RichTextCommentInputProps, MentionSuggestion } from './RichTextCommentInput';
44
+ export type { DiffViewProps, DiffFieldType, DiffMode, DiffLine } from './DiffView';
45
+ export type { RecordNavigationEnhancedProps } from './RecordNavigationEnhanced';
46
+ export type { RelationshipGraphProps, GraphNode } from './RelationshipGraph';
47
+ export type { CommentAttachmentProps, Attachment } from './CommentAttachment';
48
+ export type { PointInTimeRestoreProps, RevisionEntry } from './PointInTimeRestore';
49
+ export type { RecordActivityTimelineProps, FeedFilterMode } from './RecordActivityTimeline';
50
+ export type { RecordChatterPanelProps } from './RecordChatterPanel';
51
+ export type { CommentInputProps } from './CommentInput';
52
+ export type { FieldChangeItemProps } from './FieldChangeItem';
53
+ export type { MentionAutocompleteProps, MentionSuggestionItem } from './MentionAutocomplete';
54
+ export type { SubscriptionToggleProps } from './SubscriptionToggle';
55
+ export type { ReactionPickerProps } from './ReactionPicker';
56
+ export type { ThreadedRepliesProps } from './ThreadedReplies';
21
57
 
22
58
  // Register DetailView component
23
59
  ComponentRegistry.register('detail-view', DetailView, {
@@ -31,14 +67,22 @@ ComponentRegistry.register('detail-view', DetailView, {
31
67
  { name: 'resourceId', type: 'string', label: 'Resource ID' },
32
68
  { name: 'api', type: 'string', label: 'API Endpoint' },
33
69
  { name: 'data', type: 'object', label: 'Data' },
70
+ { name: 'layout', type: 'enum', label: 'Layout Mode', enum: ['vertical', 'horizontal', 'grid'] },
71
+ { name: 'columns', type: 'number', label: 'Grid Columns' },
34
72
  { name: 'sections', type: 'array', label: 'Sections' },
35
73
  { name: 'fields', type: 'array', label: 'Fields' },
36
74
  { name: 'tabs', type: 'array', label: 'Tabs' },
37
75
  { name: 'related', type: 'array', label: 'Related Lists' },
38
76
  { name: 'actions', type: 'array', label: 'Actions' },
39
77
  { name: 'showBack', type: 'boolean', label: 'Show Back Button', defaultValue: true },
78
+ { name: 'backUrl', type: 'string', label: 'Back URL' },
40
79
  { name: 'showEdit', type: 'boolean', label: 'Show Edit Button', defaultValue: false },
80
+ { name: 'editUrl', type: 'string', label: 'Edit URL' },
41
81
  { name: 'showDelete', type: 'boolean', label: 'Show Delete Button', defaultValue: false },
82
+ { name: 'deleteConfirmation', type: 'string', label: 'Delete Confirmation Message' },
83
+ { name: 'loading', type: 'boolean', label: 'Show Loading State' },
84
+ { name: 'header', type: 'object', label: 'Custom Header' },
85
+ { name: 'footer', type: 'object', label: 'Custom Footer' },
42
86
  ],
43
87
  defaultProps: {
44
88
  title: 'Detail View',
@@ -64,6 +108,8 @@ ComponentRegistry.register('detail-section', DetailSection, {
64
108
  { name: 'collapsible', type: 'boolean', label: 'Collapsible', defaultValue: false },
65
109
  { name: 'defaultCollapsed', type: 'boolean', label: 'Default Collapsed', defaultValue: false },
66
110
  { name: 'columns', type: 'number', label: 'Columns', defaultValue: 2 },
111
+ { name: 'showBorder', type: 'boolean', label: 'Show Border', defaultValue: true },
112
+ { name: 'headerColor', type: 'string', label: 'Header Color' },
67
113
  ],
68
114
  });
69
115
 
@@ -0,0 +1,103 @@
1
+ /**
2
+ * ObjectUI
3
+ * Copyright (c) 2024-present ObjectStack Inc.
4
+ *
5
+ * This source code is licensed under the MIT license found in the
6
+ * LICENSE file in the root directory of this source tree.
7
+ */
8
+
9
+ import { useObjectTranslation } from '@object-ui/react';
10
+
11
+ /**
12
+ * Create a safe translation hook with fallback to defaults.
13
+ * Follows the same pattern as useGridTranslation / useListViewTranslation.
14
+ *
15
+ * @param defaults - Fallback English translations keyed by i18n key
16
+ * @param testKey - A key to test if i18n is properly configured
17
+ */
18
+ export function createSafeTranslationHook(
19
+ defaults: Record<string, string>,
20
+ testKey: string,
21
+ ) {
22
+ return function useSafeTranslation() {
23
+ try {
24
+ const result = useObjectTranslation();
25
+ const testValue = result.t(testKey);
26
+ if (testValue === testKey) {
27
+ return {
28
+ t: (key: string, options?: Record<string, unknown>) => {
29
+ let value = defaults[key] || key;
30
+ if (options) {
31
+ for (const [k, v] of Object.entries(options)) {
32
+ value = value.replace(`{{${k}}}`, String(v));
33
+ }
34
+ }
35
+ return value;
36
+ },
37
+ };
38
+ }
39
+ return { t: result.t };
40
+ } catch {
41
+ return {
42
+ t: (key: string, options?: Record<string, unknown>) => {
43
+ let value = defaults[key] || key;
44
+ if (options) {
45
+ for (const [k, v] of Object.entries(options)) {
46
+ value = value.replace(`{{${k}}}`, String(v));
47
+ }
48
+ }
49
+ return value;
50
+ },
51
+ };
52
+ }
53
+ };
54
+ }
55
+
56
+ /**
57
+ * Default English translations for detail view components.
58
+ * Used as fallback when no I18nProvider is available.
59
+ */
60
+ export const DETAIL_DEFAULT_TRANSLATIONS: Record<string, string> = {
61
+ 'detail.back': 'Back',
62
+ 'detail.edit': 'Edit',
63
+ 'detail.editInline': 'Edit inline',
64
+ 'detail.save': 'Save',
65
+ 'detail.saveChanges': 'Save changes',
66
+ 'detail.editFieldsInline': 'Edit fields inline',
67
+ 'detail.share': 'Share',
68
+ 'detail.duplicate': 'Duplicate',
69
+ 'detail.export': 'Export',
70
+ 'detail.viewHistory': 'View history',
71
+ 'detail.delete': 'Delete',
72
+ 'detail.moreActions': 'More actions',
73
+ 'detail.addToFavorites': 'Add to favorites',
74
+ 'detail.removeFromFavorites': 'Remove from favorites',
75
+ 'detail.previousRecord': 'Previous record',
76
+ 'detail.nextRecord': 'Next record',
77
+ 'detail.recordOf': '{{current}} of {{total}}',
78
+ 'detail.recordNotFound': 'Record not found',
79
+ 'detail.recordNotFoundDescription': 'The record you are looking for does not exist or may have been deleted.',
80
+ 'detail.goBack': 'Go back',
81
+ 'detail.details': 'Details',
82
+ 'detail.related': 'Related',
83
+ 'detail.relatedRecords': '{{count}} records',
84
+ 'detail.relatedRecordOne': '{{count}} record',
85
+ 'detail.noRelatedRecords': 'No related records found',
86
+ 'detail.loading': 'Loading...',
87
+ 'detail.copyToClipboard': 'Copy to clipboard',
88
+ 'detail.copied': 'Copied!',
89
+ 'detail.deleteConfirmation': 'Are you sure you want to delete this record?',
90
+ 'detail.editRecord': 'Edit record',
91
+ 'detail.viewAll': 'View All',
92
+ 'detail.new': 'New',
93
+ 'detail.emptyValue': '—',
94
+ };
95
+
96
+ /**
97
+ * Translation hook for detail view components.
98
+ * Falls back to DETAIL_DEFAULT_TRANSLATIONS when no I18nProvider is available.
99
+ */
100
+ export const useDetailTranslation = createSafeTranslationHook(
101
+ DETAIL_DEFAULT_TRANSLATIONS,
102
+ 'detail.back',
103
+ );