diff options
author | 2022-06-09 12:51:19 +0200 | |
---|---|---|
committer | 2022-06-09 12:51:19 +0200 | |
commit | b43f9ceca9f7e02248f1d88245ede5267e8b72c8 (patch) | |
tree | 1d6b64603e74c45785bf44dde194315344843e1e /web/source/index.js | |
parent | [chore] gitignore shell.nix (#639) (diff) | |
download | gotosocial-b43f9ceca9f7e02248f1d88245ede5267e8b72c8.tar.xz |
[frontend] Restructure Frontend Sources (#634)
* 🐸restructure frontend stuff, include admin and future user panel in main repo, properly deduplicate bundles for css+js across uses
* rename bundled to dist, caught by gitignore
* re-include status.css for profile template
* default to localhost
* serve frontend panels
* add todo message for abstraction
* refactor oauth registration flow
* oauth restructure
* update footer template
* change panel routes
* remove superfluous css imports
* write bundle to disk from test server, use forked budo-express
* wrap all page content in container
for robustness with addons etc injection other elements in body
* update documentation, goreleaser, Dockerfile
* update template meta tags
* add AGPL-3.0+ license header everywhere
* only attach update listener on EventEmitter
* cleaner config for various frontend bundles
* fix bundler script paths
* Merge commit 'd191931932b9293ce1be44ed08a1e69b9fcc1e25'
* fix up dockerfile, goreleaser
* go mod tidy
* add uglifyify
* move status hide/show js to frontend bundle
* fix stylesheet color( func regressions
* update contributing docs for new build path
* update goreleaser + docker building
* resolve dependency paths properly
* update package name
* use api errorhandler
Co-authored-by: tsmethurst <tobi.smethurst@protonmail.com>
Diffstat (limited to 'web/source/index.js')
-rw-r--r-- | web/source/index.js | 108 |
1 files changed, 108 insertions, 0 deletions
diff --git a/web/source/index.js b/web/source/index.js new file mode 100644 index 000000000..0e5df9f9b --- /dev/null +++ b/web/source/index.js @@ -0,0 +1,108 @@ +/* + GoToSocial + Copyright (C) 2021-2022 GoToSocial Authors admin@gotosocial.org + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU Affero General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU Affero General Public License for more details. + + You should have received a copy of the GNU Affero General Public License + along with this program. If not, see <http://www.gnu.org/licenses/>. +*/ + +"use strict"; + +/* + Bundle the frontend panels for admin and user settings +*/ + +const path = require('path'); +const budoExpress = require('@f0x52/budo-express'); +const babelify = require('babelify'); +const fs = require("fs"); +const EventEmitter = require('events'); + +function out(name = "") { + return path.join(__dirname, "../assets/dist/", name); +} + +module.exports = {out}; + +const splitCSS = require("./lib/split-css.js"); + +const bundles = { + "./frontend/index.js": "frontend.js", + "./panels/admin/index.js": "admin-panel.js", + "./panels/user/index.js": "user-panel.js", +}; + +const postcssPlugins = [ + "postcss-import", + "postcss-strip-inline-comments", + "postcss-nested", + "autoprefixer", + "postcss-custom-prop-vars", + "postcss-color-mod-function" +].map((plugin) => require(plugin)()); + +const browserifyConfig = { + transform: [ + babelify.configure({ + presets: [ + require.resolve("@babel/preset-env"), + require.resolve("@babel/preset-react") + ] + }), + [require("uglifyify"), { + global: true, + exts: ".js" + }] + ], + plugin: [ + [require("icssify"), { + parser: require('postcss-scss'), + before: postcssPlugins, + mode: 'global' + }], + [require("css-extract"), { out: splitCSS }], + [require("factor-bundle"), { + outputs: Object.values(bundles).map((file) => { + return out(file); + }) + }] + ] +}; + +const entryFiles = Object.keys(bundles); + +fs.readdirSync(path.join(__dirname, "./css")).forEach((file) => { + entryFiles.push(path.join(__dirname, "./css", file)); +}); + +if (!fs.existsSync(out())){ + fs.mkdirSync(out(), { recursive: true }); +} + +const server = budoExpress({ + port: 8081, + host: "localhost", + entryFiles: entryFiles, + basePath: __dirname, + bundlePath: "bundle.js", + staticPath: out(), + expressApp: require("./dev-server.js"), + browserify: browserifyConfig, + livereloadPattern: "**/*.{html,js,svg}" +}); + +if (server instanceof EventEmitter) { + server.on("update", (contents) => { + fs.writeFileSync(out("bundle.js"), contents); + }); +}
\ No newline at end of file |