diff options
| author | codetorso <[email protected]> | 2024-06-24 03:54:53 +0530 |
|---|---|---|
| committer | codetorso <[email protected]> | 2024-06-24 03:54:53 +0530 |
| commit | 557c7b82eb89cf95f480896fbe41355352a01482 (patch) | |
| tree | 78f4ebd4b8849a3b84d899ec8827ca1230b4097f /apps/extension/content | |
| parent | clean code+ user canvas (1/2) (diff) | |
| download | supermemory-557c7b82eb89cf95f480896fbe41355352a01482.tar.xz supermemory-557c7b82eb89cf95f480896fbe41355352a01482.zip | |
Add Extension (1/2)
Diffstat (limited to 'apps/extension/content')
| -rw-r--r-- | apps/extension/content/ContentApp.tsx | 45 | ||||
| -rw-r--r-- | apps/extension/content/base.css | 3 | ||||
| -rw-r--r-- | apps/extension/content/content.css | 6 | ||||
| -rw-r--r-- | apps/extension/content/content.tsx | 15 |
4 files changed, 69 insertions, 0 deletions
diff --git a/apps/extension/content/ContentApp.tsx b/apps/extension/content/ContentApp.tsx new file mode 100644 index 00000000..b8cb6710 --- /dev/null +++ b/apps/extension/content/ContentApp.tsx @@ -0,0 +1,45 @@ +import React, { useEffect } from "react"; + +export default function ContentApp() { + const [text, setText] = React.useState(""); + const [hover, setHover] = React.useState(false); + + useEffect(() => { + const messageListener = (message: any) => { + setText(message); + setTimeout(() => setText(""), 2000); + }; + chrome.runtime.onMessage.addListener(messageListener); + + document.addEventListener('mousemove', (e)=> { + const percentageX = (e.clientX / window.innerWidth) * 100; + const percentageY = (e.clientY / window.innerHeight) * 100; + + if (percentageX > 75 && percentageY > 75){ + setHover(true) + } else { + setHover(false) + } + }) + return () => { + chrome.runtime.onMessage.removeListener(messageListener); + }; + }, []); + + return ( + <div className="pointer-events-none flex justify-end items-end h-screen w-full absolute z-99999"> + <div className="h-[30vh] bg-red-500 absolute flex justify-end items-center"> + <div + className={`${hover && "opacity-100 "} transition bg-red-600 opacity-0 h-12 w-12 `} + ></div> + </div> + + <div + className={`mx-4 my-2 flex flex-col gap-3 rounded-3xl bg-gray-900 text-xl py-4 px-6 overflow-hidden min-w-[20vw] min-h-24 max-w-96 max-h-40 ${text ? "translate-y-0 opacity-100" : "translate-y-[15%] opacity-0"} transition`} + > + <h2 className="text-2xl font-extrabold text-white">Saved!</h2> + <h2 className="text-lg font-medium text-white">{text}</h2> + </div> + </div> + ); +}
\ No newline at end of file diff --git a/apps/extension/content/base.css b/apps/extension/content/base.css new file mode 100644 index 00000000..bd6213e1 --- /dev/null +++ b/apps/extension/content/base.css @@ -0,0 +1,3 @@ +@tailwind base; +@tailwind components; +@tailwind utilities;
\ No newline at end of file diff --git a/apps/extension/content/content.css b/apps/extension/content/content.css new file mode 100644 index 00000000..b8195ee8 --- /dev/null +++ b/apps/extension/content/content.css @@ -0,0 +1,6 @@ +#extension-root { + position: fixed; + bottom: 0; + right: 0; + z-index: 99999; +} diff --git a/apps/extension/content/content.tsx b/apps/extension/content/content.tsx new file mode 100644 index 00000000..65c62d74 --- /dev/null +++ b/apps/extension/content/content.tsx @@ -0,0 +1,15 @@ +import ReactDOM from 'react-dom/client' +import ContentApp from './ContentApp' +import('./base.css') +import('./content.css') + +setTimeout(initial, 4000) + +function initial() { + const rootDiv = document.createElement('div') + rootDiv.id = 'extension-root' + document.body.appendChild(rootDiv) + + const root = ReactDOM.createRoot(rootDiv) + root.render(<><ContentApp /></>) +} |