plugins/languages/csharp/skills/desktop/SKILL.md
C# 桌面与跨平台 GUI 开发规范。覆盖 WPF / .NET MAUI / Avalonia UI / WinUI 3、 CommunityToolkit.Mvvm source generators、MVVM 数据绑定、UI 线程调度、 Dispatcher / MainThread、长任务取消、热重载、AOT 发布。当开发桌面应用、 跨平台客户端、GUI 界面, 或说 "WPF"、"MAUI"、"Avalonia"、"WinUI"、"MVVM"、 "XAML"、"数据绑定"、"DependencyProperty"、"ObservableProperty" 时加载。
npx skillsauth add lazygophers/ccplugin csharp-desktopInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
跨平台桌面优先 Avalonia / .NET MAUI; Windows-only 业务桌面用 WPF; 新 Win 应用 WinUI 3 + WindowsAppSDK。
| 场景 | 推荐 | |------|------| | 移动 + 桌面 (iOS/Android/Mac/Win) | .NET MAUI | | 桌面跨平台 (Win/Mac/Linux) | Avalonia UI | | Windows 现代应用 (MSIX) | WinUI 3 | | Windows 传统业务、生态成熟 | WPF |
source generator 消除样板:
public partial class OrderViewModel(IOrderService svc) : ObservableObject
{
[ObservableProperty] private string _query = "";
[ObservableProperty]
[NotifyCanExecuteChangedFor(nameof(SearchCommand))]
private bool _isLoading;
public ObservableCollection<OrderDto> Items { get; } = [];
[RelayCommand(CanExecute = nameof(CanSearch),
AllowConcurrentExecutions = false,
IncludeCancelCommand = true)]
private async Task SearchAsync(CancellationToken ct)
{
IsLoading = true;
try
{
Items.Clear();
await foreach (var o in svc.SearchAsync(Query, ct))
Items.Add(o);
}
finally { IsLoading = false; }
}
private bool CanSearch() => !IsLoading && !string.IsNullOrWhiteSpace(Query);
}
[RelayCommand] 自动生成 IAsyncRelayCommand + 取消支持[ObservableProperty]; 联动通知 [NotifyPropertyChangedFor]INotifyPropertyChanged 样板绝不在 UI 线程做阻塞 IO/CPU 工作。
| 框架 | 切回 UI 线程 |
|------|-------------|
| WPF | Application.Current.Dispatcher.InvokeAsync |
| WinUI 3 | DispatcherQueue.TryEnqueue |
| MAUI | MainThread.BeginInvokeOnMainThread |
| Avalonia | Dispatcher.UIThread.InvokeAsync |
异步事件处理器允许 async void, 但必须 try/catch 兜底, 错误送日志/UI 提示。
IValueConverter, 避免在 XAML 内联表达式过深ObservableCollection<T>; 高频更新批量 (Avalonia BatchUpdate、WPF CollectionViewSource.DeferRefresh)UpdateSourceTrigger=PropertyChanged 对实时校验有用, 但要权衡性能public partial class App : Application
{
private readonly IHost _host = Host.CreateDefaultBuilder()
.ConfigureServices(s =>
{
s.AddSingleton<MainWindow>();
s.AddTransient<OrderViewModel>();
s.AddHttpClient<IOrderService, OrderService>();
})
.Build();
protected override async void OnStartup(StartupEventArgs e)
{
await _host.StartAsync();
_host.Services.GetRequiredService<MainWindow>().Show();
}
}
MAUI: MauiApp.CreateBuilder().UseMauiApp<App>().UseMauiCommunityToolkit()。
App.xaml / Application.ResourcesResourceDictionary + dynamic resource, 便于主题切换Style + ControlTemplate; 不要直接改 control 默认 template 之外的内部结构<PublishAot>true</PublishAot> 或 ReadyToRun)Virtualization=true + ItemContainerStyle 复用Microsoft.Maui.Graphics; Avalonia 用 AsyncImageLoaderOnPropertyChanged 跑重计算; 提取到 background task[RelayCommand(IncludeCancelCommand = true)]
private async Task ExportAsync(CancellationToken ct)
{
Progress = 0;
await foreach (var p in _exporter.RunAsync(ct))
Progress = p;
}
IncludeCancelCommand 自动生成 ExportCancelCommand, 绑定到 UI 取消按钮。
Microsoft.Maui.TestUtils.DeviceTests、WPF/WinUI 用 Appium、Avalonia 用 Avalonia.HeadlessApplication.Current)<TrimMode>partial</TrimMode>dotnet publish -f net10.0-android 等)Microsoft.Windows.SDK.BuildToolstools
--- name: trellisx-workspace description: 维护 `.trellis/task.md` 任务看板 —— trellis 缺的跨任务总览。**一个表格, 一行一个任务**, 列为 id/名称/描述/状态/阶段/进度/worktree (状态/阶段中文显示)。在 task create/start/阶段切换/archive 后**及时更新**对应行; 并**自动清理超 7 天的已完成行**防膨胀。保持看板与 task.json 实时一致。 when_to_use: 维护 / 创建 / 更新 `.trellis/task.md` 任务看板时; task 生命周期任一节点 (create/start/阶段推进/archive) 之后同步看板时; 用户问"当前有哪些任务 / 任务进度 / 任务看板"时。被 trellisx-flow 与 trellisx-apply 注入的流程引用。 user-invocable: true argument-hint: [show|update|sync|cleanup ...] [task id] arguments:
testing
强制以 Trellis task 闭环处理用户指定的请求 (自判新建/并入 → plan→exec→check→finish 全程不跳步)。**仅用户显式主动调用** (/trellisx-flow 或明确要求"强制走 task 处理这个"); **禁止自动 / 被动 / 推断式调用** —— 不要因为某个请求"看起来该建 task"就自动触发本 skill, 那是 apply 注入的 no_task 倾向的职责。
testing
把 强推task + subtask拆分 + worktree隔离 + 闭环收尾 四维度增量注入当前项目 .trellis/ (workflow.md 的 no_task/planning/in_progress 块 + spec 背书文档 + trellis 生命周期 hook worktree 自动化)。强推 task 与闭环为纯 prompt 软约束 (非平台 hook 硬拦截)。**纯增量追加, 绝不替换 trellis 原生文本** (no_task 分类+征同意/check/finish/前缀全保留)。幂等 (marker 包裹)。
development
Claude Code 会话历史整理 — 扫 ~/.claude/projects/**/*.jsonl 全部 session transcripts, 提取学习增量 (用户校正/决策/踩坑/L0 规则) → 全局记忆库 ~/.cortex/.wiki/memory/. 默认 --apply 落盘 (--dry-run opt-in 仅出 JSON plan 预览). 与 cortex-extract (L4-inbox 内部) 互补.