0b15992464
* Start of vscode extension. Current code is copy/paste from custom editor samples from Microsoft. We need to evaluate if using their text based customer editor or full on new custom editor is the way to go * Not sure how I missed these files. Adding them * Have a custom editor triggering off of .tldr files. Added gitignores for generated folder. Have iframed tldraw loading and security policies set to do so * Can now load a .tldr file. No saving support yet. Load times are slow, mostly from editor loading up I think * Have temporary solution for saving working now too. * Missed af ile * Backing up progress in syncing tldraw editor history changes * Removed console * ... * ... * Cleanup * Have save working well now. * Moved extension into 'integrations' folder * Trying out WebviewPanelOptions.retainContextWhenHidden=true and it's looking promising * Some cleanup * Trying out new @tldraw/editor module * Have prototype loading using new embedded editor * ... * Shaved off 1 second from editor loadtime * Got save working again. Had to manually fixuppreviously created .tldr files as the format changed a bit * More tuning * Starting work to get new tldraw/tldraw working. * Added example tldr files to vscode package * Removed old editor package * Have onChange working with latest fix. Back to iframed for a few mom * Fixed up .tldr files * Have iframe free extension working, but requiring hand crafted building * ... * Better handling of empty .tldr files. Still an issue with freshly created files trying to save as .js or .json * Thoroughly added comments for the extension code. Need to add diagrams though and now will document/comment/diagram the editor src code * Added comments to all of the editor side of the VS Code Extension. Also cleaned up the code * More cleanup of VS Code Extension code and have script automating generating the initial webview's html content from the cra editor static build * Tweaks to watch logic * Improved scripts for publishing to VS Code Marketplace * Improved name * Made the smiley angry * Reverted * Turned smiley mad * Turned smiley mad * Made smiley sad * Have a lot of plumbing working for Github codespaces and github.dev support * Imported new tldraw vs code extension code. Added instructions for workflows * Quick fix * Fix for corrupted arrows files * Updated editor build step to new location * Merge branch 'main' into vscode-extension-v1, add local file updating * Update App.tsx * Cleanup, bumped to 0.0.124 @tldraw/tdlraw and published a 0.10.0 version of hte extension * Added Trello/Kanban style file * Finished video * brings up to date * Fix scripts * Update README.md * Update .babelrc Co-authored-by: Steve Ruiz <steveruizok@gmail.com>
67 lines
2.1 KiB
JavaScript
67 lines
2.1 KiB
JavaScript
/*---------------------------------------------------------------------------------------------
|
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
* Licensed under the MIT License. See License.txt in the project root for license information.
|
|
*--------------------------------------------------------------------------------------------*/
|
|
|
|
//@ts-check
|
|
'use strict';
|
|
|
|
//@ts-check
|
|
/** @typedef {import('webpack').Configuration} WebpackConfig **/
|
|
|
|
const path = require('path');
|
|
const webpack = require('webpack');
|
|
|
|
const webExtensionConfig = /** @type WebpackConfig */ {
|
|
mode: 'none', // this leaves the source code as close as possible to the original (when packaging we set this to 'production')
|
|
target: 'webworker', // extensions run in a webworker context
|
|
entry: {
|
|
extension: './src/web/extension.ts', // source of the web extension main file
|
|
'test/suite/index': './src/web/test/suite/index.ts', // source of the web extension test runner
|
|
},
|
|
output: {
|
|
filename: '[name].js',
|
|
path: path.join(__dirname, './dist/web'),
|
|
libraryTarget: 'commonjs',
|
|
},
|
|
resolve: {
|
|
mainFields: ['browser', 'module', 'main'], // look for `browser` entry point in imported node modules
|
|
extensions: ['.ts', '.js'], // support ts-files and js-files
|
|
alias: {
|
|
// provides alternate implementation for node module and source files
|
|
},
|
|
fallback: {
|
|
// Webpack 5 no longer polyfills Node.js core modules automatically.
|
|
// see https://webpack.js.org/configuration/resolve/#resolvefallback
|
|
// for the list of Node.js core module polyfills.
|
|
assert: require.resolve('assert'),
|
|
},
|
|
},
|
|
module: {
|
|
rules: [
|
|
{
|
|
test: /\.ts$/,
|
|
exclude: /node_modules/,
|
|
use: [
|
|
{
|
|
loader: 'ts-loader',
|
|
},
|
|
],
|
|
},
|
|
],
|
|
},
|
|
plugins: [
|
|
new webpack.ProvidePlugin({
|
|
process: 'process/browser', // provide a shim for the global `process` variable
|
|
}),
|
|
],
|
|
externals: {
|
|
vscode: 'commonjs vscode', // ignored because it doesn't exist
|
|
},
|
|
performance: {
|
|
hints: false,
|
|
},
|
|
devtool: 'nosources-source-map', // create a source map that points to the original source file
|
|
};
|
|
|
|
module.exports = [webExtensionConfig];
|