dockview-core 5.2.0 → 6.0.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 (117) hide show
  1. package/README.md +3 -1
  2. package/dist/cjs/api/component.api.d.ts +93 -1
  3. package/dist/cjs/api/component.api.js +146 -0
  4. package/dist/cjs/api/dockviewGroupPanelApi.d.ts +26 -0
  5. package/dist/cjs/api/dockviewGroupPanelApi.js +21 -1
  6. package/dist/cjs/api/entryPoints.js +4 -5
  7. package/dist/cjs/array.js +7 -8
  8. package/dist/cjs/dnd/dataTransfer.d.ts +2 -1
  9. package/dist/cjs/dnd/dataTransfer.js +5 -4
  10. package/dist/cjs/dnd/droptarget.d.ts +12 -0
  11. package/dist/cjs/dnd/droptarget.js +38 -10
  12. package/dist/cjs/dnd/ghost.js +1 -2
  13. package/dist/cjs/dockview/components/panel/content.js +5 -1
  14. package/dist/cjs/dockview/components/popupService.d.ts +9 -2
  15. package/dist/cjs/dockview/components/popupService.js +24 -9
  16. package/dist/cjs/dockview/components/tab/tab.d.ts +6 -1
  17. package/dist/cjs/dockview/components/tab/tab.js +81 -9
  18. package/dist/cjs/dockview/components/titlebar/tabGroupChip.d.ts +30 -0
  19. package/dist/cjs/dockview/components/titlebar/tabGroupChip.js +95 -0
  20. package/dist/cjs/dockview/components/titlebar/tabGroupIndicator.d.ts +71 -0
  21. package/dist/cjs/dockview/components/titlebar/tabGroupIndicator.js +471 -0
  22. package/dist/cjs/dockview/components/titlebar/tabGroups.d.ts +57 -0
  23. package/dist/cjs/dockview/components/titlebar/tabGroups.js +612 -0
  24. package/dist/cjs/dockview/components/titlebar/tabOverflowControl.js +1 -2
  25. package/dist/cjs/dockview/components/titlebar/tabs.d.ts +59 -0
  26. package/dist/cjs/dockview/components/titlebar/tabs.js +1227 -144
  27. package/dist/cjs/dockview/components/titlebar/tabsContainer.d.ts +6 -0
  28. package/dist/cjs/dockview/components/titlebar/tabsContainer.js +132 -14
  29. package/dist/cjs/dockview/contextMenu.d.ts +10 -0
  30. package/dist/cjs/dockview/contextMenu.js +298 -0
  31. package/dist/cjs/dockview/dockviewComponent.d.ts +60 -3
  32. package/dist/cjs/dockview/dockviewComponent.js +712 -126
  33. package/dist/cjs/dockview/dockviewGroupPanelModel.d.ts +83 -0
  34. package/dist/cjs/dockview/dockviewGroupPanelModel.js +619 -27
  35. package/dist/cjs/dockview/dockviewShell.d.ts +128 -0
  36. package/dist/cjs/dockview/dockviewShell.js +681 -0
  37. package/dist/cjs/dockview/events.d.ts +9 -0
  38. package/dist/cjs/dockview/framework.d.ts +14 -0
  39. package/dist/cjs/dockview/options.d.ts +92 -10
  40. package/dist/cjs/dockview/options.js +10 -7
  41. package/dist/cjs/dockview/tabGroup.d.ts +99 -0
  42. package/dist/cjs/dockview/tabGroup.js +219 -0
  43. package/dist/cjs/dockview/tabGroupAccent.d.ts +65 -0
  44. package/dist/cjs/dockview/tabGroupAccent.js +128 -0
  45. package/dist/cjs/dockview/theme.d.ts +56 -1
  46. package/dist/cjs/dockview/theme.js +103 -6
  47. package/dist/cjs/dockview/types.d.ts +2 -0
  48. package/dist/cjs/dom.js +19 -19
  49. package/dist/cjs/events.js +2 -2
  50. package/dist/cjs/gridview/baseComponentGridview.d.ts +1 -0
  51. package/dist/cjs/gridview/baseComponentGridview.js +6 -3
  52. package/dist/cjs/gridview/gridview.js +7 -7
  53. package/dist/cjs/index.d.ts +8 -5
  54. package/dist/cjs/index.js +6 -1
  55. package/dist/cjs/popoutWindow.js +3 -3
  56. package/dist/cjs/splitview/splitviewPanel.d.ts +1 -1
  57. package/dist/dockview-core.js +6942 -2777
  58. package/dist/dockview-core.min.js +2 -2
  59. package/dist/dockview-core.min.js.map +1 -1
  60. package/dist/dockview-core.min.noStyle.js +2 -2
  61. package/dist/dockview-core.min.noStyle.js.map +1 -1
  62. package/dist/dockview-core.noStyle.js +6940 -2775
  63. package/dist/esm/api/component.api.d.ts +93 -1
  64. package/dist/esm/api/component.api.js +118 -0
  65. package/dist/esm/api/dockviewGroupPanelApi.d.ts +26 -0
  66. package/dist/esm/api/dockviewGroupPanelApi.js +21 -1
  67. package/dist/esm/dnd/dataTransfer.d.ts +2 -1
  68. package/dist/esm/dnd/dataTransfer.js +2 -1
  69. package/dist/esm/dnd/droptarget.d.ts +12 -0
  70. package/dist/esm/dnd/droptarget.js +33 -5
  71. package/dist/esm/dockview/components/panel/content.js +5 -1
  72. package/dist/esm/dockview/components/popupService.d.ts +9 -2
  73. package/dist/esm/dockview/components/popupService.js +23 -9
  74. package/dist/esm/dockview/components/tab/tab.d.ts +6 -1
  75. package/dist/esm/dockview/components/tab/tab.js +83 -9
  76. package/dist/esm/dockview/components/titlebar/tabGroupChip.d.ts +30 -0
  77. package/dist/esm/dockview/components/titlebar/tabGroupChip.js +68 -0
  78. package/dist/esm/dockview/components/titlebar/tabGroupIndicator.d.ts +71 -0
  79. package/dist/esm/dockview/components/titlebar/tabGroupIndicator.js +354 -0
  80. package/dist/esm/dockview/components/titlebar/tabGroups.d.ts +57 -0
  81. package/dist/esm/dockview/components/titlebar/tabGroups.js +406 -0
  82. package/dist/esm/dockview/components/titlebar/tabs.d.ts +59 -0
  83. package/dist/esm/dockview/components/titlebar/tabs.js +1011 -99
  84. package/dist/esm/dockview/components/titlebar/tabsContainer.d.ts +6 -0
  85. package/dist/esm/dockview/components/titlebar/tabsContainer.js +105 -7
  86. package/dist/esm/dockview/contextMenu.d.ts +10 -0
  87. package/dist/esm/dockview/contextMenu.js +213 -0
  88. package/dist/esm/dockview/dockviewComponent.d.ts +60 -3
  89. package/dist/esm/dockview/dockviewComponent.js +460 -35
  90. package/dist/esm/dockview/dockviewGroupPanelModel.d.ts +83 -0
  91. package/dist/esm/dockview/dockviewGroupPanelModel.js +460 -4
  92. package/dist/esm/dockview/dockviewShell.d.ts +128 -0
  93. package/dist/esm/dockview/dockviewShell.js +621 -0
  94. package/dist/esm/dockview/events.d.ts +9 -0
  95. package/dist/esm/dockview/framework.d.ts +14 -0
  96. package/dist/esm/dockview/options.d.ts +92 -10
  97. package/dist/esm/dockview/options.js +5 -2
  98. package/dist/esm/dockview/tabGroup.d.ts +99 -0
  99. package/dist/esm/dockview/tabGroup.js +144 -0
  100. package/dist/esm/dockview/tabGroupAccent.d.ts +65 -0
  101. package/dist/esm/dockview/tabGroupAccent.js +116 -0
  102. package/dist/esm/dockview/theme.d.ts +56 -1
  103. package/dist/esm/dockview/theme.js +102 -5
  104. package/dist/esm/dockview/types.d.ts +2 -0
  105. package/dist/esm/dom.js +1 -1
  106. package/dist/esm/gridview/baseComponentGridview.d.ts +1 -0
  107. package/dist/esm/gridview/baseComponentGridview.js +4 -1
  108. package/dist/esm/index.d.ts +8 -5
  109. package/dist/esm/index.js +2 -1
  110. package/dist/esm/popoutWindow.js +1 -1
  111. package/dist/esm/splitview/splitviewPanel.d.ts +1 -1
  112. package/dist/package/main.cjs.js +6936 -2801
  113. package/dist/package/main.cjs.min.js +2 -2
  114. package/dist/package/main.esm.min.mjs +2 -2
  115. package/dist/package/main.esm.mjs +6922 -2800
  116. package/dist/styles/dockview.css +1945 -196
  117. package/package.json +5 -1
@@ -15,10 +15,19 @@ export declare class Tabs extends CompositeDisposable {
15
15
  private readonly _observerDisposable;
16
16
  private readonly _scrollbar;
17
17
  private _tabs;
18
+ private readonly _tabMap;
18
19
  private selectedIndex;
19
20
  private _showTabsOverflowControl;
20
21
  private _direction;
21
22
  private _animState;
23
+ private readonly _pendingMarginCleanups;
24
+ private _pendingCollapse;
25
+ private _flipTransitionCleanup;
26
+ private _voidContainer;
27
+ private _voidContainerListeners;
28
+ private _extendedDropZone;
29
+ private _chipDragCleanup;
30
+ private readonly _tabGroupManager;
22
31
  private readonly _onTabDragStart;
23
32
  readonly onTabDragStart: Event<TabDragEvent>;
24
33
  private readonly _onDrop;
@@ -28,11 +37,19 @@ export declare class Tabs extends CompositeDisposable {
28
37
  private readonly _onOverflowTabsChange;
29
38
  readonly onOverflowTabsChange: Event<{
30
39
  tabs: string[];
40
+ tabGroups: string[];
31
41
  reset: boolean;
32
42
  }>;
33
43
  get showTabsOverflowControl(): boolean;
34
44
  set showTabsOverflowControl(value: boolean);
35
45
  get element(): HTMLElement;
46
+ set voidContainer(el: HTMLElement | null);
47
+ /**
48
+ * Handle a drop that occurred on the void container (empty header
49
+ * space to the right of the tabs). Returns `true` if the drop was
50
+ * consumed by an active group drag, `false` otherwise.
51
+ */
52
+ handleVoidDrop(): boolean;
36
53
  get panels(): string[];
37
54
  get size(): number;
38
55
  get tabs(): Tab[];
@@ -49,11 +66,53 @@ export declare class Tabs extends CompositeDisposable {
49
66
  private addTab;
50
67
  private toggleDropdown;
51
68
  updateDragAndDropState(): void;
69
+ /**
70
+ * Synchronize chip elements and CSS classes for all tab groups
71
+ * in the parent group model. Call after any tab group mutation.
72
+ */
73
+ updateTabGroups(): void;
74
+ refreshTabGroupAccent(): void;
75
+ private _handleChipDragStart;
76
+ /**
77
+ * Sets the broader container that is part of the same logical drop surface
78
+ * as this tab list (e.g. the full header element). When a dragleave from
79
+ * the tabs list lands inside this container, `_animState` is preserved so
80
+ * that external dragover listeners can continue the animation.
81
+ */
82
+ setExtendedDropZone(el: HTMLElement): void;
83
+ /**
84
+ * Allows external elements (e.g. void container, left actions) to push an
85
+ * insertion index into the animation while the cursor is outside the tabs
86
+ * list itself. Pass `null` to clear the indicator.
87
+ */
88
+ setExternalInsertionIndex(index: number | null): void;
89
+ /**
90
+ * Called when the drag cursor leaves the entire header area (not just the
91
+ * tabs list). Clears animation state for cross-group drags, which never
92
+ * receive a `dragend` event on this tab list.
93
+ */
94
+ clearExternalAnimState(): void;
52
95
  private snapshotTabPositions;
53
96
  private getAverageTabWidth;
54
97
  private handleDragOver;
98
+ /**
99
+ * Batch-remove a CSS class from multiple elements instantly,
100
+ * forcing only a single reflow for the entire batch.
101
+ */
102
+ private _removeClassInstantlyBatch;
103
+ /**
104
+ * Remove `dv-tab--dragging` from the source tab instantly so it
105
+ * regains its real width before FLIP snapshots.
106
+ */
107
+ private _uncollapsSourceTab;
55
108
  private applyDragOverTransforms;
56
109
  private resetTabTransforms;
110
+ /**
111
+ * Commit a group-drag drop: clear drag classes, move the group
112
+ * in the model, and run a FLIP animation.
113
+ */
114
+ private _commitGroupMove;
115
+ private _clearGroupDragClasses;
57
116
  private resetDragAnimation;
58
117
  private runFlipAnimation;
59
118
  }