version 0.6.0 #46
|
@ -11,7 +11,7 @@ android {
|
||||||
minSdkVersion 23
|
minSdkVersion 23
|
||||||
targetSdkVersion 29
|
targetSdkVersion 29
|
||||||
versionCode 15
|
versionCode 15
|
||||||
versionName "0.5.91"
|
versionName "0.5.92"
|
||||||
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
|
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
|
||||||
resValue "string", "build_time", buildTime()
|
resValue "string", "build_time", buildTime()
|
||||||
setProperty("archivesBaseName", "projectlaogai-$versionName")
|
setProperty("archivesBaseName", "projectlaogai-$versionName")
|
||||||
|
|
|
@ -44,7 +44,6 @@ import com.google.android.material.navigation.NavigationView
|
||||||
import kotlinx.android.synthetic.main.activity_main.*
|
import kotlinx.android.synthetic.main.activity_main.*
|
||||||
import kotlinx.android.synthetic.main.app_bar_main.*
|
import kotlinx.android.synthetic.main.app_bar_main.*
|
||||||
import org.mosad.seil0.projectlaogai.controller.NFCMensaCard
|
import org.mosad.seil0.projectlaogai.controller.NFCMensaCard
|
||||||
import org.mosad.seil0.projectlaogai.controller.QISPOSParser
|
|
||||||
import org.mosad.seil0.projectlaogai.controller.cache.CacheController
|
import org.mosad.seil0.projectlaogai.controller.cache.CacheController
|
||||||
import org.mosad.seil0.projectlaogai.controller.preferences.EncryptedPreferences
|
import org.mosad.seil0.projectlaogai.controller.preferences.EncryptedPreferences
|
||||||
import org.mosad.seil0.projectlaogai.controller.preferences.Preferences
|
import org.mosad.seil0.projectlaogai.controller.preferences.Preferences
|
||||||
|
@ -156,6 +155,7 @@ class MainActivity : AppCompatActivity(), NavigationView.OnNavigationItemSelecte
|
||||||
R.id.nav_mensa -> MensaFragment()
|
R.id.nav_mensa -> MensaFragment()
|
||||||
R.id.nav_timetable -> TimeTableFragment()
|
R.id.nav_timetable -> TimeTableFragment()
|
||||||
R.id.nav_moodle -> MoodleFragment()
|
R.id.nav_moodle -> MoodleFragment()
|
||||||
|
R.id.nav_grades -> GradesFragment()
|
||||||
R.id.nav_settings -> SettingsFragment()
|
R.id.nav_settings -> SettingsFragment()
|
||||||
else -> HomeFragment()
|
else -> HomeFragment()
|
||||||
}
|
}
|
||||||
|
@ -177,10 +177,6 @@ class MainActivity : AppCompatActivity(), NavigationView.OnNavigationItemSelecte
|
||||||
Preferences.load(this) // load the settings, must be finished before doing anything else
|
Preferences.load(this) // load the settings, must be finished before doing anything else
|
||||||
CacheController(this) // load the cache
|
CacheController(this) // load the cache
|
||||||
EncryptedPreferences.load(this)
|
EncryptedPreferences.load(this)
|
||||||
|
|
||||||
val parser = QISPOSParser()
|
|
||||||
parser.parseGrades(applicationContext)
|
|
||||||
|
|
||||||
}
|
}
|
||||||
Log.i(className, "startup completed in $startupTime ms")
|
Log.i(className, "startup completed in $startupTime ms")
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,3 +1,25 @@
|
||||||
|
/**
|
||||||
|
* ProjectLaogai
|
||||||
|
*
|
||||||
|
* Copyright 2019-2020 <seil0@mosad.xyz>
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
||||||
|
* MA 02110-1301, USA.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
package org.mosad.seil0.projectlaogai.controller
|
package org.mosad.seil0.projectlaogai.controller
|
||||||
|
|
||||||
import android.content.Context
|
import android.content.Context
|
||||||
|
@ -28,22 +50,26 @@ class QISPOSParser {
|
||||||
//private val rootPath = "/qispos/rds?state=change&type=1&moduleParameter=studyPOSMenu&nextdir=change&next=menu.vm&subdir=applications&xml=menu&purge=y&navigationPosition=functions%2CstudyPOSMenu&breadcrumb=studyPOSMenu&topitem=functions&subitem=studyPOSMenu"
|
//private val rootPath = "/qispos/rds?state=change&type=1&moduleParameter=studyPOSMenu&nextdir=change&next=menu.vm&subdir=applications&xml=menu&purge=y&navigationPosition=functions%2CstudyPOSMenu&breadcrumb=studyPOSMenu&topitem=functions&subitem=studyPOSMenu"
|
||||||
|
|
||||||
|
|
||||||
fun parseGrades(context: Context) {
|
fun parseGrades(context: Context): HashMap<String, ArrayList<gradeSubject>> {
|
||||||
val gradesMap = HashMap<String, ArrayList<gradeSubject>>()
|
val gradesMap = HashMap<String, ArrayList<gradeSubject>>()
|
||||||
val gradesListHtml = readGrades(context)
|
val gradesListHtml = readGrades(context)
|
||||||
|
|
||||||
gradesListHtml?.select("table > tbody > tr")?.forEach {
|
gradesListHtml?.select("table > tbody > tr")?.forEach {
|
||||||
val row = it.select("td.qis_konto")
|
//val row = it.select("td.qis_konto")
|
||||||
|
|
||||||
|
val row = it.select("td.tabelle1_alignleft,td.tabelle1_aligncenter,td.tabelle1_alignright")
|
||||||
|
|
||||||
//println("-----------------------------------------------------------")
|
//println("-----------------------------------------------------------")
|
||||||
//println(it.select("td.qis_konto"))
|
//println(it.select("td.qis_konto"))
|
||||||
|
|
||||||
if(row.size >= 6) {
|
//if(row.size >= 6) {
|
||||||
|
// only real subjects will be selected
|
||||||
|
if(row.size >= 6 && row[0].text().length >=7) {
|
||||||
val subject = gradeSubject(
|
val subject = gradeSubject(
|
||||||
id = row[0].text(),
|
id = row[0].text(),
|
||||||
name = row[1].text(),
|
name = row[1].text(),
|
||||||
semester = row[2].text(),
|
semester = row[2].text(),
|
||||||
grade = row[3].text(),
|
grade = if (row[3].text().isNotEmpty()) row[3].text() else row[4].text(),
|
||||||
credits = row[5].text()
|
credits = row[5].text()
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -73,6 +99,8 @@ class QISPOSParser {
|
||||||
// TODO sort
|
// TODO sort
|
||||||
|
|
||||||
println("finished parsing!")
|
println("finished parsing!")
|
||||||
|
|
||||||
|
return gradesMap
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -0,0 +1,103 @@
|
||||||
|
/**
|
||||||
|
* ProjectLaogai
|
||||||
|
*
|
||||||
|
* Copyright 2019-2020 <seil0@mosad.xyz>
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
||||||
|
* MA 02110-1301, USA.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
package org.mosad.seil0.projectlaogai.fragments
|
||||||
|
|
||||||
|
import android.os.Bundle
|
||||||
|
import android.view.LayoutInflater
|
||||||
|
import android.view.View
|
||||||
|
import android.view.ViewGroup
|
||||||
|
import androidx.fragment.app.Fragment
|
||||||
|
import androidx.swiperefreshlayout.widget.SwipeRefreshLayout
|
||||||
|
import kotlinx.android.synthetic.main.fragment_grades.*
|
||||||
|
import kotlinx.coroutines.Dispatchers
|
||||||
|
import kotlinx.coroutines.GlobalScope
|
||||||
|
import kotlinx.coroutines.launch
|
||||||
|
import kotlinx.coroutines.withContext
|
||||||
|
import org.mosad.seil0.projectlaogai.R
|
||||||
|
import org.mosad.seil0.projectlaogai.controller.QISPOSParser
|
||||||
|
import org.mosad.seil0.projectlaogai.uicomponents.DayCardView
|
||||||
|
import org.mosad.seil0.projectlaogai.uicomponents.GradeLinearLayout
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A simple [Fragment] subclass.
|
||||||
|
*/
|
||||||
|
class GradesFragment : Fragment() {
|
||||||
|
|
||||||
|
private lateinit var refreshLayoutGrades: SwipeRefreshLayout
|
||||||
|
|
||||||
|
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
|
||||||
|
val view: View = inflater.inflate(R.layout.fragment_grades, container, false)
|
||||||
|
|
||||||
|
refreshLayoutGrades = view.findViewById(R.id.refreshLayout_Grades)
|
||||||
|
|
||||||
|
GlobalScope.launch(Dispatchers.Default) {
|
||||||
|
addGrades()
|
||||||
|
}
|
||||||
|
|
||||||
|
return view
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun addGrades() = GlobalScope.launch(Dispatchers.Default) {
|
||||||
|
withContext(Dispatchers.Main) {
|
||||||
|
refreshLayout_Grades.isRefreshing = true
|
||||||
|
}
|
||||||
|
|
||||||
|
val parser = QISPOSParser()
|
||||||
|
val grades = parser.parseGrades(context!!)
|
||||||
|
|
||||||
|
withContext(Dispatchers.Main) {
|
||||||
|
linLayout_Grades.removeAllViews() // clear layout
|
||||||
|
}
|
||||||
|
|
||||||
|
// for each semester add a new card
|
||||||
|
grades.forEach { semester ->
|
||||||
|
val semesterCard = DayCardView(context!!)
|
||||||
|
semesterCard.setDayHeading(semester.key)
|
||||||
|
|
||||||
|
// for each subject add a new linLayout
|
||||||
|
semester.value.forEachIndexed { index, subject ->
|
||||||
|
val subjectLayout = GradeLinearLayout(context).set {
|
||||||
|
subjectName = subject.name
|
||||||
|
grade = subject.grade
|
||||||
|
}
|
||||||
|
|
||||||
|
if (index == semester.value.lastIndex)
|
||||||
|
subjectLayout.disableDivider()
|
||||||
|
|
||||||
|
semesterCard.getLinLayoutDay().addView(subjectLayout)
|
||||||
|
}
|
||||||
|
|
||||||
|
// without context we can't access the view
|
||||||
|
withContext(Dispatchers.Main) {
|
||||||
|
linLayout_Grades.addView(semesterCard)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
withContext(Dispatchers.Main) {
|
||||||
|
refreshLayout_Grades.isRefreshing = false
|
||||||
|
}
|
||||||
|
|
||||||
|
//refreshLayoutGrades.isRefreshing = false
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,51 @@
|
||||||
|
/**
|
||||||
|
* ProjectLaogai
|
||||||
|
*
|
||||||
|
* Copyright 2019-2020 <seil0@mosad.xyz>
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
||||||
|
* MA 02110-1301, USA.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.mosad.seil0.projectlaogai.uicomponents
|
||||||
|
|
||||||
|
import android.content.Context
|
||||||
|
import android.view.View
|
||||||
|
import android.widget.LinearLayout
|
||||||
|
import androidx.cardview.widget.CardView
|
||||||
|
import kotlinx.android.synthetic.main.linearlayout_grade.view.*
|
||||||
|
import org.mosad.seil0.projectlaogai.R
|
||||||
|
|
||||||
|
class GradeLinearLayout(context: Context?): LinearLayout(context) {
|
||||||
|
|
||||||
|
var subjectName = ""
|
||||||
|
var grade = ""
|
||||||
|
|
||||||
|
init {
|
||||||
|
CardView.inflate(context, R.layout.linearlayout_grade, this)
|
||||||
|
}
|
||||||
|
|
||||||
|
fun set(func: GradeLinearLayout.() -> Unit): GradeLinearLayout = apply {
|
||||||
|
func()
|
||||||
|
|
||||||
|
txtView_subject.text = subjectName
|
||||||
|
txtView_grade.text = grade
|
||||||
|
}
|
||||||
|
|
||||||
|
fun disableDivider() {
|
||||||
|
divider_grades.visibility = View.GONE
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,41 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:id="@+id/linLayout_grade"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:orientation="vertical"
|
||||||
|
android:paddingLeft="7dp"
|
||||||
|
android:paddingTop="2dp"
|
||||||
|
android:paddingRight="7dp"
|
||||||
|
android:paddingBottom="3dp">
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:orientation="horizontal">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/txtView_subject"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_weight="1"
|
||||||
|
android:text="Mathematik 1"
|
||||||
|
android:textSize="15sp" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/txtView_grade"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_weight="1"
|
||||||
|
android:text="2,0"
|
||||||
|
android:textAlignment="textEnd"
|
||||||
|
android:textSize="15sp" />
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
<View
|
||||||
|
android:id="@+id/divider_grades"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="1dp"
|
||||||
|
android:layout_marginTop="2dp"
|
||||||
|
android:background="?dividerColor" />
|
||||||
|
</LinearLayout>
|
|
@ -0,0 +1,37 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
tools:context=".fragments.GradesFragment">
|
||||||
|
|
||||||
|
<androidx.swiperefreshlayout.widget.SwipeRefreshLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:id="@+id/refreshLayout_Grades">
|
||||||
|
|
||||||
|
<ScrollView
|
||||||
|
android:id="@+id/scrollView_Grades"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent">
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:id="@+id/linLayout_Grades"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:orientation="vertical" >
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/txtView_Loading"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:layout_marginTop="100dp"
|
||||||
|
android:padding="7dp"
|
||||||
|
android:text="@string/loading_from_hs"
|
||||||
|
android:textAlignment="center"
|
||||||
|
android:textSize="15sp" />
|
||||||
|
</LinearLayout>
|
||||||
|
</ScrollView>
|
||||||
|
</androidx.swiperefreshlayout.widget.SwipeRefreshLayout>
|
||||||
|
|
||||||
|
</FrameLayout>
|
|
@ -20,6 +20,10 @@
|
||||||
android:id="@+id/nav_moodle"
|
android:id="@+id/nav_moodle"
|
||||||
android:icon="@drawable/ic_school_black_24dp"
|
android:icon="@drawable/ic_school_black_24dp"
|
||||||
android:title="@string/moodle"/>
|
android:title="@string/moodle"/>
|
||||||
|
<item
|
||||||
|
android:id="@+id/nav_grades"
|
||||||
|
android:icon="@drawable/icon_checkmark_black"
|
||||||
|
android:title="@string/grades" />
|
||||||
<item
|
<item
|
||||||
android:id="@+id/nav_settings"
|
android:id="@+id/nav_settings"
|
||||||
android:icon="@drawable/ic_settings_black_24dp"
|
android:icon="@drawable/ic_settings_black_24dp"
|
||||||
|
|
|
@ -8,6 +8,7 @@
|
||||||
<string name="mensa">Mensa</string>
|
<string name="mensa">Mensa</string>
|
||||||
<string name="timetable">Stundenplan</string>
|
<string name="timetable">Stundenplan</string>
|
||||||
<string name="moodle">Moodle</string>
|
<string name="moodle">Moodle</string>
|
||||||
|
<string name="grades">Noten</string>
|
||||||
<string name="settings">Einstellungen</string>
|
<string name="settings">Einstellungen</string>
|
||||||
|
|
||||||
<!-- Onboarding -->
|
<!-- Onboarding -->
|
||||||
|
@ -38,6 +39,9 @@
|
||||||
<string name="courses">Studiengänge:</string>
|
<string name="courses">Studiengänge:</string>
|
||||||
<string name="lessons">Vorlesungen:</string>
|
<string name="lessons">Vorlesungen:</string>
|
||||||
|
|
||||||
|
<!-- fragment_grades -->
|
||||||
|
<string name="loading_from_hs">Lade Daten von den Hochschul Servern.\nDas kann eine Weile dauern.</string>
|
||||||
|
|
||||||
<!-- fragment_settings -->
|
<!-- fragment_settings -->
|
||||||
<string name="info">Info</string>
|
<string name="info">Info</string>
|
||||||
<string name="user">Benutzer</string>
|
<string name="user">Benutzer</string>
|
||||||
|
|
|
@ -10,6 +10,7 @@
|
||||||
<string name="mensa">Mensa</string>
|
<string name="mensa">Mensa</string>
|
||||||
<string name="timetable">Timetable</string>
|
<string name="timetable">Timetable</string>
|
||||||
<string name="moodle">Moodle</string>
|
<string name="moodle">Moodle</string>
|
||||||
|
<string name="grades">Grades</string>
|
||||||
<string name="settings">Settings</string>
|
<string name="settings">Settings</string>
|
||||||
|
|
||||||
<!-- Onboarding -->
|
<!-- Onboarding -->
|
||||||
|
@ -40,6 +41,9 @@
|
||||||
<string name="courses">Courses:</string>
|
<string name="courses">Courses:</string>
|
||||||
<string name="lessons">Lessons:</string>
|
<string name="lessons">Lessons:</string>
|
||||||
|
|
||||||
|
<!-- fragment_grades -->
|
||||||
|
<string name="loading_from_hs">Loading data from the university servers.\nThis may take a while.</string>
|
||||||
|
|
||||||
<!-- fragment_settings -->
|
<!-- fragment_settings -->
|
||||||
<string name="info">Info</string>
|
<string name="info">Info</string>
|
||||||
<string name="user">User</string>
|
<string name="user">User</string>
|
||||||
|
|
Loading…
Reference in New Issue