Tablet UI in progress

This commit is contained in:
estevez-dev 2019-09-10 15:40:49 +03:00
parent d5baabdd53
commit 9c28b0085b
2 changed files with 76 additions and 21 deletions

View File

@ -113,4 +113,5 @@ class Sizes {
static const inputWidth = 160.0; static const inputWidth = 160.0;
static const rowPadding = 10.0; static const rowPadding = 10.0;
static const doubleRowPadding = rowPadding*2; static const doubleRowPadding = rowPadding*2;
static const minViewColumnWidth = 350;
} }

View File

@ -32,9 +32,19 @@ class ViewWidgetState extends State<ViewWidget> {
); );
} else { } else {
return ListView( return ListView(
padding: EdgeInsets.all(0.0), shrinkWrap: true,
//physics: const AlwaysScrollableScrollPhysics(), padding: EdgeInsets.all(0),
children: _buildChildren(context), children: <Widget>[
ConstrainedBox(
constraints: BoxConstraints(maxHeight: 3000),
child: CustomMultiChildLayout(
delegate: ViewLayoutBuilder(
cardsCount: widget.view.cards.length
),
children: _buildChildren(context),
),
)
],
); );
} }
} }
@ -49,34 +59,31 @@ class ViewWidgetState extends State<ViewWidget> {
List<Widget> _buildChildren(BuildContext context) { List<Widget> _buildChildren(BuildContext context) {
List<Widget> result = []; List<Widget> result = [];
int layoutChildId = 0;
if (widget.view.badges.isNotEmpty) { if (widget.view.badges.isNotEmpty) {
result.insert(0, result.add(
Wrap( LayoutId(
alignment: WrapAlignment.center, id: "badges",
spacing: 10.0, child: Wrap(
runSpacing: 1.0, alignment: WrapAlignment.center,
children: _buildBadges(context), spacing: 10.0,
runSpacing: 1.0,
children: _buildBadges(context),
),
) )
); );
} }
List<Widget> cards = [];
widget.view.cards.forEach((HACard card){ widget.view.cards.forEach((HACard card){
cards.add( result.add(
ConstrainedBox( LayoutId(
constraints: BoxConstraints(maxWidth: 500), id: 'card_$layoutChildId',
child: card.build(context), child: card.build(context),
) )
); );
layoutChildId += 1;
}); });
result.add(
Column (
children: cards,
)
);
return result; return result;
} }
@ -84,7 +91,9 @@ class ViewWidgetState extends State<ViewWidget> {
List<Widget> result = []; List<Widget> result = [];
widget.view.badges.forEach((Entity entity) { widget.view.badges.forEach((Entity entity) {
if (!entity.isHidden) { if (!entity.isHidden) {
result.add(entity.buildBadgeWidget(context)); result.add(
entity.buildBadgeWidget(context)
);
} }
}); });
return result; return result;
@ -95,5 +104,50 @@ class ViewWidgetState extends State<ViewWidget> {
super.dispose(); super.dispose();
} }
}
class ViewLayoutBuilder extends MultiChildLayoutDelegate {
final int cardsCount;
ViewLayoutBuilder({@required this.cardsCount});
@override
void performLayout(Size size) {
int columnsCount = (size.width ~/ Sizes.minViewColumnWidth);
double columnWidth = size.width / columnsCount;
List<double> columnXPositions = [];
List<double> columnYPositions = [];
double startY = 0;
if (hasChild("badges")) {
Size badgesSizes = layoutChild(
'badges', BoxConstraints.tightFor(width: size.width));
startY += badgesSizes.height;
positionChild('badges', Offset(0, 0));
}
for (int i =0; i < columnsCount; i++) {
columnXPositions.add(i*columnWidth);
columnYPositions.add(startY);
}
for (int i = 0; i < cardsCount; i++) {
final String cardId = 'card_$i';
if (hasChild(cardId)) {
int columnToAdd = 0;
double minYPosition = columnYPositions[0];
for (int i=1; i<columnsCount; i++) {
if (columnYPositions[i] < minYPosition) {
minYPosition = columnYPositions[i];
columnToAdd = i;
}
}
Size newSize = layoutChild(
'$cardId', BoxConstraints.tightFor(width: columnWidth));
positionChild('$cardId', Offset(columnXPositions[columnToAdd], columnYPositions[columnToAdd]));
columnYPositions[columnToAdd] = minYPosition + newSize.height;
}
}
}
@override
bool shouldRelayout(MultiChildLayoutDelegate oldDelegate) => false;
} }