1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-11-22 09:57:02 +01:00

[TS dashboard] Reorganize files slightly (#17335)

This commit is contained in:
Elliot Winkler 2023-02-08 07:33:03 -07:00 committed by GitHub
parent 4cb2e573e5
commit 75f2951f89
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
17 changed files with 189 additions and 153 deletions

View File

@ -576,7 +576,7 @@ jobs:
- persist_to_workspace: - persist_to_workspace:
root: . root: .
paths: paths:
- development/ts-migration-dashboard/build - development/ts-migration-dashboard/build/final
test-yarn-dedupe: test-yarn-dedupe:
executor: node-browsers executor: node-browsers
@ -1013,7 +1013,7 @@ jobs:
path: storybook-build path: storybook-build
destination: storybook destination: storybook
- store_artifacts: - store_artifacts:
path: development/ts-migration-dashboard/build path: development/ts-migration-dashboard/build/final
destination: ts-migration-dashboard destination: ts-migration-dashboard
- run: - run:
name: Set branch parent commit env var name: Set branch parent commit env var

1
.gitignore vendored
View File

@ -34,7 +34,6 @@ dist
builds/ builds/
builds.zip builds.zip
development/ts-migration-dashboard/build development/ts-migration-dashboard/build
development/ts-migration-dashboard/intermediate
test-artifacts test-artifacts
test-builds test-builds

View File

@ -1,21 +1,7 @@
import React from 'react'; import React from 'react';
import classnames from 'classnames'; import classnames from 'classnames';
import { Tooltip as ReactTippy } from 'react-tippy'; import { Tooltip as ReactTippy } from 'react-tippy';
import { ModulePartition } from '../scripts/build-module-partitions'; import { readPartitionsFile } from '../../common/partitions-file';
// The `brfs` transform for browserify calls `fs.readLineSync` and
// `path.resolve` at build time and inlines file contents into the source code.
// To accomplish this we have to bring in `fs` and `path` using `require` and
// not `import`. This is weird in a TypeScript file, and typescript-eslint
// (rightly) complains about this, but it's actually okay because the above
// `import` lines will actually get turned into `require`s anyway before passing
// through the rest of browserify. However, `brfs` should handle this. There is
// an active bug for this, but there isn't a known workaround yet:
// <https://github.com/browserify/brfs/issues/39>
/* eslint-disable-next-line @typescript-eslint/no-require-imports,@typescript-eslint/no-var-requires */
const fs = require('fs');
/* eslint-disable-next-line @typescript-eslint/no-require-imports,@typescript-eslint/no-var-requires */
const path = require('path');
type Summary = { type Summary = {
numConvertedFiles: number; numConvertedFiles: number;
@ -27,14 +13,7 @@ function calculatePercentageComplete(summary: Summary) {
} }
export default function App() { export default function App() {
const partitions = JSON.parse( const partitions = readPartitionsFile();
fs.readFileSync(
path.resolve(__dirname, '../intermediate/partitions.json'),
{
encoding: 'utf-8',
},
),
) as ModulePartition[];
const allFiles = partitions.flatMap((partition) => { const allFiles = partitions.flatMap((partition) => {
return partition.children; return partition.children;

View File

@ -0,0 +1,4 @@
@import '../../../ui/css/reset';
@import './styles/tippy';
@import './styles/native-elements';
@import './styles/custom-elements';

View File

@ -1,6 +1,6 @@
import * as React from 'react'; import * as React from 'react';
import ReactDOM from 'react-dom'; import ReactDOM from 'react-dom';
import App from './App'; import App from './components/App';
const appElement = document.querySelector('#app'); const appElement = document.querySelector('#app');

View File

Before

Width:  |  Height:  |  Size: 3.2 KiB

After

Width:  |  Height:  |  Size: 3.2 KiB

View File

@ -1,61 +1,3 @@
@import '../../../ui/css/reset';
@import './tippy';
/* Native elements */
* {
box-sizing: border-box;
}
html {
font-family:
-apple-system,
BlinkMacSystemFont,
"Segoe UI",
Helvetica,
Arial,
sans-serif,
"Apple Color Emoji",
"Segoe UI Emoji";
font-size: 16px;
}
body {
padding: 2rem;
}
p:not(:last-child) {
margin-bottom: 1rem;
}
code {
font-size: 0.85em;
font-family:
ui-monospace,
SFMono-Regular,
SF Mono,
Menlo,
Consolas,
Liberation Mono,
monospace;
}
strong {
font-weight: bold;
}
em {
font-style: italic;
}
ul {
list-style: disc;
margin-bottom: 1rem;
margin-left: 1rem;
}
/* Custom elements */
:root { :root {
--blue-gray-350: hsl(209deg 13.7% 62.4%); --blue-gray-350: hsl(209deg 13.7% 62.4%);
--blue-gray-100: hsl(209.8deg 16.5% 89%); --blue-gray-100: hsl(209.8deg 16.5% 89%);

View File

@ -0,0 +1,50 @@
* {
box-sizing: border-box;
}
html {
font-family:
-apple-system,
BlinkMacSystemFont,
"Segoe UI",
Helvetica,
Arial,
sans-serif,
"Apple Color Emoji",
"Segoe UI Emoji";
font-size: 16px;
}
body {
padding: 2rem;
}
p:not(:last-child) {
margin-bottom: 1rem;
}
code {
font-size: 0.85em;
font-family:
ui-monospace,
SFMono-Regular,
SF Mono,
Menlo,
Consolas,
Liberation Mono,
monospace;
}
strong {
font-weight: bold;
}
em {
font-style: italic;
}
ul {
list-style: disc;
margin-bottom: 1rem;
margin-left: 1rem;
}

View File

@ -3,7 +3,7 @@ import path from 'path';
import fg from 'fast-glob'; import fg from 'fast-glob';
import madge from 'madge'; import madge from 'madge';
import { import {
BASE_DIRECTORY, ROOT_DIRECTORY_PATH,
ENTRYPOINT_PATTERNS, ENTRYPOINT_PATTERNS,
FILES_TO_CONVERT_PATH, FILES_TO_CONVERT_PATH,
} from './constants'; } from './constants';
@ -66,7 +66,7 @@ export default async function buildModulePartitions(): Promise<
await Promise.all( await Promise.all(
ENTRYPOINT_PATTERNS.map((entrypointPattern) => { ENTRYPOINT_PATTERNS.map((entrypointPattern) => {
return fg( return fg(
path.resolve(BASE_DIRECTORY, `${entrypointPattern}.{js,ts,tsx}`), path.resolve(ROOT_DIRECTORY_PATH, `${entrypointPattern}.{js,ts,tsx}`),
); );
}), }),
) )
@ -74,14 +74,14 @@ export default async function buildModulePartitions(): Promise<
const entryFilePaths = filterFilePaths( const entryFilePaths = filterFilePaths(
possibleEntryFilePaths.map((possibleEntrypoint) => possibleEntryFilePaths.map((possibleEntrypoint) =>
path.relative(BASE_DIRECTORY, possibleEntrypoint), path.relative(ROOT_DIRECTORY_PATH, possibleEntrypoint),
), ),
allowedFilePaths, allowedFilePaths,
); );
const result = await madge(entryFilePaths, { const result = await madge(entryFilePaths, {
baseDir: BASE_DIRECTORY, baseDir: ROOT_DIRECTORY_PATH,
tsConfig: path.join(BASE_DIRECTORY, 'tsconfig.json'), tsConfig: path.join(ROOT_DIRECTORY_PATH, 'tsconfig.json'),
}); });
const dependenciesByFilePath = result.obj(); const dependenciesByFilePath = result.obj();
const modulesById = buildModulesWithLevels( const modulesById = buildModulesWithLevels(

View File

@ -0,0 +1,39 @@
import path from 'path';
export const ROOT_DIRECTORY_PATH = path.resolve(__dirname, '../../..');
export const PROJECT_DIRECTORY_PATH = path.join(
ROOT_DIRECTORY_PATH,
'development',
'ts-migration-dashboard',
);
export const COMMON_DIRECTORY_PATH = path.join(
PROJECT_DIRECTORY_PATH,
'common',
);
export const APP_DIRECTORY_PATH = path.join(PROJECT_DIRECTORY_PATH, 'app');
export const INTERMEDIATE_BUILD_DIRECTORY_PATH = path.join(
PROJECT_DIRECTORY_PATH,
'build',
'intermediate',
);
export const FINAL_BUILD_DIRECTORY_PATH = path.join(
PROJECT_DIRECTORY_PATH,
'build',
'final',
);
export const ENTRYPOINT_PATTERNS = [
'app/scripts/background',
'app/scripts/contentscript',
'app/scripts/disable-console',
'app/scripts/inpage',
'app/scripts/phishing-detect',
'app/scripts/sentry-install',
'app/scripts/ui',
'development/build/index',
'**/*.stories',
'**/*.test',
];
export const FILES_TO_CONVERT_PATH = path.join(
PROJECT_DIRECTORY_PATH,
'files-to-convert.json',
);

View File

@ -0,0 +1,40 @@
import { ModulePartition } from './build-module-partitions';
import { INTERMEDIATE_BUILD_DIRECTORY_PATH } from './constants';
// The `brfs` transform for browserify calls `fs.readLineSync` and
// `path.resolve` at build time and inlines file contents into the source code.
// To accomplish this we have to bring in `fs` and `path` using `require` and
// not `import`. This is weird in a TypeScript file, and typescript-eslint
// (rightly) complains about this, but it's actually okay because the above
// `import` lines will actually get turned into `require`s anyway before passing
// through the rest of browserify. However, `brfs` should handle this. There is
// an active bug for this, but there isn't a known workaround yet:
// <https://github.com/browserify/brfs/issues/39>
/* eslint-disable-next-line @typescript-eslint/no-require-imports,@typescript-eslint/no-var-requires */
const fs = require('fs');
/* eslint-disable-next-line @typescript-eslint/no-require-imports,@typescript-eslint/no-var-requires */
const path = require('path');
export const PARTITIONS_FILE = path.join(
INTERMEDIATE_BUILD_DIRECTORY_PATH,
'partitions.json',
);
export function readPartitionsFile() {
const content = fs.readFileSync(
// As this function is called within the app code, which is compiled by
// Browserify and not executed by Node, this needs to be here — it cannot be
// extracted — for the reasons explained above.
path.resolve(__dirname, '../build/intermediate/partitions.json'),
{ encoding: 'utf-8' },
);
return JSON.parse(content) as ModulePartition[];
}
export function writePartitionsFile(partitions: ModulePartition[]) {
fs.mkdirSync(path.dirname(PARTITIONS_FILE), { recursive: true });
return fs.writeFileSync(
PARTITIONS_FILE,
JSON.stringify(partitions, null, ' '),
);
}

View File

@ -12,16 +12,19 @@ import gulpDartSass from 'gulp-dart-sass';
import sourcemaps from 'gulp-sourcemaps'; import sourcemaps from 'gulp-sourcemaps';
import autoprefixer from 'gulp-autoprefixer'; import autoprefixer from 'gulp-autoprefixer';
import fg from 'fast-glob'; import fg from 'fast-glob';
import buildModulePartitions from './build-module-partitions'; import buildModulePartitions from '../common/build-module-partitions';
import {
PARTITIONS_FILE,
writePartitionsFile,
} from '../common/partitions-file';
import {
PROJECT_DIRECTORY_PATH,
COMMON_DIRECTORY_PATH,
APP_DIRECTORY_PATH,
FINAL_BUILD_DIRECTORY_PATH,
} from '../common/constants';
const promisifiedPump = pify(pump); const promisifiedPump = pify(pump);
const projectDirectoryPath = path.resolve(__dirname, '../');
const sourceDirectoryPath = path.join(projectDirectoryPath, 'src');
const intermediateDirectoryPath = path.join(
projectDirectoryPath,
'intermediate',
);
const buildDirectoryPath = path.join(projectDirectoryPath, 'build');
main().catch((error) => { main().catch((error) => {
console.error(error); console.error(error);
@ -31,21 +34,15 @@ main().catch((error) => {
/** /**
* Compiles a set of files that we want to convert to TypeScript, divided by * Compiles a set of files that we want to convert to TypeScript, divided by
* level in the dependency tree. * level in the dependency tree.
*
* @param dest - The directory in which to hold the file.
*/ */
async function generateIntermediateFiles(dest: string) { async function generateIntermediateFiles() {
const partitions = await buildModulePartitions(); const partitions = await buildModulePartitions();
const partitionsFile = path.resolve(dest, 'partitions.json'); writePartitionsFile(partitions);
await pify(fs.writeFile)(
partitionsFile,
JSON.stringify(partitions, null, ' '),
);
console.log( console.log(
`- Wrote intermediate partitions file: ${path.relative( `- Wrote intermediate partitions file: ${path.relative(
projectDirectoryPath, PROJECT_DIRECTORY_PATH,
partitionsFile, PARTITIONS_FILE,
)}`, )}`,
); );
} }
@ -81,9 +78,9 @@ async function compileScripts(src: string, dest: string) {
console.log( console.log(
`- Compiled scripts: ${path.relative( `- Compiled scripts: ${path.relative(
projectDirectoryPath, PROJECT_DIRECTORY_PATH,
src, src,
)} -> ${path.relative(projectDirectoryPath, dest)}`, )} -> ${path.relative(PROJECT_DIRECTORY_PATH, dest)}`,
); );
} }
@ -106,9 +103,9 @@ async function compileStylesheets(src: string, dest: string): Promise<void> {
); );
console.log( console.log(
`- Compiled stylesheets: ${path.relative( `- Compiled stylesheets: ${path.relative(
projectDirectoryPath, PROJECT_DIRECTORY_PATH,
src, src,
)} -> ${path.relative(projectDirectoryPath, dest)}`, )} -> ${path.relative(PROJECT_DIRECTORY_PATH, dest)}`,
); );
} }
@ -128,9 +125,9 @@ async function copyStaticFiles(src: string, dest: string): Promise<void> {
await fs.copy(srcEntry, destEntry); await fs.copy(srcEntry, destEntry);
console.log( console.log(
`- Copied static files: ${path.relative( `- Copied static files: ${path.relative(
projectDirectoryPath, PROJECT_DIRECTORY_PATH,
srcEntry, srcEntry,
)} -> ${path.relative(projectDirectoryPath, destEntry)}`, )} -> ${path.relative(PROJECT_DIRECTORY_PATH, destEntry)}`,
); );
}), }),
); );
@ -160,25 +157,24 @@ async function rebuild({
console.log('Detected change, rebuilding...'); console.log('Detected change, rebuilding...');
} }
await fs.emptyDir(buildDirectoryPath); await fs.emptyDir(FINAL_BUILD_DIRECTORY_PATH);
try { try {
if (isInitial) { if (isInitial) {
await fs.emptyDir(intermediateDirectoryPath); await generateIntermediateFiles();
await generateIntermediateFiles(intermediateDirectoryPath);
} }
await compileScripts( await compileScripts(
path.join(sourceDirectoryPath, 'index.tsx'), path.join(APP_DIRECTORY_PATH, 'index.tsx'),
path.join(buildDirectoryPath, 'index.js'), path.join(FINAL_BUILD_DIRECTORY_PATH, 'index.js'),
); );
await compileStylesheets( await compileStylesheets(
path.join(sourceDirectoryPath, 'index.scss'), path.join(APP_DIRECTORY_PATH, 'index.scss'),
path.join(buildDirectoryPath), FINAL_BUILD_DIRECTORY_PATH,
); );
await copyStaticFiles( await copyStaticFiles(
path.join(sourceDirectoryPath, 'public'), path.join(APP_DIRECTORY_PATH, 'public'),
path.join(buildDirectoryPath), FINAL_BUILD_DIRECTORY_PATH,
); );
} catch (error: unknown) { } catch (error: unknown) {
console.error(error); console.error(error);
@ -202,7 +198,7 @@ async function main() {
.alias('h', 'help') .alias('h', 'help')
.parseSync(); .parseSync();
console.log(`Working directory: ${projectDirectoryPath}`); console.log(`Working directory: ${PROJECT_DIRECTORY_PATH}`);
if (opts.watch) { if (opts.watch) {
const rebuildIgnoringErrors = () => { const rebuildIgnoringErrors = () => {
@ -211,9 +207,15 @@ async function main() {
}); });
}; };
chokidar chokidar
.watch(path.join(sourceDirectoryPath, '**/*.{html,ts,tsx,scss}'), { .watch(
[
path.join(COMMON_DIRECTORY_PATH, '**/*.{html,ts,tsx,scss}'),
path.join(APP_DIRECTORY_PATH, '**/*.{html,ts,tsx,scss}'),
],
{
ignoreInitial: true, ignoreInitial: true,
}) },
)
.on('add', rebuildIgnoringErrors) .on('add', rebuildIgnoringErrors)
.on('change', rebuildIgnoringErrors) .on('change', rebuildIgnoringErrors)
.on('unlink', rebuildIgnoringErrors) .on('unlink', rebuildIgnoringErrors)

View File

@ -1,19 +0,0 @@
import path from 'path';
export const BASE_DIRECTORY = path.resolve(__dirname, '../../..');
export const ENTRYPOINT_PATTERNS = [
'app/scripts/background',
'app/scripts/contentscript',
'app/scripts/disable-console',
'app/scripts/inpage',
'app/scripts/phishing-detect',
'app/scripts/sentry-install',
'app/scripts/ui',
'development/build/index',
'**/*.stories',
'**/*.test',
];
export const FILES_TO_CONVERT_PATH = path.join(
__dirname,
'../files-to-convert.json',
);

View File

@ -3,10 +3,10 @@ import fs from 'fs';
import fg from 'fast-glob'; import fg from 'fast-glob';
import madge from 'madge'; import madge from 'madge';
import { import {
BASE_DIRECTORY, ROOT_DIRECTORY_PATH,
ENTRYPOINT_PATTERNS, ENTRYPOINT_PATTERNS,
FILES_TO_CONVERT_PATH, FILES_TO_CONVERT_PATH,
} from './constants'; } from '../common/constants';
main().catch((error) => { main().catch((error) => {
console.error(error); console.error(error);
@ -26,7 +26,7 @@ async function main(): Promise<void> {
await Promise.all( await Promise.all(
ENTRYPOINT_PATTERNS.map((entrypointPattern) => { ENTRYPOINT_PATTERNS.map((entrypointPattern) => {
return fg( return fg(
path.resolve(BASE_DIRECTORY, `${entrypointPattern}.{js,ts,tsx}`), path.resolve(ROOT_DIRECTORY_PATH, `${entrypointPattern}.{js,ts,tsx}`),
); );
}), }),
) )
@ -35,7 +35,7 @@ async function main(): Promise<void> {
`Traversing dependency trees for ${entrypoints.length} entrypoints, please wait...`, `Traversing dependency trees for ${entrypoints.length} entrypoints, please wait...`,
); );
const result = await madge(entrypoints, { const result = await madge(entrypoints, {
baseDir: BASE_DIRECTORY, baseDir: ROOT_DIRECTORY_PATH,
}); });
const dependenciesByFilePath = result.obj(); const dependenciesByFilePath = result.obj();
const sortedFilePaths = Object.keys(dependenciesByFilePath) const sortedFilePaths = Object.keys(dependenciesByFilePath)

View File

@ -83,10 +83,10 @@
"lavamoat:webapp:auto:ci": "node ./development/generate-lavamoat-policies.js --parallel=false", "lavamoat:webapp:auto:ci": "node ./development/generate-lavamoat-policies.js --parallel=false",
"lavamoat:auto": "yarn lavamoat:build:auto && yarn lavamoat:webapp:auto", "lavamoat:auto": "yarn lavamoat:build:auto && yarn lavamoat:webapp:auto",
"lavamoat:auto:ci": "yarn lavamoat:build:auto && yarn lavamoat:webapp:auto:ci", "lavamoat:auto:ci": "yarn lavamoat:build:auto && yarn lavamoat:webapp:auto:ci",
"ts-migration:dashboard:build": "ts-node development/ts-migration-dashboard/scripts/build-app.ts",
"ts-migration:dashboard:deploy": "gh-pages --dist development/ts-migration-dashboard/build/final --remote ts-migration-dashboard",
"ts-migration:dashboard:watch": "yarn ts-migration:dashboard:build --watch",
"ts-migration:enumerate": "ts-node development/ts-migration-dashboard/scripts/write-list-of-files-to-convert.ts", "ts-migration:enumerate": "ts-node development/ts-migration-dashboard/scripts/write-list-of-files-to-convert.ts",
"ts-migration:dashboard:watch": "ts-node development/ts-migration-dashboard/scripts/build.ts --watch",
"ts-migration:dashboard:build": "ts-node development/ts-migration-dashboard/scripts/build.ts",
"ts-migration:dashboard:deploy": "gh-pages --dist development/ts-migration-dashboard/build --remote ts-migration-dashboard",
"test-storybook": "test-storybook -c .storybook", "test-storybook": "test-storybook -c .storybook",
"test-storybook:ci": "concurrently -k -s first -n \"SB,TEST\" -c \"magenta,blue\" \"yarn storybook:build && npx http-server storybook-build --port 6006 \" \"wait-on tcp:6006 && yarn test-storybook --maxWorkers=2\"" "test-storybook:ci": "concurrently -k -s first -n \"SB,TEST\" -c \"magenta,blue\" \"yarn storybook:build && npx http-server storybook-build --port 6006 \" \"wait-on tcp:6006 && yarn test-storybook --maxWorkers=2\""
}, },