Sample/SwiftUI-MVVM/TicTacToe/Sources/GridStack.swift (29 lines of code) (raw):

// // Copyright (c) 2018. Uber Technologies // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // import SwiftUI struct GridStack<Content: View>: View { let rows: Int let columns: Int let spacing: CGFloat? let content: (Int, Int) -> Content var body: some View { VStack(spacing: spacing) { ForEach(0 ..< rows, id: \.self) { row in HStack(spacing: spacing) { ForEach(0 ..< columns, id: \.self) { column in content(row, column) } } } } } init( rows: Int, columns: Int, spacing: CGFloat? = nil, @ViewBuilder content: @escaping (Int, Int) -> Content ) { self.rows = rows self.columns = columns self.spacing = spacing self.content = content } }