datastar-ssegen 1.0.1 → 1.1.0

Sign up to get free protection for your applications and to get access to all the features.
package/README.md CHANGED
@@ -5,7 +5,7 @@
5
5
 
6
6
  ## Overview
7
7
 
8
- The `datastar-ssegen` is a backend JavaScript module designed to generate Server-Sent Events (SSE) for connected [Datastar](https://data-star.dev/) clients. It supports popular server frameworks such as Express.js, Node.js, and Hyper Express.js, and Bun.
8
+ The `datastar-ssegen` is a backend JavaScript module designed to generate Server-Sent Events (SSE) for connected [Datastar](https://data-star.dev/) (v1.0.0-beta.1) clients. It supports popular server frameworks such as Express.js, Node.js, and Hyper Express.js, and Bun and Elysia.
9
9
 
10
10
  This package is engineered to integrate tightly with request and response objects of these backend frameworks, enabling efficient and reactive web application development.
11
11
 
@@ -69,21 +69,55 @@ Here's a simple HTML page to interact with the server:
69
69
  <meta charset="UTF-8">
70
70
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
71
71
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
72
- <script type="module" src="https://cdn.jsdelivr.net/gh/starfederation/datastar/bundles/datastar.js"></script>
72
+ <script type="module" src="https://cdn.jsdelivr.net/gh/starfederation/datastar@v1.0.0-beta.1/bundles/datastar.js"></script>
73
73
  <title>SSE Example</title>
74
74
  </head>
75
75
  <body>
76
76
  <h1>SSE Demo</h1>
77
- <div id="qoute" data-on-load="sse('/qoute')">Qoute: </div><button onclick="sse('/qoute')">Get New Qoute</button>
78
- <div id="clock" data-on-load="sse('/clock')"></div>
77
+ <div id="qoute" data-on-load="@get('/qoute')">Qoute: </div><button onclick="@get('/qoute')">Get New Qoute</button>
78
+ <div id="clock" data-on-load="@get('/clock')"></div>
79
79
  </body>
80
80
  </html>
81
81
  ```
82
82
 
83
83
 
84
+ ### Quick Start Example with Elysia
85
+
86
+ ```javascript
87
+ import { Elysia } from "elysia";
88
+ import { html } from "@elysiajs/html";
89
+ import { ServerSentEventGenerator } from "datastar-ssegen";
90
+
91
+ const app = new Elysia()
92
+ .use(html())
93
+ .get(
94
+ "/",
95
+ () =>
96
+ `<html>
97
+ <head>
98
+ <script type="module" src="https://cdn.jsdelivr.net/gh/starfederation/datastar@v1.0.0-beta.1/bundles/datastar.js"></script>
99
+ </head>
100
+ <body data-on-load="@get('/feed')">
101
+ <div id="hello">???</div>
102
+ </body>
103
+ </html>`
104
+ )
105
+ .get("/feed", function* ({ request, set }) {
106
+ const sse = ServerSentEventGenerator(request);
107
+ set.headers = sse.headers;
108
+ yield sse.MergeFragments(`<div id="hello">Hello!</div>`);
109
+ })
110
+
111
+ .listen(3000);
112
+
113
+ console.log(
114
+ `🦊 Elysia is running at ${app.server?.hostname}:${app.server?.port}`
115
+ );
116
+ ```
117
+
84
118
  ### Quick Start Example with Bun
85
119
 
86
- Using this with Bun requires you to create the response. Below is an example of how to integrate the datastar-ssegen with a Stream.:
120
+ Using this with Bun requires you to create the response. Below is an example of how to integrate the datastar-ssegen with a Stream:
87
121
 
88
122
  ```javascript
89
123
  import { ServerSentEventGenerator } from "../index.js";
@@ -99,9 +133,9 @@ Bun.serve({
99
133
  `<html>
100
134
  <head>
101
135
  <title>Example Bun</title>
102
- <script type="module" src="https://cdn.jsdelivr.net/gh/starfederation/datastar/bundles/datastar.js"></script>
136
+ <script type="module" src="https://cdn.jsdelivr.net/gh/starfederation/datastar@v1.0.0-beta.1/bundles/datastar.js"></script>
103
137
  </head>
104
- <body data-signals="{time:''}" data-on-load="sse('/feed')">
138
+ <body data-signals="{time:''}" data-on-load="@get('/feed')">
105
139
  <div data-text="time.value"></div>
106
140
  </body>
107
141
  </html>`,
@@ -11,9 +11,9 @@ Bun.serve({
11
11
  `<html>
12
12
  <head>
13
13
  <title>Example Bun</title>
14
- <script type="module" src="https://cdn.jsdelivr.net/gh/starfederation/datastar/bundles/datastar.js"></script>
14
+ <script type="module" src="https://cdn.jsdelivr.net/gh/starfederation/datastar@v1.0.0-beta.1/bundles/datastar.js"></script>
15
15
  </head>
16
- <body data-signals="{time:''}" data-on-load="sse('/feed')">
16
+ <body data-signals="{time:''}" data-on-load="@get('/feed')">
17
17
  <div data-text="time.value"></div>
18
18
  </body>
19
19
  </html>`,
@@ -7,38 +7,38 @@ export const homepage = (name = "") => {
7
7
  return `<html>
8
8
  <head>
9
9
  <title>${name} Datastar Test</title>
10
- <script type="module" src="https://cdn.jsdelivr.net/gh/starfederation/datastar@develop/bundles/datastar.js"></script>
10
+ <script type="module" src="https://cdn.jsdelivr.net/gh/starfederation/datastar@v1.0.0-beta.1/bundles/datastar.js"></script>
11
11
  </head>
12
12
  <body>
13
13
  <h3>${name} Datastar Test</h3>
14
14
  <div data-signals="{theme: 'light', lastUpdate:'Never', xyz:'some signal'}">
15
15
  <h3>Long Lived SSE:</h3>
16
- <div id="clock" data-on-load="sse('/clock')">...Loading Clock</div>
16
+ <div id="clock" data-on-load="@get('/clock')">...Loading Clock</div>
17
17
 
18
18
  <h3>MergeSignals:</h3>
19
19
  <div>Last User Interaction:<span data-text="lastUpdate.value"></span></div>
20
20
  <h3>Merge Fragments</h3>
21
21
  <div id="quote">No Quote</div>
22
- <button data-on-click="sse('/quote')">MergeFragments</button>
22
+ <button data-on-click="@get('/quote')">MergeFragments</button>
23
23
  <h3>RemoveFragments</h3>
24
24
  <div id="trash">
25
25
  Remove me please!
26
- <button data-on-click="sse('/removeTrash')">RemoveFragments</button>
26
+ <button data-on-click="@get('/removeTrash')">RemoveFragments</button>
27
27
  </div>
28
28
  <h3>ExecuteScript</h3>
29
29
  <div>Print to Console</div>
30
- <button data-on-click="sse('/printToConsole')">ExecuteScript</button>
30
+ <button data-on-click="@get('/printToConsole')">ExecuteScript</button>
31
31
 
32
32
  <h3>ReadSignals</h3>
33
- <button data-on-click="sse('/readSignals')">ReadSignals</button>
33
+ <button data-on-click="@get('/readSignals')">ReadSignals</button>
34
34
 
35
35
  <h3>ReadSignals (post)</h3>
36
- <button data-on-click="sse('/readSignals', {method: 'post'})">ReadSignals (post)</button>
36
+ <button data-on-click="@get('/readSignals', {method: 'post'})">ReadSignals (post)</button>
37
37
 
38
38
 
39
39
  <h3>RemoveSignals</h3>
40
40
  <div>Signal xyz:<span data-text="xyz.value"></span></div>
41
- <button data-on-click="sse('/removeSignal')">Test RemoveSignals: xyz</button>
41
+ <button data-on-click="@get('/removeSignal')">Test RemoveSignals: xyz</button>
42
42
  </div>
43
43
  </body>
44
44
  </html>`;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "datastar-ssegen",
3
- "version": "1.0.1",
3
+ "version": "1.1.0",
4
4
  "description": "Datastar Server-Sent Event generator",
5
5
  "author": "John Cudd",
6
6
  "type": "module",