Merge pull request #13 from mathuo/remove-circuluar-deps

feat: remove circular dependencies
This commit is contained in:
mathuo 2021-10-17 21:52:56 +01:00 committed by GitHub
commit 7c3343a431
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 39 additions and 42 deletions

View File

@ -1,6 +1,31 @@
import { PanelOptions } from '../dockview/options';
import { tryParseJSON } from '../json';
import { PanelTransfer, PaneTransfer } from './droptarget';
class TransferObject {
constructor() {
//
}
}
export class PanelTransfer extends TransferObject {
constructor(
public readonly viewId: string,
public readonly groupId: string,
public readonly panelId: string
) {
super();
}
}
export class PaneTransfer extends TransferObject {
constructor(
public readonly viewId: string,
public readonly paneId: string
) {
super();
}
}
export const DATA_KEY = 'splitview/transfer';

View File

@ -8,31 +8,6 @@ export interface DroptargetEvent {
event: DragEvent;
}
class TransferObject {
constructor() {
//
}
}
export class PanelTransfer extends TransferObject {
constructor(
public readonly viewId: string,
public readonly groupId: string,
public readonly panelId: string
) {
super();
}
}
export class PaneTransfer extends TransferObject {
constructor(
public readonly viewId: string,
public readonly paneId: string
) {
super();
}
}
export enum Position {
Top = 'Top',
Left = 'Left',

View File

@ -0,0 +1,5 @@
export enum DockviewDropTargets {
Tab,
Panel,
TabContainer,
}

View File

@ -18,6 +18,7 @@ import { ITabsContainer, TabsContainer } from './titlebar/tabsContainer';
import { IWatermarkRenderer } from './types';
import { GroupviewPanel } from './groupviewPanel';
import { focusedElement } from '../focusedElement';
import { DockviewDropTargets } from './dnd';
export enum GroupChangeKind {
GROUP_ACTIVE = 'GROUP_ACTIVE',
@ -86,12 +87,6 @@ export interface GroupPanelViewState {
id: string;
}
export enum DockviewDropTargets {
Tab,
Panel,
TabContainer,
}
export interface IGroupview extends IDisposable, IGridPanelView {
readonly isActive: boolean;
readonly size: number;

View File

@ -7,8 +7,9 @@ import { ITabRenderer } from './types';
import { focusedElement } from '../focusedElement';
import { IGroupPanel } from './groupPanel';
import { GroupviewPanel } from './groupviewPanel';
import { DroptargetEvent, Droptarget, PanelTransfer } from '../dnd/droptarget';
import { DockviewDropTargets } from './groupview';
import { DroptargetEvent, Droptarget } from '../dnd/droptarget';
import { PanelTransfer } from '../dnd/dataTransfer';
import { DockviewDropTargets } from './dnd';
export enum MouseEventKind {
CLICK = 'CLICK',

View File

@ -11,7 +11,7 @@ import { IDockviewComponent } from '../../dockview/dockviewComponent';
import { getPanelData } from '../../dnd/dataTransfer';
import { GroupviewPanel } from '../groupviewPanel';
import { Droptarget } from '../../dnd/droptarget';
import { DockviewDropTargets } from '../groupview';
import { DockviewDropTargets } from '../dnd';
export interface TabDropIndexEvent {
event: DragEvent;

View File

@ -1,11 +1,7 @@
import { DragHandler } from '../dnd/abstractDragHandler';
import { getPaneData, LocalSelectionTransfer } from '../dnd/dataTransfer';
import {
Droptarget,
DroptargetEvent,
PaneTransfer,
Position,
} from '../dnd/droptarget';
import { Droptarget, DroptargetEvent, Position } from '../dnd/droptarget';
import { PaneTransfer } from '../dnd/dataTransfer';
import { Emitter, Event } from '../events';
import { IDisposable } from '../lifecycle';
import { Orientation } from '../splitview/core/splitview';

View File

@ -141,8 +141,8 @@ export class Paneview extends CompositeDisposable implements IDisposable {
}
public removePane(index: number) {
this.splitview.removeView(index);
const paneItem = this.paneItems.splice(index, 1)[0];
this.splitview.removeView(index);
paneItem.disposable.dispose();
return paneItem;
}