From 9815315b5338a886c21c3e8c86b588c5d01a4627 Mon Sep 17 00:00:00 2001 From: Emilie Ma Date: Thu, 29 Dec 2022 20:57:52 -0800 Subject: [PATCH] Troubleshoot blocking + add uninstall page --- landing/cobweb.png | Bin 0 -> 5238 bytes landing/index.css | 15 +++ landing/removed.html | 36 ++++++ src/pages/Background/index.ts | 112 ++++++++++-------- src/pages/Background/lib/blockSite.ts | 12 -- src/pages/Background/lib/blockTag.ts | 19 +++ src/pages/Background/lib/createStream.ts | 3 + .../Background/lib/fetchAndUpdateBalance.ts | 4 +- src/pages/Background/lib/getRate.ts | 12 +- src/pages/Background/lib/wrapTokens.ts | 1 - src/pages/Content/index.ts | 19 +++ src/pages/Popup/Popup.tsx | 68 +++++++++-- src/pages/Popup/Welcome.tsx | 10 +- src/pages/Popup/components/CobwebPage.tsx | 2 +- src/pages/Popup/components/Setting.tsx | 4 +- src/pages/shared/events.ts | 2 +- src/pages/shared/types.ts | 1 + 17 files changed, 235 insertions(+), 85 deletions(-) create mode 100644 landing/cobweb.png create mode 100644 landing/removed.html delete mode 100644 src/pages/Background/lib/blockSite.ts create mode 100644 src/pages/Background/lib/blockTag.ts diff --git a/landing/cobweb.png b/landing/cobweb.png new file mode 100644 index 0000000000000000000000000000000000000000..51d28aba6dd7e94c980b758d7ee247982550178b GIT binary patch literal 5238 zcmd5=`9BkW{NH9~uADjZ*^-c>ToH+pN+?1o%JEIP2Rr8rmjdi|cG+udYpqj627@t-U)$c^9>m#F>ot0eMT!|>uV znL;FzSi5ZE`WAV0b%(vbxwYLqvRF2NOKKY5VzC!i))&{eXNdIb0UU8{qXC1TSfq8% zkf@BEg6?_B#`ZdcMI;itCW-95ee@8XL_fH5pUvJI$B_r;$diP%{<&4m{3?;k+}zna z$n&~+d~s!MXNNUI+?ZL}tQo+M;?{cRD4o+Q2f(U+9DSSJK0|)rI(d+=X^8L|J;7k@ zWAN*B1Ner1TtWXrRrh=|2FKjp-(>ACQkkoptQ7RbpI&Tr&q7k;=m2hQlC+uKF`L{x z{-YPmX74u+FTQFXCsXO^oikW0Hojr>-M`7QktOQZZabFpp>?X7g8kDqU)?>wK-v1+ zjpgxpyZc<$9(SL^ecLigW$t5F8T%aG?%w_Z_5elS;WYFuv<>4E8^?&Woz_8IO%E20 z!7Z(Cuh4fW4AueX1O5jDxI7+>xl5oje-AHCE^pLK5Dz*$JWDDZz-_Vi$c(+&RYudm z!r(M~b|T#v0AX&obe?ZqBcH?_(vA6?pH?WML&jm@t#4J~y|tsa!$HMTf~Tis@J ztNU=Ra}*AT*E_y6x5AhqZPxW+E60|zy5_Ld?cP}ms&?epAYqxl%h=`g;;94kYkT`# z-1-h_lRdvk?ZU0MFHon6o8yZcwf*>EJPkdvJh(vJ*k<=nF3nMxIX&~Eq|N@hwY2u> zB{H3`LTjE~9a`S38YfP#Z0xZ1Iwn^#I%g-at9=A|8{3UDaDia)Q|iai`40OH`X2J! zXG-V@1NXKp8`GnQ6ZUHd@C$3(Z^vuTu1IyFrpc-ceaW@vrJuKA>X{EDWv{eb!h} z|2ZTLew`d+^#u$QclgFI@1NPrLVP}<9tDM&>;>j9xD$J&O@p`97CSl7oS!nN3Ati@ zP|Y5gU$65eN(O!3-tr&!^XK3{q~T74dDQ3|TJm4xjP;C5vocp0A+?;@Z_=QO_Ll$? z3e7*OJxHfzTOAdnmL_LwFh9OC=t1U%*ZhwlAyi@7G#=@%K5SrCjGl~+jh^ajL$P0< zc_=7OFSrn&F@n)Y&*5No)p*UWU}Xtu?8h(P_(37rKYnm~2lJwjhI2H!fF=9YWBETz zQlSMGuQTO`TvgQ~VRb{^Y~U;Q^DB2>6gC1&ocJvOYSx|e*a!bTJ8&_-3>pxVy*haisH>& zVan&1P?S#HHdRai27t!Mzb_a){&d-Fh?z@nH4G>fcwN5}iS55xRZ2;;?RL3tzdt?c)uWePF_Xf^;C(QJ%K#0Nx@HgcRk*=Ono zuU7hc#x$NkMZ7Add~4zLj+LypXXuW2myG@R+pVq#%Fi-ztELHT@OPTw54My)JI>Zm zy)9l&Gcw`D&}NS}_hIZgGp3$(txm*w%Q^4(xHuNOe#qQ$L6F=4E_IvSTeIP%v?(@D znAAnY)Ryg;<{pl|VHg}}Y55P6eJ#@`wBw1O_mG)OG;=a#JbQ4R$%Cf*?DkiEI|i3) zX1J8RCRe&uo-Vd~c=htviK(0IGPIY;DGLN!*o_4~O4s_6m^!&1m9V!Sws+HhZ@~D0 z+GGBkbH7znr~k_vhkM)dCnqO2WfCHJMP(}?Y_PWBQ8oRB3L${irIRXY6*u!aWSI6~ zR>SYInws7_C#jWpjJ%O1LP*zZ*SiQ_$5 zE`5Ej!ZGF#jE2sCNi}7|_q+?C9e0LY9iY0OWanjQNJkX^IEK$zg=8~YTtjzAi&L*w+2Wxan>$%YS~sTVT@)P zW%AvAZRY4n=e` z?P|8k>3d7=@4MoxPm2Uj#h7ODhX5oE$74a6%~qAC9-NJI$lc1V?tSQ<6Zl#wx;4i=g3=xGhDMGe3dagc^2|POw?$!?NY=&`V z$hq`ikJDQtp36d8;sbKM_oBU3KzYzLEja>G&hTr@OpG-Q2ZAYi3=uLo5eHevLofMj`5_=b|8Yll zT3Vl_r9dBV_Kw)hN5AiHj!(XdOG@7?Gq2r~ff|aP&D5RLTz(d=_XYIW3JSb|oDr{g zND~A=l0MGx#R3uB2GY^;!fVk2EMI}gIK{?5vO(6PFrTb zg0_G^Abuu@TMIit%EbbOQXpd>Rz#X3`=+$HhPe~JB3Ivi_fHQ)-9XFor|kFMGXVPR z^e7MNd2Y_wZf7A+AV$Ut@x0|aLA(W&1r&5>Pmn=qzZ8`#fn^(Mr2ObHkmy10WJw~< z$?DFK*=IR7BQKHbw<*z9sV9LV%DKe7CN5HX|N5xT@X5IJh zh03D4mcP>t!2Iz5duOTgkAy?-zDlH{gJ=`;dgAw;wWkJ z?${`IcX!u~7xs6Nk=2WGkNbPdKMA1r%kRMhfw|^!h(y65qm$)uSmb60K=LPu4*|Hq z$FAO-ovCkVAUcu7IJY~!bo`E`biR(KDx1X*o$o}N;xu09;dBr(UdVcvIgm3T0ARrr zof2CPH8M2pWbJZhb zv|qpT?n5a%-1{qR>}7ER;P?eWf#0vyj7}FgwYAHdS>)Z(9pKAMUv=M$N+ zlty34aqc3#H932>=BlDLV(Oy&%@7ejXx(Ro_J`9u8Gn9XtN?K&UTtaWU)wD(C7a45 z2J^V}*9?J?6_30`Eghf_f>fR|$ysJj)m7v6C{?BZ@jg_)dZ^p=T;RhhNxoy_WanR->H?JUN&fgSMb{LIQiXIu)QR^4 zz6`OvXHo$naVWjSR8jwqP9)^;)AJtiYM?h3F(5q!lDya?V)?rLu4J2eMIa_Hd_gv# z$Gz81=FPCDc`oA|>9>Dwp1u`47Jp*>1uP~r?xu8(NA5g(Vab6_03Z$ENFuTdn@ra`=P>< zJIer+TO{Zx9BxZ()qZp2r&&np3N960ro>twl)48K!{%WHxz3eJapHl@1Y~Z2#KwV2wwKr8+|*c$FbNba|=(0(t6OcoR2EbQshway0 z%%j61=&s0P)5Ar|4_2SQ*n>oZ@EWLa8>>p*UNZ@OTBC*XM2iD5T5zah)oja*kw-&K z3Mp#-$H%wVAIpyYiq_(vEQ^)$Ow2{Q$9)q`vQgf=-gg zskN`|9>txfAWY%84~AQZJ`|TD-!%$3FEA3#;ETjVi9X z{d@Cu%9*Zv3CRz89lo~yevf<)P0G5$1`|Rw{3eVGrMM!S4Eh{XanQ}lp10KR;5smv z2S|N)D48FlaxcvcwOsKBmxbB*RlKlmU4bO0Fur{9 zmp`5g(0Cam&97dDQB4A~%J!Ys1vPRF-s$s)y8r~xDoamX|=aNXa#UTh`boZ_%pD7c`>+LZ=i zqx_WkP&q)k7$2mNDI_PBo9Wp3Qtl1xZrGA0hva@8q{ByQX|D|>9+w-lj?Y&nms4z; zG`(~p-W9L^N0&n<4Dzp!8(jlSrDEl~^Mpm5Pv|5nc|$m9l4U`sW)hj_%>;)g`&E$o zEznwvr@**8o3BM3{@cqD23}Mh_j7OV?VGk13I+fh-|#_;ewq^q#Y3N@86%!q`nyTuNWMu_wgg`t>(8?;HTM0&nmg zopwhv?-31U*+nRcq`im8w zRVLA*__Q{0@wQ&xsWB_)S+i~CC*+9$j%kEE@**P1%jOOeB5qkRy|b6EsW&*nk|{r$hcX@z+X({cshrEb9d{hYKNaX^4~h_$ zjt%DS;#&$w;0wiqNHrv=7HkSK1MBD%e%V*{a!buTZiLXpT?4y;ugarBdmCqPWkNQ* zn8mci&MAQOysQ048vYLE1$R+Vq|dD8&VXc5{$S)4CU%L`a^D z!=>`GXZjaH52sk5K4~p2{?d^hdV_3|xds-zrg;Stojxp`aldCo1!>#O?k z#?X$xzUYjLsEhr>4}jfwE6`IA{rctdi_&M!F33;tjd^-`M{`lVs!m&_nIa670Z;^< zw73;v_o%zK16?4DM7H#+^ffc5r%h24EUK<<1-^$z79+(dkLc?=PWpV0lFmLNSM!e^ q5`|`MN9or&+g3T-GSMZ`faedgzBD#WSsW}|0GBUZwJNpriuqq2{~1&O literal 0 HcmV?d00001 diff --git a/landing/index.css b/landing/index.css index f2e10a9..1425eac 100644 --- a/landing/index.css +++ b/landing/index.css @@ -198,3 +198,18 @@ code { #differences-content-javascript { display: none; } + +.fp-container { + width: max(40%, 300px); + height: 100vh; +} + +.fp-container img { + width: 64px; + height: 64px; + margin-top: -5rem; +} + +.fp-container .card { + max-height: max-content; +} diff --git a/landing/removed.html b/landing/removed.html new file mode 100644 index 0000000..6fed0e2 --- /dev/null +++ b/landing/removed.html @@ -0,0 +1,36 @@ + + + + + Cobweb - A new way for teens to connect + + + + + + + +
+ + Cobweb logo + +
+

Sorry to see you go.

+

We've detected that you've uninstalled or disabled Cobweb.

+

+ Please make sure that you visit + app.superfluid.finance + and log in with the Metamask wallet you use with Cobweb to close out + any streams that are still open. Otherwise, your token balance will + continue to drain. +

+ +
+
+ + diff --git a/src/pages/Background/index.ts b/src/pages/Background/index.ts index 32af095..5c72432 100644 --- a/src/pages/Background/index.ts +++ b/src/pages/Background/index.ts @@ -16,7 +16,7 @@ import { MONTAG_FOUND, USER_SET_WALLET, DELETE_STREAM, - BLOCK_SITE, + BLOCK_TAG, UPDATE_SETTING, EDIT_CURRENT_STREAM, FETCH_BALANCE, @@ -29,13 +29,13 @@ import { APPROVE_FULL, } from "../shared/events"; import TOKEN_MAP, { PROD_TOKEN_MAP } from "../shared/tokens"; -import { Wallet } from "../shared/types"; +import { PayRates, Wallet } from "../shared/types"; import createStream, { updateStream } from "./lib/createStream"; import deleteStreamByTabId from "./lib/deleteStreamByTabId"; import setNewWallet from "./lib/setNewWallet"; import { getRate } from "./lib/getRate"; import setDefaultSettings from "./lib/initializeCobweb"; -import blockSite from "./lib/blockSite"; +import blockTag from "./lib/blockTag"; import updateRateSetting from "./lib/updateRateSetting"; import fetchAndUpdateBalance from "./lib/fetchAndUpdateBalance"; import setNewAddress from "./lib/updateAddress"; @@ -52,6 +52,7 @@ import { isDev } from "./lib/isDev"; chrome.runtime.onInstalled.addListener((details) => { if (details.reason === chrome.runtime.OnInstalledReason.INSTALL) { setDefaultSettings(); + chrome.runtime.setUninstallURL("https://kewbi.sh/cobweb"); } }); @@ -79,7 +80,7 @@ storage.local.set({ toasts: [] }); let { address: addressTry } = (await storage.local.get("address")) as { address: string | null; }; -if (!addressTry) { +if (!addressTry || addressTry === "NO_ADDRESS") { storage.local.set({ address: metamaskProvider.selectedAddress ?? "NO_ADDRESS", }); @@ -156,7 +157,7 @@ const getWalletAndSigner = async (): Promise<{ } } catch (e) { errorToast(e as Error); - throw e; + // throw e; } return { wallet: walletRes, signer: sfSigner }; }; @@ -180,19 +181,21 @@ const montagFound = async ({ } const tabId = sender.tab.id ?? 0; const rate = await getRate(address); - if (rate && rate.rateAmount !== constants.Zero) { - createStream({ - from: walletRes.address, - to: address, - tabId, - url: sender.tab.url ?? "", - rateAmount: rate.rateAmount, - sf, - sfSigner, - sfToken, - infuraProvider: infuraProvider as InfuraProvider, - }); + if (rate.payWhen === PayRates.BLOCKED) { + return; } + createStream({ + from: walletRes.address, + toTag: request.options.address, + to: address, + tabId, + url: sender.tab.url ?? "", + rateAmount: rate.rateAmount, + sf, + sfSigner, + sfToken, + infuraProvider: infuraProvider as InfuraProvider, + }); }; const deleteStream = async ({ request }: { request: any }) => { @@ -214,9 +217,9 @@ const setUserWallet = async ({ request }: { request: any }) => { setNewWallet(request.options.wallet); }; -const setBlockSite = async ({ request }: { request: any }) => { - blockSite({ - site: request.options.site, +const setBlockTag = async ({ request }: { request: any }) => { + blockTag({ + address: request.options.address, }); }; @@ -247,7 +250,10 @@ const editCurrentStream = async ({ request }: { request: any }) => { const fetchBalance = async () => { const { signer: sfSigner } = await getWalletAndSigner(); - if (!sfToken || !mmProvider || !sf || !sfSigner) { + const { cwInitialized } = (await storage.local.get("cwInitialized")) as { + cwInitialized: boolean | null; + }; + if (!sfToken || !mmProvider || !sf || (cwInitialized && !sfSigner)) { return; } fetchAndUpdateBalance({ sfToken, mmProvider, sfSigner, sf }); @@ -343,8 +349,8 @@ const handleMessaging = async ( sendResponse(); return; } - case BLOCK_SITE: { - setBlockSite({ request }); + case BLOCK_TAG: { + setBlockTag({ request }); sendResponse(); return; } @@ -431,34 +437,38 @@ chrome.alarms.create("cobwebAllowanceCheck" + alarmSuffix, { delayInMinutes: 5, }); chrome.alarms.onAlarm.addListener(async (alarm) => { - var parsedName = alarm.name.match(/^([\S\s]*?)(\d+)$/); - let name = ""; - let suffix = 0; - if (parsedName) { - name = parsedName[0]; - suffix = +parsedName[1]; - } - if (suffix !== alarmSuffix) { - return; - } - const { wallet, signer: sfSigner } = await getWalletAndSigner(); - if (!sf || !sfSigner || !sfToken) { - return; - } - if (name === "cobwebStreamCleanup") { - cleanUpStreams({ sfSigner, sfToken, sf }); - } else if (name === "cobwebAllowanceCheck") { - const { address } = await storage.local.get("address"); - if (!wallet || !address) { + try { + var parsedName = alarm.name.match(/^([\S\s]*?)(\d+)$/); + let name = ""; + let suffix = 0; + if (parsedName) { + name = parsedName[0]; + suffix = +parsedName[1]; + } + if (suffix !== alarmSuffix) { return; } - fetchBalance(); - fetchCobwebAllowance({ - sfToken, - sfSigner, - sf, - walletAddress: wallet.address, - mmAddress: address, - }); - } + const { wallet, signer: sfSigner } = await getWalletAndSigner(); + if (!sf || !sfSigner || !sfToken) { + return; + } + if (name === "cobwebStreamCleanup") { + cleanUpStreams({ sfSigner, sfToken, sf }); + } else if (name === "cobwebAllowanceCheck") { + const { address } = await storage.local.get("address"); + if (!wallet || !address) { + return; + } + fetchBalance(); + fetchCobwebAllowance({ + sfToken, + sfSigner, + sf, + walletAddress: wallet.address, + mmAddress: address, + }); + } + } catch {} }); + +chrome.runtime.onConnect.addListener(() => {}); diff --git a/src/pages/Background/lib/blockSite.ts b/src/pages/Background/lib/blockSite.ts deleted file mode 100644 index 05fe35f..0000000 --- a/src/pages/Background/lib/blockSite.ts +++ /dev/null @@ -1,12 +0,0 @@ -import { storage } from "@extend-chrome/storage"; -import { RateSettings, PayRates } from "../../shared/types"; -import { constants } from "ethers"; - -const blockSite = ({ site }: { site: string }) => { - storage.local.set(({ settings }: { settings: RateSettings }) => { - settings[site] = { payWhen: PayRates.BLOCKED, rateAmount: constants.Zero }; - return settings; - }); -}; - -export default blockSite; diff --git a/src/pages/Background/lib/blockTag.ts b/src/pages/Background/lib/blockTag.ts new file mode 100644 index 0000000..4020f05 --- /dev/null +++ b/src/pages/Background/lib/blockTag.ts @@ -0,0 +1,19 @@ +import { storage } from "@extend-chrome/storage"; +import { RateSettings, PayRates } from "../../shared/types"; +import { constants } from "ethers"; + +const blockTag = async ({ address }: { address: string }) => { + storage.local.set(({ settings }: { settings: RateSettings }) => { + if (!settings) { + settings = {}; + } + let newSettings = structuredClone(settings); + newSettings[address] = { + payWhen: PayRates.BLOCKED, + rateAmount: constants.Zero, + }; + return { settings: newSettings }; + }); +}; + +export default blockTag; diff --git a/src/pages/Background/lib/createStream.ts b/src/pages/Background/lib/createStream.ts index 4a2e4db..2f134f8 100644 --- a/src/pages/Background/lib/createStream.ts +++ b/src/pages/Background/lib/createStream.ts @@ -17,6 +17,7 @@ import TOKEN_MAP from "../../shared/tokens"; const createStream = async ({ from, to, + toTag, tabId, url, rateAmount, @@ -27,6 +28,7 @@ const createStream = async ({ }: { from: string; to: string; + toTag: string; tabId: number; url: string; rateAmount: BigNumber; @@ -115,6 +117,7 @@ const createStream = async ({ ...streams, { recipient: to, + recipientTag: toTag, tabId, rateAmount, requestId: uuid, diff --git a/src/pages/Background/lib/fetchAndUpdateBalance.ts b/src/pages/Background/lib/fetchAndUpdateBalance.ts index e73dbc9..464d3e3 100644 --- a/src/pages/Background/lib/fetchAndUpdateBalance.ts +++ b/src/pages/Background/lib/fetchAndUpdateBalance.ts @@ -14,7 +14,7 @@ const fetchAndUpdateBalance = async ({ mmProvider, }: { sf: Framework; - sfSigner: Signer; + sfSigner: Signer | null; sfToken: SuperToken; mmProvider: Web3Provider; }) => { @@ -47,7 +47,7 @@ const fetchAndUpdateBalance = async ({ const balance = await mmProvider.getBalance(address); storage.local.set({ mmBalance: BigNumber.from(balance) }); - if (!cwInitialized) { + if (!cwInitialized || !sfSigner) { return; } diff --git a/src/pages/Background/lib/getRate.ts b/src/pages/Background/lib/getRate.ts index 240806f..32fe958 100644 --- a/src/pages/Background/lib/getRate.ts +++ b/src/pages/Background/lib/getRate.ts @@ -2,7 +2,7 @@ import { Rate, PayRates } from "../../shared/types"; import { storage } from "@extend-chrome/storage"; import { BigNumber } from "ethers"; -export const getRate = async (address: string): Promise => { +export const getRate = async (address: string): Promise => { const { settings } = await storage.local.get("settings"); const { defaultRate } = await storage.local.get("defaultRate"); const fallbackRate = { @@ -10,13 +10,17 @@ export const getRate = async (address: string): Promise => { payWhen: PayRates.ANY, }; - if (!settings || !settings.length) { + if (!settings || !Object.keys(settings).length) { return defaultRate ?? fallbackRate; } const tryAddress = Object.keys(settings).filter((k) => - k.startsWith(`COBWEB:${address}`) + k.toLowerCase().startsWith(`cobweb:${address.toLowerCase()}`) ); - return settings.get(tryAddress) ?? defaultRate ?? fallbackRate; + return ( + (tryAddress.length > 0 ? settings[tryAddress[0]] : null) ?? + defaultRate ?? + fallbackRate + ); }; diff --git a/src/pages/Background/lib/wrapTokens.ts b/src/pages/Background/lib/wrapTokens.ts index 0c36e57..fc98ac8 100644 --- a/src/pages/Background/lib/wrapTokens.ts +++ b/src/pages/Background/lib/wrapTokens.ts @@ -35,7 +35,6 @@ export const upgradeTokens = async ({ const upgradeTokenOperation = (sfToken as WrapperSuperToken).upgrade({ amount: BigNumber.from(upgrading).toString(), }); - console.log(upgradeTokenOperation); await upgradeTokenOperation.exec(sfSigner); toast("Upgraded!"); } catch (e) { diff --git a/src/pages/Content/index.ts b/src/pages/Content/index.ts index ac63d69..4832fab 100644 --- a/src/pages/Content/index.ts +++ b/src/pages/Content/index.ts @@ -24,3 +24,22 @@ if (monetizationTag) { }); } } + +try { + const port = chrome.runtime.connect({ name: "content-script" }); + const onPortDisconnect = () => { + try { + console.log(chrome.runtime.lastError); + setTimeout(() => { + if (!chrome.runtime?.id) { + document.body.insertAdjacentHTML( + "afterend", + "" + ); + document.getElementById("cobweb-removed-link")?.click(); + } + }, 1000); + } catch {} + }; + port.onDisconnect.addListener(onPortDisconnect); +} catch {} diff --git a/src/pages/Popup/Popup.tsx b/src/pages/Popup/Popup.tsx index a9b967b..9b16b3f 100644 --- a/src/pages/Popup/Popup.tsx +++ b/src/pages/Popup/Popup.tsx @@ -3,7 +3,7 @@ import React, { useEffect, useState } from "react"; import { Link, Navigate, useSearchParams } from "react-router-dom"; import { DELETE_STREAM, - BLOCK_SITE, + BLOCK_TAG, UPDATE_SETTING, UPDATE_STREAM, CHECK_METAMASK, @@ -122,6 +122,17 @@ const Popup = () => { }; }, [currentStream]); + useEffect(() => { + const collapse = document.getElementById("collapse"); + let newCollapse: bootstrap.Collapse | null = null; + if (collapse && currentStream) { + newCollapse = new bootstrap.Collapse(collapse); + } + return () => { + newCollapse?.dispose(); + }; + }, [currentStream]); + const editStream = async ({ oldKey, newKey, @@ -175,13 +186,13 @@ const Popup = () => { const blockStream = async (stream: Stream) => { try { await cancelStream(stream); - const hostname = new URL(url).hostname; chrome.runtime.sendMessage({ - message: BLOCK_SITE, + message: BLOCK_TAG, options: { - site: hostname, + address: stream.recipientTag, }, }); + setCurrentStream(null); } catch { toast("Couldn't block site"); } @@ -269,6 +280,45 @@ const Popup = () => { Block this page + +
+
+ {rate.rateAmount === constants.Zero ? ( + + ) : null} + + + + + + + + + +
+
) : ( <> @@ -350,9 +400,8 @@ const Popup = () => {