mirror of
https://gh.wpcy.net/https://github.com/discourse/discourse.git
synced 2026-06-19 03:05:45 +08:00
This replaces the old ember-cli build with a modern Rolldown build. In local testing, this provides an 80% improvement in build times, while remaining 100% backwards compatible for themes and plugins. As part of this move, we have decided to stop using a proxy in front of Discourse for development. Development should now be done directly against the Rails server. `bin/ember-cli -u` has been replaced with `bin/dev`. This will launch Rails on `:3000`, and will run the rolldown build in the background. Log output from both processes will be shown with an appropriate prefix. You should visit `:3000` in your browser. `:4200` will no longer serve anything. To help with migration, `bin/ember-cli` is now a backwards-compatible shim. It will print help information, and will launch a lightweight server on `:4200` with instructions to move to `:3000`. If you prefer to launch Rails and the JS build as separate commands, you can still do that. Rails boot commands are unchanged, and the rolldown development builder can be run using `bin/dev --only ember`. https://meta.discourse.org/t/403908 --------- Co-authored-by: Jarek Radosz <jarek@cvx.dev> Co-authored-by: Chris Manson <chris@manson.ie>
83 lines
2.4 KiB
Text
Vendored
83 lines
2.4 KiB
Text
Vendored
<!DOCTYPE html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="utf-8" />
|
|
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
|
<title>Frontend build error</title>
|
|
<style>
|
|
body {
|
|
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
|
|
background: #1e1e1e;
|
|
color: #f0f0f0;
|
|
margin: 0;
|
|
padding: 2rem;
|
|
line-height: 1.5;
|
|
}
|
|
main {
|
|
max-width: 960px;
|
|
margin: 0 auto;
|
|
}
|
|
h1 {
|
|
color: #ff6b6b;
|
|
margin-top: 0;
|
|
}
|
|
pre {
|
|
background: #111;
|
|
color: #f0f0f0;
|
|
padding: 1rem;
|
|
border-radius: 6px;
|
|
overflow-x: auto;
|
|
white-space: pre-wrap;
|
|
word-break: break-word;
|
|
}
|
|
</style>
|
|
</head>
|
|
<body>
|
|
<main>
|
|
<h1>Frontend build error</h1>
|
|
|
|
<% error = @build_error["error"] || {} %>
|
|
<% if error["messageHtml"] %>
|
|
<pre><%= error["messageHtml"].html_safe %></pre>
|
|
<% elsif error["message"] %>
|
|
<pre><%= error["message"] %></pre>
|
|
<% end %>
|
|
|
|
<script nonce="<%= csp_nonce_placeholder %>">
|
|
const clientId = crypto.randomUUID();
|
|
const SEP = "\r\n|\r\n";
|
|
let lastId = -1;
|
|
|
|
(async function poll() {
|
|
try {
|
|
const res = await fetch(`/message-bus/${clientId}/poll`, {
|
|
method: "POST",
|
|
headers: { "Content-Type": "application/x-www-form-urlencoded" },
|
|
body: new URLSearchParams({ "/file-change": String(lastId) }),
|
|
});
|
|
const decoder = new TextDecoder();
|
|
let buffer = "";
|
|
for await (const chunk of res.body) {
|
|
buffer += decoder.decode(chunk, { stream: true });
|
|
let sep;
|
|
while ((sep = buffer.indexOf(SEP)) !== -1) {
|
|
const batch = JSON.parse(buffer.slice(0, sep));
|
|
buffer = buffer.slice(sep + SEP.length);
|
|
for (const m of batch) {
|
|
if (m.channel === "/file-change") {
|
|
return window.location.reload();
|
|
} else if (m.channel === "/__status") {
|
|
lastId = m.data["/file-change"] ?? lastId;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
} catch {
|
|
await new Promise((r) => setTimeout(r, 1000));
|
|
}
|
|
poll();
|
|
})();
|
|
</script>
|
|
</main>
|
|
</body>
|
|
</html>
|