New issue
Advanced search Search tips

Issue 777978 link

Starred by 1 user

Issue metadata

Status: Fixed
Owner: ----
Closed: Nov 2017
Cc:
Components:
EstimatedDays: ----
NextAction: ----
OS: ----
Pri: 3
Type: Bug

Blocking:
issue 273898



Sign in to add a comment

[css-grid] Positioned element with grid container as containing block wrongly uses grid padding for static position

Project Member Reported by r...@igalia.com, Oct 24 2017

Issue description


Check the attached example.
It has a positioned element which is the child of a grid item.
This positioned element has "grid-column|row: 1",
so it starts on the first line.
The positioned element doesn't have offset properties,
so it should be placed on the static position.
The static position should be exactly below the word "item"
and aligned on the left to the item's start (line 1).
However, it uses the grid container padding to shift the position,
which is wrong.
 
grid-issue-positioned-element.html
445 bytes View Download
grid-issue-positioned-element.png
7.9 KB View Download
Project Member

Comment 1 by bugdroid1@chromium.org, Nov 10 2017

The following revision refers to this bug:
  https://chromium.googlesource.com/chromium/src.git/+/6dc4cef851061c3421ba4b05e51a37beb1364f38

commit 6dc4cef851061c3421ba4b05e51a37beb1364f38
Author: Javier Fernandez <jfernandez@igalia.com>
Date: Fri Nov 10 01:01:48 2017

[css-grid] Implement the alignment logic for positioned items

We are changing how we compute the grid area's size of positioned
items, trying to make the logic as independent as possible of the
grid container's direction.
 
The new way of placing absolute positioned elements in their grid area
is based on the previously computed area's size. This provide a
mechanism to place an item in its area respecting the offsets derived
from the Content Alignment CSS properties and, which is more important,
ignoring the grid container's direction.

Additionally, we use the already implemented alignment logic that's
used for regular grid items. This patch provides almost full alignment
capabilities for positioned objects, with the exception of 'stretch'.

It's worth mentioning that some of the test cases using vertical-rl
writing mode will fail because of the bug 779105.

Bug:  603423 ,  777978 

Change-Id: I8fb121418795244d13589d603007c70f58e1f2df
Reviewed-on: https://chromium-review.googlesource.com/672423
Reviewed-by: Manuel Rego Casasnovas <rego@igalia.com>
Commit-Queue: Javier Fernandez <jfernandez@igalia.com>
Cr-Commit-Position: refs/heads/master@{#515391}
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-column-axis-alignment-positioned-items-001.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-column-axis-alignment-positioned-items-002.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-column-axis-alignment-positioned-items-003.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-column-axis-alignment-positioned-items-004.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-column-axis-alignment-positioned-items-005.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-column-axis-alignment-positioned-items-006.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-column-axis-alignment-positioned-items-007.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-column-axis-alignment-positioned-items-008.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-column-axis-alignment-positioned-items-009.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-column-axis-alignment-positioned-items-010.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-column-axis-alignment-positioned-items-011.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-column-axis-alignment-positioned-items-012.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-column-axis-alignment-positioned-items-013.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-column-axis-alignment-positioned-items-014.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-column-axis-alignment-positioned-items-015.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-column-axis-alignment-positioned-items-016.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-row-axis-alignment-positioned-items-001.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-row-axis-alignment-positioned-items-002.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-row-axis-alignment-positioned-items-003.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-row-axis-alignment-positioned-items-004.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-row-axis-alignment-positioned-items-005.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-row-axis-alignment-positioned-items-006.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-row-axis-alignment-positioned-items-007.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-row-axis-alignment-positioned-items-008.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-row-axis-alignment-positioned-items-009.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-row-axis-alignment-positioned-items-010.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-row-axis-alignment-positioned-items-011.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-row-axis-alignment-positioned-items-012.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-row-axis-alignment-positioned-items-013.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-row-axis-alignment-positioned-items-014.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-row-axis-alignment-positioned-items-015.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-row-axis-alignment-positioned-items-016.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-non-static-positioned-items-001.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-non-static-positioned-items-002.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-non-static-positioned-items-003.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-non-static-positioned-items-004.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-non-static-positioned-items-005.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-non-static-positioned-items-006.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-non-static-positioned-items-007.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-non-static-positioned-items-008.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-non-static-positioned-items-009-expected.txt
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-non-static-positioned-items-009.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-non-static-positioned-items-010-expected.txt
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-non-static-positioned-items-010.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-non-static-positioned-items-011-expected.txt
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-non-static-positioned-items-011.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-non-static-positioned-items-012-expected.txt
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-non-static-positioned-items-012.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-positioned-items-with-margin-border-padding-001.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-positioned-items-with-margin-border-padding-002.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-positioned-items-with-margin-border-padding-003.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-positioned-items-with-margin-border-padding-004.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-positioned-items-with-margin-border-padding-005.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-positioned-items-with-margin-border-padding-006.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-positioned-items-with-margin-border-padding-007.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-positioned-items-with-margin-border-padding-008.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-positioned-items-with-margin-border-padding-009.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-positioned-items-with-margin-border-padding-010.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-positioned-items-with-margin-border-padding-011.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-positioned-items-with-margin-border-padding-012.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-positioned-items-with-margin-border-padding-013.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-positioned-items-with-margin-border-padding-014.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-positioned-items-with-margin-border-padding-015.html
[add] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/LayoutTests/external/wpt/css/css-grid-1/alignment/grid-self-alignment-positioned-items-with-margin-border-padding-016.html
[modify] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/Source/core/layout/GridLayoutUtils.cpp
[modify] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/Source/core/layout/GridLayoutUtils.h
[modify] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/Source/core/layout/GridTrackSizingAlgorithm.cpp
[modify] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/Source/core/layout/LayoutGrid.cpp
[modify] https://crrev.com/6dc4cef851061c3421ba4b05e51a37beb1364f38/third_party/WebKit/Source/core/layout/LayoutGrid.h

Status: Fixed (was: Available)
This issue should be FIXED now.

Sign in to add a comment