{"id":16139936,"url":"https://github.com/ladunjexa/nextjs14-devoverflow","last_synced_at":"2025-04-06T22:11:20.607Z","repository":{"id":207210401,"uuid":"711371755","full_name":"ladunjexa/nextjs14-devoverflow","owner":"ladunjexa","description":"🧠 DevOverflow is a complex Next.js 14 app that exhibits Q\u0026A platform for developers to ask questions, share knowledge, and learn from each other.","archived":false,"fork":false,"pushed_at":"2025-01-18T18:59:36.000Z","size":3308,"stargazers_count":70,"open_issues_count":2,"forks_count":28,"subscribers_count":4,"default_branch":"main","last_synced_at":"2025-03-30T21:09:27.148Z","etag":null,"topics":["clerk","jsearch-api","mongodb","openai-api","shadcn-ui","stackoverflow-clone","tinymce","typescripted-nextjs14"],"latest_commit_sha":null,"homepage":"https://nextjs14-devoverflow.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/ladunjexa.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"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}},"created_at":"2023-10-29T03:39:24.000Z","updated_at":"2025-03-11T05:19:02.000Z","dependencies_parsed_at":"2023-11-14T16:57:48.630Z","dependency_job_id":"0ed81da1-3d11-44e4-bdb4-6f19bfaa9407","html_url":"https://github.com/ladunjexa/nextjs14-devoverflow","commit_stats":{"total_commits":96,"total_committers":3,"mean_commits":32.0,"dds":0.25,"last_synced_commit":"48fd2659cbf058a7eefe1cf02dde2341556a4dc8"},"previous_names":["ladunjexa/nextjs14-devoverflow"],"tags_count":1,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ladunjexa%2Fnextjs14-devoverflow","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ladunjexa%2Fnextjs14-devoverflow/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ladunjexa%2Fnextjs14-devoverflow/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ladunjexa%2Fnextjs14-devoverflow/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/ladunjexa","download_url":"https://codeload.github.com/ladunjexa/nextjs14-devoverflow/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":247557767,"owners_count":20958047,"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":["clerk","jsearch-api","mongodb","openai-api","shadcn-ui","stackoverflow-clone","tinymce","typescripted-nextjs14"],"created_at":"2024-10-09T23:50:12.093Z","updated_at":"2025-04-06T22:11:20.574Z","avatar_url":"https://github.com/ladunjexa.png","language":"TypeScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Next.js 14 DevOverflow\n\n\u003c!-- GitHub badges --\u003e\n\n[![Latest release](https://img.shields.io/github/v/release/ladunjexa/nextjs14-devoverflow?label=Latest%20release\u0026style=social)](https://github.com/ladunjexa/nextjs14-devoverflow/releases/tag/v0.1.0)\n[![Stars](https://img.shields.io/github/stars/ladunjexa/nextjs14-devoverflow?style=social)](https://github.com/ladunjexa/nextjs14-devoverflow/stargazers)\n[![Fork](https://img.shields.io/github/forks/ladunjexa/nextjs14-devoverflow?style=social)](https://github.com/ladunjexa/nextjs14-devoverflow/forks)\n[![GitHub commits](https://img.shields.io/github/commit-activity/t/ladunjexa/nextjs14-devoverflow?style=social\u0026logo=github)](https://github.com/ladunjexa/nextjs14-devoverflow/commits)\n[![Pull requests](https://img.shields.io/github/issues-pr/ladunjexa/nextjs14-devoverflow?style=social\u0026logo=github)](https://github.com/ladunjexa/nextjs14-devoverflow/pulls)\n\n![demo](https://i.ibb.co/x7FChRP/Thumbnail.jpg)\n\n[![ladunjexa](https://custom-icon-badges.demolab.com/badge/made%20by%20-ladunjexa-556bf2?logo=github\u0026logoColor=white\u0026labelColor=101827)](https://github.com/luadnjexa)\n[![License](https://img.shields.io/github/license/ladunjexa/nextjs14-devoverflow?color=dddddd\u0026labelColor=000000)](https://github.com/ladunjexa/nextjs14-devoverflow/blob/main/LICENSE)\n[![Top Language](https://img.shields.io/github/languages/top/ladunjexa/nextjs14-devoverflow?logo=github\u0026logoColor=%23007ACC\u0026label=TypeScript)](https://www.typescriptlang.org/)\n[![Contributors](https://img.shields.io/github/contributors/ladunjexa/nextjs14-devoverflow?style=flat\u0026color=orange\u0026label=Contributors)](https://github.com/ladunjexa/nextjs14-devoverflow/graphs/contributors)\n![Release](https://img.shields.io/github/release/ladunjexa/nextjs14-devoverflow.svg)\n![PRs](https://img.shields.io/badge/PRs-welcome-ff69b4.svg?style=shields)\n![deployment](https://img.shields.io/github/deployments/ladunjexa/nextjs14-devoverflow/Production?logo=vercel\u0026label=Website)\n[![Known Vulnerabilities](https://snyk.io/test/github/ladunjexa/nextjs14-devoverflow/badge.svg)](https://snyk.io/test/github/ladunjexa/nextjs14-devoverflow)\n\n## 🌐 Live Demo\n\nExplore the live demonstration of the project: [nextjs14-devoverflow](https://nextjs14-devoverflow.vercel.app/)\n\n## 📝 Description\n\n**DevOverflow** is a complex Q\u0026A platform for developers to ask questions, share knowledge, and learn from each other. It is built with Next.js, Tailwind CSS, Clerk, MongoDB, and more.\n\n\u003cdetails\u003e\u003csummary\u003e\u003cb\u003eFolder Structure\u003c/b\u003e\u003c/summary\u003e\n\n```bash\nnextjs14-devoverflow/\n├── app/\n├   ├── favicon.ico\n├   ├── globals.css\n├   ├── layout.tsx\n├   ├── (auth)/\n├   ├   ├── onboarding/\n├   ├   ├   └── page.tsx\n├   ├   ├── sign-in/[[...sign-in]]/\n├   ├   ├   └── page.tsx\n├   ├   ├── sign-up/[[...sign-up]]/\n├   ├   ├   └── page.tsx\n├   ├   └── layout.tsx\n├   ├── (root)/\n├   ├   ├── layout.tsx\n├   ├   ├── (home)/\n├   ├   ├   ├── loading.tsx\n├   ├   ├   └── page.tsx\n├   ├   ├── ask-question/\n├   ├   ├   └── page.tsx\n├   ├   ├── collection/\n├   ├   ├   ├── loading.tsx\n├   ├   ├   └── page.tsx\n├   ├   ├── community/\n├   ├   ├   ├── loading.tsx\n├   ├   ├   └── page.tsx\n├   ├   ├── edit-answer/\n├   ├   ├   └── [id]/\n├   ├   ├       └── page.tsx\n├   ├   ├── jobs/\n├   ├   ├   ├── loading.tsx\n├   ├   ├   └── page.tsx\n├   ├   ├── profile/\n├   ├   ├   ├── [id]/\n├   ├   ├   ├   ├── loading.tsx\n├   ├   ├   ├   └── page.tsx\n├   ├   ├   └── edit/\n├   ├   ├       └── page.tsx\n├   ├   ├── question/\n├   ├   ├   ├── [id]/\n├   ├   ├   ├   └── page.tsx\n├   ├   ├   └── edit/\n├   ├   ├       └── [id]/\n├   ├   ├           └── page.tsx\n├   ├   └── tags/\n├   ├       ├── [id]/\n├   ├       ├   ├── loading.tsx\n├   ├       ├   └── page.tsx\n├   ├       ├── page.tsx\n├   ├       └── loading.tsx\n├   └── api/\n├       ├── openai/\n├       ├   └── route.ts\n├       ├── rapidapi/\n├       ├   └── route.ts\n├       └── webhook/clerk/\n├              └── route.ts\n├── components/\n├   ├── cards/\n├   ├   ├── AnswerCard.tsx\n├   ├   ├── JobCard.tsx\n├   ├   ├── QuestionCard.tsx\n├   ├   └── UserCard.tsx\n├   ├── forms/\n├   ├   ├── Answer.tsx\n├   ├   ├── Profile.tsx\n├   ├   └── Question.tsx\n├   ├── jobs/\n├   ├   └── JobBadge.tsx\n├   ├── shared/\n├   ├   ├── AllAnswers.tsx\n├   ├   ├── AnswersTab.tsx\n├   ├   ├── EditDeleteAction.tsx\n├   ├   ├── Filter.tsx\n├   ├   ├── Filters.tsx\n├   ├   ├── LeftSidebar.tsx\n├   ├   ├── Metric.tsx\n├   ├   ├── NoResult.tsx\n├   ├   ├── Pagination.tsx\n├   ├   ├── ParseHTML.tsx\n├   ├   ├── ProfileLink.tsx\n├   ├   ├── QuestionsTab.tsx\n├   ├   ├── RenderTag.tsx\n├   ├   ├── RightSidebar.tsx\n├   ├   ├── Stats.tsx\n├   ├   ├── Switcher.tsx\n├   ├   ├── Votes.tsx\n├   ├   ├── navbar/\n├   ├   ├   ├── Navbar.tsx\n├   ├   ├   ├── Mobile.tsx\n├   ├   ├   └── Theme.tsx\n├   ├   └── search/\n├   ├       ├── GlobalFilters.tsx\n├   ├       ├── GlobalResult.tsx\n├   ├       ├── GlobalSearch.tsx\n├   ├       └── LocalSearchbar.tsx\n├   └── ui/ (generated by shadcn-ui)\n├       ├── badge.tsx\n├       ├── button.tsx\n├       ├── form.tsx\n├       ├── input.tsx\n├       ├── label.tsx\n├       ├── menubar.tsx\n├       ├── select.tsx\n├       ├── sheet.tsx\n├       ├── skeleton.tsx\n├       ├── switch.tsx\n├       ├── tabs.tsx\n├       ├── textarea.tsx\n├       ├── toast.tsx\n├       ├── toaster.tsx\n├       └── use-toast.ts\n├── constants/\n├   ├── filters.ts\n├   └── index.ts\n├── content/\n├   ├── countries.json\n├   └── jsearch.json\n├── context/\n├   └── ThemeProvider.ts\n├── datbase/\n├   ├── answer.model.ts\n├   ├── interaction.model.ts\n├   ├── question.model.ts\n├   ├── tag.model.ts\n├   └── user.model.ts\n├── lib/\n├   ├── mongoose.ts\n├   ├── utils.ts\n├   ├── validations.ts\n├   └── actions/\n├       ├── answer.action.ts\n├       ├── general.action.ts\n├       ├── interaction.action.ts\n├       ├── job.action.ts\n├       ├── question.action.ts\n├       ├── tag.action.ts\n├       ├── user.action.ts\n├       └── shared.types.d.ts\n├── public/\n├   ├── next.svg\n├   ├── vercel.svg\n├   └── assets/\n├       ├── icons/[[...]].svg\n├       └── images/[[...]].{svg,png}\n├── styles/\n├   ├── prism.css\n├   └── theme.css\n├── types/\n├   └── index.d.ts\n├── .eslintrc.json\n├── .gitignore\n├── README.md\n├── components.json\n├── middleware.ts\n├── next.config.js\n├── package.json\n├── postcss.config.js\n├── tailwind.config.ts\n└── tsconfig.ts\n```\n\n\u003c/details\u003e\n\n## 📖 Table of Contents\n\n\u003cdetails\u003e\u003csummary\u003eTable of Contents\u003c/summary\u003e\n\n- [Live Demo](#-live-demo)\n- [Description](#-description)\n- [Technologies Used](#-technologies-used)\n- [Get Started](#-get-started)\n  - [Prerequisites](#-prerequisites)\n  - [Installation and Run Locally](#-installation-and-run-locally)\n  - [Scripts](#-scripts)\n- [Environment Variables](#-environment-variables)\n- [Deployment](#-deployment)\n  - [Deploy to production (manual)](#-deploy-to-production-manual)\n  - [Deploy on Vercel (recommended)](#-deploy-on-vercel-recommended)\n  - [Deploy on Netlify](#-deploy-on-netlify)\n- [Contributing](#-contributing)\n  - [Bug / Feature Request](#-bug--feature-request)\n- [Acknowledgements](#-acknowledgements)\n- [References](#-references)\n- [Contact Us](#-contact-us)\n- [License](#-license)\n\n\u003c/details\u003e\n\n## ✨ Technologies Used\n\n\u003cdetails\u003e\u003csummary\u003e\u003cb\u003eDevOverflow\u003c/b\u003e is built using the following technologies:\u003c/summary\u003e\n\n- [TypeScript](https://www.typescriptlang.org/): TypeScript is a typed superset of JavaScript that compiles to plain JavaScript.\n- [Next.js](https://nextjs.org/): Next.js is a React framework for building server-side rendered and statically generated web applications.\n- [Tailwind CSS](https://tailwindcss.com/): Tailwind CSS is a utility-first CSS framework for rapidly building custom user interfaces.\n- [ESLint](https://eslint.org/): ESLint is a static code analysis tool for identifying problematic patterns found in JavaScript code.\n- [Prettier](https://prettier.io/): Prettier is an opinionated code formatter.\n- [Clerk](https://clerk.dev/): Clerk is a developer-first authentication API that handles all the logic for user sign up, sign in, and more.\n- [Shadcn-UI](https://ui.shadcn.com/): Shadcn UI is a React UI library that helps developers rapidly build modern web applications.\n- [TinyMCE](https://www.tiny.cloud/): TinyMCE is the world's most popular JavaScript library for rich text editing.\n- [MongoDB](https://www.mongodb.com/): MongoDB is a general purpose, document-based, distributed database built for modern application developers and for the cloud era.\n- [Mongoose](https://mongoosejs.com/): Mongoose is a MongoDB object modeling tool designed to work in an asynchronous environment.\n- [Prism.js](https://prismjs.com/): Prism is a lightweight, extensible syntax highlighter, built with modern web standards in mind.\n- [Query String](https://www.npmjs.com/package/query-string): Parse and stringify URL query strings.\n- [Svix](https://svix.com/): Svix is a webhook proxy that allows you to receive webhooks locally.\n- [Zod](https://zod.dev/): Zod is a TypeScript-first schema declaration and validation library.\n- [Vercel](https://vercel.com/): Vercel is a cloud platform for frontend developers, providing the frameworks, workflows, and infrastructure to build a faster, more personalized Web.\n\n\u003c/details\u003e\u003cbr/\u003e\n\n[![Technologies Used](https://skillicons.dev/icons?i=ts,nextjs,tailwind,mongodb,vercel)](https://skillicons.dev)\n\n## 🧰 Get Started\n\nTo get this project up and running in your development environment, follow these step-by-step instructions.\n\n### 📋 Prerequisites\n\nIn order to install and run this project locally, you would need to have the following installed on your local machine.\n\n- [Node.js](https://nodejs.org/en/)\n- [NPM](https://www.npmjs.com/get-npm)\n- [Git](https://git-scm.com/downloads)\n\n### ⚙️ Installation and Run Locally\n\n**Step 0:**\n\n\u003e [!IMPORTANT]\n\u003e - the application uses Clerk for Authentication and User Management, therefore, you need to create Clerk account [here](https://clerk.dev/) and sets the `CLERK_PUBLISHABLE_KEY` and `CLERK_SECRET_KEY` environment variables in `.env` file. Also, the different URLs for the Clerk sign-in, sign-up, after sign-in and after sign-up pages.\n\u003e - the application uses a MongoDB database, therefore, you need to create a database and connect it to the application, for this, change the `MONGODB_URL` environment variable in `.env` file located in `server` folder.\n\u003e - the application uses TinyMCE, therefore, you need to create TinyMCE account [here](https://www.tiny.cloud/) and sets the `NEXT_PUBLIC_TINYMCE_API_KEY` environment variable in `.env` file.\n\u003e - the application uses OpenAI API, therefore, you need to create OpenAI account [here](https://openai.com/) and sets the `OPENAI_API_KEY` environment variable in `.env` file.\n\u003e - the application uses RapidAPI, therefore, you need to create RapidAPI account [here](https://rapidapi.com/), subscribe to the [JSearch API](https://rapidapi.com/letscrape-6bRBa3QguO5/api/jsearch/) and sets the `RAPIDAPI_API_KEY` environment variable in `.env` file.\n\nAfter following all the instructions above, we'll want to create a new webhook on Clerk. To do this, go to the [Clerk Dashboard](https://dashboard.clerk.dev/), click on the \"Webhooks\" tab, and then click \"Add Endpoint\". For the Endpoint URL, enter `http://\u003cPASTE-YOUR-LINK-HERE\u003e/api/webhook/clerk`. For the events, select the \"user\". Then click \"Create\" to create the webhook. get the signing secret and set it as `CLERK_WEBHOOK_SECRET` environment variable in `.env` file.\n\n**Step 1:**\n\nDownload or clone this repo by using the link below:\n\n```bash\ngit clone https://github.com/ladunjexa/nextjs14-devoverflow.git\n```\n\n**Step 2:**\n\nExecute the following command in the root directory of the downloaded repo in order to install dependencies:\n\n```bash\nnpm install\n```\n\n**Step 3:**\n\nExecute the following command in order to run the development server locally:\n\n```bash\nnpm run dev\n```\n\n**Step 4:**\n\nOpen [http://localhost:3000](http://localhost:3000) with your browser to see the result.\n\n### 📜 Scripts\n\nAll scripts are defined in the `package.json` file. Here is a list of all scripts:\n\n| Script          | Action                                      |\n| :-------------- | :------------------------------------------ |\n| `npm install`   | Installs dependencies                       |\n| `npm run dev`   | Starts local dev server at `localhost:3000` |\n| `npm run build` | Build your production site to `./dist/`     |\n| `npm run start` | Start your production site locally          |\n| `npm run lint`  | Run ESLint                                  |\n\n## 🔒 Environment Variables\n\nEnvironment variables[^12] can be used for configuration. They must be set before running the app.\n\n\u003e [Environment variables](https://en.wikipedia.org/wiki/Environment_variable) are variables that are set in the operating system or shell, typically used to configure programs.\n\n**DevOverflow** uses [Clerk](https://clerk.com), [TinyMCE](https://uploadthing.com/), [RapidAPI](https://rapidapi.com), [OpenAI API](https://openai.com/blog/openai-api) and [MongoDB](https://mongodb.com) as external services. You need to create an account on each of these services and get the required credentials to run the app.\n\nCreate a `.env` file in the root directory of the project and add the following environment variables:\n\n```env\nNEXT_PUBLIC_CLERK_PUBLISHABLE_KEY=\u003cCLERK_PUBLISHABLE_KEY\u003e\nCLERK_SECRET_KEY=\u003cCLERK_SECRET_KEY\u003e\nNEXT_CLERK_WEBHOOK_SECRET=\u003cCLERK_WEBHOOK_SECRET\u003e\n\nNEXT_PUBLIC_CLERK_SIGN_IN_URL=/sign-in\nNEXT_PUBLIC_CLERK_SIGN_UP_URL=/sign-up\nNEXT_PUBLIC_CLERK_AFTER_SIGN_IN_URL=/\nNEXT_PUBLIC_CLERK_AFTER_SIGN_UP_URL=/onboarding\n\nNEXT_PUBLIC_TINY_MCE_API_KEY=\u003cYOUR_TINY_MCE_API_KEY\u003e\n\nMONGODB_URL=\u003cYOUR_MONGODB_URL\u003e\n\nNEXT_PUBLIC_SERVER_URL=\u003cYOUR_SERVER_URL\u003e\n\nOPENAI_API_KEY=\u003cYOUR_OPENAI_API_KEY\u003e\n\nRAPID_API_KEY=\u003cYOUR_RAPID_API_KEY\u003e\n```\n\n## 🚀 Deployment\n\n#### Deploy to production (manual)\n\nYou can create an optimized production build with the following command:\n\n```bash\nnpm run build\n```\n\n#### Deploy on Vercel (recommended)\n\nThe easiest way to deploy this Next.js app is to use the [Vercel Platform](https://vercel.com/new?utm_medium=default-template\u0026filter=next.js\u0026utm_source=create-next-app\u0026utm_campaign=create-next-app-readme).\n\n[![Deploy with Vercel](https://vercel.com/button)](https://vercel.com/new/clone?repository-url=https%3A%2F%2Fgithub.com%2Fladunjexa%2Fnextjs14-devoverflow)\n\n#### Deploy on Netlify\n\nYou can also deploy this Next.js app with [Netlify](https://www.netlify.com/).\n\n[![Deploy with Netlify](https://www.netlify.com/img/deploy/button.svg)](https://app.netlify.com/start/deploy?repository=https://github.com/ladunjexa/nextjs14-devoverflow)\n\nCheck out [Next.js deployment documentation](https://nextjs.org/docs/deployment) for more details.\n\n## 🔧 Contributing\n\n[![contributors](https://contrib.rocks/image?repo=ladunjexa/nextjs14-devoverflow)](https://github.com/ladunjexa/nextjs14-devoverflow/graphs/contributors)\n\nContributions are what make the open source community such an amazing place to learn, inspire, and create. Any contributions you make are **greatly appreciated**.\n\nTo fix a bug or enhance an existing module, follow these steps:\n\n1. Fork the repo\n2. Create a new branch (`git checkout -b improve-feature`)\n3. Make the appropriate changes in the files\n4. Commit your changes (`git commit -am 'Improve feature'`)\n5. Push to the branch (`git push origin improve-feature`)\n6. Create a Pull Request 🎉\n\n### 📩 Bug / Feature Request\n\nIf you find a bug (failure of a module to execute its intended function), kindly open an issue [here](https://github.com/ladunjexa/nextjs14-devoverflow/issues/new) by including the issue with a title and clear description.\n\nIf you'd like to request a new function, feel free to do so by opening an issue [here](https://github.com/ladunjexa/nextjs14-devoverflow/issues/new). Please include sample queries and their corresponding results.\n\n## 💎 Acknowledgements\n\nI'd like to express my gratitude to the following people who helped me with this project and made it possible:\n\n- [Clerk](https://clerk.dev/)\n- [MongoDB](https://mongodb.com)\n- [Mongoose](https://mongoosejs.com/)\n- [Zod](https://zod.dev/)\n- [Shadcn](https://shadcn.com/)\n- [Tailwind CSS](https://tailwindcss.com/)\n- [Svix](https://svix.com/)\n- [TinyMCE](https://www.tiny.cloud/)\n- [OpenAI API](https://openai.com/blog/openai-api)\n- [RapidAPI](https://rapidapi.com/)\n- [Vercel](https://vercel.com/)\n- [JavaScript Mastery](https://www.jsmastery.pro/)\n\n## 📚 References\n\nJSMastery. (2023). [Ultimate Next.js 14 Course | Become a top 1% Next.js 14 developer](https://www.jsmastery.pro/ultimate-next-course). E-Learning.\n\n## 📞 Contact Us\n\n[![Telegram](https://img.shields.io/badge/Telegram-@ladunjexa-2CA5E0?style=social\u0026logo=telegram\u0026logoColor=000000)](https://t.me/ladunjexa)\n[![LinkedIn](https://img.shields.io/badge/LinkedIn-ladunjexa-blue?style=flat\u0026logo=linkedin\u0026logoColor=b0c0c0\u0026labelColor=363D44)](https://www.linkedin.com/in/lironabutbul)\n[![Instagram](https://img.shields.io/badge/Instagram-ladunjexa-grey?style=flat\u0026logo=instagram\u0026logoColor=b0c0c0\u0026labelColor=8134af)](https://www.instagram.com/ladunjexa)\n[![Discord](https://img.shields.io/badge/Discord-ladunjexa-7289da?style=flat\u0026logo=discord\u0026logoColor=b0c0c0\u0026labelColor=2c2f33)](https://discord.com/users/827996364331810816)\n\n\u003c!-- [![Twitter](https://img.shields.io/twitter/follow/ladunjexa.svg?style=social)](https://twitter.com/intent/follow?screen_name=ladunjexa) --\u003e\n\n## 📋 License\n\n**DevOverflow** is open source software [licensed as MIT](https://opensource.org/license/mit/) and is free to use — See [LICENSE](https://github.com/ladunjexa/nextjs14-devoverflow/blob/main/LICENSE) for more details.\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fladunjexa%2Fnextjs14-devoverflow","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fladunjexa%2Fnextjs14-devoverflow","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fladunjexa%2Fnextjs14-devoverflow/lists"}