Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/martin2844/gatsby-blog-auth
A blog with auth for users to login and comment, using firebase
https://github.com/martin2844/gatsby-blog-auth
Last synced: 8 days ago
JSON representation
A blog with auth for users to login and comment, using firebase
- Host: GitHub
- URL: https://github.com/martin2844/gatsby-blog-auth
- Owner: martin2844
- License: mit
- Created: 2020-03-27T23:39:48.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-01-11T22:05:58.000Z (almost 2 years ago)
- Last Synced: 2023-03-03T13:27:10.933Z (over 1 year ago)
- Language: JavaScript
- Size: 14.8 MB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 25
-
Metadata Files:
- Readme: readme.md
- License: LICENSE
Awesome Lists containing this project
README
# Gatsby Blog Firebase Auth / CodigoMate blog
Welcome to this repo!
This is basically a gatsby blog, but it has some quite nice added extra perks.This blog features:
* Gatsby Image
* Markdown posts, you own all your content
* Pagination for blog posts
* Blog posts thumbs
* Tag and Category navigation
* Breadcrumbs
* Post comments
* User interaction by firebase including comments on posts, user dashboard with user avatar and user display names.
* All home made components, no component libraries for UI
* Smart 404.js page, thanks to [Sam Larsen](https://sld.codes/articles/Rethinking-404-Pages)
* Mobile Side bar menu### History
1. New Branch codigoMate, will make this idea my actual blog since its a nice idea
2. Ui Refactoring -> inspired on designshack
3. Header planning - algorithm for dynamic menu creation
4. Index Page - planning, just the latest 10-12 tuts - some more info below - maybe courses in the future
5. Idea 30 dias de react
6. Cat and Tag pages - Cat Page first
7. Prism JS
8. State management for breadcrumbs
9. Breadcrumbs to global state. Now working.
10. Pagination working on url level. Must add page numbers on the bottom.
11. Page no's added to bottom. Must add Prev and Next buttons, and style it a bit better. Must add follwoing format < 1 2 3 ... 188 >
12. Created regex check for paginated breadcrumbs. Created Custom Buttton component.
13. Some media queries, added logo
14. Added mobile menu - still needs some retouchingJuly:
1. Added merge true to DB handling in profile
2. Separated pro, paid and free markdown from normal. If md has type then its a course
3. Added pro categories for user DB
4. Created checkPro hook.
5. Added courses createPage
6. Added course page, must format post display. But post query has correct filter
7. Courses are now being displayed from the course folder
8. Fixed conditional rendering of courses card
9. Fixed graphql query for posts which are courses
10. Reestructure of links to spanish
11. SetCrumbs hooks
12. Crumb contexts
13. Success alert @ p.success
14. Trickster css triangle for profile
15. Bottom bar header for profile tab
16. Proverlay on index courses
17. More updates to header - About dropdown
18. Contact API - Contact Page with spinner, alert posting, done.August:
1. Pay BTN initialized in preview template.
Must still make the user login before paying, if user clicks pay, and is not logged in -> redirect to login page, then if possible back to course. This could be made by adding to context the course where user pressed pay, then sending user to BTN via link and #ID in BTN.
1. Add context to store where user clicked pay,
2. after succesful login if that context existed redirect to preview, + ID for scroll POS
3. Clear the context.
Still need to clear some issues in payment SV.
First of all, check if still in sandbox mode, then test the external reference.
Then test user creation, what is it? Do we need it?
Also revise trello card, still lots of thing missing, is payment a priority?
Need to add all billing info for user, so if user was created normally now we need to add information for payment. So basically make a checkout flow... This is important and great for learning.1. First add all info to node api. // Allready added structure in pay.js
2. Then check via postman2. Created Checkout page, if user does not have billing info, send to checkout page before meli.
3. Hoisted course, if user is not logged and wants to buy, redirect to login, and then once logged in, redirect to check out.
September 2020:
Forgot about it, life happened.
Started again, with edit profile. Must continue flow there.
**19-9-20**:
- Refactor edit profile page.
- Added image upload to IMGUR
- added random image functionality.
- added alerts
*Must add to complete*:
- Alert animations and fade-outs
- Password changing logic
- Check mobile for edit profile.
**22-9-20**
Finished checkout.js flow.
**13-10-2020**
- Added Footer Component with mobile
- Worked on profile page - must adapt
## Ideas to implement
For the courses section we'll have two types of courses free and paid.
Courses will be structured in markdown, so on gatsby node on the markdown loop we will have to create an if statement to separate courses from normal blog posts.```
If (format === course) {
if(type === free) {
create page @ /courses/free/blblblbl
} else {
if(type === paid) {} else {
}
}} else {
create page @ /tutoriales/
}```
also, .gitignore - avoid pushing paid courses. Actually this would not work since netlify uses git repo to push. Either fork repo when integration is done, and create new private repo with that or make repo private
## Handle pro
user: pro - not only true but array of numbers corresponding to courses id.
So on checkpro we'll check if the number inside the array corresponds to the course they are trying to buy or see.
In /preview/course we'll have the preview of the course if the user is not pro on that course, if the user is pro on that course we will redirect to that course
Also inside profile we will have your courses, if user has a course, we'll filter paid courses through graphql using state and user's pro data.# Courses
If user pro - check courses inside user object. You'll get ID of course.
Map through courses and match id from user to course ID.When accessing preview if users courses contains c1 - skip preview and redirect to course
# Checkout.js
// Posibilidad de agregar "Checkout State" - carrito tácito. Lleva dos cursos y tené un 30% descuento en el pago total
// Entonces acá hay que recomendar cursos en base a los que ya hay. Para un futuro.Still Alive