GithubHelp home page GithubHelp logo

meetup's Introduction

NotMeetup

Live Site: https://haskjdhashdasd9.onrender.com

Backend: https://github.com/brandonetter/MeetUp/tree/main/server

Summary Of Features: This is a partial clone of the website Meetup.com, some of the features include --

  • Google Maps Integration

    • Using DistanceMatrix to grab the Distance between Groups and Search Locations
    • Using the Map to allow using to select locations through clicking
    • Grabbing detailed information about the User's Location
    • Displaying Markers on relevant points of interest
  • Authentication

    • Session management using JSON Web Tokens
    • Cross Site Request Forgery (CSRF) Protection
  • Database

    • Sequelize ORM
    • Data validation on server-side
    • Image upload using Multer
  • FrontEnd

    • Built using React
    • Calendar Widget for selecting Dates and Displaying upcoming Events
    • Image Carousel
    • Animation of Background using SVG animations
    • Loading Images for smooth User Experience

Screenshots:

landing

demo1

demo2

demo3

Build And Run Instructions:

  1. git clone this repo
  2. cd Meetup && npm run full-install
  3. npm run start or npm run dev

Tech:

  • React
  • Redux
  • NodeJS
    • Express
    • JSON Web Tokens
    • BCrypt
    • Multer
  • Sequelize ORM
    • SQLite3
    • Postgres
  • CSS HTML
  • Javascript
  • Google Maps API

Todo:

  • Add User Profiles and User Image Uploads
  • Add Moderator Controls
  • Add Mobile Site
  • Email Notifications and Subscriptions
  • Toasts and Notifcations
  • Add Messaging and Group Chats Using SocketIO

Personal Notes:

I really learned a lot about project management with this one, as it was my biggest solo project in Web Dev. Key take-aways for me are--

  • Your test environment should be as close to you deploy environment as you can manage
  • Naming conventions and project structure are critically important to development speed once the project grows to a certain size.
  • Be comfortable with deleting and rewriting small parts of the backend once the front-end seems to demand it.

I picked up a few programming patterns I'd like to continue using in future projects. Like using React's map along-side Object.keysTo iterate through Objects containing Arrays with in-line JSX inline

Or like integrating data validation inside of Sequelize Models to make a clean and self-contained system

valid1

...

valid2

meetup's People

Contributors

brandonetter avatar

Stargazers

Philip Ling avatar

Watchers

 avatar

meetup's Issues

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.