plugins/languages/flutter/skills/ios/SKILL.md
Flutter iOS 平台规范 — Cupertino 设计、Impeller (iOS 默认)、ATT/隐私清单、Info.plist 权限描述、ProMotion 120Hz、App Store 审核合规。当用户开发 iOS/iPadOS 端、提到 "iOS"、"Cupertino"、"App Store"、"ATT"、"权限"、"Info.plist"、"TestFlight" 时加载。
npx skillsauth add lazygophers/ccplugin flutter-iosInstall 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.
CupertinoApp(
theme: const CupertinoThemeData(
primaryColor: CupertinoColors.activeBlue,
brightness: Brightness.light,
),
);
CupertinoPageScaffold(
navigationBar: const CupertinoNavigationBar(middle: Text('Settings')),
child: CupertinoListSection.insetGrouped(
header: const Text('Account'),
children: [
CupertinoListTile(
title: const Text('Profile'),
leading: const Icon(CupertinoIcons.person),
trailing: const CupertinoListTileChevron(),
onTap: () => context.push('/profile'),
),
],
),
);
// 销毁性 alert
showCupertinoDialog(
context: context,
builder: (_) => CupertinoAlertDialog(
title: const Text('Delete'),
actions: [
CupertinoDialogAction(
isDestructiveAction: true,
onPressed: () => Navigator.pop(context, true),
child: const Text('Delete'),
),
CupertinoDialogAction(
isDefaultAction: true,
onPressed: () => Navigator.pop(context, false),
child: const Text('Cancel'),
),
],
),
);
Impeller 自 Flutter 3.10 起 iOS 默认启用,消除 shader compilation jank。
优化要点:
BackdropFilter 控制使用范围 (开销大)Opacity → color.withValues(alpha: …)CustomPaint 复杂度可控// 高质量毛玻璃
ClipRRect(
borderRadius: BorderRadius.circular(16),
child: BackdropFilter(
filter: ImageFilter.blur(sigmaX: 10, sigmaY: 10),
child: Container(
color: CupertinoColors.systemBackground.withValues(alpha: 0.8),
child: content,
),
),
);
// 1. 图片预缓存
@override
void didChangeDependencies() {
super.didChangeDependencies();
precacheImage(const AssetImage('assets/hero.png'), context);
}
// 2. CachedNetworkImage + 降采样
CachedNetworkImage(
imageUrl: url,
memCacheWidth: 200,
memCacheHeight: 200,
placeholder: (_, __) => const CupertinoActivityIndicator(),
);
声明所有 SDK 收集的数据类型 + 使用必需 API 的 Reason。Flutter 默认模板已含,自定义插件需补充。
import 'package:app_tracking_transparency/app_tracking_transparency.dart';
Future<void> ensureTrackingPermission() async {
final status = await AppTrackingTransparency.trackingAuthorizationStatus;
if (status == TrackingStatus.notDetermined) {
await AppTrackingTransparency.requestTrackingAuthorization();
}
}
| Key | 场景 |
| --- | --- |
| NSCameraUsageDescription | 相机 |
| NSPhotoLibraryUsageDescription | 相册 |
| NSLocationWhenInUseUsageDescription | 定位 |
| NSMicrophoneUsageDescription | 麦克风 |
| NSUserTrackingUsageDescription | ATT |
缺失任一会导致 App Store 拒审或运行崩溃。
ios/Runner/Runner.entitlements 配置 associated-domains + 服务器部署 apple-app-site-association。
testWidgets('Cupertino navigation', (tester) async {
debugDefaultTargetPlatformOverride = TargetPlatform.iOS;
await tester.pumpWidget(const ProviderScope(child: CupertinoApp(home: SettingsPage())));
await tester.tap(find.text('Profile'));
await tester.pumpAndSettle();
expect(find.byType(ProfilePage), findsOneWidget);
debugDefaultTargetPlatformOverride = null;
});
flutter build ios --release --split-debug-info=build/debug-info --obfuscate
flutter build ipa --release --export-method=app-store
| AI 借口 | 实际检查 | 严重度 | | --- | --- | --- | | "Material 在 iOS 也行" | iOS 是否 Cupertino? | 高 | | "不需要 ATT" | 涉广告追踪是否实现 ATT? | 高 | | "权限直接请求" | Info.plist 描述是否完整? | 高 | | "BackdropFilter 随便用" | 使用范围是否受控? | 中 | | "120fps 自动" | ProMotion 上是否实测无掉帧? | 中 | | "隐私清单不重要" | iOS 17+ 必需 PrivacyInfo.xcprivacy | 高 |
CupertinoAppPrivacyInfo.xcprivacy 完整NS*UsageDescription 完整TargetPlatform.iOS 覆盖Skills(flutter:core) / Skills(flutter:ui) / Skills(flutter:state)tools
--- 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 内部) 互补.