aboutsummaryrefslogtreecommitdiff
path: root/apps/extension/content
diff options
context:
space:
mode:
authorcodetorso <[email protected]>2024-06-24 03:54:53 +0530
committercodetorso <[email protected]>2024-06-24 03:54:53 +0530
commit557c7b82eb89cf95f480896fbe41355352a01482 (patch)
tree78f4ebd4b8849a3b84d899ec8827ca1230b4097f /apps/extension/content
parentclean code+ user canvas (1/2) (diff)
downloadsupermemory-557c7b82eb89cf95f480896fbe41355352a01482.tar.xz
supermemory-557c7b82eb89cf95f480896fbe41355352a01482.zip
Add Extension (1/2)
Diffstat (limited to 'apps/extension/content')
-rw-r--r--apps/extension/content/ContentApp.tsx45
-rw-r--r--apps/extension/content/base.css3
-rw-r--r--apps/extension/content/content.css6
-rw-r--r--apps/extension/content/content.tsx15
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 /></>)
+}