mirror of
https://github.com/meshtastic/Meshtastic-Apple.git
synced 2026-04-20 22:13:56 +00:00
131 lines
3.9 KiB
Swift
131 lines
3.9 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") private var meshMapType = "hybridFlyover"
|
|
@AppStorage("meshMapShowNodeHistory") private var meshMapShowNodeHistory = false
|
|
@AppStorage("meshMapShowRouteLines") private var meshMapShowRouteLines = false
|
|
|
|
@FetchRequest(sortDescriptors: [NSSortDescriptor(key: "time", ascending: true)],
|
|
predicate: NSPredicate(format: "time >= %@ && nodePosition != nil", Calendar.current.startOfDay(for: Date()) as NSDate), animation: .none)
|
|
private var positions: FetchedResults<PositionEntity>
|
|
|
|
@FetchRequest(sortDescriptors: [NSSortDescriptor(key: "name", ascending: false)],
|
|
predicate: NSPredicate(
|
|
format: "expire == nil || expire >= %@", Date() as NSDate
|
|
), animation: .none)
|
|
private var waypoints: FetchedResults<WaypointEntity>
|
|
|
|
@State private var mapType: MKMapType = .standard
|
|
@State var selectedTracking: UserTrackingModes = .none
|
|
@State var isPresentingInfoSheet: Bool = false
|
|
|
|
@State var waypointCoordinate: WaypointCoordinate?
|
|
@State private var customMapOverlay: MapViewSwiftUI.CustomMapOverlay? = MapViewSwiftUI.CustomMapOverlay(
|
|
mapName: "offlinemap",
|
|
tileType: "png",
|
|
canReplaceMapContent: true
|
|
)
|
|
|
|
var body: some View {
|
|
|
|
NavigationStack {
|
|
ZStack {
|
|
|
|
MapViewSwiftUI(
|
|
onLongPress: { coord in
|
|
waypointCoordinate = WaypointCoordinate(id: .init(), coordinate: coord, waypointId: 0)
|
|
}, onWaypointEdit: { wpId in
|
|
if wpId > 0 {
|
|
waypointCoordinate = WaypointCoordinate(id: .init(), coordinate: nil, waypointId: Int64(wpId))
|
|
}
|
|
},
|
|
positions: Array(positions),
|
|
waypoints: Array(waypoints),
|
|
mapViewType: mapType,
|
|
userTrackingMode: selectedTracking.MKUserTrackingModeValue(),
|
|
showNodeHistory: meshMapShowNodeHistory,
|
|
showRouteLines: meshMapShowRouteLines,
|
|
customMapOverlay: self.customMapOverlay
|
|
)
|
|
VStack(alignment: .trailing) {
|
|
|
|
HStack(alignment: .top) {
|
|
Spacer()
|
|
MapButtons(tracking: $selectedTracking, isPresentingInfoSheet: $isPresentingInfoSheet)
|
|
.padding(.trailing, 8)
|
|
.padding(.top, 16)
|
|
}
|
|
|
|
Spacer()
|
|
|
|
}
|
|
VStack {
|
|
Spacer()
|
|
Picker("Map Type", selection: $mapType) {
|
|
ForEach(MeshMapType.allCases) { map in
|
|
Text(map.description).tag(map.MKMapTypeValue())
|
|
}
|
|
}
|
|
.background(.thinMaterial, in: RoundedRectangle(cornerRadius: 12, style: .continuous))
|
|
.pickerStyle(.menu)
|
|
.padding(.bottom, 5)
|
|
}
|
|
}
|
|
.ignoresSafeArea(.all, edges: [.top, .leading, .trailing])
|
|
.frame(maxHeight: .infinity)
|
|
.sheet(item: $waypointCoordinate, content: { wpc in
|
|
WaypointFormView(coordinate: wpc)
|
|
.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: {
|
|
UIApplication.shared.isIdleTimerDisabled = true
|
|
self.bleManager.context = context
|
|
self.bleManager.userSettings = userSettings
|
|
switch meshMapType {
|
|
case "standard":
|
|
mapType = .standard
|
|
case "mutedStandard":
|
|
mapType = .mutedStandard
|
|
case "hybrid":
|
|
mapType = .hybrid
|
|
case "hybridFlyover":
|
|
mapType = .hybridFlyover
|
|
case "satellite":
|
|
mapType = .satellite
|
|
case "satelliteFlyover":
|
|
mapType = .satelliteFlyover
|
|
default:
|
|
mapType = .hybridFlyover
|
|
}
|
|
})
|
|
.onDisappear(perform: {
|
|
UIApplication.shared.isIdleTimerDisabled = false
|
|
})
|
|
}
|
|
}
|