diff --git a/packages/core/src/cursor_manager/cursor.css b/packages/core/src/cursor_manager/cursor.css index fc99d10b..f234e3ba 100644 --- a/packages/core/src/cursor_manager/cursor.css +++ b/packages/core/src/cursor_manager/cursor.css @@ -1,13 +1,15 @@ /* * in lib mode, vite can't handle image url in css, so we need to convert it to base64 manually - TODO: find a way to handle it + * TODO: find a way to handle it */ .suika-cursor-default { + /* cursor: url('./cursor-icons/suika-cursor-default.png') 5 5 auto; */ cursor: url() 5 5, auto; } .suika-cursor-move { + /* cursor: url('./cursor-icons/suika-cursor-move.png') 16 16 auto; */ cursor: url() 16 16, auto; diff --git a/packages/suika/src/index.tsx b/packages/suika/src/index.tsx index ec0eec03..55c861e3 100644 --- a/packages/suika/src/index.tsx +++ b/packages/suika/src/index.tsx @@ -2,6 +2,9 @@ import React from 'react'; import ReactDOM from 'react-dom/client'; import './index.css'; import App from './App'; +// vite does not automatically import styles when referencing other packages, you need to manually import them +import '@suika/core/dist/style.css'; +import '@suika/components/dist/style.css'; // vite does not automatically import styles when referencing other packages, you need to manually import them // TODO: FIXME: find a better way to do this diff --git a/scripts/dev.js b/scripts/dev.js index 23d7d7f3..5e567130 100644 --- a/scripts/dev.js +++ b/scripts/dev.js @@ -2,6 +2,7 @@ const { context } = require('esbuild'); const args = require('minimist')(process.argv.slice(2)); const path = require('path'); const { sassPlugin } = require('esbuild-sass-plugin'); +const fs = require('fs'); const setup = async () => { const target = args._[0]; @@ -28,6 +29,7 @@ const setup = async () => { ], outfile, bundle: true, + metafile: true, external: Object.keys({ ...pkgJson.dependencies, ...pkgJson.peerDependencies, @@ -38,7 +40,7 @@ const setup = async () => { platform: 'browser', plugins: [ sassPlugin({ - type: 'style', + type: 'css', }), { name: 'watch-build', @@ -46,8 +48,27 @@ const setup = async () => { build.onEnd((result) => { if (result.errors.length) { console.error('build failed:', result.errors); - } else { - console.log('watch build succeeded:', relativeOutputFile); + return; + } + console.log('watch build succeeded:', relativeOutputFile); + + // rename output CSS file + if (result.metafile) { + const outputs = result.metafile.outputs; + Object.keys(outputs).forEach((output) => { + const oldPath = path.resolve(output); + let newPath; + if (output.endsWith('.css')) { + // .es.css ---> style.css + newPath = oldPath.replace( + `dist/${target}.es.css`, + 'dist/style.css', + ); + } + if (newPath && oldPath !== newPath) { + fs.renameSync(oldPath, newPath); + } + }); } }); },