|
@ -78,7 +78,7 @@ import { arePlusFeaturesEnabled, ensurePlusFeaturesEnabled } from '../../subscri |
|
|
import type { |
|
|
import type { |
|
|
DimMergeCommitsParams, |
|
|
DimMergeCommitsParams, |
|
|
DismissBannerParams, |
|
|
DismissBannerParams, |
|
|
DoubleClickedRefParams, |
|
|
|
|
|
|
|
|
DoubleClickedParams, |
|
|
EnsureRowParams, |
|
|
EnsureRowParams, |
|
|
GetMissingAvatarsParams, |
|
|
GetMissingAvatarsParams, |
|
|
GetMissingRefsMetadataParams, |
|
|
GetMissingRefsMetadataParams, |
|
@ -125,7 +125,7 @@ import { |
|
|
DidSearchNotificationType, |
|
|
DidSearchNotificationType, |
|
|
DimMergeCommitsCommandType, |
|
|
DimMergeCommitsCommandType, |
|
|
DismissBannerCommandType, |
|
|
DismissBannerCommandType, |
|
|
DoubleClickedRefCommandType, |
|
|
|
|
|
|
|
|
DoubleClickedCommandType, |
|
|
EnsureRowCommandType, |
|
|
EnsureRowCommandType, |
|
|
GetMissingAvatarsCommandType, |
|
|
GetMissingAvatarsCommandType, |
|
|
GetMissingRefsMetadataCommandType, |
|
|
GetMissingRefsMetadataCommandType, |
|
@ -415,8 +415,8 @@ export class GraphWebview extends WebviewBase { |
|
|
case DismissBannerCommandType.method: |
|
|
case DismissBannerCommandType.method: |
|
|
onIpc(DismissBannerCommandType, e, params => this.dismissBanner(params)); |
|
|
onIpc(DismissBannerCommandType, e, params => this.dismissBanner(params)); |
|
|
break; |
|
|
break; |
|
|
case DoubleClickedRefCommandType.method: |
|
|
|
|
|
onIpc(DoubleClickedRefCommandType, e, params => this.onDoubleClickRef(params)); |
|
|
|
|
|
|
|
|
case DoubleClickedCommandType.method: |
|
|
|
|
|
onIpc(DoubleClickedCommandType, e, params => this.onDoubleClick(params)); |
|
|
break; |
|
|
break; |
|
|
case EnsureRowCommandType.method: |
|
|
case EnsureRowCommandType.method: |
|
|
onIpc(EnsureRowCommandType, e, params => this.onEnsureRow(params, e.completionId)); |
|
|
onIpc(EnsureRowCommandType, e, params => this.onEnsureRow(params, e.completionId)); |
|
@ -624,8 +624,8 @@ export class GraphWebview extends WebviewBase { |
|
|
this.updateExcludedRefs(this._graph, e.refs, e.visible); |
|
|
this.updateExcludedRefs(this._graph, e.refs, e.visible); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
private onDoubleClickRef(e: DoubleClickedRefParams) { |
|
|
|
|
|
if (e.ref.context) { |
|
|
|
|
|
|
|
|
private onDoubleClick(e: DoubleClickedParams) { |
|
|
|
|
|
if (e.type === 'ref' && e.ref.context) { |
|
|
const item = typeof e.ref.context === 'string' ? JSON.parse(e.ref.context) : e.ref.context; |
|
|
const item = typeof e.ref.context === 'string' ? JSON.parse(e.ref.context) : e.ref.context; |
|
|
if (!('webview' in item)) { |
|
|
if (!('webview' in item)) { |
|
|
item.webview = this.id; |
|
|
item.webview = this.id; |
|
@ -643,6 +643,9 @@ export class GraphWebview extends WebviewBase { |
|
|
configuration.isUnset('gitCommands.skipConfirmations') ? true : undefined, |
|
|
configuration.isUnset('gitCommands.skipConfirmations') ? true : undefined, |
|
|
); |
|
|
); |
|
|
} |
|
|
} |
|
|
|
|
|
} else if (e.type === 'row' && e.row) { |
|
|
|
|
|
const commit = this.getRevisionReference(this.repository?.path, e.row.id, e.row.type); |
|
|
|
|
|
if (commit != null) return GitActions.Commit.showDetailsView(commit, { preserveFocus: e.preserveFocus }); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
return Promise.resolve(); |
|
|
return Promise.resolve(); |
|
@ -931,22 +934,8 @@ export class GraphWebview extends WebviewBase { |
|
|
private fireSelectionChanged(id: string | undefined, type: GitGraphRowType | undefined) { |
|
|
private fireSelectionChanged(id: string | undefined, type: GitGraphRowType | undefined) { |
|
|
if (this.repository == null) return; |
|
|
if (this.repository == null) return; |
|
|
|
|
|
|
|
|
let commits: GitRevisionReference[] | undefined; |
|
|
|
|
|
if (id != null) { |
|
|
|
|
|
if (type === GitGraphRowType.Stash) { |
|
|
|
|
|
commits = [ |
|
|
|
|
|
GitReference.create(id, this.repository.path, { |
|
|
|
|
|
refType: 'stash', |
|
|
|
|
|
name: id, |
|
|
|
|
|
number: undefined, |
|
|
|
|
|
}), |
|
|
|
|
|
]; |
|
|
|
|
|
} else if (type === GitGraphRowType.Working) { |
|
|
|
|
|
commits = [GitReference.create(GitRevision.uncommitted, this.repository.path, { refType: 'revision' })]; |
|
|
|
|
|
} else { |
|
|
|
|
|
commits = [GitReference.create(id, this.repository.path, { refType: 'revision' })]; |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
const commit = this.getRevisionReference(this.repository.path, id, type); |
|
|
|
|
|
const commits = commit != null ? [commit] : undefined; |
|
|
|
|
|
|
|
|
this._selection = commits; |
|
|
this._selection = commits; |
|
|
this._onDidChangeSelection.fire({ selection: commits ?? [] }); |
|
|
this._onDidChangeSelection.fire({ selection: commits ?? [] }); |
|
@ -965,6 +954,29 @@ export class GraphWebview extends WebviewBase { |
|
|
|
|
|
|
|
|
private _notifyDidChangeStateDebounced: Deferrable<GraphWebview['notifyDidChangeState']> | undefined = undefined; |
|
|
private _notifyDidChangeStateDebounced: Deferrable<GraphWebview['notifyDidChangeState']> | undefined = undefined; |
|
|
|
|
|
|
|
|
|
|
|
private getRevisionReference( |
|
|
|
|
|
repoPath: string | undefined, |
|
|
|
|
|
id: string | undefined, |
|
|
|
|
|
type: GitGraphRowType | undefined, |
|
|
|
|
|
) { |
|
|
|
|
|
if (repoPath == null || id == null) return undefined; |
|
|
|
|
|
|
|
|
|
|
|
switch (type) { |
|
|
|
|
|
case GitGraphRowType.Stash: |
|
|
|
|
|
return GitReference.create(id, repoPath, { |
|
|
|
|
|
refType: 'stash', |
|
|
|
|
|
name: id, |
|
|
|
|
|
number: undefined, |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
case GitGraphRowType.Working: |
|
|
|
|
|
return GitReference.create(GitRevision.uncommitted, repoPath, { refType: 'revision' }); |
|
|
|
|
|
|
|
|
|
|
|
default: |
|
|
|
|
|
return GitReference.create(id, repoPath, { refType: 'revision' }); |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
@debug() |
|
|
@debug() |
|
|
private updateState(immediate: boolean = false) { |
|
|
private updateState(immediate: boolean = false) { |
|
|
this._pendingIpcNotifications.clear(); |
|
|
this._pendingIpcNotifications.clear(); |
|
|