ExpansionTile constructor

const ExpansionTile({
  1. Key? key,
  2. Widget? leading,
  3. required Widget title,
  4. Widget? subtitle,
  5. ValueChanged<bool>? onExpansionChanged,
  6. List<Widget> children = const <Widget>[],
  7. Widget? trailing,
  8. bool showTrailingIcon = true,
  9. bool initiallyExpanded = false,
  10. bool maintainState = false,
  11. EdgeInsetsGeometry? tilePadding,
  12. CrossAxisAlignment? expandedCrossAxisAlignment,
  13. Alignment? expandedAlignment,
  14. EdgeInsetsGeometry? childrenPadding,
  15. Color? backgroundColor,
  16. Color? collapsedBackgroundColor,
  17. Color? textColor,
  18. Color? collapsedTextColor,
  19. Color? iconColor,
  20. Color? collapsedIconColor,
  21. ShapeBorder? shape,
  22. ShapeBorder? collapsedShape,
  23. Clip? clipBehavior,
  24. ListTileControlAffinity? controlAffinity,
  25. ExpansionTileController? controller,
  26. bool? dense,
  27. VisualDensity? visualDensity,
  28. double? minTileHeight,
  29. bool? enableFeedback = true,
  30. bool enabled = true,
  31. AnimationStyle? expansionAnimationStyle,
  32. bool internalAddSemanticForOnTap = false,
})

Creates a single-line ListTile with an expansion arrow icon that expands or collapses the tile to reveal or hide the children. The initiallyExpanded property must be non-null.

Implementation

const ExpansionTile({
  super.key,
  this.leading,
  required this.title,
  this.subtitle,
  this.onExpansionChanged,
  this.children = const <Widget>[],
  this.trailing,
  this.showTrailingIcon = true,
  this.initiallyExpanded = false,
  this.maintainState = false,
  this.tilePadding,
  this.expandedCrossAxisAlignment,
  this.expandedAlignment,
  this.childrenPadding,
  this.backgroundColor,
  this.collapsedBackgroundColor,
  this.textColor,
  this.collapsedTextColor,
  this.iconColor,
  this.collapsedIconColor,
  this.shape,
  this.collapsedShape,
  this.clipBehavior,
  this.controlAffinity,
  this.controller,
  this.dense,
  this.visualDensity,
  this.minTileHeight,
  this.enableFeedback = true,
  this.enabled = true,
  this.expansionAnimationStyle,
  this.internalAddSemanticForOnTap = false,
}) : assert(
     expandedCrossAxisAlignment != CrossAxisAlignment.baseline,
     'CrossAxisAlignment.baseline is not supported since the expanded children '
         'are aligned in a column, not a row. Try to use another constant.',
     );