{"id":25908004,"url":"https://github.com/nima-moradi1/newgram","last_synced_at":"2026-04-09T08:19:10.937Z","repository":{"id":248505417,"uuid":"828876055","full_name":"Nima-Moradi1/NewGram","owner":"Nima-Moradi1","description":"NewGram is a social media app which you can post your favorites, like , dislike , bookmark and even explore and follow others !","archived":false,"fork":false,"pushed_at":"2024-07-15T11:26:21.000Z","size":2504,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"main","last_synced_at":"2024-07-16T12:21:12.674Z","etag":null,"topics":["appwrite-auth","appwrite-database","appwrite-storage","rhf","shadcn-ui","tailwindcss","tanstack-react-query","typescript","vitejs","zod"],"latest_commit_sha":null,"homepage":"","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/Nima-Moradi1.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"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":"2024-07-15T09:55:59.000Z","updated_at":"2024-07-15T11:26:25.000Z","dependencies_parsed_at":"2024-07-15T12:02:49.260Z","dependency_job_id":"20210204-5d0a-46d9-8969-ae4e02b82623","html_url":"https://github.com/Nima-Moradi1/NewGram","commit_stats":null,"previous_names":["nima-moradi1/newgram"],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Nima-Moradi1%2FNewGram","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Nima-Moradi1%2FNewGram/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Nima-Moradi1%2FNewGram/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Nima-Moradi1%2FNewGram/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/Nima-Moradi1","download_url":"https://codeload.github.com/Nima-Moradi1/NewGram/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":241622598,"owners_count":19992504,"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":["appwrite-auth","appwrite-database","appwrite-storage","rhf","shadcn-ui","tailwindcss","tanstack-react-query","typescript","vitejs","zod"],"created_at":"2025-03-03T07:16:11.271Z","updated_at":"2025-11-28T08:02:31.315Z","avatar_url":"https://github.com/Nima-Moradi1.png","language":"TypeScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"\n# NewGram\n\u003cdiv align=\"center\"\u003e\n  \u003cbr /\u003e\n  \u003cdiv\u003e\n    \u003cimg src=\"https://img.shields.io/badge/-React_JS-black?style=for-the-badge\u0026logoColor=white\u0026logo=react\u0026color=61DAFB\" alt=\"react.js\" /\u003e\n    \u003cimg src=\"https://img.shields.io/badge/-Appwrite-black?style=for-the-badge\u0026logoColor=white\u0026logo=appwrite\u0026color=FD366E\" alt=\"appwrite\" /\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/-React_Query-black?style=for-the-badge\u0026logoColor=white\u0026logo=reactquery\u0026color=FF4154\" alt=\"reactquery\" /\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  \u003c/div\u003e\n\n  \u003ch3 align=\"center\"\u003eA Social Media App\u003c/h3\u003e\n\u003c/div\u003e\n\n## \u003ca name=\"introduction\"\u003e🤖 Introduction\u003c/a\u003e\n\nExplore social media with this user-friendly platform that has a nice look and lots of features. Easily create and explore posts, and enjoy a strong authentication system and quick data fetching using React Query for a smooth user experience.\n\n## \u003ca name=\"tech-stack\"\u003e⚙️ Tech Stack\u003c/a\u003e\n\n- React.js\n- Appwrite\n- React Query\n- TypeScript\n- Shadcn\n- Tailwind CSS\n\n## \u003ca name=\"features\"\u003e🔋 Features\u003c/a\u003e\n\n👉 **Authentication System**: A robust authentication system ensuring security and user privacy\n\n👉 **Explore Page**: Homepage for users to explore posts, with a featured section for top creators\n\n👉 **Like and Save Functionality**: Enable users to like and save posts, with dedicated pages for managing liked and saved content\n\n👉 **Detailed Post Page**: A detailed post page displaying content and related posts for an immersive user experience\n\n👉 **Profile Page**: A user profile page showcasing liked posts and providing options to edit the profile\n\n👉 **Browse Other Users**: Allow users to browse and explore other users' profiles and posts\n\n👉 **Create Post Page**: Implement a user-friendly create post page with effortless file management, storage, and drag-drop feature\n\n👉 **Edit Post Functionality**: Provide users with the ability to edit the content of their posts at any time\n\n👉 **Responsive UI with Bottom Bar**: A responsive UI with a bottom bar, enhancing the mobile app feel for seamless navigation\n\n👉 **React Query Integration**: Incorporate the React Query (Tanstack Query) data fetching library for, Auto caching to enhance performance, Parallel queries for efficient data retrieval, First-class Mutations, etc\n\n👉 **Backend as a Service (BaaS) - Appwrite**: Utilize Appwrite as a Backend as a Service solution for streamlined backend development, offering features like authentication, database, file storage, and more\n\nand many more, including code architecture and reusability \n\n## \u003ca name=\"quick-start\"\u003e🤸 Quick Start\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/Nima-Moradi1/NewGram.git\ncd social_media_app\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:\n\n```env\nVITE_APPWRITE_URL=\nVITE_APPWRITE_PROJECT_ID=\nVITE_APPWRITE_DATABASE_ID=\nVITE_APPWRITE_STORAGE_ID=\nVITE_APPWRITE_USER_COLLECTION_ID=\nVITE_APPWRITE_POST_COLLECTION_ID=\nVITE_APPWRITE_SAVES_COLLECTION_ID=\n```\n\nReplace the placeholder values with your actual Appwrite credentials. You can obtain these credentials by signing up on the [Appwrite website](https://appwrite.io/).\n\n**Running the Project**\n\n```bash\nnpm start\n```\n\nOpen [http://localhost:3000](http://localhost:3000) in your browser to view the project.\n=======\n# React + TypeScript + Vite\n\nThis template provides a minimal setup to get React working in Vite with HMR and some ESLint rules.\n\nCurrently, two official plugins are available:\n\n- [@vitejs/plugin-react](https://github.com/vitejs/vite-plugin-react/blob/main/packages/plugin-react/README.md) uses [Babel](https://babeljs.io/) for Fast Refresh\n- [@vitejs/plugin-react-swc](https://github.com/vitejs/vite-plugin-react-swc) uses [SWC](https://swc.rs/) for Fast Refresh\n\n## Expanding the ESLint configuration\n\nIf you are developing a production application, we recommend updating the configuration to enable type aware lint rules:\n\n- Configure the top-level `parserOptions` property like this:\n\n```js\nexport default {\n  // other rules...\n  parserOptions: {\n    ecmaVersion: 'latest',\n    sourceType: 'module',\n    project: ['./tsconfig.json', './tsconfig.node.json'],\n    tsconfigRootDir: __dirname,\n  },\n}\n```\n\n- Replace `plugin:@typescript-eslint/recommended` to `plugin:@typescript-eslint/recommended-type-checked` or `plugin:@typescript-eslint/strict-type-checked`\n- Optionally add `plugin:@typescript-eslint/stylistic-type-checked`\n- Install [eslint-plugin-react](https://github.com/jsx-eslint/eslint-plugin-react) and add `plugin:react/recommended` \u0026 `plugin:react/jsx-runtime` to the `extends` list\n\u003e\u003e\u003e\u003e\u003e\u003e\u003e 675e6c8 (basic setup and css files and configs)\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fnima-moradi1%2Fnewgram","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fnima-moradi1%2Fnewgram","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fnima-moradi1%2Fnewgram/lists"}