{"id":26221455,"url":"https://github.com/deepsingh132/aionair","last_synced_at":"2025-04-17T03:50:57.276Z","repository":{"id":243560707,"uuid":"812653592","full_name":"deepsingh132/aionair","owner":"deepsingh132","description":"A cutting-edge AI SaaS platform that enables users to create, discover, and enjoy podcasts with advanced features like text-to-audio conversion with multi-voice AI, podcast thumbnail image generation, and seamless playback. The platform is built using Next.js, TypeScript, Convex, OpenAI, Stripe, Clerk, ShadCN, and Tailwind CSS.","archived":false,"fork":false,"pushed_at":"2025-03-19T22:34:29.000Z","size":14241,"stargazers_count":30,"open_issues_count":0,"forks_count":10,"subscribers_count":1,"default_branch":"main","last_synced_at":"2025-03-29T05:51:19.754Z","etag":null,"topics":["ai","clerk","convex","music","nextjs","openai","player","podcast","react","saas","saas-application","shadcn-ui","stripe","subscriptions","tailwind","tailwindcss","transcribe","transcription","typescript","zod"],"latest_commit_sha":null,"homepage":"https://aionair.vercel.app","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/deepsingh132.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":".github/FUNDING.yml","license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null},"funding":{"github":["deepsingh132"],"patreon":null,"open_collective":null,"ko_fi":null,"tidelift":null,"community_bridge":null,"liberapay":null,"issuehunt":null,"lfx_crowdfunding":null,"polar":null,"buy_me_a_coffee":"deepsingh132","thanks_dev":null,"custom":null}},"created_at":"2024-06-09T14:03:17.000Z","updated_at":"2025-03-19T22:34:32.000Z","dependencies_parsed_at":"2024-06-09T21:29:14.561Z","dependency_job_id":"6164752b-0d0f-41b4-9be9-c4c2ca7dbcfb","html_url":"https://github.com/deepsingh132/aionair","commit_stats":null,"previous_names":["deepsingh132/aionair"],"tags_count":1,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/deepsingh132%2Faionair","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/deepsingh132%2Faionair/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/deepsingh132%2Faionair/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/deepsingh132%2Faionair/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/deepsingh132","download_url":"https://codeload.github.com/deepsingh132/aionair/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":249311807,"owners_count":21249315,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["ai","clerk","convex","music","nextjs","openai","player","podcast","react","saas","saas-application","shadcn-ui","stripe","subscriptions","tailwind","tailwindcss","transcribe","transcription","typescript","zod"],"created_at":"2025-03-12T16:20:25.220Z","updated_at":"2025-04-17T03:50:57.259Z","avatar_url":"https://github.com/deepsingh132.png","language":"TypeScript","funding_links":["https://github.com/sponsors/deepsingh132","https://buymeacoffee.com/deepsingh132","https://www.buymeacoffee.com/deepsingh132"],"categories":[],"sub_categories":[],"readme":"\u003cdiv align=\"center\"\u003e\n  \u003cbr /\u003e\n      \u003cimg src=\"assets/banner.png\" alt=\"Project Banner\" style=\"border-radius:12px; max-width:100%;\"\u003e\n  \u003cbr /\u003e\n\n  \u003cdiv\u003e\n    \u003cimg src=\"https://img.shields.io/badge/-Typescript-black?style=for-the-badge\u0026logoColor=white\u0026logo=typescript\u0026color=3178C6\" alt=\"typescript\" /\u003e\n    \u003cimg src=\"https://img.shields.io/badge/-Next_._JS-black?style=for-the-badge\u0026logoColor=white\u0026logo=nextdotjs\u0026color=000000\" alt=\"nextdotjs\" /\u003e\n    \u003cimg src=\"https://img.shields.io/badge/-Tailwind_CSS-black?style=for-the-badge\u0026logoColor=white\u0026logo=tailwindcss\u0026color=06B6D4\" alt=\"tailwindcss\" /\u003e\n    \u003cimg src=\"https://img.shields.io/badge/-OpenAI-black?style=for-the-badge\u0026logoColor=white\u0026logo=openai\u0026color=412991\" alt=\"openai\" /\u003e\n    \u003cimg src=\"https://img.shields.io/badge/-Convex-black?style=for-the-badge\u0026logoColor=white\u0026logo=convex\u0026color=FFD700\" alt=\"convex\" /\u003e\n    \u003cimg src=\"https://img.shields.io/badge/-Clerk-black?style=for-the-badge\u0026logoColor=white\u0026logo=clerk\u0026color=000000\" alt=\"clerk\" /\u003e\n    \u003cimg src=\"https://img.shields.io/badge/shadcn%2Fui-000000?style=for-the-badge\u0026logo=shadcnui\u0026logoColor=white\" alt=\"shadcn\" /\u003e\n    \u003cimg src=\"https://img.shields.io/badge/zod-%233068b7.svg?style=for-the-badge\u0026logo=zod\u0026logoColor=white)\" alt=\"zod\"\u003e\n\n  \u003c/div\u003e\n\n  \u003ch1 align=\"center\"\u003eOnAir.ai Podcast Platform\u003c/h1\u003e\n\n  ![GitHub deployments](https://img.shields.io/github/deployments/deepsingh132/aionair/production?label=build)\n  [![Docker Image CI](https://github.com/deepsingh132/aionair/actions/workflows/docker-image.yml/badge.svg)](https://github.com/deepsingh132/aionair/actions/workflows/docker-image.yml)\n  [![Node.js CI](https://github.com/deepsingh132/aionair/actions/workflows/node.js.yml/badge.svg)](https://github.com/deepsingh132/aionair/actions/workflows/node.js.yml)\n  [![GitHub license](https://img.shields.io/badge/license-MIT-blue.svg)](https://github.com/facebook/react/blob/main/LICENSE)\n  [![PRs Welcome](https://img.shields.io/badge/PRs-welcome-brightgreen.svg)](https://reactjs.org/docs/how-to-contribute.html#your-first-pull-request)\n\n  [![\"Buy Me A Coffee\"](https://www.buymeacoffee.com/assets/img/custom_images/yellow_img.png)](https://www.buymeacoffee.com/deepsingh132)\n\n\n\n\u003c/div\u003e\n\n## 📋 \u003ca name=\"table\"\u003eTable of Contents\u003c/a\u003e\n\n1. 🤖 [Introduction](#introduction)\n2. ⚙️ [Tech Stack](#tech-stack)\n3. 🔋 [Features](#features)\n4. 📸 [Screenshots](#screenshots)\n5. 🤸 [Getting Started](#getting-started)\n6. 🐳 [Docker Instructions](#docker)\n7. 📄 [License](#license)\n8. 📞 [Contact](#contact)\n\n\n## \u003ca name=\"introduction\"\u003e🤖 Introduction\u003c/a\u003e\n\nA cutting-edge AI SaaS platform that enables users to create, discover, and enjoy podcasts with advanced features like text-to-audio conversion with multi-voice AI, podcast thumbnail Image generation and seamless playback. The platform is built using Next.js, TypeScript, Convex, OpenAI, Clerk, ShadCN, and Tailwind CSS. It offers a modern home page, podcast discovery page, search functionality, podcast creation page, profile page, podcast details page, and a responsive design for a seamless user experience.\n\n## \u003ca name=\"tech-stack\"\u003e⚙️ Tech Stack\u003c/a\u003e\n\n- Next.js\n- TypeScript\n- Convex\n- OpenAI\n- Stripe (for payments)\n- Clerk\n- ShadCN\n- Tailwind CSS\n- Zod (for validation)\n\n## \u003ca name=\"features\"\u003e🔋 Features\u003c/a\u003e\n\n👉 **Advanced Authentication**: Offers secure and dependable user login and registration functionalities.\n\n👉 **Contemporary Home Page**: Highlights trending podcasts with a persistent player for uninterrupted listening.\n\n👉 **Podcast Discovery Page**: A dedicated section for users to explore a wide range of new and popular podcasts.\n\n👉 **Comprehensive Search Functionality**: Empowers users to effortlessly find podcasts using various filters and criteria.\n\n👉 **Podcast Creation Page**: Facilitates podcast creation with text-to-speech conversion, AI-generated images, and preview options.\n\n👉 **Multi-Voice AI Capability**: Provides multiple AI-generated voice options for creating dynamic and engaging podcasts.\n\n👉 **User Profile Page**: Allows users to view and manage their created podcasts, including options to delete them.\n\n👉 **Detailed Podcast Page**: Presents in-depth information about each podcast, including creator details, listener statistics, and transcripts.\n\n👉 **Enhanced Podcast Player**: Includes features like rewind/fast forward controls and mute/unmute functionality for an optimal listening experience.\n\n👉 **Responsive Design**: Ensures the platform looks great and works seamlessly on all devices and screen sizes.\n\nand many more, including code architecture and reusability\n\n## \u003ca name=\"screenshots\"\u003e📸 Screenshots\u003c/a\u003e\n\n| Homepage |\n| :-----------: |\n|  \u003cimg src=\"assets/screenshots/home.png\" alt=\"Home Page\" style=\"border-radius:12px; max-width:100%;\"\u003e  |\n| Discover Page |\n| \u003cimg src=\"assets/screenshots/discover.png\" alt=\"Discover Page\" style=\"border-radius:12px; max-width:100%;\"\u003e   |\n| Create Podcast Page |\n| \u003cimg src=\"assets/screenshots/create.png\" alt=\"Create Podcast Page\" style=\"border-radius:12px; max-width:100%;\"\u003e |\n| Podcast Details Page |\n|  \u003cimg src=\"assets/screenshots/podcast.png\" alt=\"Podcast Details Page\" style=\"border-radius:12px; max-width:100%;\"\u003e |\n| Profile Page |\n|  \u003cimg src=\"assets/screenshots/profile.png\" alt=\"Profile Page\" style=\"border-radius:12px; max-width:100%;\"\u003e |\n| Plans Page |\n|  \u003cimg src=\"assets/screenshots/plans.png\" alt=\"Plans Page\" style=\"border-radius:12px; max-width:100%;\"\u003e |\n| Payment / Stripe Checkout Page |\n|  \u003cimg src=\"assets/screenshots/stripe.png\" alt=\"Payment Page\" style=\"border-radius:12px; max-width:100%;\"\u003e |\n| Usage Page |\n|  \u003cimg src=\"assets/screenshots/usage.png\" alt=\"Usage Page\" style=\"border-radius:12px; max-width:100%;\"\u003e |\n\n\n## \u003ca name=\"getting-started\"\u003e🤸 Getting Started\u003c/a\u003e\n\nFollow these steps to set up the project locally on your machine.\n\n**Prerequisites**\n\nMake sure you have the following installed on your machine:\n\n- [Git](https://git-scm.com/)\n- [Node.js](https://nodejs.org/en)\n- [npm](https://www.npmjs.com/) (Node Package Manager)\n\n**Cloning the Repository**\n\n```bash\ngit clone https://github.com/deepsingh132/aionair.git\ncd aionair\n```\n\n**Installation**\n\nInstall the project dependencies using npm:\n\n```bash\nnpm install\n```\n\n**Set Up Environment Variables**\n\nCreate a new file named `.env` in the root of your project and add the following content to your local env file and on the convex dashboard:\n\n```env\nCONVEX_DEPLOYMENT=\nNEXT_PUBLIC_CONVEX_URL=\nNEXT_PUBLIC_CLERK_PUBLISHABLE_KEY=\nCLERK_SECRET_KEY=\nNEXT_PUBLIC_CLERK_SIGN_IN_URL='/sign-in'\nNEXT_PUBLIC_CLERK_SIGN_UP_URL='/sign-up'\nOPENAI_API_KEY=\nNEXT_PUBLIC_STRIPE_PUBLISHABLE_KEY=\nSTRIPE_SECRET_KEY=\n```\n\nReplace the placeholder values with your actual Convex \u0026 Clerk credentials. You can obtain these credentials by signing up on the [Convex](https://www.convex.dev/), [Clerk](https://clerk.com/),\n[OpenAI](https://platform.openai.com/) and [Stripe](https://stripe.com/) websites.\n\n**Running the Project**\n\n```bash\nnpm run dev\n```\n\nOpen [http://localhost:3000](http://localhost:3000) in your browser to view the project.\n\n**Testing Stripe Payments**\n\nTo test the Stripe payments/subscriptions functionality, you can use the following test card details:\n\n- **Card Number**: 4242 4242 4242 4242\n- **Expiry Date**: Any future date\n- **CVC/CVV**: Any 3-digit number\n- **Cardholder Name**: Any name\n- **Address**: Any address (e.g., 123 Main Street)\n- **ZIP Code**: Any 5-digit number\n\nYou can also use the [Stripe Test Cards](https://docs.stripe.com/testing#cards) for more test card details.\n\n## \u003ca name=\"docker\"\u003e🐳 Docker Instructions\u003c/a\u003e\n\nYou can run this project using Docker with the latest image from Docker Hub. Make sure you have Docker installed and running on your machine.\nFollow these steps:\n\n1. Pull the latest image from Docker Hub.\n\n    ```bash\n    docker pull deepsingh132/aionair:latest\n    ```\n\n2. Run the Docker image with the following command:\n\n    ```bash\n    docker run --env-file .YOURENVFILE -p 3000:3000 deepsingh132/aionair:latest\n    ```\n\n3. Open [http://localhost:3000](http://localhost:3000) in your browser to view the project.\n\n## \u003ca name=\"license\"\u003e📚 License\u003c/a\u003e\n\nThis project is licensed under the [MIT License](https://opensource.org/licenses/MIT) - see the [LICENSE](LICENSE) file for details.\n\n## \u003ca name=\"contact\"\u003e📞 Contact\u003c/a\u003e\n\nIf you have any queries or feedback, please feel free to reach out to me at my [email](mailto:mandeeparora132@gmail.com) or connect with me on [LinkedIn](https://www.linkedin.com/in/deepsingh132/).\n\n\u003cbr /\u003e\n\u003cbr /\u003e\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdeepsingh132%2Faionair","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fdeepsingh132%2Faionair","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdeepsingh132%2Faionair/lists"}