dragContainer(for:itemID:in:_:)
A container with draggable views.
Declaration
nonisolated func dragContainer<ItemID, Item, Data>(for itemType: Item.Type = Item.self, itemID: KeyPath<Item, ItemID>, in namespace: Namespace.ID? = nil, _ payload: @escaping (Array<ItemID>) -> Data) -> some View where ItemID : Hashable, ItemID : Sendable, Item : Transferable, Item == Data.Element, Data : Collection
Parameters
- itemType:
A type of the dragged items.
- itemID:
A closure that provides an item’s identifier.
- namespace:
A namespace that identifies the drag container.
- payload:
A closure which is called when a drag operation begins. As an argument, the closure receives either the identifiers of all the selected items, if the dragged item is a part of selection or only the identifier of the dragged item, if it is not part of the selection. Using the passed identifiers, put together the payload to drag, and return from the closure. Return an empty
Collectionto disable the drag.
Return Value
A view that can be activated as the source of a drag and drop operation, beginning with user gesture input.
Discussion
In an example below, an app presents a view with Fruit values. Fruit does not conform to Identifiable but uses its name as its identifier.
@State private var fruits: [Fruit]
@State private var selection: [String]
var body: some View {
VStack {
ForEach(fruits) { fruit in
FruitView(fruit)
.draggable(containerItemID: fruit.name)
}
}
.dragContainer(itemID: \Fruit.name) { ids in
fruits(with: ids)
}
}
func fruits(with ids: [String]) -> [Fruit] { ... }
struct Fruit: Transferable {
var name: String
...
}