Skip to content

[CdkDrag]: Allow out of scope binding with drop container #14099

@shlomiassaf

Description

@shlomiassaf

Bug, feature request, or proposal: proposal

What is the expected behavior?

CdkDrag accepts CdkDropListContainer as an @Input (in addition to the current injection logic)

What is the current behavior?

CdkDrag accepts CdkDropListContainer from DI (optional) or through direct assignment.

What is the use-case or motivation for changing an existing behavior?

When CdkDropListContainer comes from DI it requires the drop container to be a direct parent of the drag element.

When working with dynamic content (table, tree, select, or any "portal like" components) it is sometimes not possible to have the container and the drag element in a parent/descendant relationship.

For example: In a CdkTable dragging a header cell left/right having the header row as the drop container. The row and cell are not defined as parent/descendant in the template and the view creators will not pass the proper injectables in such case.

The current implementation does not require a drop container, it's optional. So adding an @Input is quite simple. The init only happen when actual dragging starts so it shouldn't be an issue.

The CdkDropList will require some modifications because it uses a template query to get all of the child drag items it manages. This is also doable... Maybe by having a flag that defines the work mode or another directive that does not use a template query.

When a drag item is assigned a drop container it will notify the container so it can store a ref to it... doing the same when the drag is destroyed or disconnected from the parent drop container.

Thanks!

Metadata

Metadata

Assignees

No one assigned

    Labels

    P4A relatively minor issue that is not relevant to core functionsarea: cdk/drag-dropfeatureThis issue represents a new feature or feature request rather than a bug or bug fix

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions