aboutsummaryrefslogtreecommitdiff
path: root/apps
diff options
context:
space:
mode:
authorcodetorso <[email protected]>2024-06-02 19:54:55 +0530
committercodetorso <[email protected]>2024-06-02 19:54:55 +0530
commitf3d7f8937608f1bc99e8e902ddaa72b02544322e (patch)
tree22d2184c717d640513156b24647e84448e5fc2f4 /apps
parentfixed some import bugs (diff)
downloadsupermemory-f3d7f8937608f1bc99e8e902ddaa72b02544322e.tar.xz
supermemory-f3d7f8937608f1bc99e8e902ddaa72b02544322e.zip
Add Extension Template
Diffstat (limited to 'apps')
-rw-r--r--apps/an-extension/README.md37
-rw-r--r--apps/an-extension/background.ts1
-rw-r--r--apps/an-extension/content/ContentApp.tsx87
-rw-r--r--apps/an-extension/content/base.css3
-rw-r--r--apps/an-extension/content/content.css6
-rw-r--r--apps/an-extension/content/content.tsx19
-rw-r--r--apps/an-extension/extension-env.d.ts9
-rw-r--r--apps/an-extension/manifest.json23
-rw-r--r--apps/an-extension/package.json20
-rw-r--r--apps/an-extension/postcss.config.js6
-rw-r--r--apps/an-extension/public/chromeWindow.pngbin0 -> 297816 bytes
-rw-r--r--apps/an-extension/public/icon/icon_16.pngbin0 -> 1038 bytes
-rw-r--r--apps/an-extension/public/icon/icon_48.pngbin0 -> 4771 bytes
-rw-r--r--apps/an-extension/public/react.pngbin0 -> 76583 bytes
-rw-r--r--apps/an-extension/public/tailwind.pngbin0 -> 28424 bytes
-rw-r--r--apps/an-extension/public/tailwind_bg.pngbin0 -> 174555 bytes
-rw-r--r--apps/an-extension/public/typescript.pngbin0 -> 23667 bytes
-rw-r--r--apps/an-extension/tailwind.config.js8
-rw-r--r--apps/an-extension/tsconfig.json18
19 files changed, 237 insertions, 0 deletions
diff --git a/apps/an-extension/README.md b/apps/an-extension/README.md
new file mode 100644
index 00000000..6f11ddab
--- /dev/null
+++ b/apps/an-extension/README.md
@@ -0,0 +1,37 @@
+# an-extension
+
+> This project was bootstrapped using the Extension.js React-TypeScript template.
+
+## Scripts Available
+
+In the project directory, you can run:
+
+### npm dev
+
+```
+// Runs the app in the development mode.
+// Will open a new browser instance with your extension loaded.
+// The page will reload when you make changes.
+npm dev
+```
+
+### npm start
+
+```
+// Runs the app in the production mode.
+// Will open a new browser instance with your extension loaded.
+// This is how your browser extension will work once published.
+npm start
+```
+
+### npm build
+
+```
+// Builds the app for production.
+// Bundles your browser extension in production mode for the target browser.
+npm run build
+```
+
+## Learn More
+
+You can learn more in the [Extension.js](https://extension.js.org) documentation.
diff --git a/apps/an-extension/background.ts b/apps/an-extension/background.ts
new file mode 100644
index 00000000..798d5018
--- /dev/null
+++ b/apps/an-extension/background.ts
@@ -0,0 +1 @@
+console.log('Hello from the background script!')
diff --git a/apps/an-extension/content/ContentApp.tsx b/apps/an-extension/content/ContentApp.tsx
new file mode 100644
index 00000000..a0715969
--- /dev/null
+++ b/apps/an-extension/content/ContentApp.tsx
@@ -0,0 +1,87 @@
+import React from 'react'
+import reactLogo from '../public/react.png'
+import tailwindBg from '../public/tailwind_bg.png'
+import typescriptLogo from '../public/typescript.png'
+import tailwindLogo from '../public/tailwind.png'
+import chromeWindowBg from '../public/chromeWindow.png'
+
+export default function ContentApp() {
+ const [isdialogOpen, setIsDialogOpen] = React.useState(true)
+
+ if (!isdialogOpen) {
+ return (
+ <div className="mx-auto p-6">
+ <button
+ onClick={() => setIsDialogOpen(true)}
+ className="bg-white rounded-md p-3 text-sm font-semibold text-gray-900 shadow-sm hover:bg-gray-100 focus-visible:outline focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-white"
+ >
+ 🧩 Open content script hint <span aria-hidden="true">+</span>
+ </button>
+ </div>
+ )
+ }
+
+ return (
+ <div className="mx-auto max-w-7xl md:px-0 lg:p-6">
+ <div className="relative isolate overflow-hidden bg-gray-900 px-6 pt-16 shadow-2xl lg:rounded-3xl md:pt-24 md:h-full sm:h-[100vh] lg:flex lg:gap-x-20 lg:px-24 lg:pt-0">
+ <div className="absolute z-20 top-0 inset-x-0 flex justify-center overflow-hidden pointer-events-none">
+ <div className="w-[108rem] flex-none flex justify-end">
+ <picture>
+ <img
+ src={tailwindBg}
+ alt=""
+ className="w-[90rem] flex-none max-w-none hidden dark:block"
+ decoding="async"
+ />
+ </picture>
+ </div>
+ </div>
+ <div className="mx-auto max-w-md text-center lg:py-12 lg:mx-0 lg:flex-auto lg:text-left">
+ <div className="flex items-center justify-center space-x-4 my-4 mx-auto">
+ <img
+ alt="React logo"
+ src={reactLogo}
+ className="relative inline-block w-12"
+ />
+ <div className="text-3xl text-white">+</div>
+ <img
+ alt="TypeScript logo"
+ src={typescriptLogo}
+ className="relative inline-block w-12"
+ />
+ <div className="text-3xl text-white">+</div>
+ <img
+ alt="Tailwind logo"
+ src={tailwindLogo}
+ className="relative inline-block w-12"
+ />
+ </div>
+ <h2 className="text-3xl font-bold tracking-tight text-white sm:text-4xl">
+ This is a content script running React, TypeScript, and
+ Tailwind.css.
+ </h2>
+ <p className="mt-6 text-lg leading-8 text-gray-300">
+ Learn more about creating cross-browser extensions by{' '}
+ <button
+ onClick={() => setIsDialogOpen(false)}
+ className="underline hover:no-underline
+ "
+ >
+ closing this hint
+ </button>
+ .
+ </p>
+ </div>
+ <div className="relative mt-16 h-80 lg:mt-8">
+ <img
+ className="absolute left-0 top-0 w-[57rem] max-w-none rounded-md bg-white/5 ring-1 ring-white/10"
+ src={chromeWindowBg}
+ alt="Chrome window screenshot"
+ width="1824"
+ height="1080"
+ />
+ </div>
+ </div>
+ </div>
+ )
+}
diff --git a/apps/an-extension/content/base.css b/apps/an-extension/content/base.css
new file mode 100644
index 00000000..bd6213e1
--- /dev/null
+++ b/apps/an-extension/content/base.css
@@ -0,0 +1,3 @@
+@tailwind base;
+@tailwind components;
+@tailwind utilities; \ No newline at end of file
diff --git a/apps/an-extension/content/content.css b/apps/an-extension/content/content.css
new file mode 100644
index 00000000..b8195ee8
--- /dev/null
+++ b/apps/an-extension/content/content.css
@@ -0,0 +1,6 @@
+#extension-root {
+ position: fixed;
+ bottom: 0;
+ right: 0;
+ z-index: 99999;
+}
diff --git a/apps/an-extension/content/content.tsx b/apps/an-extension/content/content.tsx
new file mode 100644
index 00000000..01569724
--- /dev/null
+++ b/apps/an-extension/content/content.tsx
@@ -0,0 +1,19 @@
+import React from 'react'
+import ReactDOM from 'react-dom/client'
+import ContentApp from './ContentApp'
+import('./base.css')
+import('./content.css')
+
+setTimeout(initial, 1000)
+
+function initial() {
+ // Create a new div element and append it to the document's body
+ const rootDiv = document.createElement('div')
+ rootDiv.id = 'extension-root'
+ document.body.appendChild(rootDiv)
+
+ // Use `createRoot` to create a root, then render the <App /> component
+ // Note that `createRoot` takes the container DOM node, not the React element
+ const root = ReactDOM.createRoot(rootDiv)
+ root.render(<ContentApp />)
+}
diff --git a/apps/an-extension/extension-env.d.ts b/apps/an-extension/extension-env.d.ts
new file mode 100644
index 00000000..356fb729
--- /dev/null
+++ b/apps/an-extension/extension-env.d.ts
@@ -0,0 +1,9 @@
+// Required Extension.js types for TypeScript projects.
+// This file auto-generated and should not be excluded.
+// If you need extra types, consider creating a new *.d.ts and
+// referencing it in the "include" array in your tsconfig.json file.
+// See https://www.typescriptlang.org/tsconfig#include for info.
+/// <reference types="@extension-create/develop/dist/types/index.d.ts" />
+
+// Polyfill types for browser.* APIs.
+/// <reference types="@extension-create/develop/dist/types/polyfill.d.ts" />
diff --git a/apps/an-extension/manifest.json b/apps/an-extension/manifest.json
new file mode 100644
index 00000000..a270fb66
--- /dev/null
+++ b/apps/an-extension/manifest.json
@@ -0,0 +1,23 @@
+{
+ "manifest_version": 3,
+ "version": "1.0",
+ "name": "an-extension",
+ "description": "An extension template using React and TypeScript. This template includes a content script using Tailwind.css. To see it in action, visit https://extension.js.org.",
+ "background": {
+ "service_worker": "./background.ts"
+ },
+ "content_scripts": [
+ {
+ "matches": [
+ "https://extension.js.org/*"
+ ],
+ "js": [
+ "./content/content.tsx"
+ ]
+ }
+ ],
+ "icons": {
+ "16": "public/icon/icon_16.png",
+ "48": "public/icon/icon_48.png"
+ }
+} \ No newline at end of file
diff --git a/apps/an-extension/package.json b/apps/an-extension/package.json
new file mode 100644
index 00000000..3625295b
--- /dev/null
+++ b/apps/an-extension/package.json
@@ -0,0 +1,20 @@
+{
+ "devDependencies": {
+ "@types/react": "^18.0.9",
+ "@types/react-dom": "^18.0.5",
+ "react": "^18.1.0",
+ "react-dom": "^18.1.0",
+ "tailwindcss": "^3.4.1",
+ "typescript": "5.3.3",
+ "extension": "latest"
+ },
+ "scripts": {
+ "dev": "extension dev",
+ "start": "extension start",
+ "build": "extension build"
+ },
+ "dependencies": {},
+ "name": "an-extension",
+ "private": true,
+ "version": "0.0.0"
+} \ No newline at end of file
diff --git a/apps/an-extension/postcss.config.js b/apps/an-extension/postcss.config.js
new file mode 100644
index 00000000..85f717cc
--- /dev/null
+++ b/apps/an-extension/postcss.config.js
@@ -0,0 +1,6 @@
+module.exports = {
+ plugins: {
+ tailwindcss: {},
+ autoprefixer: {}
+ }
+}
diff --git a/apps/an-extension/public/chromeWindow.png b/apps/an-extension/public/chromeWindow.png
new file mode 100644
index 00000000..da525dd8
--- /dev/null
+++ b/apps/an-extension/public/chromeWindow.png
Binary files differ
diff --git a/apps/an-extension/public/icon/icon_16.png b/apps/an-extension/public/icon/icon_16.png
new file mode 100644
index 00000000..651139b5
--- /dev/null
+++ b/apps/an-extension/public/icon/icon_16.png
Binary files differ
diff --git a/apps/an-extension/public/icon/icon_48.png b/apps/an-extension/public/icon/icon_48.png
new file mode 100644
index 00000000..73b36f0f
--- /dev/null
+++ b/apps/an-extension/public/icon/icon_48.png
Binary files differ
diff --git a/apps/an-extension/public/react.png b/apps/an-extension/public/react.png
new file mode 100644
index 00000000..9080fddd
--- /dev/null
+++ b/apps/an-extension/public/react.png
Binary files differ
diff --git a/apps/an-extension/public/tailwind.png b/apps/an-extension/public/tailwind.png
new file mode 100644
index 00000000..83ed5e12
--- /dev/null
+++ b/apps/an-extension/public/tailwind.png
Binary files differ
diff --git a/apps/an-extension/public/tailwind_bg.png b/apps/an-extension/public/tailwind_bg.png
new file mode 100644
index 00000000..edc40be8
--- /dev/null
+++ b/apps/an-extension/public/tailwind_bg.png
Binary files differ
diff --git a/apps/an-extension/public/typescript.png b/apps/an-extension/public/typescript.png
new file mode 100644
index 00000000..93614694
--- /dev/null
+++ b/apps/an-extension/public/typescript.png
Binary files differ
diff --git a/apps/an-extension/tailwind.config.js b/apps/an-extension/tailwind.config.js
new file mode 100644
index 00000000..069e1bc3
--- /dev/null
+++ b/apps/an-extension/tailwind.config.js
@@ -0,0 +1,8 @@
+/** @type {import('tailwindcss').Config} */
+module.exports = {
+ content: ['**/*.html', '**/*.tsx'],
+ theme: {
+ extend: {}
+ },
+ plugins: []
+}
diff --git a/apps/an-extension/tsconfig.json b/apps/an-extension/tsconfig.json
new file mode 100644
index 00000000..520f3602
--- /dev/null
+++ b/apps/an-extension/tsconfig.json
@@ -0,0 +1,18 @@
+{
+ "compilerOptions": {
+ "allowJs": true,
+ "allowSyntheticDefaultImports": true,
+ "esModuleInterop": true,
+ "forceConsistentCasingInFileNames": true,
+ "isolatedModules": false,
+ "jsx": "react-jsx",
+ "lib": ["dom", "dom.iterable", "esnext"],
+ "moduleResolution": "node",
+ "module": "esnext",
+ "resolveJsonModule": true,
+ "strict": true,
+ "target": "esnext"
+ },
+ "include": ["./"],
+ "exclude": ["node_modules", "dist"]
+}