mirror of
https://github.com/arduino/arduino-ide.git
synced 2025-10-24 10:38:32 +00:00

Selecting "Help > Environment" from the Arduino IDE menus opens a page containing usage information for the Arduino IDE application in the browser. Previously, the URL used was the same as that of in Arduino IDE 1.x: https://www.arduino.cc/en/Guide/Environment The documentation from that page was written for Arduino IDE 1.x. Even though the UI of the two versions is aligned for the most part, some advancements made for the 2.x major version series resulted in some differences. This means that documentation targeted at Arduino IDE 1.x is not always applicable to Arduino IDE 2.x. Fortunately, documentation is now available for each major version series of the IDE. So resolution is only a matter of pointing the menu item at the correct URL.
193 lines
6.6 KiB
TypeScript
193 lines
6.6 KiB
TypeScript
import { inject, injectable } from '@theia/core/shared/inversify';
|
|
import { MonacoEditor } from '@theia/monaco/lib/browser/monaco-editor';
|
|
import { EditorManager } from '@theia/editor/lib/browser/editor-manager';
|
|
import { WindowService } from '@theia/core/lib/browser/window/window-service';
|
|
import { CommandHandler } from '@theia/core/lib/common/command';
|
|
import { ArduinoMenus } from '../menu/arduino-menus';
|
|
import { QuickInputService } from '@theia/core/lib/browser/quick-input/quick-input-service';
|
|
import {
|
|
Contribution,
|
|
Command,
|
|
MenuModelRegistry,
|
|
CommandRegistry,
|
|
KeybindingRegistry,
|
|
} from './contribution';
|
|
import { nls } from '@theia/core/lib/common';
|
|
import { IDEUpdaterCommands } from '../ide-updater/ide-updater-commands';
|
|
import { ElectronCommands } from '@theia/core/lib/electron-browser/menu/electron-menu-contribution';
|
|
import * as monaco from '@theia/monaco-editor-core';
|
|
|
|
@injectable()
|
|
export class Help extends Contribution {
|
|
@inject(EditorManager)
|
|
protected readonly editorManager: EditorManager;
|
|
|
|
@inject(WindowService)
|
|
protected readonly windowService: WindowService;
|
|
|
|
@inject(QuickInputService)
|
|
protected readonly quickInputService: QuickInputService;
|
|
|
|
override registerCommands(registry: CommandRegistry): void {
|
|
const open = (url: string) =>
|
|
this.windowService.openNewWindow(url, { external: true });
|
|
const createOpenHandler = (url: string) =>
|
|
<CommandHandler>{
|
|
execute: () => open(url),
|
|
};
|
|
registry.registerCommand(
|
|
Help.Commands.GETTING_STARTED,
|
|
createOpenHandler('https://www.arduino.cc/en/Guide')
|
|
);
|
|
registry.registerCommand(
|
|
Help.Commands.ENVIRONMENT,
|
|
createOpenHandler(
|
|
'https://docs.arduino.cc/software/ide-v2/tutorials/getting-started-ide-v2'
|
|
)
|
|
);
|
|
registry.registerCommand(
|
|
Help.Commands.TROUBLESHOOTING,
|
|
createOpenHandler('https://support.arduino.cc/hc/en-us')
|
|
);
|
|
registry.registerCommand(
|
|
Help.Commands.REFERENCE,
|
|
createOpenHandler('https://www.arduino.cc/reference/en/')
|
|
);
|
|
registry.registerCommand(Help.Commands.FIND_IN_REFERENCE, {
|
|
execute: async () => {
|
|
let searchFor: string | undefined = undefined;
|
|
const { currentEditor } = this.editorManager;
|
|
if (currentEditor && currentEditor.editor instanceof MonacoEditor) {
|
|
const codeEditor = currentEditor.editor.getControl();
|
|
const selection = codeEditor.getSelection();
|
|
const model = codeEditor.getModel();
|
|
if (model && selection && !monaco.Range.isEmpty(selection)) {
|
|
searchFor = model.getValueInRange(selection);
|
|
}
|
|
}
|
|
if (!searchFor) {
|
|
searchFor = await this.quickInputService.input({
|
|
prompt: nls.localize('arduino/help/search', 'Search on Arduino.cc'),
|
|
placeHolder: nls.localize('arduino/help/keyword', 'Type a keyword'),
|
|
});
|
|
}
|
|
if (searchFor) {
|
|
return open(
|
|
`https://www.arduino.cc/search?q=${encodeURIComponent(
|
|
searchFor
|
|
)}&tab=reference`
|
|
);
|
|
}
|
|
},
|
|
});
|
|
registry.registerCommand(
|
|
Help.Commands.FAQ,
|
|
createOpenHandler('https://support.arduino.cc/hc/en-us')
|
|
);
|
|
registry.registerCommand(
|
|
Help.Commands.VISIT_ARDUINO,
|
|
createOpenHandler('https://www.arduino.cc/')
|
|
);
|
|
registry.registerCommand(
|
|
Help.Commands.PRIVACY_POLICY,
|
|
createOpenHandler('https://www.arduino.cc/en/privacy-policy')
|
|
);
|
|
}
|
|
|
|
override registerMenus(registry: MenuModelRegistry): void {
|
|
registry.unregisterMenuAction({
|
|
commandId: ElectronCommands.TOGGLE_DEVELOPER_TOOLS.id,
|
|
});
|
|
|
|
registry.registerMenuAction(ArduinoMenus.HELP__MAIN_GROUP, {
|
|
commandId: Help.Commands.GETTING_STARTED.id,
|
|
order: '0',
|
|
});
|
|
registry.registerMenuAction(ArduinoMenus.HELP__MAIN_GROUP, {
|
|
commandId: Help.Commands.ENVIRONMENT.id,
|
|
order: '1',
|
|
});
|
|
registry.registerMenuAction(ArduinoMenus.HELP__MAIN_GROUP, {
|
|
commandId: Help.Commands.TROUBLESHOOTING.id,
|
|
order: '2',
|
|
});
|
|
registry.registerMenuAction(ArduinoMenus.HELP__MAIN_GROUP, {
|
|
commandId: Help.Commands.REFERENCE.id,
|
|
order: '3',
|
|
});
|
|
|
|
registry.registerMenuAction(ArduinoMenus.HELP__FIND_GROUP, {
|
|
commandId: Help.Commands.FIND_IN_REFERENCE.id,
|
|
order: '4',
|
|
});
|
|
registry.registerMenuAction(ArduinoMenus.HELP__FIND_GROUP, {
|
|
commandId: Help.Commands.FAQ.id,
|
|
order: '5',
|
|
});
|
|
registry.registerMenuAction(ArduinoMenus.HELP__FIND_GROUP, {
|
|
commandId: Help.Commands.VISIT_ARDUINO.id,
|
|
order: '6',
|
|
});
|
|
registry.registerMenuAction(ArduinoMenus.HELP__FIND_GROUP, {
|
|
commandId: Help.Commands.PRIVACY_POLICY.id,
|
|
order: '7',
|
|
});
|
|
registry.registerMenuAction(ArduinoMenus.HELP__FIND_GROUP, {
|
|
commandId: IDEUpdaterCommands.CHECK_FOR_UPDATES.id,
|
|
order: '8',
|
|
});
|
|
}
|
|
|
|
override registerKeybindings(registry: KeybindingRegistry): void {
|
|
registry.registerKeybinding({
|
|
command: Help.Commands.FIND_IN_REFERENCE.id,
|
|
keybinding: 'CtrlCmd+Shift+F',
|
|
});
|
|
}
|
|
}
|
|
|
|
export namespace Help {
|
|
export namespace Commands {
|
|
export const GETTING_STARTED: Command = {
|
|
id: 'arduino-getting-started',
|
|
label: nls.localize('arduino/help/gettingStarted', 'Getting Started'),
|
|
category: 'Arduino',
|
|
};
|
|
export const ENVIRONMENT: Command = {
|
|
id: 'arduino-environment',
|
|
label: nls.localize('arduino/help/environment', 'Environment'),
|
|
category: 'Arduino',
|
|
};
|
|
export const TROUBLESHOOTING: Command = {
|
|
id: 'arduino-troubleshooting',
|
|
label: nls.localize('arduino/help/troubleshooting', 'Troubleshooting'),
|
|
category: 'Arduino',
|
|
};
|
|
export const REFERENCE: Command = {
|
|
id: 'arduino-reference',
|
|
label: nls.localize('arduino/help/reference', 'Reference'),
|
|
category: 'Arduino',
|
|
};
|
|
export const FIND_IN_REFERENCE: Command = {
|
|
id: 'arduino-find-in-reference',
|
|
label: nls.localize('arduino/help/findInReference', 'Find in Reference'),
|
|
category: 'Arduino',
|
|
};
|
|
export const FAQ: Command = {
|
|
id: 'arduino-faq',
|
|
label: nls.localize('arduino/help/faq', 'Frequently Asked Questions'),
|
|
category: 'Arduino',
|
|
};
|
|
export const VISIT_ARDUINO: Command = {
|
|
id: 'arduino-visit-arduino',
|
|
label: nls.localize('arduino/help/visit', 'Visit Arduino.cc'),
|
|
category: 'Arduino',
|
|
};
|
|
export const PRIVACY_POLICY: Command = {
|
|
id: 'arduino-privacy-policy',
|
|
label: nls.localize('arduino/help/privacyPolicy', 'Privacy Policy'),
|
|
category: 'Arduino',
|
|
};
|
|
}
|
|
}
|