Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/misterpea/nytimes-aggregator
React project using the New York Times web API
https://github.com/misterpea/nytimes-aggregator
docker materials-ui nginx nodejs nytimes react react-router subscriptions
Last synced: 6 days ago
JSON representation
React project using the New York Times web API
- Host: GitHub
- URL: https://github.com/misterpea/nytimes-aggregator
- Owner: MisterPea
- License: mit
- Created: 2020-10-10T18:20:20.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2023-03-15T11:49:48.000Z (over 1 year ago)
- Last Synced: 2023-03-15T12:20:13.222Z (over 1 year ago)
- Topics: docker, materials-ui, nginx, nodejs, nytimes, react, react-router, subscriptions
- Language: JavaScript
- Homepage:
- Size: 1.93 MB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# NYTimes Top Stories Aggregator 📰
A website allowing you to view the latest Top Stories as they appear on _The New York Times_. Users who sign up (via email) can choose subjects based upon their interests. Once daily, an email is sent out with the most recent stories based upon those interests.This project lives at: [https://thetimespage.misterpea.me](https://thetimespage.misterpea.me)
### Features - To do:
#### Auth
* [x] Firebase login for users to save articles and subscribe to topics
* [x] Lost password/change password
* [ ] Email account confirmation
#### Frontend:
* [x] Articles browse page
* [x] Section menu
* [x] Modals - For selecting subscriptions and login
* [x] Styling - possible Materials-UI
* [ ] Branding for NY Times API usage
* [x] Aria Labeling
* [x] _User Info_ page with current subscriptions, ability to pause change notifications, change username/password/email
#### Backend:
* [x] Scheduling calls to retreive latests stories
* [x] Add/delete subscriptions
* [x] Add/delete/pause subscriptions through user panel
* [x] Rate limit prevention
* [x] Twilio SendGrid setup
* [x] Google Cloud Functions setup for daily emails
* [x] Setup HTTPS and DNS
* [x] Lessen Cache Duration#### Continuing Development:
* [x] Move password reset to same page as login - via Form Dialog
* [ ] Add backdrop loading indicator
* [x] Add backend caching to nyt api calls
* [ ] User Added Image for user icon
* [ ] Better styling for dialogs/user-info
* [x] Add caching within Nginx#### Stack:
- React
- React Router
- Material-UI
- Scss
- Express
- Node
- Docker
- Nginx
- Firebase Auth
- Firestore NoSQL
- Google Cloud Platform: Compute Engine, Cloud Functions & Cloud Scheduler
- Twilio SendgridRate Limit: 4,000 requests per day and 10 requests per minute. You should sleep 6 seconds between calls to avoid hitting the per minute rate limit.