规范了文件结构
Some checks failed
Monaco Editor checks / Monaco Editor checks (push) Failing after 39s

This commit is contained in:
mxwj 2024-11-21 16:39:15 +08:00
parent 42f411fc64
commit 11b799fa14
5 changed files with 160 additions and 302 deletions

@ -0,0 +1,149 @@
/*---------------------------------------------------------------------------------------------
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License. See License.txt in the project root for license information.
*--------------------------------------------------------------------------------------------*/
import { EditorPane } from '../../../../browser/parts/editor/editorPane.js';
import { Dimension } from '../../../../../base/browser/dom.js';
import { StockDetailsInput } from './StockDetailsInput.js';
import { ITelemetryService } from '../../../../../platform/telemetry/common/telemetry.js';
import { IThemeService } from '../../../../../platform/theme/common/themeService.js';
import { IStorageService } from '../../../../../platform/storage/common/storage.js';
import { CancellationToken } from '../../../../../base/common/cancellation.js';
import { IEditorOptions } from '../../../../../platform/editor/common/editor.js';
import { IEditorOpenContext } from '../../../../common/editor.js';
import { IEditorGroup } from '../../../../services/editor/common/editorGroupsService.js';
export class StockDetailsEditor extends EditorPane {
static readonly ID = 'workbench.editor.stockDetails';
private container: HTMLElement | null = null;
constructor(
group: IEditorGroup,
@ITelemetryService telemetryService: ITelemetryService,
@IThemeService themeService: IThemeService,
@IStorageService storageService: IStorageService
) {
super(StockDetailsEditor.ID, group, telemetryService, themeService, storageService);
}
/**
*
*/
protected createEditor(parent: HTMLElement): void {
this.container = document.createElement('div');
this.container.className = 'stock-details-editor';
// 添加占位符
const placeholder = document.createElement('div');
placeholder.className = 'stock-placeholder';
placeholder.textContent = '请选择一只股票查看详情';
this.container.appendChild(placeholder);
parent.appendChild(this.container);
}
/**
*
*/
override async setInput(
input: StockDetailsInput,
options: IEditorOptions | undefined,
context: IEditorOpenContext,
token: CancellationToken
): Promise<void> {
await super.setInput(input, options, context, token);
if (input.resource) {
console.log(`setInput 接收到股票代码: ${input.getCode()}`);
const stockCode = input.getCode();
if (!stockCode || stockCode.trim() === '') {
this.renderErrorMessage('股票代码为空,请选择有效的股票。');
return;
}
this.renderStockDetails(stockCode);
} else {
this.renderErrorMessage('未提供有效的股票代码');
}
}
/**
*
*/
private renderStockDetails(stockCode: string): void {
if (!this.container) {
return;
}
// 清空容器内容
this.container.textContent = ''; // 不使用 innerHTML
// 创建标题
const title = document.createElement('h3');
title.textContent = '股票详情';
// 使用内联样式修改标题样式
title.style.fontSize = '24px'; // 修改字体大小为 24 像素
title.style.fontWeight = 'bold'; // 设置字体加粗
title.style.margin = '10px 0'; // 设置上下外边距
// 创建股票代码段
const codeInfo = document.createElement('p');
codeInfo.textContent = `代码: ${stockCode}`;
// 模拟价格信息
const priceInfo = document.createElement('p');
priceInfo.textContent = '价格: ¥123.45';
// 模拟涨跌幅信息
const changeInfo = document.createElement('p');
changeInfo.textContent = '涨跌幅: +3.21%';
// 添加到容器
this.container.appendChild(title);
this.container.appendChild(codeInfo);
this.container.appendChild(priceInfo);
this.container.appendChild(changeInfo);
}
/**
*
*/
private renderErrorMessage(message: string): void {
if (!this.container) {
return;
}
this.container.textContent = ''; // 清空之前的内容
const errorDiv = document.createElement('div');
errorDiv.className = 'stock-error';
errorDiv.textContent = message;
this.container.appendChild(errorDiv);
}
/**
*
*/
override layout(dimension: Dimension): void {
if (this.container) {
this.container.style.width = `${dimension.width}px`;
this.container.style.height = `${dimension.height}px`;
}
}
/**
*
*/
override clearInput(): void {
if (this.container) {
this.container.textContent = ''; // 不使用 innerHTML
}
super.clearInput();
}
}

@ -16,15 +16,9 @@ export class StockDetailsInput extends EditorInput {
constructor(resource: URI) {
super();
// 打印传入的 URI无论是否有效
console.log(`StockDetailsInput 创建: ${resource ? resource.toString() : 'undefined'}`);
if (!resource || !resource.path || resource.path.trim() === '') {
// 如果 URI 无效,仅输出警告,不抛出异常
console.warn(`StockDetailsInput: 收到无效的资源路径 ${resource ? resource.toString() : 'undefined'}`);
}
this.resource = resource;
}
@ -33,7 +27,14 @@ export class StockDetailsInput extends EditorInput {
}
override getName(): string {
return `Stock Details (${this.resource.path})`;
// 获取股票代码部分
const stockCode = this.resource.toString().replace(/^stock-details:\/\/+/, ''); // 移除前缀 'stock-details://'
return `${stockCode}`; // 自定义标题
}
public getCode(): string {
// 从 URI 中提取股票代码,移除前缀 'stock-details://'
return this.resource.toString().replace(/^stock-details:\/\/+/, '');
}
override matches(other: EditorInput): boolean {

@ -19,8 +19,8 @@ import { ExampleView } from './views/exampleView.js';
import { IViewPaneOptions } from '../../../browser/parts/views/viewPane.js';
import { EditorPaneDescriptor, IEditorPaneRegistry } from '../../../browser/editor.js';
import { EditorExtensions } from '../../../common/editor.js';
import { StockDetailsEditor } from './views/StockDetailsEditor.js';
import { StockDetailsInput } from './views/StockDetailsInput.js';
import { StockDetailsEditor } from './editors/StockDetailsEditor.js';
import { StockDetailsInput } from './editors/StockDetailsInput.js';

@ -1,292 +0,0 @@
/*---------------------------------------------------------------------------------------------
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License. See License.txt in the project root for license information.
*--------------------------------------------------------------------------------------------*/
// import { EditorPane } from '../../../../browser/parts/editor/editorPane.js';
// import { Dimension } from '../../../../../base/browser/dom.js';
// import { StockDetailsInput } from './StockDetailsInput.js';
// import { ITelemetryService } from '../../../../../platform/telemetry/common/telemetry.js';
// import { IThemeService } from '../../../../../platform/theme/common/themeService.js';
// import { IStorageService } from '../../../../../platform/storage/common/storage.js';
// import { CancellationToken } from '../../../../../base/common/cancellation.js';
// import { IEditorOptions } from '../../../../../platform/editor/common/editor.js';
// import { IEditorOpenContext } from '../../../../common/editor.js';
// export class StockDetailsEditor extends EditorPane {
// static readonly ID = 'workbench.editor.stockDetails';
// private container: HTMLElement | null = null;
// constructor(
// id: string,
// group: any, // 实际类型是 IEditorGroup
// @ITelemetryService telemetryService: ITelemetryService,
// @IThemeService themeService: IThemeService,
// @IStorageService storageService: IStorageService
// ) {
// super(id, group, telemetryService, themeService, storageService);
// }
// protected createEditor(parent: HTMLElement): void {
// this.container = document.createElement('div');
// this.container.className = 'stock-details-editor';
// parent.appendChild(this.container);
// }
// override async setInput(
// input: StockDetailsInput,
// options: IEditorOptions | undefined,
// context: IEditorOpenContext,
// token: CancellationToken
// ): Promise<void> {
// super.setInput(input, options, context, token);
// if (input.resource) {
// const stockCode = input.resource.path;
// this.container!.innerHTML = `加载股票详情: ${stockCode}`;
// // 加载和渲染股票数据逻辑
// }
// }
// override layout(dimension: Dimension): void {
// // 实现布局逻辑
// }
// override clearInput(): void {
// if (this.container) {
// this.container.innerHTML = '';
// }
// super.clearInput();
// }
// }
// import { EditorPane } from '../../../../browser/parts/editor/editorPane.js';
// import { Dimension } from '../../../../../base/browser/dom.js';
// import { StockDetailsInput } from './StockDetailsInput.js';
// import { ITelemetryService } from '../../../../../platform/telemetry/common/telemetry.js';
// import { IThemeService } from '../../../../../platform/theme/common/themeService.js';
// import { IStorageService } from '../../../../../platform/storage/common/storage.js';
// import { CancellationToken } from '../../../../../base/common/cancellation.js';
// import { IEditorOptions } from '../../../../../platform/editor/common/editor.js';
// import { IEditorOpenContext } from '../../../../common/editor.js';
// import { IEditorGroup } from '../../../../services/editor/common/editorGroupsService.js';
// export class StockDetailsEditor extends EditorPane {
// static readonly ID = 'workbench.editor.stockDetails';
// private container: HTMLElement | null = null;
// constructor(
// group: IEditorGroup, // 修改第一个参数为 IEditorGroup 类型
// @ITelemetryService telemetryService: ITelemetryService,
// @IThemeService themeService: IThemeService,
// @IStorageService storageService: IStorageService
// ) {
// super(StockDetailsEditor.ID, group, telemetryService, themeService, storageService); // ID 移动到 super 调用
// }
// protected createEditor(parent: HTMLElement): void {
// this.container = document.createElement('div');
// this.container.className = 'stock-details-editor';
// parent.appendChild(this.container);
// }
// override async setInput(
// input: StockDetailsInput,
// options: IEditorOptions | undefined,
// context: IEditorOpenContext,
// token: CancellationToken
// ): Promise<void> {
// super.setInput(input, options, context, token);
// if (input.resource) {
// const stockCode = input.resource.path;
// // 清空之前的内容
// this.container!.textContent = '';
// // 创建一个新的 div 节点
// const stockDetailsDiv = document.createElement('div');
// stockDetailsDiv.className = 'stock-details';
// stockDetailsDiv.textContent = `加载股票详情: ${stockCode}`;
// // 将节点插入到容器中
// this.container!.appendChild(stockDetailsDiv);
// } else {
// this.container!.textContent = '未提供有效的股票代码';
// }
// }
// override layout(dimension: Dimension): void {
// // 实现布局逻辑
// }
// override clearInput(): void {
// if (this.container) {
// this.container.innerHTML = '';
// }
// super.clearInput();
// }
// }
import { EditorPane } from '../../../../browser/parts/editor/editorPane.js';
import { Dimension } from '../../../../../base/browser/dom.js';
import { StockDetailsInput } from './StockDetailsInput.js';
import { ITelemetryService } from '../../../../../platform/telemetry/common/telemetry.js';
import { IThemeService } from '../../../../../platform/theme/common/themeService.js';
import { IStorageService } from '../../../../../platform/storage/common/storage.js';
import { CancellationToken } from '../../../../../base/common/cancellation.js';
import { IEditorOptions } from '../../../../../platform/editor/common/editor.js';
import { IEditorOpenContext } from '../../../../common/editor.js';
import { IEditorGroup } from '../../../../services/editor/common/editorGroupsService.js';
export class StockDetailsEditor extends EditorPane {
static readonly ID = 'workbench.editor.stockDetails';
private container: HTMLElement | null = null;
constructor(
group: IEditorGroup,
@ITelemetryService telemetryService: ITelemetryService,
@IThemeService themeService: IThemeService,
@IStorageService storageService: IStorageService
) {
super(StockDetailsEditor.ID, group, telemetryService, themeService, storageService);
}
/**
*
*/
protected createEditor(parent: HTMLElement): void {
this.container = document.createElement('div');
this.container.className = 'stock-details-editor';
// 添加占位符
const placeholder = document.createElement('div');
placeholder.className = 'stock-placeholder';
placeholder.textContent = '请选择一只股票查看详情';
this.container.appendChild(placeholder);
parent.appendChild(this.container);
}
/**
*
*/
// override async setInput(
// input: StockDetailsInput,
// options: IEditorOptions | undefined,
// context: IEditorOpenContext,
// token: CancellationToken
// ): Promise<void> {
// await super.setInput(input, options, context, token);
// if (input.resource) {
// const stockCode = input.resource.path;
// // 清空现有内容并加载新的股票详情。
// this.renderStockDetails(stockCode);
// } else {
// this.renderErrorMessage('未提供有效的股票代码');
// }
// }
override async setInput(
input: StockDetailsInput,
options: IEditorOptions | undefined,
context: IEditorOpenContext,
token: CancellationToken
): Promise<void> {
await super.setInput(input, options, context, token);
if (input.resource) {
console.log(`setInput 接收到资源: ${input.resource.toString()}`);
const stockCode = input.resource.toString();
if (!stockCode || stockCode.trim() === '') {
this.renderErrorMessage('股票代码为空,请选择有效的股票。');
return;
}
this.renderStockDetails(stockCode);
} else {
this.renderErrorMessage('未提供有效的股票代码');
}
}
/**
*
*/
private renderStockDetails(stockCode: string): void {
if (!this.container) {
return;
}
// 清空容器内容
this.container.textContent = ''; // 不使用 innerHTML
// 创建标题
const title = document.createElement('h3');
title.textContent = '股票详情';
// 创建股票代码段
const codeInfo = document.createElement('p');
codeInfo.textContent = `代码: ${stockCode}`;
// 模拟价格信息
const priceInfo = document.createElement('p');
priceInfo.textContent = '价格: ¥123.45';
// 模拟涨跌幅信息
const changeInfo = document.createElement('p');
changeInfo.textContent = '涨跌幅: +3.21%';
// 添加到容器
this.container.appendChild(title);
this.container.appendChild(codeInfo);
this.container.appendChild(priceInfo);
this.container.appendChild(changeInfo);
}
/**
*
*/
private renderErrorMessage(message: string): void {
if (!this.container) {
return;
}
this.container.textContent = ''; // 清空之前的内容
const errorDiv = document.createElement('div');
errorDiv.className = 'stock-error';
errorDiv.textContent = message;
this.container.appendChild(errorDiv);
}
/**
*
*/
override layout(dimension: Dimension): void {
if (this.container) {
this.container.style.width = `${dimension.width}px`;
this.container.style.height = `${dimension.height}px`;
}
}
/**
*
*/
override clearInput(): void {
if (this.container) {
this.container.textContent = ''; // 不使用 innerHTML
}
super.clearInput();
}
}

@ -21,7 +21,7 @@ import { URI } from '../../../../../base/common/uri.js';
import './media/exampleViewContainer.css';
import { IEditorService } from '../../../../services/editor/common/editorService.js';
import { StockDetailsInput } from './StockDetailsInput.js';
import { StockDetailsInput } from '../editors/StockDetailsInput.js';
export class ExampleView extends ViewPane {
constructor(