@nsite/stealthis 0.3.0 → 0.5.0
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/README.md +2 -8
- package/package.json +1 -1
- package/src/nostr.ts +22 -19
- package/src/widget.ts +10 -7
package/README.md
CHANGED
|
@@ -8,18 +8,12 @@ When loaded on an nsite, `<nsite-deploy>` detects the site owner's pubkey from t
|
|
|
8
8
|
|
|
9
9
|
## Install
|
|
10
10
|
|
|
11
|
-
Add a script tag to your nsite. The widget auto-injects a fixed-position button in the bottom-right corner.
|
|
12
|
-
|
|
13
|
-
```html
|
|
14
|
-
<script src="https://unpkg.com/@nsite/stealthis/dist/stealthis.js"></script>
|
|
15
|
-
```
|
|
16
|
-
|
|
17
|
-
Or use the ES module:
|
|
18
|
-
|
|
19
11
|
```js
|
|
20
12
|
import '@nsite/stealthis';
|
|
21
13
|
```
|
|
22
14
|
|
|
15
|
+
The widget auto-injects a fixed-position button in the bottom-right corner.
|
|
16
|
+
|
|
23
17
|
## Manual placement
|
|
24
18
|
|
|
25
19
|
If you want to control where the button appears, add the element yourself (the auto-inject will skip if one already exists):
|
package/package.json
CHANGED
package/src/nostr.ts
CHANGED
|
@@ -249,6 +249,7 @@ export function createDeployEvent(
|
|
|
249
249
|
description?: string;
|
|
250
250
|
deployerPubkey: string;
|
|
251
251
|
deployerRelays: string[];
|
|
252
|
+
noTrail?: boolean;
|
|
252
253
|
}
|
|
253
254
|
): EventTemplate {
|
|
254
255
|
const tags: string[][] = [];
|
|
@@ -257,25 +258,27 @@ export function createDeployEvent(
|
|
|
257
258
|
if (t[0] === 'path' || t[0] === 'server') tags.push([...t]);
|
|
258
259
|
}
|
|
259
260
|
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
261
|
+
if (!options.noTrail) {
|
|
262
|
+
// Paper trail: copy muse tags, add new one, enforce max 9
|
|
263
|
+
const sourceMuses = source.tags
|
|
264
|
+
.filter((t) => t[0] === 'muse' && t[1] && t[2])
|
|
265
|
+
.map((t) => [...t])
|
|
266
|
+
.sort((a, b) => parseInt(a[1], 10) - parseInt(b[1], 10));
|
|
267
|
+
|
|
268
|
+
const maxIndex = sourceMuses.length > 0
|
|
269
|
+
? Math.max(...sourceMuses.map((t) => parseInt(t[1], 10)))
|
|
270
|
+
: -1;
|
|
271
|
+
const newMuse = ['muse', String(maxIndex + 1), options.deployerPubkey, ...options.deployerRelays];
|
|
272
|
+
const allMuses = [...sourceMuses, newMuse];
|
|
273
|
+
|
|
274
|
+
// Keep index 0 (originator) + newest, FIFO truncate the middle
|
|
275
|
+
if (allMuses.length > MAX_MUSE_TAGS) {
|
|
276
|
+
const originator = allMuses[0];
|
|
277
|
+
const keep = allMuses.slice(allMuses.length - (MAX_MUSE_TAGS - 1));
|
|
278
|
+
tags.push(originator, ...keep);
|
|
279
|
+
} else {
|
|
280
|
+
for (const t of allMuses) tags.push(t);
|
|
281
|
+
}
|
|
279
282
|
}
|
|
280
283
|
|
|
281
284
|
if (options.title) tags.push(['title', options.title]);
|
package/src/widget.ts
CHANGED
|
@@ -54,12 +54,14 @@ export class NsiteDeployButton extends HTMLElement {
|
|
|
54
54
|
this.ctx = nostr.parseContext();
|
|
55
55
|
if (this.ctx) {
|
|
56
56
|
this.manifestPromise = nostr.fetchManifest(this.ctx);
|
|
57
|
-
this.
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
57
|
+
if (!this.hasAttribute('no-trail')) {
|
|
58
|
+
this.manifestPromise.then((manifest) => {
|
|
59
|
+
if (manifest) {
|
|
60
|
+
this.muses = nostr.extractMuses(manifest);
|
|
61
|
+
if (this.muses.length > 0 && this.state === 'idle') this.render();
|
|
62
|
+
}
|
|
63
|
+
});
|
|
64
|
+
}
|
|
63
65
|
this.render();
|
|
64
66
|
}
|
|
65
67
|
}
|
|
@@ -608,7 +610,8 @@ export class NsiteDeployButton extends HTMLElement {
|
|
|
608
610
|
title: this.siteTitle || undefined,
|
|
609
611
|
description: this.siteDescription || undefined,
|
|
610
612
|
deployerPubkey: this.userPubkey,
|
|
611
|
-
deployerRelays: this.userRelays
|
|
613
|
+
deployerRelays: this.userRelays,
|
|
614
|
+
noTrail: this.hasAttribute('no-trail')
|
|
612
615
|
});
|
|
613
616
|
|
|
614
617
|
this.statusMsg = 'Waiting for signature...';
|