Microblog AI is an application that showcases the power of Azure Static Web Apps combined with Azure Functions and Server-Side Rendering (SSR) using Remix. The application leverages Azure OpenAI's GPT-4o artificial intelligence to enable the creation of microblogs in a simple and intuitive way.
Microblog AI is a web application that allows users to create, edit, and view microblogs with the assistance of an advanced AI model. The main goal of this application is to demonstrate how Azure Static Web Apps, combined with Azure Functions and Server-Side Rendering (SSR) using Remix, can be used to build modern, scalable, and efficient web applications. This approach combines the benefits of SSR, such as faster load times and improved SEO, with the scalability and ease of management of a serverless architecture.
The application is designed to be user-friendly, with an intuitive interface that allows users to focus on writing content. Using Azure OpenAI's GPT-4o, users can generate ideas and content quickly and intelligently. Microblog AI is ideal for writers, bloggers, and anyone who wants to share their ideas efficiently.
- Improved Performance: SSR enables pages to be rendered on the server and sent to the client pre-rendered, resulting in faster load times and a smoother user experience.
- Enhanced SEO: With SSR, search engines can index the server-rendered HTML, improving the website's visibility in search results.
- Scalability: Azure Static Web Apps provides a scalable and managed solution for hosting web applications, with native integration with Azure Functions for backend logic.
- Simplified Development: With Azure Static Web Apps, setting up CI/CD pipelines is easy, automating the build and deployment process for rapid and efficient iterations.
For more information on the Hybrid Apps approach in Azure Static Web Apps, refer to the official documentation.
graph TD
    subgraph Client Side
        A[Browser]
    end
    subgraph Azure Static Web Apps
        B[Static Web App Host]
        C[Remix Application - app folder]
        subgraph Routes & Services
            D1[app/routes/generate.tsx]
            D2[app/services/openaiService.ts]
        end
    end
    subgraph Server Side - server folder
        E[Azure Functions v4]
        F[Remix Azure Functions Adapter]
    end
    subgraph Azure Services
        G[Azure OpenAI Services]
        H[GPT-4o Model]
    end
    subgraph Development Tools
        I[swa-cli]
        J[GitHub Copilot]
    end
    A <--> B
    B <--> C
    C --> D1
    D1 --> D2
    C <--> F
    F <--> E
    D2 --> G
    G --> H
    I -.-> B
    J -.-> C
    classDef default fill:#8B4513,color:white, stroke:#333,stroke-width:2px
    classDef azure fill:#0078D4,color:white,stroke:#0078D4
    classDef client fill:#FF6B6B,color:white,stroke:#FF4949
    classDef server fill:#4ECDC4,color:white,stroke:#45B7AF
    classDef dev fill:#2D3748,color:white,stroke:#1A202C
    class A client
    class B,C azure
    class E,F server
    class G,H azure
    class I,J dev
    The application follows a modern web architecture leveraging Azure services and Remix framework:
- 
Client Side - Browser interaction with the web application
- Handles user interactions and form submissions
 
- 
Azure Static Web Apps - Static Web App Host: Manages static content delivery and routing
- Remix Application (appfolder):- Contains the main application logic
- Houses routes and services
- generate.tsx: Handles AI content generation UI and form logic
- openaiService.ts: Manages Azure OpenAI API integration
 
 
- 
Server Side ( serverfolder)- Azure Functions v4: Provides serverless backend infrastructure
- Remix Azure Functions Adapter: Enables Server-Side Rendering (SSR)
- Processes incoming requests and handles SSR operations
 
- 
Azure Services - Azure OpenAI Services: Provides AI capabilities
- GPT-4o Model: Powers the content generation features
 
- 
Development Tools - swa-cli: Local development and deployment tool
- GitHub Copilot: AI-powered development assistant
 
- Users interact with the application through their browser
- Requests are handled by Azure Static Web Apps
- The Remix application processes these requests:
- For page loads: Uses Azure Functions for SSR
- For AI generation: Directly calls Azure OpenAI through openaiService.ts
 
- Responses are sent back to the client with either:
- Server-rendered content
- AI-generated content from Azure OpenAI
 
This architecture ensures optimal performance through SSR while maintaining direct access to AI services for content generation.
- Node.js 20.x (Required for Azure Functions v4 compatibility)
- npm or yarn
- Azure subscription with OpenAI Service access
- Git
- Visual Studio Code (recommended)
- Azure Functions Core Tools v4
- Azure Static Web Apps CLI (npm install -g @azure/static-web-apps-cli)
Here is an example of the Microblog AI project in action:
- Create and edit microblogs.
- View microblogs.
- Integration with Azure OpenAI for intelligent content generation.
- Remix: Used to build the web application with a server-side and client-side rendering approach, providing a faster and more efficient user experience.
- Tailwind CSS: Used for fast and customizable styling, enabling the creation of modern and responsive interfaces.
- TypeScript: Adds static typing to JavaScript, helping prevent common errors and improving code maintainability.
- Azure OpenAI: Azure API used to integrate the GPT-4o model, responsible for generating intelligent content for microblogs.
- Azure Static Web Apps: Service used to host the web application in a scalable and cost-effective way, integrated with CI/CD pipelines.
- Azure Functions: Used to create serverless functions that handle the application's backend logic, allowing automatic scaling as needed.
- GitHub Copilot: AI-powered coding assistant that helps accelerate development by providing context-based code suggestions.
- Remix Azure Functions Adapter: Adapter used to integrate Remix with Azure Functions, facilitating SSR implementation.
- swa-cli: Command-line utility for local development and deployment of Azure Static Web Apps.
Note: This project uses Azure Functions v4 programming model, which requires Node.js versions up to 20.x for compatibility.
Note: You can use GitHub Codespaces to run this application without any local setup. Click the "Code" button and select "Open with Codespaces" to get started. Or just click in the button below:
To run this application locally, follow these steps:
- 
Fork the Repository: - Visit https://github.com/Azure-Samples/microblog-ai-swa-remix and click the "Fork" button to create a copy of the project in your GitHub account.
 
- 
Clone the Forked Repository: - Clone the forked repository to your local environment and navigate to the project directory:
 
git clone <your-fork-url>
cd microblog-ai-swa-remix- Install Dependencies:
- Install all project dependencies using npm:
 
- in the root folder:
npm installAnd then in the server folder:
cd server 
npm install- 
Environment Configuration: - Create a .envfile in the project's root directory with the following environment variables:
 
- Create a 
AZURE_OPENAI_API_KEY=<your-azure-openai-key>
AZURE_OPENAI_ENDPOINT=<your-openai-endpoint>
AZURE_OPENAI_DEPLOYMENT_NAME=<your-openai-model>
AZURE_OPENAI_API_VERSION=<your-openai-api-version>- Azure Functions Configuration:
- Create a local.settings.jsonfile in theserverfolder with the following content:
{
  "IsEncrypted": false,
  "Values": {
    "AzureWebJobsStorage": "UseDevelopmentStorage=true",
    "FUNCTIONS_WORKER_RUNTIME": "node",
    "AZURE_OPENAI_API_KEY": "<your-azure-openai-key>",
    "AZURE_OPENAI_ENDPOINT": "<your-openai-endpoint>",
    "AZURE_OPENAI_DEPLOYMENT_NAME": "<your-openai-model>",
    "AZURE_OPENAI_API_VERSION": "<your-openai-api-version>"
  },
  "Host": {
    "LocalHttpPort": 7071,
    "CORS": "*",
    "CORSCredential": true
  }
}- 
Build the Project: - To compile the project, run:
 
npm run build- Or to compile both the root and server (where Azure Functions are located), run:
npm run build:all- 
Run the Application: - To start the development server locally, run:
 
npm run dev- 
Simulate Production Environment: - To simulate how the project would run on Azure Static Web Apps, use the command:
 
swa startThe application will be available at http://localhost:4280.
Important: This application requires an Azure subscription with access to Azure OpenAI Service. Ensure you have:
- An active Azure subscription
- Access to Azure OpenAI Service
- A deployed GPT-4 model named 'gpt-4o'
- Valid API credentials (endpoint and key)
For more information on deploying an LLM model in Azure Foundry, refer to the official documentation.
- 
Node.js Version Mismatch - Error: "Azure Functions runtime: Version mismatch"
- Solution: Ensure you're using Node.js 20.x (nvm use 20)
 
- 
Azure OpenAI Access - Error: "Authentication failed" or "Resource not found"
- Solution: Verify your Azure OpenAI credentials and ensure your deployment is active
 
- 
Local Development - Error: "Port already in use"
- Solution: Change the port in local.settings.jsonor kill the process using the current port.
 
Contributions are welcome! Feel free to open issues and pull requests for improvements, bug fixes, or new features.
This project is licensed under the MIT License. By contributing to this repository, you agree that your contributions will be licensed under the MIT license. For more details, see the LICENSE file.



