diff --git a/app/src/main/java/pl/szczodrzynski/edziennik/ui/dialogs/event/EventManualV2Dialog.kt b/app/src/main/java/pl/szczodrzynski/edziennik/ui/dialogs/event/EventManualV2Dialog.kt index 955ef66b..527acf15 100644 --- a/app/src/main/java/pl/szczodrzynski/edziennik/ui/dialogs/event/EventManualV2Dialog.kt +++ b/app/src/main/java/pl/szczodrzynski/edziennik/ui/dialogs/event/EventManualV2Dialog.kt @@ -57,300 +57,292 @@ class EventManualV2Dialog( private lateinit var event: Event private var customColor: Int? = null - init { - run { - if (activity.isFinishing) - return@run - job = Job() - onShowListener?.invoke(TAG) - b = DialogEventManualV2Binding.inflate(activity.layoutInflater) - dialog = MaterialAlertDialogBuilder(activity) - .setTitle(R.string.dialog_event_manual_title) - .setView(b.root) - .setNegativeButton(R.string.cancel) { dialog, _ -> dialog.dismiss() } - .setPositiveButton(R.string.save) { _, _ -> saveEvent() } - .setOnDismissListener { - onDismissListener?.invoke(TAG) - } - .show() + init { run { + if (activity.isFinishing) + return@run + job = Job() + onShowListener?.invoke(TAG) + b = DialogEventManualV2Binding.inflate(activity.layoutInflater) + dialog = MaterialAlertDialogBuilder(activity) + .setTitle(R.string.dialog_event_manual_title) + .setView(b.root) + .setNegativeButton(R.string.cancel) { dialog, _ -> dialog.dismiss() } + .setPositiveButton(R.string.save) { _, _ -> saveEvent() } + .setOnDismissListener { + onDismissListener?.invoke(TAG) + } + .show() - event = editingEvent?.clone() ?: Event().also { event -> - event.profileId = profileId - /*defaultDate?.let { - event.eventDate = it - b.date = it - } - defaultTime?.let { - event.startTime = it - b.time = it - } - defaultType?.let { - event.type = it - }*/ + event = editingEvent?.clone() ?: Event().also { event -> + event.profileId = profileId + /*defaultDate?.let { + event.eventDate = it + b.date = it } - - b.showMore.onClick { - // TODO iconics is broken - it.apply { - refreshDrawableState() - - if (isChecked) - Anim.expand(b.moreLayout, 200, null) - else - Anim.collapse(b.moreLayout, 200, null) - } + defaultTime?.let { + event.startTime = it + b.time = it } - - loadLists() + defaultType?.let { + event.type = it + }*/ } - } - private fun loadLists() { - launch { - val deferred = async(Dispatchers.Default) { - // get the team list - val teams = app.db.teamDao().getAllNow(profileId) - b.teamDropdown.clear() - b.teamDropdown += TextInputDropDown.Item( - -1, - activity.getString(R.string.dialog_event_manual_no_team), - "" - ) - b.teamDropdown += teams.map { TextInputDropDown.Item(it.id, it.name, tag = it) } + b.showMore.onClick { // TODO iconics is broken + it.apply { + refreshDrawableState() - // get the subject list - val subjects = app.db.subjectDao().getAllNow(profileId) - b.subjectDropdown.clear() - b.subjectDropdown += TextInputDropDown.Item( - -1, - activity.getString(R.string.dialog_event_manual_no_subject), - "" - ) - b.subjectDropdown += subjects.map { TextInputDropDown.Item(it.id, it.longName, tag = it) } - - // get the teacher list - val teachers = app.db.teacherDao().getAllNow(profileId) - b.teacherDropdown.clear() - b.teacherDropdown += TextInputDropDown.Item( - -1, - activity.getString(R.string.dialog_event_manual_no_teacher), - "" - ) - b.teacherDropdown += teachers.map { TextInputDropDown.Item(it.id, it.fullName, tag = it) } - - // get the event type list - val eventTypes = app.db.eventTypeDao().getAllNow(profileId) - b.typeDropdown.clear() - b.typeDropdown += eventTypes.map { TextInputDropDown.Item(it.id, it.name, tag = it) } + if (isChecked) + Anim.expand(b.moreLayout, 200, null) + else + Anim.collapse(b.moreLayout, 200, null) } - deferred.await() + } - b.teamDropdown.isEnabled = true - b.subjectDropdown.isEnabled = true - b.teacherDropdown.isEnabled = true - b.typeDropdown.isEnabled = true + loadLists() + }} - b.typeDropdown.selected?.let { item -> + private fun loadLists() { launch { + val deferred = async(Dispatchers.Default) { + // get the team list + val teams = app.db.teamDao().getAllNow(profileId) + b.teamDropdown.clear() + b.teamDropdown += TextInputDropDown.Item( + -1, + activity.getString(R.string.dialog_event_manual_no_team), + "" + ) + b.teamDropdown += teams.map { TextInputDropDown.Item(it.id, it.name, tag = it) } + + // get the subject list + val subjects = app.db.subjectDao().getAllNow(profileId) + b.subjectDropdown.clear() + b.subjectDropdown += TextInputDropDown.Item( + -1, + activity.getString(R.string.dialog_event_manual_no_subject), + "" + ) + b.subjectDropdown += subjects.map { TextInputDropDown.Item(it.id, it.longName, tag = it) } + + // get the teacher list + val teachers = app.db.teacherDao().getAllNow(profileId) + b.teacherDropdown.clear() + b.teacherDropdown += TextInputDropDown.Item( + -1, + activity.getString(R.string.dialog_event_manual_no_teacher), + "" + ) + b.teacherDropdown += teachers.map { TextInputDropDown.Item(it.id, it.fullName, tag = it) } + + // get the event type list + val eventTypes = app.db.eventTypeDao().getAllNow(profileId) + b.typeDropdown.clear() + b.typeDropdown += eventTypes.map { TextInputDropDown.Item(it.id, it.name, tag = it) } + } + deferred.await() + + b.teamDropdown.isEnabled = true + b.subjectDropdown.isEnabled = true + b.teacherDropdown.isEnabled = true + b.typeDropdown.isEnabled = true + + b.typeDropdown.selected?.let { item -> + customColor = (item.tag as EventType).color + } + + // copy IDs from event being edited + editingEvent?.let { + b.teamDropdown.select(it.teamId) + b.subjectDropdown.select(it.subjectId) + b.teacherDropdown.select(it.teacherId) + b.typeDropdown.select(it.type)?.let { item -> customColor = (item.tag as EventType).color } - - // copy IDs from event being edited - editingEvent?.let { - b.teamDropdown.select(it.teamId) - b.subjectDropdown.select(it.subjectId) - b.teacherDropdown.select(it.teacherId) - b.typeDropdown.select(it.type)?.let { item -> - customColor = (item.tag as EventType).color - } - if (it.color != -1) - customColor = it.color - } - - // copy IDs from the LessonFull - defaultLesson?.let { - b.teamDropdown.select(it.displayTeamId) - b.subjectDropdown.select(it.displaySubjectId) - b.teacherDropdown.select(it.displayTeacherId) - } - - b.typeDropdown.setOnChangeListener { - b.typeDropdown.background.colorFilter = PorterDuffColorFilter((it.tag as EventType).color, PorterDuff.Mode.SRC_ATOP) - customColor = null - return@setOnChangeListener true - } - customColor?.let { - b.typeDropdown.background.colorFilter = PorterDuffColorFilter(it, PorterDuff.Mode.SRC_ATOP) - } - b.typeColor.onClick { - val currentColor = (b.typeDropdown?.selected?.tag as EventType?)?.color - ?: Event.COLOR_DEFAULT - val colorPickerDialog = ColorPickerDialog.newBuilder() - .setColor(currentColor) - .create() - colorPickerDialog.setColorPickerDialogListener( - object : ColorPickerDialogListener { - override fun onDialogDismissed(dialogId: Int) {} - override fun onColorSelected(dialogId: Int, color: Int) { - b.typeDropdown.background.colorFilter = PorterDuffColorFilter(color, PorterDuff.Mode.SRC_ATOP) - customColor = color - } - }) - colorPickerDialog.show(activity.fragmentManager, "color-picker-dialog") - } - - loadDates() + if (it.color != -1) + customColor = it.color } - } - private fun loadDates() { - launch { - val date = Date.getToday() - val today = date.value - var weekDay = date.weekDay + // copy IDs from the LessonFull + defaultLesson?.let { + b.teamDropdown.select(it.displayTeamId) + b.subjectDropdown.select(it.displaySubjectId) + b.teacherDropdown.select(it.displayTeacherId) + } - val deferred = async(Dispatchers.Default) { - val dates = mutableListOf() - // item choosing the next lesson of specific subject - b.subjectDropdown.selected?.let { - if (it.tag is Subject) { - dates += TextInputDropDown.Item( - -it.id, - activity.getString(R.string.dialog_event_manual_date_next_lesson, it.tag.longName) - ) - } + b.typeDropdown.setOnChangeListener { + b.typeColor.background.colorFilter = PorterDuffColorFilter((it.tag as EventType).color, PorterDuff.Mode.SRC_ATOP) + customColor = null + return@setOnChangeListener true + } + (customColor ?: Event.COLOR_DEFAULT).let { + b.typeColor.background.colorFilter = PorterDuffColorFilter(it, PorterDuff.Mode.SRC_ATOP) + } + b.typeColor.onClick { + val currentColor = (b.typeDropdown?.selected?.tag as EventType?)?.color ?: Event.COLOR_DEFAULT + val colorPickerDialog = ColorPickerDialog.newBuilder() + .setColor(currentColor) + .create() + colorPickerDialog.setColorPickerDialogListener( + object : ColorPickerDialogListener { + override fun onDialogDismissed(dialogId: Int) {} + override fun onColorSelected(dialogId: Int, color: Int) { + b.typeColor.background.colorFilter = PorterDuffColorFilter(color, PorterDuff.Mode.SRC_ATOP) + customColor = color + } + }) + colorPickerDialog.show(activity.fragmentManager, "color-picker-dialog") + } + + loadDates() + }} + + private fun loadDates() { launch { + val date = Date.getToday() + val today = date.value + var weekDay = date.weekDay + + val deferred = async(Dispatchers.Default) { + val dates = mutableListOf() + // item choosing the next lesson of specific subject + b.subjectDropdown.selected?.let { + if (it.tag is Subject) { + dates += TextInputDropDown.Item( + -it.id, + activity.getString(R.string.dialog_event_manual_date_next_lesson, it.tag.longName) + ) } + } - // TODAY + // TODAY + dates += TextInputDropDown.Item( + date.value.toLong(), + activity.getString(R.string.dialog_event_manual_date_today, date.formattedString), + tag = date.clone() + ) + + // TOMORROW + if (weekDay < 4) { + date.stepForward(0, 0, 1) + weekDay++ dates += TextInputDropDown.Item( date.value.toLong(), - activity.getString(R.string.dialog_event_manual_date_today, date.formattedString), + activity.getString(R.string.dialog_event_manual_date_tomorrow, date.formattedString), tag = date.clone() ) - - // TOMORROW - if (weekDay < 4) { - date.stepForward(0, 0, 1) - weekDay++ - dates += TextInputDropDown.Item( - date.value.toLong(), - activity.getString(R.string.dialog_event_manual_date_tomorrow, date.formattedString), - tag = date.clone() - ) - } - // REMAINING SCHOOL DAYS OF THE CURRENT WEEK - while (weekDay < 4) { - date.stepForward(0, 0, 1) // step one day forward - weekDay++ - dates += TextInputDropDown.Item( - date.value.toLong(), - activity.getString(R.string.dialog_event_manual_date_this_week, Week.getFullDayName(weekDay), date.formattedString), - tag = date.clone() - ) - } - // go to next week Monday - date.stepForward(0, 0, -weekDay + 7) - weekDay = 0 - // ALL SCHOOL DAYS OF THE NEXT WEEK - while (weekDay < 4) { - dates += TextInputDropDown.Item( - date.value.toLong(), - activity.getString(R.string.dialog_event_manual_date_next_week, Week.getFullDayName(weekDay), date.formattedString), - tag = date.clone() - ) - date.stepForward(0, 0, 1) // step one day forward - weekDay++ - } + } + // REMAINING SCHOOL DAYS OF THE CURRENT WEEK + while (weekDay < 4) { + date.stepForward(0, 0, 1) // step one day forward + weekDay++ dates += TextInputDropDown.Item( - -1L, - activity.getString(R.string.dialog_event_manual_date_other) + date.value.toLong(), + activity.getString(R.string.dialog_event_manual_date_this_week, Week.getFullDayName(weekDay), date.formattedString), + tag = date.clone() ) - dates } - - val dates = deferred.await() - b.dateDropdown.clear().append(dates) - - editingEvent?.eventDate?.let { - b.dateDropdown.select(TextInputDropDown.Item( - it.value.toLong(), - it.formattedString, - tag = it - )) + // go to next week Monday + date.stepForward(0, 0, -weekDay + 7) + weekDay = 0 + // ALL SCHOOL DAYS OF THE NEXT WEEK + while (weekDay < 4) { + dates += TextInputDropDown.Item( + date.value.toLong(), + activity.getString(R.string.dialog_event_manual_date_next_week, Week.getFullDayName(weekDay), date.formattedString), + tag = date.clone() + ) + date.stepForward(0, 0, 1) // step one day forward + weekDay++ } - - defaultLesson?.displayDate?.let { - b.dateDropdown.select(TextInputDropDown.Item( - it.value.toLong(), - it.formattedString, - tag = it - )) - } - - if (b.dateDropdown.selected == null) { - b.dateDropdown.select(today.toLong()) - } - - b.dateDropdown.isEnabled = true - - b.dateDropdown.setOnChangeListener { item -> - when { - // next lesson with specified subject - item.id < -1 -> { - val teamId = defaultLesson?.teamId ?: -1 - val selectedLessonDate = defaultLesson?.date ?: Date.getToday() - - when (teamId) { - -1L -> app.db.timetableDao().getNextWithSubject(profileId, selectedLessonDate, -item.id) - else -> app.db.timetableDao().getNextWithSubjectAndTeam(profileId, selectedLessonDate, -item.id, teamId) - }.observeOnce(activity, Observer { - val lessonDate = it?.displayDate ?: return@Observer - b.dateDropdown.select(TextInputDropDown.Item( - lessonDate.value.toLong(), - lessonDate.formattedString, - tag = lessonDate - )) - b.teamDropdown.select(it.displayTeamId) - b.subjectDropdown.select(it.displaySubjectId) - b.teacherDropdown.select(it.displayTeacherId) - defaultLoaded = false - loadHours(it.displayStartTime) - }) - return@setOnChangeListener false - } - // custom date - item.id == -1L -> { - MaterialDatePicker.Builder - .datePicker() - .setSelection((b.dateDropdown.selectedId?.let { Date.fromValue(it.toInt()) } - ?: Date.getToday()).inMillis) - .build() - .apply { - addOnPositiveButtonClickListener { - val dateSelected = Date.fromMillis(it) - b.dateDropdown.select(TextInputDropDown.Item( - dateSelected.value.toLong(), - dateSelected.formattedString, - tag = dateSelected - )) - loadHours() - } - show(this@EventManualV2Dialog.activity.supportFragmentManager, "MaterialDatePicker") - } - - return@setOnChangeListener false - } - // a specific date - else -> { - b.dateDropdown.select(item) - loadHours() - } - } - return@setOnChangeListener true - } - - loadHours() + dates += TextInputDropDown.Item( + -1L, + activity.getString(R.string.dialog_event_manual_date_other) + ) + dates } - } + + val dates = deferred.await() + b.dateDropdown.clear().append(dates) + + editingEvent?.eventDate?.let { + b.dateDropdown.select(TextInputDropDown.Item( + it.value.toLong(), + it.formattedString, + tag = it + )) + } + + defaultLesson?.displayDate?.let { + b.dateDropdown.select(TextInputDropDown.Item( + it.value.toLong(), + it.formattedString, + tag = it + )) + } + + if (b.dateDropdown.selected == null) { + b.dateDropdown.select(today.toLong()) + } + + b.dateDropdown.isEnabled = true + + b.dateDropdown.setOnChangeListener { item -> + when { + // next lesson with specified subject + item.id < -1 -> { + val teamId = defaultLesson?.teamId ?: -1 + val selectedLessonDate = defaultLesson?.date ?: Date.getToday() + + when (teamId) { + -1L -> app.db.timetableDao().getNextWithSubject(profileId, selectedLessonDate, -item.id) + else -> app.db.timetableDao().getNextWithSubjectAndTeam(profileId, selectedLessonDate, -item.id, teamId) + }.observeOnce(activity, Observer { + val lessonDate = it?.displayDate ?: return@Observer + b.dateDropdown.select(TextInputDropDown.Item( + lessonDate.value.toLong(), + lessonDate.formattedString, + tag = lessonDate + )) + b.teamDropdown.select(it.displayTeamId) + b.subjectDropdown.select(it.displaySubjectId) + b.teacherDropdown.select(it.displayTeacherId) + defaultLoaded = false + loadHours(it.displayStartTime) + }) + return@setOnChangeListener false + } + // custom date + item.id == -1L -> { + MaterialDatePicker.Builder + .datePicker() + .setSelection((b.dateDropdown.selectedId?.let { Date.fromValue(it.toInt()) } + ?: Date.getToday()).inMillis) + .build() + .apply { + addOnPositiveButtonClickListener { + val dateSelected = Date.fromMillis(it) + b.dateDropdown.select(TextInputDropDown.Item( + dateSelected.value.toLong(), + dateSelected.formattedString, + tag = dateSelected + )) + loadHours() + } + show(this@EventManualV2Dialog.activity.supportFragmentManager, "MaterialDatePicker") + } + + return@setOnChangeListener false + } + // a specific date + else -> { + b.dateDropdown.select(item) + loadHours() + } + } + return@setOnChangeListener true + } + + loadHours() + }} private fun loadHours(defaultHour: Time? = null) { b.timeDropdown.isEnabled = false @@ -378,7 +370,8 @@ class EventManualV2Dialog( lesson.displayStartTime?.stringHM ?: "", lesson.displaySubjectName?.let { when { - lesson.type == Lesson.TYPE_CANCELLED -> it.asStrikethroughSpannable() + lesson.type == Lesson.TYPE_CANCELLED + || lesson.type == Lesson.TYPE_SHIFTED_SOURCE -> it.asStrikethroughSpannable() lesson.type != Lesson.TYPE_NORMAL -> it.asItalicSpannable() else -> it } @@ -405,7 +398,8 @@ class EventManualV2Dialog( // clear subject, teacher selection b.subjectDropdown.deselect() b.teacherDropdown.deselect() - } else { + } + else { editingEvent?.let { b.timeDropdown.select(it.startTime?.value?.toLong()) } @@ -442,7 +436,7 @@ class EventManualV2Dialog( b.teamDropdown.deselect() b.subjectDropdown.deselect() b.teacherDropdown.deselect() - item.tag.displayTeamId?.let { + item.tag.displayTeamId?.let { b.teamDropdown.select(it) } item.tag.displaySubjectId?.let {