1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 |
- const { gzip } = require('@gfx/zopfli');
- const FS = require('fs');
- const path = require('path');
- const BUNDLE_JS = FS.readFileSync(path.resolve(__dirname, './dist/js/app.js'));
- const HTML = `
- <!DOCTYPE html>
- <html lang=en>
- <head>
- <meta charset=utf-8>
- <meta http-equiv=X-UA-Compatible content="IE=edge">
- <meta name=viewport content="width=device-width,initial-scale=1">
- <link rel=icon href=/favicon.ico> <title>ElegantOTA</title>
- </head>
- <body style="overflow: hidden;">
- <noscript>
- <strong>We're sorry but ElegantOTA doesn't work properly without JavaScript enabled. Please enable it to continue.</strong>
- </noscript>
- <div id=app></div>
- <script defer>${BUNDLE_JS}</script>
- </body>
- </html>
- `;
- function chunkArray(myArray, chunk_size) {
- let index = 0;
- const arrayLength = myArray.length;
- const tempArray = [];
- for (index = 0; index < arrayLength; index += chunk_size) {
- myChunk = myArray.slice(index, index + chunk_size);
-
- tempArray.push(myChunk);
- }
- return tempArray;
- }
- function addLineBreaks(buffer) {
- let data = '';
- const chunks = chunkArray(buffer, 30);
- chunks.forEach((chunk, index) => {
- data += chunk.join(',');
- if (index + 1 !== chunks.length) {
- data += ',\n';
- }
- });
- return data;
- }
- gzip(HTML, { numiterations: 15 }, (err, output) => {
- if (err) {
- return console.error(err);
- }
- const FILE = `#ifndef ElegantOTAWebpage_h
- #define ElegantOTAWebpage_h
- const uint32_t ELEGANT_HTML_SIZE = ${output.length};
- const uint8_t ELEGANT_HTML[] PROGMEM = {
- ${addLineBreaks(output)}
- };
- #endif
- `;
- FS.writeFileSync(path.resolve(__dirname, '../src/elegantWebpage.h'), FILE);
- console.log(`[COMPRESS] Compressed Build Files to elegantWebpage.h: ${ (output.length/1024).toFixed(2) }KB`);
- });
|