blob: 33598c3b1b8fe9f2039647c05187b2bd4aec7d55 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
|
//
// UnitsView.swift
// iosApp
//
// Created by Iván on 27/01/22.
// Copyright © 2022 orgName. All rights reserved.
//
import SwiftUI
import SwiftUIX
import shared
struct UnitsView: View {
@StateObject var unitsViewModel = UnitsViewModel()
@State var shouldShowMenu = false
var body: some View {
NavigationView {
TabView(selection: $unitsViewModel.unitsDisplayMode, content: {
MapView(unitsViewModel: unitsViewModel)
.tabItem {
Image(systemName: "map")
Text("map")
}
.tag(UnitsViewModel.UnitsDisplayMode.map)
DevicesView(unitsViewModel: unitsViewModel)
.tabItem {
Image(systemName: "list.bullet")
Text("devices")
}
.tag(UnitsViewModel.UnitsDisplayMode.list)
})
.navigationTitle(getNavigationTitle(unitsViewModel.unitsDisplayMode))
.navigationBarTitleDisplayMode(.inline)
.navigationSearchBar {
SearchBar(NSLocalizedString("search", comment: ""),
text: $unitsViewModel.searchQuery,
isEditing: $unitsViewModel.isEditing,
onCommit: {})
.showsCancelButton(unitsViewModel.isEditing)
.onCancel {
unitsViewModel.searchQuery = ""
}
}
.navigationSearchBarHiddenWhenScrolling(false)
.toolbar {
ToolbarItem(placement: .navigationBarTrailing) {
Menu {
Picker (selection: $unitsViewModel.mapLayerType, label: Text("Map layer")) {
Text("OpenStreetMap")
.tag(MapLayer.companion.layers[MapLayer.Type_.streets]!)
Text("Satellite")
.tag(MapLayer.companion.layers[MapLayer.Type_.satellite]!)
}
} label: {
Image(systemName: "square.stack.3d.up")
}
.visible(unitsViewModel.unitsDisplayMode == .map)
}
ToolbarItem(placement: .navigationBarTrailing) {
Button(action: {}) {
Image(systemName: "person")
}
}
}
}
}
private func getNavigationTitle(_ unitDisplayMode: UnitsViewModel.UnitsDisplayMode) -> LocalizedStringKey {
switch unitDisplayMode {
case .list:
return "devices"
case .map:
return "map"
}
}
}
|