build: Migrate to Vite 🚀 (#6713)

* init

* add: vite dev build working

* fix: href serving from public

* feat: add ejs plugin

* feat: migrated env files and ejs templating

* chore: add types related to envs

* chore: add vite-env types

* feat: support vite pwa

* chore: upgrade vite pwa

* chore: pin node version to 16.18.1

* chore: preserve use of nodejs 14

* refactor: preserve REACT_APP as env prefix

* chore: support esm environment variables

* fix ts config

* use VITE prefix and remove vite-plugin-env-compatible

* introduce import-meta-loader for building pacakge as webpack isn't compatible with import.meta syntax

* lint

* remove import.meta.env in main.js

* set debug flag to false

* migrate to vitest and use jest-canvas-mock 2.4.0 so its comp
atible with vite

* integrate vitest-ui

* fix most of teh test

* snaps

* Add script for testing with vite ui

* fix all tests related to mocking

* fix more test

* fix more

* fix flip.test.tsx

* fix contentxmenu snaps

* fix regression snaps

* fix excalidraw.test.tsx and this makes all tests finally pass :)

* use node 16

* specify node version

* use node 16 in lint as well

* fix mobile.test.tsx

* use node 16

* add style-loader

* upgrade to node 18

* fix lint package.json

* support eslint with vite

* fix lint

* fix lint

* fix ts

* remove pwa/sw stuff

* use env vars in EJS the vite way

* fix lint

* move remainig jest mock/spy to vite

* don't cache locales

* fix regex

* add fonts cache

* tweak

* add custom service worker

* upgrade vite and create font cache again

* cache fonts.css and locales

* tweak

* use manifestTransforms for filtering locales

* use assets js pattern for locales

* add font.css to globIgnore so its pushed to fonts cache

* create a separate chunk for locales with rollup

* remove manifestTransforms and fix glob pattern for locales to filter from workbox pre-cache

* push sourcemaps in production

* add comments in config

* lint

* use node 18

* disable pwa in dev

* fix

* fix

* increase limit of bundle

* upgrade vite-pwa to latest

* remove public/workbox so workbox assets are not precached

* fon't club en.json and percentages.json with manual locales chunk to fix first load+offline mode

* tweak regex

* remove happy-dom as its not used

* add comment

* use any instead of ts-ignore

* cleanup

* remove jest-canvas-mock resolution as vite-canvas-mock was patched locking deps at 2.4.0

* use same theme color present in entry point

---------

Co-authored-by: Weslley Braga <weslley@bambee.com>
Co-authored-by: dwelle <luzar.david@gmail.com>
This commit is contained in:
Aakansha Doshi 2023-07-26 15:55:20 +05:30 committed by GitHub
parent 2a2495175b
commit e93bbc5776
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
100 changed files with 6012 additions and 9758 deletions

View file

@ -1,9 +1,9 @@
// Jest Snapshot v1, https://goo.gl/fbAQLP
// Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html
exports[`Test dragCreate add element to the scene when pointer dragging long enough arrow 1`] = `1`;
exports[`Test dragCreate > add element to the scene when pointer dragging long enough > arrow 1`] = `1`;
exports[`Test dragCreate add element to the scene when pointer dragging long enough arrow 2`] = `
Object {
exports[`Test dragCreate > add element to the scene when pointer dragging long enough > arrow 2`] = `
{
"angle": 0,
"backgroundColor": "transparent",
"boundElements": null,
@ -11,7 +11,7 @@ Object {
"endBinding": null,
"fillStyle": "hachure",
"frameId": null,
"groupIds": Array [],
"groupIds": [],
"height": 50,
"id": "id0",
"isDeleted": false,
@ -19,18 +19,18 @@ Object {
"link": null,
"locked": false,
"opacity": 100,
"points": Array [
Array [
"points": [
[
0,
0,
],
Array [
[
30,
50,
],
],
"roughness": 1,
"roundness": Object {
"roundness": {
"type": 2,
},
"seed": 337897,
@ -49,16 +49,16 @@ Object {
}
`;
exports[`Test dragCreate add element to the scene when pointer dragging long enough diamond 1`] = `1`;
exports[`Test dragCreate > add element to the scene when pointer dragging long enough > diamond 1`] = `1`;
exports[`Test dragCreate add element to the scene when pointer dragging long enough diamond 2`] = `
Object {
exports[`Test dragCreate > add element to the scene when pointer dragging long enough > diamond 2`] = `
{
"angle": 0,
"backgroundColor": "transparent",
"boundElements": null,
"fillStyle": "hachure",
"frameId": null,
"groupIds": Array [],
"groupIds": [],
"height": 50,
"id": "id0",
"isDeleted": false,
@ -66,7 +66,7 @@ Object {
"locked": false,
"opacity": 100,
"roughness": 1,
"roundness": Object {
"roundness": {
"type": 2,
},
"seed": 337897,
@ -83,16 +83,16 @@ Object {
}
`;
exports[`Test dragCreate add element to the scene when pointer dragging long enough ellipse 1`] = `1`;
exports[`Test dragCreate > add element to the scene when pointer dragging long enough > ellipse 1`] = `1`;
exports[`Test dragCreate add element to the scene when pointer dragging long enough ellipse 2`] = `
Object {
exports[`Test dragCreate > add element to the scene when pointer dragging long enough > ellipse 2`] = `
{
"angle": 0,
"backgroundColor": "transparent",
"boundElements": null,
"fillStyle": "hachure",
"frameId": null,
"groupIds": Array [],
"groupIds": [],
"height": 50,
"id": "id0",
"isDeleted": false,
@ -100,7 +100,7 @@ Object {
"locked": false,
"opacity": 100,
"roughness": 1,
"roundness": Object {
"roundness": {
"type": 2,
},
"seed": 337897,
@ -117,8 +117,8 @@ Object {
}
`;
exports[`Test dragCreate add element to the scene when pointer dragging long enough line 1`] = `
Object {
exports[`Test dragCreate > add element to the scene when pointer dragging long enough > line 1`] = `
{
"angle": 0,
"backgroundColor": "transparent",
"boundElements": null,
@ -126,7 +126,7 @@ Object {
"endBinding": null,
"fillStyle": "hachure",
"frameId": null,
"groupIds": Array [],
"groupIds": [],
"height": 50,
"id": "id0",
"isDeleted": false,
@ -134,18 +134,18 @@ Object {
"link": null,
"locked": false,
"opacity": 100,
"points": Array [
Array [
"points": [
[
0,
0,
],
Array [
[
30,
50,
],
],
"roughness": 1,
"roundness": Object {
"roundness": {
"type": 2,
},
"seed": 337897,
@ -164,16 +164,16 @@ Object {
}
`;
exports[`Test dragCreate add element to the scene when pointer dragging long enough rectangle 1`] = `1`;
exports[`Test dragCreate > add element to the scene when pointer dragging long enough > rectangle 1`] = `1`;
exports[`Test dragCreate add element to the scene when pointer dragging long enough rectangle 2`] = `
Object {
exports[`Test dragCreate > add element to the scene when pointer dragging long enough > rectangle 2`] = `
{
"angle": 0,
"backgroundColor": "transparent",
"boundElements": null,
"fillStyle": "hachure",
"frameId": null,
"groupIds": Array [],
"groupIds": [],
"height": 50,
"id": "id0",
"isDeleted": false,
@ -181,7 +181,7 @@ Object {
"locked": false,
"opacity": 100,
"roughness": 1,
"roundness": Object {
"roundness": {
"type": 3,
},
"seed": 337897,