46 lines
1.4 KiB
Dart
46 lines
1.4 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:mobile_nebula/services/utils.dart';
|
|
|
|
import 'ConfigHeader.dart';
|
|
|
|
class ConfigSection extends StatelessWidget {
|
|
const ConfigSection({Key? key, this.label, required this.children, this.borderColor, this.labelColor})
|
|
: super(key: key);
|
|
|
|
final List<Widget> children;
|
|
final String? label;
|
|
final Color? borderColor;
|
|
final Color? labelColor;
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
final border = BorderSide(color: borderColor ?? Utils.configSectionBorder(context));
|
|
|
|
List<Widget> _children = [];
|
|
final len = children.length;
|
|
|
|
for (var i = 0; i < len; i++) {
|
|
_children.add(children[i]);
|
|
|
|
if (i < len - 1) {
|
|
double pad = 15;
|
|
if (children[i + 1].runtimeType.toString() == 'ConfigButtonItem') {
|
|
pad = 0;
|
|
}
|
|
_children.add(Padding(
|
|
child: Divider(height: 1, color: Utils.configSectionBorder(context)), padding: EdgeInsets.only(left: pad)));
|
|
}
|
|
}
|
|
|
|
return Column(crossAxisAlignment: CrossAxisAlignment.start, children: [
|
|
label != null ? ConfigHeader(label: label!, color: labelColor) : Container(height: 20),
|
|
Container(
|
|
decoration:
|
|
BoxDecoration(border: Border(top: border, bottom: border), color: Utils.configItemBackground(context)),
|
|
child: Column(
|
|
children: _children,
|
|
))
|
|
]);
|
|
}
|
|
}
|