UNPKG

@theia/core

Version:

Theia is a cloud & desktop IDE framework implemented in TypeScript.

54 lines (51 loc) 2.43 kB
// ***************************************************************************** // Copyright (C) 2025 TypeFox and others. // // This program and the accompanying materials are made available under the // terms of the Eclipse Public License v. 2.0 which is available at // http://www.eclipse.org/legal/epl-2.0. // // This Source Code may also be made available under the following Secondary // Licenses when the conditions for such availability set forth in the Eclipse // Public License v. 2.0 are satisfied: GNU General Public License, version 2 // with the GNU Classpath Exception which is available at // https://www.gnu.org/software/classpath/license.html. // // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0 // ***************************************************************************** export const TextReplacementContribution = Symbol('TextReplacementContribution'); /** * Enables adopters to override text in the application. All `TextReplacementContribution`s need to be bound in the `frontendPreload` scope of the package.json. * * @example Create a text replacement contribution * ```typescript * import { TextReplacementContribution } from '@theia/core/lib/browser/preload/text-replacement-contribution'; * export class TextSampleReplacementContribution implements TextReplacementContribution { * getReplacement(locale: string): Record<string, string> { * switch (locale) { * case 'en': { * return { * 'About': 'About Theia', * }; * } * case 'de': { * return { * 'About': 'Über Theia', * }; * } * } * return {}; * } * } * ``` */ export interface TextReplacementContribution { /** * This method returns a map of **default values** and their replacement values for the specified locale. * **Do not** use the keys of the `nls.localization` call, but the English default values. * * @param locale The locale for which the replacement should be returned. * @returns A map of default values and their replacement values. */ getReplacement(locale: string): Record<string, string>; }