From 5fed66133dfa4d582836df555726e0ee4eed171e Mon Sep 17 00:00:00 2001 From: minimo-io Date: Mon, 15 Apr 2024 20:01:50 -0300 Subject: [PATCH] Starting out nostr followback --- .gitignore | 41 +++++++- nostr-followback/README.md | 10 ++ nostr-followback/package.json | 21 ++++ nostr-followback/src/app.html | 12 +++ nostr-followback/src/lib/index.js | 1 + nostr-followback/src/routes/+page.svelte | 121 +++++++++++++++++++++++ nostr-followback/static/favicon.png | Bin 0 -> 1571 bytes nostr-followback/svelte.config.js | 13 +++ nostr-followback/vite.config.js | 6 ++ 9 files changed, 224 insertions(+), 1 deletion(-) create mode 100644 nostr-followback/README.md create mode 100644 nostr-followback/package.json create mode 100644 nostr-followback/src/app.html create mode 100644 nostr-followback/src/lib/index.js create mode 100644 nostr-followback/src/routes/+page.svelte create mode 100644 nostr-followback/static/favicon.png create mode 100644 nostr-followback/svelte.config.js create mode 100644 nostr-followback/vite.config.js diff --git a/.gitignore b/.gitignore index 75e0f84..a358c79 100644 --- a/.gitignore +++ b/.gitignore @@ -1,4 +1,43 @@ .DS_Store **/.DS_Store + +.editorconfig + +# Bundler cache +.bundle +vendor +Gemfile.lock + +# Jekyll cache +.jekyll-cache +_site + +build dist -.editorconfig \ No newline at end of file +# RubyGems +*.gem + +# NPM dependencies +node_modules +package-lock.json + +# IDE configurations +.idea +.vscode + +# Misc +assets/js/dist +.editorconfig +.env.local +.env.development.local +.env.test.local +.env.production.local + +npm-debug.log* +yarn-debug.log* +yarn-error.log* + +# netlify +.netlify + +.svelte-kit \ No newline at end of file diff --git a/nostr-followback/README.md b/nostr-followback/README.md new file mode 100644 index 0000000..eb9a694 --- /dev/null +++ b/nostr-followback/README.md @@ -0,0 +1,10 @@ +# Nostr Reciprocal Follow + +Check who does and does not follow you back on Nostr. + +## ToDo + +- Create this but without SvelteKit (just Vite + Svelte) +- Polish the proof-of-concept code +- Configure Vite for the miniapp to be loaded in the article's url as base +- Save followbackers and not followbackers in lists to see details diff --git a/nostr-followback/package.json b/nostr-followback/package.json new file mode 100644 index 0000000..0fee7e0 --- /dev/null +++ b/nostr-followback/package.json @@ -0,0 +1,21 @@ +{ + "name": "test-nostr-reciprocal", + "version": "0.0.1", + "private": true, + "scripts": { + "dev": "vite dev", + "build": "vite build", + "preview": "vite preview" + }, + "devDependencies": { + "@sveltejs/adapter-auto": "^3.0.0", + "@sveltejs/kit": "^2.0.0", + "@sveltejs/vite-plugin-svelte": "^3.0.0", + "svelte": "^4.2.7", + "vite": "^5.0.3" + }, + "type": "module", + "dependencies": { + "@nostr-dev-kit/ndk": "^2.7.1" + } +} diff --git a/nostr-followback/src/app.html b/nostr-followback/src/app.html new file mode 100644 index 0000000..77a5ff5 --- /dev/null +++ b/nostr-followback/src/app.html @@ -0,0 +1,12 @@ + + + + + + + %sveltekit.head% + + +
%sveltekit.body%
+ + diff --git a/nostr-followback/src/lib/index.js b/nostr-followback/src/lib/index.js new file mode 100644 index 0000000..856f2b6 --- /dev/null +++ b/nostr-followback/src/lib/index.js @@ -0,0 +1 @@ +// place files you want to import through the `$lib` alias in this folder. diff --git a/nostr-followback/src/routes/+page.svelte b/nostr-followback/src/routes/+page.svelte new file mode 100644 index 0000000..6943495 --- /dev/null +++ b/nostr-followback/src/routes/+page.svelte @@ -0,0 +1,121 @@ + + +

Who does not follows you on Nostr

+{#if !userThumb} + {npubToQuery} +{/if} +
+{#if userThumb} +
+ user-thumb + User: {userName} |  Follows: {followsCount} +
+ Unknown: {unknownFollowBack} | Follow_Back: {followBackCount} | Not_Follow_Back: {notFollowBackCount} +
+{:else} +
Loading data...
+{/if} diff --git a/nostr-followback/static/favicon.png b/nostr-followback/static/favicon.png new file mode 100644 index 0000000000000000000000000000000000000000..825b9e65af7c104cfb07089bb28659393b4f2097 GIT binary patch literal 1571 zcmV+;2Hg3HP)Px)-AP12RCwC$UE6KzI1p6{F2N z1VK2vi|pOpn{~#djwYcWXTI_im_u^TJgMZ4JMOsSj!0ma>B?-(Hr@X&W@|R-$}W@Z zgj#$x=!~7LGqHW?IO8+*oE1MyDp!G=L0#^lUx?;!fXv@l^6SvTnf^ac{5OurzC#ZMYc20lI%HhX816AYVs1T3heS1*WaWH z%;x>)-J}YB5#CLzU@GBR6sXYrD>Vw(Fmt#|JP;+}<#6b63Ike{Fuo!?M{yEffez;| zp!PfsuaC)>h>-AdbnwN13g*1LowNjT5?+lFVd#9$!8Z9HA|$*6dQ8EHLu}U|obW6f z2%uGv?vr=KNq7YYa2Roj;|zooo<)lf=&2yxM@e`kM$CmCR#x>gI>I|*Ubr({5Y^rb zghxQU22N}F51}^yfDSt786oMTc!W&V;d?76)9KXX1 z+6Okem(d}YXmmOiZq$!IPk5t8nnS{%?+vDFz3BevmFNgpIod~R{>@#@5x9zJKEHLHv!gHeK~n)Ld!M8DB|Kfe%~123&Hz1Z(86nU7*G5chmyDe ziV7$pB7pJ=96hpxHv9rCR29%bLOXlKU<_13_M8x)6;P8E1Kz6G<&P?$P^%c!M5`2` zfY2zg;VK5~^>TJGQzc+33-n~gKt{{of8GzUkWmU110IgI0DLxRIM>0US|TsM=L|@F z0Bun8U!cRB7-2apz=y-7*UxOxz@Z0)@QM)9wSGki1AZ38ceG7Q72z5`i;i=J`ILzL z@iUO?SBBG-0cQuo+an4TsLy-g-x;8P4UVwk|D8{W@U1Zi z!M)+jqy@nQ$p?5tsHp-6J304Q={v-B>66$P0IDx&YT(`IcZ~bZfmn11#rXd7<5s}y zBi9eim&zQc0Dk|2>$bs0PnLmDfMP5lcXRY&cvJ=zKxI^f0%-d$tD!`LBf9^jMSYUA zI8U?CWdY@}cRq6{5~y+)#h1!*-HcGW@+gZ4B};0OnC~`xQOyH19z*TA!!BJ%9s0V3F?CAJ{hTd#*tf+ur-W9MOURF-@B77_-OshsY}6 zOXRY=5%C^*26z?l)1=$bz30!so5tfABdSYzO+H=CpV~aaUefmjvfZ3Ttu9W&W3Iu6 zROlh0MFA5h;my}8lB0tAV-Rvc2Zs_CCSJnx@d`**$idgy-iMob4dJWWw|21b4NB=LfsYp0Aeh{Ov)yztQi;eL4y5 zMi>8^SzKqk8~k?UiQK^^-5d8c%bV?$F8%X~czyiaKCI2=UH