Skip to content

albertwchang/PayPal-Clone

Repository files navigation

Project Approach:

  1. Build out client-side / front-end while employing mock data (that would be expected from server), and data obtained from a chosen exchange-rate (and possibly currency) API
  2. Build out server to provide required client data, but based on mocked DB models
  3. Integrate MongoDB usage (using aggregation framework -- noSQL version of SQL's left outer joins)
  4. Update Readme to have instructions on installing, configuring and setting up locally.
  5. Deploy to Heroku

Considerations:

  1. Attempting to send money in currency inconsistent w/ both sender && recipient's selected currency not allowed, e.g. USD -> JPY -> USD
  2. User cannot send to onself
  3. When sending in different currency from sender's own currency, exchange rate for that currency needs to be accessed. Converted amount to clearly distinguish between the amount deducted from their account vs. what is actually sent to recipient
  4. Computed transfer amt + deducted amount will timeout after 2 minutes just as a quick-and-dirty attempt to circumvent real-world, real-time exchange rate changes.
  5. At "Send Money view", include account balance, and provide some sort of mechanism to show insufficient funds, and subsequently prevent user from sending unavailable funds
  6. Include a "error" view that shows any and all error results following payment attempt.
  7. Given that I will be using Ajax only (no-real time, event-based updates on the client), server needs to check for insufficient funds regardless).
  8. With transaction items (History view), include icons to distinguish between 'gifts' vs. 'business' transactions, and 'received' vs. 'sent'
  9. 'Send Payment' view should have a "Back" navigation of some sort.

SETUP & INSTALL

  1. Clone this repo
  2. Go into the cloned project via CLI, and then run 'npm install' within the directory
  3. Run 'npm install webpack -g'
  4. Run 'npm install webpack-dev-server -g'
  5. (Despite seeing error messages regarding peer dependencies) Run 'npm install [email protected]'
  6. Lastly, run 'npm start'. Internet browser will navigate to http://localhost:4567. No other installs needed as app is currently not running an app server

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published