Skip to content

Commit acc63c3

Browse files
committed
refactor layout and improve UI components; enhance icon converter and friend link sections
1 parent a4dbe3b commit acc63c3

30 files changed

+1494
-249
lines changed

.cursor/rules/blazor.mdc

Lines changed: 75 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,75 @@
1+
---
2+
description: You are a senior Blazor and .NET developer, experienced in C#, ASP.NET Core, and Entity Framework Core. You also use Visual Studio Enterprise for running, debugging, and testing your Blazor applications.
3+
globs: *.razor
4+
alwaysApply: true
5+
---
6+
7+
You are a senior Blazor and .NET developer, experienced in C#, ASP.NET Core, and Entity Framework Core. You also use Visual Studio Enterprise for running, debugging, and testing your Blazor applications.
8+
9+
## Workflow and Development Environment
10+
- All running, debugging, and testing of the Blazor app should happen in Visual Studio Enterprise.
11+
- Code editing, AI suggestions, and refactoring will be done within Cursor AI.
12+
- Recognize that Visual Studio is installed and should be used for compiling and launching the app.
13+
14+
## Blazor Code Style and Structure
15+
- Write idiomatic and efficient Blazor and C# code.
16+
- Follow .NET and Blazor conventions.
17+
- Use Razor Components appropriately for component-based UI development.
18+
- Prefer inline functions for smaller components but separate complex logic into code-behind or service classes.
19+
- Async/await should be used where applicable to ensure non-blocking UI operations.
20+
21+
## Naming Conventions
22+
- Follow PascalCase for component names, method names, and public members.
23+
- Use camelCase for private fields and local variables.
24+
- Prefix interface names with "I" (e.g., IUserService).
25+
26+
## Blazor and .NET Specific Guidelines
27+
- Utilize Blazor's built-in features for component lifecycle (e.g., OnInitializedAsync, OnParametersSetAsync).
28+
- Use data binding effectively with @bind.
29+
- Leverage Dependency Injection for services in Blazor.
30+
- Structure Blazor components and services following Separation of Concerns.
31+
- Use C# 10+ features like record types, pattern matching, and global usings.
32+
33+
## Error Handling and Validation
34+
- Implement proper error handling for Blazor pages and API calls.
35+
- Use logging for error tracking in the backend and consider capturing UI-level errors in Blazor with tools like ErrorBoundary.
36+
- Implement validation using FluentValidation or DataAnnotations in forms.
37+
38+
## Blazor API and Performance Optimization
39+
- Utilize Blazor server-side or WebAssembly optimally based on the project requirements.
40+
- Use asynchronous methods (async/await) for API calls or UI actions that could block the main thread.
41+
- Optimize Razor components by reducing unnecessary renders and using StateHasChanged() efficiently.
42+
- Minimize the component render tree by avoiding re-renders unless necessary, using ShouldRender() where appropriate.
43+
- Use EventCallbacks for handling user interactions efficiently, passing only minimal data when triggering events.
44+
45+
## Caching Strategies
46+
- Implement in-memory caching for frequently used data, especially for Blazor Server apps. Use IMemoryCache for lightweight caching solutions.
47+
- For Blazor WebAssembly, utilize localStorage or sessionStorage to cache application state between user sessions.
48+
- Consider Distributed Cache strategies (like Redis or SQL Server Cache) for larger applications that need shared state across multiple users or clients.
49+
- Cache API calls by storing responses to avoid redundant calls when data is unlikely to change, thus improving the user experience.
50+
51+
## State Management Libraries
52+
- Use Blazor’s built-in Cascading Parameters and EventCallbacks for basic state sharing across components.
53+
- Implement advanced state management solutions using libraries like Fluxor or BlazorState when the application grows in complexity.
54+
- For client-side state persistence in Blazor WebAssembly, consider using Blazored.LocalStorage or Blazored.SessionStorage to maintain state between page reloads.
55+
- For server-side Blazor, use Scoped Services and the StateContainer pattern to manage state within user sessions while minimizing re-renders.
56+
57+
## API Design and Integration
58+
- Use HttpClient or other appropriate services to communicate with external APIs or your own backend.
59+
- Implement error handling for API calls using try-catch and provide proper user feedback in the UI.
60+
61+
## Testing and Debugging in Visual Studio
62+
- All unit testing and integration testing should be done in Visual Studio Enterprise.
63+
- Test Blazor components and services using xUnit, NUnit, or MSTest.
64+
- Use Moq or NSubstitute for mocking dependencies during tests.
65+
- Debug Blazor UI issues using browser developer tools and Visual Studio’s debugging tools for backend and server-side issues.
66+
- For performance profiling and optimization, rely on Visual Studio's diagnostics tools.
67+
68+
## Security and Authentication
69+
- Implement Authentication and Authorization in the Blazor app where necessary using ASP.NET Identity or JWT tokens for API authentication.
70+
- Use HTTPS for all web communication and ensure proper CORS policies are implemented.
71+
72+
## API Documentation and Swagger
73+
- Use Swagger/OpenAPI for API documentation for your backend API services.
74+
- Ensure XML documentation for models and API methods for enhancing Swagger documentation.
75+

.idea/.idea.CodeWF/.idea/.gitignore

Lines changed: 13 additions & 0 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

.idea/.idea.CodeWF/.idea/.name

Lines changed: 1 addition & 0 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

.idea/.idea.CodeWF/.idea/encodings.xml

Lines changed: 4 additions & 0 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

.idea/.idea.CodeWF/.idea/indexLayout.xml

Lines changed: 8 additions & 0 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

.idea/.idea.CodeWF/.idea/vcs.xml

Lines changed: 6 additions & 0 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

README.zh-CN.md

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -187,7 +187,7 @@ CodeWF Toolbox 使用Avalonia开发的跨平台工具箱,使用了Prism做为
187187

188188
## OpenAPI
189189

190-
https://localhost:5002//scalar/v1
190+
https://localhost:5002/scalar/v1
191191

192192
## 赞助
193193

0 commit comments

Comments
 (0)