The Personal Site of Lalo Morales


Modern Software Development: My Full-Stack Workflow from Code to Deployment

workflow blog post

In today’s rapidly evolving tech landscape, having a streamlined development workflow is crucial. With the advent of powerful tools and platforms, developers can now build, test, and deploy applications more efficiently than ever before. In this blog post, I want to share my personal setup that combines traditional development tools with cutting-edge AI assistance to create and deploy software effectively. Let’s dive into how I take projects from mere ideas to live deployments.


๐Ÿ”ง Local Development Environment

The Foundation: MacBook and Terminal

My journey begins on a MacBook, which serves as my primary development machine. While graphical user interfaces are user-friendly, I often find myself gravitating towards the Terminal for its speed and efficiency. The Unix-based system on macOS provides a robust environment for:

  • Quick File Operations: Navigating directories, moving files, and managing permissions become second nature with command-line operations.
  • Git Commands: Version control is seamless when you can stage, commit, and push changes without leaving the Terminal.
  • Package Management: Tools like Homebrew make installing and managing software packages straightforward.

This setup allows me to have granular control over my development environment, ensuring that I can tailor it to the specific needs of each project.

Visual Studio Code: My Command Center

Visual Studio Code (VS Code) is more than just a code editorโ€”it’s the command center of my development workflow. Its versatility stems from a rich ecosystem of extensions and integrations that enhance productivity.

AI Coding Assistants

One of the game-changing features in my workflow is the integration of AI coding assistants within VS Code:

  • GitHub Copilot: Acting as an AI pair programmer, Copilot doesn’t just autocomplete code; it understands context and can suggest entire functions or solutions. This accelerates development by reducing boilerplate coding and providing intelligent suggestions.
  • Other AI Models: Through various extensions, I have access to AI models like:
    • Claude (Anthropic)
    • GPT (OpenAI)
    • Llama Models
    • Perplexity

These AI assistants aid in code generation, debugging, and even documentation, allowing me to focus on solving complex problems rather than getting bogged down by syntax and structure.


๐Ÿ› ๏ธ Alternative Development Platforms

While local development is essential, sometimes I need to prototype or experiment quickly without setting up a full environment. That’s where cloud-based platforms come into play.

Replit

Replit is a fantastic tool for:

  • Quick Prototyping: Spin up a new project in seconds to test out ideas.
  • Testing Without Local Setup: Experiment with different programming languages or frameworks without installing anything locally.
  • Collaborative Coding: Invite team members to code together in real-time.
  • Direct GitHub Integration: Save and sync your work directly with GitHub repositories.

This platform is a go-to when I need to validate concepts or work collaboratively without the overhead of environment setup.

StackBlitz and Bolt.new

StackBlitz offers a powerful browser-based development environment, and their Bolt.new service is perfect for:

  • Creating Web Applications Quickly: Build and preview web apps instantly.
  • Testing Frameworks: Experiment with different libraries and frameworks without affecting your local setup.
  • Sharing Live Environments: Share a live coding session with others for feedback or collaboration.

GPTEngineer

For projects that require rapid scaffolding or AI-driven development, I turn to GPTEngineer:

  • Project Scaffolding: Generate the basic structure of a project based on descriptions.
  • Basic Implementations: Create initial code implementations to build upon.
  • AI Experimentation: Leverage AI to explore new approaches to problem-solving.

๐Ÿ“š Version Control and Deployment

GitHub: The Central Hub

Regardless of where or how I’m coding, GitHub remains the central repository for all my projects. It provides:

  • Version Control: Track changes over time and revert if necessary.
  • Code Backup: Securely store code in the cloud.
  • Collaboration: Work with others through pull requests and issue tracking.
  • Integration: Connect with various tools and services for continuous integration and deployment.

By syncing all my code to GitHub, I ensure that my projects are organized, accessible, and maintainable.

GitHub Pages: From Code to Live

One of the standout features of GitHub is GitHub Pages, which allows me to host websites directly from my repositories. When a project is ready for deployment:

  1. Enable Pages: Activate GitHub Pages in the repository settings.
  2. Select Branch: Choose the branch (usually main or gh-pages) to deploy.
  3. Automatic Build: GitHub automatically builds and serves the site.

This process simplifies deployment, making it easy to share projects with the world without needing additional hosting services.


๐ŸŒ Domain Management and Going Live

Bluehost and Domain Configuration

To give my projects a professional touch, I manage custom domains through Bluehost. This involves:

  • Domain Management: Purchase and manage domains and subdomains.
  • DNS Configuration: Point DNS records to GitHub Pages by setting CNAME and A records.
  • GitHub Integration: Add the custom domain in the GitHub Pages settings of the repository.
  • Propagation Wait Time: Allow 24-48 hours for DNS changes to propagate globally.

By configuring custom domains, I can host multiple projects under a unified branding strategy, enhancing credibility and recognition.


๐Ÿ”„ The Complete Workflow in Action

Bringing it all together, here’s how a typical project flows from inception to deployment:

1. Initial Development

  • Coding in VS Code: Start building the project with the help of AI assistants.
  • Terminal Operations: Use the Terminal for tasks like initializing Git repositories and installing dependencies.
  • Version Control: Commit changes regularly and push to GitHub to maintain a history of the project.

2. Rapid Prototyping (If Needed)

  • Use Replit or StackBlitz: For quick experiments or to test alternative approaches.
  • Collaborate and Share: Work with others in real-time or get feedback.
  • Integration with GitHub: Merge successful prototypes back into the main repository.

3. Deployment

  • Enable GitHub Pages: Turn on the hosting feature in the repository settings.
  • Configure Build Settings: Specify any build commands or configurations needed.
  • Testing: Ensure the deployed version works as intended.

4. Domain Setup

  • Create Subdomain: Set up a subdomain in Bluehost for the project.
  • Configure DNS Records: Update CNAME and A records to point to GitHub Pages.
  • Link in GitHub: Add the custom domain to the GitHub Pages settings.
  • Wait for Propagation: Allow time for DNS changes to take effect.

๐ŸŽฏ Benefits of This Setup

This workflow offers several advantages that enhance productivity and project quality:

  • Flexibility: Easily switch between local and cloud development environments based on the project’s needs.
  • AI Assistance: Utilize multiple AI models to aid in coding, debugging, and documentation.
  • Version Control: Keep all code organized and backed up with GitHub’s robust version control system.
  • Easy Deployment: Streamlined process from code to a live site without the need for complex hosting solutions.
  • Professional Appearance: Custom domains and subdomains add credibility and make projects easily accessible.

๐Ÿš€ Continuous Improvement

The tech world doesn’t stand still, and neither does my workflow. I continuously explore new tools, platforms, and methodologies to enhance my development process. This includes:

  • Staying Updated: Keeping abreast of the latest updates in AI models and development tools.
  • Experimentation: Trying out new platforms like emerging cloud IDEs or AI-assisted coding tools.
  • Feedback Loop: Incorporating feedback from peers and the development community to refine my workflow.

The key is finding the right balance between reliable tools and innovative solutions to maintain efficiency without sacrificing quality.


Conclusion

Navigating the modern software development landscape requires a toolkit that’s both versatile and powerful. By combining traditional development tools like VS Code and Terminal with AI assistance and cloud-based platforms, I can efficiently take projects from concept to deployment. Leveraging GitHub for version control and deployment, along with custom domain management through Bluehost, ensures that my projects are professional and accessible. While the setup might seem complex initially, each component plays a vital role in creating a streamlined and effective development workflow.

Whether you’re a seasoned developer or just starting out, I hope this insight into my workflow provides valuable ideas for optimizing your own development process. Embracing both tried-and-true tools and cutting-edge technology can significantly enhance your ability to build and deploy software in today’s fast-paced tech environment.

Share via
Copy link