mirror of
https://github.com/etesync/android
synced 2025-01-11 00:01:12 +00:00
Mostly fix email sending for events with attendees.
We need to correctly set the organizer (and for that we need the email address of the account).
This commit is contained in:
parent
21d6459cd9
commit
16f7187a77
@ -157,7 +157,7 @@ constructor(context: Context, account: Account, settings: AccountSettings, extra
|
|||||||
private fun createInviteAttendeesNotification(event: Event, icsContent: String) {
|
private fun createInviteAttendeesNotification(event: Event, icsContent: String) {
|
||||||
val intent = EventEmailInvitation(context, account).createIntent(event, icsContent)
|
val intent = EventEmailInvitation(context, account).createIntent(event, icsContent)
|
||||||
if (intent != null) {
|
if (intent != null) {
|
||||||
val notificationHelper = SyncNotification(context, event.uid!!, event.uid!!.hashCode())
|
val notificationHelper = SyncNotification(context, icsContent, event.hashCode())
|
||||||
notificationHelper.notify(
|
notificationHelper.notify(
|
||||||
context.getString(
|
context.getString(
|
||||||
R.string.sync_calendar_attendees_notification_title, event.summary),
|
R.string.sync_calendar_attendees_notification_title, event.summary),
|
||||||
|
@ -25,6 +25,7 @@ import com.etesync.syncadapter.Constants
|
|||||||
import com.etesync.syncadapter.R
|
import com.etesync.syncadapter.R
|
||||||
import com.etesync.syncadapter.resource.*
|
import com.etesync.syncadapter.resource.*
|
||||||
import com.etesync.syncadapter.ui.BaseActivity
|
import com.etesync.syncadapter.ui.BaseActivity
|
||||||
|
import com.etesync.syncadapter.utils.EventEmailInvitation
|
||||||
import com.etesync.syncadapter.utils.TaskProviderHandling
|
import com.etesync.syncadapter.utils.TaskProviderHandling
|
||||||
import com.google.android.material.tabs.TabLayout
|
import com.google.android.material.tabs.TabLayout
|
||||||
import ezvcard.util.PartialDate
|
import ezvcard.util.PartialDate
|
||||||
@ -40,6 +41,9 @@ class CollectionItemFragment(private val cachedItem: CachedItem) : Fragment() {
|
|||||||
private val model: AccountViewModel by activityViewModels()
|
private val model: AccountViewModel by activityViewModels()
|
||||||
private val collectionModel: CollectionViewModel by activityViewModels()
|
private val collectionModel: CollectionViewModel by activityViewModels()
|
||||||
|
|
||||||
|
private var emailInvitationEvent: Event? = null
|
||||||
|
private var emailInvitationEventString: String? = null
|
||||||
|
|
||||||
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
|
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
|
||||||
val ret = inflater.inflate(R.layout.journal_item_activity, container, false)
|
val ret = inflater.inflate(R.layout.journal_item_activity, container, false)
|
||||||
setHasOptionsMenu(true)
|
setHasOptionsMenu(true)
|
||||||
@ -58,7 +62,7 @@ class CollectionItemFragment(private val cachedItem: CachedItem) : Fragment() {
|
|||||||
|
|
||||||
private fun initUi(inflater: LayoutInflater, v: View, cachedCollection: CachedCollection) {
|
private fun initUi(inflater: LayoutInflater, v: View, cachedCollection: CachedCollection) {
|
||||||
val viewPager = v.findViewById<ViewPager>(R.id.viewpager)
|
val viewPager = v.findViewById<ViewPager>(R.id.viewpager)
|
||||||
viewPager.adapter = TabsAdapter(childFragmentManager, requireContext(), cachedCollection, cachedItem)
|
viewPager.adapter = TabsAdapter(childFragmentManager, this, requireContext(), cachedCollection, cachedItem)
|
||||||
|
|
||||||
val tabLayout = v.findViewById<TabLayout>(R.id.tabs)
|
val tabLayout = v.findViewById<TabLayout>(R.id.tabs)
|
||||||
tabLayout.setupWithViewPager(viewPager)
|
tabLayout.setupWithViewPager(viewPager)
|
||||||
@ -66,27 +70,35 @@ class CollectionItemFragment(private val cachedItem: CachedItem) : Fragment() {
|
|||||||
v.findViewById<View>(R.id.journal_list_item).visibility = View.GONE
|
v.findViewById<View>(R.id.journal_list_item).visibility = View.GONE
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fun allowSendEmail(event: Event?, icsContent: String) {
|
||||||
|
emailInvitationEvent = event
|
||||||
|
emailInvitationEventString = icsContent
|
||||||
|
activity?.invalidateOptionsMenu()
|
||||||
|
}
|
||||||
|
|
||||||
override fun onCreateOptionsMenu(menu: Menu, inflater: MenuInflater) {
|
override fun onCreateOptionsMenu(menu: Menu, inflater: MenuInflater) {
|
||||||
inflater.inflate(R.menu.collection_item_fragment, menu)
|
inflater.inflate(R.menu.collection_item_fragment, menu)
|
||||||
// FIXME menu.setGroupVisible(R.id.journal_item_menu_event_invite, emailInvitationEvent != null)
|
menu.setGroupVisible(R.id.journal_item_menu_event_invite, emailInvitationEvent != null)
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onOptionsItemSelected(item: MenuItem): Boolean {
|
override fun onOptionsItemSelected(item: MenuItem): Boolean {
|
||||||
|
val accountHolder = model.value!!
|
||||||
when (item.itemId) {
|
when (item.itemId) {
|
||||||
R.id.on_send_event_invite -> {
|
R.id.on_send_event_invite -> {
|
||||||
// FIXME
|
val account = accountHolder.account
|
||||||
|
val intent = EventEmailInvitation(requireContext(), account).createIntent(emailInvitationEvent!!, emailInvitationEventString!!)
|
||||||
|
startActivity(intent)
|
||||||
}
|
}
|
||||||
R.id.on_restore_item -> {
|
R.id.on_restore_item -> {
|
||||||
restoreItem()
|
restoreItem(accountHolder)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return super.onOptionsItemSelected(item)
|
return super.onOptionsItemSelected(item)
|
||||||
}
|
}
|
||||||
|
|
||||||
fun restoreItem() {
|
fun restoreItem(accountHolder: AccountHolder) {
|
||||||
// FIXME: This code makes the assumption that providers are all available. May not be true for tasks, and potentially others too.
|
// FIXME: This code makes the assumption that providers are all available. May not be true for tasks, and potentially others too.
|
||||||
val context = requireContext()
|
val context = requireContext()
|
||||||
val accountHolder = model.value!!
|
|
||||||
val account = accountHolder.account
|
val account = accountHolder.account
|
||||||
val cachedCol = collectionModel.value!!
|
val cachedCol = collectionModel.value!!
|
||||||
when (cachedCol.meta.collectionType) {
|
when (cachedCol.meta.collectionType) {
|
||||||
@ -146,7 +158,7 @@ class CollectionItemFragment(private val cachedItem: CachedItem) : Fragment() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private class TabsAdapter(fm: FragmentManager, private val context: Context, private val cachedCollection: CachedCollection, private val cachedItem: CachedItem) : FragmentPagerAdapter(fm) {
|
private class TabsAdapter(fm: FragmentManager, private val mainFragment: CollectionItemFragment, private val context: Context, private val cachedCollection: CachedCollection, private val cachedItem: CachedItem) : FragmentPagerAdapter(fm) {
|
||||||
|
|
||||||
override fun getCount(): Int {
|
override fun getCount(): Int {
|
||||||
// FIXME: Make it depend on info enumType (only have non-raw for known types)
|
// FIXME: Make it depend on info enumType (only have non-raw for known types)
|
||||||
@ -165,7 +177,7 @@ private class TabsAdapter(fm: FragmentManager, private val context: Context, pri
|
|||||||
|
|
||||||
override fun getItem(position: Int): Fragment {
|
override fun getItem(position: Int): Fragment {
|
||||||
return if (position == 0) {
|
return if (position == 0) {
|
||||||
PrettyFragment(cachedCollection, cachedItem.content)
|
PrettyFragment(mainFragment, cachedCollection, cachedItem.content)
|
||||||
} else if (position == 1) {
|
} else if (position == 1) {
|
||||||
TextFragment(cachedItem.content)
|
TextFragment(cachedItem.content)
|
||||||
} else {
|
} else {
|
||||||
@ -187,7 +199,7 @@ class TextFragment(private val content: String) : Fragment() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class PrettyFragment(private val cachedCollection: CachedCollection, private val content: String) : Fragment() {
|
class PrettyFragment(private val mainFragment: CollectionItemFragment, private val cachedCollection: CachedCollection, private val content: String) : Fragment() {
|
||||||
private var asyncTask: Future<Unit>? = null
|
private var asyncTask: Future<Unit>? = null
|
||||||
|
|
||||||
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
|
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
|
||||||
@ -280,11 +292,10 @@ class PrettyFragment(private val cachedCollection: CachedCollection, private val
|
|||||||
}
|
}
|
||||||
setTextViewText(view, R.id.reminders, sb.toString())
|
setTextViewText(view, R.id.reminders, sb.toString())
|
||||||
|
|
||||||
/* FIXME:
|
if (event.attendees.isNotEmpty()) {
|
||||||
if (event.attendees.isNotEmpty() && activity != null) {
|
mainFragment.allowSendEmail(event, content)
|
||||||
(activity as JournalItemActivity).allowSendEmail(event, syncEntry.content)
|
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user