diff --git a/apps/metamigo-frontend/.eslintrc.json b/apps/metamigo-frontend/.eslintrc.json new file mode 100644 index 0000000..bffb357 --- /dev/null +++ b/apps/metamigo-frontend/.eslintrc.json @@ -0,0 +1,3 @@ +{ + "extends": "next/core-web-vitals" +} diff --git a/apps/metamigo-frontend/.gitignore b/apps/metamigo-frontend/.gitignore new file mode 100644 index 0000000..fd3dbb5 --- /dev/null +++ b/apps/metamigo-frontend/.gitignore @@ -0,0 +1,36 @@ +# See https://help.github.com/articles/ignoring-files/ for more about ignoring files. + +# dependencies +/node_modules +/.pnp +.pnp.js +.yarn/install-state.gz + +# testing +/coverage + +# next.js +/.next/ +/out/ + +# production +/build + +# misc +.DS_Store +*.pem + +# debug +npm-debug.log* +yarn-debug.log* +yarn-error.log* + +# local env files +.env*.local + +# vercel +.vercel + +# typescript +*.tsbuildinfo +next-env.d.ts diff --git a/apps/metamigo-frontend/README.md b/apps/metamigo-frontend/README.md new file mode 100644 index 0000000..c403366 --- /dev/null +++ b/apps/metamigo-frontend/README.md @@ -0,0 +1,36 @@ +This is a [Next.js](https://nextjs.org/) project bootstrapped with [`create-next-app`](https://github.com/vercel/next.js/tree/canary/packages/create-next-app). + +## Getting Started + +First, run the development server: + +```bash +npm run dev +# or +yarn dev +# or +pnpm dev +# or +bun dev +``` + +Open [http://localhost:3000](http://localhost:3000) with your browser to see the result. + +You can start editing the page by modifying `app/page.tsx`. The page auto-updates as you edit the file. + +This project uses [`next/font`](https://nextjs.org/docs/basic-features/font-optimization) to automatically optimize and load Inter, a custom Google Font. + +## Learn More + +To learn more about Next.js, take a look at the following resources: + +- [Next.js Documentation](https://nextjs.org/docs) - learn about Next.js features and API. +- [Learn Next.js](https://nextjs.org/learn) - an interactive Next.js tutorial. + +You can check out [the Next.js GitHub repository](https://github.com/vercel/next.js/) - your feedback and contributions are welcome! + +## Deploy on Vercel + +The easiest way to deploy your Next.js app is to use the [Vercel Platform](https://vercel.com/new?utm_medium=default-template&filter=next.js&utm_source=create-next-app&utm_campaign=create-next-app-readme) from the creators of Next.js. + +Check out our [Next.js deployment documentation](https://nextjs.org/docs/deployment) for more details. diff --git a/apps/metamigo-frontend/app/_components/InternalLayout.tsx b/apps/metamigo-frontend/app/_components/InternalLayout.tsx new file mode 100644 index 0000000..3eea55f --- /dev/null +++ b/apps/metamigo-frontend/app/_components/InternalLayout.tsx @@ -0,0 +1,21 @@ +"use client"; + +import { FC, PropsWithChildren, useState } from "react"; +import { Grid } from "@mui/material"; +import { Sidebar } from "./Sidebar"; + +export const InternalLayout: FC = ({ children }) => { + const [open, setOpen] = useState(true); + + return ( + + + + {children as any} + + + ); +}; diff --git a/apps/metamigo-frontend/app/_components/List.tsx b/apps/metamigo-frontend/app/_components/List.tsx new file mode 100644 index 0000000..024a729 --- /dev/null +++ b/apps/metamigo-frontend/app/_components/List.tsx @@ -0,0 +1,84 @@ +"use client"; + +import { FC } from "react"; +import { Grid, Box } from "@mui/material"; +import { DataGridPro, GridColDef } from "@mui/x-data-grid-pro"; +import { useRouter } from "next/navigation"; + +interface ListProps { + title: string; + entity: string; + rows: any; + columns: GridColDef[]; +} + +export const List: FC = ({ title, entity, rows, columns }) => { + const router = useRouter(); + + const onRowClick = (id: string) => { + router.push(`/${entity}/${id}`); + }; + + return ( + + + +

{title}

+
+ + + onRowClick(row.id)} + /> + + +
+
+ ); +}; diff --git a/apps/metamigo-frontend/app/_components/Sidebar.tsx b/apps/metamigo-frontend/app/_components/Sidebar.tsx new file mode 100644 index 0000000..872b3bb --- /dev/null +++ b/apps/metamigo-frontend/app/_components/Sidebar.tsx @@ -0,0 +1,349 @@ +"use client"; + +import { FC } from "react"; +import { + Box, + Grid, + Typography, + List, + ListItemButton, + ListItemIcon, + ListItemText, + ListItemSecondaryAction, + Drawer, +} from "@mui/material"; +import { + ExpandCircleDown as ExpandCircleDownIcon, + AccountCircle as AccountCircleIcon, + Chat as ChatIcon, + PermPhoneMsg as PhoneIcon, + WhatsApp as WhatsAppIcon, + Facebook as FacebookIcon, +} from "@mui/icons-material"; +import { usePathname } from "next/navigation"; +import Link from "next/link"; +import Image from "next/image"; +// import LinkLogo from "public/link-logo-small.png"; +// import { useSession, signOut } from "next-auth/react"; + +const openWidth = 270; +const closedWidth = 100; + +const MenuItem = ({ + name, + href, + Icon, + iconSize, + inset = false, + selected = false, + open = true, + badge, + target = "_self", +}: any) => ( + + + {iconSize > 0 ? ( + + + + + + ) : ( + + + + + )} + {open && ( + + {name} + + } + /> + )} + {badge && badge > 0 ? ( + + + {badge} + + + ) : null} + + +); + +interface SidebarProps { + open: boolean; + setOpen: (open: boolean) => void; +} + +export const Sidebar: FC = ({ open, setOpen }) => { + const pathname = usePathname(); + // const { data: session } = useSession(); + // const username = session?.user?.name || "User"; + + // const logout = () => { + // signOut({ callbackUrl: "/login" }); + // }; + + return ( + + { + setOpen!(!open); + }} + > + + + + + + + Link logo + + . + + {open && ( + + + Metamigo + + + )} + + + + + + + + + + + + + + + + ); +}; diff --git a/apps/metamigo-frontend/app/_lib/database.ts b/apps/metamigo-frontend/app/_lib/database.ts new file mode 100644 index 0000000..e69de29 diff --git a/apps/metamigo-frontend/app/_lib/facebook.ts b/apps/metamigo-frontend/app/_lib/facebook.ts new file mode 100644 index 0000000..e69de29 diff --git a/apps/metamigo-frontend/app/_lib/routing.ts b/apps/metamigo-frontend/app/_lib/routing.ts new file mode 100644 index 0000000..e69de29 diff --git a/apps/metamigo-frontend/app/_lib/signal.ts b/apps/metamigo-frontend/app/_lib/signal.ts new file mode 100644 index 0000000..e69de29 diff --git a/apps/metamigo-frontend/app/_lib/voice.ts b/apps/metamigo-frontend/app/_lib/voice.ts new file mode 100644 index 0000000..e69de29 diff --git a/apps/metamigo-frontend/app/_lib/whatsapp.ts b/apps/metamigo-frontend/app/_lib/whatsapp.ts new file mode 100644 index 0000000..e69de29 diff --git a/apps/metamigo-frontend/app/_styles/globals.css b/apps/metamigo-frontend/app/_styles/globals.css new file mode 100644 index 0000000..f4bd77c --- /dev/null +++ b/apps/metamigo-frontend/app/_styles/globals.css @@ -0,0 +1,107 @@ +:root { + --max-width: 1100px; + --border-radius: 12px; + --font-mono: ui-monospace, Menlo, Monaco, "Cascadia Mono", "Segoe UI Mono", + "Roboto Mono", "Oxygen Mono", "Ubuntu Monospace", "Source Code Pro", + "Fira Mono", "Droid Sans Mono", "Courier New", monospace; + + --foreground-rgb: 0, 0, 0; + --background-start-rgb: 214, 219, 220; + --background-end-rgb: 255, 255, 255; + + --primary-glow: conic-gradient( + from 180deg at 50% 50%, + #16abff33 0deg, + #0885ff33 55deg, + #54d6ff33 120deg, + #0071ff33 160deg, + transparent 360deg + ); + --secondary-glow: radial-gradient( + rgba(255, 255, 255, 1), + rgba(255, 255, 255, 0) + ); + + --tile-start-rgb: 239, 245, 249; + --tile-end-rgb: 228, 232, 233; + --tile-border: conic-gradient( + #00000080, + #00000040, + #00000030, + #00000020, + #00000010, + #00000010, + #00000080 + ); + + --callout-rgb: 238, 240, 241; + --callout-border-rgb: 172, 175, 176; + --card-rgb: 180, 185, 188; + --card-border-rgb: 131, 134, 135; +} + +@media (prefers-color-scheme: dark) { + :root { + --foreground-rgb: 255, 255, 255; + --background-start-rgb: 0, 0, 0; + --background-end-rgb: 0, 0, 0; + + --primary-glow: radial-gradient(rgba(1, 65, 255, 0.4), rgba(1, 65, 255, 0)); + --secondary-glow: linear-gradient( + to bottom right, + rgba(1, 65, 255, 0), + rgba(1, 65, 255, 0), + rgba(1, 65, 255, 0.3) + ); + + --tile-start-rgb: 2, 13, 46; + --tile-end-rgb: 2, 5, 19; + --tile-border: conic-gradient( + #ffffff80, + #ffffff40, + #ffffff30, + #ffffff20, + #ffffff10, + #ffffff10, + #ffffff80 + ); + + --callout-rgb: 20, 20, 20; + --callout-border-rgb: 108, 108, 108; + --card-rgb: 100, 100, 100; + --card-border-rgb: 200, 200, 200; + } +} + +* { + box-sizing: border-box; + padding: 0; + margin: 0; +} + +html, +body { + max-width: 100vw; + overflow-x: hidden; +} + +body { + color: rgb(var(--foreground-rgb)); + background: linear-gradient( + to bottom, + transparent, + rgb(var(--background-end-rgb)) + ) + rgb(var(--background-start-rgb)); +} + +a { + color: inherit; + text-decoration: none; +} + +@media (prefers-color-scheme: dark) { + html { + color-scheme: dark; + } +} diff --git a/apps/metamigo-frontend/app/api/[service]/bots/[token]/receive/route.ts b/apps/metamigo-frontend/app/api/[service]/bots/[token]/receive/route.ts new file mode 100644 index 0000000..e69de29 diff --git a/apps/metamigo-frontend/app/api/[service]/bots/[token]/register/route.ts b/apps/metamigo-frontend/app/api/[service]/bots/[token]/register/route.ts new file mode 100644 index 0000000..e69de29 diff --git a/apps/metamigo-frontend/app/api/[service]/bots/[token]/request-code/route.ts b/apps/metamigo-frontend/app/api/[service]/bots/[token]/request-code/route.ts new file mode 100644 index 0000000..e69de29 diff --git a/apps/metamigo-frontend/app/api/[service]/bots/[token]/reset-session/route.ts b/apps/metamigo-frontend/app/api/[service]/bots/[token]/reset-session/route.ts new file mode 100644 index 0000000..e69de29 diff --git a/apps/metamigo-frontend/app/api/[service]/bots/[token]/route.ts b/apps/metamigo-frontend/app/api/[service]/bots/[token]/route.ts new file mode 100644 index 0000000..e69de29 diff --git a/apps/metamigo-frontend/app/api/[service]/bots/[token]/send/route.ts b/apps/metamigo-frontend/app/api/[service]/bots/[token]/send/route.ts new file mode 100644 index 0000000..e69de29 diff --git a/apps/metamigo-frontend/app/api/[service]/bots/route.ts b/apps/metamigo-frontend/app/api/[service]/bots/route.ts new file mode 100644 index 0000000..e69de29 diff --git a/apps/metamigo-frontend/app/facebook/[id]/edit/page.tsx b/apps/metamigo-frontend/app/facebook/[id]/edit/page.tsx new file mode 100644 index 0000000..1ae9052 --- /dev/null +++ b/apps/metamigo-frontend/app/facebook/[id]/edit/page.tsx @@ -0,0 +1,3 @@ +export default function Page() { + return

Facebook view

; +} diff --git a/apps/metamigo-frontend/app/facebook/[id]/page.tsx b/apps/metamigo-frontend/app/facebook/[id]/page.tsx new file mode 100644 index 0000000..1ae9052 --- /dev/null +++ b/apps/metamigo-frontend/app/facebook/[id]/page.tsx @@ -0,0 +1,3 @@ +export default function Page() { + return

Facebook view

; +} diff --git a/apps/metamigo-frontend/app/facebook/new/page.tsx b/apps/metamigo-frontend/app/facebook/new/page.tsx new file mode 100644 index 0000000..31d20d4 --- /dev/null +++ b/apps/metamigo-frontend/app/facebook/new/page.tsx @@ -0,0 +1,3 @@ +export default function Page() { + return

Facebook Home

; +} diff --git a/apps/metamigo-frontend/app/facebook/page.tsx b/apps/metamigo-frontend/app/facebook/page.tsx new file mode 100644 index 0000000..6b769f2 --- /dev/null +++ b/apps/metamigo-frontend/app/facebook/page.tsx @@ -0,0 +1,46 @@ +"use client"; + +import { GridColDef } from "@mui/x-data-grid-pro"; +import { List } from "@/app/_components/List"; + +export default function Page() { + const columns: GridColDef[] = [ + { + field: "id", + headerName: "ID", + flex: 1, + }, + { + field: "phoneNumber", + headerName: "Phone Number", + flex: 2, + }, + { + field: "createdAt", + headerName: "Created At", + valueGetter: (params: any) => + new Date(params.row?.createdAt).toLocaleString(), + flex: 1, + }, + { + field: "updatedAt", + headerName: "Updated At", + valueGetter: (params: any) => + new Date(params.row?.updatedAt).toLocaleString(), + flex: 1, + }, + ]; + + const rows = [ + { + id: 10, + phoneNumber: "1234567890", + createdAt: new Date(), + updatedAt: new Date(), + }, + ]; + + return ( + + ); +} diff --git a/apps/metamigo-frontend/app/favicon.ico b/apps/metamigo-frontend/app/favicon.ico new file mode 100644 index 0000000..718d6fe Binary files /dev/null and b/apps/metamigo-frontend/app/favicon.ico differ diff --git a/apps/metamigo-frontend/app/layout.tsx b/apps/metamigo-frontend/app/layout.tsx new file mode 100644 index 0000000..00c7d92 --- /dev/null +++ b/apps/metamigo-frontend/app/layout.tsx @@ -0,0 +1,25 @@ +import type { Metadata } from "next"; +import { Inter } from "next/font/google"; +import { InternalLayout } from "./_components/InternalLayout"; +import "./_styles/globals.css"; + +const inter = Inter({ subsets: ["latin"] }); + +export const metadata: Metadata = { + title: "Metamigo", + description: "", +}; + +export default function RootLayout({ + children, +}: Readonly<{ + children: React.ReactNode; +}>) { + return ( + + + {children} + + + ); +} diff --git a/apps/metamigo-frontend/app/page.module.css b/apps/metamigo-frontend/app/page.module.css new file mode 100644 index 0000000..5c4b1e6 --- /dev/null +++ b/apps/metamigo-frontend/app/page.module.css @@ -0,0 +1,230 @@ +.main { + display: flex; + flex-direction: column; + justify-content: space-between; + align-items: center; + padding: 6rem; + min-height: 100vh; +} + +.description { + display: inherit; + justify-content: inherit; + align-items: inherit; + font-size: 0.85rem; + max-width: var(--max-width); + width: 100%; + z-index: 2; + font-family: var(--font-mono); +} + +.description a { + display: flex; + justify-content: center; + align-items: center; + gap: 0.5rem; +} + +.description p { + position: relative; + margin: 0; + padding: 1rem; + background-color: rgba(var(--callout-rgb), 0.5); + border: 1px solid rgba(var(--callout-border-rgb), 0.3); + border-radius: var(--border-radius); +} + +.code { + font-weight: 700; + font-family: var(--font-mono); +} + +.grid { + display: grid; + grid-template-columns: repeat(4, minmax(25%, auto)); + max-width: 100%; + width: var(--max-width); +} + +.card { + padding: 1rem 1.2rem; + border-radius: var(--border-radius); + background: rgba(var(--card-rgb), 0); + border: 1px solid rgba(var(--card-border-rgb), 0); + transition: background 200ms, border 200ms; +} + +.card span { + display: inline-block; + transition: transform 200ms; +} + +.card h2 { + font-weight: 600; + margin-bottom: 0.7rem; +} + +.card p { + margin: 0; + opacity: 0.6; + font-size: 0.9rem; + line-height: 1.5; + max-width: 30ch; + text-wrap: balance; +} + +.center { + display: flex; + justify-content: center; + align-items: center; + position: relative; + padding: 4rem 0; +} + +.center::before { + background: var(--secondary-glow); + border-radius: 50%; + width: 480px; + height: 360px; + margin-left: -400px; +} + +.center::after { + background: var(--primary-glow); + width: 240px; + height: 180px; + z-index: -1; +} + +.center::before, +.center::after { + content: ""; + left: 50%; + position: absolute; + filter: blur(45px); + transform: translateZ(0); +} + +.logo { + position: relative; +} +/* Enable hover only on non-touch devices */ +@media (hover: hover) and (pointer: fine) { + .card:hover { + background: rgba(var(--card-rgb), 0.1); + border: 1px solid rgba(var(--card-border-rgb), 0.15); + } + + .card:hover span { + transform: translateX(4px); + } +} + +@media (prefers-reduced-motion) { + .card:hover span { + transform: none; + } +} + +/* Mobile */ +@media (max-width: 700px) { + .content { + padding: 4rem; + } + + .grid { + grid-template-columns: 1fr; + margin-bottom: 120px; + max-width: 320px; + text-align: center; + } + + .card { + padding: 1rem 2.5rem; + } + + .card h2 { + margin-bottom: 0.5rem; + } + + .center { + padding: 8rem 0 6rem; + } + + .center::before { + transform: none; + height: 300px; + } + + .description { + font-size: 0.8rem; + } + + .description a { + padding: 1rem; + } + + .description p, + .description div { + display: flex; + justify-content: center; + position: fixed; + width: 100%; + } + + .description p { + align-items: center; + inset: 0 0 auto; + padding: 2rem 1rem 1.4rem; + border-radius: 0; + border: none; + border-bottom: 1px solid rgba(var(--callout-border-rgb), 0.25); + background: linear-gradient( + to bottom, + rgba(var(--background-start-rgb), 1), + rgba(var(--callout-rgb), 0.5) + ); + background-clip: padding-box; + backdrop-filter: blur(24px); + } + + .description div { + align-items: flex-end; + pointer-events: none; + inset: auto 0 0; + padding: 2rem; + height: 200px; + background: linear-gradient( + to bottom, + transparent 0%, + rgb(var(--background-end-rgb)) 40% + ); + z-index: 1; + } +} + +/* Tablet and Smaller Desktop */ +@media (min-width: 701px) and (max-width: 1120px) { + .grid { + grid-template-columns: repeat(2, 50%); + } +} + +@media (prefers-color-scheme: dark) { + .vercelLogo { + filter: invert(1); + } + + .logo { + filter: invert(1) drop-shadow(0 0 0.3rem #ffffff70); + } +} + +@keyframes rotate { + from { + transform: rotate(360deg); + } + to { + transform: rotate(0deg); + } +} diff --git a/apps/metamigo-frontend/app/page.tsx b/apps/metamigo-frontend/app/page.tsx new file mode 100644 index 0000000..3b7bbc1 --- /dev/null +++ b/apps/metamigo-frontend/app/page.tsx @@ -0,0 +1,3 @@ +export default function Page() { + return

Home

; +} diff --git a/apps/metamigo-frontend/app/signal/[id]/page.tsx b/apps/metamigo-frontend/app/signal/[id]/page.tsx new file mode 100644 index 0000000..e69de29 diff --git a/apps/metamigo-frontend/app/signal/new/page.tsx b/apps/metamigo-frontend/app/signal/new/page.tsx new file mode 100644 index 0000000..e69de29 diff --git a/apps/metamigo-frontend/app/signal/page.tsx b/apps/metamigo-frontend/app/signal/page.tsx new file mode 100644 index 0000000..dad2984 --- /dev/null +++ b/apps/metamigo-frontend/app/signal/page.tsx @@ -0,0 +1,46 @@ +"use client"; + +import { GridColDef } from "@mui/x-data-grid-pro"; +import { List } from "@/app/_components/List"; + +export default function Page() { + const columns: GridColDef[] = [ + { + field: "id", + headerName: "ID", + flex: 1, + }, + { + field: "phoneNumber", + headerName: "Phone Number", + flex: 2, + }, + { + field: "createdAt", + headerName: "Created At", + valueGetter: (params: any) => + new Date(params.row?.createdAt).toLocaleString(), + flex: 1, + }, + { + field: "updatedAt", + headerName: "Updated At", + valueGetter: (params: any) => + new Date(params.row?.updatedAt).toLocaleString(), + flex: 1, + }, + ]; + + const rows = [ + { + id: 10, + phoneNumber: "1234567890", + createdAt: new Date(), + updatedAt: new Date(), + }, + ]; + + return ( + + ); +} diff --git a/apps/metamigo-frontend/app/users/page.tsx b/apps/metamigo-frontend/app/users/page.tsx new file mode 100644 index 0000000..f81d4e4 --- /dev/null +++ b/apps/metamigo-frontend/app/users/page.tsx @@ -0,0 +1,44 @@ +"use client"; + +import { GridColDef } from "@mui/x-data-grid-pro"; +import { List } from "@/app/_components/List"; + +export default function Page() { + const columns: GridColDef[] = [ + { + field: "id", + headerName: "ID", + flex: 1, + }, + { + field: "phoneNumber", + headerName: "Phone Number", + flex: 2, + }, + { + field: "createdAt", + headerName: "Created At", + valueGetter: (params: any) => + new Date(params.row?.createdAt).toLocaleString(), + flex: 1, + }, + { + field: "updatedAt", + headerName: "Updated At", + valueGetter: (params: any) => + new Date(params.row?.updatedAt).toLocaleString(), + flex: 1, + }, + ]; + + const rows = [ + { + id: 10, + phoneNumber: "1234567890", + createdAt: new Date(), + updatedAt: new Date(), + }, + ]; + + return ; +} diff --git a/apps/metamigo-frontend/app/voice/[id]/edit/page.tsx b/apps/metamigo-frontend/app/voice/[id]/edit/page.tsx new file mode 100644 index 0000000..e704b4c --- /dev/null +++ b/apps/metamigo-frontend/app/voice/[id]/edit/page.tsx @@ -0,0 +1,3 @@ +export default function Page() { + return

Voice Edit

; +} diff --git a/apps/metamigo-frontend/app/voice/[id]/page.tsx b/apps/metamigo-frontend/app/voice/[id]/page.tsx new file mode 100644 index 0000000..e69de29 diff --git a/apps/metamigo-frontend/app/voice/new/page.tsx b/apps/metamigo-frontend/app/voice/new/page.tsx new file mode 100644 index 0000000..e69de29 diff --git a/apps/metamigo-frontend/app/voice/page.tsx b/apps/metamigo-frontend/app/voice/page.tsx new file mode 100644 index 0000000..cbd5ca3 --- /dev/null +++ b/apps/metamigo-frontend/app/voice/page.tsx @@ -0,0 +1,46 @@ +"use client"; + +import { GridColDef } from "@mui/x-data-grid-pro"; +import { List } from "@/app/_components/List"; + +export default function Page() { + const columns: GridColDef[] = [ + { + field: "id", + headerName: "ID", + flex: 1, + }, + { + field: "phoneNumber", + headerName: "Phone Number", + flex: 2, + }, + { + field: "createdAt", + headerName: "Created At", + valueGetter: (params: any) => + new Date(params.row?.createdAt).toLocaleString(), + flex: 1, + }, + { + field: "updatedAt", + headerName: "Updated At", + valueGetter: (params: any) => + new Date(params.row?.updatedAt).toLocaleString(), + flex: 1, + }, + ]; + + const rows = [ + { + id: 10, + phoneNumber: "1234567890", + createdAt: new Date(), + updatedAt: new Date(), + }, + ]; + + return ( + + ); +} diff --git a/apps/metamigo-frontend/app/whatsapp/[id]/edit/page.tsx b/apps/metamigo-frontend/app/whatsapp/[id]/edit/page.tsx new file mode 100644 index 0000000..795e053 --- /dev/null +++ b/apps/metamigo-frontend/app/whatsapp/[id]/edit/page.tsx @@ -0,0 +1,3 @@ +export default function Page() { + return

Whatsapp edit

; +} diff --git a/apps/metamigo-frontend/app/whatsapp/[id]/page.tsx b/apps/metamigo-frontend/app/whatsapp/[id]/page.tsx new file mode 100644 index 0000000..b4f0a76 --- /dev/null +++ b/apps/metamigo-frontend/app/whatsapp/[id]/page.tsx @@ -0,0 +1,3 @@ +export default function Page() { + return

Whatsapp View

; +} diff --git a/apps/metamigo-frontend/app/whatsapp/new/page.tsx b/apps/metamigo-frontend/app/whatsapp/new/page.tsx new file mode 100644 index 0000000..4daf31a --- /dev/null +++ b/apps/metamigo-frontend/app/whatsapp/new/page.tsx @@ -0,0 +1,3 @@ +export default function Page() { + return

Whatsapp new

; +} diff --git a/apps/metamigo-frontend/app/whatsapp/page.tsx b/apps/metamigo-frontend/app/whatsapp/page.tsx new file mode 100644 index 0000000..0875335 --- /dev/null +++ b/apps/metamigo-frontend/app/whatsapp/page.tsx @@ -0,0 +1,105 @@ +"use client"; + +import { GridColDef } from "@mui/x-data-grid-pro"; +import { List } from "@/app/_components/List"; + +export default function Page() { + const columns: GridColDef[] = [ + { + field: "id", + headerName: "ID", + flex: 1, + }, + { + field: "phoneNumber", + headerName: "Phone Number", + flex: 2, + }, + { + field: "createdAt", + headerName: "Created At", + valueGetter: (params: any) => + new Date(params.row?.createdAt).toLocaleString(), + flex: 1, + }, + { + field: "updatedAt", + headerName: "Updated At", + valueGetter: (params: any) => + new Date(params.row?.updatedAt).toLocaleString(), + flex: 1, + }, + ]; + + const rows = [ + { + id: 1, + phoneNumber: "1234567890", + createdAt: new Date(), + updatedAt: new Date(), + }, + { + id: 2, + phoneNumber: "1234567890", + createdAt: new Date(), + updatedAt: new Date(), + }, + { + id: 3, + phoneNumber: "1234567890", + createdAt: new Date(), + updatedAt: new Date(), + }, + { + id: 4, + phoneNumber: "1234567890", + createdAt: new Date(), + updatedAt: new Date(), + }, + { + id: 5, + phoneNumber: "1234567890", + createdAt: new Date(), + updatedAt: new Date(), + }, + { + id: 6, + phoneNumber: "1234567890", + createdAt: new Date(), + updatedAt: new Date(), + }, + { + id: 7, + phoneNumber: "1234567890", + createdAt: new Date(), + updatedAt: new Date(), + }, + { + id: 8, + phoneNumber: "1234567890", + createdAt: new Date(), + updatedAt: new Date(), + }, + { + id: 9, + phoneNumber: "1234567890", + createdAt: new Date(), + updatedAt: new Date(), + }, + { + id: 10, + phoneNumber: "1234567890", + createdAt: new Date(), + updatedAt: new Date(), + }, + ]; + + return ( + + ); +} diff --git a/apps/metamigo-frontend/next.config.mjs b/apps/metamigo-frontend/next.config.mjs new file mode 100644 index 0000000..4678774 --- /dev/null +++ b/apps/metamigo-frontend/next.config.mjs @@ -0,0 +1,4 @@ +/** @type {import('next').NextConfig} */ +const nextConfig = {}; + +export default nextConfig; diff --git a/apps/metamigo-frontend/package.json b/apps/metamigo-frontend/package.json new file mode 100644 index 0000000..71fc0b1 --- /dev/null +++ b/apps/metamigo-frontend/package.json @@ -0,0 +1,47 @@ +{ + "name": "metamigo-frontend", + "version": "0.1.0", + "private": true, + "scripts": { + "dev": "next dev", + "build": "next build", + "start": "next start", + "lint": "next lint" + }, + "dependencies": { + "@emotion/cache": "^11.11.0", + "@emotion/react": "^11.11.4", + "@emotion/server": "^11.11.0", + "@emotion/styled": "^11.11.0", + "@fontsource/playfair-display": "^5.0.20", + "@fontsource/poppins": "^5.0.8", + "@fontsource/roboto": "^5.0.8", + "@mui/icons-material": "^5", + "@mui/lab": "^5.0.0-alpha.166", + "@mui/material": "^5", + "@mui/x-data-grid-pro": "^6.19.5", + "@mui/x-date-pickers-pro": "^6.19.5", + "date-fns": "^3.3.1", + "leafcutter-common": "*", + "material-ui-popup-state": "^5.0.10", + "mui-chips-input": "^2.1.4", + "next": "14.1.0", + "next-auth": "^4.24.6", + "react": "18.2.0", + "react-cookie": "^7.1.0", + "react-digit-input": "^2.1.0", + "react-dom": "18.2.0", + "react-polyglot": "^0.7.2", + "react-qr-code": "^2.0.12", + "react-timer-hook": "^3.0.7", + "tss-react": "^4.9.4" + }, + "devDependencies": { + "typescript": "^5", + "@types/node": "^20", + "@types/react": "^18", + "@types/react-dom": "^18", + "eslint": "^8", + "eslint-config-next": "14.1.1" + } +} diff --git a/apps/metamigo-frontend/public/next.svg b/apps/metamigo-frontend/public/next.svg new file mode 100644 index 0000000..5174b28 --- /dev/null +++ b/apps/metamigo-frontend/public/next.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/apps/metamigo-frontend/public/vercel.svg b/apps/metamigo-frontend/public/vercel.svg new file mode 100644 index 0000000..d2f8422 --- /dev/null +++ b/apps/metamigo-frontend/public/vercel.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/apps/metamigo-frontend/tsconfig.json b/apps/metamigo-frontend/tsconfig.json new file mode 100644 index 0000000..e7ff90f --- /dev/null +++ b/apps/metamigo-frontend/tsconfig.json @@ -0,0 +1,26 @@ +{ + "compilerOptions": { + "lib": ["dom", "dom.iterable", "esnext"], + "allowJs": true, + "skipLibCheck": true, + "strict": true, + "noEmit": true, + "esModuleInterop": true, + "module": "esnext", + "moduleResolution": "bundler", + "resolveJsonModule": true, + "isolatedModules": true, + "jsx": "preserve", + "incremental": true, + "plugins": [ + { + "name": "next" + } + ], + "paths": { + "@/*": ["./*"] + } + }, + "include": ["next-env.d.ts", "**/*.ts", "**/*.tsx", ".next/types/**/*.ts"], + "exclude": ["node_modules"] +} diff --git a/package-lock.json b/package-lock.json index 75135c1..b4f948e 100644 --- a/package-lock.json +++ b/package-lock.json @@ -406,6 +406,407 @@ } } }, + "apps/metamigo-frontend": { + "version": "0.1.0", + "dependencies": { + "@emotion/cache": "^11.11.0", + "@emotion/react": "^11.11.4", + "@emotion/server": "^11.11.0", + "@emotion/styled": "^11.11.0", + "@fontsource/playfair-display": "^5.0.20", + "@fontsource/poppins": "^5.0.8", + "@fontsource/roboto": "^5.0.8", + "@mui/icons-material": "^5", + "@mui/lab": "^5.0.0-alpha.166", + "@mui/material": "^5", + "@mui/x-data-grid-pro": "^6.19.5", + "@mui/x-date-pickers-pro": "^6.19.5", + "date-fns": "^3.3.1", + "leafcutter-common": "*", + "material-ui-popup-state": "^5.0.10", + "mui-chips-input": "^2.1.4", + "next": "14.1.0", + "next-auth": "^4.24.6", + "react": "18.2.0", + "react-cookie": "^7.1.0", + "react-digit-input": "^2.1.0", + "react-dom": "18.2.0", + "react-polyglot": "^0.7.2", + "react-qr-code": "^2.0.12", + "react-timer-hook": "^3.0.7", + "tss-react": "^4.9.4" + }, + "devDependencies": { + "@types/node": "^20", + "@types/react": "^18", + "@types/react-dom": "^18", + "eslint": "^8", + "eslint-config-next": "14.1.1", + "typescript": "^5" + } + }, + "apps/metamigo-frontend/node_modules/@next/env": { + "version": "14.1.1", + "resolved": "https://registry.npmjs.org/@next/env/-/env-14.1.1.tgz", + "integrity": "sha512-7CnQyD5G8shHxQIIg3c7/pSeYFeMhsNbpU/bmvH7ZnDql7mNRgg8O2JZrhrc/soFnfBnKP4/xXNiiSIPn2w8gA==" + }, + "apps/metamigo-frontend/node_modules/@next/eslint-plugin-next": { + "version": "14.1.1", + "resolved": "https://registry.npmjs.org/@next/eslint-plugin-next/-/eslint-plugin-next-14.1.1.tgz", + "integrity": "sha512-NP1WoGFnFLpqqCWgGFjnn/sTwUExdPyjeFKRdQP1X/bL/tjAQ/TXDmYqw6vzGaP5NaZ2u6xzg+N/0nd7fOPOGQ==", + "dev": true, + "dependencies": { + "glob": "10.3.10" + } + }, + "apps/metamigo-frontend/node_modules/@next/swc-darwin-arm64": { + "version": "14.1.1", + "resolved": "https://registry.npmjs.org/@next/swc-darwin-arm64/-/swc-darwin-arm64-14.1.1.tgz", + "integrity": "sha512-yDjSFKQKTIjyT7cFv+DqQfW5jsD+tVxXTckSe1KIouKk75t1qZmj/mV3wzdmFb0XHVGtyRjDMulfVG8uCKemOQ==", + "cpu": [ + "arm64" + ], + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": ">= 10" + } + }, + "apps/metamigo-frontend/node_modules/@next/swc-darwin-x64": { + "version": "14.1.1", + "resolved": "https://registry.npmjs.org/@next/swc-darwin-x64/-/swc-darwin-x64-14.1.1.tgz", + "integrity": "sha512-KCQmBL0CmFmN8D64FHIZVD9I4ugQsDBBEJKiblXGgwn7wBCSe8N4Dx47sdzl4JAg39IkSN5NNrr8AniXLMb3aw==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": ">= 10" + } + }, + "apps/metamigo-frontend/node_modules/@next/swc-linux-arm64-gnu": { + "version": "14.1.1", + "resolved": "https://registry.npmjs.org/@next/swc-linux-arm64-gnu/-/swc-linux-arm64-gnu-14.1.1.tgz", + "integrity": "sha512-YDQfbWyW0JMKhJf/T4eyFr4b3tceTorQ5w2n7I0mNVTFOvu6CGEzfwT3RSAQGTi/FFMTFcuspPec/7dFHuP7Eg==", + "cpu": [ + "arm64" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">= 10" + } + }, + "apps/metamigo-frontend/node_modules/@next/swc-linux-arm64-musl": { + "version": "14.1.1", + "resolved": "https://registry.npmjs.org/@next/swc-linux-arm64-musl/-/swc-linux-arm64-musl-14.1.1.tgz", + "integrity": "sha512-fiuN/OG6sNGRN/bRFxRvV5LyzLB8gaL8cbDH5o3mEiVwfcMzyE5T//ilMmaTrnA8HLMS6hoz4cHOu6Qcp9vxgQ==", + "cpu": [ + "arm64" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">= 10" + } + }, + "apps/metamigo-frontend/node_modules/@next/swc-linux-x64-gnu": { + "version": "14.1.1", + "resolved": "https://registry.npmjs.org/@next/swc-linux-x64-gnu/-/swc-linux-x64-gnu-14.1.1.tgz", + "integrity": "sha512-rv6AAdEXoezjbdfp3ouMuVqeLjE1Bin0AuE6qxE6V9g3Giz5/R3xpocHoAi7CufRR+lnkuUjRBn05SYJ83oKNQ==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">= 10" + } + }, + "apps/metamigo-frontend/node_modules/@next/swc-linux-x64-musl": { + "version": "14.1.1", + "resolved": "https://registry.npmjs.org/@next/swc-linux-x64-musl/-/swc-linux-x64-musl-14.1.1.tgz", + "integrity": "sha512-YAZLGsaNeChSrpz/G7MxO3TIBLaMN8QWMr3X8bt6rCvKovwU7GqQlDu99WdvF33kI8ZahvcdbFsy4jAFzFX7og==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">= 10" + } + }, + "apps/metamigo-frontend/node_modules/@next/swc-win32-arm64-msvc": { + "version": "14.1.1", + "resolved": "https://registry.npmjs.org/@next/swc-win32-arm64-msvc/-/swc-win32-arm64-msvc-14.1.1.tgz", + "integrity": "sha512-1L4mUYPBMvVDMZg1inUYyPvFSduot0g73hgfD9CODgbr4xiTYe0VOMTZzaRqYJYBA9mana0x4eaAaypmWo1r5A==", + "cpu": [ + "arm64" + ], + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">= 10" + } + }, + "apps/metamigo-frontend/node_modules/@next/swc-win32-ia32-msvc": { + "version": "14.1.1", + "resolved": "https://registry.npmjs.org/@next/swc-win32-ia32-msvc/-/swc-win32-ia32-msvc-14.1.1.tgz", + "integrity": "sha512-jvIE9tsuj9vpbbXlR5YxrghRfMuG0Qm/nZ/1KDHc+y6FpnZ/apsgh+G6t15vefU0zp3WSpTMIdXRUsNl/7RSuw==", + "cpu": [ + "ia32" + ], + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">= 10" + } + }, + "apps/metamigo-frontend/node_modules/@next/swc-win32-x64-msvc": { + "version": "14.1.1", + "resolved": "https://registry.npmjs.org/@next/swc-win32-x64-msvc/-/swc-win32-x64-msvc-14.1.1.tgz", + "integrity": "sha512-S6K6EHDU5+1KrBDLko7/c1MNy/Ya73pIAmvKeFwsF4RmBFJSO7/7YeD4FnZ4iBdzE69PpQ4sOMU9ORKeNuxe8A==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">= 10" + } + }, + "apps/metamigo-frontend/node_modules/@typescript-eslint/parser": { + "version": "6.21.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-6.21.0.tgz", + "integrity": "sha512-tbsV1jPne5CkFQCgPBcDOt30ItF7aJoZL997JSF7MhGQqOeT3svWRYxiqlfA5RUdlHN6Fi+EI9bxqbdyAUZjYQ==", + "dev": true, + "dependencies": { + "@typescript-eslint/scope-manager": "6.21.0", + "@typescript-eslint/types": "6.21.0", + "@typescript-eslint/typescript-estree": "6.21.0", + "@typescript-eslint/visitor-keys": "6.21.0", + "debug": "^4.3.4" + }, + "engines": { + "node": "^16.0.0 || >=18.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + }, + "peerDependencies": { + "eslint": "^7.0.0 || ^8.0.0" + }, + "peerDependenciesMeta": { + "typescript": { + "optional": true + } + } + }, + "apps/metamigo-frontend/node_modules/@typescript-eslint/scope-manager": { + "version": "6.21.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-6.21.0.tgz", + "integrity": "sha512-OwLUIWZJry80O99zvqXVEioyniJMa+d2GrqpUTqi5/v5D5rOrppJVBPa0yKCblcigC0/aYAzxxqQ1B+DS2RYsg==", + "dev": true, + "dependencies": { + "@typescript-eslint/types": "6.21.0", + "@typescript-eslint/visitor-keys": "6.21.0" + }, + "engines": { + "node": "^16.0.0 || >=18.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + } + }, + "apps/metamigo-frontend/node_modules/@typescript-eslint/types": { + "version": "6.21.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-6.21.0.tgz", + "integrity": "sha512-1kFmZ1rOm5epu9NZEZm1kckCDGj5UJEf7P1kliH4LKu/RkwpsfqqGmY2OOcUs18lSlQBKLDYBOGxRVtrMN5lpg==", + "dev": true, + "engines": { + "node": "^16.0.0 || >=18.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + } + }, + "apps/metamigo-frontend/node_modules/@typescript-eslint/typescript-estree": { + "version": "6.21.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-6.21.0.tgz", + "integrity": "sha512-6npJTkZcO+y2/kr+z0hc4HwNfrrP4kNYh57ek7yCNlrBjWQ1Y0OS7jiZTkgumrvkX5HkEKXFZkkdFNkaW2wmUQ==", + "dev": true, + "dependencies": { + "@typescript-eslint/types": "6.21.0", + "@typescript-eslint/visitor-keys": "6.21.0", + "debug": "^4.3.4", + "globby": "^11.1.0", + "is-glob": "^4.0.3", + "minimatch": "9.0.3", + "semver": "^7.5.4", + "ts-api-utils": "^1.0.1" + }, + "engines": { + "node": "^16.0.0 || >=18.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + }, + "peerDependenciesMeta": { + "typescript": { + "optional": true + } + } + }, + "apps/metamigo-frontend/node_modules/@typescript-eslint/visitor-keys": { + "version": "6.21.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-6.21.0.tgz", + "integrity": "sha512-JJtkDduxLi9bivAB+cYOVMtbkqdPOhZ+ZI5LC47MIRrDV4Yn2o+ZnW10Nkmr28xRpSpdJ6Sm42Hjf2+REYXm0A==", + "dev": true, + "dependencies": { + "@typescript-eslint/types": "6.21.0", + "eslint-visitor-keys": "^3.4.1" + }, + "engines": { + "node": "^16.0.0 || >=18.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + } + }, + "apps/metamigo-frontend/node_modules/eslint-config-next": { + "version": "14.1.1", + "resolved": "https://registry.npmjs.org/eslint-config-next/-/eslint-config-next-14.1.1.tgz", + "integrity": "sha512-OLyw2oHzwE0M0EODGYMbjksDQKSshQWBzYY+Nkoxoe3+Q5G0lpb9EkekyDk7Foz9BMfotbYShJrgYoBEAVqU4Q==", + "dev": true, + "dependencies": { + "@next/eslint-plugin-next": "14.1.1", + "@rushstack/eslint-patch": "^1.3.3", + "@typescript-eslint/parser": "^5.4.2 || ^6.0.0", + "eslint-import-resolver-node": "^0.3.6", + "eslint-import-resolver-typescript": "^3.5.2", + "eslint-plugin-import": "^2.28.1", + "eslint-plugin-jsx-a11y": "^6.7.1", + "eslint-plugin-react": "^7.33.2", + "eslint-plugin-react-hooks": "^4.5.0 || 5.0.0-canary-7118f5dd7-20230705" + }, + "peerDependencies": { + "eslint": "^7.23.0 || ^8.0.0", + "typescript": ">=3.3.1" + }, + "peerDependenciesMeta": { + "typescript": { + "optional": true + } + } + }, + "apps/metamigo-frontend/node_modules/eslint-visitor-keys": { + "version": "3.4.3", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", + "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", + "dev": true, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "apps/metamigo-frontend/node_modules/next": { + "version": "14.1.1", + "resolved": "https://registry.npmjs.org/next/-/next-14.1.1.tgz", + "integrity": "sha512-McrGJqlGSHeaz2yTRPkEucxQKe5Zq7uPwyeHNmJaZNY4wx9E9QdxmTp310agFRoMuIYgQrCrT3petg13fSVOww==", + "dependencies": { + "@next/env": "14.1.1", + "@swc/helpers": "0.5.2", + "busboy": "1.6.0", + "caniuse-lite": "^1.0.30001579", + "graceful-fs": "^4.2.11", + "postcss": "8.4.31", + "styled-jsx": "5.1.1" + }, + "bin": { + "next": "dist/bin/next" + }, + "engines": { + "node": ">=18.17.0" + }, + "optionalDependencies": { + "@next/swc-darwin-arm64": "14.1.1", + "@next/swc-darwin-x64": "14.1.1", + "@next/swc-linux-arm64-gnu": "14.1.1", + "@next/swc-linux-arm64-musl": "14.1.1", + "@next/swc-linux-x64-gnu": "14.1.1", + "@next/swc-linux-x64-musl": "14.1.1", + "@next/swc-win32-arm64-msvc": "14.1.1", + "@next/swc-win32-ia32-msvc": "14.1.1", + "@next/swc-win32-x64-msvc": "14.1.1" + }, + "peerDependencies": { + "@opentelemetry/api": "^1.1.0", + "react": "^18.2.0", + "react-dom": "^18.2.0", + "sass": "^1.3.0" + }, + "peerDependenciesMeta": { + "@opentelemetry/api": { + "optional": true + }, + "sass": { + "optional": true + } + } + }, + "apps/metamigo-frontend/node_modules/postcss": { + "version": "8.4.31", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.31.tgz", + "integrity": "sha512-PS08Iboia9mts/2ygV3eLpY5ghnUcfLV/EXTOW1E2qYxJKGGBUtNjN76FYHnMs36RmARn41bC0AZmn+rR0OVpQ==", + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/postcss" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "dependencies": { + "nanoid": "^3.3.6", + "picocolors": "^1.0.0", + "source-map-js": "^1.0.2" + }, + "engines": { + "node": "^10 || ^12 || >=14" + } + }, "apps/metamigo-worker": { "name": "@digiresilience/metamigo-worker", "version": "0.2.0", @@ -6585,6 +6986,15 @@ "csstype": "^3.0.2" } }, + "node_modules/@types/react-dom": { + "version": "18.2.19", + "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-18.2.19.tgz", + "integrity": "sha512-aZvQL6uUbIJpjZk4U8JZGbau9KDeAwMfmhyWorxgBkqDIEf6ROjRozcmPIicqsUwPUjbkDfHKgGee1Lq65APcA==", + "dev": true, + "dependencies": { + "@types/react": "*" + } + }, "node_modules/@types/react-transition-group": { "version": "4.4.10", "resolved": "https://registry.npmjs.org/@types/react-transition-group/-/react-transition-group-4.4.10.tgz", @@ -16680,6 +17090,10 @@ "node": ">= 8" } }, + "node_modules/metamigo-frontend": { + "resolved": "apps/metamigo-frontend", + "link": true + }, "node_modules/micromark": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/micromark/-/micromark-4.0.0.tgz",