|
@@ -1,198 +1,44 @@
|
|
|
-(function () {
|
|
|
- const METADATA = {
|
|
|
- CORE: {
|
|
|
- paths: {
|
|
|
- src: '/vscode/out/vs',
|
|
|
- 'npm/dev': 'node_modules/monaco-editor-core/dev/vs',
|
|
|
- 'npm/min': 'node_modules/monaco-editor-core/min/vs',
|
|
|
- built: '/vscode/out-monaco-editor-core/min/vs',
|
|
|
- releaseDev: 'release/dev/vs',
|
|
|
- releaseMin: 'release/min/vs'
|
|
|
- }
|
|
|
- },
|
|
|
- PLUGINS: [
|
|
|
- {
|
|
|
- name: 'monaco-typescript',
|
|
|
- modulePrefix: 'vs/language/typescript',
|
|
|
- paths: {
|
|
|
- src: './out/amd/language/typescript',
|
|
|
- dev: './out/release/dev/vs/language/typescript',
|
|
|
- min: './out/release/min/vs/language/typescript'
|
|
|
- }
|
|
|
- },
|
|
|
- {
|
|
|
- name: 'monaco-css',
|
|
|
- modulePrefix: 'vs/language/css',
|
|
|
- paths: {
|
|
|
- src: './out/amd/language/css',
|
|
|
- dev: './out/release/dev/vs/language/css',
|
|
|
- min: './out/release/min/vs/language/css'
|
|
|
- }
|
|
|
- },
|
|
|
- {
|
|
|
- name: 'monaco-json',
|
|
|
- modulePrefix: 'vs/language/json',
|
|
|
- paths: {
|
|
|
- src: './out/amd/language/json',
|
|
|
- dev: './out/release/dev/vs/language/json',
|
|
|
- min: './out/release/min/vs/language/json'
|
|
|
- }
|
|
|
- },
|
|
|
- {
|
|
|
- name: 'monaco-html',
|
|
|
- modulePrefix: 'vs/language/html',
|
|
|
- paths: {
|
|
|
- src: './out/amd/language/html',
|
|
|
- dev: './out/release/dev/vs/language/html',
|
|
|
- min: './out/release/min/vs/language/html'
|
|
|
- }
|
|
|
- },
|
|
|
- {
|
|
|
- name: 'monaco-languages',
|
|
|
- modulePrefix: 'vs/basic-languages',
|
|
|
- paths: {
|
|
|
- src: './out/amd/basic-languages',
|
|
|
- dev: './out/release/dev/vs/basic-languages',
|
|
|
- min: './out/release/min/vs/basic-languages'
|
|
|
- }
|
|
|
- }
|
|
|
- ]
|
|
|
- };
|
|
|
-
|
|
|
- let LOADER_OPTS = (function () {
|
|
|
- function parseQueryString() {
|
|
|
- let str = window.location.search;
|
|
|
- str = str.replace(/^\?/, '');
|
|
|
- let pieces = str.split(/&/);
|
|
|
- let result = {};
|
|
|
- pieces.forEach(function (piece) {
|
|
|
- let config = piece.split(/=/);
|
|
|
- result[config[0]] = config[1];
|
|
|
- });
|
|
|
- return result;
|
|
|
- }
|
|
|
- let overwrites = parseQueryString();
|
|
|
- let result = {};
|
|
|
- result['editor'] = overwrites['editor'] || 'npm/dev';
|
|
|
- METADATA.PLUGINS.map(function (plugin) {
|
|
|
- result[plugin.name] = overwrites[plugin.name] || 'dev';
|
|
|
- });
|
|
|
- return result;
|
|
|
- })();
|
|
|
- function toHREF(search) {
|
|
|
- let port = window.location.port;
|
|
|
- if (port.length > 0) {
|
|
|
- port = ':' + port;
|
|
|
- }
|
|
|
- return (
|
|
|
- window.location.protocol +
|
|
|
- '//' +
|
|
|
- window.location.hostname +
|
|
|
- port +
|
|
|
- window.location.pathname +
|
|
|
- search +
|
|
|
- window.location.hash
|
|
|
- );
|
|
|
- }
|
|
|
+//@ts-check
|
|
|
|
|
|
- function Component(name, modulePrefix, paths) {
|
|
|
- this.name = name;
|
|
|
- this.modulePrefix = modulePrefix;
|
|
|
- this.paths = paths;
|
|
|
- this.selectedPath = LOADER_OPTS[name];
|
|
|
- }
|
|
|
- Component.prototype.isRelease = function () {
|
|
|
- return /release/.test(this.selectedPath);
|
|
|
- };
|
|
|
- Component.prototype.getResolvedPath = function (PATH_PREFIX) {
|
|
|
- let resolvedPath = this.paths[this.selectedPath];
|
|
|
- if (!/^\//.test(resolvedPath)) {
|
|
|
- resolvedPath = PATH_PREFIX + '/monaco-editor/' + resolvedPath;
|
|
|
- }
|
|
|
- return resolvedPath;
|
|
|
+(function () {
|
|
|
+ const corePaths = {
|
|
|
+ src: '/vscode/out/vs',
|
|
|
+ 'npm/dev': 'node_modules/monaco-editor-core/dev/vs',
|
|
|
+ 'npm/min': 'node_modules/monaco-editor-core/min/vs',
|
|
|
+ built: '/vscode/out-monaco-editor-core/min/vs',
|
|
|
+ releaseDev: 'release/dev/vs',
|
|
|
+ releaseMin: 'release/min/vs'
|
|
|
};
|
|
|
- Component.prototype.generateLoaderConfig = function (dest, PATH_PREFIX) {
|
|
|
- dest[this.modulePrefix] = this.getResolvedPath(PATH_PREFIX);
|
|
|
+ const pluginPaths = {
|
|
|
+ src: 'out/amd',
|
|
|
+ dev: 'out/release/dev/vs',
|
|
|
+ min: 'out/release/min/vs'
|
|
|
};
|
|
|
- Component.prototype.generateUrlForPath = function (pathName) {
|
|
|
- let NEW_LOADER_OPTS = {};
|
|
|
- Object.keys(LOADER_OPTS).forEach(function (key) {
|
|
|
- NEW_LOADER_OPTS[key] = LOADER_OPTS[key] === 'npm/dev' ? undefined : LOADER_OPTS[key];
|
|
|
- });
|
|
|
- NEW_LOADER_OPTS[this.name] = pathName === 'npm/dev' ? undefined : pathName;
|
|
|
-
|
|
|
- let search = Object.keys(NEW_LOADER_OPTS)
|
|
|
- .map(function (key) {
|
|
|
- let value = NEW_LOADER_OPTS[key];
|
|
|
- if (value) {
|
|
|
- return key + '=' + value;
|
|
|
- }
|
|
|
- return '';
|
|
|
- })
|
|
|
- .filter(function (assignment) {
|
|
|
- return !!assignment;
|
|
|
- })
|
|
|
- .join('&');
|
|
|
- if (search.length > 0) {
|
|
|
- search = '?' + search;
|
|
|
- }
|
|
|
- return toHREF(search);
|
|
|
- };
|
|
|
- Component.prototype.renderLoadingOptions = function () {
|
|
|
- return (
|
|
|
- '<strong style="width:130px;display:inline-block;">' +
|
|
|
- this.name +
|
|
|
- '</strong>:   ' +
|
|
|
- Object.keys(this.paths)
|
|
|
- .map(
|
|
|
- function (pathName) {
|
|
|
- if (pathName === this.selectedPath) {
|
|
|
- return '<strong>' + pathName + '</strong>';
|
|
|
- }
|
|
|
- return '<a href="' + this.generateUrlForPath(pathName) + '">' + pathName + '</a>';
|
|
|
- }.bind(this)
|
|
|
- )
|
|
|
- .join('   ')
|
|
|
- );
|
|
|
- };
|
|
|
-
|
|
|
- let RESOLVED_CORE = new Component('editor', 'vs', METADATA.CORE.paths);
|
|
|
- self.RESOLVED_CORE_PATH = RESOLVED_CORE.getResolvedPath('');
|
|
|
- let RESOLVED_PLUGINS = METADATA.PLUGINS.map(function (plugin) {
|
|
|
- return new Component(plugin.name, plugin.modulePrefix, plugin.paths);
|
|
|
- });
|
|
|
-
|
|
|
- function loadScript(path, callback) {
|
|
|
- let script = document.createElement('script');
|
|
|
- script.onload = callback;
|
|
|
- script.async = true;
|
|
|
- script.type = 'text/javascript';
|
|
|
- script.src = path;
|
|
|
- document.head.appendChild(script);
|
|
|
- }
|
|
|
+ const parsedQuery = parseQueryString();
|
|
|
+ const editorQueryName = 'editor';
|
|
|
+ const pluginsQueryName = 'plugins';
|
|
|
+ const defaultEditorQueryValue = 'npm/dev';
|
|
|
+ const defaultPluginsQueryValue = 'src';
|
|
|
+ const editorQueryValue = parsedQuery[editorQueryName] || defaultEditorQueryValue;
|
|
|
+ const pluginsQueryValue = parsedQuery[pluginsQueryName] || defaultPluginsQueryValue;
|
|
|
+ const corePath = resolvePath(corePaths[editorQueryValue]);
|
|
|
+ const pluginPath = resolvePath(pluginPaths[pluginsQueryValue]);
|
|
|
+ const isRelease = /release/.test(editorQueryValue);
|
|
|
|
|
|
(function () {
|
|
|
- let allComponents = [RESOLVED_CORE];
|
|
|
- if (!RESOLVED_CORE.isRelease()) {
|
|
|
- allComponents = allComponents.concat(RESOLVED_PLUGINS);
|
|
|
- }
|
|
|
-
|
|
|
let div = document.createElement('div');
|
|
|
div.className = 'dev-setup-control';
|
|
|
div.style.position = 'fixed';
|
|
|
- div.style.top = 0;
|
|
|
- div.style.right = 0;
|
|
|
+ div.style.top = '0';
|
|
|
+ div.style.right = '0';
|
|
|
div.style.background = 'lightgray';
|
|
|
div.style.padding = '5px 20px 5px 5px';
|
|
|
div.style.zIndex = '1000';
|
|
|
|
|
|
div.innerHTML =
|
|
|
'<ul><li>' +
|
|
|
- allComponents
|
|
|
- .map(function (component) {
|
|
|
- return component.renderLoadingOptions();
|
|
|
- })
|
|
|
- .join('</li><li>') +
|
|
|
+ renderLoadingOptions(true) +
|
|
|
+ (isRelease ? '' : `</li><li>${renderLoadingOptions(false)}`) +
|
|
|
'</li></ul>';
|
|
|
|
|
|
document.body.appendChild(div);
|
|
@@ -206,31 +52,44 @@
|
|
|
}
|
|
|
})();
|
|
|
|
|
|
- self.getCodiconPath = function (PATH_PREFIX) {
|
|
|
- PATH_PREFIX = PATH_PREFIX || '';
|
|
|
- const result = RESOLVED_CORE.getResolvedPath(PATH_PREFIX);
|
|
|
- return result + '/base/browser/ui/codicons/codicon/codicon.ttf';
|
|
|
+ /** @type {any} */
|
|
|
+ const global = self;
|
|
|
+
|
|
|
+ global.getCodiconPath = () => {
|
|
|
+ return `${corePath}/base/browser/ui/codicons/codicon/codicon.ttf`;
|
|
|
};
|
|
|
|
|
|
- self.loadEditor = function (callback, PATH_PREFIX) {
|
|
|
+ /**
|
|
|
+ *
|
|
|
+ * @param {()=>void} callback
|
|
|
+ * @param {string} [PATH_PREFIX]
|
|
|
+ */
|
|
|
+ global.loadEditor = (callback, PATH_PREFIX) => {
|
|
|
PATH_PREFIX = PATH_PREFIX || '';
|
|
|
|
|
|
- loadScript(RESOLVED_CORE.getResolvedPath(PATH_PREFIX) + '/loader.js', function () {
|
|
|
- let loaderPathsConfig = {};
|
|
|
- window.AMD = true;
|
|
|
- loaderPathsConfig['vs/fillers/monaco-editor-core'] =
|
|
|
- PATH_PREFIX + '/monaco-editor/./out/amd/fillers/monaco-editor-core-amd';
|
|
|
- if (!RESOLVED_CORE.isRelease()) {
|
|
|
- RESOLVED_PLUGINS.forEach(function (plugin) {
|
|
|
- plugin.generateLoaderConfig(loaderPathsConfig, PATH_PREFIX);
|
|
|
- });
|
|
|
+ loadScript(`${PATH_PREFIX}${corePath}/loader.js`, () => {
|
|
|
+ global.AMD = true;
|
|
|
+
|
|
|
+ /** @type {{[name:string]: string;}} */
|
|
|
+ const loaderPathsConfig = {};
|
|
|
+ if (isRelease) {
|
|
|
+ loaderPathsConfig['vs'] = `${PATH_PREFIX}${corePath}`;
|
|
|
+ } else {
|
|
|
+ loaderPathsConfig[
|
|
|
+ 'vs/fillers/monaco-editor-core'
|
|
|
+ ] = `${PATH_PREFIX}/monaco-editor/out/amd/fillers/monaco-editor-core-amd`;
|
|
|
+ loaderPathsConfig['vs/language'] = `${PATH_PREFIX}${pluginPath}/language`;
|
|
|
+ loaderPathsConfig['vs/basic-language'] = `${PATH_PREFIX}${pluginPath}/basic-language`;
|
|
|
+ loaderPathsConfig['vs'] = `${PATH_PREFIX}${corePath}`;
|
|
|
}
|
|
|
- RESOLVED_CORE.generateLoaderConfig(loaderPathsConfig, PATH_PREFIX);
|
|
|
|
|
|
console.log('LOADER CONFIG: ');
|
|
|
console.log(JSON.stringify(loaderPathsConfig, null, '\t'));
|
|
|
|
|
|
- require.config({
|
|
|
+ /** @type {any} */
|
|
|
+ const req = require;
|
|
|
+
|
|
|
+ req.config({
|
|
|
paths: loaderPathsConfig
|
|
|
// 'vs/nls' : {
|
|
|
// availableLanguages: {
|
|
@@ -239,23 +98,121 @@
|
|
|
// }
|
|
|
});
|
|
|
|
|
|
- require(['vs/editor/editor.main'], function () {
|
|
|
- if (!RESOLVED_CORE.isRelease()) {
|
|
|
- // At this point we've loaded the monaco-editor-core
|
|
|
- require([
|
|
|
+ req(['vs/editor/editor.main'], () => {
|
|
|
+ if (isRelease) {
|
|
|
+ callback();
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ // At this point we've loaded the monaco-editor-core
|
|
|
+ req(
|
|
|
+ [
|
|
|
'vs/basic-languages/monaco.contribution',
|
|
|
'vs/language/css/monaco.contribution',
|
|
|
'vs/language/html/monaco.contribution',
|
|
|
'vs/language/json/monaco.contribution',
|
|
|
'vs/language/typescript/monaco.contribution'
|
|
|
- ], function () {
|
|
|
- // At this point we've loaded all the plugins
|
|
|
- callback();
|
|
|
- });
|
|
|
- } else {
|
|
|
- callback();
|
|
|
- }
|
|
|
+ ],
|
|
|
+ callback
|
|
|
+ );
|
|
|
});
|
|
|
});
|
|
|
};
|
|
|
+
|
|
|
+ function parseQueryString() {
|
|
|
+ const str = window.location.search.replace(/^\?/, '');
|
|
|
+ const pieces = str.split(/&/);
|
|
|
+ /** @type {{[name:string]: string;}} */
|
|
|
+ const result = {};
|
|
|
+ pieces.forEach((piece) => {
|
|
|
+ const config = piece.split(/=/);
|
|
|
+ result[config[0]] = config[1];
|
|
|
+ });
|
|
|
+ return result;
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * @param {string} path
|
|
|
+ */
|
|
|
+ function resolvePath(path) {
|
|
|
+ if (/^\//.test(path)) {
|
|
|
+ return path;
|
|
|
+ }
|
|
|
+ return `/monaco-editor/${path}`;
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * @param {boolean} isEditor
|
|
|
+ */
|
|
|
+ function renderLoadingOptions(isEditor) {
|
|
|
+ const name = isEditor ? 'editor' : 'plugins';
|
|
|
+ const paths = isEditor ? corePaths : pluginPaths;
|
|
|
+ const selectedPath = isEditor ? editorQueryValue : pluginsQueryValue;
|
|
|
+ return (
|
|
|
+ '<strong style="width:130px;display:inline-block;">' +
|
|
|
+ name +
|
|
|
+ '</strong>:   ' +
|
|
|
+ Object.keys(paths)
|
|
|
+ .map((path) => {
|
|
|
+ if (path === selectedPath) {
|
|
|
+ return '<strong>' + path + '</strong>';
|
|
|
+ }
|
|
|
+ return '<a href="' + generateUrlForLoadingOption(isEditor, path) + '">' + path + '</a>';
|
|
|
+ })
|
|
|
+ .join('   ')
|
|
|
+ );
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * @param {boolean} isEditor
|
|
|
+ * @param {string} value
|
|
|
+ */
|
|
|
+ function generateUrlForLoadingOption(isEditor, value) {
|
|
|
+ /** @type {{[name:string]: string;}} */
|
|
|
+ const newQueryOptions = {};
|
|
|
+ const newEditorQueryValue = isEditor ? value : editorQueryValue;
|
|
|
+ const newPluginsQueryValue = isEditor ? pluginsQueryValue : value;
|
|
|
+ if (newEditorQueryValue !== defaultEditorQueryValue) {
|
|
|
+ newQueryOptions[editorQueryName] = newEditorQueryValue;
|
|
|
+ }
|
|
|
+ if (newPluginsQueryValue !== defaultPluginsQueryValue) {
|
|
|
+ newQueryOptions[pluginsQueryName] = newPluginsQueryValue;
|
|
|
+ }
|
|
|
+
|
|
|
+ let search = Object.keys(newQueryOptions)
|
|
|
+ .map((key) => `${key}=${newQueryOptions[key]}`)
|
|
|
+ .join('&');
|
|
|
+
|
|
|
+ if (search.length > 0) {
|
|
|
+ search = '?' + search;
|
|
|
+ }
|
|
|
+ return toHREF(search);
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * @param {string} search
|
|
|
+ */
|
|
|
+ function toHREF(search) {
|
|
|
+ let port = window.location.port;
|
|
|
+ if (port.length > 0) {
|
|
|
+ port = ':' + port;
|
|
|
+ }
|
|
|
+ return (
|
|
|
+ window.location.protocol +
|
|
|
+ '//' +
|
|
|
+ window.location.hostname +
|
|
|
+ port +
|
|
|
+ window.location.pathname +
|
|
|
+ search +
|
|
|
+ window.location.hash
|
|
|
+ );
|
|
|
+ }
|
|
|
+
|
|
|
+ function loadScript(path, callback) {
|
|
|
+ const script = document.createElement('script');
|
|
|
+ script.onload = callback;
|
|
|
+ script.async = true;
|
|
|
+ script.type = 'text/javascript';
|
|
|
+ script.src = path;
|
|
|
+ document.head.appendChild(script);
|
|
|
+ }
|
|
|
})();
|