Change your List
to store an IconData
instead of a String
:
List<Map<String, IconData>> _categories = [
{
'name': 'Sports',
'icon': Icons.directions_run,
},
{
'name': 'Politics',
'icon': Icons.gavel,
},
{
'name': 'Science',
'icon': Icons.wb_sunny,
},
];
Then, call the IconData
from your build method:
Widget _buildCategoryCards(BuildContext context, int index) {
return Container(
padding: EdgeInsets.symmetric(vertical: 5.0),
child: Card(
child: Container(
padding: EdgeInsets.all(15.0),
child: Row(
children: <Widget>[
Icon(_categories[index]['icon']),
SizedBox(width: 20.0),
Text(_categories[index]['name']),
],
),
),
),
);
}
Note that this is not useful (even not effecient) to use a Map
to do what you want. You should use a custom class:
Class Category {
String name;
IconData icon;
Category(this.name, this.icon);
}
And then replace your List
with this:
List<Category> _categories = [
Category('Sports', Icons.directions_run),
Category('Politics', Icons.gavel),
Category('Science', Icons.wb_sunny),
];
finally in your Widget:
children: <Widget>[
Icon(_categories[index].icon),
SizedBox(width: 20.0),
Text(_categories[index].name),
],