mirror of
https://github.com/ivabus/GradeMapper
synced 2024-11-10 02:05:17 +03:00
Refactoring everything
This commit is contained in:
parent
852092ae8e
commit
d192d6e334
|
@ -7,14 +7,12 @@
|
||||||
objects = {
|
objects = {
|
||||||
|
|
||||||
/* Begin PBXBuildFile section */
|
/* Begin PBXBuildFile section */
|
||||||
4F7E91CD279615A200CB18B7 /* SubjectView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4F7E91CC279615A200CB18B7 /* SubjectView.swift */; };
|
|
||||||
4FEB3F0F2795DFE90005C604 /* GradeMapperApp.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4FEB3EFF2795DFE80005C604 /* GradeMapperApp.swift */; };
|
4FEB3F0F2795DFE90005C604 /* GradeMapperApp.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4FEB3EFF2795DFE80005C604 /* GradeMapperApp.swift */; };
|
||||||
4FEB3F112795DFE90005C604 /* ContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4FEB3F002795DFE80005C604 /* ContentView.swift */; };
|
4FEB3F112795DFE90005C604 /* ContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4FEB3F002795DFE80005C604 /* ContentView.swift */; };
|
||||||
4FEB3F132795DFE90005C604 /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 4FEB3F012795DFE90005C604 /* Assets.xcassets */; };
|
4FEB3F132795DFE90005C604 /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 4FEB3F012795DFE90005C604 /* Assets.xcassets */; };
|
||||||
/* End PBXBuildFile section */
|
/* End PBXBuildFile section */
|
||||||
|
|
||||||
/* Begin PBXFileReference section */
|
/* Begin PBXFileReference section */
|
||||||
4F7E91CC279615A200CB18B7 /* SubjectView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SubjectView.swift; sourceTree = "<group>"; };
|
|
||||||
4FD40DBC279702A900A5A6D2 /* GradeMapper (iOS).entitlements */ = {isa = PBXFileReference; lastKnownFileType = text.plist.entitlements; path = "GradeMapper (iOS).entitlements"; sourceTree = "<group>"; };
|
4FD40DBC279702A900A5A6D2 /* GradeMapper (iOS).entitlements */ = {isa = PBXFileReference; lastKnownFileType = text.plist.entitlements; path = "GradeMapper (iOS).entitlements"; sourceTree = "<group>"; };
|
||||||
4FEB3EFF2795DFE80005C604 /* GradeMapperApp.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GradeMapperApp.swift; sourceTree = "<group>"; };
|
4FEB3EFF2795DFE80005C604 /* GradeMapperApp.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = GradeMapperApp.swift; sourceTree = "<group>"; };
|
||||||
4FEB3F002795DFE80005C604 /* ContentView.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = ContentView.swift; sourceTree = "<group>"; };
|
4FEB3F002795DFE80005C604 /* ContentView.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = ContentView.swift; sourceTree = "<group>"; };
|
||||||
|
@ -50,7 +48,6 @@
|
||||||
4FEB3EFF2795DFE80005C604 /* GradeMapperApp.swift */,
|
4FEB3EFF2795DFE80005C604 /* GradeMapperApp.swift */,
|
||||||
4FEB3F002795DFE80005C604 /* ContentView.swift */,
|
4FEB3F002795DFE80005C604 /* ContentView.swift */,
|
||||||
4FEB3F012795DFE90005C604 /* Assets.xcassets */,
|
4FEB3F012795DFE90005C604 /* Assets.xcassets */,
|
||||||
4F7E91CC279615A200CB18B7 /* SubjectView.swift */,
|
|
||||||
);
|
);
|
||||||
path = Shared;
|
path = Shared;
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
|
@ -141,7 +138,6 @@
|
||||||
buildActionMask = 2147483647;
|
buildActionMask = 2147483647;
|
||||||
files = (
|
files = (
|
||||||
4FEB3F112795DFE90005C604 /* ContentView.swift in Sources */,
|
4FEB3F112795DFE90005C604 /* ContentView.swift in Sources */,
|
||||||
4F7E91CD279615A200CB18B7 /* SubjectView.swift in Sources */,
|
|
||||||
4FEB3F0F2795DFE90005C604 /* GradeMapperApp.swift in Sources */,
|
4FEB3F0F2795DFE90005C604 /* GradeMapperApp.swift in Sources */,
|
||||||
);
|
);
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
|
@ -269,6 +265,7 @@
|
||||||
CODE_SIGN_STYLE = Automatic;
|
CODE_SIGN_STYLE = Automatic;
|
||||||
CURRENT_PROJECT_VERSION = 1;
|
CURRENT_PROJECT_VERSION = 1;
|
||||||
DEVELOPMENT_TEAM = F5PQ7AR4DP;
|
DEVELOPMENT_TEAM = F5PQ7AR4DP;
|
||||||
|
"ENABLE_HARDENED_RUNTIME[sdk=macosx*]" = YES;
|
||||||
ENABLE_PREVIEWS = YES;
|
ENABLE_PREVIEWS = YES;
|
||||||
GENERATE_INFOPLIST_FILE = YES;
|
GENERATE_INFOPLIST_FILE = YES;
|
||||||
INFOPLIST_KEY_UIApplicationSceneManifest_Generation = YES;
|
INFOPLIST_KEY_UIApplicationSceneManifest_Generation = YES;
|
||||||
|
@ -289,7 +286,7 @@
|
||||||
SUPPORTS_MAC_DESIGNED_FOR_IPHONE_IPAD = NO;
|
SUPPORTS_MAC_DESIGNED_FOR_IPHONE_IPAD = NO;
|
||||||
SWIFT_EMIT_LOC_STRINGS = YES;
|
SWIFT_EMIT_LOC_STRINGS = YES;
|
||||||
SWIFT_VERSION = 5.0;
|
SWIFT_VERSION = 5.0;
|
||||||
TARGETED_DEVICE_FAMILY = "1,2";
|
TARGETED_DEVICE_FAMILY = "1,2,6";
|
||||||
};
|
};
|
||||||
name = Debug;
|
name = Debug;
|
||||||
};
|
};
|
||||||
|
@ -302,6 +299,7 @@
|
||||||
CODE_SIGN_STYLE = Automatic;
|
CODE_SIGN_STYLE = Automatic;
|
||||||
CURRENT_PROJECT_VERSION = 1;
|
CURRENT_PROJECT_VERSION = 1;
|
||||||
DEVELOPMENT_TEAM = F5PQ7AR4DP;
|
DEVELOPMENT_TEAM = F5PQ7AR4DP;
|
||||||
|
"ENABLE_HARDENED_RUNTIME[sdk=macosx*]" = YES;
|
||||||
ENABLE_PREVIEWS = YES;
|
ENABLE_PREVIEWS = YES;
|
||||||
GENERATE_INFOPLIST_FILE = YES;
|
GENERATE_INFOPLIST_FILE = YES;
|
||||||
INFOPLIST_KEY_UIApplicationSceneManifest_Generation = YES;
|
INFOPLIST_KEY_UIApplicationSceneManifest_Generation = YES;
|
||||||
|
@ -322,7 +320,7 @@
|
||||||
SUPPORTS_MAC_DESIGNED_FOR_IPHONE_IPAD = NO;
|
SUPPORTS_MAC_DESIGNED_FOR_IPHONE_IPAD = NO;
|
||||||
SWIFT_EMIT_LOC_STRINGS = YES;
|
SWIFT_EMIT_LOC_STRINGS = YES;
|
||||||
SWIFT_VERSION = 5.0;
|
SWIFT_VERSION = 5.0;
|
||||||
TARGETED_DEVICE_FAMILY = "1,2";
|
TARGETED_DEVICE_FAMILY = "1,2,6";
|
||||||
VALIDATE_PRODUCT = YES;
|
VALIDATE_PRODUCT = YES;
|
||||||
};
|
};
|
||||||
name = Release;
|
name = Release;
|
||||||
|
|
|
@ -3,4 +3,22 @@
|
||||||
uuid = "1FA12096-94D4-4153-9D70-423E3C4922F7"
|
uuid = "1FA12096-94D4-4153-9D70-423E3C4922F7"
|
||||||
type = "1"
|
type = "1"
|
||||||
version = "2.0">
|
version = "2.0">
|
||||||
|
<Breakpoints>
|
||||||
|
<BreakpointProxy
|
||||||
|
BreakpointExtensionID = "Xcode.Breakpoint.FileBreakpoint">
|
||||||
|
<BreakpointContent
|
||||||
|
uuid = "DB7E51B9-F3B0-41A1-892B-99BA9E5AF18A"
|
||||||
|
shouldBeEnabled = "Yes"
|
||||||
|
ignoreCount = "0"
|
||||||
|
continueAfterRunningActions = "No"
|
||||||
|
filePath = "Shared/ContentView.swift"
|
||||||
|
startingColumnNumber = "9223372036854775807"
|
||||||
|
endingColumnNumber = "9223372036854775807"
|
||||||
|
startingLineNumber = "16"
|
||||||
|
endingLineNumber = "16"
|
||||||
|
landmarkName = "Grade"
|
||||||
|
landmarkType = "13">
|
||||||
|
</BreakpointContent>
|
||||||
|
</BreakpointProxy>
|
||||||
|
</Breakpoints>
|
||||||
</Bucket>
|
</Bucket>
|
||||||
|
|
|
@ -1,36 +1,71 @@
|
||||||
//
|
//
|
||||||
// ContentView.swift
|
// SubjectView.swift
|
||||||
// Shared
|
// GradeMapper
|
||||||
//
|
//
|
||||||
// Created by Иван Бущик on 17.01.2022.
|
// Created by Иван Бущик on 18.01.2022.
|
||||||
//
|
//
|
||||||
|
|
||||||
import SwiftUI
|
import SwiftUI
|
||||||
|
enum Grade: Int, Identifiable, CaseIterable{
|
||||||
|
case One = 1
|
||||||
|
case Two = 2
|
||||||
|
case Three = 3
|
||||||
|
case Four = 4
|
||||||
|
case Five = 5
|
||||||
|
|
||||||
struct ContentView: View{
|
var id: Int { self.rawValue }
|
||||||
var body: some View {
|
|
||||||
VStack(alignment: .center) {
|
|
||||||
Text("GradeMapper")
|
|
||||||
.font(.largeTitle)
|
|
||||||
.fontWeight(.heavy)
|
|
||||||
.multilineTextAlignment(.center)
|
|
||||||
NavigationView {
|
|
||||||
List{
|
|
||||||
ForEach(subjectsNames, id: \.self) {
|
|
||||||
subjectName in NavigationLink("\(subjectName)", destination: SubjectView(name: subjectName))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}.padding([.leading, .top], 5.0)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
struct ContentView: View {
|
||||||
|
var counter = counters()
|
||||||
|
@State var sr: Double = 0
|
||||||
|
@State private var selectedGrade = Grade.One
|
||||||
|
@State var selectedTypeOfGrade = "Контрольная работа"
|
||||||
|
|
||||||
|
var body: some View {
|
||||||
|
Text("GradeMapper")
|
||||||
|
.font(.largeTitle)
|
||||||
|
.fontWeight(.heavy)
|
||||||
|
.multilineTextAlignment(.center)
|
||||||
|
.padding(.top, -75)
|
||||||
|
VStack(alignment: .center, spacing: 75){
|
||||||
|
VStack(alignment: .leading, spacing: 30){
|
||||||
|
Picker("Тип оценки", selection: $selectedTypeOfGrade){
|
||||||
|
ForEach([String](coof.keys), id: \.self) {
|
||||||
|
subjectSN in Text("\(subjectSN)")
|
||||||
|
}
|
||||||
|
}.pickerStyle(.wheel)
|
||||||
|
VStack{
|
||||||
|
Picker("Оценка", selection: $selectedGrade){
|
||||||
|
ForEach(Grade.allCases, id: \.self) {
|
||||||
|
currGrade in Text("\(currGrade.rawValue)")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}.pickerStyle(.segmented).padding(.horizontal, 20)
|
||||||
|
}.padding(.top, 100)
|
||||||
|
Button ("Добавить оценку"){
|
||||||
|
counter.multiplier = coof[selectedTypeOfGrade]!
|
||||||
|
counter.gradesWeighted += Double(selectedGrade.rawValue) * counter.multiplier
|
||||||
|
counter.weightsSum += counter.multiplier
|
||||||
|
self.sr = (counter.gradesWeighted / counter.weightsSum)
|
||||||
|
}.buttonStyle(.borderedProminent)
|
||||||
|
Text(String("Средний балл: \(self.sr)"))
|
||||||
|
.fontWeight(.bold)
|
||||||
|
Button ("Очистить"){
|
||||||
|
counter.multiplier = 1.5
|
||||||
|
counter.gradesWeighted = 0
|
||||||
|
counter.weightsSum = 0
|
||||||
|
self.sr = 0
|
||||||
|
}.buttonStyle(.borderedProminent)
|
||||||
|
}
|
||||||
|
.padding(.top, -155.0)
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
struct ContentView_Previews: PreviewProvider {
|
struct ContentView_Previews: PreviewProvider {
|
||||||
static var previews: some View {
|
static var previews: some View {
|
||||||
ContentView()
|
ContentView()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -7,39 +7,17 @@
|
||||||
|
|
||||||
import SwiftUI
|
import SwiftUI
|
||||||
|
|
||||||
class helpMe{
|
class counters{
|
||||||
var multiplier: Double
|
var multiplier: Double
|
||||||
var subjectName: String
|
|
||||||
var subjectSubName: String
|
|
||||||
var grade: Int
|
|
||||||
var sum: Double
|
|
||||||
var sr: Double
|
|
||||||
var gradesWeighted: Double = 0
|
var gradesWeighted: Double = 0
|
||||||
var weightsSum: Double = 0
|
var weightsSum: Double = 0
|
||||||
var history: [Int]
|
|
||||||
init(){
|
init(){
|
||||||
self.multiplier = 1.5
|
self.multiplier = 1.0
|
||||||
self.subjectName = "Русский язык"
|
|
||||||
self.subjectSubName = "Контрольная работа"
|
|
||||||
self.gradesWeighted = 0
|
self.gradesWeighted = 0
|
||||||
self.weightsSum = 0
|
self.weightsSum = 0
|
||||||
self.sr = 0
|
|
||||||
self.sum = 0
|
|
||||||
self.grade = 0
|
|
||||||
self.history = []
|
|
||||||
}
|
}
|
||||||
func set(n1: String, n2: String) -> Void{
|
|
||||||
self.multiplier = subjects[n1]![n2]!
|
|
||||||
self.subjectName = n1
|
|
||||||
self.subjectSubName = n2
|
|
||||||
}
|
|
||||||
func setGrade(grade: Int){
|
|
||||||
self.grade = grade
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@main
|
@main
|
||||||
struct GradeMapperApp: App {
|
struct GradeMapperApp: App {
|
||||||
var body: some Scene {
|
var body: some Scene {
|
||||||
|
@ -49,69 +27,29 @@ struct GradeMapperApp: App {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var subjects: [String : [String : Double]] = [
|
var coof = [
|
||||||
"Русский язык": [
|
"Работа на уроке": 1.0,
|
||||||
"Контрольная работа": 1.5,
|
"Тест": 1.0,
|
||||||
"Контрольный диктант": 1.5,
|
"Чтение наизусть": 1.0,
|
||||||
"Административная контрольная работа": 1.5,
|
"Сочинение": 1.0,
|
||||||
"Словарный диктант": 1.4,
|
"Дистанционный урок": 1.0,
|
||||||
"Домашнее сочинение": 1.4,
|
"Электронное обучение": 1.0,
|
||||||
"Изложение": 1.4,
|
"Ведение тетради": 1.0,
|
||||||
"Проверочная работа": 1.3,
|
"Викторина": 1.0,
|
||||||
"Самостоятельная работа": 1.2,
|
"Работа над ошибками": 1.0,
|
||||||
"Работа на уроке": 1.0,
|
"Самостоятельная работа": 1.2,
|
||||||
"Тест": 1.0,
|
"Проверочная работа": 1.3,
|
||||||
"Сочинение": 1.0,
|
"Практическая работа": 1.3,
|
||||||
"Домашняя работа": 1.0
|
"Лабораторная работа": 1.3,
|
||||||
], "Литература": [
|
"Срезовая работа": 1.3,
|
||||||
"Контрольная работа": 1.5,
|
"Словарный диктант": 1.4,
|
||||||
"Классное сочинение": 1.5,
|
"Домашнее сочинение": 1.4,
|
||||||
"Домашнее сочинение": 1.4,
|
"Аудирование": 1.4,
|
||||||
"Проверочная работа": 1.3,
|
"Изложение": 1.4,
|
||||||
"Самостоятельная работа": 1.2,
|
"Контрольная работа": 1.5,
|
||||||
"Работа на уроке": 1.0,
|
"Контрольный диктант": 1.5,
|
||||||
"Тест": 1.0,
|
"Контрольная практическая работа": 1.5,
|
||||||
"Сочинение": 1.0,
|
"Административная к.р.": 1.5,
|
||||||
"Домашняя работа": 1.0
|
"Зачёт": 1.5,
|
||||||
], "Алгебрa": [
|
"Классное сочинение": 1.5
|
||||||
"Контрольная работа": 1.5,
|
|
||||||
"Административная контрольная работа": 1.5,
|
|
||||||
"Контрольная практическая работа": 1.5,
|
|
||||||
"Зачёт": 1.5,
|
|
||||||
"Проверочная работа": 1.3,
|
|
||||||
"Самостоятельная работа": 1.2,
|
|
||||||
"Работа на уроке": 1.0,
|
|
||||||
"Домашняя работа": 1.0
|
|
||||||
], "Геометрия": [
|
|
||||||
"Контрольная работа": 1.5,
|
|
||||||
"Административная контрольная работа": 1.5,
|
|
||||||
"Контрольная практическая работа": 1.5,
|
|
||||||
"Зачёт": 1.5,
|
|
||||||
"Проверочная работа": 1.3,
|
|
||||||
"Практическая работа": 1.3,
|
|
||||||
"Самостоятельная работа": 1.2,
|
|
||||||
"Работа на уроке": 1.0,
|
|
||||||
"Домашняя работа": 1.0
|
|
||||||
], "Физика": [
|
|
||||||
"Контрольная работа": 1.5,
|
|
||||||
"Зачёт": 1.5,
|
|
||||||
"Проверочная работа": 1.3,
|
|
||||||
"Практическая работа": 1.3,
|
|
||||||
"Срезовая работа": 1.3,
|
|
||||||
"Лабораторная работа": 1.3,
|
|
||||||
"Самостоятельная работа": 1.2,
|
|
||||||
"Работа на уроке": 1.0,
|
|
||||||
"Тест": 1.0,
|
|
||||||
"Домашняя работа": 1.0
|
|
||||||
], "Информатика": [
|
|
||||||
"Контрольная работа": 1.5,
|
|
||||||
"Зачёт": 1.5,
|
|
||||||
"Проверочная работа": 1.3,
|
|
||||||
"Практическая работа": 1.3,
|
|
||||||
"Самостоятельная работа": 1.2,
|
|
||||||
"Работа на уроке": 1.0,
|
|
||||||
"Домашняя работа": 1.0
|
|
||||||
]
|
|
||||||
]
|
]
|
||||||
|
|
||||||
var subjectsNames: [String] = [String](subjects.keys)
|
|
||||||
|
|
|
@ -1,67 +0,0 @@
|
||||||
//
|
|
||||||
// SubjectView.swift
|
|
||||||
// GradeMapper
|
|
||||||
//
|
|
||||||
// Created by Иван Бущик on 18.01.2022.
|
|
||||||
//
|
|
||||||
|
|
||||||
import SwiftUI
|
|
||||||
enum Grade: Int, Identifiable, CaseIterable{
|
|
||||||
case One = 1
|
|
||||||
case Two = 2
|
|
||||||
case Three = 3
|
|
||||||
case Four = 4
|
|
||||||
case Five = 5
|
|
||||||
|
|
||||||
var id: Int { self.rawValue }
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
struct SubjectView: View {
|
|
||||||
var ow = helpMe()
|
|
||||||
@State var srr: Double = 0
|
|
||||||
var name: String
|
|
||||||
@State private var selectedGrade = Grade.One
|
|
||||||
@State var selectedTypeOfGrade = "Контрольная работа"
|
|
||||||
|
|
||||||
var body: some View {
|
|
||||||
var current = subjects[name]!
|
|
||||||
VStack(alignment: .center, spacing: 75){
|
|
||||||
Text("\(name)")
|
|
||||||
.font(.title)
|
|
||||||
.fontWeight(.black)
|
|
||||||
.multilineTextAlignment(.center)
|
|
||||||
VStack(alignment: .leading, spacing: 30){
|
|
||||||
Picker("Тип оценки", selection: $selectedTypeOfGrade){
|
|
||||||
ForEach([String](subjects[name]!.keys), id: \.self) {
|
|
||||||
subjectSN in Text("\(subjectSN)")
|
|
||||||
}
|
|
||||||
}.pickerStyle(.wheel)
|
|
||||||
VStack{
|
|
||||||
Picker("Оценка", selection: $selectedGrade){
|
|
||||||
ForEach(Grade.allCases, id: \.self) {
|
|
||||||
currGrade in Text("\(currGrade.rawValue)")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}.pickerStyle(.segmented)
|
|
||||||
}
|
|
||||||
Button ("Добавить оценку"){
|
|
||||||
ow.multiplier = current[selectedTypeOfGrade]!
|
|
||||||
ow.gradesWeighted += Double(selectedGrade.rawValue) * ow.multiplier
|
|
||||||
ow.weightsSum += ow.multiplier
|
|
||||||
ow.sr = (ow.gradesWeighted / ow.weightsSum)
|
|
||||||
print(ow.sr)
|
|
||||||
print(ow.multiplier)
|
|
||||||
self.srr = ow.sr
|
|
||||||
}.buttonStyle(.borderedProminent)
|
|
||||||
Text(String("Средний балл: \(self.srr)"))
|
|
||||||
.fontWeight(.bold)
|
|
||||||
}
|
|
||||||
.padding(.top, -155.0)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
struct SubjectView_Previews: PreviewProvider {
|
|
||||||
static var previews: some View {
|
|
||||||
SubjectView(name: "Русский язык")
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Reference in a new issue