mirror of
https://github.com/meshtastic/Meshtastic-Apple.git
synced 2026-04-20 22:13:56 +00:00
164 lines
6.4 KiB
Swift
164 lines
6.4 KiB
Swift
////
|
|
//// NodeMapControl.swift
|
|
//// Meshtastic
|
|
////
|
|
//// Created by Garth Vander Houwen on 9/9/23.
|
|
////
|
|
//import SwiftUI
|
|
//import CoreLocation
|
|
//import MapKit
|
|
//import WeatherKit
|
|
//import OSLog
|
|
//
|
|
//struct NodeMapMapkit: View {
|
|
//
|
|
// @Environment(\.managedObjectContext) var context
|
|
// @EnvironmentObject var bleManager: BLEManager
|
|
// /// Weather
|
|
// /// The current weather condition for the city.
|
|
// @State private var condition: WeatherCondition?
|
|
// @State private var temperature: Measurement<UnitTemperature>?
|
|
// @State private var humidity: Int?
|
|
// @State private var symbolName: String = "cloud.fill"
|
|
// @State private var attributionLink: URL?
|
|
// @State private var attributionLogo: URL?
|
|
//
|
|
// @Environment(\.colorScheme) var colorScheme: ColorScheme
|
|
// @AppStorage("meshMapType") private var meshMapType = 0
|
|
// @AppStorage("meshMapShowNodeHistory") private var meshMapShowNodeHistory = false
|
|
// @AppStorage("meshMapShowRouteLines") private var meshMapShowRouteLines = false
|
|
// @State private var selectedMapLayer: MapLayer = .standard
|
|
// @State var waypointCoordinate: WaypointCoordinate?
|
|
// @State var editingWaypoint: Int = 0
|
|
// @State private var customMapOverlay: MapViewSwiftUI.CustomMapOverlay? = MapViewSwiftUI.CustomMapOverlay(
|
|
// mapName: "offlinemap",
|
|
// tileType: "png",
|
|
// canReplaceMapContent: true
|
|
// )
|
|
// @FetchRequest(sortDescriptors: [NSSortDescriptor(key: "name", ascending: false)],
|
|
// predicate: NSPredicate(
|
|
// format: "expire == nil || expire >= %@", Date() as NSDate
|
|
// ), animation: .none)
|
|
// private var waypoints: FetchedResults<WaypointEntity>
|
|
// @ObservedObject var node: NodeInfoEntity
|
|
//
|
|
// var body: some View {
|
|
//
|
|
// NavigationStack {
|
|
// GeometryReader { bounds in
|
|
// VStack {
|
|
// if node.hasPositions {
|
|
// ZStack {
|
|
// let positionArray = node.positions?.array as? [PositionEntity] ?? []
|
|
// let lastTenThousand = Array(positionArray.prefix(10000))
|
|
// // let todaysPositions = positionArray.filter { $0.time! >= Calendar.current.startOfDay(for: Date()) }
|
|
// 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))
|
|
// }
|
|
// },
|
|
// selectedMapLayer: selectedMapLayer,
|
|
// positions: lastTenThousand,
|
|
// waypoints: Array(waypoints),
|
|
// userTrackingMode: MKUserTrackingMode.none,
|
|
// showNodeHistory: meshMapShowNodeHistory,
|
|
// showRouteLines: meshMapShowRouteLines,
|
|
// customMapOverlay: self.customMapOverlay
|
|
// )
|
|
// VStack(alignment: .leading) {
|
|
// Spacer()
|
|
// HStack(alignment: .bottom, spacing: 1) {
|
|
// Picker("Map Type", selection: $selectedMapLayer) {
|
|
// ForEach(MapLayer.allCases, id: \.self) { layer in
|
|
// if layer == MapLayer.offline && UserDefaults.enableOfflineMaps {
|
|
// Text(layer.localized)
|
|
// } else if layer != MapLayer.offline {
|
|
// Text(layer.localized)
|
|
// }
|
|
// }
|
|
// }
|
|
// .onChange(of: (selectedMapLayer)) { newMapLayer in
|
|
// UserDefaults.mapLayer = newMapLayer
|
|
// }
|
|
// .background(.thinMaterial, in: RoundedRectangle(cornerRadius: 12, style: .continuous))
|
|
// .pickerStyle(.menu)
|
|
// .padding(5)
|
|
// VStack {
|
|
// VStack {
|
|
// Label(temperature?.formatted(.measurement(width: .narrow)) ?? "??", systemImage: symbolName)
|
|
// .font(.caption)
|
|
//
|
|
// Label("\(humidity ?? 0)%", systemImage: "humidity")
|
|
// .font(.caption2)
|
|
//
|
|
// AsyncImage(url: attributionLogo) { image in
|
|
// image
|
|
// .resizable()
|
|
// .scaledToFit()
|
|
// } placeholder: {
|
|
// ProgressView()
|
|
// .controlSize(.mini)
|
|
// }
|
|
// .frame(height: 10)
|
|
//
|
|
// Link("Other data sources", destination: attributionLink ?? URL(string: "https://weather-data.apple.com/legal-attribution.html")!)
|
|
// .font(.caption2)
|
|
// }
|
|
// .padding(5)
|
|
//
|
|
// }
|
|
// .background(.thinMaterial, in: RoundedRectangle(cornerRadius: 12, style: .continuous))
|
|
// .padding(5)
|
|
// .task {
|
|
// do {
|
|
// if node.hasPositions {
|
|
// let mostRecent = node.positions?.lastObject as? PositionEntity
|
|
// let weather = try await WeatherService.shared.weather(for: mostRecent?.nodeLocation ?? CLLocation(latitude: LocationHelper.currentLocation.latitude, longitude: LocationHelper.currentLocation.longitude))
|
|
// condition = weather.currentWeather.condition
|
|
// temperature = weather.currentWeather.temperature
|
|
// humidity = Int(weather.currentWeather.humidity * 100)
|
|
// symbolName = weather.currentWeather.symbolName
|
|
// let attribution = try await WeatherService.shared.attribution
|
|
// attributionLink = attribution.legalPageURL
|
|
// attributionLogo = colorScheme == .light ? attribution.combinedMarkLightURL : attribution.combinedMarkDarkURL
|
|
// }
|
|
// } catch {
|
|
// Logger.services.error("Could not gather weather information: \(error.localizedDescription)")
|
|
// condition = .clear
|
|
// symbolName = "cloud.fill"
|
|
// }
|
|
// }
|
|
// }
|
|
// }
|
|
// }
|
|
// .ignoresSafeArea(.all, edges: [.top, .leading, .trailing])
|
|
// .frame(idealWidth: bounds.size.width, minHeight: bounds.size.height / 1.65)
|
|
// }
|
|
// } else {
|
|
// HStack {
|
|
// }
|
|
// .padding([.top], 20)
|
|
// }
|
|
// }
|
|
// .edgesIgnoringSafeArea([.leading, .trailing])
|
|
// .sheet(item: $waypointCoordinate, content: { wpc in
|
|
// WaypointFormMapKit(coordinate: wpc)
|
|
// .presentationDetents([.medium, .large])
|
|
// .presentationDragIndicator(.automatic)
|
|
// })
|
|
// .navigationBarTitle(String(node.user?.longName ?? "unknown".localized), displayMode: .inline)
|
|
// .navigationBarItems(trailing:
|
|
// ZStack {
|
|
// ConnectedDevice(
|
|
// bluetoothOn: bleManager.isSwitchedOn,
|
|
// deviceConnected: bleManager.connectedPeripheral != nil,
|
|
// name: (bleManager.connectedPeripheral != nil) ? bleManager.connectedPeripheral.shortName : "?")
|
|
// })
|
|
// }
|
|
// .padding(.bottom, 2)
|
|
// }
|
|
// }
|
|
//}
|