@tuturuuu/ui 0.8.0 → 0.10.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 (245) hide show
  1. package/CHANGELOG.md +69 -0
  2. package/biome.json +1 -1
  3. package/package.json +74 -71
  4. package/src/components/ui/accordion.tsx +1 -1
  5. package/src/components/ui/breadcrumb.tsx +1 -1
  6. package/src/components/ui/calendar-app/calendar-page-shell.tsx +4 -0
  7. package/src/components/ui/calendar-app/components/calendar-connections-settings-content.tsx +239 -33
  8. package/src/components/ui/calendar-app/components/load-smart-scheduling-tasks.tsx +143 -0
  9. package/src/components/ui/calendar-app/components/priority-view.tsx +10 -3
  10. package/src/components/ui/calendar-app/components/tasks-sidebar.tsx +4 -116
  11. package/src/components/ui/calendar-app/components/use-calendar-connections-manager.ts +67 -2
  12. package/src/components/ui/calendar.tsx +1 -1
  13. package/src/components/ui/carousel.tsx +1 -1
  14. package/src/components/ui/chat/chat-agent-details-external-thread-panel.test.tsx +1 -1
  15. package/src/components/ui/chat/chat-agent-details-external-thread-panel.tsx +1 -1
  16. package/src/components/ui/chat/chat-agent-details-operations-panel.test.tsx +1 -1
  17. package/src/components/ui/chat/chat-agent-details-operations-panel.tsx +1 -1
  18. package/src/components/ui/chat/chat-agent-details-setup-panel.tsx +1 -1
  19. package/src/components/ui/chat/chat-agent-details-sidebar.test.tsx +1 -1
  20. package/src/components/ui/chat/chat-agent-details-sidebar.tsx +2 -2
  21. package/src/components/ui/chat/chat-agent-details-utils.test.ts +1 -1
  22. package/src/components/ui/chat/chat-agent-details-utils.tsx +1 -1
  23. package/src/components/ui/chat/chat-agent-details-zalo-personal-panel.tsx +2 -2
  24. package/src/components/ui/checkbox.tsx +1 -1
  25. package/src/components/ui/color-picker.tsx +1 -1
  26. package/src/components/ui/command.tsx +1 -1
  27. package/src/components/ui/context-menu.tsx +5 -1
  28. package/src/components/ui/custom/__tests__/settings-dialog-search.test.ts +78 -0
  29. package/src/components/ui/custom/__tests__/settings-dialog-shell-compile-graph.test.ts +76 -0
  30. package/src/components/ui/custom/__tests__/settings-dialog-shell.test.tsx +3 -0
  31. package/src/components/ui/custom/__tests__/workspace-select-helpers.test.ts +46 -1
  32. package/src/components/ui/custom/combobox.test.tsx +195 -0
  33. package/src/components/ui/custom/combobox.tsx +273 -156
  34. package/src/components/ui/custom/education/modules/youtube/delete-link-button.tsx +5 -13
  35. package/src/components/ui/custom/facebook-mockup/facebook-mockup.tsx +7 -1
  36. package/src/components/ui/custom/facebook-mockup/form.tsx +1 -1
  37. package/src/components/ui/custom/facebook-mockup/image-upload-field.tsx +1 -1
  38. package/src/components/ui/custom/facebook-mockup/preview.tsx +1 -1
  39. package/src/components/ui/custom/nav-link.test.tsx +165 -0
  40. package/src/components/ui/custom/nav-link.tsx +69 -11
  41. package/src/components/ui/custom/navigation.tsx +1 -0
  42. package/src/components/ui/custom/settings/task-settings.tsx +104 -0
  43. package/src/components/ui/custom/settings-dialog-search-loader.d.ts +5 -0
  44. package/src/components/ui/custom/settings-dialog-search-loader.js +3 -0
  45. package/src/components/ui/custom/settings-dialog-search.ts +75 -0
  46. package/src/components/ui/custom/settings-dialog-shell.tsx +65 -28
  47. package/src/components/ui/custom/theme-toggle.tsx +1 -1
  48. package/src/components/ui/custom/workspace-select-helpers.ts +23 -0
  49. package/src/components/ui/custom/workspace-select.tsx +25 -19
  50. package/src/components/ui/dialog.test.tsx +52 -0
  51. package/src/components/ui/dialog.tsx +6 -2
  52. package/src/components/ui/dropdown-menu.tsx +5 -1
  53. package/src/components/ui/finance/debts/debt-loan-form.tsx +12 -5
  54. package/src/components/ui/finance/debts/debt-loan-summary.tsx +3 -2
  55. package/src/components/ui/finance/debts/debts-page.test.tsx +54 -5
  56. package/src/components/ui/finance/debts/debts-page.tsx +15 -2
  57. package/src/components/ui/finance/invoices/components/subscription-group-selector.tsx +3 -5
  58. package/src/components/ui/finance/invoices/new-invoice-page.test.tsx +25 -5
  59. package/src/components/ui/finance/invoices/new-invoice-page.tsx +7 -2
  60. package/src/components/ui/finance/invoices/standard-invoice.tsx +4 -2
  61. package/src/components/ui/finance/invoices/subscription-invoice.tsx +4 -2
  62. package/src/components/ui/finance/invoices/utils.ts +3 -1
  63. package/src/components/ui/finance/transactions/form-content-dialog.tsx +3 -0
  64. package/src/components/ui/finance/transactions/form-types.ts +1 -0
  65. package/src/components/ui/finance/transactions/form.tsx +2 -0
  66. package/src/components/ui/finance/transactions/infinite-transactions-list.tsx +2 -0
  67. package/src/components/ui/finance/transactions/period-charts/category-breakdown-dialog.tsx +1 -1
  68. package/src/components/ui/finance/transactions/transaction-edit-dialog.tsx +1 -4
  69. package/src/components/ui/finance/transactions/transactions-create-summary.tsx +3 -0
  70. package/src/components/ui/finance/transactions/transactions-page.tsx +4 -1
  71. package/src/components/ui/finance/wallets/form.test.tsx +51 -3
  72. package/src/components/ui/finance/wallets/form.tsx +15 -4
  73. package/src/components/ui/finance/wallets/walletId/wallet-details-actions.tsx +4 -0
  74. package/src/components/ui/finance/wallets/walletId/wallet-details-page.tsx +4 -2
  75. package/src/components/ui/finance/wallets/wallets-data-table.tsx +1 -0
  76. package/src/components/ui/finance/wallets/wallets-page.tsx +5 -2
  77. package/src/components/ui/input-otp.tsx +1 -1
  78. package/src/components/ui/legacy/calendar/all-day-event-bar.tsx +28 -39
  79. package/src/components/ui/legacy/calendar/calendar-cell.tsx +2 -0
  80. package/src/components/ui/legacy/calendar/calendar-content.tsx +10 -6
  81. package/src/components/ui/legacy/calendar/calendar-header.tsx +23 -3
  82. package/src/components/ui/legacy/calendar/calendar-loading-skeleton.tsx +135 -0
  83. package/src/components/ui/legacy/calendar/calendar-matrix.tsx +175 -237
  84. package/src/components/ui/legacy/calendar/event-card.test.tsx +177 -0
  85. package/src/components/ui/legacy/calendar/event-card.tsx +220 -131
  86. package/src/components/ui/legacy/calendar/event-modal.tsx +17 -17
  87. package/src/components/ui/legacy/calendar/event-provider-display.tsx +69 -0
  88. package/src/components/ui/legacy/calendar/smart-calendar.test.tsx +86 -4
  89. package/src/components/ui/legacy/calendar/smart-calendar.tsx +32 -2
  90. package/src/components/ui/legacy/meet/create-plan-dialog.tsx +19 -10
  91. package/src/components/ui/navigation-menu.tsx +1 -1
  92. package/src/components/ui/pagination.tsx +1 -1
  93. package/src/components/ui/radio-group.tsx +1 -1
  94. package/src/components/ui/select.tsx +5 -1
  95. package/src/components/ui/sheet.tsx +1 -1
  96. package/src/components/ui/sidebar.tsx +1 -1
  97. package/src/components/ui/storefront/cart-popover.tsx +61 -0
  98. package/src/components/ui/storefront/cart-summary-parts.tsx +290 -0
  99. package/src/components/ui/storefront/cart-summary.tsx +93 -154
  100. package/src/components/ui/storefront/checkout-overlay.tsx +4 -5
  101. package/src/components/ui/storefront/listing-card.tsx +1 -1
  102. package/src/components/ui/storefront/merch-sections.tsx +70 -0
  103. package/src/components/ui/storefront/product-detail.tsx +1 -1
  104. package/src/components/ui/storefront/storefront-surface.test.tsx +106 -11
  105. package/src/components/ui/storefront/storefront-surface.tsx +101 -166
  106. package/src/components/ui/storefront/types.ts +4 -0
  107. package/src/components/ui/storefront/utils.ts +6 -0
  108. package/src/components/ui/text-editor/__tests__/extensions.test.ts +123 -0
  109. package/src/components/ui/text-editor/background-color-extension.ts +62 -0
  110. package/src/components/ui/text-editor/color-controls.tsx +284 -0
  111. package/src/components/ui/text-editor/editor.tsx +69 -14
  112. package/src/components/ui/text-editor/extensions.ts +8 -2
  113. package/src/components/ui/text-editor/highlight-extension.ts +22 -0
  114. package/src/components/ui/text-editor/tool-bar.tsx +9 -16
  115. package/src/components/ui/toast.tsx +1 -1
  116. package/src/components/ui/tu-do/boards/__tests__/board-share-dialog.test.tsx +286 -0
  117. package/src/components/ui/tu-do/boards/__tests__/task-board-form.test.tsx +12 -0
  118. package/src/components/ui/tu-do/boards/board-public-link-section.tsx +231 -0
  119. package/src/components/ui/tu-do/boards/board-share-dialog.tsx +15 -226
  120. package/src/components/ui/tu-do/boards/board-share-settings-panel.tsx +351 -0
  121. package/src/components/ui/tu-do/boards/boardId/board-column.tsx +121 -39
  122. package/src/components/ui/tu-do/boards/boardId/enhanced-task-list.tsx +7 -0
  123. package/src/components/ui/tu-do/boards/boardId/kanban/bulk/bulk-mutations-clear-delete.ts +2 -0
  124. package/src/components/ui/tu-do/boards/boardId/kanban/bulk/bulk-mutations-move.ts +5 -0
  125. package/src/components/ui/tu-do/boards/boardId/kanban/bulk/bulk-mutations-updates.ts +3 -0
  126. package/src/components/ui/tu-do/boards/boardId/kanban/bulk/bulk-operation-types.ts +3 -3
  127. package/src/components/ui/tu-do/boards/boardId/kanban/data/kanban-deadline-query.ts +50 -2
  128. package/src/components/ui/tu-do/boards/boardId/kanban/data/use-bulk-resources.ts +59 -5
  129. package/src/components/ui/tu-do/boards/boardId/kanban/dnd/__tests__/column-reorder.test.ts +17 -0
  130. package/src/components/ui/tu-do/boards/boardId/kanban/dnd/column-reorder.ts +4 -1
  131. package/src/components/ui/tu-do/boards/boardId/kanban/dnd/drag-preview.tsx +20 -1
  132. package/src/components/ui/tu-do/boards/boardId/kanban/dnd/task-drag-cache.ts +38 -9
  133. package/src/components/ui/tu-do/boards/boardId/kanban/dnd/task-drag-order.ts +2 -8
  134. package/src/components/ui/tu-do/boards/boardId/kanban/dnd/task-sort-key.ts +47 -0
  135. package/src/components/ui/tu-do/boards/boardId/kanban/dnd/use-kanban-dnd.ts +81 -30
  136. package/src/components/ui/tu-do/boards/boardId/kanban/planner/__tests__/kanban-planner-island.test.tsx +380 -0
  137. package/src/components/ui/tu-do/boards/boardId/kanban/planner/kanban-planner-dialog.tsx +204 -0
  138. package/src/components/ui/tu-do/boards/boardId/kanban/planner/planner-digest-panel.tsx +61 -0
  139. package/src/components/ui/tu-do/boards/boardId/kanban/planner/planner-item-strip.tsx +54 -0
  140. package/src/components/ui/tu-do/boards/boardId/kanban/planner/planner-plan-toolbar.tsx +251 -0
  141. package/src/components/ui/tu-do/boards/boardId/kanban/planner/planner-scope-badge.tsx +27 -0
  142. package/src/components/ui/tu-do/boards/boardId/kanban/planner/planner-section.tsx +58 -0
  143. package/src/components/ui/tu-do/boards/boardId/kanban/planner/planner-share-dialog.tsx +238 -0
  144. package/src/components/ui/tu-do/boards/boardId/kanban/planner/planner-target-controls.tsx +143 -0
  145. package/src/components/ui/tu-do/boards/boardId/kanban/planner/planner-utils.ts +65 -0
  146. package/src/components/ui/tu-do/boards/boardId/kanban/planner/use-kanban-planner-state.ts +234 -0
  147. package/src/components/ui/tu-do/boards/boardId/kanban/rendering/kanban-columns.test.tsx +642 -5
  148. package/src/components/ui/tu-do/boards/boardId/kanban/rendering/kanban-columns.tsx +224 -15
  149. package/src/components/ui/tu-do/boards/boardId/kanban/rendering/kanban-deadline-panels.tsx +535 -53
  150. package/src/components/ui/tu-do/boards/boardId/kanban/rendering/kanban-skeleton.tsx +101 -33
  151. package/src/components/ui/tu-do/boards/boardId/kanban.tsx +235 -113
  152. package/src/components/ui/tu-do/boards/boardId/task-board-server-page.test.tsx +50 -5
  153. package/src/components/ui/tu-do/boards/boardId/task-board-server-page.tsx +12 -2
  154. package/src/components/ui/tu-do/boards/boardId/task-card/measured-task-card.tsx +10 -1
  155. package/src/components/ui/tu-do/boards/boardId/task-card/task-card-comparator.ts +3 -0
  156. package/src/components/ui/tu-do/boards/boardId/task-card/task-card-open-options.test.ts +20 -0
  157. package/src/components/ui/tu-do/boards/boardId/task-card/task-card-open-options.ts +10 -0
  158. package/src/components/ui/tu-do/boards/boardId/task-card/task-card.tsx +271 -36
  159. package/src/components/ui/tu-do/boards/boardId/task-filter.test.tsx +152 -0
  160. package/src/components/ui/tu-do/boards/boardId/task-filter.tsx +555 -545
  161. package/src/components/ui/tu-do/boards/boardId/task-list.tsx +22 -0
  162. package/src/components/ui/tu-do/boards/boardId/timeline/timeline-grid.tsx +9 -0
  163. package/src/components/ui/tu-do/boards/boardId/timeline/timeline-task-row.tsx +9 -0
  164. package/src/components/ui/tu-do/boards/boardId/timeline/timeline-toolbar.tsx +9 -0
  165. package/src/components/ui/tu-do/boards/boardId/timeline-board.tsx +35 -3
  166. package/src/components/ui/tu-do/boards/form.tsx +1 -1
  167. package/src/components/ui/tu-do/boards/share-section.tsx +100 -0
  168. package/src/components/ui/tu-do/drafts/draft-convert-dialog.tsx +10 -12
  169. package/src/components/ui/tu-do/drafts/drafts-page.tsx +33 -16
  170. package/src/components/ui/tu-do/hooks/__tests__/useTaskLabelManagement.test.tsx +48 -0
  171. package/src/components/ui/tu-do/hooks/__tests__/useTaskProjectManagement.test.tsx +144 -0
  172. package/src/components/ui/tu-do/hooks/useTaskDialog.ts +7 -0
  173. package/src/components/ui/tu-do/hooks/useTaskLabelManagement.ts +115 -106
  174. package/src/components/ui/tu-do/hooks/useTaskProjectManagement.ts +115 -122
  175. package/src/components/ui/tu-do/initiatives/task-initiatives-client.tsx +56 -88
  176. package/src/components/ui/tu-do/my-tasks/my-tasks-content.tsx +26 -2
  177. package/src/components/ui/tu-do/my-tasks/use-my-tasks-state.ts +55 -8
  178. package/src/components/ui/tu-do/notes/note-edit-dialog.tsx +1 -4
  179. package/src/components/ui/tu-do/progress/task-progress-import-panel.tsx +60 -0
  180. package/src/components/ui/tu-do/progress/task-progress-leaderboards-panel.tsx +156 -0
  181. package/src/components/ui/tu-do/progress/task-progress-page.tsx +348 -0
  182. package/src/components/ui/tu-do/progress/task-progress-panels.tsx +301 -0
  183. package/src/components/ui/tu-do/providers/task-dialog-provider.tsx +26 -0
  184. package/src/components/ui/tu-do/shared/__tests__/assignee-select.test.tsx +81 -10
  185. package/src/components/ui/tu-do/shared/__tests__/board-client.test.tsx +141 -1
  186. package/src/components/ui/tu-do/shared/__tests__/board-header.test.tsx +377 -36
  187. package/src/components/ui/tu-do/shared/__tests__/board-switcher.test.tsx +374 -0
  188. package/src/components/ui/tu-do/shared/__tests__/board-views.test.tsx +419 -5
  189. package/src/components/ui/tu-do/shared/__tests__/task-board-loading-state.test.tsx +38 -0
  190. package/src/components/ui/tu-do/shared/__tests__/task-cache-patches.test.ts +147 -0
  191. package/src/components/ui/tu-do/shared/__tests__/task-legacy-route-recovery.test.tsx +16 -0
  192. package/src/components/ui/tu-do/shared/__tests__/use-progressive-board-loader.test.tsx +3 -0
  193. package/src/components/ui/tu-do/shared/assignee-select.tsx +77 -26
  194. package/src/components/ui/tu-do/shared/board-client.tsx +15 -10
  195. package/src/components/ui/tu-do/shared/board-config-storage.ts +7 -1
  196. package/src/components/ui/tu-do/shared/board-header.tsx +471 -975
  197. package/src/components/ui/tu-do/shared/board-layout-settings.tsx +165 -136
  198. package/src/components/ui/tu-do/shared/board-switcher.tsx +244 -220
  199. package/src/components/ui/tu-do/shared/board-user-presence-avatars.tsx +18 -12
  200. package/src/components/ui/tu-do/shared/board-views.tsx +577 -85
  201. package/src/components/ui/tu-do/shared/list-view.tsx +246 -2
  202. package/src/components/ui/tu-do/shared/recycle-bin-panel.tsx +142 -94
  203. package/src/components/ui/tu-do/shared/special-task-list-pins.ts +51 -0
  204. package/src/components/ui/tu-do/shared/task-board-loading-state.tsx +28 -0
  205. package/src/components/ui/tu-do/shared/task-cache-patches.ts +394 -0
  206. package/src/components/ui/tu-do/shared/task-dialog-manager.tsx +21 -1
  207. package/src/components/ui/tu-do/shared/task-edit-dialog/components/quick-settings-popover.tsx +5 -1
  208. package/src/components/ui/tu-do/shared/task-edit-dialog/components/task-dialog-header.tsx +25 -2
  209. package/src/components/ui/tu-do/shared/task-edit-dialog/components/task-list-selector.tsx +7 -1
  210. package/src/components/ui/tu-do/shared/task-edit-dialog/field-diff-viewer.tsx +3 -2
  211. package/src/components/ui/tu-do/shared/task-edit-dialog/hooks/use-task-data.ts +79 -10
  212. package/src/components/ui/tu-do/shared/task-edit-dialog/hooks/use-task-mutations.ts +76 -77
  213. package/src/components/ui/tu-do/shared/task-edit-dialog/hooks/use-task-relationships.test.tsx +63 -0
  214. package/src/components/ui/tu-do/shared/task-edit-dialog/hooks/use-task-relationships.ts +78 -69
  215. package/src/components/ui/tu-do/shared/task-edit-dialog/personal-overrides-section.tsx +28 -8
  216. package/src/components/ui/tu-do/shared/task-edit-dialog/relationships/dependencies-section.tsx +14 -3
  217. package/src/components/ui/tu-do/shared/task-edit-dialog/relationships/parent-section.tsx +6 -1
  218. package/src/components/ui/tu-do/shared/task-edit-dialog/relationships/related-section.tsx +6 -1
  219. package/src/components/ui/tu-do/shared/task-edit-dialog/relationships/subtasks-section.tsx +6 -1
  220. package/src/components/ui/tu-do/shared/task-edit-dialog/relationships/types/task-relationships.types.ts +8 -0
  221. package/src/components/ui/tu-do/shared/task-edit-dialog/selective-revert-panel.test.tsx +91 -0
  222. package/src/components/ui/tu-do/shared/task-edit-dialog/selective-revert-panel.tsx +123 -78
  223. package/src/components/ui/tu-do/shared/task-edit-dialog/task-activity-section.tsx +7 -1
  224. package/src/components/ui/tu-do/shared/task-edit-dialog/task-dialog-actions.tsx +8 -1
  225. package/src/components/ui/tu-do/shared/task-edit-dialog/task-properties-section.test.tsx +150 -0
  226. package/src/components/ui/tu-do/shared/task-edit-dialog/task-properties-section.tsx +61 -35
  227. package/src/components/ui/tu-do/shared/task-edit-dialog/task-relationships-properties.tsx +44 -2
  228. package/src/components/ui/tu-do/shared/task-edit-dialog/task-snapshot-dialog.tsx +8 -3
  229. package/src/components/ui/tu-do/shared/task-edit-dialog.tsx +11 -1
  230. package/src/components/ui/tu-do/shared/task-legacy-route-recovery.tsx +2 -9
  231. package/src/components/ui/tu-do/shared/task-row-actions-menu.tsx +11 -0
  232. package/src/components/ui/tu-do/shared/use-progressive-board-loader.ts +2 -0
  233. package/src/declarations.d.ts +1 -0
  234. package/src/hooks/__tests__/use-calendar-readonly.test.tsx +322 -2
  235. package/src/hooks/__tests__/use-calendar-sync.test.tsx +446 -0
  236. package/src/hooks/__tests__/useBoardPresence.test.tsx +191 -0
  237. package/src/hooks/__tests__/useBoardRealtime.test.tsx +24 -144
  238. package/src/hooks/use-calendar-sync.tsx +247 -243
  239. package/src/hooks/use-calendar.tsx +323 -138
  240. package/src/hooks/use-task-actions.ts +24 -0
  241. package/src/hooks/use-user-workspace-config.ts +75 -0
  242. package/src/hooks/use-workspace-currency.ts +8 -3
  243. package/src/hooks/useBoardPresence.ts +364 -0
  244. package/src/hooks/useBoardRealtimeEventHandler.ts +45 -90
  245. package/src/lib/workspace-actions.ts +2 -6
@@ -76,13 +76,13 @@ import { EditListDialog } from './edit-list-dialog';
76
76
  import { isTaskListNameExistsError } from './task-board-errors';
77
77
  import { translateTaskListNameForDisplay } from './utils/translate-task-list-display-name';
78
78
 
79
- interface BoardLayoutSettingsProps {
80
- open: boolean;
81
- onOpenChange: (open: boolean) => void;
79
+ interface BoardLayoutSettingsContentProps {
82
80
  boardId: string;
83
81
  wsId?: string;
84
82
  lists: WorkspaceTaskList[];
85
83
  onUpdate: () => void;
84
+ disableScrollArea?: boolean;
85
+ scrollAreaClassName?: string;
86
86
  translations?: {
87
87
  boardLayoutSettings?: string;
88
88
  boardLayoutSettingsDescription?: string;
@@ -136,6 +136,11 @@ interface BoardLayoutSettingsProps {
136
136
  };
137
137
  }
138
138
 
139
+ interface BoardLayoutSettingsProps extends BoardLayoutSettingsContentProps {
140
+ open: boolean;
141
+ onOpenChange: (open: boolean) => void;
142
+ }
143
+
139
144
  const statusConfig = {
140
145
  not_started: {
141
146
  icon: CircleDashed,
@@ -458,15 +463,15 @@ function SortableListItem({
458
463
  );
459
464
  }
460
465
 
461
- export function BoardLayoutSettings({
462
- open,
463
- onOpenChange,
466
+ export function BoardLayoutSettingsContent({
464
467
  boardId,
465
468
  wsId,
466
469
  lists,
467
470
  onUpdate,
471
+ disableScrollArea = false,
472
+ scrollAreaClassName,
468
473
  translations,
469
- }: BoardLayoutSettingsProps) {
474
+ }: BoardLayoutSettingsContentProps) {
470
475
  const t = useMemo(
471
476
  () => ({
472
477
  boardLayoutSettings:
@@ -895,139 +900,127 @@ export function BoardLayoutSettings({
895
900
  setCreatingList(true);
896
901
  }, []);
897
902
 
898
- return (
899
- <>
900
- <Dialog open={open} onOpenChange={onOpenChange}>
901
- <DialogContent className="max-w-3xl">
902
- <DialogHeader>
903
- <DialogTitle>{t.boardLayoutSettings}</DialogTitle>
904
- <DialogDescription>
905
- {t.boardLayoutSettingsDescription}
906
- </DialogDescription>
907
- </DialogHeader>
908
-
909
- <div className="space-y-6">
910
- {/* Lists by Status */}
911
- <ScrollArea className="h-125 pr-4">
912
- <DndContext
913
- sensors={sensors}
914
- collisionDetection={closestCenter}
915
- onDragEnd={handleDragEnd}
916
- >
917
- <div className="space-y-6">
918
- {statuses.map((status) => {
919
- const StatusIcon = statusConfig[status].icon;
920
- const statusLists = (groupedLists[status] || []).sort(
921
- (a, b) => (a?.position || 0) - (b?.position || 0)
922
- );
903
+ const listGroups = (
904
+ <DndContext
905
+ sensors={sensors}
906
+ collisionDetection={closestCenter}
907
+ onDragEnd={handleDragEnd}
908
+ >
909
+ <div className="space-y-6">
910
+ {statuses.map((status) => {
911
+ const StatusIcon = statusConfig[status].icon;
912
+ const statusLists = (groupedLists[status] || []).sort(
913
+ (a, b) => (a?.position || 0) - (b?.position || 0)
914
+ );
923
915
 
924
- return (
925
- <div key={status} className="space-y-3">
926
- <div className="flex items-center justify-between gap-3">
927
- <div className="flex items-center gap-2">
928
- <div
929
- className={cn(
930
- 'flex h-6 w-6 items-center justify-center rounded',
931
- statusConfig[status].bgColor
932
- )}
933
- >
934
- <StatusIcon
935
- className={cn(
936
- 'h-3.5 w-3.5',
937
- statusConfig[status].color
938
- )}
939
- />
940
- </div>
941
- <h3 className="font-semibold text-sm">
942
- {statusLabels[status]}
943
- </h3>
944
- <Badge variant="secondary" className="text-[10px]">
945
- {statusLists.length}
946
- </Badge>
947
- </div>
948
- <Button
949
- variant="ghost"
950
- size="sm"
951
- className="h-8 gap-1.5 px-2 text-muted-foreground hover:text-foreground"
952
- onClick={() => openCreateListDialog(status)}
953
- >
954
- <Plus className="h-3.5 w-3.5" />
955
- {t.addNewList}
956
- </Button>
957
- </div>
916
+ return (
917
+ <div key={status} className="space-y-3">
918
+ <div className="flex items-center justify-between gap-3">
919
+ <div className="flex items-center gap-2">
920
+ <div
921
+ className={cn(
922
+ 'flex h-6 w-6 items-center justify-center rounded',
923
+ statusConfig[status].bgColor
924
+ )}
925
+ >
926
+ <StatusIcon
927
+ className={cn('h-3.5 w-3.5', statusConfig[status].color)}
928
+ />
929
+ </div>
930
+ <h3 className="font-semibold text-sm">
931
+ {statusLabels[status]}
932
+ </h3>
933
+ <Badge variant="secondary" className="text-[10px]">
934
+ {statusLists.length}
935
+ </Badge>
936
+ </div>
937
+ <Button
938
+ variant="ghost"
939
+ size="sm"
940
+ className="h-8 gap-1.5 px-2 text-muted-foreground hover:text-foreground"
941
+ onClick={() => openCreateListDialog(status)}
942
+ >
943
+ <Plus className="h-3.5 w-3.5" />
944
+ {t.addNewList}
945
+ </Button>
946
+ </div>
958
947
 
959
- {statusLists.length === 0 ? (
960
- <div className="rounded-lg border-2 border-dashed p-4 text-center">
961
- <p className="text-muted-foreground text-sm">
962
- {t.noListsInStatus}
963
- </p>
964
- <Button
965
- variant="outline"
966
- size="sm"
967
- className="mt-3 gap-1.5"
968
- onClick={() => openCreateListDialog(status)}
969
- >
970
- <Plus className="h-3.5 w-3.5" />
971
- {t.addNewList}
972
- </Button>
973
- </div>
974
- ) : (
975
- <SortableContext
976
- items={statusLists.map((l) => l.id)}
977
- strategy={verticalListSortingStrategy}
978
- >
979
- <div className="space-y-2">
980
- {statusLists.map((list) => (
981
- <SortableListItem
982
- key={list.id}
983
- list={list}
984
- taskCount={0}
985
- onEdit={setEditingList}
986
- onDelete={setDeletingList}
987
- onColorChange={handleColorChange}
988
- translations={{
989
- task: t.task,
990
- tasks: t.tasks,
991
- changeColor: t.changeColor,
992
- editList: t.editList,
993
- deleteList: t.deleteList,
994
- backlog: t.backlog,
995
- active: t.active,
996
- review: t.review,
997
- doneStatus: t.doneStatus,
998
- closed: t.closed,
999
- documents: t.documents,
1000
- gray: t.gray,
1001
- red: t.red,
1002
- blue: t.blue,
1003
- green: t.green,
1004
- yellow: t.yellow,
1005
- orange: t.orange,
1006
- purple: t.purple,
1007
- pink: t.pink,
1008
- indigo: t.indigo,
1009
- cyan: t.cyan,
1010
- }}
1011
- />
1012
- ))}
1013
- </div>
1014
- </SortableContext>
1015
- )}
1016
- </div>
1017
- );
1018
- })}
948
+ {statusLists.length === 0 ? (
949
+ <div className="rounded-lg border-2 border-dashed p-4 text-center">
950
+ <p className="text-muted-foreground text-sm">
951
+ {t.noListsInStatus}
952
+ </p>
953
+ <Button
954
+ variant="outline"
955
+ size="sm"
956
+ className="mt-3 gap-1.5"
957
+ onClick={() => openCreateListDialog(status)}
958
+ >
959
+ <Plus className="h-3.5 w-3.5" />
960
+ {t.addNewList}
961
+ </Button>
1019
962
  </div>
1020
- </DndContext>
1021
- </ScrollArea>
1022
- </div>
963
+ ) : (
964
+ <SortableContext
965
+ items={statusLists.map((l) => l.id)}
966
+ strategy={verticalListSortingStrategy}
967
+ >
968
+ <div className="space-y-2">
969
+ {statusLists.map((list) => (
970
+ <SortableListItem
971
+ key={list.id}
972
+ list={list}
973
+ taskCount={0}
974
+ onEdit={setEditingList}
975
+ onDelete={setDeletingList}
976
+ onColorChange={handleColorChange}
977
+ translations={{
978
+ task: t.task,
979
+ tasks: t.tasks,
980
+ changeColor: t.changeColor,
981
+ editList: t.editList,
982
+ deleteList: t.deleteList,
983
+ backlog: t.backlog,
984
+ active: t.active,
985
+ review: t.review,
986
+ doneStatus: t.doneStatus,
987
+ closed: t.closed,
988
+ documents: t.documents,
989
+ gray: t.gray,
990
+ red: t.red,
991
+ blue: t.blue,
992
+ green: t.green,
993
+ yellow: t.yellow,
994
+ orange: t.orange,
995
+ purple: t.purple,
996
+ pink: t.pink,
997
+ indigo: t.indigo,
998
+ cyan: t.cyan,
999
+ }}
1000
+ />
1001
+ ))}
1002
+ </div>
1003
+ </SortableContext>
1004
+ )}
1005
+ </div>
1006
+ );
1007
+ })}
1008
+ </div>
1009
+ </DndContext>
1010
+ );
1023
1011
 
1024
- <DialogFooter>
1025
- <Button variant="outline" onClick={() => onOpenChange(false)}>
1026
- {t.done}
1027
- </Button>
1028
- </DialogFooter>
1029
- </DialogContent>
1030
- </Dialog>
1012
+ return (
1013
+ <>
1014
+ <div className="space-y-6">
1015
+ {/* Lists by Status */}
1016
+ {disableScrollArea ? (
1017
+ <div className={scrollAreaClassName}>{listGroups}</div>
1018
+ ) : (
1019
+ <ScrollArea className={cn('h-125 pr-4', scrollAreaClassName)}>
1020
+ {listGroups}
1021
+ </ScrollArea>
1022
+ )}
1023
+ </div>
1031
1024
 
1032
1025
  {/* Create List Dialog */}
1033
1026
  <CreateListDialog
@@ -1103,3 +1096,39 @@ export function BoardLayoutSettings({
1103
1096
  </>
1104
1097
  );
1105
1098
  }
1099
+
1100
+ export function BoardLayoutSettings({
1101
+ open,
1102
+ onOpenChange,
1103
+ translations,
1104
+ ...contentProps
1105
+ }: BoardLayoutSettingsProps) {
1106
+ const title = translations?.boardLayoutSettings ?? 'Board Layout Settings';
1107
+ const description =
1108
+ translations?.boardLayoutSettingsDescription ??
1109
+ 'Manage your board columns and organize them by status. Drag to reorder within each status group.';
1110
+ const done = translations?.done ?? 'Done';
1111
+
1112
+ return (
1113
+ <Dialog open={open} onOpenChange={onOpenChange}>
1114
+ <DialogContent className="max-w-3xl">
1115
+ <DialogHeader>
1116
+ <DialogTitle>{title}</DialogTitle>
1117
+ <DialogDescription>{description}</DialogDescription>
1118
+ </DialogHeader>
1119
+
1120
+ <BoardLayoutSettingsContent
1121
+ {...contentProps}
1122
+ scrollAreaClassName="h-125 pr-4"
1123
+ translations={translations}
1124
+ />
1125
+
1126
+ <DialogFooter>
1127
+ <Button variant="outline" onClick={() => onOpenChange(false)}>
1128
+ {done}
1129
+ </Button>
1130
+ </DialogFooter>
1131
+ </DialogContent>
1132
+ </Dialog>
1133
+ );
1134
+ }