Part of speech highlighting when tapped from dictionary list
This commit is contained in:
parent
c7f50a4d3a
commit
d5e3d29225
@ -7,12 +7,13 @@
|
|||||||
objects = {
|
objects = {
|
||||||
|
|
||||||
/* Begin PBXBuildFile section */
|
/* Begin PBXBuildFile section */
|
||||||
|
7E20D5FF2733AFE700D75B9A /* PartsOfSpeechView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7E20D5FE2733AFE700D75B9A /* PartsOfSpeechView.swift */; };
|
||||||
|
7E20D6012734466800D75B9A /* TokiDictionaryViewModel.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7E20D6002734466800D75B9A /* TokiDictionaryViewModel.swift */; };
|
||||||
7E2811172733027F0063DC78 /* TokiDictionary.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7E2811142733027F0063DC78 /* TokiDictionary.swift */; };
|
7E2811172733027F0063DC78 /* TokiDictionary.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7E2811142733027F0063DC78 /* TokiDictionary.swift */; };
|
||||||
7E2811182733027F0063DC78 /* TokiJSONLoader.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7E2811152733027F0063DC78 /* TokiJSONLoader.swift */; };
|
7E2811182733027F0063DC78 /* TokiJSONLoader.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7E2811152733027F0063DC78 /* TokiJSONLoader.swift */; };
|
||||||
7E2811192733027F0063DC78 /* TokiPartOfSpeech.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7E2811162733027F0063DC78 /* TokiPartOfSpeech.swift */; };
|
7E2811192733027F0063DC78 /* TokiPartOfSpeech.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7E2811162733027F0063DC78 /* TokiPartOfSpeech.swift */; };
|
||||||
7E28111C273302860063DC78 /* toki-partsofspeech.json in Resources */ = {isa = PBXBuildFile; fileRef = 7E28111A273302860063DC78 /* toki-partsofspeech.json */; };
|
7E28111C273302860063DC78 /* toki-partsofspeech.json in Resources */ = {isa = PBXBuildFile; fileRef = 7E28111A273302860063DC78 /* toki-partsofspeech.json */; };
|
||||||
7E28111D273302860063DC78 /* toki-dictionary.json in Resources */ = {isa = PBXBuildFile; fileRef = 7E28111B273302860063DC78 /* toki-dictionary.json */; };
|
7E28111D273302860063DC78 /* toki-dictionary.json in Resources */ = {isa = PBXBuildFile; fileRef = 7E28111B273302860063DC78 /* toki-dictionary.json */; };
|
||||||
7E281120273303220063DC78 /* TokiPartsOfSpeechProvider.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7E28111F273303220063DC78 /* TokiPartsOfSpeechProvider.swift */; };
|
|
||||||
7E28112227330DD30063DC78 /* Constants.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7E28112127330DD20063DC78 /* Constants.swift */; };
|
7E28112227330DD30063DC78 /* Constants.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7E28112127330DD20063DC78 /* Constants.swift */; };
|
||||||
7E943A21273211C200E7DDF4 /* Toki_TrainerApp.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7E943A20273211C200E7DDF4 /* Toki_TrainerApp.swift */; };
|
7E943A21273211C200E7DDF4 /* Toki_TrainerApp.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7E943A20273211C200E7DDF4 /* Toki_TrainerApp.swift */; };
|
||||||
7E943A23273211C200E7DDF4 /* ContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7E943A22273211C200E7DDF4 /* ContentView.swift */; };
|
7E943A23273211C200E7DDF4 /* ContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7E943A22273211C200E7DDF4 /* ContentView.swift */; };
|
||||||
@ -23,12 +24,13 @@
|
|||||||
/* End PBXBuildFile section */
|
/* End PBXBuildFile section */
|
||||||
|
|
||||||
/* Begin PBXFileReference section */
|
/* Begin PBXFileReference section */
|
||||||
|
7E20D5FE2733AFE700D75B9A /* PartsOfSpeechView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = PartsOfSpeechView.swift; sourceTree = "<group>"; };
|
||||||
|
7E20D6002734466800D75B9A /* TokiDictionaryViewModel.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = TokiDictionaryViewModel.swift; sourceTree = "<group>"; };
|
||||||
7E2811142733027F0063DC78 /* TokiDictionary.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = TokiDictionary.swift; sourceTree = "<group>"; };
|
7E2811142733027F0063DC78 /* TokiDictionary.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = TokiDictionary.swift; sourceTree = "<group>"; };
|
||||||
7E2811152733027F0063DC78 /* TokiJSONLoader.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = TokiJSONLoader.swift; sourceTree = "<group>"; };
|
7E2811152733027F0063DC78 /* TokiJSONLoader.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = TokiJSONLoader.swift; sourceTree = "<group>"; };
|
||||||
7E2811162733027F0063DC78 /* TokiPartOfSpeech.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = TokiPartOfSpeech.swift; sourceTree = "<group>"; };
|
7E2811162733027F0063DC78 /* TokiPartOfSpeech.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = TokiPartOfSpeech.swift; sourceTree = "<group>"; };
|
||||||
7E28111A273302860063DC78 /* toki-partsofspeech.json */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.json; path = "toki-partsofspeech.json"; sourceTree = "<group>"; };
|
7E28111A273302860063DC78 /* toki-partsofspeech.json */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.json; path = "toki-partsofspeech.json"; sourceTree = "<group>"; };
|
||||||
7E28111B273302860063DC78 /* toki-dictionary.json */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.json; path = "toki-dictionary.json"; sourceTree = "<group>"; };
|
7E28111B273302860063DC78 /* toki-dictionary.json */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.json; path = "toki-dictionary.json"; sourceTree = "<group>"; };
|
||||||
7E28111F273303220063DC78 /* TokiPartsOfSpeechProvider.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = TokiPartsOfSpeechProvider.swift; sourceTree = "<group>"; };
|
|
||||||
7E28112127330DD20063DC78 /* Constants.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = Constants.swift; sourceTree = "<group>"; };
|
7E28112127330DD20063DC78 /* Constants.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = Constants.swift; sourceTree = "<group>"; };
|
||||||
7E943A1D273211C200E7DDF4 /* Toki Trainer.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = "Toki Trainer.app"; sourceTree = BUILT_PRODUCTS_DIR; };
|
7E943A1D273211C200E7DDF4 /* Toki Trainer.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = "Toki Trainer.app"; sourceTree = BUILT_PRODUCTS_DIR; };
|
||||||
7E943A20273211C200E7DDF4 /* Toki_TrainerApp.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Toki_TrainerApp.swift; sourceTree = "<group>"; };
|
7E943A20273211C200E7DDF4 /* Toki_TrainerApp.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Toki_TrainerApp.swift; sourceTree = "<group>"; };
|
||||||
@ -65,16 +67,17 @@
|
|||||||
children = (
|
children = (
|
||||||
7E943A20273211C200E7DDF4 /* Toki_TrainerApp.swift */,
|
7E943A20273211C200E7DDF4 /* Toki_TrainerApp.swift */,
|
||||||
7E943A22273211C200E7DDF4 /* ContentView.swift */,
|
7E943A22273211C200E7DDF4 /* ContentView.swift */,
|
||||||
|
7E20D5FE2733AFE700D75B9A /* PartsOfSpeechView.swift */,
|
||||||
);
|
);
|
||||||
path = Views;
|
path = Views;
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
};
|
};
|
||||||
7E281113273302530063DC78 /* States */ = {
|
7E281113273302530063DC78 /* ViewModels */ = {
|
||||||
isa = PBXGroup;
|
isa = PBXGroup;
|
||||||
children = (
|
children = (
|
||||||
7E28111F273303220063DC78 /* TokiPartsOfSpeechProvider.swift */,
|
7E20D6002734466800D75B9A /* TokiDictionaryViewModel.swift */,
|
||||||
);
|
);
|
||||||
path = States;
|
path = ViewModels;
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
};
|
};
|
||||||
7E28111E273302890063DC78 /* JSON Data */ = {
|
7E28111E273302890063DC78 /* JSON Data */ = {
|
||||||
@ -106,7 +109,7 @@
|
|||||||
isa = PBXGroup;
|
isa = PBXGroup;
|
||||||
children = (
|
children = (
|
||||||
7E28111E273302890063DC78 /* JSON Data */,
|
7E28111E273302890063DC78 /* JSON Data */,
|
||||||
7E281113273302530063DC78 /* States */,
|
7E281113273302530063DC78 /* ViewModels */,
|
||||||
7E2811122733024F0063DC78 /* Views */,
|
7E2811122733024F0063DC78 /* Views */,
|
||||||
7E281111273302420063DC78 /* Models */,
|
7E281111273302420063DC78 /* Models */,
|
||||||
7E943A24273211C300E7DDF4 /* Assets.xcassets */,
|
7E943A24273211C300E7DDF4 /* Assets.xcassets */,
|
||||||
@ -200,8 +203,9 @@
|
|||||||
files = (
|
files = (
|
||||||
7E943A2D273211C300E7DDF4 /* Toki_Trainer.xcdatamodeld in Sources */,
|
7E943A2D273211C300E7DDF4 /* Toki_Trainer.xcdatamodeld in Sources */,
|
||||||
7E943A2A273211C300E7DDF4 /* Persistence.swift in Sources */,
|
7E943A2A273211C300E7DDF4 /* Persistence.swift in Sources */,
|
||||||
|
7E20D5FF2733AFE700D75B9A /* PartsOfSpeechView.swift in Sources */,
|
||||||
|
7E20D6012734466800D75B9A /* TokiDictionaryViewModel.swift in Sources */,
|
||||||
7E2811192733027F0063DC78 /* TokiPartOfSpeech.swift in Sources */,
|
7E2811192733027F0063DC78 /* TokiPartOfSpeech.swift in Sources */,
|
||||||
7E281120273303220063DC78 /* TokiPartsOfSpeechProvider.swift in Sources */,
|
|
||||||
7E943A23273211C200E7DDF4 /* ContentView.swift in Sources */,
|
7E943A23273211C200E7DDF4 /* ContentView.swift in Sources */,
|
||||||
7E2811172733027F0063DC78 /* TokiDictionary.swift in Sources */,
|
7E2811172733027F0063DC78 /* TokiDictionary.swift in Sources */,
|
||||||
7E943A21273211C200E7DDF4 /* Toki_TrainerApp.swift in Sources */,
|
7E943A21273211C200E7DDF4 /* Toki_TrainerApp.swift in Sources */,
|
||||||
|
@ -8,28 +8,26 @@
|
|||||||
import Foundation
|
import Foundation
|
||||||
|
|
||||||
class TokiJSONLoader: ObservableObject {
|
class TokiJSONLoader: ObservableObject {
|
||||||
@Published var dictionary: [TokiDictEntry] = []
|
|
||||||
@Published var partsOfSpeech: [TokiPartOfSpeech] = []
|
|
||||||
|
|
||||||
func loadDictionary() {
|
func loadDictionary() -> [TokiDictEntry]? {
|
||||||
let jsonData = loadJSON("toki-dictionary")
|
let jsonData = loadJSON("toki-dictionary")
|
||||||
do {
|
do {
|
||||||
let decodedData = try JSONDecoder().decode([TokiDictEntry].self, from: jsonData!)
|
let decodedData = try JSONDecoder().decode([TokiDictEntry].self, from: jsonData!)
|
||||||
dictionary = decodedData
|
return decodedData
|
||||||
} catch {
|
} catch {
|
||||||
print("Decode error: \(error)")
|
print("Decode error: \(error)")
|
||||||
return
|
return nil
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func loadPOS() {
|
func loadPOS() -> [TokiPartOfSpeech]? {
|
||||||
let jsonData = loadJSON("toki-partsofspeech")
|
let jsonData = loadJSON("toki-partsofspeech")
|
||||||
do {
|
do {
|
||||||
let decodedData = try JSONDecoder().decode([TokiPartOfSpeech].self, from: jsonData!)
|
let decodedData = try JSONDecoder().decode([TokiPartOfSpeech].self, from: jsonData!)
|
||||||
partsOfSpeech = decodedData
|
return decodedData
|
||||||
} catch {
|
} catch {
|
||||||
print("Decode error: \(error)")
|
print("Decode error: \(error)")
|
||||||
return
|
return nil
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,8 +0,0 @@
|
|||||||
//
|
|
||||||
// TokiPartsOfSpeechProvider.swift
|
|
||||||
// Toki Trainer
|
|
||||||
//
|
|
||||||
// Created by Avery Ada Pace on 11/3/21.
|
|
||||||
//
|
|
||||||
|
|
||||||
import Foundation
|
|
25
Toki Trainer/ViewModels/TokiDictionaryViewModel.swift
Normal file
25
Toki Trainer/ViewModels/TokiDictionaryViewModel.swift
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
//
|
||||||
|
// TokiDictionaryViewModel.swift
|
||||||
|
// Toki Trainer
|
||||||
|
//
|
||||||
|
// Created by Avery Ada Pace on 11/4/21.
|
||||||
|
//
|
||||||
|
|
||||||
|
import Foundation
|
||||||
|
|
||||||
|
class TokiDictionaryViewModel: ObservableObject
|
||||||
|
{
|
||||||
|
let jsonLoader: TokiJSONLoader = TokiJSONLoader()
|
||||||
|
|
||||||
|
@Published var dictionary: [TokiDictEntry] = []
|
||||||
|
@Published var partsOfSpeech: [TokiPartOfSpeech] = []
|
||||||
|
|
||||||
|
init() {
|
||||||
|
if let safeDictionary = jsonLoader.loadDictionary() {
|
||||||
|
dictionary = safeDictionary
|
||||||
|
}
|
||||||
|
if let safePartsOfSpeech = jsonLoader.loadPOS() {
|
||||||
|
partsOfSpeech = safePartsOfSpeech
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -8,22 +8,30 @@
|
|||||||
import SwiftUI
|
import SwiftUI
|
||||||
import CoreData
|
import CoreData
|
||||||
|
|
||||||
|
extension String: Identifiable {
|
||||||
|
public var id: String { self }
|
||||||
|
}
|
||||||
|
|
||||||
struct ContentView: View {
|
struct ContentView: View {
|
||||||
|
@Environment(\.managedObjectContext) private var viewContext
|
||||||
|
|
||||||
@ObservedObject var jsonLoader = TokiJSONLoader()
|
@ObservedObject var tokiDictViewModel = TokiDictionaryViewModel()
|
||||||
|
@State private var selectedPartOfSpeech: String? = nil
|
||||||
|
|
||||||
var body: some View {
|
var body: some View {
|
||||||
VStack {
|
VStack {
|
||||||
TextField("Enter Toki Pona Word or Phrase", text: /*@START_MENU_TOKEN@*//*@PLACEHOLDER=Value@*/.constant("")/*@END_MENU_TOKEN@*/)
|
TextField("Enter Toki Pona Word or Phrase", text: /*@START_MENU_TOKEN@*//*@PLACEHOLDER=Value@*/.constant("")/*@END_MENU_TOKEN@*/)
|
||||||
.multilineTextAlignment(.center)
|
.multilineTextAlignment(.center)
|
||||||
.padding(8)
|
.padding(8)
|
||||||
List(jsonLoader.dictionary, id: \.word) { entry in
|
List(tokiDictViewModel.dictionary, id: \.word) { entry in
|
||||||
VStack(alignment: .leading) {
|
VStack(alignment: .leading) {
|
||||||
Text(entry.word)
|
Text(entry.word)
|
||||||
.font(.title)
|
.font(.title)
|
||||||
ForEach(entry.definitions, id: \.pos) { definition in
|
ForEach(entry.definitions, id: \.pos) { definition in
|
||||||
HStack(alignment: .top) {
|
HStack(alignment: .top) {
|
||||||
Button(action: openPartsOfSpeechView) {
|
Button(action: {
|
||||||
|
self.selectedPartOfSpeech = String(definition.pos)
|
||||||
|
}) {
|
||||||
Text(definition.pos)
|
Text(definition.pos)
|
||||||
.frame(width: 45, height: 22, alignment: .center)
|
.frame(width: 45, height: 22, alignment: .center)
|
||||||
.foregroundColor(.black)
|
.foregroundColor(.black)
|
||||||
@ -31,6 +39,7 @@ struct ContentView: View {
|
|||||||
.cornerRadius(5.0)
|
.cornerRadius(5.0)
|
||||||
.padding(4)
|
.padding(4)
|
||||||
}
|
}
|
||||||
|
.buttonStyle(BorderlessButtonStyle())
|
||||||
Text(definition.definition)
|
Text(definition.definition)
|
||||||
.fixedSize(horizontal: false, vertical: true)
|
.fixedSize(horizontal: false, vertical: true)
|
||||||
.padding(4)
|
.padding(4)
|
||||||
@ -40,19 +49,19 @@ struct ContentView: View {
|
|||||||
}
|
}
|
||||||
.safeAreaInset(edge: .bottom) {
|
.safeAreaInset(edge: .bottom) {
|
||||||
HStack() {
|
HStack() {
|
||||||
Button(action: openPartsOfSpeechView) {
|
Button("Parts of Speech") {
|
||||||
Text("Parts of Speech")
|
self.selectedPartOfSpeech = ""
|
||||||
}
|
}
|
||||||
.padding(8)
|
.padding(8)
|
||||||
}
|
}
|
||||||
.frame(maxWidth: .infinity)
|
.frame(maxWidth: .infinity)
|
||||||
.background(.thinMaterial)
|
.background(.thinMaterial)
|
||||||
}
|
}
|
||||||
.onAppear {
|
.sheet(item: $selectedPartOfSpeech) { selectedPOS in
|
||||||
self.jsonLoader.loadDictionary()
|
PartsOfSpeechView(selectedPartOfSpeech: selectedPOS, tokiDictViewModel: self.tokiDictViewModel)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func openPartsOfSpeechView() {
|
func openPartsOfSpeechView() {
|
||||||
print("Button pressed.")
|
print("Button pressed.")
|
||||||
|
49
Toki Trainer/Views/PartsOfSpeechView.swift
Normal file
49
Toki Trainer/Views/PartsOfSpeechView.swift
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
//
|
||||||
|
// PartsOfSpeechView.swift
|
||||||
|
// Toki Trainer
|
||||||
|
//
|
||||||
|
// Created by Avery Ada Pace on 11/4/21.
|
||||||
|
//
|
||||||
|
|
||||||
|
import SwiftUI
|
||||||
|
|
||||||
|
struct PartsOfSpeechView: View {
|
||||||
|
var selectedPartOfSpeech: String? = nil
|
||||||
|
|
||||||
|
@ObservedObject var tokiDictViewModel: TokiDictionaryViewModel
|
||||||
|
|
||||||
|
// init(selectedPartOfSpeech: String) {
|
||||||
|
// _selectedPartOfSpeech = State(initialValue: selectedPartOfSpeech)
|
||||||
|
// }
|
||||||
|
|
||||||
|
var body: some View {
|
||||||
|
VStack {
|
||||||
|
Text("Parts of Speech")
|
||||||
|
.padding()
|
||||||
|
VStack(alignment: .leading) {
|
||||||
|
ForEach(tokiDictViewModel.partsOfSpeech, id: \.pos) { pos in
|
||||||
|
HStack {
|
||||||
|
Text(pos.pos)
|
||||||
|
.frame(width: 45, height: 22, alignment: .center)
|
||||||
|
.background(Color(K.posColors[pos.pos]!))
|
||||||
|
.cornerRadius(5.0)
|
||||||
|
.padding(1)
|
||||||
|
Text(pos.definition)
|
||||||
|
Spacer()
|
||||||
|
}
|
||||||
|
//.background(.blue)
|
||||||
|
.background((selectedPartOfSpeech == pos.pos) ? Color(UIColor.systemGray4) : .white)
|
||||||
|
.cornerRadius(5.0)
|
||||||
|
.padding(2)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Spacer()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
struct PartsOfSpeechView_Previews: PreviewProvider {
|
||||||
|
static var previews: some View {
|
||||||
|
PartsOfSpeechView(selectedPartOfSpeech: "sep", tokiDictViewModel: TokiDictionaryViewModel())
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user