earthsdk3-assets 3.0.25 → 3.0.26

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "earthsdk3-assets",
3
- "version": "3.0.25",
3
+ "version": "3.0.26",
4
4
  "description": "地球可视化实验室 (EarthSDK&CesiumLab) https://www.bjxbsj.cn",
5
5
  "private": false,
6
6
  "type": "module",
@@ -56,7 +56,7 @@ class EarthsdkAssetsRspackPlugin {
56
56
  tagName: 'script',
57
57
  voidTag: false,
58
58
  attributes: {
59
- src: './js/earthsdk3-assets/earthsdk3-assets.js'
59
+ src: '/js/earthsdk3-assets/earthsdk3-assets.js'
60
60
  },
61
61
  meta: { plugin: 'earthsdk-assets' }
62
62
  });
@@ -46,7 +46,7 @@ class EarthsdkAssetsWebpackPlugin {
46
46
  tagName: 'script',
47
47
  voidTag: false,
48
48
  attributes: {
49
- src: './js/earthsdk3-assets/earthsdk3-assets.js'
49
+ src: '/js/earthsdk3-assets/earthsdk3-assets.js'
50
50
  },
51
51
  meta: { plugin: 'earthsdk-assets' }
52
52
  });
@@ -65,43 +65,39 @@ class EarthsdkAssetsWebpackPlugin {
65
65
  compiler.hooks.afterEnvironment.tap('EarthsdkAssetsWebpackPlugin', () => {
66
66
  const devServer = compiler.options.devServer;
67
67
  if (devServer) {
68
- const originalSetupMiddlewares = devServer.setupMiddlewares;
68
+ const originalBefore = devServer.before;
69
69
 
70
- devServer.setupMiddlewares = (middlewares, server) => {
71
- middlewares.unshift({
72
- name: 'earthsdk-assets-middleware',
73
- path: '/js/earthsdk3-assets',
74
- middleware: (req, res, next) => {
75
- const urlPath = decodeURIComponent(req.url);
76
- const fileName = urlPath === '/' ? 'earthsdk3-assets.js' : urlPath.slice(1);
77
- const filePath = path.join(ROOT_DIR, fileName);
78
-
79
- if (!fs.existsSync(filePath)) {
80
- return next();
81
- }
82
-
83
- const ext = path.extname(filePath).slice(1).toLowerCase();
84
- const mimeTypes = {
85
- js: 'application/javascript',
86
- json: 'application/json',
87
- png: 'image/png',
88
- jpg: 'image/jpeg',
89
- jpeg: 'image/jpeg',
90
- webp: 'image/webp',
91
- glb: 'model/gltf-binary',
92
- bin: 'application/octet-stream'
93
- };
94
-
95
- res.setHeader('Content-Type', mimeTypes[ext] || 'application/octet-stream');
96
- res.setHeader('Cache-Control', 'max-age=3600');
97
- fs.createReadStream(filePath).pipe(res);
70
+ devServer.before = (app, server, compiler) => {
71
+ app.use('/js/earthsdk3-assets', (req, res, next) => {
72
+ const urlPath = decodeURIComponent(req.originalUrl);
73
+ const relativePath = urlPath.replace('/js/earthsdk3-assets', '');
74
+ const fileName = relativePath === '/' || relativePath === '' ? 'earthsdk3-assets.js' : relativePath.slice(1);
75
+ const filePath = path.join(ROOT_DIR, fileName);
76
+
77
+ if (!fs.existsSync(filePath)) {
78
+ return next();
98
79
  }
80
+
81
+ const ext = path.extname(filePath).slice(1).toLowerCase();
82
+ const mimeTypes = {
83
+ js: 'application/javascript',
84
+ json: 'application/json',
85
+ png: 'image/png',
86
+ jpg: 'image/jpeg',
87
+ jpeg: 'image/jpeg',
88
+ webp: 'image/webp',
89
+ glb: 'model/gltf-binary',
90
+ bin: 'application/octet-stream'
91
+ };
92
+
93
+ res.setHeader('Content-Type', mimeTypes[ext] || 'application/octet-stream');
94
+ res.setHeader('Cache-Control', 'max-age=3600');
95
+ fs.createReadStream(filePath).pipe(res);
99
96
  });
100
97
 
101
- if (originalSetupMiddlewares) {
102
- return originalSetupMiddlewares(middlewares, server);
98
+ if (originalBefore) {
99
+ originalBefore(app, server, compiler);
103
100
  }
104
- return middlewares;
105
101
  };
106
102
  }
107
103
  });