mirror of
https://github.com/meshtastic/Meshtastic-Apple.git
synced 2026-04-20 22:13:56 +00:00
95 lines
3.1 KiB
Swift
95 lines
3.1 KiB
Swift
//
|
|
// NodeMap.swift
|
|
// MeshtasticApple
|
|
//
|
|
// Created by Garth Vander Houwen on 8/7/21.
|
|
//
|
|
|
|
import SwiftUI
|
|
import MapKit
|
|
import CoreLocation
|
|
import CoreData
|
|
|
|
struct NodeMap: View {
|
|
|
|
@Environment(\.managedObjectContext) var context
|
|
@EnvironmentObject var bleManager: BLEManager
|
|
@EnvironmentObject var userSettings: UserSettings
|
|
@AppStorage("meshMapType") var type: String = "hybrid"
|
|
@AppStorage("meshMapCustomTileServer") var customTileServer: String = "" {
|
|
didSet {
|
|
if customTileServer == "" {
|
|
self.customMapOverlay = nil
|
|
} else {
|
|
self.customMapOverlay = MapViewSwiftUI.CustomMapOverlay(
|
|
mapName: customTileServer,
|
|
tileType: "png",
|
|
canReplaceMapContent: true
|
|
)
|
|
}
|
|
}
|
|
}
|
|
@FetchRequest(sortDescriptors: [NSSortDescriptor(key: "time", ascending: false)], animation: .default)
|
|
private var positions: FetchedResults<PositionEntity>
|
|
|
|
@FetchRequest(sortDescriptors: [NSSortDescriptor(key: "name", ascending: false)], animation: .default)
|
|
private var waypoints: FetchedResults<WaypointEntity>
|
|
|
|
@State private var mapType: MKMapType = .standard
|
|
@State var waypointCoordinate: CLLocationCoordinate2D?
|
|
@State private var presentingWaypointForm = false
|
|
@State private var customMapOverlay: MapViewSwiftUI.CustomMapOverlay? = MapViewSwiftUI.CustomMapOverlay(
|
|
mapName: "offlinemap",
|
|
tileType: "png",
|
|
canReplaceMapContent: true
|
|
)
|
|
@State private var overlays: [MapViewSwiftUI.Overlay] = []
|
|
|
|
var body: some View {
|
|
|
|
NavigationStack {
|
|
ZStack {
|
|
|
|
MapViewSwiftUI(onMarkerTap: { coord in
|
|
presentingWaypointForm = true
|
|
waypointCoordinate = coord
|
|
}, positions: Array(positions), waypoints: Array(waypoints), region: MKCoordinateRegion(center: LocationHelper.currentLocation, span: MKCoordinateSpan(latitudeDelta: 0.005, longitudeDelta: 0.005)), mapViewType: mapType,
|
|
customMapOverlay: self.customMapOverlay,
|
|
overlays: self.overlays
|
|
)
|
|
VStack {
|
|
Spacer()
|
|
Picker("Map Type", selection: $mapType) {
|
|
Text("Standard").tag(MKMapType.standard)
|
|
Text("Standard Muted").tag(MKMapType.mutedStandard)
|
|
Text("Hybrid").tag(MKMapType.hybrid)
|
|
Text("Hybrid Flyover").tag(MKMapType.hybridFlyover)
|
|
Text("Satellite").tag(MKMapType.satellite)
|
|
Text("Satellite Flyover").tag(MKMapType.satelliteFlyover)
|
|
}
|
|
.pickerStyle(.menu)
|
|
}
|
|
}
|
|
.ignoresSafeArea(.all, edges: [.top, .leading, .trailing])
|
|
.frame(maxHeight: .infinity)
|
|
.sheet(isPresented: $presentingWaypointForm ) {//, onDismiss: didDismissSheet) {
|
|
WaypointFormView(coordinate: waypointCoordinate ?? LocationHelper.DefaultLocation)
|
|
.presentationDetents([.medium, .large])
|
|
.presentationDragIndicator(.automatic)
|
|
}
|
|
}
|
|
.navigationBarItems(leading:
|
|
MeshtasticLogo(), trailing:
|
|
ZStack {
|
|
ConnectedDevice(
|
|
bluetoothOn: bleManager.isSwitchedOn,
|
|
deviceConnected: bleManager.connectedPeripheral != nil,
|
|
name: (bleManager.connectedPeripheral != nil) ? bleManager.connectedPeripheral.shortName :
|
|
"????")
|
|
})
|
|
.onAppear(perform: {
|
|
self.bleManager.context = context
|
|
self.bleManager.userSettings = userSettings
|
|
})
|
|
}
|
|
}
|