A simple and cross-platform SFSymbol picker for SwiftUI
SymbolPicker provides a simple and cross-platform interface for picking a SFSymbol. SymbolPicker is implemented with SwiftUI and supports iOS, macOS, watchOS, tvOS and visionOS platforms.
- iOS 16.0+ / macOS 13.0+ / watchOS 9.0+ / tvOS 16.0+ / visionOS 1.0+
- Xcode 16.0+
- Swift 6.0+
SymbolPicker is available as a Swift Package. Add this repo to your project through Xcode GUI or Package.swift.
dependencies: [
    .package(url: "https://github.com/xnth97/SymbolPicker.git", .upToNextMajor(from: "1.6.0"))
]It is suggested to use SymbolPicker within a sheet.
import SwiftUI
import SymbolPicker
struct ContentView: View {
    @State private var iconPickerPresented = false
    @State private var icon = "pencil"
    var body: some View {
        Button {
            iconPickerPresented = true
        } label: {
            HStack {
                Image(systemName: icon)
                Text(icon)
            }
        }
        .sheet(isPresented: $iconPickerPresented) {
            SymbolPicker(symbol: $icon)
        }
    }
}- Categories support
- Multiplatform support
- Platform availability support
- Codegen from latest SF Symbols
- Nullable symbol
SymbolPicker is available under the MIT license. See the LICENSE file for more info.

