From 4d0a3637f29d872a357b059fa379cf9e8939d7fa Mon Sep 17 00:00:00 2001 From: Jackson Kearl Date: Thu, 28 Jan 2021 11:46:49 -0800 Subject: [PATCH] Fix #115318: Getting started "Tweak My Settings" resets the getting started page --- .../gettingStarted/browser/gettingStarted.ts | 20 +++++++++++++------ 1 file changed, 14 insertions(+), 6 deletions(-) diff --git a/src/vs/workbench/contrib/welcome/gettingStarted/browser/gettingStarted.ts b/src/vs/workbench/contrib/welcome/gettingStarted/browser/gettingStarted.ts index d2ded164fe0..0d0fca860db 100644 --- a/src/vs/workbench/contrib/welcome/gettingStarted/browser/gettingStarted.ts +++ b/src/vs/workbench/contrib/welcome/gettingStarted/browser/gettingStarted.ts @@ -7,7 +7,7 @@ import 'vs/css!./gettingStarted'; import 'vs/workbench/contrib/welcome/gettingStarted/browser/vs_code_editor_getting_started'; import { localize } from 'vs/nls'; import { IInstantiationService } from 'vs/platform/instantiation/common/instantiation'; -import { WalkThroughInput } from 'vs/workbench/contrib/welcome/walkThrough/browser/walkThroughInput'; +import { WalkThroughInput, WalkThroughInputOptions } from 'vs/workbench/contrib/welcome/walkThrough/browser/walkThroughInput'; import { FileAccess, Schemas } from 'vs/base/common/network'; import { IEditorInputFactory } from 'vs/workbench/common/editor'; import { Disposable, DisposableStore } from 'vs/base/common/lifecycle'; @@ -26,6 +26,7 @@ import { DomScrollableElement } from 'vs/base/browser/ui/scrollbar/scrollableEle import { gettingStartedCheckedCodicon, gettingStartedUncheckedCodicon } from 'vs/workbench/contrib/welcome/gettingStarted/browser/gettingStartedIcons'; import { ServicesAccessor } from 'vs/editor/browser/editorExtensions'; import { IOpenerService } from 'vs/platform/opener/common/opener'; +import { ITextModelService } from 'vs/editor/common/services/resolverService'; export const gettingStartedInputTypeId = 'workbench.editors.gettingStartedInput'; const telemetryFrom = 'gettingStartedPage'; @@ -33,6 +34,15 @@ const telemetryFrom = 'gettingStartedPage'; export class GettingStartedInput extends WalkThroughInput { static readonly ID = gettingStartedInputTypeId; + constructor( + options: WalkThroughInputOptions & { selectedCategory?: string, selectedTask?: string }, + @ITextModelService textModelResolverService: ITextModelService + ) { + super(options, textModelResolverService); + this.selectedCategory = options.selectedCategory; + this.selectedTask = options.selectedTask; + } + selectedCategory: string | undefined; selectedTask: string | undefined; } @@ -53,8 +63,10 @@ export function getGettingStartedInput(accessor: ServicesAccessor, options: { se name: localize('editorGettingStarted.title', "Getting Started"), resource, telemetryFrom, + selectedCategory: options.selectedCategory, + selectedTask: options.selectedTask, onReady: (container: HTMLElement, disposableStore: DisposableStore) => { - const page = instantiationService.createInstance(GettingStartedPage, options, editorInput); + const page = instantiationService.createInstance(GettingStartedPage, editorInput); page.onReady(container); pages.push(page); disposableStore.add(page); @@ -79,7 +91,6 @@ export class GettingStartedPage extends Disposable { private detailImageScrollbar: DomScrollableElement | undefined; constructor( - initialState: { selectedCategory?: string, selectedTask?: string }, editorInput: GettingStartedInput, @ICommandService private readonly commandService: ICommandService, @IProductService private readonly productService: IProductService, @@ -92,9 +103,6 @@ export class GettingStartedPage extends Disposable { this.editorInput = editorInput; - this.editorInput.selectedCategory = initialState.selectedCategory; - this.editorInput.selectedTask = initialState.selectedTask; - this.gettingStartedCategories = this.gettingStartedService.getCategories(); this._register(this.dispatchListeners); this._register(this.gettingStartedService.onDidAddTask(task => console.log('added new task', task, 'that isnt being rendered yet')));