Skip to content

Commit

Permalink
feat(preset-umi): integrate umi ui to preset-umi (umijs#10837)
Browse files Browse the repository at this point in the history
* feat(preset-umi): integrate umi ui to preset-umi

* chore: add DEBUG_UMI_UI_PATH for local debug

* fix: ci

* chore: update pnpm-lock.yaml
  • Loading branch information
sorrycc authored Mar 24, 2023
1 parent a966ea5 commit 759a0f9
Show file tree
Hide file tree
Showing 6 changed files with 132 additions and 123 deletions.
4 changes: 3 additions & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,9 @@
"test:e2e": "jest --config jest.e2e.config.ts",
"tsc:check": "tsc --noEmit",
"turbo:clean": "rimraf .turbo",
"ui:dev": "pnpm --filter @umijs/ui dev",
"ui:build": "pnpm --filter @umijs/ui ui:build",
"ui:dev": "pnpm --filter @umijs/ui ui:dev",
"ui:release": "pnpm --filter @umijs/ui release",
"valtio:build": "pnpm --filter @umijs/valtio build",
"valtio:dev": "pnpm --filter @umijs/valtio dev",
"valtio:release": "umi-scripts releaseValtio"
Expand Down
1 change: 1 addition & 0 deletions packages/preset-umi/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@
"@umijs/plugin-run": "workspace:*",
"@umijs/renderer-react": "workspace:*",
"@umijs/server": "workspace:*",
"@umijs/ui": "workspace:*",
"@umijs/utils": "workspace:*",
"@umijs/zod2ts": "workspace:*",
"babel-plugin-dynamic-import-node": "2.3.3",
Expand Down
107 changes: 104 additions & 3 deletions packages/preset-umi/src/features/ui/ui.ts
Original file line number Diff line number Diff line change
@@ -1,17 +1,118 @@
import { isLocalDev } from '@umijs/utils';
import fs from 'fs';
import path from 'path';
import { IApi } from '../../types';
// @ts-ignore
import sirv from '../../../compiled/sirv';

const ENTRY_PATH = '/__umi_ui/entry';

export default (api: IApi) => {
api.describe({
enableBy() {
return api.name === 'dev' && api.args.ui;
return api.name === 'dev' && api.userConfig.ui;
},
config: {
schema({ zod }) {
return zod.object({});
},
},
});

const uiDir = path.dirname(require.resolve('@umijs/ui/package.json'));

api.onCheck(() => {
if (!fs.existsSync(path.join(uiDir, 'dist'))) {
if (isLocalDev()) {
throw new Error(
`@umijs/ui not built, please run 'pnpm ui:build' first.`,
);
} else {
throw new Error(`@umijs/ui not found, please fill an issue on github.`);
}
}
});

api.onBeforeMiddleware(({ app }) => {
app.use(ENTRY_PATH, async (req: any, _res) => {
req;
app.use(
ENTRY_PATH,
sirv(path.join(uiDir, 'dist'), {
etag: true,
dev: true,
single: true,
}),
);
});

api.addHTMLStyles(() => {
return [
`
#umi-ui-container.umi-ui-container-show {
display: block;
}
#umi-ui-container {
position: fixed;
bottom: 10px;
left: calc(10vw + 10px);
height: calc(75vh - 20px);
width: calc(80vw - 20px);
display: none;
border-radius: .5rem;
z-index: 2147483646;
}
#umi-ui-toggle-btn {
width: 40px;
height: 40px;
position: fixed;
left: 50%;
bottom: -20px;
transform: translateX(-50%);
cursor: pointer;
display: flex;
background-size: 100% 100%;
background-image: url('');
transition: bottom 0.1s linear;
z-index: 2147483647;
}
#umi-ui-toggle-btn:hover {
bottom: 0px;
}
#umi-ui-iframe {
width: 100%;
height: 100%;
outline: none;
border: 1px solid rgba(125,125,125,0.2);
border-radius: 0.5rem;
}
`,
];
});

api.onGenerateFiles(({ isFirstTime }) => {
if (!isFirstTime) return;
api.writeTmpFile({
path: 'core/ui.ts',
noPluginDir: true,
content: `
// button and iframe
const container = document.createElement('div')
container.id = 'umi-ui-container';
const iframe = document.createElement('iframe');
iframe.id = 'umi-ui-iframe';
iframe.src = '${process.env.DEBUG_UMI_UI_PATH || ENTRY_PATH}';
const uiBtn = document.createElement('div');
uiBtn.id = 'umi-ui-toggle-btn';
container.appendChild(iframe);
document.body.appendChild(uiBtn);
document.body.appendChild(container);
uiBtn.addEventListener('click', () => {
container.classList.toggle('umi-ui-container-show');
});
`,
});
});

api.addEntryImports(() => {
return [{ source: '@@/core/ui' }];
});
};
Loading

0 comments on commit 759a0f9

Please sign in to comment.