* Delete outdated development instructions for Next.js + Tailwind and Python; add comprehensive guidelines for PostgreSQL DBA, Angular, ASP.NET REST APIs, Azure Functions with TypeScript, Bicep, Blazor, CMake with vcpkg, C#, .NET MAUI, GenAIScript, Terraform for Azure, localization, and markdown standards. * Update documentation and prompts for consistency and clarity - Standardized description formatting in various markdown files to use single quotes. - Added error handling utility in update-readme.js for safer file operations. - Improved title extraction logic in update-readme.js to handle frontmatter more robustly. - Updated chat modes section in README to reflect new emoji and sorted chat mode links. - Cleaned up various instruction files for better readability and consistency. - Ensured all markdown files end with a newline for better compatibility with version control. * Remove standardize-frontmatter.js script * Add usage instructions for creating and switching chat modes in README.md * Update README.md generation script to enhance instructions and usage details for custom chat modes * Update README.md and update-readme.js for improved instruction clarity and consistency * Refactor README.md links and update readme script for improved clarity and consistency in instructions * Update README.md and update-readme.js for improved instruction clarity and consistency * Changing from a patch to regen approach for the readme * Bit more cleanup for how to show things in the readme * Adding missing description * Another missing description --------- Co-authored-by: Aaron Powell <me@aaron-powell.com>
70 lines
3.2 KiB
Markdown
70 lines
3.2 KiB
Markdown
---
|
|
description: '.NET MAUI component and application patterns'
|
|
applyTo: '**/*.xaml, **/*.cs'
|
|
---
|
|
|
|
# .NET MAUI
|
|
|
|
## .NET MAUI Code Style and Structure
|
|
|
|
- Write idiomatic and efficient .NET MAUI and C# code.
|
|
- Follow .NET and .NET MAUI conventions.
|
|
- Prefer inline functions for smaller components but separate complex logic into code-behind or service classes.
|
|
- Async/await should be used where applicable to ensure non-blocking UI operations.
|
|
|
|
## Naming Conventions
|
|
|
|
- Follow PascalCase for component names, method names, and public members.
|
|
- Use camelCase for private fields and local variables.
|
|
- Prefix interface names with "I" (e.g., IUserService).
|
|
|
|
## .NET MAUI and .NET Specific Guidelines
|
|
|
|
- Utilize .NET MAUI's built-in features for component lifecycle (e.g. OnAppearing, OnDisappearing).
|
|
- Use data binding effectively with {Binding}.
|
|
- Structure .NET MAUI components and services following Separation of Concerns.
|
|
- Always use the latest version C#, currently C# 13 features like record types, pattern matching, and global usings.
|
|
|
|
## Error Handling and Validation
|
|
|
|
- Implement proper error handling for .NET MAUI pages and API calls.
|
|
- Use logging for error tracking in the backend and consider capturing UI-level errors in MAUI with tools like MAUI Community Toolkit's Logger.
|
|
- Implement validation using FluentValidation or DataAnnotations in forms.
|
|
|
|
## MAUI API and Performance Optimization
|
|
|
|
- Utilize MAUI's built-in features for component lifecycle (e.g. OnAppearing, OnDisappearing).
|
|
- Use asynchronous methods (async/await) for API calls or UI actions that could block the main thread.
|
|
- Optimize MAUI components by reducing unnecessary renders and using OnPropertyChanged() efficiently.
|
|
- Minimize the component render tree by avoiding re-renders unless necessary, using BatchBegin() and BatchCommit() where appropriate.
|
|
|
|
## Caching Strategies
|
|
|
|
- Implement in-memory caching for frequently used data, especially for MAUI apps. Use IMemoryCache for lightweight caching solutions.
|
|
- Consider Distributed Cache strategies (like Redis or SQL Server Cache) for larger applications that need shared state across multiple users or clients.
|
|
- Cache API calls by storing responses to avoid redundant calls when data is unlikely to change, thus improving the user experience.
|
|
|
|
## State Management Libraries
|
|
|
|
- Use dependency injection and the .NET MAUI Community Toolkit for state sharing across components.
|
|
|
|
## API Design and Integration
|
|
|
|
- Use HttpClient or other appropriate services to communicate with external APIs or your own backend.
|
|
- Implement error handling for API calls using try-catch and provide proper user feedback in the UI.
|
|
|
|
## Testing and Debugging
|
|
|
|
- Test components and services using xUnit, NUnit, or MSTest.
|
|
- Use Moq or NSubstitute for mocking dependencies during tests.
|
|
|
|
## Security and Authentication
|
|
|
|
- Implement Authentication and Authorization in the MAUI app where necessary using OAuth or JWT tokens for API authentication.
|
|
- Use HTTPS for all web communication and ensure proper CORS policies are implemented.
|
|
|
|
## API Documentation and Swagger
|
|
|
|
- Use Swagger/OpenAPI for API documentation for your backend API services.
|
|
- Ensure XML documentation for models and API methods for enhancing Swagger documentation.
|