mirror of
https://github.com/excalidraw/excalidraw.git
synced 2025-10-24 08:24:32 +02:00

* lasso without 'real' shape detection * select a single linear el * improve ux * feed segments to worker * simplify path threshold adaptive to zoom * add a tiny threshold for checks * refactor code * lasso tests * fix: ts * do not capture lasso tool * try worker-loader in next config * update config * refactor * lint * feat: show active tool when using "more tools" * keep lasso if selected from toolbar * fix incorrect checks for resetting to selection * shift for additive selection * bound text related fixes * lint * keep alt toggled lasso selection if shift pressed * fix regression * fix 'dead' lassos * lint * use workerpool and polyfill * fix worker bundled with window related code * refactor * add file extension for worker constructor error * another attempt at constructor error * attempt at build issue * attempt with dynamic import * test not importing from math * narrow down imports * Reusing existing workers infrastructure (fallback to the main thread, type-safety) * Points on curve inside the shared chunk * Give up on experimental code splitting * Remove potentially unnecessary optimisation * Removing workers as the complexit is much worse, while perf. does not seem to be much better * fix selecting text containers and containing frames together * render fill directly from animated trail * do not re-render static when setting selected element ids in lasso * remove unnecessary property * tweak trail animation * slice points to remove notch * always start alt-lasso from initial point * revert build & worker changes (unused) * remove `lasso` from `hasStrokeColor` * label change * remove unused props * remove unsafe optimization * snaps --------- Co-authored-by: dwelle <5153846+dwelle@users.noreply.github.com> Co-authored-by: Marcel Mraz <marcel@excalidraw.com>
298 lines
8.9 KiB
TypeScript
298 lines
8.9 KiB
TypeScript
import path from "path";
|
|
import { defineConfig, loadEnv } from "vite";
|
|
import react from "@vitejs/plugin-react";
|
|
import svgrPlugin from "vite-plugin-svgr";
|
|
import { ViteEjsPlugin } from "vite-plugin-ejs";
|
|
import { VitePWA } from "vite-plugin-pwa";
|
|
import checker from "vite-plugin-checker";
|
|
import { createHtmlPlugin } from "vite-plugin-html";
|
|
import Sitemap from "vite-plugin-sitemap";
|
|
import { woff2BrowserPlugin } from "../scripts/woff2/woff2-vite-plugins";
|
|
export default defineConfig(({ mode }) => {
|
|
// To load .env variables
|
|
const envVars = loadEnv(mode, `../`);
|
|
// https://vitejs.dev/config/
|
|
return {
|
|
server: {
|
|
port: Number(envVars.VITE_APP_PORT || 3000),
|
|
// open the browser
|
|
open: true,
|
|
},
|
|
// We need to specify the envDir since now there are no
|
|
//more located in parallel with the vite.config.ts file but in parent dir
|
|
envDir: "../",
|
|
resolve: {
|
|
alias: [
|
|
{
|
|
find: /^@excalidraw\/common$/,
|
|
replacement: path.resolve(
|
|
__dirname,
|
|
"../packages/common/src/index.ts",
|
|
),
|
|
},
|
|
{
|
|
find: /^@excalidraw\/common\/(.*?)/,
|
|
replacement: path.resolve(__dirname, "../packages/common/src/$1"),
|
|
},
|
|
{
|
|
find: /^@excalidraw\/element$/,
|
|
replacement: path.resolve(
|
|
__dirname,
|
|
"../packages/element/src/index.ts",
|
|
),
|
|
},
|
|
{
|
|
find: /^@excalidraw\/element\/(.*?)/,
|
|
replacement: path.resolve(__dirname, "../packages/element/src/$1"),
|
|
},
|
|
{
|
|
find: /^@excalidraw\/excalidraw$/,
|
|
replacement: path.resolve(
|
|
__dirname,
|
|
"../packages/excalidraw/index.tsx",
|
|
),
|
|
},
|
|
{
|
|
find: /^@excalidraw\/excalidraw\/(.*?)/,
|
|
replacement: path.resolve(__dirname, "../packages/excalidraw/$1"),
|
|
},
|
|
{
|
|
find: /^@excalidraw\/math$/,
|
|
replacement: path.resolve(__dirname, "../packages/math/src/index.ts"),
|
|
},
|
|
{
|
|
find: /^@excalidraw\/math\/(.*?)/,
|
|
replacement: path.resolve(__dirname, "../packages/math/src/$1"),
|
|
},
|
|
{
|
|
find: /^@excalidraw\/utils$/,
|
|
replacement: path.resolve(
|
|
__dirname,
|
|
"../packages/utils/src/index.ts",
|
|
),
|
|
},
|
|
{
|
|
find: /^@excalidraw\/utils\/(.*?)/,
|
|
replacement: path.resolve(__dirname, "../packages/utils/src/$1"),
|
|
},
|
|
],
|
|
},
|
|
build: {
|
|
outDir: "build",
|
|
rollupOptions: {
|
|
output: {
|
|
assetFileNames(chunkInfo) {
|
|
if (chunkInfo?.name?.endsWith(".woff2")) {
|
|
const family = chunkInfo.name.split("-")[0];
|
|
return `fonts/${family}/[name][extname]`;
|
|
}
|
|
|
|
return "assets/[name]-[hash][extname]";
|
|
},
|
|
// Creating separate chunk for locales except for en and percentages.json so they
|
|
// can be cached at runtime and not merged with
|
|
// app precache. en.json and percentages.json are needed for first load
|
|
// or fallback hence not clubbing with locales so first load followed by offline mode works fine. This is how CRA used to work too.
|
|
manualChunks(id) {
|
|
if (
|
|
id.includes("packages/excalidraw/locales") &&
|
|
id.match(/en.json|percentages.json/) === null
|
|
) {
|
|
const index = id.indexOf("locales/");
|
|
// Taking the substring after "locales/"
|
|
return `locales/${id.substring(index + 8)}`;
|
|
}
|
|
},
|
|
},
|
|
},
|
|
sourcemap: true,
|
|
// don't auto-inline small assets (i.e. fonts hosted on CDN)
|
|
assetsInlineLimit: 0,
|
|
},
|
|
plugins: [
|
|
Sitemap({
|
|
hostname: "https://excalidraw.com",
|
|
outDir: "build",
|
|
changefreq: "monthly",
|
|
// its static in public folder
|
|
generateRobotsTxt: false,
|
|
}),
|
|
woff2BrowserPlugin(),
|
|
react(),
|
|
checker({
|
|
typescript: true,
|
|
eslint:
|
|
envVars.VITE_APP_ENABLE_ESLINT === "false"
|
|
? undefined
|
|
: { lintCommand: 'eslint "./**/*.{js,ts,tsx}"' },
|
|
overlay: {
|
|
initialIsOpen: envVars.VITE_APP_COLLAPSE_OVERLAY === "false",
|
|
badgeStyle: "margin-bottom: 4rem; margin-left: 1rem",
|
|
},
|
|
}),
|
|
svgrPlugin(),
|
|
ViteEjsPlugin(),
|
|
VitePWA({
|
|
registerType: "autoUpdate",
|
|
devOptions: {
|
|
/* set this flag to true to enable in Development mode */
|
|
enabled: envVars.VITE_APP_ENABLE_PWA === "true",
|
|
},
|
|
|
|
workbox: {
|
|
// don't precache fonts, locales and separate chunks
|
|
globIgnores: [
|
|
"fonts.css",
|
|
"**/locales/**",
|
|
"service-worker.js",
|
|
"**/*.chunk-*.js",
|
|
],
|
|
runtimeCaching: [
|
|
{
|
|
urlPattern: new RegExp(".+.woff2"),
|
|
handler: "CacheFirst",
|
|
options: {
|
|
cacheName: "fonts",
|
|
expiration: {
|
|
maxEntries: 1000,
|
|
maxAgeSeconds: 60 * 60 * 24 * 90, // 90 days
|
|
},
|
|
cacheableResponse: {
|
|
// 0 to cache "opaque" responses from cross-origin requests (i.e. CDN)
|
|
statuses: [0, 200],
|
|
},
|
|
},
|
|
},
|
|
{
|
|
urlPattern: new RegExp("fonts.css"),
|
|
handler: "StaleWhileRevalidate",
|
|
options: {
|
|
cacheName: "fonts",
|
|
expiration: {
|
|
maxEntries: 50,
|
|
},
|
|
},
|
|
},
|
|
{
|
|
urlPattern: new RegExp("locales/[^/]+.js"),
|
|
handler: "CacheFirst",
|
|
options: {
|
|
cacheName: "locales",
|
|
expiration: {
|
|
maxEntries: 50,
|
|
maxAgeSeconds: 60 * 60 * 24 * 30, // <== 30 days
|
|
},
|
|
},
|
|
},
|
|
{
|
|
urlPattern: new RegExp(".chunk-.+.js"),
|
|
handler: "CacheFirst",
|
|
options: {
|
|
cacheName: "chunk",
|
|
expiration: {
|
|
maxEntries: 50,
|
|
maxAgeSeconds: 60 * 60 * 24 * 90, // <== 90 days
|
|
},
|
|
},
|
|
},
|
|
],
|
|
},
|
|
manifest: {
|
|
short_name: "Excalidraw",
|
|
name: "Excalidraw",
|
|
description:
|
|
"Excalidraw is a whiteboard tool that lets you easily sketch diagrams that have a hand-drawn feel to them.",
|
|
icons: [
|
|
{
|
|
src: "android-chrome-192x192.png",
|
|
sizes: "192x192",
|
|
type: "image/png",
|
|
},
|
|
{
|
|
src: "apple-touch-icon.png",
|
|
type: "image/png",
|
|
sizes: "180x180",
|
|
},
|
|
{
|
|
src: "favicon-32x32.png",
|
|
sizes: "32x32",
|
|
type: "image/png",
|
|
},
|
|
{
|
|
src: "favicon-16x16.png",
|
|
sizes: "16x16",
|
|
type: "image/png",
|
|
},
|
|
],
|
|
start_url: "/",
|
|
id: "excalidraw",
|
|
display: "standalone",
|
|
theme_color: "#121212",
|
|
background_color: "#ffffff",
|
|
file_handlers: [
|
|
{
|
|
action: "/",
|
|
accept: {
|
|
"application/vnd.excalidraw+json": [".excalidraw"],
|
|
},
|
|
},
|
|
],
|
|
share_target: {
|
|
action: "/web-share-target",
|
|
method: "POST",
|
|
enctype: "multipart/form-data",
|
|
params: {
|
|
files: [
|
|
{
|
|
name: "file",
|
|
accept: [
|
|
"application/vnd.excalidraw+json",
|
|
"application/json",
|
|
".excalidraw",
|
|
],
|
|
},
|
|
],
|
|
},
|
|
},
|
|
screenshots: [
|
|
{
|
|
src: "/screenshots/virtual-whiteboard.png",
|
|
type: "image/png",
|
|
sizes: "462x945",
|
|
},
|
|
{
|
|
src: "/screenshots/wireframe.png",
|
|
type: "image/png",
|
|
sizes: "462x945",
|
|
},
|
|
{
|
|
src: "/screenshots/illustration.png",
|
|
type: "image/png",
|
|
sizes: "462x945",
|
|
},
|
|
{
|
|
src: "/screenshots/shapes.png",
|
|
type: "image/png",
|
|
sizes: "462x945",
|
|
},
|
|
{
|
|
src: "/screenshots/collaboration.png",
|
|
type: "image/png",
|
|
sizes: "462x945",
|
|
},
|
|
{
|
|
src: "/screenshots/export.png",
|
|
type: "image/png",
|
|
sizes: "462x945",
|
|
},
|
|
],
|
|
},
|
|
}),
|
|
createHtmlPlugin({
|
|
minify: true,
|
|
}),
|
|
],
|
|
publicDir: "../public",
|
|
};
|
|
});
|