SKILL.md
$2a
MaterialApp(
title: 'App Name',
theme: ThemeData(
useMaterial3: true,
colorScheme: ColorScheme.fromSeed(
seedColor: Colors.deepPurple,
brightness: Brightness.light,
),
// Use colorScheme.secondary instead of accentColor
),
darkTheme: ThemeData(
useMaterial3: true,
colorScheme: ColorScheme.fromSeed(
seedColor: Colors.deepPurple,
brightness: Brightness.dark,
),
),
home: const MyHomePage(),
);
-
Normalize Component Themes
Update all component theme definitions in ThemeData to use their *ThemeData equivalents. Do not use the base theme classes for configuration.
cardTheme->CardThemeData
dialogTheme->DialogThemeData
tabBarTheme->TabBarThemeData
appBarTheme->AppBarThemeData(ReplacecolorwithbackgroundColor)
bottomAppBarTheme->BottomAppBarThemeData
inputDecorationTheme->InputDecorationThemeData
ThemeData(
colorScheme: ColorScheme.fromSeed(seedColor: Colors.blue),
appBarTheme: const AppBarThemeData(
backgroundColor: Colors.blue, // Do not use 'color'
elevation: 4.0,
),
cardTheme: const CardThemeData(
elevation: 2.0,
),
);
-
Migrate Buttons and Button Styles
Replace legacy buttons. Use the styleFrom() static method for simple overrides, or ButtonStyle with MaterialStateProperty for state-dependent styling.
// Simple override using styleFrom
TextButton(
style: TextButton.styleFrom(
foregroundColor: Colors.blue,
disabledForegroundColor: Colors.red,
),
onPressed: () {},
child: const Text('TextButton'),
)
// State-dependent override using MaterialStateProperty
OutlinedButton(
style: ButtonStyle(
side: MaterialStateProperty.resolveWith<BorderSide>(
(Set<MaterialState> states) {
if (states.contains(MaterialState.pressed)) {
return const BorderSide(color: Colors.blue, width: 2);
}
return const BorderSide(color: Colors.grey, width: 1);
}
),
),
onPressed: () {},
child: const Text('OutlinedButton'),
)
-
Decision Logic: Platform Idioms
Apply platform-specific adaptations based on the host OS to reduce cognitive load and build user trust.
- Scrollbars: IF desktop platform -> Set
thumbVisibility: true(oralwaysShown). IF mobile -> Use default auto-hiding behavior.
- Text Selection: IF text is informational and non-interactive -> Wrap in
SelectableTextto allow mouse selection on Web/Desktop.
- Button Ordering: IF Windows -> Place confirmation button on the LEFT. IF macOS/Linux/Android/iOS -> Place confirmation button on the RIGHT.
// Platform-aware button ordering
TextDirection btnDirection = Platform.isWindows
? TextDirection.rtl
: TextDirection.ltr;
Row(
children: [
const Spacer(),
Row(
textDirection: btnDirection,
children: [
TextButton(
onPressed: () => Navigator.pop(context, false),
child: const Text('Cancel'),
),
ElevatedButton(
onPressed: () => Navigator.pop(context, true),
child: const Text('OK'),
),
],
),
],
)
-
Validate-and-Fix
Scan the generated code to verify that no FlatButton, RaisedButton, OutlineButton, or ButtonTheme classes remain. Verify that AppBarTheme does not use the color property. Fix any instances found.
Constraints
- Single Source of Truth: All colors must be derived from the
ColorScheme(e.g.,Theme.of(context).colorScheme.primary). Do not hardcode hex colors unless explicitly requested.
- No Legacy Buttons: Never output
FlatButton,RaisedButton, orOutlineButton.
- No Accent Properties: Never use
accentColor,accentColorBrightness,accentTextTheme, oraccentIconTheme. UsecolorScheme.secondaryandcolorScheme.onSecondaryinstead.
- Component Theme Suffixes: Always append
Datato component themes when configuringThemeData(e.g.,CardThemeData, notCardTheme).
- AppBar Background: Never use the
colorproperty inAppBarThemeorAppBarThemeData; strictly usebackgroundColor.