You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Web-Dev-For-Beginners/AGENTS.md

12 KiB

AGENTS.md

Project Overview

This is an educational curriculum repository for teaching web development fundamentals to beginners. The curriculum is a comprehensive 12-week course developed by Microsoft Cloud Advocates, featuring 24 hands-on lessons covering JavaScript, CSS, and HTML.

Key Components

  • Educational Content: 24 structured lessons organized into project-based modules
  • Practical Projects: Terrarium, Typing Game, Browser Extension, Space Game, Banking App, Code Editor, and AI Chat Assistant
  • Interactive Quizzes: 48 quizzes with 3 questions each (pre/post-lesson assessments)
  • Multi-language Support: Automated translations for 50+ languages via GitHub Actions
  • Technologies: HTML, CSS, JavaScript, Vue.js 3, Vite, Node.js, Express, Python (for AI projects)

Architecture

  • Educational repository with lesson-based structure
  • Each lesson folder contains README, code examples, and solutions
  • Standalone projects in separate directories (quiz-app, various lesson projects)
  • Translation system using GitHub Actions (co-op-translator)
  • Documentation served via Docsify and available as PDF

Setup Commands

This repository is primarily for educational content consumption. For working with specific projects:

Main Repository Setup

git clone https://github.com/microsoft/Web-Dev-For-Beginners.git
cd Web-Dev-For-Beginners

Quiz App Setup (Vue 3 + Vite)

cd quiz-app
npm install
npm run dev        # Start development server
npm run build      # Build for production
npm run lint       # Run ESLint

Bank Project API (Node.js + Express)

cd 7-bank-project/api
npm install
npm start          # Start API server
npm run lint       # Run ESLint
npm run format     # Format with Prettier

Browser Extension Projects

cd 5-browser-extension/solution
npm install
# Follow browser-specific extension loading instructions

Space Game Projects

cd 6-space-game/solution
npm install
# Open index.html in browser or use Live Server

Chat Project (Python Backend)

cd 9-chat-project/solution/backend/python
pip install openai
# Set GITHUB_TOKEN environment variable
python api.py

Development Workflow

For Content Contributors

  1. Fork the repository to your GitHub account
  2. Clone your fork locally
  3. Create a new branch for your changes
  4. Make changes to lesson content or code examples
  5. Test any code changes in relevant project directories
  6. Submit pull requests following contribution guidelines

For Learners

  1. Fork or clone the repository
  2. Navigate to lesson directories sequentially
  3. Read README files for each lesson
  4. Complete pre-lesson quizzes at https://ff-quizzes.netlify.app/web/
  5. Work through code examples in lesson folders
  6. Complete assignments and challenges
  7. Take post-lesson quizzes

Live Development

  • Documentation: Run docsify serve in root (port 3000)
  • Quiz App: Run npm run dev in quiz-app directory
  • Projects: Use VS Code Live Server extension for HTML projects
  • API Projects: Run npm start in respective API directories

Testing Instructions

Quiz App Testing

cd quiz-app
npm run lint       # Check for code style issues
npm run build      # Verify build succeeds

Bank API Testing

cd 7-bank-project/api
npm run lint       # Check for code style issues
node server.js     # Verify server starts without errors

General Testing Approach

  • This is an educational repository without comprehensive automated tests
  • Manual testing focuses on:
    • Code examples run without errors
    • Links in documentation work correctly
    • Project builds complete successfully
    • Examples follow best practices

Pre-submission Checks

  • Run npm run lint in directories with package.json
  • Verify markdown links are valid
  • Test code examples in browser or Node.js
  • Check that translations maintain proper structure

Code Style Guidelines

JavaScript

  • Use modern ES6+ syntax
  • Follow standard ESLint configurations provided in projects
  • Use meaningful variable and function names for educational clarity
  • Add comments explaining concepts for learners
  • Format using Prettier where configured

HTML/CSS

  • Semantic HTML5 elements
  • Responsive design principles
  • Clear class naming conventions
  • Comments explaining CSS techniques for learners

Python

  • PEP 8 style guidelines
  • Clear, educational code examples
  • Type hints where helpful for learning

Markdown Documentation

  • Clear heading hierarchy
  • Code blocks with language specification
  • Links to additional resources
  • Screenshots and images in images/ directories
  • Alt text for images for accessibility

File Organization

  • Lessons numbered sequentially (1-getting-started-lessons, 2-js-basics, etc.)
  • Each project has solution/ and often start/ or your-work/ directories
  • Images stored in lesson-specific images/ folders
  • Translations in translations/{language-code}/ structure

Build and Deployment

Quiz App Deployment (Azure Static Web Apps)

The quiz-app is configured for Azure Static Web Apps deployment:

cd quiz-app
npm run build      # Creates dist/ folder
# Deploys via GitHub Actions workflow on push to main

Azure Static Web Apps configuration:

  • App location: /quiz-app
  • Output location: dist
  • Workflow: .github/workflows/azure-static-web-apps-ashy-river-0debb7803.yml

Documentation PDF Generation

npm install                    # Install docsify-to-pdf
npm run convert               # Generate PDF from docs

Docsify Documentation

npm install -g docsify-cli    # Install Docsify globally
docsify serve                 # Serve on localhost:3000

Project-specific Builds

Each project directory may have its own build process:

  • Vue projects: npm run build creates production bundles
  • Static projects: No build step, serve files directly

Pull Request Guidelines

Title Format

Use clear, descriptive titles indicating the area of change:

  • [Quiz-app] Add new quiz for lesson X
  • [Lesson-3] Fix typo in terrarium project
  • [Translation] Add Spanish translation for lesson 5
  • [Docs] Update setup instructions

Required Checks

Before submitting a PR:

  1. Code Quality:

    • Run npm run lint in affected project directories
    • Fix all linting errors and warnings
  2. Build Verification:

    • Run npm run build if applicable
    • Ensure no build errors
  3. Link Validation:

    • Test all markdown links
    • Verify image references work
  4. Content Review:

    • Proofread for spelling and grammar
    • Ensure code examples are correct and educational
    • Verify translations maintain original meaning

Contribution Requirements

Review Process

  • PRs reviewed by maintainers and community
  • Educational clarity is prioritized
  • Code examples should follow current best practices
  • Translations reviewed for accuracy and cultural appropriateness

Translation System

Automated Translation

  • Uses GitHub Actions with co-op-translator workflow
  • Translates to 50+ languages automatically
  • Source files in main directories
  • Translated files in translations/{language-code}/ directories

Adding Manual Translation Improvements

  1. Locate file in translations/{language-code}/
  2. Make improvements while preserving structure
  3. Ensure code examples remain functional
  4. Test any localized quiz content

Translation Metadata

Translated files include metadata header:

<!--
CO_OP_TRANSLATOR_METADATA:
{
  "original_hash": "...",
  "translation_date": "...",
  "source_file": "...",
  "language_code": "..."
}
-->

Debugging and Troubleshooting

Common Issues

Quiz app fails to start:

  • Check Node.js version (v14+ recommended)
  • Delete node_modules and package-lock.json, run npm install again
  • Check for port conflicts (default: Vite uses port 5173)

API server won't start:

  • Verify Node.js version meets minimum (node >=10)
  • Check if port is already in use
  • Ensure all dependencies installed with npm install

Browser extension won't load:

  • Verify manifest.json is properly formatted
  • Check browser console for errors
  • Follow browser-specific extension installation instructions

Python chat project issues:

  • Ensure OpenAI package installed: pip install openai
  • Verify GITHUB_TOKEN environment variable is set
  • Check GitHub Models access permissions

Docsify not serving docs:

  • Install docsify-cli globally: npm install -g docsify-cli
  • Run from repository root directory
  • Check that docs/_sidebar.md exists

Development Environment Tips

  • Use VS Code with Live Server extension for HTML projects
  • Install ESLint and Prettier extensions for consistent formatting
  • Use browser DevTools for debugging JavaScript
  • For Vue projects, install Vue DevTools browser extension

Performance Considerations

  • Large number of translated files (50+ languages) means full clones are large
  • Use shallow clone if only working on content: git clone --depth 1
  • Exclude translations from searches when working on English content
  • Build processes may be slow on first run (npm install, Vite build)

Security Considerations

Environment Variables

  • API keys should never be committed to repository
  • Use .env files (already in .gitignore)
  • Document required environment variables in project READMEs

Python Projects

  • Use virtual environments: python -m venv venv
  • Keep dependencies updated
  • GitHub tokens should have minimal required permissions

GitHub Models Access

  • Personal Access Tokens (PAT) required for GitHub Models
  • Tokens should be stored as environment variables
  • Never commit tokens or credentials

Additional Notes

Target Audience

  • Complete beginners to web development
  • Students and self-learners
  • Teachers using the curriculum in classrooms
  • Content is designed for accessibility and gradual skill building

Educational Philosophy

  • Project-based learning approach
  • Frequent knowledge checks (quizzes)
  • Hands-on coding exercises
  • Real-world application examples
  • Focus on fundamentals before frameworks

Repository Maintenance

  • Active community of learners and contributors
  • Regular updates to dependencies and content
  • Issues and discussions monitored by maintainers
  • Translation updates automated via GitHub Actions

Working with Specific Projects

For detailed instructions on individual projects, refer to the README files in:

  • quiz-app/README.md - Vue 3 quiz application
  • 7-bank-project/README.md - Banking application with authentication
  • 5-browser-extension/README.md - Browser extension development
  • 6-space-game/README.md - Canvas-based game development
  • 9-chat-project/README.md - AI chat assistant project

Monorepo Structure

While not a traditional monorepo, this repository contains multiple independent projects:

  • Each lesson is self-contained
  • Projects don't share dependencies
  • Work on individual projects without affecting others
  • Clone entire repo for the full curriculum experience