GithubHelp home page GithubHelp logo

sdkdeepa / udemy-web-bootcamp Goto Github PK

View Code? Open in Web Editor NEW
230.0 4.0 115.0 18.78 MB

The Complete Web Development Bootcamp course on Udemy, taught by Angela Yu.

HTML 40.69% CSS 19.75% JavaScript 31.06% EJS 8.41% Procfile 0.09%
react ejs practice mongodb heroku-deployment html-css-javascript bootstrap4 node-js express-js npm

udemy-web-bootcamp's Introduction

The complete web development bootcamp

Alt text

Resources

https://www.appbrewery.co/p/web-development-course-resources

Projects


  • Project 7: Weather App - Node.js and Express.js. This project uses external weather API to make GET call to get the weather data after a POST request is sent.

  • Project 8: Newsletter Sign up - Html, CSS, Bootstrap, JS, Nodejs, express,API, NPM, Nodemon, body-parser etc - https://shrouded-river-17694.herokuapp.com/

  • Project 9 and 10: Todo List app - Continuation of Todo list app v2. Added get, post and delete routes. You can now create and delete todo list for today and for custom list. Custom list can be added to the home route (ex: /work). Using MongoDB Altas cloud database the data is collected. Hosted application through Heroku. Check out: https://tranquil-earth-77166.herokuapp.com/

  • Project 11: Multipage Personal Blog Website - Created a multi page personal blog application using HTML, CSS, Bootstrap, JS, Node.js, Express.js, body-parser, API, EJS, Heroku, Mongoose, MogoDB Altas cloud cluster. Checkout: https://morning-brook-32061.herokuapp.com/

Example of wireframing a project

  • Project 2. wireframing TinDog.png

Topics covered

HTML, CSS, JavaScript, Bootstrap 4, DOM & DOM Manipulation, jQuery, Node.js, Express, React EJS, body-parser, nodemon, lodash, MongoDB, MongoDB Atlas, mongoose, mongoose-encryption, dotenv, md5, bcrypt, passport, passport-local, passport-local-mongoose, passport-google-path20, mongoose-findorcreate, express-session, API, JSON, Authentication, Mailchimp API, Build REST API from scratch, Heroku.

Section 9: Introduction to JavaScript ES6

  • 116-117: Challenge: Changing Casing in Text
  • 118: Basic Arithmetic and Modulo Operator in Javascript
  • 121-122: Functions Part 1: Challenge - The Karel Robot
  • 124: Functions Part 2: Parameters and Arguments

Section 10: Intermediate JavaScript

  • 131: Random Number Generation in Javascript: Building a Love Calculator
  • 132: Control Statements: Using If-Else Conditionals & Logic
  • Coding Exercise 5: BMI Calculator Advanced (IF/ELSE)
  • Coding Exercise 6: Leap Year
  • 138: Adding Elements and Intermediate Array Techniques

Section 12: Boss Level Challenge 1 - The Dicee Game

  • Create an External JS File
  • Add Dice Images
  • Create a Random Number
  • Change both img to a Random Dice
  • Change both img Elements
  • Change the Title to Display a Winner

Section 13: Advanced JavaScript and DOM Manipulation

  • 172: Higher Order Function Challenge

Section 14: Drum Kit

  • 171: Adding Event Listners to a Button
  • 174: How to Play Sounds on a Website
  • 176: How to Use Switch Statements in JavaScript
  • 179: Using Keyboard Event Listeners to Check for Key Presses
  • 181: Adding Animation to Websites

Section 15: Boss Level Challenge 2 - The Simon Game

  • Add JS and jQuery
  • Create a New Pattern
  • Show the Sequence to the User with Animations and Sounds
  • Check Which Button is Pressed
  • Add Sounds to Button Clicks
  • Add Animations to User Clicks
  • Start the Game
  • Check the User's Answer Against the Game Sequence
  • Game Over
  • Restart the Game

Section 19: Express.js with Node.js

  • 241: Creating Our First Server with Express
  • 242: Handling Requests and Responses: the GET Request
  • 244: Understanding and Working with Routes
  • 246: Calculator Challenge Setup
  • 248: Responding to Requests with HTML Files
  • 249: Processing Post Requests with Body Parser
  • 250: BMI Routing Challenge

Section 20: APIs - Application Programming Interfaces

  • 258: Making GET Requests with the Node HTTPS Module
  • 259: How to Parse JSON
  • 260: Using Express to Render a Website with Live API Data
  • 261: Using Body Parser to Parse POST Requests to the Server Project: Weather Project

Section 21: Newsletter Signup

  • 263: Setting up the Sign Up Page
  • 264: Posting Data to Mailchimp's Servers via their API
  • 265: Adding Success and Failure Pages
  • 266: Deploying Your Server with Heroku

Project: https://shrouded-river-17694.herokuapp.com/

Section 22: EJS

  • 282: Templates? Why Do We Need Templates?
  • 283: Creating Your First EJS Template
  • 284: Running Code Inside the EJS Template
  • 285: Passing Data from Your Webpage to Your Server
  • 287: Adding Pre-Made CSS Stylesheets to Your Website
  • 288: Understanding Templating vs Layouts
  • 289: Understanding Node Module Exports: How to Pass Functions and Data between Files

Section 23: Boss Level Challenge 3 - Blog Website

  • Get Home route and add content to home.ejs
  • Pass data from homeStartingContent to home.ejs
  • Add header and footer partials to home.ejs
  • Moved header and footer to partials folder
  • Add About and Contact routes, pass content to about and contact.ejs
  • Add nav href to header
  • Add compose form and POST route
  • Add text fields to compose form and use bootstrap
  • Create JS object for post
  • Push post into posts array
  • Add posts to render array
  • Loop through all posts
  • Refactor for loop to use forEach
  • Render each post onto Home
  • Add express routing parameters /posts/:blogPost
  • Loop through posts array to check if it matches title in url
  • Add lodash and use _.lowerCase on titles
  • Separate page for each blog post
  • Truncate post body on Home page to 100 characters
  • Add Read More to posts

Section 27: Mongoose

  • 357: Introduction to Mongoose
  • 358: Reading from Your Database with Mongoose
  • 359: Data Validation with Mongoose
  • 360: Updating and Deleting Data Using Mongoose
  • 361: Establishing Relationships and Embedding Documents using Mongoose

Section 28: Putting Everything Together

  • 364: Take ToDoList Project to the Next Level and Connect it with Mongoose
  • 365: Rendering Database Items into the ToDoList App
  • 366: Adding New Items to our ToDoList Database
  • 367: Deleting Items from our ToDoList Database
  • 368: Creating Custom Lists using Express Route Parameters
  • 369: Adding New Items to the Custom ToDoLists
  • 370: Revisiting Lodash and Deleting Items from Custom ToDo Lists

Section 29 - Deploying Your Web Application

  • 374: How to Deploy Web Apps with a Database
  • 374: How to Setup MongoDB Atlas
  • 375: Deploying An App with a Database to Heroku

Folder: Project 9 and 10: Todo List https://tranquil-earth-77166.herokuapp.com/

Section 30 - Boss Level Challenge 4 - Blog Website Upgrade

  • 381: Save Composed Posts with MongoDB
  • 382: Get Home Page to Render the Posts
  • 383: Redirect to Home Page after save() is completed with no errors
  • 384: Render correct blog post based on post _id

Folder: Project 11: Blog website completed https://morning-brook-32061.herokuapp.com/

Section 31 - Build Your Own RESTful API From Scratch

  • 389: Set Up Server Challenge
  • 391: GET All Articles
  • 392: POST a New Article
  • 393: Delete All Articles
  • 394: Chained Route Handlers Using Express
  • 395: GET a Specific Article
  • 396: PUT a Specific Article
  • 397: PATCH a Specific Article
  • 398: DELETE a Specific Article

Folder: Wiki-API

Section 32 - Authentication & Security

  • 403: Getting Set Up
  • 404: Level 1 - Register Users with Username and Password
  • 406: Level 2 - Database Encryption
  • 407: Using Environment Variables to Keep Secrets Safe
  • 408: Level 3 - Hashing Passwords
  • 410: Level 4 - Salting and Hashing Passwords with bcrypt
  • 412: Level 5 - Using Passport.js to Add Cookies and Sessions
  • 413a: Level 6 - OAuth 2.0 & How to Implement Sign In with Google
  • 413b: Level 6 - OAuth 2.0 with Facebook
  • 414: Letting Users Submit Secrets

Folder: Secrets

Section 33 - React.js

  • 422: JSX Code Practice
  • 423: JavaScript Expressions in JSX & ES6 Template Literals
  • 424: JavaScript Expressions in JSX Practice
  • 425: Attributes and Styling React Elements
  • 426: Inline Styling for React Elements
  • 427: React Styling Practice
  • 428: React Components
  • 429: React Components Practice
  • 431: JavaScript ES6 Import, Export and Modules Practice
  • 434: Keeper App Project - Part 1
  • 436: React Props
  • 437: React Props Practice
  • 438: React DevTools - https://990sq.csb.app/
  • 439: Mapping Data to Components - https://0lrqy.csb.app/
  • 440: Mapping Data to Components Practice - https://1kzup.csb.app/
  • 441: JavaScript ES6 Map/Filter/Reduce
  • 442: JavaScript ES6 Arrow functions
  • 443: Keeper App Project - Part 2
  • 444: React Conditional Rendering with the Ternary Operator & AND Operator
  • 445: Conditional Rendering Practice - https://pr7ow.csb.app/
  • 447: React Hooks - useState
  • 448: useState Hook Practice
  • 449: JavaScript ES6 Object & Array Destructuring
  • 450: JavaScript ES6 Destructuring Challenge
  • 451: Event Handling in React
  • 452: React Forms
  • 454: Changing Complex State
  • 455: Changing Complex State Practice
  • 456: JavaScript ES6 Spread Operator
  • 457: JavaScript ES6 Spread Operator Practice
  • 458: Managing a Component Tree
  • 459: Managing a Component Tree Practice
  • 460: Keeper App Project - Part 3
  • 461: React Dependencies & Styling the Keeper App - https://pbt9b.csb.app/

Tools used

udemy-web-bootcamp's People

Contributors

sdkdeepa avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar

udemy-web-bootcamp's Issues

Issue with Post method in Newsletter App

I tried exactly the same code but it is not working. But when I try to use the new version from Mailchimp it works but when i try to access response.statusCode, it say undefined. Could you kindly check one.
Here is the snippet of my code.

app.post("/",(req,res)=>{
const fName = req.body.fName;
const lName = req.body.lName;
const email = req.body.email;
client.setConfig({
apiKey: "f45c07cf2dd7d45af20f0b083aba6261-us14",
server: "us14",
});
const run = async () => {
const response = await client.lists.addListMember("8041b6b1ac",
{
email_address: email,
status: "subscribed",
merge_fields: {
FNAME: fName,
LNAME: lName,
},
},

        {
            skipMergeValidation: false
        }
    );
    console.log(`This user's subscription status is ${response.status}.`);
};

run();

});

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.