From ee9b095f24dc9e11beb844565869af3c8a0ba1b9 Mon Sep 17 00:00:00 2001 From: ralhamami Date: Thu, 5 Nov 2015 20:49:00 -0600 Subject: [PATCH 1/6] Fixed Need for Pressing Back Button Twice on Attendance Item Fragment -Updated onBackPressed in MainActivity to pop the backstack in TeacherAttendanceItem instance --- .../edu/uco/schambers/classmate/Activites/MainActivity.java | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/app/src/main/java/edu/uco/schambers/classmate/Activites/MainActivity.java b/app/src/main/java/edu/uco/schambers/classmate/Activites/MainActivity.java index 2592faa..f56e684 100644 --- a/app/src/main/java/edu/uco/schambers/classmate/Activites/MainActivity.java +++ b/app/src/main/java/edu/uco/schambers/classmate/Activites/MainActivity.java @@ -40,6 +40,7 @@ import edu.uco.schambers.classmate.Fragments.StudentInterface; import edu.uco.schambers.classmate.Fragments.StudentResponseFragment; import edu.uco.schambers.classmate.Fragments.StudentRollCall; +import edu.uco.schambers.classmate.Fragments.TeacherAttendanceItem; import edu.uco.schambers.classmate.Fragments.TeacherInterface; import edu.uco.schambers.classmate.Fragments.TeacherQuestionResults; import edu.uco.schambers.classmate.Fragments.UserInformation; @@ -485,7 +486,9 @@ public void onBackPressed(){ if (f instanceof StudentRollCall && !((StudentRollCall) f).allowBackPressed()){ return; } - + else if (f instanceof TeacherAttendanceItem){ + getFragmentManager().popBackStack(); + } super.onBackPressed(); } } From 6f97779df6775f13a8f094279d4a3e1fcc5dab55 Mon Sep 17 00:00:00 2001 From: Rayan Al-Hammami Date: Thu, 5 Nov 2015 20:51:25 -0600 Subject: [PATCH 2/6] Added Descriptive Comment to onBackPressed --- .../edu/uco/schambers/classmate/Activites/MainActivity.java | 2 ++ 1 file changed, 2 insertions(+) diff --git a/app/src/main/java/edu/uco/schambers/classmate/Activites/MainActivity.java b/app/src/main/java/edu/uco/schambers/classmate/Activites/MainActivity.java index f56e684..07c2418 100644 --- a/app/src/main/java/edu/uco/schambers/classmate/Activites/MainActivity.java +++ b/app/src/main/java/edu/uco/schambers/classmate/Activites/MainActivity.java @@ -486,6 +486,8 @@ public void onBackPressed(){ if (f instanceof StudentRollCall && !((StudentRollCall) f).allowBackPressed()){ return; } + //Back button will pop back stack in instances of teacher attendance item + //to allow pressing back only once else if (f instanceof TeacherAttendanceItem){ getFragmentManager().popBackStack(); } From 1f3a7494c65394a59b45ebd18a7aeada4e7e73c0 Mon Sep 17 00:00:00 2001 From: Rayan Al-Hammami Date: Sun, 8 Nov 2015 17:02:55 -0600 Subject: [PATCH 3/6] Added Note Functionality for Individual Students -Using a context display -Storing to shared preferences -Still working out some bugs --- .../Fragments/TeacherAttendance.java | 6 +- .../Fragments/TeacherAttendanceItem.java | 56 ++++++++++-- .../fragment_teacher_attendance_item.xml | 86 ++++++------------- 3 files changed, 76 insertions(+), 72 deletions(-) diff --git a/app/src/main/java/edu/uco/schambers/classmate/Fragments/TeacherAttendance.java b/app/src/main/java/edu/uco/schambers/classmate/Fragments/TeacherAttendance.java index 458e37b..6016f92 100644 --- a/app/src/main/java/edu/uco/schambers/classmate/Fragments/TeacherAttendance.java +++ b/app/src/main/java/edu/uco/schambers/classmate/Fragments/TeacherAttendance.java @@ -282,7 +282,7 @@ public void buildTable(View view, int position){ teacherAttendanceTable.bringToFront(); teacherAttendanceTable.removeAllViews(); //Loops through the entire list of students - for (StudentAbsenceByClass student : students) { + for (final StudentAbsenceByClass student : students) { //If the current student's course is equal to the course chosen //Store the number of absences @@ -300,7 +300,7 @@ public boolean onTouch(View v, MotionEvent event) { //Momentarily change background color to indicate the touch v.setBackgroundColor(Color.GRAY); //Set up a new fragment object - Fragment teacherAttendanceItem = TeacherAttendanceItem.newInstance(absences + "", "test"); + Fragment teacherAttendanceItem = TeacherAttendanceItem.newInstance(absences + "", student.getName()); //Pass the attendance info, replace the current fragment, and place old //fragment on the backstack FragmentTransaction transaction = getFragmentManager().beginTransaction(); @@ -318,7 +318,7 @@ public boolean onTouch(View v, MotionEvent event) { TextView c0 = new TextView(view.getContext()); c0.setText(student.getName()); TextView c2 = new TextView(view.getContext()); - c2.setText(String.valueOf(student.getAbsences())); + c2.setText(String.valueOf(4)); //student.getAbsences()) //Add the data to the row tr.addView(c0); tr.addView(c2); diff --git a/app/src/main/java/edu/uco/schambers/classmate/Fragments/TeacherAttendanceItem.java b/app/src/main/java/edu/uco/schambers/classmate/Fragments/TeacherAttendanceItem.java index bd43c26..81dcd56 100644 --- a/app/src/main/java/edu/uco/schambers/classmate/Fragments/TeacherAttendanceItem.java +++ b/app/src/main/java/edu/uco/schambers/classmate/Fragments/TeacherAttendanceItem.java @@ -13,29 +13,42 @@ package edu.uco.schambers.classmate.Fragments; import android.annotation.TargetApi; +import android.app.AlertDialog; import android.app.Fragment; import android.content.Context; +import android.content.DialogInterface; +import android.content.SharedPreferences; import android.graphics.Color; import android.net.Uri; import android.os.Build; import android.os.Bundle; +import android.text.Editable; +import android.util.Log; import android.view.LayoutInflater; import android.view.Menu; import android.view.MenuInflater; import android.view.MenuItem; import android.view.View; import android.view.ViewGroup; +import android.widget.ArrayAdapter; +import android.widget.Button; +import android.widget.EditText; import android.widget.LinearLayout; +import android.widget.ListView; import android.widget.TextView; import org.achartengine.ChartFactory; import org.achartengine.model.CategorySeries; import org.achartengine.renderer.DefaultRenderer; import org.achartengine.renderer.SimpleSeriesRenderer; +import org.w3c.dom.Text; + import edu.uco.schambers.classmate.R; public class TeacherAttendanceItem extends Fragment { int absences; - private TextView missing, attendance; + String studentName; + String note; + AlertDialog.Builder alert; private View mChart; private static final String ARG_PARAM1 = "param1"; private static final String ARG_PARAM2 = "param2"; @@ -57,6 +70,7 @@ public static TeacherAttendanceItem newInstance(String param1, String param2) { public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); absences = Integer.parseInt(getArguments().getString(ARG_PARAM1)); + studentName = getArguments().getString(ARG_PARAM2); } @@ -105,28 +119,52 @@ public View onCreateView(LayoutInflater inflater, ViewGroup container, //@TargetApi(Build.VERSION_CODES.M) private void initUI(final View rootView) { + alert = new AlertDialog.Builder(getContext()); String[] titles = new String[]{" Attendance ", " Absences "}; - int[] values = new int[]{10, absences}; - missing = (TextView) rootView.findViewById(R.id.ra_tvAbsences); - attendance = (TextView) rootView.findViewById(R.id.ra_tvAttendance); - attendance.setText(10+""); - missing.setText(absences+""); + int[] values = new int[]{10, 4}; //absences + TextView tvStudentName = (TextView)rootView.findViewById(R.id.textView4); + tvStudentName.setText(studentName); drawPieChar(rootView, rootView.getContext(), titles, values); + Button addNote = (Button)rootView.findViewById(R.id.addNote); + addNote.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + final EditText edittext = new EditText(getContext()); + alert.setMessage("Enter your note:"); + alert.setTitle("Add Note"); + + alert.setView(edittext); + + alert.setPositiveButton("Save", new DialogInterface.OnClickListener() { + public void onClick(DialogInterface dialog, int whichButton) { + note = edittext.getText().toString(); + TextView tvNote = (TextView) rootView.findViewById(R.id.tvNote); + tvNote.setText(note); + } + }); + + alert.setNegativeButton("Cancel", new DialogInterface.OnClickListener() { + public void onClick(DialogInterface dialog, int whichButton) { + } + }); + + alert.show(); + } + }); } public void drawPieChar(View rootView, Context context, String[] title, int[] value) { - // Color of each Pie Chart Section + // Color of each Pie Chart Sections int[] colors = {Color.BLUE, Color.MAGENTA, Color.GREEN, Color.CYAN, Color.RED, Color.TRANSPARENT}; - //Set up the percentage data CategorySeries categorySeries = new CategorySeries("Draw Pie"); double sum=0; for(int i=0;i - - - - - - - - - - - - - - + android:layout_height="wrap_content" + android:layout_column="0" + android:textAppearance="?android:attr/textAppearanceLarge"/> - + - +