Refactor, decompose and add previews. Fix part of speech sheet pop over
This commit is contained in:
parent
aae0b6c87e
commit
5999cc3533
@ -35,7 +35,7 @@ struct Provider: IntentTimelineProvider {
|
|||||||
func getTimeline(for configuration: ConfigurationIntent, in context: Context, completion: @escaping (Timeline<Entry>) -> ()) {
|
func getTimeline(for configuration: ConfigurationIntent, in context: Context, completion: @escaping (Timeline<Entry>) -> ()) {
|
||||||
var entries: [DefinitionEntry] = []
|
var entries: [DefinitionEntry] = []
|
||||||
|
|
||||||
for i in 0...5 {
|
for _ in 0...5 {
|
||||||
entries.append(getRandomEntry(configuration: configuration))
|
entries.append(getRandomEntry(configuration: configuration))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -43,6 +43,9 @@
|
|||||||
7EBAE6AA273D65FD00BCFA09 /* toki-lessons.json in Resources */ = {isa = PBXBuildFile; fileRef = 7EBAE6A9273D65FD00BCFA09 /* toki-lessons.json */; };
|
7EBAE6AA273D65FD00BCFA09 /* toki-lessons.json in Resources */ = {isa = PBXBuildFile; fileRef = 7EBAE6A9273D65FD00BCFA09 /* toki-lessons.json */; };
|
||||||
7EF546162737B8FB00537AE6 /* FlashCardResultsView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7EF546152737B8FA00537AE6 /* FlashCardResultsView.swift */; };
|
7EF546162737B8FB00537AE6 /* FlashCardResultsView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7EF546152737B8FA00537AE6 /* FlashCardResultsView.swift */; };
|
||||||
E1D79AE328EC396200A104BF /* DictionaryView.swift in Sources */ = {isa = PBXBuildFile; fileRef = E1D79AE228EC396200A104BF /* DictionaryView.swift */; };
|
E1D79AE328EC396200A104BF /* DictionaryView.swift in Sources */ = {isa = PBXBuildFile; fileRef = E1D79AE228EC396200A104BF /* DictionaryView.swift */; };
|
||||||
|
E1D79AE528F1914600A104BF /* TranslatorView.swift in Sources */ = {isa = PBXBuildFile; fileRef = E1D79AE428F1914600A104BF /* TranslatorView.swift */; };
|
||||||
|
E1D79AE728F1925400A104BF /* TokiWordsListEntryView.swift in Sources */ = {isa = PBXBuildFile; fileRef = E1D79AE628F1925400A104BF /* TokiWordsListEntryView.swift */; };
|
||||||
|
E1D79AEB28F194EF00A104BF /* LanguageDirectionView.swift in Sources */ = {isa = PBXBuildFile; fileRef = E1D79AEA28F194EF00A104BF /* LanguageDirectionView.swift */; };
|
||||||
/* End PBXBuildFile section */
|
/* End PBXBuildFile section */
|
||||||
|
|
||||||
/* Begin PBXContainerItemProxy section */
|
/* Begin PBXContainerItemProxy section */
|
||||||
@ -102,6 +105,9 @@
|
|||||||
7EBAE6A9273D65FD00BCFA09 /* toki-lessons.json */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.json; path = "toki-lessons.json"; sourceTree = "<group>"; };
|
7EBAE6A9273D65FD00BCFA09 /* toki-lessons.json */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.json; path = "toki-lessons.json"; sourceTree = "<group>"; };
|
||||||
7EF546152737B8FA00537AE6 /* FlashCardResultsView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = FlashCardResultsView.swift; sourceTree = "<group>"; };
|
7EF546152737B8FA00537AE6 /* FlashCardResultsView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = FlashCardResultsView.swift; sourceTree = "<group>"; };
|
||||||
E1D79AE228EC396200A104BF /* DictionaryView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = DictionaryView.swift; sourceTree = "<group>"; };
|
E1D79AE228EC396200A104BF /* DictionaryView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = DictionaryView.swift; sourceTree = "<group>"; };
|
||||||
|
E1D79AE428F1914600A104BF /* TranslatorView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = TranslatorView.swift; sourceTree = "<group>"; };
|
||||||
|
E1D79AE628F1925400A104BF /* TokiWordsListEntryView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = TokiWordsListEntryView.swift; sourceTree = "<group>"; };
|
||||||
|
E1D79AEA28F194EF00A104BF /* LanguageDirectionView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = LanguageDirectionView.swift; sourceTree = "<group>"; };
|
||||||
/* End PBXFileReference section */
|
/* End PBXFileReference section */
|
||||||
|
|
||||||
/* Begin PBXFrameworksBuildPhase section */
|
/* Begin PBXFrameworksBuildPhase section */
|
||||||
@ -138,14 +144,13 @@
|
|||||||
7E2811122733024F0063DC78 /* Views */ = {
|
7E2811122733024F0063DC78 /* Views */ = {
|
||||||
isa = PBXGroup;
|
isa = PBXGroup;
|
||||||
children = (
|
children = (
|
||||||
|
E1D79AE828F1947F00A104BF /* WordListViews */,
|
||||||
7E943A20273211C200E7DDF4 /* Toki_TrainerApp.swift */,
|
7E943A20273211C200E7DDF4 /* Toki_TrainerApp.swift */,
|
||||||
7E943A22273211C200E7DDF4 /* ContentView.swift */,
|
7E943A22273211C200E7DDF4 /* ContentView.swift */,
|
||||||
7E20D5FE2733AFE700D75B9A /* PartsOfSpeechView.swift */,
|
|
||||||
7E71E6EC2735D70C007CFF72 /* FlashCardView.swift */,
|
7E71E6EC2735D70C007CFF72 /* FlashCardView.swift */,
|
||||||
7EF546152737B8FA00537AE6 /* FlashCardResultsView.swift */,
|
7EF546152737B8FA00537AE6 /* FlashCardResultsView.swift */,
|
||||||
7E716B4127398CDF009E2CF6 /* FlashCardLessonsView.swift */,
|
7E716B4127398CDF009E2CF6 /* FlashCardLessonsView.swift */,
|
||||||
7E716B452739B968009E2CF6 /* FlashCardLessonResultsView.swift */,
|
7E716B452739B968009E2CF6 /* FlashCardLessonResultsView.swift */,
|
||||||
E1D79AE228EC396200A104BF /* DictionaryView.swift */,
|
|
||||||
);
|
);
|
||||||
path = Views;
|
path = Views;
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
@ -234,6 +239,26 @@
|
|||||||
path = "Preview Content";
|
path = "Preview Content";
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
};
|
};
|
||||||
|
E1D79AE828F1947F00A104BF /* WordListViews */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
E1D79AE928F1949900A104BF /* SharedViews */,
|
||||||
|
E1D79AE228EC396200A104BF /* DictionaryView.swift */,
|
||||||
|
E1D79AE428F1914600A104BF /* TranslatorView.swift */,
|
||||||
|
);
|
||||||
|
path = WordListViews;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
|
E1D79AE928F1949900A104BF /* SharedViews */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
E1D79AE628F1925400A104BF /* TokiWordsListEntryView.swift */,
|
||||||
|
7E20D5FE2733AFE700D75B9A /* PartsOfSpeechView.swift */,
|
||||||
|
E1D79AEA28F194EF00A104BF /* LanguageDirectionView.swift */,
|
||||||
|
);
|
||||||
|
path = SharedViews;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
/* End PBXGroup section */
|
/* End PBXGroup section */
|
||||||
|
|
||||||
/* Begin PBXNativeTarget section */
|
/* Begin PBXNativeTarget section */
|
||||||
@ -357,6 +382,8 @@
|
|||||||
7E943A2A273211C300E7DDF4 /* Persistence.swift in Sources */,
|
7E943A2A273211C300E7DDF4 /* Persistence.swift in Sources */,
|
||||||
7E20D5FF2733AFE700D75B9A /* PartsOfSpeechView.swift in Sources */,
|
7E20D5FF2733AFE700D75B9A /* PartsOfSpeechView.swift in Sources */,
|
||||||
7E71E6F12736DAE4007CFF72 /* FlashCardsViewModel.swift in Sources */,
|
7E71E6F12736DAE4007CFF72 /* FlashCardsViewModel.swift in Sources */,
|
||||||
|
E1D79AEB28F194EF00A104BF /* LanguageDirectionView.swift in Sources */,
|
||||||
|
E1D79AE528F1914600A104BF /* TranslatorView.swift in Sources */,
|
||||||
7E20D6012734466800D75B9A /* TokiDictionaryViewModel.swift in Sources */,
|
7E20D6012734466800D75B9A /* TokiDictionaryViewModel.swift in Sources */,
|
||||||
7E716B4427398D3D009E2CF6 /* FlashCardLessonsViewModel.swift in Sources */,
|
7E716B4427398D3D009E2CF6 /* FlashCardLessonsViewModel.swift in Sources */,
|
||||||
7E2811192733027F0063DC78 /* TokiPartOfSpeech.swift in Sources */,
|
7E2811192733027F0063DC78 /* TokiPartOfSpeech.swift in Sources */,
|
||||||
@ -366,6 +393,7 @@
|
|||||||
7EF546162737B8FB00537AE6 /* FlashCardResultsView.swift in Sources */,
|
7EF546162737B8FB00537AE6 /* FlashCardResultsView.swift in Sources */,
|
||||||
7E716B4227398CDF009E2CF6 /* FlashCardLessonsView.swift in Sources */,
|
7E716B4227398CDF009E2CF6 /* FlashCardLessonsView.swift in Sources */,
|
||||||
7E2811172733027F0063DC78 /* TokiDictionary.swift in Sources */,
|
7E2811172733027F0063DC78 /* TokiDictionary.swift in Sources */,
|
||||||
|
E1D79AE728F1925400A104BF /* TokiWordsListEntryView.swift in Sources */,
|
||||||
7E71E6ED2735D70C007CFF72 /* FlashCardView.swift in Sources */,
|
7E71E6ED2735D70C007CFF72 /* FlashCardView.swift in Sources */,
|
||||||
7E943A21273211C200E7DDF4 /* Toki_TrainerApp.swift in Sources */,
|
7E943A21273211C200E7DDF4 /* Toki_TrainerApp.swift in Sources */,
|
||||||
7E716B462739B968009E2CF6 /* FlashCardLessonResultsView.swift in Sources */,
|
7E716B462739B968009E2CF6 /* FlashCardLessonResultsView.swift in Sources */,
|
||||||
|
@ -0,0 +1,6 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<Bucket
|
||||||
|
uuid = "67504E59-573C-478E-8136-93CA344B943E"
|
||||||
|
type = "1"
|
||||||
|
version = "2.0">
|
||||||
|
</Bucket>
|
@ -0,0 +1,19 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
||||||
|
<plist version="1.0">
|
||||||
|
<dict>
|
||||||
|
<key>SchemeUserState</key>
|
||||||
|
<dict>
|
||||||
|
<key>Toki Trainer WidgetsExtension.xcscheme_^#shared#^_</key>
|
||||||
|
<dict>
|
||||||
|
<key>orderHint</key>
|
||||||
|
<integer>0</integer>
|
||||||
|
</dict>
|
||||||
|
<key>Toki Trainer.xcscheme_^#shared#^_</key>
|
||||||
|
<dict>
|
||||||
|
<key>orderHint</key>
|
||||||
|
<integer>1</integer>
|
||||||
|
</dict>
|
||||||
|
</dict>
|
||||||
|
</dict>
|
||||||
|
</plist>
|
@ -44,6 +44,11 @@ class TokiDictionaryViewModel: ObservableObject {
|
|||||||
dictionary = []
|
dictionary = []
|
||||||
translatedDictionary = []
|
translatedDictionary = []
|
||||||
|
|
||||||
|
if input.isEmpty {
|
||||||
|
dictionary = fullDictionary
|
||||||
|
translatedDictionary.append(TokiSubWordListEntry("Dictionary"))
|
||||||
|
}
|
||||||
|
|
||||||
let capturePattern = #"(\w+)"#
|
let capturePattern = #"(\w+)"#
|
||||||
let captures = self.searchStringForRegex(string: input, regex: capturePattern)
|
let captures = self.searchStringForRegex(string: input, regex: capturePattern)
|
||||||
for capture in captures {
|
for capture in captures {
|
||||||
|
@ -15,8 +15,6 @@ extension String: Identifiable {
|
|||||||
struct ContentView: View {
|
struct ContentView: View {
|
||||||
@Environment(\.managedObjectContext) private var viewContext
|
@Environment(\.managedObjectContext) private var viewContext
|
||||||
|
|
||||||
@State private var tokiInput: String = ""
|
|
||||||
|
|
||||||
var body: some View {
|
var body: some View {
|
||||||
TabView {
|
TabView {
|
||||||
DictionaryView()
|
DictionaryView()
|
||||||
@ -34,11 +32,6 @@ struct ContentView: View {
|
|||||||
Image(systemName: "character.textbox")
|
Image(systemName: "character.textbox")
|
||||||
Text("Flash Cards")
|
Text("Flash Cards")
|
||||||
}
|
}
|
||||||
// FlashCardResultsView()
|
|
||||||
// .tabItem {
|
|
||||||
// Image(systemName: "number.circle")
|
|
||||||
// Text("Flash Card Results")
|
|
||||||
// }
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -47,177 +40,6 @@ struct ContentView: View {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
struct TranslatorView: View {
|
|
||||||
@ObservedObject var tokiDictViewModel = TokiDictionaryViewModel()
|
|
||||||
@State private var selectedPartOfSpeech: String?
|
|
||||||
@State private var tokiInput: String = ""
|
|
||||||
@State private var translateToTokiPona: Bool = false
|
|
||||||
|
|
||||||
var body: some View {
|
|
||||||
VStack {
|
|
||||||
Button(action: changeTranslationDirection) {
|
|
||||||
if translateToTokiPona == true {
|
|
||||||
LanguageDirectionView(from: "English", to: "Toki Pona", fromColor: .blue, toColor: .cyan)
|
|
||||||
} else {
|
|
||||||
LanguageDirectionView(from: "Toki Pona", to: "English", fromColor: .cyan, toColor: .blue)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
TextField("Enter Toki Pona Word or Phrase", text: $tokiInput)
|
|
||||||
.multilineTextAlignment(.center)
|
|
||||||
.textInputAutocapitalization(.never)
|
|
||||||
.disableAutocorrection(true)
|
|
||||||
.padding(8)
|
|
||||||
.onSubmit {
|
|
||||||
tokiDictViewModel.translatePhrase(tokiInput)
|
|
||||||
}
|
|
||||||
if tokiInput.count == 0 {
|
|
||||||
List(tokiDictViewModel.dictionary, id: \.word) { entry in
|
|
||||||
TokiWordsListEntryView(entry: entry, selectedPartOfSpeech: $selectedPartOfSpeech)
|
|
||||||
}
|
|
||||||
//TokiWordsView(tokiDictViewModel: tokiDictViewModel, selectedPartOfSpeech: selectedPartOfSpeech, tokiInput: $tokiInput)
|
|
||||||
} else {
|
|
||||||
List(tokiDictViewModel.translatedDictionary, id: \.header) { section in
|
|
||||||
Section {
|
|
||||||
ForEach(section.subDictionary, id: \.word) { entry in
|
|
||||||
TokiWordsListEntryView(entry: entry, selectedPartOfSpeech: $selectedPartOfSpeech)
|
|
||||||
}
|
|
||||||
} header: {
|
|
||||||
Text(section.header)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// ForEach(tokiDictViewModel.translatedDictionary) { entry in
|
|
||||||
// TokiSectionedWordsView(tokiDictViewModel: tokiDictViewModel, tokiInput: $tokiInput)
|
|
||||||
// }
|
|
||||||
}
|
|
||||||
}
|
|
||||||
.onChange(of: tokiInput) { newValue in
|
|
||||||
tokiDictViewModel.translatePhrase(newValue)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func changeTranslationDirection() {
|
|
||||||
translateToTokiPona.toggle()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
struct TokiSectionedWordsView: View {
|
|
||||||
@ObservedObject var tokiDictViewModel: TokiDictionaryViewModel
|
|
||||||
@Binding var tokiInput: String
|
|
||||||
|
|
||||||
var body: some View {
|
|
||||||
Section(header: Text(tokiInput)) {
|
|
||||||
TokiWordsView(tokiDictViewModel: tokiDictViewModel, tokiInput: $tokiInput)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
struct TokiWordsListEntryView: View {
|
|
||||||
@State var entry: TokiDictEntry
|
|
||||||
@Binding var selectedPartOfSpeech: String?
|
|
||||||
|
|
||||||
var body: some View {
|
|
||||||
VStack(alignment: .leading) {
|
|
||||||
Text(entry.word)
|
|
||||||
.font(.title)
|
|
||||||
ForEach(entry.definitions, id: \.pos) { definition in
|
|
||||||
HStack(alignment: .top) {
|
|
||||||
Button(action: {
|
|
||||||
self.selectedPartOfSpeech = String(definition.pos)
|
|
||||||
}) {
|
|
||||||
Text(definition.pos)
|
|
||||||
.frame(width: 45, height: 22, alignment: .center)
|
|
||||||
.foregroundColor(.black)
|
|
||||||
.background(Color(K.posColors[definition.pos]!))
|
|
||||||
.cornerRadius(5.0)
|
|
||||||
.padding(4)
|
|
||||||
}
|
|
||||||
.buttonStyle(BorderlessButtonStyle())
|
|
||||||
Text(definition.definition)
|
|
||||||
.fixedSize(horizontal: false, vertical: true)
|
|
||||||
.padding(4)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
struct TokiWordsView: View {
|
|
||||||
@ObservedObject var tokiDictViewModel: TokiDictionaryViewModel
|
|
||||||
@State var selectedPartOfSpeech: String?
|
|
||||||
|
|
||||||
@Binding var tokiInput: String
|
|
||||||
|
|
||||||
var body: some View {
|
|
||||||
List(tokiDictViewModel.dictionary, id: \.word) { entry in
|
|
||||||
VStack(alignment: .leading) {
|
|
||||||
Text(entry.word)
|
|
||||||
.font(.title)
|
|
||||||
ForEach(entry.definitions, id: \.pos) { definition in
|
|
||||||
HStack(alignment: .top) {
|
|
||||||
Button(action: {
|
|
||||||
self.selectedPartOfSpeech = String(definition.pos)
|
|
||||||
}) {
|
|
||||||
Text(definition.pos)
|
|
||||||
.frame(width: 45, height: 22, alignment: .center)
|
|
||||||
.foregroundColor(.black)
|
|
||||||
.background(Color(K.posColors[definition.pos]!))
|
|
||||||
.cornerRadius(5.0)
|
|
||||||
.padding(4)
|
|
||||||
}
|
|
||||||
.buttonStyle(BorderlessButtonStyle())
|
|
||||||
Text(definition.definition)
|
|
||||||
.fixedSize(horizontal: false, vertical: true)
|
|
||||||
.padding(4)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
.sheet(item: $selectedPartOfSpeech) { selectedPOS in
|
|
||||||
PartsOfSpeechView(selectedPartOfSpeech: selectedPOS, partsOfSpeech: tokiDictViewModel.partsOfSpeech)
|
|
||||||
}
|
|
||||||
.onChange(of: tokiInput) { newValue in
|
|
||||||
tokiDictViewModel.translatePhrase(newValue)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
struct LanguageDirectionView: View {
|
|
||||||
private var fromText: String = ""
|
|
||||||
private var toText: String = ""
|
|
||||||
private var fromColor: Color = .black
|
|
||||||
private var toColor: Color = .black
|
|
||||||
|
|
||||||
init(from: String, to: String, fromColor: Color, toColor: Color) {
|
|
||||||
self.fromText = from
|
|
||||||
self.toText = to
|
|
||||||
self.fromColor = fromColor
|
|
||||||
self.toColor = toColor
|
|
||||||
}
|
|
||||||
|
|
||||||
var body: some View {
|
|
||||||
HStack {
|
|
||||||
Text(fromText)
|
|
||||||
.bold()
|
|
||||||
.multilineTextAlignment(.center)
|
|
||||||
.foregroundColor(.white)
|
|
||||||
.frame(width: 100)
|
|
||||||
.background(fromColor)
|
|
||||||
.border(fromColor)
|
|
||||||
.cornerRadius(5)
|
|
||||||
Image(systemName: "chevron.right")
|
|
||||||
//rforegroundColor(.black)
|
|
||||||
Text(toText)
|
|
||||||
.bold()
|
|
||||||
.multilineTextAlignment(.center)
|
|
||||||
.foregroundColor(.white)
|
|
||||||
.frame(width: 100)
|
|
||||||
.background(toColor)
|
|
||||||
.border(toColor)
|
|
||||||
.cornerRadius(5)
|
|
||||||
}
|
|
||||||
.padding(.top, 4)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
struct ContentView_Previews: PreviewProvider {
|
struct ContentView_Previews: PreviewProvider {
|
||||||
|
@ -157,7 +157,7 @@ struct FlashCardStack: View {
|
|||||||
var cardInDatabase = false
|
var cardInDatabase = false
|
||||||
for answer in flashCardAnswers {
|
for answer in flashCardAnswers {
|
||||||
if answer.word == shuffledDictionary[currentFlashCard].word {
|
if answer.word == shuffledDictionary[currentFlashCard].word {
|
||||||
print("word in database: \(answer.word)")
|
print("word in database: \(answer.word ?? "nil")")
|
||||||
print("tries: \(answer.triesCount)")
|
print("tries: \(answer.triesCount)")
|
||||||
print("correct`: \(answer.correctCount)")
|
print("correct`: \(answer.correctCount)")
|
||||||
cardInDatabase = true
|
cardInDatabase = true
|
||||||
|
@ -26,9 +26,19 @@ struct DictionaryView: View {
|
|||||||
List(tokiDictViewModel.dictionary, id: \.word) { entry in
|
List(tokiDictViewModel.dictionary, id: \.word) { entry in
|
||||||
TokiWordsListEntryView(entry: entry, selectedPartOfSpeech: $selectedPartOfSpeech)
|
TokiWordsListEntryView(entry: entry, selectedPartOfSpeech: $selectedPartOfSpeech)
|
||||||
}
|
}
|
||||||
|
.sheet(item: $selectedPartOfSpeech) { selectedPOS in
|
||||||
|
PartsOfSpeechView(selectedPartOfSpeech: selectedPOS)
|
||||||
|
}
|
||||||
.onChange(of: tokiInput) { newValue in
|
.onChange(of: tokiInput) { newValue in
|
||||||
tokiDictViewModel.filterDictionary(newValue)
|
tokiDictViewModel.filterDictionary(newValue)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
struct DictionaryView_Previews: PreviewProvider {
|
||||||
|
|
||||||
|
static var previews: some View {
|
||||||
|
DictionaryView(selectedPartOfSpeech: "n").previewLayout(.sizeThatFits).environment(\.managedObjectContext, PersistenceController.preview.container.viewContext)
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,53 @@
|
|||||||
|
//
|
||||||
|
// LanguageDirectionView.swift
|
||||||
|
// Toki Trainer
|
||||||
|
//
|
||||||
|
// Created by maddiefuzz on 10/8/22.
|
||||||
|
//
|
||||||
|
|
||||||
|
import SwiftUI
|
||||||
|
|
||||||
|
struct LanguageDirectionView: View {
|
||||||
|
private var fromText: String = ""
|
||||||
|
private var toText: String = ""
|
||||||
|
private var fromColor: Color = .black
|
||||||
|
private var toColor: Color = .black
|
||||||
|
|
||||||
|
init(from: String, to: String, fromColor: Color, toColor: Color) {
|
||||||
|
self.fromText = from
|
||||||
|
self.toText = to
|
||||||
|
self.fromColor = fromColor
|
||||||
|
self.toColor = toColor
|
||||||
|
}
|
||||||
|
|
||||||
|
var body: some View {
|
||||||
|
HStack {
|
||||||
|
Text(fromText)
|
||||||
|
.bold()
|
||||||
|
.multilineTextAlignment(.center)
|
||||||
|
.foregroundColor(.white)
|
||||||
|
.frame(width: 100)
|
||||||
|
.background(fromColor)
|
||||||
|
.border(fromColor)
|
||||||
|
.cornerRadius(5)
|
||||||
|
Image(systemName: "chevron.right")
|
||||||
|
Text(toText)
|
||||||
|
.bold()
|
||||||
|
.multilineTextAlignment(.center)
|
||||||
|
.foregroundColor(.white)
|
||||||
|
.frame(width: 100)
|
||||||
|
.background(toColor)
|
||||||
|
.border(toColor)
|
||||||
|
.cornerRadius(5)
|
||||||
|
}
|
||||||
|
.padding(.top, 4)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
struct LanguageDirectionView_Previews: PreviewProvider {
|
||||||
|
|
||||||
|
static var previews: some View {
|
||||||
|
LanguageDirectionView(from: "English", to: "Toki Pona", fromColor: .blue, toColor: .cyan)
|
||||||
|
.previewLayout(.fixed(width: 260, height: 40))
|
||||||
|
}
|
||||||
|
}
|
@ -12,8 +12,6 @@ struct PartsOfSpeechView: View {
|
|||||||
|
|
||||||
@ObservedObject var tokiDictViewModel = TokiDictionaryViewModel()
|
@ObservedObject var tokiDictViewModel = TokiDictionaryViewModel()
|
||||||
|
|
||||||
var partsOfSpeech: [TokiPartOfSpeech]
|
|
||||||
|
|
||||||
var body: some View {
|
var body: some View {
|
||||||
VStack {
|
VStack {
|
||||||
Text("Parts of Speech")
|
Text("Parts of Speech")
|
||||||
@ -42,8 +40,8 @@ struct PartsOfSpeechView: View {
|
|||||||
|
|
||||||
struct PartsOfSpeechView_Previews: PreviewProvider {
|
struct PartsOfSpeechView_Previews: PreviewProvider {
|
||||||
static var previews: some View {
|
static var previews: some View {
|
||||||
PartsOfSpeechView(selectedPartOfSpeech: "sep", partsOfSpeech: [TokiPartOfSpeech(pos: "sep", definition: "test")])
|
PartsOfSpeechView(selectedPartOfSpeech: "sep")
|
||||||
.preferredColorScheme(.dark)
|
.preferredColorScheme(.dark)
|
||||||
PartsOfSpeechView(selectedPartOfSpeech: "sep", partsOfSpeech: [TokiPartOfSpeech(pos: "sep", definition: "test")])
|
PartsOfSpeechView(selectedPartOfSpeech: "sep")
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -0,0 +1,47 @@
|
|||||||
|
//
|
||||||
|
// TokiWordsListEntryView.swift
|
||||||
|
// Toki Trainer
|
||||||
|
//
|
||||||
|
// Created by maddiefuzz on 10/8/22.
|
||||||
|
//
|
||||||
|
|
||||||
|
import SwiftUI
|
||||||
|
|
||||||
|
struct TokiWordsListEntryView: View {
|
||||||
|
@State var entry: TokiDictEntry
|
||||||
|
@Binding var selectedPartOfSpeech: String?
|
||||||
|
|
||||||
|
var body: some View {
|
||||||
|
VStack(alignment: .leading) {
|
||||||
|
Text(entry.word)
|
||||||
|
.font(.title)
|
||||||
|
ForEach(entry.definitions, id: \.pos) { definition in
|
||||||
|
HStack(alignment: .top) {
|
||||||
|
Button(action: {
|
||||||
|
self.selectedPartOfSpeech = String(definition.pos)
|
||||||
|
}) {
|
||||||
|
Text(definition.pos)
|
||||||
|
.frame(width: 45, height: 22, alignment: .center)
|
||||||
|
.foregroundColor(.black)
|
||||||
|
.background(Color(K.posColors[definition.pos]!))
|
||||||
|
.cornerRadius(5.0)
|
||||||
|
.padding(4)
|
||||||
|
}
|
||||||
|
.buttonStyle(BorderlessButtonStyle())
|
||||||
|
Text(definition.definition)
|
||||||
|
.fixedSize(horizontal: false, vertical: true)
|
||||||
|
.padding(4)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
struct TokiWordsListEntryView_Previews: PreviewProvider {
|
||||||
|
static var entry = TokiDictionaryViewModel().dictionary[5]
|
||||||
|
|
||||||
|
static var previews: some View {
|
||||||
|
TokiWordsListEntryView(entry: entry, selectedPartOfSpeech: .constant("n"))
|
||||||
|
.previewLayout(.sizeThatFits)
|
||||||
|
}
|
||||||
|
}
|
68
Toki Trainer/Views/WordListViews/TranslatorView.swift
Normal file
68
Toki Trainer/Views/WordListViews/TranslatorView.swift
Normal file
@ -0,0 +1,68 @@
|
|||||||
|
//
|
||||||
|
// TranslatorView.swift
|
||||||
|
// Toki Trainer
|
||||||
|
//
|
||||||
|
// Created by maddiefuzz on 10/8/22.
|
||||||
|
//
|
||||||
|
|
||||||
|
import SwiftUI
|
||||||
|
|
||||||
|
struct TranslatorView: View {
|
||||||
|
@ObservedObject var tokiDictViewModel = TokiDictionaryViewModel()
|
||||||
|
@State private var selectedPartOfSpeech: String?
|
||||||
|
@State private var tokiInput: String = ""
|
||||||
|
@State private var translateToTokiPona: Bool = false
|
||||||
|
|
||||||
|
var body: some View {
|
||||||
|
VStack {
|
||||||
|
Button(action: changeTranslationDirection) {
|
||||||
|
// TODO: This needs to actually switch how the lookup happens
|
||||||
|
if translateToTokiPona == true {
|
||||||
|
LanguageDirectionView(from: "English", to: "Toki Pona", fromColor: .blue, toColor: .cyan)
|
||||||
|
} else {
|
||||||
|
LanguageDirectionView(from: "Toki Pona", to: "English", fromColor: .cyan, toColor: .blue)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
TextField("Enter Toki Pona Word or Phrase", text: $tokiInput)
|
||||||
|
.multilineTextAlignment(.center)
|
||||||
|
.textInputAutocapitalization(.never)
|
||||||
|
.disableAutocorrection(true)
|
||||||
|
.padding(8)
|
||||||
|
.onSubmit {
|
||||||
|
tokiDictViewModel.translatePhrase(tokiInput)
|
||||||
|
}
|
||||||
|
if tokiInput.count == 0 {
|
||||||
|
List(tokiDictViewModel.dictionary, id: \.word) { entry in
|
||||||
|
TokiWordsListEntryView(entry: entry, selectedPartOfSpeech: $selectedPartOfSpeech)
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
List(tokiDictViewModel.translatedDictionary, id: \.header) { section in
|
||||||
|
Section {
|
||||||
|
ForEach(section.subDictionary, id: \.word) { entry in
|
||||||
|
TokiWordsListEntryView(entry: entry, selectedPartOfSpeech: $selectedPartOfSpeech)
|
||||||
|
}
|
||||||
|
} header: {
|
||||||
|
Text(section.header)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.sheet(item: $selectedPartOfSpeech) { selectedPOS in
|
||||||
|
PartsOfSpeechView(selectedPartOfSpeech: selectedPOS)
|
||||||
|
}
|
||||||
|
.onChange(of: tokiInput) { newValue in
|
||||||
|
tokiDictViewModel.translatePhrase(newValue)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func changeTranslationDirection() {
|
||||||
|
translateToTokiPona.toggle()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
struct TranslatorView_Previews: PreviewProvider {
|
||||||
|
|
||||||
|
static var previews: some View {
|
||||||
|
TranslatorView().previewLayout(.sizeThatFits).environment(\.managedObjectContext, PersistenceController.preview.container.viewContext)
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user