From 9054af6da9fc43ffb42edcf6e9600e05e5be8947 Mon Sep 17 00:00:00 2001 From: tylandercasper <5085108+tylandercasper@users.noreply.github.com> Date: Wed, 28 Aug 2024 08:04:54 -0500 Subject: [PATCH] AbsolutePositioned children don't expand the layout This allows constraints such as center or stretch to work the same way they do in Figma --- lib/figma_auto_layout.dart | 36 +++++++++++++----------------------- 1 file changed, 13 insertions(+), 23 deletions(-) diff --git a/lib/figma_auto_layout.dart b/lib/figma_auto_layout.dart index cc74d60..aba3f9e 100644 --- a/lib/figma_auto_layout.dart +++ b/lib/figma_auto_layout.dart @@ -1,6 +1,7 @@ library figma_auto_layout; import 'package:flutter/material.dart'; +import 'package:flutter/widgets.dart'; import 'package:signed_spacing_flex/signed_spacing_flex.dart'; export 'package:signed_spacing_flex/signed_spacing_flex.dart' @@ -275,13 +276,11 @@ class FigmaAutoLayout extends FigmaAutoLayoutChild { return newChildren; } - /// Generates a list of absolute positioned children at their appropriate positions - /// to be displayed on top of the normal children. - List _buildPositionedChildrenUnderneath(BuildContext context) { + List _buildPositionedChildren(BuildContext context, bool showOnTop) { var newChildren = []; for (final child in children) { - if (child.hasAbsolutePosition && !child.showOnTop) { + if (child.hasAbsolutePosition && child.showOnTop == showOnTop) { newChildren.add( Positioned.directional( textDirection: _getTextDirection(context), @@ -294,29 +293,20 @@ class FigmaAutoLayout extends FigmaAutoLayoutChild { ); } } - return newChildren; + if (newChildren.isEmpty) return []; + return [Positioned.fill(child: Stack(children: newChildren))]; + } + + /// Generates a list of absolute positioned children at their appropriate positions + /// to be displayed on top of the normal children. + List _buildPositionedChildrenUnderneath(BuildContext context) { + return _buildPositionedChildren(context, false); } /// Generates a list of absolute positioned children at their appropriate positions. /// to be displayed underneath the normal children. List _buildPositionedChildrenOnTop(BuildContext context) { - var newChildren = []; - - for (final child in children) { - if (child.hasAbsolutePosition && child.showOnTop) { - newChildren.add( - Positioned.directional( - textDirection: _getTextDirection(context), - start: child.start, - top: child.top, - end: child.end, - bottom: child.bottom, - child: child, - ), - ); - } - } - return newChildren; + return _buildPositionedChildren(context, true); } @override @@ -344,7 +334,7 @@ class FigmaAutoLayout extends FigmaAutoLayoutChild { ), ), ), - ..._buildPositionedChildrenOnTop(context), + ..._buildPositionedChildrenOnTop(context) ], ); }