Merge pull request #6894 from vector-im/feature/bma/remove_fragment_module
Remove fragment module
This commit is contained in:
commit
2b5920e451
1
changelog.d/6894.misc
Normal file
1
changelog.d/6894.misc
Normal file
@ -0,0 +1 @@
|
|||||||
|
Remove FragmentModule and the Fragment factory. No need to Inject the constructor on your Fragment, just add @AndroidEntryPoint annotation and @Inject class members.
|
@ -7,8 +7,8 @@ Hilt is built on top of Dagger 2 and simplify usage by removing needs to create
|
|||||||
When you create a new feature, you should have the following:
|
When you create a new feature, you should have the following:
|
||||||
|
|
||||||
Annotate your Activity with @AndroidEntryPoint
|
Annotate your Activity with @AndroidEntryPoint
|
||||||
|
Annotate your Fragment with @AndroidEntryPoint
|
||||||
If you have a BottomSheetFragment => Annotate it with @AndroidEntryPoint
|
If you have a BottomSheetFragment => Annotate it with @AndroidEntryPoint
|
||||||
Otherwise => Add your Fragment to the FragmentModule
|
|
||||||
Add your ViewModel.Factory to the MavericksViewModelModule
|
Add your ViewModel.Factory to the MavericksViewModelModule
|
||||||
Makes sure your ViewModel as the following code:
|
Makes sure your ViewModel as the following code:
|
||||||
|
|
||||||
|
@ -18,10 +18,10 @@ import javax.inject.Inject
|
|||||||
data class ${fragmentArgsClass}() : Parcelable
|
data class ${fragmentArgsClass}() : Parcelable
|
||||||
</#if>
|
</#if>
|
||||||
|
|
||||||
//TODO add this fragment into FragmentModule
|
@AndroidEntryPoint
|
||||||
class ${fragmentClass} @Inject constructor(
|
class ${fragmentClass}() :
|
||||||
private val viewModelFactory: ${viewModelClass}.Factory
|
VectorBaseFragment(),
|
||||||
) : VectorBaseFragment(), ${viewModelClass}.Factory by viewModelFactory {
|
${viewModelClass}.Factory by viewModelFactory {
|
||||||
|
|
||||||
<#if createFragmentArgs>
|
<#if createFragmentArgs>
|
||||||
private val fragmentArgs: ${fragmentArgsClass} by args()
|
private val fragmentArgs: ${fragmentArgsClass} by args()
|
||||||
|
@ -28,7 +28,8 @@ import im.vector.app.core.platform.VectorBaseFragment
|
|||||||
import im.vector.app.databinding.FragmentDebugMemoryLeaksBinding
|
import im.vector.app.databinding.FragmentDebugMemoryLeaksBinding
|
||||||
|
|
||||||
@AndroidEntryPoint
|
@AndroidEntryPoint
|
||||||
class DebugMemoryLeaksFragment : VectorBaseFragment<FragmentDebugMemoryLeaksBinding>() {
|
class DebugMemoryLeaksFragment :
|
||||||
|
VectorBaseFragment<FragmentDebugMemoryLeaksBinding>() {
|
||||||
|
|
||||||
private val viewModel: DebugMemoryLeaksViewModel by fragmentViewModel()
|
private val viewModel: DebugMemoryLeaksViewModel by fragmentViewModel()
|
||||||
|
|
||||||
|
@ -16,7 +16,6 @@
|
|||||||
|
|
||||||
package im.vector.app.core.di
|
package im.vector.app.core.di
|
||||||
|
|
||||||
import androidx.fragment.app.FragmentFactory
|
|
||||||
import androidx.lifecycle.ViewModelProvider
|
import androidx.lifecycle.ViewModelProvider
|
||||||
import dagger.hilt.EntryPoint
|
import dagger.hilt.EntryPoint
|
||||||
import dagger.hilt.InstallIn
|
import dagger.hilt.InstallIn
|
||||||
@ -25,6 +24,5 @@ import dagger.hilt.android.components.ActivityComponent
|
|||||||
@InstallIn(ActivityComponent::class)
|
@InstallIn(ActivityComponent::class)
|
||||||
@EntryPoint
|
@EntryPoint
|
||||||
interface ActivityEntryPoint {
|
interface ActivityEntryPoint {
|
||||||
fun fragmentFactory(): FragmentFactory
|
|
||||||
fun viewModelFactory(): ViewModelProvider.Factory
|
fun viewModelFactory(): ViewModelProvider.Factory
|
||||||
}
|
}
|
||||||
|
@ -1,27 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright 2019 New Vector Ltd
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
package im.vector.app.core.di
|
|
||||||
|
|
||||||
import androidx.fragment.app.Fragment
|
|
||||||
import dagger.MapKey
|
|
||||||
import kotlin.reflect.KClass
|
|
||||||
|
|
||||||
@Target(AnnotationTarget.FUNCTION, AnnotationTarget.PROPERTY_GETTER, AnnotationTarget.PROPERTY_SETTER)
|
|
||||||
@Retention(AnnotationRetention.RUNTIME)
|
|
||||||
@MapKey
|
|
||||||
annotation class FragmentKey(val value: KClass<out Fragment>)
|
|
@ -1,954 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright 2019 New Vector Ltd
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
package im.vector.app.core.di
|
|
||||||
|
|
||||||
import androidx.fragment.app.Fragment
|
|
||||||
import androidx.fragment.app.FragmentFactory
|
|
||||||
import dagger.Binds
|
|
||||||
import dagger.Module
|
|
||||||
import dagger.hilt.InstallIn
|
|
||||||
import dagger.hilt.android.components.ActivityComponent
|
|
||||||
import dagger.multibindings.IntoMap
|
|
||||||
import im.vector.app.features.analytics.ui.consent.AnalyticsOptInFragment
|
|
||||||
import im.vector.app.features.attachments.preview.AttachmentsPreviewFragment
|
|
||||||
import im.vector.app.features.contactsbook.ContactsBookFragment
|
|
||||||
import im.vector.app.features.crypto.keysbackup.settings.KeysBackupSettingsFragment
|
|
||||||
import im.vector.app.features.crypto.quads.SharedSecuredStorageKeyFragment
|
|
||||||
import im.vector.app.features.crypto.quads.SharedSecuredStoragePassphraseFragment
|
|
||||||
import im.vector.app.features.crypto.quads.SharedSecuredStorageResetAllFragment
|
|
||||||
import im.vector.app.features.crypto.recover.BootstrapConclusionFragment
|
|
||||||
import im.vector.app.features.crypto.recover.BootstrapConfirmPassphraseFragment
|
|
||||||
import im.vector.app.features.crypto.recover.BootstrapEnterPassphraseFragment
|
|
||||||
import im.vector.app.features.crypto.recover.BootstrapMigrateBackupFragment
|
|
||||||
import im.vector.app.features.crypto.recover.BootstrapReAuthFragment
|
|
||||||
import im.vector.app.features.crypto.recover.BootstrapSaveRecoveryKeyFragment
|
|
||||||
import im.vector.app.features.crypto.recover.BootstrapSetupRecoveryKeyFragment
|
|
||||||
import im.vector.app.features.crypto.recover.BootstrapWaitingFragment
|
|
||||||
import im.vector.app.features.crypto.verification.QuadSLoadingFragment
|
|
||||||
import im.vector.app.features.crypto.verification.cancel.VerificationCancelFragment
|
|
||||||
import im.vector.app.features.crypto.verification.cancel.VerificationNotMeFragment
|
|
||||||
import im.vector.app.features.crypto.verification.choose.VerificationChooseMethodFragment
|
|
||||||
import im.vector.app.features.crypto.verification.conclusion.VerificationConclusionFragment
|
|
||||||
import im.vector.app.features.crypto.verification.emoji.VerificationEmojiCodeFragment
|
|
||||||
import im.vector.app.features.crypto.verification.qrconfirmation.VerificationQRWaitingFragment
|
|
||||||
import im.vector.app.features.crypto.verification.qrconfirmation.VerificationQrScannedByOtherFragment
|
|
||||||
import im.vector.app.features.crypto.verification.request.VerificationRequestFragment
|
|
||||||
import im.vector.app.features.devtools.RoomDevToolEditFragment
|
|
||||||
import im.vector.app.features.devtools.RoomDevToolFragment
|
|
||||||
import im.vector.app.features.devtools.RoomDevToolSendFormFragment
|
|
||||||
import im.vector.app.features.devtools.RoomDevToolStateEventListFragment
|
|
||||||
import im.vector.app.features.discovery.DiscoverySettingsFragment
|
|
||||||
import im.vector.app.features.discovery.change.SetIdentityServerFragment
|
|
||||||
import im.vector.app.features.home.HomeDetailFragment
|
|
||||||
import im.vector.app.features.home.HomeDrawerFragment
|
|
||||||
import im.vector.app.features.home.LoadingFragment
|
|
||||||
import im.vector.app.features.home.NewHomeDetailFragment
|
|
||||||
import im.vector.app.features.home.room.breadcrumbs.BreadcrumbsFragment
|
|
||||||
import im.vector.app.features.home.room.detail.TimelineFragment
|
|
||||||
import im.vector.app.features.home.room.detail.search.SearchFragment
|
|
||||||
import im.vector.app.features.home.room.list.RoomListFragment
|
|
||||||
import im.vector.app.features.home.room.list.home.HomeRoomListFragment
|
|
||||||
import im.vector.app.features.home.room.list.home.NewChatBottomSheet
|
|
||||||
import im.vector.app.features.home.room.threads.list.views.ThreadListFragment
|
|
||||||
import im.vector.app.features.location.LocationSharingFragment
|
|
||||||
import im.vector.app.features.location.preview.LocationPreviewFragment
|
|
||||||
import im.vector.app.features.login.LoginCaptchaFragment
|
|
||||||
import im.vector.app.features.login.LoginFragment
|
|
||||||
import im.vector.app.features.login.LoginGenericTextInputFormFragment
|
|
||||||
import im.vector.app.features.login.LoginResetPasswordFragment
|
|
||||||
import im.vector.app.features.login.LoginResetPasswordMailConfirmationFragment
|
|
||||||
import im.vector.app.features.login.LoginResetPasswordSuccessFragment
|
|
||||||
import im.vector.app.features.login.LoginServerSelectionFragment
|
|
||||||
import im.vector.app.features.login.LoginServerUrlFormFragment
|
|
||||||
import im.vector.app.features.login.LoginSignUpSignInSelectionFragment
|
|
||||||
import im.vector.app.features.login.LoginSplashFragment
|
|
||||||
import im.vector.app.features.login.LoginWaitForEmailFragment
|
|
||||||
import im.vector.app.features.login.LoginWebFragment
|
|
||||||
import im.vector.app.features.login.terms.LoginTermsFragment
|
|
||||||
import im.vector.app.features.matrixto.MatrixToRoomSpaceFragment
|
|
||||||
import im.vector.app.features.matrixto.MatrixToUserFragment
|
|
||||||
import im.vector.app.features.onboarding.ftueauth.FtueAuthAccountCreatedFragment
|
|
||||||
import im.vector.app.features.onboarding.ftueauth.FtueAuthCaptchaFragment
|
|
||||||
import im.vector.app.features.onboarding.ftueauth.FtueAuthChooseDisplayNameFragment
|
|
||||||
import im.vector.app.features.onboarding.ftueauth.FtueAuthChooseProfilePictureFragment
|
|
||||||
import im.vector.app.features.onboarding.ftueauth.FtueAuthCombinedLoginFragment
|
|
||||||
import im.vector.app.features.onboarding.ftueauth.FtueAuthCombinedRegisterFragment
|
|
||||||
import im.vector.app.features.onboarding.ftueauth.FtueAuthCombinedServerSelectionFragment
|
|
||||||
import im.vector.app.features.onboarding.ftueauth.FtueAuthEmailEntryFragment
|
|
||||||
import im.vector.app.features.onboarding.ftueauth.FtueAuthGenericTextInputFormFragment
|
|
||||||
import im.vector.app.features.onboarding.ftueauth.FtueAuthLegacyStyleCaptchaFragment
|
|
||||||
import im.vector.app.features.onboarding.ftueauth.FtueAuthLegacyWaitForEmailFragment
|
|
||||||
import im.vector.app.features.onboarding.ftueauth.FtueAuthLoginFragment
|
|
||||||
import im.vector.app.features.onboarding.ftueauth.FtueAuthPersonalizationCompleteFragment
|
|
||||||
import im.vector.app.features.onboarding.ftueauth.FtueAuthPhoneConfirmationFragment
|
|
||||||
import im.vector.app.features.onboarding.ftueauth.FtueAuthPhoneEntryFragment
|
|
||||||
import im.vector.app.features.onboarding.ftueauth.FtueAuthResetPasswordFragment
|
|
||||||
import im.vector.app.features.onboarding.ftueauth.FtueAuthResetPasswordMailConfirmationFragment
|
|
||||||
import im.vector.app.features.onboarding.ftueauth.FtueAuthResetPasswordSuccessFragment
|
|
||||||
import im.vector.app.features.onboarding.ftueauth.FtueAuthServerSelectionFragment
|
|
||||||
import im.vector.app.features.onboarding.ftueauth.FtueAuthSignUpSignInSelectionFragment
|
|
||||||
import im.vector.app.features.onboarding.ftueauth.FtueAuthSplashCarouselFragment
|
|
||||||
import im.vector.app.features.onboarding.ftueauth.FtueAuthSplashFragment
|
|
||||||
import im.vector.app.features.onboarding.ftueauth.FtueAuthUseCaseFragment
|
|
||||||
import im.vector.app.features.onboarding.ftueauth.FtueAuthWaitForEmailFragment
|
|
||||||
import im.vector.app.features.onboarding.ftueauth.FtueAuthWebFragment
|
|
||||||
import im.vector.app.features.onboarding.ftueauth.terms.FtueAuthLegacyStyleTermsFragment
|
|
||||||
import im.vector.app.features.onboarding.ftueauth.terms.FtueAuthTermsFragment
|
|
||||||
import im.vector.app.features.pin.PinFragment
|
|
||||||
import im.vector.app.features.poll.create.CreatePollFragment
|
|
||||||
import im.vector.app.features.qrcode.QrCodeScannerFragment
|
|
||||||
import im.vector.app.features.reactions.EmojiChooserFragment
|
|
||||||
import im.vector.app.features.reactions.EmojiSearchResultFragment
|
|
||||||
import im.vector.app.features.roomdirectory.PublicRoomsFragment
|
|
||||||
import im.vector.app.features.roomdirectory.createroom.CreateRoomFragment
|
|
||||||
import im.vector.app.features.roomdirectory.picker.RoomDirectoryPickerFragment
|
|
||||||
import im.vector.app.features.roomdirectory.roompreview.RoomPreviewNoPreviewFragment
|
|
||||||
import im.vector.app.features.roommemberprofile.RoomMemberProfileFragment
|
|
||||||
import im.vector.app.features.roommemberprofile.devices.DeviceListFragment
|
|
||||||
import im.vector.app.features.roommemberprofile.devices.DeviceTrustInfoActionFragment
|
|
||||||
import im.vector.app.features.roomprofile.RoomProfileFragment
|
|
||||||
import im.vector.app.features.roomprofile.alias.RoomAliasFragment
|
|
||||||
import im.vector.app.features.roomprofile.banned.RoomBannedMemberListFragment
|
|
||||||
import im.vector.app.features.roomprofile.members.RoomMemberListFragment
|
|
||||||
import im.vector.app.features.roomprofile.notifications.RoomNotificationSettingsFragment
|
|
||||||
import im.vector.app.features.roomprofile.permissions.RoomPermissionsFragment
|
|
||||||
import im.vector.app.features.roomprofile.settings.RoomSettingsFragment
|
|
||||||
import im.vector.app.features.roomprofile.settings.joinrule.RoomJoinRuleFragment
|
|
||||||
import im.vector.app.features.roomprofile.settings.joinrule.advanced.RoomJoinRuleChooseRestrictedFragment
|
|
||||||
import im.vector.app.features.roomprofile.uploads.RoomUploadsFragment
|
|
||||||
import im.vector.app.features.roomprofile.uploads.files.RoomUploadsFilesFragment
|
|
||||||
import im.vector.app.features.roomprofile.uploads.media.RoomUploadsMediaFragment
|
|
||||||
import im.vector.app.features.settings.VectorSettingsGeneralFragment
|
|
||||||
import im.vector.app.features.settings.VectorSettingsHelpAboutFragment
|
|
||||||
import im.vector.app.features.settings.VectorSettingsLabsFragment
|
|
||||||
import im.vector.app.features.settings.VectorSettingsPinFragment
|
|
||||||
import im.vector.app.features.settings.VectorSettingsPreferencesFragment
|
|
||||||
import im.vector.app.features.settings.VectorSettingsSecurityPrivacyFragment
|
|
||||||
import im.vector.app.features.settings.account.deactivation.DeactivateAccountFragment
|
|
||||||
import im.vector.app.features.settings.crosssigning.CrossSigningSettingsFragment
|
|
||||||
import im.vector.app.features.settings.devices.VectorSettingsDevicesFragment
|
|
||||||
import im.vector.app.features.settings.devtools.AccountDataFragment
|
|
||||||
import im.vector.app.features.settings.devtools.GossipingEventsPaperTrailFragment
|
|
||||||
import im.vector.app.features.settings.devtools.IncomingKeyRequestListFragment
|
|
||||||
import im.vector.app.features.settings.devtools.KeyRequestsFragment
|
|
||||||
import im.vector.app.features.settings.devtools.OutgoingKeyRequestListFragment
|
|
||||||
import im.vector.app.features.settings.font.FontScaleSettingFragment
|
|
||||||
import im.vector.app.features.settings.homeserver.HomeserverSettingsFragment
|
|
||||||
import im.vector.app.features.settings.ignored.VectorSettingsIgnoredUsersFragment
|
|
||||||
import im.vector.app.features.settings.legals.LegalsFragment
|
|
||||||
import im.vector.app.features.settings.locale.LocalePickerFragment
|
|
||||||
import im.vector.app.features.settings.notifications.VectorSettingsAdvancedNotificationPreferenceFragment
|
|
||||||
import im.vector.app.features.settings.notifications.VectorSettingsNotificationPreferenceFragment
|
|
||||||
import im.vector.app.features.settings.notifications.VectorSettingsNotificationsTroubleshootFragment
|
|
||||||
import im.vector.app.features.settings.push.PushGatewaysFragment
|
|
||||||
import im.vector.app.features.settings.push.PushRulesFragment
|
|
||||||
import im.vector.app.features.settings.threepids.ThreePidsSettingsFragment
|
|
||||||
import im.vector.app.features.share.IncomingShareFragment
|
|
||||||
import im.vector.app.features.signout.soft.SoftLogoutFragment
|
|
||||||
import im.vector.app.features.spaces.SpaceListFragment
|
|
||||||
import im.vector.app.features.spaces.create.ChoosePrivateSpaceTypeFragment
|
|
||||||
import im.vector.app.features.spaces.create.ChooseSpaceTypeFragment
|
|
||||||
import im.vector.app.features.spaces.create.CreateSpaceAdd3pidInvitesFragment
|
|
||||||
import im.vector.app.features.spaces.create.CreateSpaceDefaultRoomsFragment
|
|
||||||
import im.vector.app.features.spaces.create.CreateSpaceDetailsFragment
|
|
||||||
import im.vector.app.features.spaces.explore.SpaceDirectoryFragment
|
|
||||||
import im.vector.app.features.spaces.leave.SpaceLeaveAdvancedFragment
|
|
||||||
import im.vector.app.features.spaces.manage.SpaceAddRoomFragment
|
|
||||||
import im.vector.app.features.spaces.manage.SpaceManageRoomsFragment
|
|
||||||
import im.vector.app.features.spaces.manage.SpaceSettingsFragment
|
|
||||||
import im.vector.app.features.spaces.people.SpacePeopleFragment
|
|
||||||
import im.vector.app.features.spaces.preview.SpacePreviewFragment
|
|
||||||
import im.vector.app.features.terms.ReviewTermsFragment
|
|
||||||
import im.vector.app.features.usercode.ShowUserCodeFragment
|
|
||||||
import im.vector.app.features.userdirectory.UserListFragment
|
|
||||||
import im.vector.app.features.widgets.WidgetFragment
|
|
||||||
|
|
||||||
@InstallIn(ActivityComponent::class)
|
|
||||||
@Module
|
|
||||||
interface FragmentModule {
|
|
||||||
/**
|
|
||||||
* Fragments with @IntoMap will be injected by this factory.
|
|
||||||
*/
|
|
||||||
@Binds
|
|
||||||
fun bindFragmentFactory(factory: VectorFragmentFactory): FragmentFactory
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(RoomListFragment::class)
|
|
||||||
fun bindRoomListFragment(fragment: RoomListFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(NewChatBottomSheet::class)
|
|
||||||
fun bindNewChatBottomSheetFragment(fragment: NewChatBottomSheet): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(LocalePickerFragment::class)
|
|
||||||
fun bindLocalePickerFragment(fragment: LocalePickerFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(SpaceListFragment::class)
|
|
||||||
fun bindSpaceListFragment(fragment: SpaceListFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(TimelineFragment::class)
|
|
||||||
fun bindTimelineFragment(fragment: TimelineFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(RoomDirectoryPickerFragment::class)
|
|
||||||
fun bindRoomDirectoryPickerFragment(fragment: RoomDirectoryPickerFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(CreateRoomFragment::class)
|
|
||||||
fun bindCreateRoomFragment(fragment: CreateRoomFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(RoomPreviewNoPreviewFragment::class)
|
|
||||||
fun bindRoomPreviewNoPreviewFragment(fragment: RoomPreviewNoPreviewFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(KeysBackupSettingsFragment::class)
|
|
||||||
fun bindKeysBackupSettingsFragment(fragment: KeysBackupSettingsFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(LoadingFragment::class)
|
|
||||||
fun bindLoadingFragment(fragment: LoadingFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(HomeDrawerFragment::class)
|
|
||||||
fun bindHomeDrawerFragment(fragment: HomeDrawerFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(HomeDetailFragment::class)
|
|
||||||
fun bindHomeDetailFragment(fragment: HomeDetailFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(NewHomeDetailFragment::class)
|
|
||||||
fun bindNewHomeDetailFragment(fragment: NewHomeDetailFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(EmojiSearchResultFragment::class)
|
|
||||||
fun bindEmojiSearchResultFragment(fragment: EmojiSearchResultFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(LoginFragment::class)
|
|
||||||
fun bindLoginFragment(fragment: LoginFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(LoginCaptchaFragment::class)
|
|
||||||
fun bindLoginCaptchaFragment(fragment: LoginCaptchaFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(LoginTermsFragment::class)
|
|
||||||
fun bindLoginTermsFragment(fragment: LoginTermsFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(LoginServerUrlFormFragment::class)
|
|
||||||
fun bindLoginServerUrlFormFragment(fragment: LoginServerUrlFormFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(LoginResetPasswordMailConfirmationFragment::class)
|
|
||||||
fun bindLoginResetPasswordMailConfirmationFragment(fragment: LoginResetPasswordMailConfirmationFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(LoginResetPasswordFragment::class)
|
|
||||||
fun bindLoginResetPasswordFragment(fragment: LoginResetPasswordFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(LoginResetPasswordSuccessFragment::class)
|
|
||||||
fun bindLoginResetPasswordSuccessFragment(fragment: LoginResetPasswordSuccessFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(LoginServerSelectionFragment::class)
|
|
||||||
fun bindLoginServerSelectionFragment(fragment: LoginServerSelectionFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(LoginSignUpSignInSelectionFragment::class)
|
|
||||||
fun bindLoginSignUpSignInSelectionFragment(fragment: LoginSignUpSignInSelectionFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(LoginSplashFragment::class)
|
|
||||||
fun bindLoginSplashFragment(fragment: LoginSplashFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(LoginWebFragment::class)
|
|
||||||
fun bindLoginWebFragment(fragment: LoginWebFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(LoginGenericTextInputFormFragment::class)
|
|
||||||
fun bindLoginGenericTextInputFormFragment(fragment: LoginGenericTextInputFormFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(LoginWaitForEmailFragment::class)
|
|
||||||
fun bindLoginWaitForEmailFragment(fragment: LoginWaitForEmailFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FtueAuthLegacyStyleCaptchaFragment::class)
|
|
||||||
fun bindFtueAuthLegacyStyleCaptchaFragment(fragment: FtueAuthLegacyStyleCaptchaFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FtueAuthCaptchaFragment::class)
|
|
||||||
fun bindFtueAuthCaptchaFragment(fragment: FtueAuthCaptchaFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FtueAuthGenericTextInputFormFragment::class)
|
|
||||||
fun bindFtueAuthGenericTextInputFormFragment(fragment: FtueAuthGenericTextInputFormFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FtueAuthLoginFragment::class)
|
|
||||||
fun bindFtueAuthLoginFragment(fragment: FtueAuthLoginFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FtueAuthResetPasswordFragment::class)
|
|
||||||
fun bindFtueAuthResetPasswordFragment(fragment: FtueAuthResetPasswordFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FtueAuthResetPasswordMailConfirmationFragment::class)
|
|
||||||
fun bindFtueAuthResetPasswordMailConfirmationFragment(fragment: FtueAuthResetPasswordMailConfirmationFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FtueAuthResetPasswordSuccessFragment::class)
|
|
||||||
fun bindFtueAuthResetPasswordSuccessFragment(fragment: FtueAuthResetPasswordSuccessFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FtueAuthServerSelectionFragment::class)
|
|
||||||
fun bindFtueAuthServerSelectionFragment(fragment: FtueAuthServerSelectionFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FtueAuthSignUpSignInSelectionFragment::class)
|
|
||||||
fun bindFtueAuthSignUpSignInSelectionFragment(fragment: FtueAuthSignUpSignInSelectionFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FtueAuthSplashFragment::class)
|
|
||||||
fun bindFtueAuthSplashFragment(fragment: FtueAuthSplashFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FtueAuthSplashCarouselFragment::class)
|
|
||||||
fun bindFtueAuthSplashCarouselFragment(fragment: FtueAuthSplashCarouselFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FtueAuthUseCaseFragment::class)
|
|
||||||
fun bindFtueAuthUseCaseFragment(fragment: FtueAuthUseCaseFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FtueAuthWaitForEmailFragment::class)
|
|
||||||
fun bindFtueAuthWaitForEmailFragment(fragment: FtueAuthWaitForEmailFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FtueAuthLegacyWaitForEmailFragment::class)
|
|
||||||
fun bindFtueAuthLegacyWaitForEmailFragment(fragment: FtueAuthLegacyWaitForEmailFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FtueAuthWebFragment::class)
|
|
||||||
fun bindFtueAuthWebFragment(fragment: FtueAuthWebFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FtueAuthLegacyStyleTermsFragment::class)
|
|
||||||
fun bindFtueAuthLegacyStyleTermsFragment(fragment: FtueAuthLegacyStyleTermsFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FtueAuthTermsFragment::class)
|
|
||||||
fun bindFtueAuthTermsFragment(fragment: FtueAuthTermsFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FtueAuthAccountCreatedFragment::class)
|
|
||||||
fun bindFtueAuthAccountCreatedFragment(fragment: FtueAuthAccountCreatedFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FtueAuthEmailEntryFragment::class)
|
|
||||||
fun bindFtueAuthEmailEntryFragment(fragment: FtueAuthEmailEntryFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FtueAuthPhoneEntryFragment::class)
|
|
||||||
fun bindFtueAuthPhoneEntryFragment(fragment: FtueAuthPhoneEntryFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FtueAuthPhoneConfirmationFragment::class)
|
|
||||||
fun bindFtueAuthPhoneConfirmationFragment(fragment: FtueAuthPhoneConfirmationFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FtueAuthChooseDisplayNameFragment::class)
|
|
||||||
fun bindFtueAuthChooseDisplayNameFragment(fragment: FtueAuthChooseDisplayNameFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FtueAuthChooseProfilePictureFragment::class)
|
|
||||||
fun bindFtueAuthChooseProfilePictureFragment(fragment: FtueAuthChooseProfilePictureFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FtueAuthPersonalizationCompleteFragment::class)
|
|
||||||
fun bindFtueAuthPersonalizationCompleteFragment(fragment: FtueAuthPersonalizationCompleteFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FtueAuthCombinedLoginFragment::class)
|
|
||||||
fun bindFtueAuthCombinedLoginFragment(fragment: FtueAuthCombinedLoginFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FtueAuthCombinedRegisterFragment::class)
|
|
||||||
fun bindFtueAuthCombinedRegisterFragment(fragment: FtueAuthCombinedRegisterFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FtueAuthCombinedServerSelectionFragment::class)
|
|
||||||
fun bindFtueAuthCombinedServerSelectionFragment(fragment: FtueAuthCombinedServerSelectionFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(UserListFragment::class)
|
|
||||||
fun bindUserListFragment(fragment: UserListFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(PushGatewaysFragment::class)
|
|
||||||
fun bindPushGatewaysFragment(fragment: PushGatewaysFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(VectorSettingsNotificationsTroubleshootFragment::class)
|
|
||||||
fun bindVectorSettingsNotificationsTroubleshootFragment(fragment: VectorSettingsNotificationsTroubleshootFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(VectorSettingsAdvancedNotificationPreferenceFragment::class)
|
|
||||||
fun bindVectorSettingsAdvancedNotificationPreferenceFragment(fragment: VectorSettingsAdvancedNotificationPreferenceFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(VectorSettingsNotificationPreferenceFragment::class)
|
|
||||||
fun bindVectorSettingsNotificationPreferenceFragment(fragment: VectorSettingsNotificationPreferenceFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(VectorSettingsLabsFragment::class)
|
|
||||||
fun bindVectorSettingsLabsFragment(fragment: VectorSettingsLabsFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(HomeserverSettingsFragment::class)
|
|
||||||
fun bindHomeserverSettingsFragment(fragment: HomeserverSettingsFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(FontScaleSettingFragment::class)
|
|
||||||
fun bindFontScaleSettingFragment(fragment: FontScaleSettingFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(VectorSettingsPinFragment::class)
|
|
||||||
fun bindVectorSettingsPinFragment(fragment: VectorSettingsPinFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(VectorSettingsGeneralFragment::class)
|
|
||||||
fun bindVectorSettingsGeneralFragment(fragment: VectorSettingsGeneralFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(PushRulesFragment::class)
|
|
||||||
fun bindPushRulesFragment(fragment: PushRulesFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(VectorSettingsPreferencesFragment::class)
|
|
||||||
fun bindVectorSettingsPreferencesFragment(fragment: VectorSettingsPreferencesFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(VectorSettingsSecurityPrivacyFragment::class)
|
|
||||||
fun bindVectorSettingsSecurityPrivacyFragment(fragment: VectorSettingsSecurityPrivacyFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(VectorSettingsHelpAboutFragment::class)
|
|
||||||
fun bindVectorSettingsHelpAboutFragment(fragment: VectorSettingsHelpAboutFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(VectorSettingsIgnoredUsersFragment::class)
|
|
||||||
fun bindVectorSettingsIgnoredUsersFragment(fragment: VectorSettingsIgnoredUsersFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(VectorSettingsDevicesFragment::class)
|
|
||||||
fun bindVectorSettingsDevicesFragment(fragment: VectorSettingsDevicesFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(ThreePidsSettingsFragment::class)
|
|
||||||
fun bindThreePidsSettingsFragment(fragment: ThreePidsSettingsFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(PublicRoomsFragment::class)
|
|
||||||
fun bindPublicRoomsFragment(fragment: PublicRoomsFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(RoomProfileFragment::class)
|
|
||||||
fun bindRoomProfileFragment(fragment: RoomProfileFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(RoomMemberListFragment::class)
|
|
||||||
fun bindRoomMemberListFragment(fragment: RoomMemberListFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(RoomUploadsFragment::class)
|
|
||||||
fun bindRoomUploadsFragment(fragment: RoomUploadsFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(RoomUploadsMediaFragment::class)
|
|
||||||
fun bindRoomUploadsMediaFragment(fragment: RoomUploadsMediaFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(RoomUploadsFilesFragment::class)
|
|
||||||
fun bindRoomUploadsFilesFragment(fragment: RoomUploadsFilesFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(RoomSettingsFragment::class)
|
|
||||||
fun bindRoomSettingsFragment(fragment: RoomSettingsFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(RoomAliasFragment::class)
|
|
||||||
fun bindRoomAliasFragment(fragment: RoomAliasFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(RoomPermissionsFragment::class)
|
|
||||||
fun bindRoomPermissionsFragment(fragment: RoomPermissionsFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(RoomMemberProfileFragment::class)
|
|
||||||
fun bindRoomMemberProfileFragment(fragment: RoomMemberProfileFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(BreadcrumbsFragment::class)
|
|
||||||
fun bindBreadcrumbsFragment(fragment: BreadcrumbsFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(AnalyticsOptInFragment::class)
|
|
||||||
fun bindAnalyticsOptInFragment(fragment: AnalyticsOptInFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(EmojiChooserFragment::class)
|
|
||||||
fun bindEmojiChooserFragment(fragment: EmojiChooserFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(SoftLogoutFragment::class)
|
|
||||||
fun bindSoftLogoutFragment(fragment: SoftLogoutFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(VerificationRequestFragment::class)
|
|
||||||
fun bindVerificationRequestFragment(fragment: VerificationRequestFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(VerificationChooseMethodFragment::class)
|
|
||||||
fun bindVerificationChooseMethodFragment(fragment: VerificationChooseMethodFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(VerificationEmojiCodeFragment::class)
|
|
||||||
fun bindVerificationEmojiCodeFragment(fragment: VerificationEmojiCodeFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(VerificationQrScannedByOtherFragment::class)
|
|
||||||
fun bindVerificationQrScannedByOtherFragment(fragment: VerificationQrScannedByOtherFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(VerificationQRWaitingFragment::class)
|
|
||||||
fun bindVerificationQRWaitingFragment(fragment: VerificationQRWaitingFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(VerificationConclusionFragment::class)
|
|
||||||
fun bindVerificationConclusionFragment(fragment: VerificationConclusionFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(VerificationCancelFragment::class)
|
|
||||||
fun bindVerificationCancelFragment(fragment: VerificationCancelFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(QuadSLoadingFragment::class)
|
|
||||||
fun bindQuadSLoadingFragment(fragment: QuadSLoadingFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(VerificationNotMeFragment::class)
|
|
||||||
fun bindVerificationNotMeFragment(fragment: VerificationNotMeFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(QrCodeScannerFragment::class)
|
|
||||||
fun bindQrCodeScannerFragment(fragment: QrCodeScannerFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(DeviceListFragment::class)
|
|
||||||
fun bindDeviceListFragment(fragment: DeviceListFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(DeviceTrustInfoActionFragment::class)
|
|
||||||
fun bindDeviceTrustInfoActionFragment(fragment: DeviceTrustInfoActionFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(CrossSigningSettingsFragment::class)
|
|
||||||
fun bindCrossSigningSettingsFragment(fragment: CrossSigningSettingsFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(AttachmentsPreviewFragment::class)
|
|
||||||
fun bindAttachmentsPreviewFragment(fragment: AttachmentsPreviewFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(IncomingShareFragment::class)
|
|
||||||
fun bindIncomingShareFragment(fragment: IncomingShareFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(AccountDataFragment::class)
|
|
||||||
fun bindAccountDataFragment(fragment: AccountDataFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(OutgoingKeyRequestListFragment::class)
|
|
||||||
fun bindOutgoingKeyRequestListFragment(fragment: OutgoingKeyRequestListFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(IncomingKeyRequestListFragment::class)
|
|
||||||
fun bindIncomingKeyRequestListFragment(fragment: IncomingKeyRequestListFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(KeyRequestsFragment::class)
|
|
||||||
fun bindKeyRequestsFragment(fragment: KeyRequestsFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(GossipingEventsPaperTrailFragment::class)
|
|
||||||
fun bindGossipingEventsPaperTrailFragment(fragment: GossipingEventsPaperTrailFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(BootstrapEnterPassphraseFragment::class)
|
|
||||||
fun bindBootstrapEnterPassphraseFragment(fragment: BootstrapEnterPassphraseFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(BootstrapConfirmPassphraseFragment::class)
|
|
||||||
fun bindBootstrapConfirmPassphraseFragment(fragment: BootstrapConfirmPassphraseFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(BootstrapWaitingFragment::class)
|
|
||||||
fun bindBootstrapWaitingFragment(fragment: BootstrapWaitingFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(BootstrapSetupRecoveryKeyFragment::class)
|
|
||||||
fun bindBootstrapSetupRecoveryKeyFragment(fragment: BootstrapSetupRecoveryKeyFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(BootstrapSaveRecoveryKeyFragment::class)
|
|
||||||
fun bindBootstrapSaveRecoveryKeyFragment(fragment: BootstrapSaveRecoveryKeyFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(BootstrapConclusionFragment::class)
|
|
||||||
fun bindBootstrapConclusionFragment(fragment: BootstrapConclusionFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(BootstrapReAuthFragment::class)
|
|
||||||
fun bindBootstrapReAuthFragment(fragment: BootstrapReAuthFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(BootstrapMigrateBackupFragment::class)
|
|
||||||
fun bindBootstrapMigrateBackupFragment(fragment: BootstrapMigrateBackupFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(DeactivateAccountFragment::class)
|
|
||||||
fun bindDeactivateAccountFragment(fragment: DeactivateAccountFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(SharedSecuredStoragePassphraseFragment::class)
|
|
||||||
fun bindSharedSecuredStoragePassphraseFragment(fragment: SharedSecuredStoragePassphraseFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(SharedSecuredStorageKeyFragment::class)
|
|
||||||
fun bindSharedSecuredStorageKeyFragment(fragment: SharedSecuredStorageKeyFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(SharedSecuredStorageResetAllFragment::class)
|
|
||||||
fun bindSharedSecuredStorageResetAllFragment(fragment: SharedSecuredStorageResetAllFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(SetIdentityServerFragment::class)
|
|
||||||
fun bindSetIdentityServerFragment(fragment: SetIdentityServerFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(DiscoverySettingsFragment::class)
|
|
||||||
fun bindDiscoverySettingsFragment(fragment: DiscoverySettingsFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(LegalsFragment::class)
|
|
||||||
fun bindLegalsFragment(fragment: LegalsFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(ReviewTermsFragment::class)
|
|
||||||
fun bindReviewTermsFragment(fragment: ReviewTermsFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(WidgetFragment::class)
|
|
||||||
fun bindWidgetFragment(fragment: WidgetFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(ContactsBookFragment::class)
|
|
||||||
fun bindPhoneBookFragment(fragment: ContactsBookFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(PinFragment::class)
|
|
||||||
fun bindPinFragment(fragment: PinFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(RoomBannedMemberListFragment::class)
|
|
||||||
fun bindRoomBannedMemberListFragment(fragment: RoomBannedMemberListFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(RoomNotificationSettingsFragment::class)
|
|
||||||
fun bindRoomNotificationSettingsFragment(fragment: RoomNotificationSettingsFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(SearchFragment::class)
|
|
||||||
fun bindSearchFragment(fragment: SearchFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(ShowUserCodeFragment::class)
|
|
||||||
fun bindShowUserCodeFragment(fragment: ShowUserCodeFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(RoomDevToolFragment::class)
|
|
||||||
fun bindRoomDevToolFragment(fragment: RoomDevToolFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(RoomDevToolStateEventListFragment::class)
|
|
||||||
fun bindRoomDevToolStateEventListFragment(fragment: RoomDevToolStateEventListFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(RoomDevToolEditFragment::class)
|
|
||||||
fun bindRoomDevToolEditFragment(fragment: RoomDevToolEditFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(RoomDevToolSendFormFragment::class)
|
|
||||||
fun bindRoomDevToolSendFormFragment(fragment: RoomDevToolSendFormFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(SpacePreviewFragment::class)
|
|
||||||
fun bindSpacePreviewFragment(fragment: SpacePreviewFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(ChooseSpaceTypeFragment::class)
|
|
||||||
fun bindChooseSpaceTypeFragment(fragment: ChooseSpaceTypeFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(CreateSpaceDetailsFragment::class)
|
|
||||||
fun bindCreateSpaceDetailsFragment(fragment: CreateSpaceDetailsFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(CreateSpaceDefaultRoomsFragment::class)
|
|
||||||
fun bindCreateSpaceDefaultRoomsFragment(fragment: CreateSpaceDefaultRoomsFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(MatrixToUserFragment::class)
|
|
||||||
fun bindMatrixToUserFragment(fragment: MatrixToUserFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(MatrixToRoomSpaceFragment::class)
|
|
||||||
fun bindMatrixToRoomSpaceFragment(fragment: MatrixToRoomSpaceFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(SpaceDirectoryFragment::class)
|
|
||||||
fun bindSpaceDirectoryFragment(fragment: SpaceDirectoryFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(ChoosePrivateSpaceTypeFragment::class)
|
|
||||||
fun bindChoosePrivateSpaceTypeFragment(fragment: ChoosePrivateSpaceTypeFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(CreateSpaceAdd3pidInvitesFragment::class)
|
|
||||||
fun bindCreateSpaceAdd3pidInvitesFragment(fragment: CreateSpaceAdd3pidInvitesFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(SpaceAddRoomFragment::class)
|
|
||||||
fun bindSpaceAddRoomFragment(fragment: SpaceAddRoomFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(SpacePeopleFragment::class)
|
|
||||||
fun bindSpacePeopleFragment(fragment: SpacePeopleFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(SpaceSettingsFragment::class)
|
|
||||||
fun bindSpaceSettingsFragment(fragment: SpaceSettingsFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(SpaceManageRoomsFragment::class)
|
|
||||||
fun bindSpaceManageRoomsFragment(fragment: SpaceManageRoomsFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(RoomJoinRuleFragment::class)
|
|
||||||
fun bindRoomJoinRuleFragment(fragment: RoomJoinRuleFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(RoomJoinRuleChooseRestrictedFragment::class)
|
|
||||||
fun bindRoomJoinRuleChooseRestrictedFragment(fragment: RoomJoinRuleChooseRestrictedFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(SpaceLeaveAdvancedFragment::class)
|
|
||||||
fun bindSpaceLeaveAdvancedFragment(fragment: SpaceLeaveAdvancedFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(ThreadListFragment::class)
|
|
||||||
fun bindThreadListFragment(fragment: ThreadListFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(CreatePollFragment::class)
|
|
||||||
fun bindCreatePollFragment(fragment: CreatePollFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(LocationSharingFragment::class)
|
|
||||||
fun bindLocationSharingFragment(fragment: LocationSharingFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(LocationPreviewFragment::class)
|
|
||||||
fun bindLocationPreviewFragment(fragment: LocationPreviewFragment): Fragment
|
|
||||||
|
|
||||||
@Binds
|
|
||||||
@IntoMap
|
|
||||||
@FragmentKey(HomeRoomListFragment::class)
|
|
||||||
fun binHomeRoomListFragment(fragment: HomeRoomListFragment): Fragment
|
|
||||||
}
|
|
@ -1,43 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright 2019 New Vector Ltd
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
package im.vector.app.core.di
|
|
||||||
|
|
||||||
import androidx.fragment.app.Fragment
|
|
||||||
import androidx.fragment.app.FragmentFactory
|
|
||||||
import timber.log.Timber
|
|
||||||
import javax.inject.Inject
|
|
||||||
import javax.inject.Provider
|
|
||||||
|
|
||||||
/**
|
|
||||||
* FragmentFactory which uses Dagger to create the instances.
|
|
||||||
*/
|
|
||||||
class VectorFragmentFactory @Inject constructor(
|
|
||||||
private val creators: @JvmSuppressWildcards Map<Class<out Fragment>, Provider<Fragment>>
|
|
||||||
) : FragmentFactory() {
|
|
||||||
|
|
||||||
override fun instantiate(classLoader: ClassLoader, className: String): Fragment {
|
|
||||||
val fragmentClass = loadFragmentClass(classLoader, className)
|
|
||||||
val creator: Provider<out Fragment>? = creators[fragmentClass]
|
|
||||||
return if (creator == null) {
|
|
||||||
Timber.v("Unknown model class: $className, fallback to default instance")
|
|
||||||
super.instantiate(classLoader, className)
|
|
||||||
} else {
|
|
||||||
creator.get()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -0,0 +1,34 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2022 New Vector Ltd
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package im.vector.app.core.dialogs
|
||||||
|
|
||||||
|
import androidx.fragment.app.Fragment
|
||||||
|
import im.vector.app.core.resources.ColorProvider
|
||||||
|
import im.vector.app.core.time.Clock
|
||||||
|
import javax.inject.Inject
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Factory for [GalleryOrCameraDialogHelper].
|
||||||
|
*/
|
||||||
|
class GalleryOrCameraDialogHelperFactory @Inject constructor(
|
||||||
|
private val colorProvider: ColorProvider,
|
||||||
|
private val clock: Clock,
|
||||||
|
) {
|
||||||
|
fun create(fragment: Fragment): GalleryOrCameraDialogHelper {
|
||||||
|
return GalleryOrCameraDialogHelper(fragment, colorProvider, clock)
|
||||||
|
}
|
||||||
|
}
|
@ -21,7 +21,6 @@ import android.app.Activity
|
|||||||
import android.content.Context
|
import android.content.Context
|
||||||
import android.os.Build
|
import android.os.Build
|
||||||
import android.os.Bundle
|
import android.os.Bundle
|
||||||
import android.os.Parcelable
|
|
||||||
import android.view.Menu
|
import android.view.Menu
|
||||||
import android.view.MenuInflater
|
import android.view.MenuInflater
|
||||||
import android.view.MenuItem
|
import android.view.MenuItem
|
||||||
@ -39,8 +38,6 @@ import androidx.core.content.ContextCompat
|
|||||||
import androidx.core.util.Consumer
|
import androidx.core.util.Consumer
|
||||||
import androidx.core.view.MenuProvider
|
import androidx.core.view.MenuProvider
|
||||||
import androidx.core.view.isVisible
|
import androidx.core.view.isVisible
|
||||||
import androidx.fragment.app.Fragment
|
|
||||||
import androidx.fragment.app.FragmentFactory
|
|
||||||
import androidx.fragment.app.FragmentManager
|
import androidx.fragment.app.FragmentManager
|
||||||
import androidx.lifecycle.Lifecycle
|
import androidx.lifecycle.Lifecycle
|
||||||
import androidx.lifecycle.ViewModelProvider
|
import androidx.lifecycle.ViewModelProvider
|
||||||
@ -67,7 +64,6 @@ import im.vector.app.core.extensions.registerStartForActivityResult
|
|||||||
import im.vector.app.core.extensions.restart
|
import im.vector.app.core.extensions.restart
|
||||||
import im.vector.app.core.extensions.setTextOrHide
|
import im.vector.app.core.extensions.setTextOrHide
|
||||||
import im.vector.app.core.extensions.singletonEntryPoint
|
import im.vector.app.core.extensions.singletonEntryPoint
|
||||||
import im.vector.app.core.extensions.toMvRxBundle
|
|
||||||
import im.vector.app.core.resources.BuildMeta
|
import im.vector.app.core.resources.BuildMeta
|
||||||
import im.vector.app.core.utils.AndroidSystemSettingsProvider
|
import im.vector.app.core.utils.AndroidSystemSettingsProvider
|
||||||
import im.vector.app.core.utils.ToolbarConfig
|
import im.vector.app.core.utils.ToolbarConfig
|
||||||
@ -169,7 +165,6 @@ abstract class VectorBaseActivity<VB : ViewBinding> : AppCompatActivity(), Maver
|
|||||||
|
|
||||||
lateinit var navigator: Navigator
|
lateinit var navigator: Navigator
|
||||||
private set
|
private set
|
||||||
private lateinit var fragmentFactory: FragmentFactory
|
|
||||||
|
|
||||||
private lateinit var activeSessionHolder: ActiveSessionHolder
|
private lateinit var activeSessionHolder: ActiveSessionHolder
|
||||||
private lateinit var vectorPreferences: VectorPreferences
|
private lateinit var vectorPreferences: VectorPreferences
|
||||||
@ -210,8 +205,6 @@ abstract class VectorBaseActivity<VB : ViewBinding> : AppCompatActivity(), Maver
|
|||||||
val singletonEntryPoint = singletonEntryPoint()
|
val singletonEntryPoint = singletonEntryPoint()
|
||||||
val activityEntryPoint = EntryPointAccessors.fromActivity(this, ActivityEntryPoint::class.java)
|
val activityEntryPoint = EntryPointAccessors.fromActivity(this, ActivityEntryPoint::class.java)
|
||||||
ThemeUtils.setActivityTheme(this, getOtherThemes())
|
ThemeUtils.setActivityTheme(this, getOtherThemes())
|
||||||
fragmentFactory = activityEntryPoint.fragmentFactory()
|
|
||||||
supportFragmentManager.fragmentFactory = fragmentFactory
|
|
||||||
viewModelFactory = activityEntryPoint.viewModelFactory()
|
viewModelFactory = activityEntryPoint.viewModelFactory()
|
||||||
super.onCreate(savedInstanceState)
|
super.onCreate(savedInstanceState)
|
||||||
addOnMultiWindowModeChangedListener(onMultiWindowModeChangedListener)
|
addOnMultiWindowModeChangedListener(onMultiWindowModeChangedListener)
|
||||||
@ -464,12 +457,6 @@ abstract class VectorBaseActivity<VB : ViewBinding> : AppCompatActivity(), Maver
|
|||||||
bugReporter.inMultiWindowMode = it.isInMultiWindowMode
|
bugReporter.inMultiWindowMode = it.isInMultiWindowMode
|
||||||
}
|
}
|
||||||
|
|
||||||
protected fun createFragment(fragmentClass: Class<out Fragment>, argsParcelable: Parcelable? = null): Fragment {
|
|
||||||
return fragmentFactory.instantiate(classLoader, fragmentClass.name).apply {
|
|
||||||
arguments = argsParcelable?.toMvRxBundle()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ==========================================================================================
|
/* ==========================================================================================
|
||||||
* PRIVATE METHODS
|
* PRIVATE METHODS
|
||||||
* ========================================================================================== */
|
* ========================================================================================== */
|
||||||
|
@ -123,7 +123,6 @@ abstract class VectorBaseFragment<VB : ViewBinding> : Fragment(), MavericksView
|
|||||||
analyticsTracker = singletonEntryPoint.analyticsTracker()
|
analyticsTracker = singletonEntryPoint.analyticsTracker()
|
||||||
unrecognizedCertificateDialog = singletonEntryPoint.unrecognizedCertificateDialog()
|
unrecognizedCertificateDialog = singletonEntryPoint.unrecognizedCertificateDialog()
|
||||||
viewModelFactory = activityEntryPoint.viewModelFactory()
|
viewModelFactory = activityEntryPoint.viewModelFactory()
|
||||||
childFragmentManager.fragmentFactory = activityEntryPoint.fragmentFactory()
|
|
||||||
super.onAttach(context)
|
super.onAttach(context)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -21,6 +21,7 @@ import android.view.LayoutInflater
|
|||||||
import android.view.View
|
import android.view.View
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import com.airbnb.mvrx.activityViewModel
|
import com.airbnb.mvrx.activityViewModel
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.setTextWithColoredPart
|
import im.vector.app.core.extensions.setTextWithColoredPart
|
||||||
import im.vector.app.core.platform.OnBackPressed
|
import im.vector.app.core.platform.OnBackPressed
|
||||||
@ -30,9 +31,12 @@ import im.vector.app.databinding.FragmentAnalyticsOptinBinding
|
|||||||
import im.vector.app.features.analytics.AnalyticsConfig
|
import im.vector.app.features.analytics.AnalyticsConfig
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class AnalyticsOptInFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val analyticsConfig: AnalyticsConfig,
|
class AnalyticsOptInFragment :
|
||||||
) : VectorBaseFragment<FragmentAnalyticsOptinBinding>(), OnBackPressed {
|
VectorBaseFragment<FragmentAnalyticsOptinBinding>(),
|
||||||
|
OnBackPressed {
|
||||||
|
|
||||||
|
@Inject lateinit var analyticsConfig: AnalyticsConfig
|
||||||
|
|
||||||
// Share the view model with the Activity so that the Activity
|
// Share the view model with the Activity so that the Activity
|
||||||
// can decide what to do when the data has been saved
|
// can decide what to do when the data has been saved
|
||||||
|
@ -39,6 +39,7 @@ import com.airbnb.mvrx.args
|
|||||||
import com.airbnb.mvrx.fragmentViewModel
|
import com.airbnb.mvrx.fragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
import com.yalantis.ucrop.UCrop
|
import com.yalantis.ucrop.UCrop
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.cleanup
|
import im.vector.app.core.extensions.cleanup
|
||||||
import im.vector.app.core.extensions.insertBeforeLast
|
import im.vector.app.core.extensions.insertBeforeLast
|
||||||
@ -63,15 +64,17 @@ data class AttachmentsPreviewArgs(
|
|||||||
val attachments: List<ContentAttachmentData>
|
val attachments: List<ContentAttachmentData>
|
||||||
) : Parcelable
|
) : Parcelable
|
||||||
|
|
||||||
class AttachmentsPreviewFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val attachmentMiniaturePreviewController: AttachmentMiniaturePreviewController,
|
class AttachmentsPreviewFragment :
|
||||||
private val attachmentBigPreviewController: AttachmentBigPreviewController,
|
VectorBaseFragment<FragmentAttachmentsPreviewBinding>(),
|
||||||
private val colorProvider: ColorProvider,
|
|
||||||
private val clock: Clock,
|
|
||||||
) : VectorBaseFragment<FragmentAttachmentsPreviewBinding>(),
|
|
||||||
AttachmentMiniaturePreviewController.Callback,
|
AttachmentMiniaturePreviewController.Callback,
|
||||||
VectorMenuProvider {
|
VectorMenuProvider {
|
||||||
|
|
||||||
|
@Inject lateinit var attachmentMiniaturePreviewController: AttachmentMiniaturePreviewController
|
||||||
|
@Inject lateinit var attachmentBigPreviewController: AttachmentBigPreviewController
|
||||||
|
@Inject lateinit var colorProvider: ColorProvider
|
||||||
|
@Inject lateinit var clock: Clock
|
||||||
|
|
||||||
private val fragmentArgs: AttachmentsPreviewArgs by args()
|
private val fragmentArgs: AttachmentsPreviewArgs by args()
|
||||||
private val viewModel: AttachmentsPreviewViewModel by fragmentViewModel()
|
private val viewModel: AttachmentsPreviewViewModel by fragmentViewModel()
|
||||||
|
|
||||||
|
@ -24,6 +24,7 @@ import androidx.core.view.isVisible
|
|||||||
import androidx.lifecycle.lifecycleScope
|
import androidx.lifecycle.lifecycleScope
|
||||||
import com.airbnb.mvrx.activityViewModel
|
import com.airbnb.mvrx.activityViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.core.extensions.cleanup
|
import im.vector.app.core.extensions.cleanup
|
||||||
import im.vector.app.core.extensions.configureWith
|
import im.vector.app.core.extensions.configureWith
|
||||||
import im.vector.app.core.extensions.hideKeyboard
|
import im.vector.app.core.extensions.hideKeyboard
|
||||||
@ -44,9 +45,12 @@ import reactivecircus.flowbinding.android.widget.checkedChanges
|
|||||||
import reactivecircus.flowbinding.android.widget.textChanges
|
import reactivecircus.flowbinding.android.widget.textChanges
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class ContactsBookFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val contactsBookController: ContactsBookController
|
class ContactsBookFragment :
|
||||||
) : VectorBaseFragment<FragmentContactsBookBinding>(), ContactsBookController.Callback {
|
VectorBaseFragment<FragmentContactsBookBinding>(),
|
||||||
|
ContactsBookController.Callback {
|
||||||
|
|
||||||
|
@Inject lateinit var contactsBookController: ContactsBookController
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentContactsBookBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentContactsBookBinding {
|
||||||
return FragmentContactsBookBinding.inflate(inflater, container, false)
|
return FragmentContactsBookBinding.inflate(inflater, container, false)
|
||||||
|
@ -22,15 +22,16 @@ import android.view.View
|
|||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import android.view.inputmethod.EditorInfo
|
import android.view.inputmethod.EditorInfo
|
||||||
import androidx.core.widget.doOnTextChanged
|
import androidx.core.widget.doOnTextChanged
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.registerStartForActivityResult
|
import im.vector.app.core.extensions.registerStartForActivityResult
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
import im.vector.app.core.utils.startImportTextFromFileIntent
|
import im.vector.app.core.utils.startImportTextFromFileIntent
|
||||||
import im.vector.app.databinding.FragmentKeysBackupRestoreFromKeyBinding
|
import im.vector.app.databinding.FragmentKeysBackupRestoreFromKeyBinding
|
||||||
import org.matrix.android.sdk.api.extensions.tryOrNull
|
import org.matrix.android.sdk.api.extensions.tryOrNull
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
class KeysBackupRestoreFromKeyFragment @Inject constructor() :
|
@AndroidEntryPoint
|
||||||
|
class KeysBackupRestoreFromKeyFragment :
|
||||||
VectorBaseFragment<FragmentKeysBackupRestoreFromKeyBinding>() {
|
VectorBaseFragment<FragmentKeysBackupRestoreFromKeyBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentKeysBackupRestoreFromKeyBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentKeysBackupRestoreFromKeyBinding {
|
||||||
|
@ -24,12 +24,14 @@ import android.view.ViewGroup
|
|||||||
import android.view.inputmethod.EditorInfo
|
import android.view.inputmethod.EditorInfo
|
||||||
import androidx.core.text.set
|
import androidx.core.text.set
|
||||||
import androidx.core.widget.doOnTextChanged
|
import androidx.core.widget.doOnTextChanged
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
import im.vector.app.databinding.FragmentKeysBackupRestoreFromPassphraseBinding
|
import im.vector.app.databinding.FragmentKeysBackupRestoreFromPassphraseBinding
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
class KeysBackupRestoreFromPassphraseFragment @Inject constructor() : VectorBaseFragment<FragmentKeysBackupRestoreFromPassphraseBinding>() {
|
@AndroidEntryPoint
|
||||||
|
class KeysBackupRestoreFromPassphraseFragment :
|
||||||
|
VectorBaseFragment<FragmentKeysBackupRestoreFromPassphraseBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentKeysBackupRestoreFromPassphraseBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentKeysBackupRestoreFromPassphraseBinding {
|
||||||
return FragmentKeysBackupRestoreFromPassphraseBinding.inflate(inflater, container, false)
|
return FragmentKeysBackupRestoreFromPassphraseBinding.inflate(inflater, container, false)
|
||||||
|
@ -20,13 +20,15 @@ import android.view.LayoutInflater
|
|||||||
import android.view.View
|
import android.view.View
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import androidx.core.view.isVisible
|
import androidx.core.view.isVisible
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
import im.vector.app.core.utils.LiveEvent
|
import im.vector.app.core.utils.LiveEvent
|
||||||
import im.vector.app.databinding.FragmentKeysBackupRestoreSuccessBinding
|
import im.vector.app.databinding.FragmentKeysBackupRestoreSuccessBinding
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
class KeysBackupRestoreSuccessFragment @Inject constructor() : VectorBaseFragment<FragmentKeysBackupRestoreSuccessBinding>() {
|
@AndroidEntryPoint
|
||||||
|
class KeysBackupRestoreSuccessFragment :
|
||||||
|
VectorBaseFragment<FragmentKeysBackupRestoreSuccessBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentKeysBackupRestoreSuccessBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentKeysBackupRestoreSuccessBinding {
|
||||||
return FragmentKeysBackupRestoreSuccessBinding.inflate(inflater, container, false)
|
return FragmentKeysBackupRestoreSuccessBinding.inflate(inflater, container, false)
|
||||||
|
@ -22,6 +22,7 @@ import android.view.ViewGroup
|
|||||||
import com.airbnb.mvrx.activityViewModel
|
import com.airbnb.mvrx.activityViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.cleanup
|
import im.vector.app.core.extensions.cleanup
|
||||||
import im.vector.app.core.extensions.configureWith
|
import im.vector.app.core.extensions.configureWith
|
||||||
@ -30,10 +31,13 @@ import im.vector.app.databinding.FragmentKeysBackupSettingsBinding
|
|||||||
import im.vector.app.features.crypto.keysbackup.restore.KeysBackupRestoreActivity
|
import im.vector.app.features.crypto.keysbackup.restore.KeysBackupRestoreActivity
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class KeysBackupSettingsFragment @Inject constructor(private val keysBackupSettingsRecyclerViewController: KeysBackupSettingsRecyclerViewController) :
|
@AndroidEntryPoint
|
||||||
|
class KeysBackupSettingsFragment :
|
||||||
VectorBaseFragment<FragmentKeysBackupSettingsBinding>(),
|
VectorBaseFragment<FragmentKeysBackupSettingsBinding>(),
|
||||||
KeysBackupSettingsRecyclerViewController.Listener {
|
KeysBackupSettingsRecyclerViewController.Listener {
|
||||||
|
|
||||||
|
@Inject lateinit var keysBackupSettingsRecyclerViewController: KeysBackupSettingsRecyclerViewController
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentKeysBackupSettingsBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentKeysBackupSettingsBinding {
|
||||||
return FragmentKeysBackupSettingsBinding.inflate(inflater, container, false)
|
return FragmentKeysBackupSettingsBinding.inflate(inflater, container, false)
|
||||||
}
|
}
|
||||||
|
@ -20,12 +20,14 @@ import android.os.Bundle
|
|||||||
import android.view.LayoutInflater
|
import android.view.LayoutInflater
|
||||||
import android.view.View
|
import android.view.View
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
import im.vector.app.core.utils.LiveEvent
|
import im.vector.app.core.utils.LiveEvent
|
||||||
import im.vector.app.databinding.FragmentKeysBackupSetupStep1Binding
|
import im.vector.app.databinding.FragmentKeysBackupSetupStep1Binding
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
class KeysBackupSetupStep1Fragment @Inject constructor() : VectorBaseFragment<FragmentKeysBackupSetupStep1Binding>() {
|
@AndroidEntryPoint
|
||||||
|
class KeysBackupSetupStep1Fragment :
|
||||||
|
VectorBaseFragment<FragmentKeysBackupSetupStep1Binding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentKeysBackupSetupStep1Binding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentKeysBackupSetupStep1Binding {
|
||||||
return FragmentKeysBackupSetupStep1Binding.inflate(inflater, container, false)
|
return FragmentKeysBackupSetupStep1Binding.inflate(inflater, container, false)
|
||||||
|
@ -24,6 +24,7 @@ import androidx.core.widget.doOnTextChanged
|
|||||||
import androidx.lifecycle.viewModelScope
|
import androidx.lifecycle.viewModelScope
|
||||||
import androidx.transition.TransitionManager
|
import androidx.transition.TransitionManager
|
||||||
import com.nulabinc.zxcvbn.Zxcvbn
|
import com.nulabinc.zxcvbn.Zxcvbn
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.hidePassword
|
import im.vector.app.core.extensions.hidePassword
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
@ -31,9 +32,10 @@ import im.vector.app.databinding.FragmentKeysBackupSetupStep2Binding
|
|||||||
import im.vector.app.features.settings.VectorLocale
|
import im.vector.app.features.settings.VectorLocale
|
||||||
import kotlinx.coroutines.Dispatchers
|
import kotlinx.coroutines.Dispatchers
|
||||||
import kotlinx.coroutines.launch
|
import kotlinx.coroutines.launch
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
class KeysBackupSetupStep2Fragment @Inject constructor() : VectorBaseFragment<FragmentKeysBackupSetupStep2Binding>() {
|
@AndroidEntryPoint
|
||||||
|
class KeysBackupSetupStep2Fragment :
|
||||||
|
VectorBaseFragment<FragmentKeysBackupSetupStep2Binding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentKeysBackupSetupStep2Binding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentKeysBackupSetupStep2Binding {
|
||||||
return FragmentKeysBackupSetupStep2Binding.inflate(inflater, container, false)
|
return FragmentKeysBackupSetupStep2Binding.inflate(inflater, container, false)
|
||||||
|
@ -28,6 +28,7 @@ import androidx.lifecycle.lifecycleScope
|
|||||||
import arrow.core.Try
|
import arrow.core.Try
|
||||||
import com.google.android.material.bottomsheet.BottomSheetDialog
|
import com.google.android.material.bottomsheet.BottomSheetDialog
|
||||||
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.registerStartForActivityResult
|
import im.vector.app.core.extensions.registerStartForActivityResult
|
||||||
import im.vector.app.core.extensions.safeOpenOutputStream
|
import im.vector.app.core.extensions.safeOpenOutputStream
|
||||||
@ -44,9 +45,10 @@ import java.io.IOException
|
|||||||
import java.text.SimpleDateFormat
|
import java.text.SimpleDateFormat
|
||||||
import java.util.Date
|
import java.util.Date
|
||||||
import java.util.Locale
|
import java.util.Locale
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
class KeysBackupSetupStep3Fragment @Inject constructor() : VectorBaseFragment<FragmentKeysBackupSetupStep3Binding>() {
|
@AndroidEntryPoint
|
||||||
|
class KeysBackupSetupStep3Fragment :
|
||||||
|
VectorBaseFragment<FragmentKeysBackupSetupStep3Binding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentKeysBackupSetupStep3Binding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentKeysBackupSetupStep3Binding {
|
||||||
return FragmentKeysBackupSetupStep3Binding.inflate(inflater, container, false)
|
return FragmentKeysBackupSetupStep3Binding.inflate(inflater, container, false)
|
||||||
|
@ -24,6 +24,7 @@ import android.view.ViewGroup
|
|||||||
import android.view.inputmethod.EditorInfo
|
import android.view.inputmethod.EditorInfo
|
||||||
import androidx.lifecycle.lifecycleScope
|
import androidx.lifecycle.lifecycleScope
|
||||||
import com.airbnb.mvrx.activityViewModel
|
import com.airbnb.mvrx.activityViewModel
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.registerStartForActivityResult
|
import im.vector.app.core.extensions.registerStartForActivityResult
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
@ -35,9 +36,10 @@ import kotlinx.coroutines.flow.onEach
|
|||||||
import org.matrix.android.sdk.api.extensions.tryOrNull
|
import org.matrix.android.sdk.api.extensions.tryOrNull
|
||||||
import reactivecircus.flowbinding.android.widget.editorActionEvents
|
import reactivecircus.flowbinding.android.widget.editorActionEvents
|
||||||
import reactivecircus.flowbinding.android.widget.textChanges
|
import reactivecircus.flowbinding.android.widget.textChanges
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
class SharedSecuredStorageKeyFragment @Inject constructor() : VectorBaseFragment<FragmentSsssAccessFromKeyBinding>() {
|
@AndroidEntryPoint
|
||||||
|
class SharedSecuredStorageKeyFragment :
|
||||||
|
VectorBaseFragment<FragmentSsssAccessFromKeyBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentSsssAccessFromKeyBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentSsssAccessFromKeyBinding {
|
||||||
return FragmentSsssAccessFromKeyBinding.inflate(inflater, container, false)
|
return FragmentSsssAccessFromKeyBinding.inflate(inflater, container, false)
|
||||||
|
@ -24,20 +24,19 @@ import android.view.inputmethod.EditorInfo
|
|||||||
import androidx.core.text.toSpannable
|
import androidx.core.text.toSpannable
|
||||||
import androidx.lifecycle.lifecycleScope
|
import androidx.lifecycle.lifecycleScope
|
||||||
import com.airbnb.mvrx.activityViewModel
|
import com.airbnb.mvrx.activityViewModel
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
import im.vector.app.core.resources.ColorProvider
|
|
||||||
import im.vector.app.databinding.FragmentSsssAccessFromPassphraseBinding
|
import im.vector.app.databinding.FragmentSsssAccessFromPassphraseBinding
|
||||||
import im.vector.lib.core.utils.flow.throttleFirst
|
import im.vector.lib.core.utils.flow.throttleFirst
|
||||||
import kotlinx.coroutines.flow.launchIn
|
import kotlinx.coroutines.flow.launchIn
|
||||||
import kotlinx.coroutines.flow.onEach
|
import kotlinx.coroutines.flow.onEach
|
||||||
import reactivecircus.flowbinding.android.widget.editorActionEvents
|
import reactivecircus.flowbinding.android.widget.editorActionEvents
|
||||||
import reactivecircus.flowbinding.android.widget.textChanges
|
import reactivecircus.flowbinding.android.widget.textChanges
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
class SharedSecuredStoragePassphraseFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val colorProvider: ColorProvider
|
class SharedSecuredStoragePassphraseFragment :
|
||||||
) : VectorBaseFragment<FragmentSsssAccessFromPassphraseBinding>() {
|
VectorBaseFragment<FragmentSsssAccessFromPassphraseBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentSsssAccessFromPassphraseBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentSsssAccessFromPassphraseBinding {
|
||||||
return FragmentSsssAccessFromPassphraseBinding.inflate(inflater, container, false)
|
return FragmentSsssAccessFromPassphraseBinding.inflate(inflater, container, false)
|
||||||
|
@ -22,14 +22,15 @@ import android.view.View
|
|||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import com.airbnb.mvrx.activityViewModel
|
import com.airbnb.mvrx.activityViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.setTextOrHide
|
import im.vector.app.core.extensions.setTextOrHide
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
import im.vector.app.databinding.FragmentSsssResetAllBinding
|
import im.vector.app.databinding.FragmentSsssResetAllBinding
|
||||||
import im.vector.app.features.roommemberprofile.devices.DeviceListBottomSheet
|
import im.vector.app.features.roommemberprofile.devices.DeviceListBottomSheet
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
class SharedSecuredStorageResetAllFragment @Inject constructor() :
|
@AndroidEntryPoint
|
||||||
|
class SharedSecuredStorageResetAllFragment :
|
||||||
VectorBaseFragment<FragmentSsssResetAllBinding>() {
|
VectorBaseFragment<FragmentSsssResetAllBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentSsssResetAllBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentSsssResetAllBinding {
|
||||||
|
@ -23,6 +23,7 @@ import android.view.ViewGroup
|
|||||||
import androidx.core.text.toSpannable
|
import androidx.core.text.toSpannable
|
||||||
import com.airbnb.mvrx.parentFragmentViewModel
|
import com.airbnb.mvrx.parentFragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
import im.vector.app.core.resources.ColorProvider
|
import im.vector.app.core.resources.ColorProvider
|
||||||
@ -30,9 +31,11 @@ import im.vector.app.core.utils.colorizeMatchingText
|
|||||||
import im.vector.app.databinding.FragmentBootstrapConclusionBinding
|
import im.vector.app.databinding.FragmentBootstrapConclusionBinding
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class BootstrapConclusionFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val colorProvider: ColorProvider
|
class BootstrapConclusionFragment :
|
||||||
) : VectorBaseFragment<FragmentBootstrapConclusionBinding>() {
|
VectorBaseFragment<FragmentBootstrapConclusionBinding>() {
|
||||||
|
|
||||||
|
@Inject lateinit var colorProvider: ColorProvider
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentBootstrapConclusionBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentBootstrapConclusionBinding {
|
||||||
return FragmentBootstrapConclusionBinding.inflate(inflater, container, false)
|
return FragmentBootstrapConclusionBinding.inflate(inflater, container, false)
|
||||||
|
@ -25,6 +25,7 @@ import androidx.core.view.isGone
|
|||||||
import androidx.lifecycle.lifecycleScope
|
import androidx.lifecycle.lifecycleScope
|
||||||
import com.airbnb.mvrx.parentFragmentViewModel
|
import com.airbnb.mvrx.parentFragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.hideKeyboard
|
import im.vector.app.core.extensions.hideKeyboard
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
@ -34,9 +35,9 @@ import kotlinx.coroutines.flow.launchIn
|
|||||||
import kotlinx.coroutines.flow.onEach
|
import kotlinx.coroutines.flow.onEach
|
||||||
import reactivecircus.flowbinding.android.widget.editorActionEvents
|
import reactivecircus.flowbinding.android.widget.editorActionEvents
|
||||||
import reactivecircus.flowbinding.android.widget.textChanges
|
import reactivecircus.flowbinding.android.widget.textChanges
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
class BootstrapConfirmPassphraseFragment @Inject constructor() :
|
@AndroidEntryPoint
|
||||||
|
class BootstrapConfirmPassphraseFragment :
|
||||||
VectorBaseFragment<FragmentBootstrapEnterPassphraseBinding>() {
|
VectorBaseFragment<FragmentBootstrapEnterPassphraseBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentBootstrapEnterPassphraseBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentBootstrapEnterPassphraseBinding {
|
||||||
|
@ -24,6 +24,7 @@ import android.view.inputmethod.EditorInfo
|
|||||||
import androidx.lifecycle.lifecycleScope
|
import androidx.lifecycle.lifecycleScope
|
||||||
import com.airbnb.mvrx.parentFragmentViewModel
|
import com.airbnb.mvrx.parentFragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
import im.vector.app.databinding.FragmentBootstrapEnterPassphraseBinding
|
import im.vector.app.databinding.FragmentBootstrapEnterPassphraseBinding
|
||||||
@ -33,9 +34,9 @@ import kotlinx.coroutines.flow.launchIn
|
|||||||
import kotlinx.coroutines.flow.onEach
|
import kotlinx.coroutines.flow.onEach
|
||||||
import reactivecircus.flowbinding.android.widget.editorActionEvents
|
import reactivecircus.flowbinding.android.widget.editorActionEvents
|
||||||
import reactivecircus.flowbinding.android.widget.textChanges
|
import reactivecircus.flowbinding.android.widget.textChanges
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
class BootstrapEnterPassphraseFragment @Inject constructor() :
|
@AndroidEntryPoint
|
||||||
|
class BootstrapEnterPassphraseFragment :
|
||||||
VectorBaseFragment<FragmentBootstrapEnterPassphraseBinding>() {
|
VectorBaseFragment<FragmentBootstrapEnterPassphraseBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentBootstrapEnterPassphraseBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentBootstrapEnterPassphraseBinding {
|
||||||
|
@ -30,6 +30,7 @@ import androidx.core.view.isVisible
|
|||||||
import androidx.lifecycle.lifecycleScope
|
import androidx.lifecycle.lifecycleScope
|
||||||
import com.airbnb.mvrx.parentFragmentViewModel
|
import com.airbnb.mvrx.parentFragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.hideKeyboard
|
import im.vector.app.core.extensions.hideKeyboard
|
||||||
import im.vector.app.core.extensions.registerStartForActivityResult
|
import im.vector.app.core.extensions.registerStartForActivityResult
|
||||||
@ -47,9 +48,11 @@ import reactivecircus.flowbinding.android.widget.editorActionEvents
|
|||||||
import reactivecircus.flowbinding.android.widget.textChanges
|
import reactivecircus.flowbinding.android.widget.textChanges
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class BootstrapMigrateBackupFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val colorProvider: ColorProvider
|
class BootstrapMigrateBackupFragment :
|
||||||
) : VectorBaseFragment<FragmentBootstrapMigrateBackupBinding>() {
|
VectorBaseFragment<FragmentBootstrapMigrateBackupBinding>() {
|
||||||
|
|
||||||
|
@Inject lateinit var colorProvider: ColorProvider
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentBootstrapMigrateBackupBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentBootstrapMigrateBackupBinding {
|
||||||
return FragmentBootstrapMigrateBackupBinding.inflate(inflater, container, false)
|
return FragmentBootstrapMigrateBackupBinding.inflate(inflater, container, false)
|
||||||
|
@ -23,15 +23,14 @@ import android.view.ViewGroup
|
|||||||
import androidx.core.view.isVisible
|
import androidx.core.view.isVisible
|
||||||
import com.airbnb.mvrx.parentFragmentViewModel
|
import com.airbnb.mvrx.parentFragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.core.extensions.setTextOrHide
|
import im.vector.app.core.extensions.setTextOrHide
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
import im.vector.app.core.resources.ColorProvider
|
|
||||||
import im.vector.app.databinding.FragmentBootstrapReauthBinding
|
import im.vector.app.databinding.FragmentBootstrapReauthBinding
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
class BootstrapReAuthFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val colorProvider: ColorProvider
|
class BootstrapReAuthFragment :
|
||||||
) : VectorBaseFragment<FragmentBootstrapReauthBinding>() {
|
VectorBaseFragment<FragmentBootstrapReauthBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentBootstrapReauthBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentBootstrapReauthBinding {
|
||||||
return FragmentBootstrapReauthBinding.inflate(inflater, container, false)
|
return FragmentBootstrapReauthBinding.inflate(inflater, container, false)
|
||||||
|
@ -27,21 +27,20 @@ import androidx.core.view.isVisible
|
|||||||
import androidx.lifecycle.lifecycleScope
|
import androidx.lifecycle.lifecycleScope
|
||||||
import com.airbnb.mvrx.parentFragmentViewModel
|
import com.airbnb.mvrx.parentFragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.registerStartForActivityResult
|
import im.vector.app.core.extensions.registerStartForActivityResult
|
||||||
import im.vector.app.core.extensions.safeOpenOutputStream
|
import im.vector.app.core.extensions.safeOpenOutputStream
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
import im.vector.app.core.resources.ColorProvider
|
|
||||||
import im.vector.app.core.utils.startSharePlainTextIntent
|
import im.vector.app.core.utils.startSharePlainTextIntent
|
||||||
import im.vector.app.core.utils.toast
|
import im.vector.app.core.utils.toast
|
||||||
import im.vector.app.databinding.FragmentBootstrapSaveKeyBinding
|
import im.vector.app.databinding.FragmentBootstrapSaveKeyBinding
|
||||||
import kotlinx.coroutines.Dispatchers
|
import kotlinx.coroutines.Dispatchers
|
||||||
import kotlinx.coroutines.launch
|
import kotlinx.coroutines.launch
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
class BootstrapSaveRecoveryKeyFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val colorProvider: ColorProvider
|
class BootstrapSaveRecoveryKeyFragment :
|
||||||
) : VectorBaseFragment<FragmentBootstrapSaveKeyBinding>() {
|
VectorBaseFragment<FragmentBootstrapSaveKeyBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentBootstrapSaveKeyBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentBootstrapSaveKeyBinding {
|
||||||
return FragmentBootstrapSaveKeyBinding.inflate(inflater, container, false)
|
return FragmentBootstrapSaveKeyBinding.inflate(inflater, container, false)
|
||||||
|
@ -23,13 +23,14 @@ import android.view.ViewGroup
|
|||||||
import androidx.core.view.isVisible
|
import androidx.core.view.isVisible
|
||||||
import com.airbnb.mvrx.parentFragmentViewModel
|
import com.airbnb.mvrx.parentFragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
import im.vector.app.databinding.FragmentBootstrapSetupRecoveryBinding
|
import im.vector.app.databinding.FragmentBootstrapSetupRecoveryBinding
|
||||||
import im.vector.app.features.raw.wellknown.SecureBackupMethod
|
import im.vector.app.features.raw.wellknown.SecureBackupMethod
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
class BootstrapSetupRecoveryKeyFragment @Inject constructor() :
|
@AndroidEntryPoint
|
||||||
|
class BootstrapSetupRecoveryKeyFragment :
|
||||||
VectorBaseFragment<FragmentBootstrapSetupRecoveryBinding>() {
|
VectorBaseFragment<FragmentBootstrapSetupRecoveryBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentBootstrapSetupRecoveryBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentBootstrapSetupRecoveryBinding {
|
||||||
|
@ -21,11 +21,12 @@ import android.view.ViewGroup
|
|||||||
import androidx.core.view.isVisible
|
import androidx.core.view.isVisible
|
||||||
import com.airbnb.mvrx.parentFragmentViewModel
|
import com.airbnb.mvrx.parentFragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
import im.vector.app.databinding.FragmentBootstrapWaitingBinding
|
import im.vector.app.databinding.FragmentBootstrapWaitingBinding
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
class BootstrapWaitingFragment @Inject constructor() :
|
@AndroidEntryPoint
|
||||||
|
class BootstrapWaitingFragment :
|
||||||
VectorBaseFragment<FragmentBootstrapWaitingBinding>() {
|
VectorBaseFragment<FragmentBootstrapWaitingBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentBootstrapWaitingBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentBootstrapWaitingBinding {
|
||||||
|
@ -18,11 +18,13 @@ package im.vector.app.features.crypto.verification
|
|||||||
|
|
||||||
import android.view.LayoutInflater
|
import android.view.LayoutInflater
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
import im.vector.app.databinding.FragmentProgressBinding
|
import im.vector.app.databinding.FragmentProgressBinding
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
class QuadSLoadingFragment @Inject constructor() : VectorBaseFragment<FragmentProgressBinding>() {
|
@AndroidEntryPoint
|
||||||
|
class QuadSLoadingFragment :
|
||||||
|
VectorBaseFragment<FragmentProgressBinding>() {
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentProgressBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentProgressBinding {
|
||||||
return FragmentProgressBinding.inflate(inflater, container, false)
|
return FragmentProgressBinding.inflate(inflater, container, false)
|
||||||
}
|
}
|
||||||
|
@ -22,6 +22,7 @@ import android.view.View
|
|||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import com.airbnb.mvrx.parentFragmentViewModel
|
import com.airbnb.mvrx.parentFragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.core.extensions.cleanup
|
import im.vector.app.core.extensions.cleanup
|
||||||
import im.vector.app.core.extensions.configureWith
|
import im.vector.app.core.extensions.configureWith
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
@ -29,11 +30,13 @@ import im.vector.app.databinding.BottomSheetVerificationChildFragmentBinding
|
|||||||
import im.vector.app.features.crypto.verification.VerificationBottomSheetViewModel
|
import im.vector.app.features.crypto.verification.VerificationBottomSheetViewModel
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class VerificationCancelFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
val controller: VerificationCancelController
|
class VerificationCancelFragment :
|
||||||
) : VectorBaseFragment<BottomSheetVerificationChildFragmentBinding>(),
|
VectorBaseFragment<BottomSheetVerificationChildFragmentBinding>(),
|
||||||
VerificationCancelController.Listener {
|
VerificationCancelController.Listener {
|
||||||
|
|
||||||
|
@Inject lateinit var controller: VerificationCancelController
|
||||||
|
|
||||||
private val viewModel by parentFragmentViewModel(VerificationBottomSheetViewModel::class)
|
private val viewModel by parentFragmentViewModel(VerificationBottomSheetViewModel::class)
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): BottomSheetVerificationChildFragmentBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): BottomSheetVerificationChildFragmentBinding {
|
||||||
|
@ -22,6 +22,7 @@ import android.view.View
|
|||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import com.airbnb.mvrx.parentFragmentViewModel
|
import com.airbnb.mvrx.parentFragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.core.extensions.cleanup
|
import im.vector.app.core.extensions.cleanup
|
||||||
import im.vector.app.core.extensions.configureWith
|
import im.vector.app.core.extensions.configureWith
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
@ -29,11 +30,13 @@ import im.vector.app.databinding.BottomSheetVerificationChildFragmentBinding
|
|||||||
import im.vector.app.features.crypto.verification.VerificationBottomSheetViewModel
|
import im.vector.app.features.crypto.verification.VerificationBottomSheetViewModel
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class VerificationNotMeFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
val controller: VerificationNotMeController
|
class VerificationNotMeFragment :
|
||||||
) : VectorBaseFragment<BottomSheetVerificationChildFragmentBinding>(),
|
VectorBaseFragment<BottomSheetVerificationChildFragmentBinding>(),
|
||||||
VerificationNotMeController.Listener {
|
VerificationNotMeController.Listener {
|
||||||
|
|
||||||
|
@Inject lateinit var controller: VerificationNotMeController
|
||||||
|
|
||||||
private val viewModel by parentFragmentViewModel(VerificationBottomSheetViewModel::class)
|
private val viewModel by parentFragmentViewModel(VerificationBottomSheetViewModel::class)
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): BottomSheetVerificationChildFragmentBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): BottomSheetVerificationChildFragmentBinding {
|
||||||
|
@ -23,6 +23,7 @@ import android.view.ViewGroup
|
|||||||
import com.airbnb.mvrx.fragmentViewModel
|
import com.airbnb.mvrx.fragmentViewModel
|
||||||
import com.airbnb.mvrx.parentFragmentViewModel
|
import com.airbnb.mvrx.parentFragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.cleanup
|
import im.vector.app.core.extensions.cleanup
|
||||||
import im.vector.app.core.extensions.configureWith
|
import im.vector.app.core.extensions.configureWith
|
||||||
@ -39,11 +40,12 @@ import im.vector.app.features.qrcode.QrCodeScannerActivity
|
|||||||
import timber.log.Timber
|
import timber.log.Timber
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class VerificationChooseMethodFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
val controller: VerificationChooseMethodController
|
class VerificationChooseMethodFragment :
|
||||||
) : VectorBaseFragment<BottomSheetVerificationChildFragmentBinding>(),
|
VectorBaseFragment<BottomSheetVerificationChildFragmentBinding>(),
|
||||||
VerificationChooseMethodController.Listener {
|
VerificationChooseMethodController.Listener {
|
||||||
|
|
||||||
|
@Inject lateinit var controller: VerificationChooseMethodController
|
||||||
private val viewModel by fragmentViewModel(VerificationChooseMethodViewModel::class)
|
private val viewModel by fragmentViewModel(VerificationChooseMethodViewModel::class)
|
||||||
|
|
||||||
private val sharedViewModel by parentFragmentViewModel(VerificationBottomSheetViewModel::class)
|
private val sharedViewModel by parentFragmentViewModel(VerificationBottomSheetViewModel::class)
|
||||||
|
@ -23,6 +23,7 @@ import android.view.ViewGroup
|
|||||||
import com.airbnb.mvrx.fragmentViewModel
|
import com.airbnb.mvrx.fragmentViewModel
|
||||||
import com.airbnb.mvrx.parentFragmentViewModel
|
import com.airbnb.mvrx.parentFragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.core.extensions.cleanup
|
import im.vector.app.core.extensions.cleanup
|
||||||
import im.vector.app.core.extensions.configureWith
|
import im.vector.app.core.extensions.configureWith
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
@ -32,11 +33,13 @@ import im.vector.app.features.crypto.verification.VerificationBottomSheetViewMod
|
|||||||
import kotlinx.parcelize.Parcelize
|
import kotlinx.parcelize.Parcelize
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class VerificationConclusionFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
val controller: VerificationConclusionController
|
class VerificationConclusionFragment :
|
||||||
) : VectorBaseFragment<BottomSheetVerificationChildFragmentBinding>(),
|
VectorBaseFragment<BottomSheetVerificationChildFragmentBinding>(),
|
||||||
VerificationConclusionController.Listener {
|
VerificationConclusionController.Listener {
|
||||||
|
|
||||||
|
@Inject lateinit var controller: VerificationConclusionController
|
||||||
|
|
||||||
@Parcelize
|
@Parcelize
|
||||||
data class Args(
|
data class Args(
|
||||||
val isSuccessFull: Boolean,
|
val isSuccessFull: Boolean,
|
||||||
|
@ -22,6 +22,7 @@ import android.view.ViewGroup
|
|||||||
import com.airbnb.mvrx.fragmentViewModel
|
import com.airbnb.mvrx.fragmentViewModel
|
||||||
import com.airbnb.mvrx.parentFragmentViewModel
|
import com.airbnb.mvrx.parentFragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.core.extensions.cleanup
|
import im.vector.app.core.extensions.cleanup
|
||||||
import im.vector.app.core.extensions.configureWith
|
import im.vector.app.core.extensions.configureWith
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
@ -30,11 +31,13 @@ import im.vector.app.features.crypto.verification.VerificationAction
|
|||||||
import im.vector.app.features.crypto.verification.VerificationBottomSheetViewModel
|
import im.vector.app.features.crypto.verification.VerificationBottomSheetViewModel
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class VerificationEmojiCodeFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
val controller: VerificationEmojiCodeController
|
class VerificationEmojiCodeFragment :
|
||||||
) : VectorBaseFragment<BottomSheetVerificationChildFragmentBinding>(),
|
VectorBaseFragment<BottomSheetVerificationChildFragmentBinding>(),
|
||||||
VerificationEmojiCodeController.Listener {
|
VerificationEmojiCodeController.Listener {
|
||||||
|
|
||||||
|
@Inject lateinit var controller: VerificationEmojiCodeController
|
||||||
|
|
||||||
private val viewModel by fragmentViewModel(VerificationEmojiCodeViewModel::class)
|
private val viewModel by fragmentViewModel(VerificationEmojiCodeViewModel::class)
|
||||||
|
|
||||||
private val sharedViewModel by parentFragmentViewModel(VerificationBottomSheetViewModel::class)
|
private val sharedViewModel by parentFragmentViewModel(VerificationBottomSheetViewModel::class)
|
||||||
|
@ -22,6 +22,7 @@ import android.view.LayoutInflater
|
|||||||
import android.view.View
|
import android.view.View
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import com.airbnb.mvrx.Mavericks
|
import com.airbnb.mvrx.Mavericks
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.core.extensions.cleanup
|
import im.vector.app.core.extensions.cleanup
|
||||||
import im.vector.app.core.extensions.configureWith
|
import im.vector.app.core.extensions.configureWith
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
@ -29,9 +30,11 @@ import im.vector.app.databinding.BottomSheetVerificationChildFragmentBinding
|
|||||||
import kotlinx.parcelize.Parcelize
|
import kotlinx.parcelize.Parcelize
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class VerificationQRWaitingFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
val controller: VerificationQRWaitingController
|
class VerificationQRWaitingFragment :
|
||||||
) : VectorBaseFragment<BottomSheetVerificationChildFragmentBinding>() {
|
VectorBaseFragment<BottomSheetVerificationChildFragmentBinding>() {
|
||||||
|
|
||||||
|
@Inject lateinit var controller: VerificationQRWaitingController
|
||||||
|
|
||||||
@Parcelize
|
@Parcelize
|
||||||
data class Args(
|
data class Args(
|
||||||
|
@ -21,6 +21,7 @@ import android.view.View
|
|||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import com.airbnb.mvrx.parentFragmentViewModel
|
import com.airbnb.mvrx.parentFragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.core.extensions.cleanup
|
import im.vector.app.core.extensions.cleanup
|
||||||
import im.vector.app.core.extensions.configureWith
|
import im.vector.app.core.extensions.configureWith
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
@ -29,11 +30,13 @@ import im.vector.app.features.crypto.verification.VerificationAction
|
|||||||
import im.vector.app.features.crypto.verification.VerificationBottomSheetViewModel
|
import im.vector.app.features.crypto.verification.VerificationBottomSheetViewModel
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class VerificationQrScannedByOtherFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
val controller: VerificationQrScannedByOtherController
|
class VerificationQrScannedByOtherFragment :
|
||||||
) : VectorBaseFragment<BottomSheetVerificationChildFragmentBinding>(),
|
VectorBaseFragment<BottomSheetVerificationChildFragmentBinding>(),
|
||||||
VerificationQrScannedByOtherController.Listener {
|
VerificationQrScannedByOtherController.Listener {
|
||||||
|
|
||||||
|
@Inject lateinit var controller: VerificationQrScannedByOtherController
|
||||||
|
|
||||||
private val sharedViewModel by parentFragmentViewModel(VerificationBottomSheetViewModel::class)
|
private val sharedViewModel by parentFragmentViewModel(VerificationBottomSheetViewModel::class)
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): BottomSheetVerificationChildFragmentBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): BottomSheetVerificationChildFragmentBinding {
|
||||||
|
@ -21,6 +21,7 @@ import android.view.View
|
|||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import com.airbnb.mvrx.parentFragmentViewModel
|
import com.airbnb.mvrx.parentFragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.core.extensions.cleanup
|
import im.vector.app.core.extensions.cleanup
|
||||||
import im.vector.app.core.extensions.configureWith
|
import im.vector.app.core.extensions.configureWith
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
@ -29,11 +30,13 @@ import im.vector.app.features.crypto.verification.VerificationAction
|
|||||||
import im.vector.app.features.crypto.verification.VerificationBottomSheetViewModel
|
import im.vector.app.features.crypto.verification.VerificationBottomSheetViewModel
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class VerificationRequestFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
val controller: VerificationRequestController
|
class VerificationRequestFragment :
|
||||||
) : VectorBaseFragment<BottomSheetVerificationChildFragmentBinding>(),
|
VectorBaseFragment<BottomSheetVerificationChildFragmentBinding>(),
|
||||||
VerificationRequestController.Listener {
|
VerificationRequestController.Listener {
|
||||||
|
|
||||||
|
@Inject lateinit var controller: VerificationRequestController
|
||||||
|
|
||||||
private val viewModel by parentFragmentViewModel(VerificationBottomSheetViewModel::class)
|
private val viewModel by parentFragmentViewModel(VerificationBottomSheetViewModel::class)
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): BottomSheetVerificationChildFragmentBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): BottomSheetVerificationChildFragmentBinding {
|
||||||
|
@ -109,15 +109,15 @@ class RoomDevToolActivity :
|
|||||||
}
|
}
|
||||||
RoomDevToolViewState.Mode.StateEventList,
|
RoomDevToolViewState.Mode.StateEventList,
|
||||||
RoomDevToolViewState.Mode.StateEventListByType -> {
|
RoomDevToolViewState.Mode.StateEventListByType -> {
|
||||||
val frag = createFragment(RoomDevToolStateEventListFragment::class.java)
|
val frag = RoomDevToolStateEventListFragment()
|
||||||
navigateTo(frag)
|
navigateTo(frag)
|
||||||
}
|
}
|
||||||
RoomDevToolViewState.Mode.EditEventContent -> {
|
RoomDevToolViewState.Mode.EditEventContent -> {
|
||||||
val frag = createFragment(RoomDevToolEditFragment::class.java)
|
val frag = RoomDevToolEditFragment()
|
||||||
navigateTo(frag)
|
navigateTo(frag)
|
||||||
}
|
}
|
||||||
is RoomDevToolViewState.Mode.SendEventForm -> {
|
is RoomDevToolViewState.Mode.SendEventForm -> {
|
||||||
val frag = createFragment(RoomDevToolSendFormFragment::class.java)
|
val frag = RoomDevToolSendFormFragment()
|
||||||
navigateTo(frag)
|
navigateTo(frag)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -23,15 +23,16 @@ import android.view.ViewGroup
|
|||||||
import androidx.lifecycle.lifecycleScope
|
import androidx.lifecycle.lifecycleScope
|
||||||
import com.airbnb.mvrx.activityViewModel
|
import com.airbnb.mvrx.activityViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.core.extensions.hideKeyboard
|
import im.vector.app.core.extensions.hideKeyboard
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
import im.vector.app.databinding.FragmentDevtoolsEditorBinding
|
import im.vector.app.databinding.FragmentDevtoolsEditorBinding
|
||||||
import kotlinx.coroutines.flow.launchIn
|
import kotlinx.coroutines.flow.launchIn
|
||||||
import kotlinx.coroutines.flow.onEach
|
import kotlinx.coroutines.flow.onEach
|
||||||
import reactivecircus.flowbinding.android.widget.textChanges
|
import reactivecircus.flowbinding.android.widget.textChanges
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
class RoomDevToolEditFragment @Inject constructor() :
|
@AndroidEntryPoint
|
||||||
|
class RoomDevToolEditFragment :
|
||||||
VectorBaseFragment<FragmentDevtoolsEditorBinding>() {
|
VectorBaseFragment<FragmentDevtoolsEditorBinding>() {
|
||||||
|
|
||||||
private val sharedViewModel: RoomDevToolViewModel by activityViewModel()
|
private val sharedViewModel: RoomDevToolViewModel by activityViewModel()
|
||||||
|
@ -21,6 +21,7 @@ import android.view.LayoutInflater
|
|||||||
import android.view.View
|
import android.view.View
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import com.airbnb.mvrx.activityViewModel
|
import com.airbnb.mvrx.activityViewModel
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.cleanup
|
import im.vector.app.core.extensions.cleanup
|
||||||
import im.vector.app.core.extensions.configureWith
|
import im.vector.app.core.extensions.configureWith
|
||||||
@ -28,11 +29,13 @@ import im.vector.app.core.platform.VectorBaseFragment
|
|||||||
import im.vector.app.databinding.FragmentGenericRecyclerBinding
|
import im.vector.app.databinding.FragmentGenericRecyclerBinding
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class RoomDevToolFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val epoxyController: RoomDevToolRootController
|
class RoomDevToolFragment :
|
||||||
) : VectorBaseFragment<FragmentGenericRecyclerBinding>(),
|
VectorBaseFragment<FragmentGenericRecyclerBinding>(),
|
||||||
DevToolsInteractionListener {
|
DevToolsInteractionListener {
|
||||||
|
|
||||||
|
@Inject lateinit var epoxyController: RoomDevToolRootController
|
||||||
|
|
||||||
private val sharedViewModel: RoomDevToolViewModel by activityViewModel()
|
private val sharedViewModel: RoomDevToolViewModel by activityViewModel()
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentGenericRecyclerBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentGenericRecyclerBinding {
|
||||||
|
@ -22,15 +22,19 @@ import android.view.View
|
|||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import com.airbnb.mvrx.activityViewModel
|
import com.airbnb.mvrx.activityViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.core.extensions.cleanup
|
import im.vector.app.core.extensions.cleanup
|
||||||
import im.vector.app.core.extensions.configureWith
|
import im.vector.app.core.extensions.configureWith
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
import im.vector.app.databinding.FragmentGenericRecyclerBinding
|
import im.vector.app.databinding.FragmentGenericRecyclerBinding
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class RoomDevToolSendFormFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val epoxyController: RoomDevToolSendFormController
|
class RoomDevToolSendFormFragment :
|
||||||
) : VectorBaseFragment<FragmentGenericRecyclerBinding>(), DevToolsInteractionListener {
|
VectorBaseFragment<FragmentGenericRecyclerBinding>(),
|
||||||
|
DevToolsInteractionListener {
|
||||||
|
|
||||||
|
@Inject lateinit var epoxyController: RoomDevToolSendFormController
|
||||||
|
|
||||||
val sharedViewModel: RoomDevToolViewModel by activityViewModel()
|
val sharedViewModel: RoomDevToolViewModel by activityViewModel()
|
||||||
|
|
||||||
|
@ -22,6 +22,7 @@ import android.view.View
|
|||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import com.airbnb.mvrx.activityViewModel
|
import com.airbnb.mvrx.activityViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.cleanup
|
import im.vector.app.core.extensions.cleanup
|
||||||
import im.vector.app.core.extensions.configureWith
|
import im.vector.app.core.extensions.configureWith
|
||||||
@ -29,9 +30,12 @@ import im.vector.app.core.platform.VectorBaseFragment
|
|||||||
import im.vector.app.databinding.FragmentGenericRecyclerBinding
|
import im.vector.app.databinding.FragmentGenericRecyclerBinding
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class RoomDevToolStateEventListFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val epoxyController: RoomStateListController
|
class RoomDevToolStateEventListFragment :
|
||||||
) : VectorBaseFragment<FragmentGenericRecyclerBinding>(), DevToolsInteractionListener {
|
VectorBaseFragment<FragmentGenericRecyclerBinding>(),
|
||||||
|
DevToolsInteractionListener {
|
||||||
|
|
||||||
|
@Inject lateinit var epoxyController: RoomStateListController
|
||||||
|
|
||||||
val sharedViewModel: RoomDevToolViewModel by activityViewModel()
|
val sharedViewModel: RoomDevToolViewModel by activityViewModel()
|
||||||
|
|
||||||
|
@ -25,6 +25,7 @@ import com.airbnb.mvrx.args
|
|||||||
import com.airbnb.mvrx.fragmentViewModel
|
import com.airbnb.mvrx.fragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.cleanup
|
import im.vector.app.core.extensions.cleanup
|
||||||
import im.vector.app.core.extensions.configureWith
|
import im.vector.app.core.extensions.configureWith
|
||||||
@ -43,11 +44,13 @@ import org.matrix.android.sdk.api.session.identity.ThreePid
|
|||||||
import org.matrix.android.sdk.api.session.terms.TermsService
|
import org.matrix.android.sdk.api.session.terms.TermsService
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class DiscoverySettingsFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val controller: DiscoverySettingsController
|
class DiscoverySettingsFragment :
|
||||||
) : VectorBaseFragment<FragmentGenericRecyclerBinding>(),
|
VectorBaseFragment<FragmentGenericRecyclerBinding>(),
|
||||||
DiscoverySettingsController.Listener {
|
DiscoverySettingsController.Listener {
|
||||||
|
|
||||||
|
@Inject lateinit var controller: DiscoverySettingsController
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentGenericRecyclerBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentGenericRecyclerBinding {
|
||||||
return FragmentGenericRecyclerBinding.inflate(inflater, container, false)
|
return FragmentGenericRecyclerBinding.inflate(inflater, container, false)
|
||||||
}
|
}
|
||||||
|
@ -28,6 +28,7 @@ import androidx.lifecycle.lifecycleScope
|
|||||||
import com.airbnb.mvrx.fragmentViewModel
|
import com.airbnb.mvrx.fragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.registerStartForActivityResult
|
import im.vector.app.core.extensions.registerStartForActivityResult
|
||||||
import im.vector.app.core.extensions.toReducedUrl
|
import im.vector.app.core.extensions.toReducedUrl
|
||||||
@ -42,9 +43,11 @@ import org.matrix.android.sdk.api.session.terms.TermsService
|
|||||||
import reactivecircus.flowbinding.android.widget.textChanges
|
import reactivecircus.flowbinding.android.widget.textChanges
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class SetIdentityServerFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
val colorProvider: ColorProvider
|
class SetIdentityServerFragment :
|
||||||
) : VectorBaseFragment<FragmentSetIdentityServerBinding>() {
|
VectorBaseFragment<FragmentSetIdentityServerBinding>() {
|
||||||
|
|
||||||
|
@Inject lateinit var colorProvider: ColorProvider
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentSetIdentityServerBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentSetIdentityServerBinding {
|
||||||
return FragmentSetIdentityServerBinding.inflate(inflater, container, false)
|
return FragmentSetIdentityServerBinding.inflate(inflater, container, false)
|
||||||
|
@ -28,6 +28,7 @@ import com.airbnb.mvrx.activityViewModel
|
|||||||
import com.airbnb.mvrx.fragmentViewModel
|
import com.airbnb.mvrx.fragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
import com.google.android.material.badge.BadgeDrawable
|
import com.google.android.material.badge.BadgeDrawable
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.SpaceStateHandler
|
import im.vector.app.SpaceStateHandler
|
||||||
import im.vector.app.core.extensions.commitTransaction
|
import im.vector.app.core.extensions.commitTransaction
|
||||||
@ -60,19 +61,21 @@ import org.matrix.android.sdk.api.session.crypto.model.DeviceInfo
|
|||||||
import org.matrix.android.sdk.api.session.room.model.RoomSummary
|
import org.matrix.android.sdk.api.session.room.model.RoomSummary
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class HomeDetailFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val avatarRenderer: AvatarRenderer,
|
class HomeDetailFragment :
|
||||||
private val colorProvider: ColorProvider,
|
VectorBaseFragment<FragmentHomeDetailBinding>(),
|
||||||
private val alertManager: PopupAlertManager,
|
|
||||||
private val callManager: WebRtcCallManager,
|
|
||||||
private val vectorPreferences: VectorPreferences,
|
|
||||||
private val spaceStateHandler: SpaceStateHandler,
|
|
||||||
) : VectorBaseFragment<FragmentHomeDetailBinding>(),
|
|
||||||
KeysBackupBanner.Delegate,
|
KeysBackupBanner.Delegate,
|
||||||
CurrentCallsView.Callback,
|
CurrentCallsView.Callback,
|
||||||
OnBackPressed,
|
OnBackPressed,
|
||||||
VectorMenuProvider {
|
VectorMenuProvider {
|
||||||
|
|
||||||
|
@Inject lateinit var avatarRenderer: AvatarRenderer
|
||||||
|
@Inject lateinit var colorProvider: ColorProvider
|
||||||
|
@Inject lateinit var alertManager: PopupAlertManager
|
||||||
|
@Inject lateinit var callManager: WebRtcCallManager
|
||||||
|
@Inject lateinit var vectorPreferences: VectorPreferences
|
||||||
|
@Inject lateinit var spaceStateHandler: SpaceStateHandler
|
||||||
|
|
||||||
private val viewModel: HomeDetailViewModel by fragmentViewModel()
|
private val viewModel: HomeDetailViewModel by fragmentViewModel()
|
||||||
private val unknownDeviceDetectorSharedViewModel: UnknownDeviceDetectorSharedViewModel by activityViewModel()
|
private val unknownDeviceDetectorSharedViewModel: UnknownDeviceDetectorSharedViewModel by activityViewModel()
|
||||||
private val unreadMessagesSharedViewModel: UnreadMessagesSharedViewModel by activityViewModel()
|
private val unreadMessagesSharedViewModel: UnreadMessagesSharedViewModel by activityViewModel()
|
||||||
|
@ -23,6 +23,7 @@ import android.view.ViewGroup
|
|||||||
import androidx.core.app.ActivityOptionsCompat
|
import androidx.core.app.ActivityOptionsCompat
|
||||||
import androidx.core.view.ViewCompat
|
import androidx.core.view.ViewCompat
|
||||||
import androidx.core.view.isVisible
|
import androidx.core.view.isVisible
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.observeK
|
import im.vector.app.core.extensions.observeK
|
||||||
import im.vector.app.core.extensions.replaceChildFragment
|
import im.vector.app.core.extensions.replaceChildFragment
|
||||||
@ -40,12 +41,14 @@ import org.matrix.android.sdk.api.session.Session
|
|||||||
import org.matrix.android.sdk.api.util.toMatrixItem
|
import org.matrix.android.sdk.api.util.toMatrixItem
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class HomeDrawerFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val session: Session,
|
class HomeDrawerFragment :
|
||||||
private val vectorPreferences: VectorPreferences,
|
VectorBaseFragment<FragmentHomeDrawerBinding>() {
|
||||||
private val avatarRenderer: AvatarRenderer,
|
|
||||||
private val buildMeta: BuildMeta,
|
@Inject lateinit var session: Session
|
||||||
) : VectorBaseFragment<FragmentHomeDrawerBinding>() {
|
@Inject lateinit var vectorPreferences: VectorPreferences
|
||||||
|
@Inject lateinit var avatarRenderer: AvatarRenderer
|
||||||
|
@Inject lateinit var buildMeta: BuildMeta
|
||||||
|
|
||||||
private lateinit var sharedActionViewModel: HomeSharedActionViewModel
|
private lateinit var sharedActionViewModel: HomeSharedActionViewModel
|
||||||
|
|
||||||
|
@ -21,11 +21,12 @@ import android.os.Bundle
|
|||||||
import android.view.LayoutInflater
|
import android.view.LayoutInflater
|
||||||
import android.view.View
|
import android.view.View
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
import im.vector.app.databinding.FragmentLoadingBinding
|
import im.vector.app.databinding.FragmentLoadingBinding
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
class LoadingFragment @Inject constructor() : VectorBaseFragment<FragmentLoadingBinding>() {
|
@AndroidEntryPoint
|
||||||
|
class LoadingFragment : VectorBaseFragment<FragmentLoadingBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoadingBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoadingBinding {
|
||||||
return FragmentLoadingBinding.inflate(inflater, container, false)
|
return FragmentLoadingBinding.inflate(inflater, container, false)
|
||||||
|
@ -28,6 +28,7 @@ import com.airbnb.mvrx.activityViewModel
|
|||||||
import com.airbnb.mvrx.fragmentViewModel
|
import com.airbnb.mvrx.fragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
import com.google.android.material.badge.BadgeDrawable
|
import com.google.android.material.badge.BadgeDrawable
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.SpaceStateHandler
|
import im.vector.app.SpaceStateHandler
|
||||||
import im.vector.app.core.extensions.commitTransaction
|
import im.vector.app.core.extensions.commitTransaction
|
||||||
@ -60,20 +61,22 @@ import org.matrix.android.sdk.api.session.room.model.RoomSummary
|
|||||||
import org.matrix.android.sdk.api.util.toMatrixItem
|
import org.matrix.android.sdk.api.util.toMatrixItem
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class NewHomeDetailFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val avatarRenderer: AvatarRenderer,
|
class NewHomeDetailFragment :
|
||||||
private val colorProvider: ColorProvider,
|
VectorBaseFragment<FragmentNewHomeDetailBinding>(),
|
||||||
private val alertManager: PopupAlertManager,
|
|
||||||
private val callManager: WebRtcCallManager,
|
|
||||||
private val vectorPreferences: VectorPreferences,
|
|
||||||
private val spaceStateHandler: SpaceStateHandler,
|
|
||||||
private val session: Session,
|
|
||||||
) : VectorBaseFragment<FragmentNewHomeDetailBinding>(),
|
|
||||||
KeysBackupBanner.Delegate,
|
KeysBackupBanner.Delegate,
|
||||||
CurrentCallsView.Callback,
|
CurrentCallsView.Callback,
|
||||||
OnBackPressed,
|
OnBackPressed,
|
||||||
VectorMenuProvider {
|
VectorMenuProvider {
|
||||||
|
|
||||||
|
@Inject lateinit var avatarRenderer: AvatarRenderer
|
||||||
|
@Inject lateinit var colorProvider: ColorProvider
|
||||||
|
@Inject lateinit var alertManager: PopupAlertManager
|
||||||
|
@Inject lateinit var callManager: WebRtcCallManager
|
||||||
|
@Inject lateinit var vectorPreferences: VectorPreferences
|
||||||
|
@Inject lateinit var spaceStateHandler: SpaceStateHandler
|
||||||
|
@Inject lateinit var session: Session
|
||||||
|
|
||||||
private val viewModel: HomeDetailViewModel by fragmentViewModel()
|
private val viewModel: HomeDetailViewModel by fragmentViewModel()
|
||||||
private val unknownDeviceDetectorSharedViewModel: UnknownDeviceDetectorSharedViewModel by activityViewModel()
|
private val unknownDeviceDetectorSharedViewModel: UnknownDeviceDetectorSharedViewModel by activityViewModel()
|
||||||
private val unreadMessagesSharedViewModel: UnreadMessagesSharedViewModel by activityViewModel()
|
private val unreadMessagesSharedViewModel: UnreadMessagesSharedViewModel by activityViewModel()
|
||||||
|
@ -22,6 +22,7 @@ import android.view.View
|
|||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import com.airbnb.mvrx.fragmentViewModel
|
import com.airbnb.mvrx.fragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.core.extensions.cleanup
|
import im.vector.app.core.extensions.cleanup
|
||||||
import im.vector.app.core.extensions.configureWith
|
import im.vector.app.core.extensions.configureWith
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
@ -30,11 +31,13 @@ import im.vector.app.features.home.room.detail.RoomDetailSharedAction
|
|||||||
import im.vector.app.features.home.room.detail.RoomDetailSharedActionViewModel
|
import im.vector.app.features.home.room.detail.RoomDetailSharedActionViewModel
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class BreadcrumbsFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val breadcrumbsController: BreadcrumbsController
|
class BreadcrumbsFragment :
|
||||||
) : VectorBaseFragment<FragmentBreadcrumbsBinding>(),
|
VectorBaseFragment<FragmentBreadcrumbsBinding>(),
|
||||||
BreadcrumbsController.Listener {
|
BreadcrumbsController.Listener {
|
||||||
|
|
||||||
|
@Inject lateinit var breadcrumbsController: BreadcrumbsController
|
||||||
|
|
||||||
private lateinit var sharedActionViewModel: RoomDetailSharedActionViewModel
|
private lateinit var sharedActionViewModel: RoomDetailSharedActionViewModel
|
||||||
private val breadcrumbsViewModel: BreadcrumbsViewModel by fragmentViewModel()
|
private val breadcrumbsViewModel: BreadcrumbsViewModel by fragmentViewModel()
|
||||||
|
|
||||||
|
@ -67,10 +67,12 @@ import com.airbnb.mvrx.fragmentViewModel
|
|||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
||||||
import com.vanniktech.emoji.EmojiPopup
|
import com.vanniktech.emoji.EmojiPopup
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.animations.play
|
import im.vector.app.core.animations.play
|
||||||
import im.vector.app.core.dialogs.ConfirmationDialogBuilder
|
import im.vector.app.core.dialogs.ConfirmationDialogBuilder
|
||||||
import im.vector.app.core.dialogs.GalleryOrCameraDialogHelper
|
import im.vector.app.core.dialogs.GalleryOrCameraDialogHelper
|
||||||
|
import im.vector.app.core.dialogs.GalleryOrCameraDialogHelperFactory
|
||||||
import im.vector.app.core.epoxy.LayoutManagerStateRestorer
|
import im.vector.app.core.epoxy.LayoutManagerStateRestorer
|
||||||
import im.vector.app.core.error.fatalError
|
import im.vector.app.core.error.fatalError
|
||||||
import im.vector.app.core.extensions.cleanup
|
import im.vector.app.core.extensions.cleanup
|
||||||
@ -255,31 +257,8 @@ import java.net.URL
|
|||||||
import java.util.UUID
|
import java.util.UUID
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class TimelineFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val session: Session,
|
class TimelineFragment :
|
||||||
private val avatarRenderer: AvatarRenderer,
|
|
||||||
private val timelineEventController: TimelineEventController,
|
|
||||||
autoCompleterFactory: AutoCompleter.Factory,
|
|
||||||
private val permalinkHandler: PermalinkHandler,
|
|
||||||
private val notificationDrawerManager: NotificationDrawerManager,
|
|
||||||
private val eventHtmlRenderer: EventHtmlRenderer,
|
|
||||||
private val vectorPreferences: VectorPreferences,
|
|
||||||
private val threadsManager: ThreadsManager,
|
|
||||||
private val colorProvider: ColorProvider,
|
|
||||||
private val dimensionConverter: DimensionConverter,
|
|
||||||
private val userPreferencesProvider: UserPreferencesProvider,
|
|
||||||
private val notificationUtils: NotificationUtils,
|
|
||||||
private val matrixItemColorProvider: MatrixItemColorProvider,
|
|
||||||
private val imageContentRenderer: ImageContentRenderer,
|
|
||||||
private val roomDetailPendingActionStore: RoomDetailPendingActionStore,
|
|
||||||
private val pillsPostProcessorFactory: PillsPostProcessor.Factory,
|
|
||||||
private val callManager: WebRtcCallManager,
|
|
||||||
private val audioMessagePlaybackTracker: AudioMessagePlaybackTracker,
|
|
||||||
private val shareIntentHandler: ShareIntentHandler,
|
|
||||||
private val clock: Clock,
|
|
||||||
private val vectorFeatures: VectorFeatures,
|
|
||||||
private val buildMeta: BuildMeta,
|
|
||||||
) :
|
|
||||||
VectorBaseFragment<FragmentTimelineBinding>(),
|
VectorBaseFragment<FragmentTimelineBinding>(),
|
||||||
TimelineEventController.Callback,
|
TimelineEventController.Callback,
|
||||||
VectorInviteView.Callback,
|
VectorInviteView.Callback,
|
||||||
@ -289,6 +268,31 @@ class TimelineFragment @Inject constructor(
|
|||||||
CurrentCallsView.Callback,
|
CurrentCallsView.Callback,
|
||||||
VectorMenuProvider {
|
VectorMenuProvider {
|
||||||
|
|
||||||
|
@Inject lateinit var session: Session
|
||||||
|
@Inject lateinit var avatarRenderer: AvatarRenderer
|
||||||
|
@Inject lateinit var timelineEventController: TimelineEventController
|
||||||
|
@Inject lateinit var autoCompleterFactory: AutoCompleter.Factory
|
||||||
|
@Inject lateinit var permalinkHandler: PermalinkHandler
|
||||||
|
@Inject lateinit var notificationDrawerManager: NotificationDrawerManager
|
||||||
|
@Inject lateinit var eventHtmlRenderer: EventHtmlRenderer
|
||||||
|
@Inject lateinit var vectorPreferences: VectorPreferences
|
||||||
|
@Inject lateinit var threadsManager: ThreadsManager
|
||||||
|
@Inject lateinit var colorProvider: ColorProvider
|
||||||
|
@Inject lateinit var dimensionConverter: DimensionConverter
|
||||||
|
@Inject lateinit var userPreferencesProvider: UserPreferencesProvider
|
||||||
|
@Inject lateinit var notificationUtils: NotificationUtils
|
||||||
|
@Inject lateinit var matrixItemColorProvider: MatrixItemColorProvider
|
||||||
|
@Inject lateinit var imageContentRenderer: ImageContentRenderer
|
||||||
|
@Inject lateinit var roomDetailPendingActionStore: RoomDetailPendingActionStore
|
||||||
|
@Inject lateinit var pillsPostProcessorFactory: PillsPostProcessor.Factory
|
||||||
|
@Inject lateinit var callManager: WebRtcCallManager
|
||||||
|
@Inject lateinit var audioMessagePlaybackTracker: AudioMessagePlaybackTracker
|
||||||
|
@Inject lateinit var shareIntentHandler: ShareIntentHandler
|
||||||
|
@Inject lateinit var clock: Clock
|
||||||
|
@Inject lateinit var vectorFeatures: VectorFeatures
|
||||||
|
@Inject lateinit var buildMeta: BuildMeta
|
||||||
|
@Inject lateinit var galleryOrCameraDialogHelperFactory: GalleryOrCameraDialogHelperFactory
|
||||||
|
|
||||||
companion object {
|
companion object {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -309,7 +313,7 @@ class TimelineFragment @Inject constructor(
|
|||||||
private const val ircPattern = " (IRC)"
|
private const val ircPattern = " (IRC)"
|
||||||
}
|
}
|
||||||
|
|
||||||
private val galleryOrCameraDialogHelper = GalleryOrCameraDialogHelper(this, colorProvider, clock)
|
private lateinit var galleryOrCameraDialogHelper: GalleryOrCameraDialogHelper
|
||||||
|
|
||||||
private val timelineArgs: TimelineArgs by args()
|
private val timelineArgs: TimelineArgs by args()
|
||||||
private val glideRequests by lazy {
|
private val glideRequests by lazy {
|
||||||
@ -362,6 +366,7 @@ class TimelineFragment @Inject constructor(
|
|||||||
override fun onCreate(savedInstanceState: Bundle?) {
|
override fun onCreate(savedInstanceState: Bundle?) {
|
||||||
super.onCreate(savedInstanceState)
|
super.onCreate(savedInstanceState)
|
||||||
analyticsScreenName = MobileScreen.ScreenName.Room
|
analyticsScreenName = MobileScreen.ScreenName.Room
|
||||||
|
galleryOrCameraDialogHelper = galleryOrCameraDialogHelperFactory.create(this)
|
||||||
setFragmentResultListener(MigrateRoomBottomSheet.REQUEST_KEY) { _, bundle ->
|
setFragmentResultListener(MigrateRoomBottomSheet.REQUEST_KEY) { _, bundle ->
|
||||||
bundle.getString(MigrateRoomBottomSheet.BUNDLE_KEY_REPLACEMENT_ROOM)?.let { replacementRoomId ->
|
bundle.getString(MigrateRoomBottomSheet.BUNDLE_KEY_REPLACEMENT_ROOM)?.let { replacementRoomId ->
|
||||||
timelineViewModel.handle(RoomDetailAction.RoomUpgradeSuccess(replacementRoomId))
|
timelineViewModel.handle(RoomDetailAction.RoomUpgradeSuccess(replacementRoomId))
|
||||||
|
@ -29,6 +29,7 @@ import com.airbnb.mvrx.Success
|
|||||||
import com.airbnb.mvrx.args
|
import com.airbnb.mvrx.args
|
||||||
import com.airbnb.mvrx.fragmentViewModel
|
import com.airbnb.mvrx.fragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.cleanup
|
import im.vector.app.core.extensions.cleanup
|
||||||
import im.vector.app.core.extensions.configureWith
|
import im.vector.app.core.extensions.configureWith
|
||||||
@ -51,12 +52,13 @@ data class SearchArgs(
|
|||||||
val roomAvatarUrl: String?
|
val roomAvatarUrl: String?
|
||||||
) : Parcelable
|
) : Parcelable
|
||||||
|
|
||||||
class SearchFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val controller: SearchResultController
|
class SearchFragment :
|
||||||
) : VectorBaseFragment<FragmentSearchBinding>(),
|
VectorBaseFragment<FragmentSearchBinding>(),
|
||||||
StateView.EventCallback,
|
StateView.EventCallback,
|
||||||
SearchResultController.Listener {
|
SearchResultController.Listener {
|
||||||
|
|
||||||
|
@Inject lateinit var controller: SearchResultController
|
||||||
private val fragmentArgs: SearchArgs by args()
|
private val fragmentArgs: SearchArgs by args()
|
||||||
private val searchViewModel: SearchViewModel by fragmentViewModel()
|
private val searchViewModel: SearchViewModel by fragmentViewModel()
|
||||||
|
|
||||||
|
@ -35,6 +35,7 @@ import com.airbnb.mvrx.args
|
|||||||
import com.airbnb.mvrx.fragmentViewModel
|
import com.airbnb.mvrx.fragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.epoxy.LayoutManagerStateRestorer
|
import im.vector.app.core.epoxy.LayoutManagerStateRestorer
|
||||||
import im.vector.app.core.extensions.cleanup
|
import im.vector.app.core.extensions.cleanup
|
||||||
@ -70,17 +71,19 @@ data class RoomListParams(
|
|||||||
val displayMode: RoomListDisplayMode
|
val displayMode: RoomListDisplayMode
|
||||||
) : Parcelable
|
) : Parcelable
|
||||||
|
|
||||||
class RoomListFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val pagedControllerFactory: RoomSummaryPagedControllerFactory,
|
class RoomListFragment :
|
||||||
private val notificationDrawerManager: NotificationDrawerManager,
|
VectorBaseFragment<FragmentRoomListBinding>(),
|
||||||
private val footerController: RoomListFooterController,
|
|
||||||
private val userPreferencesProvider: UserPreferencesProvider
|
|
||||||
) : VectorBaseFragment<FragmentRoomListBinding>(),
|
|
||||||
RoomListListener,
|
RoomListListener,
|
||||||
OnBackPressed,
|
OnBackPressed,
|
||||||
FilteredRoomFooterItem.Listener,
|
FilteredRoomFooterItem.Listener,
|
||||||
NotifsFabMenuView.Listener {
|
NotifsFabMenuView.Listener {
|
||||||
|
|
||||||
|
@Inject lateinit var pagedControllerFactory: RoomSummaryPagedControllerFactory
|
||||||
|
@Inject lateinit var notificationDrawerManager: NotificationDrawerManager
|
||||||
|
@Inject lateinit var footerController: RoomListFooterController
|
||||||
|
@Inject lateinit var userPreferencesProvider: UserPreferencesProvider
|
||||||
|
|
||||||
private var modelBuildListener: OnModelBuildFinishedListener? = null
|
private var modelBuildListener: OnModelBuildFinishedListener? = null
|
||||||
private lateinit var sharedActionViewModel: RoomListQuickActionsSharedActionViewModel
|
private lateinit var sharedActionViewModel: RoomListQuickActionsSharedActionViewModel
|
||||||
private val roomListParams: RoomListParams by args()
|
private val roomListParams: RoomListParams by args()
|
||||||
|
@ -29,6 +29,7 @@ import com.airbnb.epoxy.OnModelBuildFinishedListener
|
|||||||
import com.airbnb.mvrx.fragmentViewModel
|
import com.airbnb.mvrx.fragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.epoxy.LayoutManagerStateRestorer
|
import im.vector.app.core.epoxy.LayoutManagerStateRestorer
|
||||||
import im.vector.app.core.extensions.cleanup
|
import im.vector.app.core.extensions.cleanup
|
||||||
@ -57,13 +58,15 @@ import org.matrix.android.sdk.api.session.room.model.tag.RoomTag
|
|||||||
import org.matrix.android.sdk.api.session.room.notification.RoomNotificationState
|
import org.matrix.android.sdk.api.session.room.notification.RoomNotificationState
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class HomeRoomListFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val roomSummaryItemFactory: RoomSummaryItemFactory,
|
class HomeRoomListFragment :
|
||||||
private val userPreferencesProvider: UserPreferencesProvider,
|
VectorBaseFragment<FragmentRoomListBinding>(),
|
||||||
private val recentRoomCarouselController: RecentRoomCarouselController
|
|
||||||
) : VectorBaseFragment<FragmentRoomListBinding>(),
|
|
||||||
RoomListListener {
|
RoomListListener {
|
||||||
|
|
||||||
|
@Inject lateinit var roomSummaryItemFactory: RoomSummaryItemFactory
|
||||||
|
@Inject lateinit var userPreferencesProvider: UserPreferencesProvider
|
||||||
|
@Inject lateinit var recentRoomCarouselController: RecentRoomCarouselController
|
||||||
|
|
||||||
private val roomListViewModel: HomeRoomListViewModel by fragmentViewModel()
|
private val roomListViewModel: HomeRoomListViewModel by fragmentViewModel()
|
||||||
private lateinit var sharedQuickActionsViewModel: RoomListQuickActionsSharedActionViewModel
|
private lateinit var sharedQuickActionsViewModel: RoomListQuickActionsSharedActionViewModel
|
||||||
private lateinit var sharedActionViewModel: RoomListSharedActionViewModel
|
private lateinit var sharedActionViewModel: RoomListSharedActionViewModel
|
||||||
|
@ -26,6 +26,7 @@ import androidx.core.view.isVisible
|
|||||||
import com.airbnb.mvrx.args
|
import com.airbnb.mvrx.args
|
||||||
import com.airbnb.mvrx.fragmentViewModel
|
import com.airbnb.mvrx.fragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.cleanup
|
import im.vector.app.core.extensions.cleanup
|
||||||
import im.vector.app.core.extensions.configureWith
|
import im.vector.app.core.extensions.configureWith
|
||||||
@ -48,15 +49,17 @@ import org.matrix.android.sdk.api.session.room.timeline.TimelineEvent
|
|||||||
import org.matrix.android.sdk.api.util.MatrixItem
|
import org.matrix.android.sdk.api.util.MatrixItem
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class ThreadListFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val avatarRenderer: AvatarRenderer,
|
class ThreadListFragment :
|
||||||
private val bugReporter: BugReporter,
|
VectorBaseFragment<FragmentThreadListBinding>(),
|
||||||
private val threadListController: ThreadListController,
|
|
||||||
val threadListViewModelFactory: ThreadListViewModel.Factory
|
|
||||||
) : VectorBaseFragment<FragmentThreadListBinding>(),
|
|
||||||
ThreadListController.Listener,
|
ThreadListController.Listener,
|
||||||
VectorMenuProvider {
|
VectorMenuProvider {
|
||||||
|
|
||||||
|
@Inject lateinit var avatarRenderer: AvatarRenderer
|
||||||
|
@Inject lateinit var bugReporter: BugReporter
|
||||||
|
@Inject lateinit var threadListController: ThreadListController
|
||||||
|
@Inject lateinit var threadListViewModelFactory: ThreadListViewModel.Factory
|
||||||
|
|
||||||
private val threadListViewModel: ThreadListViewModel by fragmentViewModel()
|
private val threadListViewModel: ThreadListViewModel by fragmentViewModel()
|
||||||
|
|
||||||
private val threadListArgs: ThreadListArgs by args()
|
private val threadListArgs: ThreadListArgs by args()
|
||||||
|
@ -31,6 +31,7 @@ import com.airbnb.mvrx.fragmentViewModel
|
|||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
||||||
import com.mapbox.mapboxsdk.maps.MapView
|
import com.mapbox.mapboxsdk.maps.MapView
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.platform.VectorBaseBottomSheetDialogFragment
|
import im.vector.app.core.platform.VectorBaseBottomSheetDialogFragment
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
@ -53,15 +54,17 @@ import javax.inject.Inject
|
|||||||
/**
|
/**
|
||||||
* We should consider using SupportMapFragment for a out of the box lifecycle handling.
|
* We should consider using SupportMapFragment for a out of the box lifecycle handling.
|
||||||
*/
|
*/
|
||||||
class LocationSharingFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val urlMapProvider: UrlMapProvider,
|
class LocationSharingFragment :
|
||||||
private val avatarRenderer: AvatarRenderer,
|
VectorBaseFragment<FragmentLocationSharingBinding>(),
|
||||||
private val matrixItemColorProvider: MatrixItemColorProvider,
|
|
||||||
private val vectorPreferences: VectorPreferences,
|
|
||||||
) : VectorBaseFragment<FragmentLocationSharingBinding>(),
|
|
||||||
LocationTargetChangeListener,
|
LocationTargetChangeListener,
|
||||||
VectorBaseBottomSheetDialogFragment.ResultListener {
|
VectorBaseBottomSheetDialogFragment.ResultListener {
|
||||||
|
|
||||||
|
@Inject lateinit var urlMapProvider: UrlMapProvider
|
||||||
|
@Inject lateinit var avatarRenderer: AvatarRenderer
|
||||||
|
@Inject lateinit var matrixItemColorProvider: MatrixItemColorProvider
|
||||||
|
@Inject lateinit var vectorPreferences: VectorPreferences
|
||||||
|
|
||||||
private val viewModel: LocationSharingViewModel by fragmentViewModel()
|
private val viewModel: LocationSharingViewModel by fragmentViewModel()
|
||||||
|
|
||||||
private val locationSharingNavigator: LocationSharingNavigator by lazy { DefaultLocationSharingNavigator(activity) }
|
private val locationSharingNavigator: LocationSharingNavigator by lazy { DefaultLocationSharingNavigator(activity) }
|
||||||
|
@ -62,7 +62,8 @@ import javax.inject.Inject
|
|||||||
* Screen showing a map with all the current users sharing their live location in a room.
|
* Screen showing a map with all the current users sharing their live location in a room.
|
||||||
*/
|
*/
|
||||||
@AndroidEntryPoint
|
@AndroidEntryPoint
|
||||||
class LiveLocationMapViewFragment @Inject constructor() : VectorBaseFragment<FragmentLiveLocationMapViewBinding>() {
|
class LiveLocationMapViewFragment :
|
||||||
|
VectorBaseFragment<FragmentLiveLocationMapViewBinding>() {
|
||||||
|
|
||||||
@Inject lateinit var urlMapProvider: UrlMapProvider
|
@Inject lateinit var urlMapProvider: UrlMapProvider
|
||||||
@Inject lateinit var bottomSheetController: LiveLocationBottomSheetController
|
@Inject lateinit var bottomSheetController: LiveLocationBottomSheetController
|
||||||
|
@ -27,6 +27,7 @@ import com.airbnb.mvrx.args
|
|||||||
import com.airbnb.mvrx.fragmentViewModel
|
import com.airbnb.mvrx.fragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
import com.mapbox.mapboxsdk.maps.MapView
|
import com.mapbox.mapboxsdk.maps.MapView
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
import im.vector.app.core.platform.VectorMenuProvider
|
import im.vector.app.core.platform.VectorMenuProvider
|
||||||
@ -43,12 +44,14 @@ import javax.inject.Inject
|
|||||||
/*
|
/*
|
||||||
* TODO Move locationPinProvider to a ViewModel
|
* TODO Move locationPinProvider to a ViewModel
|
||||||
*/
|
*/
|
||||||
class LocationPreviewFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val urlMapProvider: UrlMapProvider,
|
class LocationPreviewFragment :
|
||||||
private val locationPinProvider: LocationPinProvider
|
VectorBaseFragment<FragmentLocationPreviewBinding>(),
|
||||||
) : VectorBaseFragment<FragmentLocationPreviewBinding>(),
|
|
||||||
VectorMenuProvider {
|
VectorMenuProvider {
|
||||||
|
|
||||||
|
@Inject lateinit var urlMapProvider: UrlMapProvider
|
||||||
|
@Inject lateinit var locationPinProvider: LocationPinProvider
|
||||||
|
|
||||||
private val args: LocationSharingArgs by args()
|
private val args: LocationSharingArgs by args()
|
||||||
|
|
||||||
private val viewModel: LocationPreviewViewModel by fragmentViewModel()
|
private val viewModel: LocationPreviewViewModel by fragmentViewModel()
|
||||||
|
@ -33,6 +33,7 @@ import android.webkit.WebViewClient
|
|||||||
import androidx.core.view.isVisible
|
import androidx.core.view.isVisible
|
||||||
import com.airbnb.mvrx.args
|
import com.airbnb.mvrx.args
|
||||||
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.utils.AssetReader
|
import im.vector.app.core.utils.AssetReader
|
||||||
import im.vector.app.databinding.FragmentLoginCaptchaBinding
|
import im.vector.app.databinding.FragmentLoginCaptchaBinding
|
||||||
@ -51,9 +52,11 @@ data class LoginCaptchaFragmentArgument(
|
|||||||
/**
|
/**
|
||||||
* In this screen, the user is asked to confirm he is not a robot.
|
* In this screen, the user is asked to confirm he is not a robot.
|
||||||
*/
|
*/
|
||||||
class LoginCaptchaFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val assetReader: AssetReader
|
class LoginCaptchaFragment :
|
||||||
) : AbstractLoginFragment<FragmentLoginCaptchaBinding>() {
|
AbstractLoginFragment<FragmentLoginCaptchaBinding>() {
|
||||||
|
|
||||||
|
@Inject lateinit var assetReader: AssetReader
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoginCaptchaBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoginCaptchaBinding {
|
||||||
return FragmentLoginCaptchaBinding.inflate(inflater, container, false)
|
return FragmentLoginCaptchaBinding.inflate(inflater, container, false)
|
||||||
|
@ -28,6 +28,7 @@ import androidx.core.view.isVisible
|
|||||||
import androidx.lifecycle.lifecycleScope
|
import androidx.lifecycle.lifecycleScope
|
||||||
import com.airbnb.mvrx.Fail
|
import com.airbnb.mvrx.Fail
|
||||||
import com.airbnb.mvrx.Loading
|
import com.airbnb.mvrx.Loading
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.hideKeyboard
|
import im.vector.app.core.extensions.hideKeyboard
|
||||||
import im.vector.app.core.extensions.hidePassword
|
import im.vector.app.core.extensions.hidePassword
|
||||||
@ -41,7 +42,6 @@ import org.matrix.android.sdk.api.failure.Failure
|
|||||||
import org.matrix.android.sdk.api.failure.MatrixError
|
import org.matrix.android.sdk.api.failure.MatrixError
|
||||||
import org.matrix.android.sdk.api.failure.isInvalidPassword
|
import org.matrix.android.sdk.api.failure.isInvalidPassword
|
||||||
import reactivecircus.flowbinding.android.widget.textChanges
|
import reactivecircus.flowbinding.android.widget.textChanges
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* In this screen:
|
* In this screen:
|
||||||
@ -51,7 +51,9 @@ import javax.inject.Inject
|
|||||||
* In signup mode:
|
* In signup mode:
|
||||||
* - the user is asked for login and password
|
* - the user is asked for login and password
|
||||||
*/
|
*/
|
||||||
class LoginFragment @Inject constructor() : AbstractSSOLoginFragment<FragmentLoginBinding>() {
|
@AndroidEntryPoint
|
||||||
|
class LoginFragment :
|
||||||
|
AbstractSSOLoginFragment<FragmentLoginBinding>() {
|
||||||
|
|
||||||
private var isSignupMode = false
|
private var isSignupMode = false
|
||||||
|
|
||||||
|
@ -29,6 +29,7 @@ import androidx.lifecycle.lifecycleScope
|
|||||||
import com.airbnb.mvrx.args
|
import com.airbnb.mvrx.args
|
||||||
import com.google.i18n.phonenumbers.NumberParseException
|
import com.google.i18n.phonenumbers.NumberParseException
|
||||||
import com.google.i18n.phonenumbers.PhoneNumberUtil
|
import com.google.i18n.phonenumbers.PhoneNumberUtil
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.hideKeyboard
|
import im.vector.app.core.extensions.hideKeyboard
|
||||||
import im.vector.app.core.extensions.isEmail
|
import im.vector.app.core.extensions.isEmail
|
||||||
@ -41,7 +42,6 @@ import org.matrix.android.sdk.api.auth.registration.RegisterThreePid
|
|||||||
import org.matrix.android.sdk.api.failure.Failure
|
import org.matrix.android.sdk.api.failure.Failure
|
||||||
import org.matrix.android.sdk.api.failure.is401
|
import org.matrix.android.sdk.api.failure.is401
|
||||||
import reactivecircus.flowbinding.android.widget.textChanges
|
import reactivecircus.flowbinding.android.widget.textChanges
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
enum class TextInputFormFragmentMode {
|
enum class TextInputFormFragmentMode {
|
||||||
SetEmail,
|
SetEmail,
|
||||||
@ -59,7 +59,9 @@ data class LoginGenericTextInputFormFragmentArgument(
|
|||||||
/**
|
/**
|
||||||
* In this screen, the user is asked for a text input.
|
* In this screen, the user is asked for a text input.
|
||||||
*/
|
*/
|
||||||
class LoginGenericTextInputFormFragment @Inject constructor() : AbstractLoginFragment<FragmentLoginGenericTextInputFormBinding>() {
|
@AndroidEntryPoint
|
||||||
|
class LoginGenericTextInputFormFragment :
|
||||||
|
AbstractLoginFragment<FragmentLoginGenericTextInputFormBinding>() {
|
||||||
|
|
||||||
private val params: LoginGenericTextInputFormFragmentArgument by args()
|
private val params: LoginGenericTextInputFormFragmentArgument by args()
|
||||||
|
|
||||||
|
@ -24,6 +24,7 @@ import androidx.lifecycle.lifecycleScope
|
|||||||
import com.airbnb.mvrx.Fail
|
import com.airbnb.mvrx.Fail
|
||||||
import com.airbnb.mvrx.Loading
|
import com.airbnb.mvrx.Loading
|
||||||
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.hideKeyboard
|
import im.vector.app.core.extensions.hideKeyboard
|
||||||
import im.vector.app.core.extensions.hidePassword
|
import im.vector.app.core.extensions.hidePassword
|
||||||
@ -36,12 +37,13 @@ import kotlinx.coroutines.flow.launchIn
|
|||||||
import kotlinx.coroutines.flow.map
|
import kotlinx.coroutines.flow.map
|
||||||
import kotlinx.coroutines.flow.onEach
|
import kotlinx.coroutines.flow.onEach
|
||||||
import reactivecircus.flowbinding.android.widget.textChanges
|
import reactivecircus.flowbinding.android.widget.textChanges
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* In this screen, the user is asked for email and new password to reset his password.
|
* In this screen, the user is asked for email and new password to reset his password.
|
||||||
*/
|
*/
|
||||||
class LoginResetPasswordFragment @Inject constructor() : AbstractLoginFragment<FragmentLoginResetPasswordBinding>() {
|
@AndroidEntryPoint
|
||||||
|
class LoginResetPasswordFragment :
|
||||||
|
AbstractLoginFragment<FragmentLoginResetPasswordBinding>() {
|
||||||
|
|
||||||
// Show warning only once
|
// Show warning only once
|
||||||
private var showWarning = true
|
private var showWarning = true
|
||||||
|
@ -22,15 +22,17 @@ import android.view.View
|
|||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import com.airbnb.mvrx.Fail
|
import com.airbnb.mvrx.Fail
|
||||||
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.databinding.FragmentLoginResetPasswordMailConfirmationBinding
|
import im.vector.app.databinding.FragmentLoginResetPasswordMailConfirmationBinding
|
||||||
import org.matrix.android.sdk.api.failure.is401
|
import org.matrix.android.sdk.api.failure.is401
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* In this screen, the user is asked to check their email and to click on a button once it's done.
|
* In this screen, the user is asked to check their email and to click on a button once it's done.
|
||||||
*/
|
*/
|
||||||
class LoginResetPasswordMailConfirmationFragment @Inject constructor() : AbstractLoginFragment<FragmentLoginResetPasswordMailConfirmationBinding>() {
|
@AndroidEntryPoint
|
||||||
|
class LoginResetPasswordMailConfirmationFragment :
|
||||||
|
AbstractLoginFragment<FragmentLoginResetPasswordMailConfirmationBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoginResetPasswordMailConfirmationBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoginResetPasswordMailConfirmationBinding {
|
||||||
return FragmentLoginResetPasswordMailConfirmationBinding.inflate(inflater, container, false)
|
return FragmentLoginResetPasswordMailConfirmationBinding.inflate(inflater, container, false)
|
||||||
|
@ -20,13 +20,15 @@ import android.os.Bundle
|
|||||||
import android.view.LayoutInflater
|
import android.view.LayoutInflater
|
||||||
import android.view.View
|
import android.view.View
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.databinding.FragmentLoginResetPasswordSuccessBinding
|
import im.vector.app.databinding.FragmentLoginResetPasswordSuccessBinding
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* In this screen, we confirm to the user that his password has been reset.
|
* In this screen, we confirm to the user that his password has been reset.
|
||||||
*/
|
*/
|
||||||
class LoginResetPasswordSuccessFragment @Inject constructor() : AbstractLoginFragment<FragmentLoginResetPasswordSuccessBinding>() {
|
@AndroidEntryPoint
|
||||||
|
class LoginResetPasswordSuccessFragment :
|
||||||
|
AbstractLoginFragment<FragmentLoginResetPasswordSuccessBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoginResetPasswordSuccessBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoginResetPasswordSuccessBinding {
|
||||||
return FragmentLoginResetPasswordSuccessBinding.inflate(inflater, container, false)
|
return FragmentLoginResetPasswordSuccessBinding.inflate(inflater, container, false)
|
||||||
|
@ -20,16 +20,18 @@ import android.os.Bundle
|
|||||||
import android.view.LayoutInflater
|
import android.view.LayoutInflater
|
||||||
import android.view.View
|
import android.view.View
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.utils.openUrlInChromeCustomTab
|
import im.vector.app.core.utils.openUrlInChromeCustomTab
|
||||||
import im.vector.app.databinding.FragmentLoginServerSelectionBinding
|
import im.vector.app.databinding.FragmentLoginServerSelectionBinding
|
||||||
import me.gujun.android.span.span
|
import me.gujun.android.span.span
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* In this screen, the user will choose between matrix.org, modular or other type of homeserver.
|
* In this screen, the user will choose between matrix.org, modular or other type of homeserver.
|
||||||
*/
|
*/
|
||||||
class LoginServerSelectionFragment @Inject constructor() : AbstractLoginFragment<FragmentLoginServerSelectionBinding>() {
|
@AndroidEntryPoint
|
||||||
|
class LoginServerSelectionFragment :
|
||||||
|
AbstractLoginFragment<FragmentLoginServerSelectionBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoginServerSelectionBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoginServerSelectionBinding {
|
||||||
return FragmentLoginServerSelectionBinding.inflate(inflater, container, false)
|
return FragmentLoginServerSelectionBinding.inflate(inflater, container, false)
|
||||||
|
@ -27,6 +27,7 @@ import androidx.core.view.isInvisible
|
|||||||
import androidx.core.view.isVisible
|
import androidx.core.view.isVisible
|
||||||
import androidx.lifecycle.lifecycleScope
|
import androidx.lifecycle.lifecycleScope
|
||||||
import com.google.android.material.textfield.TextInputLayout
|
import com.google.android.material.textfield.TextInputLayout
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.hideKeyboard
|
import im.vector.app.core.extensions.hideKeyboard
|
||||||
import im.vector.app.core.resources.BuildMeta
|
import im.vector.app.core.resources.BuildMeta
|
||||||
@ -43,9 +44,11 @@ import javax.inject.Inject
|
|||||||
/**
|
/**
|
||||||
* In this screen, the user is prompted to enter a homeserver url.
|
* In this screen, the user is prompted to enter a homeserver url.
|
||||||
*/
|
*/
|
||||||
class LoginServerUrlFormFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val buildMeta: BuildMeta,
|
class LoginServerUrlFormFragment :
|
||||||
) : AbstractLoginFragment<FragmentLoginServerUrlFormBinding>() {
|
AbstractLoginFragment<FragmentLoginServerUrlFormBinding>() {
|
||||||
|
|
||||||
|
@Inject lateinit var buildMeta: BuildMeta
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoginServerUrlFormBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoginServerUrlFormBinding {
|
||||||
return FragmentLoginServerUrlFormBinding.inflate(inflater, container, false)
|
return FragmentLoginServerUrlFormBinding.inflate(inflater, container, false)
|
||||||
|
@ -22,16 +22,18 @@ import android.view.View
|
|||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import androidx.core.view.isVisible
|
import androidx.core.view.isVisible
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.toReducedUrl
|
import im.vector.app.core.extensions.toReducedUrl
|
||||||
import im.vector.app.databinding.FragmentLoginSignupSigninSelectionBinding
|
import im.vector.app.databinding.FragmentLoginSignupSigninSelectionBinding
|
||||||
import im.vector.app.features.login.SocialLoginButtonsView.Mode
|
import im.vector.app.features.login.SocialLoginButtonsView.Mode
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* In this screen, the user is asked to sign up or to sign in to the homeserver.
|
* In this screen, the user is asked to sign up or to sign in to the homeserver.
|
||||||
*/
|
*/
|
||||||
class LoginSignUpSignInSelectionFragment @Inject constructor() : AbstractSSOLoginFragment<FragmentLoginSignupSigninSelectionBinding>() {
|
@AndroidEntryPoint
|
||||||
|
class LoginSignUpSignInSelectionFragment :
|
||||||
|
AbstractSSOLoginFragment<FragmentLoginSignupSigninSelectionBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoginSignupSigninSelectionBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoginSignupSigninSelectionBinding {
|
||||||
return FragmentLoginSignupSigninSelectionBinding.inflate(inflater, container, false)
|
return FragmentLoginSignupSigninSelectionBinding.inflate(inflater, container, false)
|
||||||
|
@ -23,6 +23,7 @@ import android.view.View
|
|||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import androidx.core.view.isVisible
|
import androidx.core.view.isVisible
|
||||||
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.resources.BuildMeta
|
import im.vector.app.core.resources.BuildMeta
|
||||||
import im.vector.app.databinding.FragmentLoginSplashBinding
|
import im.vector.app.databinding.FragmentLoginSplashBinding
|
||||||
@ -35,10 +36,12 @@ import javax.inject.Inject
|
|||||||
/**
|
/**
|
||||||
* In this screen, the user is viewing an introduction to what he can do with this application.
|
* In this screen, the user is viewing an introduction to what he can do with this application.
|
||||||
*/
|
*/
|
||||||
class LoginSplashFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val vectorPreferences: VectorPreferences,
|
class LoginSplashFragment :
|
||||||
private val buildMeta: BuildMeta,
|
AbstractLoginFragment<FragmentLoginSplashBinding>() {
|
||||||
) : AbstractLoginFragment<FragmentLoginSplashBinding>() {
|
|
||||||
|
@Inject lateinit var vectorPreferences: VectorPreferences
|
||||||
|
@Inject lateinit var buildMeta: BuildMeta
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoginSplashBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoginSplashBinding {
|
||||||
return FragmentLoginSplashBinding.inflate(inflater, container, false)
|
return FragmentLoginSplashBinding.inflate(inflater, container, false)
|
||||||
|
@ -22,11 +22,11 @@ import android.view.LayoutInflater
|
|||||||
import android.view.View
|
import android.view.View
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import com.airbnb.mvrx.args
|
import com.airbnb.mvrx.args
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.databinding.FragmentLoginWaitForEmailBinding
|
import im.vector.app.databinding.FragmentLoginWaitForEmailBinding
|
||||||
import kotlinx.parcelize.Parcelize
|
import kotlinx.parcelize.Parcelize
|
||||||
import org.matrix.android.sdk.api.failure.is401
|
import org.matrix.android.sdk.api.failure.is401
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
@Parcelize
|
@Parcelize
|
||||||
data class LoginWaitForEmailFragmentArgument(
|
data class LoginWaitForEmailFragmentArgument(
|
||||||
@ -36,7 +36,9 @@ data class LoginWaitForEmailFragmentArgument(
|
|||||||
/**
|
/**
|
||||||
* In this screen, the user is asked to check their emails.
|
* In this screen, the user is asked to check their emails.
|
||||||
*/
|
*/
|
||||||
class LoginWaitForEmailFragment @Inject constructor() : AbstractLoginFragment<FragmentLoginWaitForEmailBinding>() {
|
@AndroidEntryPoint
|
||||||
|
class LoginWaitForEmailFragment :
|
||||||
|
AbstractLoginFragment<FragmentLoginWaitForEmailBinding>() {
|
||||||
|
|
||||||
private val params: LoginWaitForEmailFragmentArgument by args()
|
private val params: LoginWaitForEmailFragmentArgument by args()
|
||||||
|
|
||||||
|
@ -32,6 +32,7 @@ import android.webkit.WebView
|
|||||||
import android.webkit.WebViewClient
|
import android.webkit.WebViewClient
|
||||||
import com.airbnb.mvrx.activityViewModel
|
import com.airbnb.mvrx.activityViewModel
|
||||||
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.utils.AssetReader
|
import im.vector.app.core.utils.AssetReader
|
||||||
import im.vector.app.databinding.FragmentLoginWebBinding
|
import im.vector.app.databinding.FragmentLoginWebBinding
|
||||||
@ -47,9 +48,11 @@ import javax.inject.Inject
|
|||||||
* This screen is displayed when the application does not support login flow or registration flow
|
* This screen is displayed when the application does not support login flow or registration flow
|
||||||
* of the homeserver, as a fallback to login or to create an account.
|
* of the homeserver, as a fallback to login or to create an account.
|
||||||
*/
|
*/
|
||||||
class LoginWebFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val assetReader: AssetReader
|
class LoginWebFragment :
|
||||||
) : AbstractLoginFragment<FragmentLoginWebBinding>() {
|
AbstractLoginFragment<FragmentLoginWebBinding>() {
|
||||||
|
|
||||||
|
@Inject lateinit var assetReader: AssetReader
|
||||||
|
|
||||||
private val softLogoutViewModel: SoftLogoutViewModel by activityViewModel()
|
private val softLogoutViewModel: SoftLogoutViewModel by activityViewModel()
|
||||||
|
|
||||||
|
@ -42,11 +42,12 @@ data class LoginTermsFragmentArgument(
|
|||||||
/**
|
/**
|
||||||
* LoginTermsFragment displays the list of policies the user has to accept.
|
* LoginTermsFragment displays the list of policies the user has to accept.
|
||||||
*/
|
*/
|
||||||
class LoginTermsFragment @Inject constructor(
|
class LoginTermsFragment :
|
||||||
private val policyController: PolicyController
|
AbstractLoginFragment<FragmentLoginTermsBinding>(),
|
||||||
) : AbstractLoginFragment<FragmentLoginTermsBinding>(),
|
|
||||||
PolicyController.PolicyControllerListener {
|
PolicyController.PolicyControllerListener {
|
||||||
|
|
||||||
|
@Inject lateinit var policyController: PolicyController
|
||||||
|
|
||||||
private val params: LoginTermsFragmentArgument by args()
|
private val params: LoginTermsFragmentArgument by args()
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoginTermsBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoginTermsBinding {
|
||||||
|
@ -28,6 +28,7 @@ import com.airbnb.mvrx.Success
|
|||||||
import com.airbnb.mvrx.Uninitialized
|
import com.airbnb.mvrx.Uninitialized
|
||||||
import com.airbnb.mvrx.parentFragmentViewModel
|
import com.airbnb.mvrx.parentFragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.setTextOrHide
|
import im.vector.app.core.extensions.setTextOrHide
|
||||||
import im.vector.app.core.platform.ButtonStateView
|
import im.vector.app.core.platform.ButtonStateView
|
||||||
@ -38,10 +39,12 @@ import org.matrix.android.sdk.api.session.room.model.Membership
|
|||||||
import org.matrix.android.sdk.api.session.room.model.RoomType
|
import org.matrix.android.sdk.api.session.room.model.RoomType
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class MatrixToRoomSpaceFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val avatarRenderer: AvatarRenderer,
|
class MatrixToRoomSpaceFragment :
|
||||||
private val spaceCardRenderer: SpaceCardRenderer
|
VectorBaseFragment<FragmentMatrixToRoomSpaceCardBinding>() {
|
||||||
) : VectorBaseFragment<FragmentMatrixToRoomSpaceCardBinding>() {
|
|
||||||
|
@Inject lateinit var avatarRenderer: AvatarRenderer
|
||||||
|
@Inject lateinit var spaceCardRenderer: SpaceCardRenderer
|
||||||
|
|
||||||
private val sharedViewModel: MatrixToBottomSheetViewModel by parentFragmentViewModel()
|
private val sharedViewModel: MatrixToBottomSheetViewModel by parentFragmentViewModel()
|
||||||
|
|
||||||
|
@ -28,15 +28,18 @@ import com.airbnb.mvrx.Success
|
|||||||
import com.airbnb.mvrx.Uninitialized
|
import com.airbnb.mvrx.Uninitialized
|
||||||
import com.airbnb.mvrx.parentFragmentViewModel
|
import com.airbnb.mvrx.parentFragmentViewModel
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.core.extensions.setTextOrHide
|
import im.vector.app.core.extensions.setTextOrHide
|
||||||
import im.vector.app.core.platform.VectorBaseFragment
|
import im.vector.app.core.platform.VectorBaseFragment
|
||||||
import im.vector.app.databinding.FragmentMatrixToUserCardBinding
|
import im.vector.app.databinding.FragmentMatrixToUserCardBinding
|
||||||
import im.vector.app.features.home.AvatarRenderer
|
import im.vector.app.features.home.AvatarRenderer
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class MatrixToUserFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val avatarRenderer: AvatarRenderer
|
class MatrixToUserFragment :
|
||||||
) : VectorBaseFragment<FragmentMatrixToUserCardBinding>() {
|
VectorBaseFragment<FragmentMatrixToUserCardBinding>() {
|
||||||
|
|
||||||
|
@Inject lateinit var avatarRenderer: AvatarRenderer
|
||||||
|
|
||||||
private val sharedViewModel: MatrixToBottomSheetViewModel by parentFragmentViewModel()
|
private val sharedViewModel: MatrixToBottomSheetViewModel by parentFragmentViewModel()
|
||||||
|
|
||||||
|
@ -23,6 +23,7 @@ import android.view.View
|
|||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import androidx.core.text.toSpannable
|
import androidx.core.text.toSpannable
|
||||||
import androidx.core.view.isVisible
|
import androidx.core.view.isVisible
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.animations.play
|
import im.vector.app.core.animations.play
|
||||||
import im.vector.app.core.di.ActiveSessionHolder
|
import im.vector.app.core.di.ActiveSessionHolder
|
||||||
@ -34,9 +35,11 @@ import im.vector.app.features.onboarding.OnboardingViewEvents
|
|||||||
import im.vector.app.features.onboarding.OnboardingViewState
|
import im.vector.app.features.onboarding.OnboardingViewState
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class FtueAuthAccountCreatedFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val activeSessionHolder: ActiveSessionHolder
|
class FtueAuthAccountCreatedFragment :
|
||||||
) : AbstractFtueAuthFragment<FragmentFtueAccountCreatedBinding>() {
|
AbstractFtueAuthFragment<FragmentFtueAccountCreatedBinding>() {
|
||||||
|
|
||||||
|
@Inject lateinit var activeSessionHolder: ActiveSessionHolder
|
||||||
|
|
||||||
private var hasPlayedConfetti = false
|
private var hasPlayedConfetti = false
|
||||||
|
|
||||||
|
@ -24,6 +24,7 @@ import android.view.ViewGroup
|
|||||||
import android.view.ViewStub
|
import android.view.ViewStub
|
||||||
import com.airbnb.mvrx.args
|
import com.airbnb.mvrx.args
|
||||||
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.crawlCausesFor
|
import im.vector.app.core.extensions.crawlCausesFor
|
||||||
import im.vector.app.databinding.FragmentFtueLoginCaptchaBinding
|
import im.vector.app.databinding.FragmentFtueLoginCaptchaBinding
|
||||||
@ -43,9 +44,11 @@ data class FtueAuthCaptchaFragmentArgument(
|
|||||||
/**
|
/**
|
||||||
* In this screen, the user is asked to confirm they are not a robot.
|
* In this screen, the user is asked to confirm they are not a robot.
|
||||||
*/
|
*/
|
||||||
class FtueAuthCaptchaFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val captchaWebview: CaptchaWebview
|
class FtueAuthCaptchaFragment :
|
||||||
) : AbstractFtueAuthFragment<FragmentFtueLoginCaptchaBinding>() {
|
AbstractFtueAuthFragment<FragmentFtueLoginCaptchaBinding>() {
|
||||||
|
|
||||||
|
@Inject lateinit var captchaWebview: CaptchaWebview
|
||||||
|
|
||||||
private val params: FtueAuthCaptchaFragmentArgument by args()
|
private val params: FtueAuthCaptchaFragmentArgument by args()
|
||||||
private var webViewBinding: ViewStubWebviewBinding? = null
|
private var webViewBinding: ViewStubWebviewBinding? = null
|
||||||
|
@ -22,15 +22,17 @@ import android.view.LayoutInflater
|
|||||||
import android.view.View
|
import android.view.View
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import android.view.inputmethod.EditorInfo
|
import android.view.inputmethod.EditorInfo
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.core.extensions.hasContent
|
import im.vector.app.core.extensions.hasContent
|
||||||
import im.vector.app.core.platform.SimpleTextWatcher
|
import im.vector.app.core.platform.SimpleTextWatcher
|
||||||
import im.vector.app.databinding.FragmentFtueDisplayNameBinding
|
import im.vector.app.databinding.FragmentFtueDisplayNameBinding
|
||||||
import im.vector.app.features.onboarding.OnboardingAction
|
import im.vector.app.features.onboarding.OnboardingAction
|
||||||
import im.vector.app.features.onboarding.OnboardingViewEvents
|
import im.vector.app.features.onboarding.OnboardingViewEvents
|
||||||
import im.vector.app.features.onboarding.OnboardingViewState
|
import im.vector.app.features.onboarding.OnboardingViewState
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
class FtueAuthChooseDisplayNameFragment @Inject constructor() : AbstractFtueAuthFragment<FragmentFtueDisplayNameBinding>() {
|
@AndroidEntryPoint
|
||||||
|
class FtueAuthChooseDisplayNameFragment :
|
||||||
|
AbstractFtueAuthFragment<FragmentFtueDisplayNameBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentFtueDisplayNameBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentFtueDisplayNameBinding {
|
||||||
return FragmentFtueDisplayNameBinding.inflate(inflater, container, false)
|
return FragmentFtueDisplayNameBinding.inflate(inflater, container, false)
|
||||||
|
@ -24,12 +24,11 @@ import android.view.ViewGroup
|
|||||||
import android.widget.Toast
|
import android.widget.Toast
|
||||||
import androidx.core.view.isInvisible
|
import androidx.core.view.isInvisible
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.di.ActiveSessionHolder
|
import im.vector.app.core.di.ActiveSessionHolder
|
||||||
import im.vector.app.core.dialogs.GalleryOrCameraDialogHelper
|
import im.vector.app.core.dialogs.GalleryOrCameraDialogHelper
|
||||||
import im.vector.app.core.extensions.singletonEntryPoint
|
import im.vector.app.core.dialogs.GalleryOrCameraDialogHelperFactory
|
||||||
import im.vector.app.core.resources.ColorProvider
|
|
||||||
import im.vector.app.core.time.Clock
|
|
||||||
import im.vector.app.databinding.FragmentFtueProfilePictureBinding
|
import im.vector.app.databinding.FragmentFtueProfilePictureBinding
|
||||||
import im.vector.app.features.home.AvatarRenderer
|
import im.vector.app.features.home.AvatarRenderer
|
||||||
import im.vector.app.features.onboarding.OnboardingAction
|
import im.vector.app.features.onboarding.OnboardingAction
|
||||||
@ -38,19 +37,26 @@ import im.vector.app.features.onboarding.OnboardingViewState
|
|||||||
import org.matrix.android.sdk.api.util.MatrixItem
|
import org.matrix.android.sdk.api.util.MatrixItem
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class FtueAuthChooseProfilePictureFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val activeSessionHolder: ActiveSessionHolder,
|
class FtueAuthChooseProfilePictureFragment :
|
||||||
colorProvider: ColorProvider,
|
AbstractFtueAuthFragment<FragmentFtueProfilePictureBinding>(),
|
||||||
clock: Clock,
|
GalleryOrCameraDialogHelper.Listener {
|
||||||
) : AbstractFtueAuthFragment<FragmentFtueProfilePictureBinding>(), GalleryOrCameraDialogHelper.Listener {
|
|
||||||
|
|
||||||
private val galleryOrCameraDialogHelper = GalleryOrCameraDialogHelper(this, colorProvider, clock)
|
@Inject lateinit var activeSessionHolder: ActiveSessionHolder
|
||||||
private val avatarRenderer: AvatarRenderer by lazy { requireContext().singletonEntryPoint().avatarRenderer() }
|
@Inject lateinit var galleryOrCameraDialogHelperFactory: GalleryOrCameraDialogHelperFactory
|
||||||
|
@Inject lateinit var avatarRenderer: AvatarRenderer
|
||||||
|
|
||||||
|
private lateinit var galleryOrCameraDialogHelper: GalleryOrCameraDialogHelper
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentFtueProfilePictureBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentFtueProfilePictureBinding {
|
||||||
return FragmentFtueProfilePictureBinding.inflate(inflater, container, false)
|
return FragmentFtueProfilePictureBinding.inflate(inflater, container, false)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
override fun onCreate(savedInstanceState: Bundle?) {
|
||||||
|
super.onCreate(savedInstanceState)
|
||||||
|
galleryOrCameraDialogHelper = galleryOrCameraDialogHelperFactory.create(this)
|
||||||
|
}
|
||||||
|
|
||||||
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
|
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
|
||||||
super.onViewCreated(view, savedInstanceState)
|
super.onViewCreated(view, savedInstanceState)
|
||||||
setupViews()
|
setupViews()
|
||||||
|
@ -24,6 +24,7 @@ import android.view.ViewGroup
|
|||||||
import androidx.autofill.HintConstants
|
import androidx.autofill.HintConstants
|
||||||
import androidx.core.view.isVisible
|
import androidx.core.view.isVisible
|
||||||
import androidx.lifecycle.lifecycleScope
|
import androidx.lifecycle.lifecycleScope
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.clearErrorOnChange
|
import im.vector.app.core.extensions.clearErrorOnChange
|
||||||
import im.vector.app.core.extensions.content
|
import im.vector.app.core.extensions.content
|
||||||
@ -48,10 +49,12 @@ import kotlinx.coroutines.flow.launchIn
|
|||||||
import reactivecircus.flowbinding.android.widget.textChanges
|
import reactivecircus.flowbinding.android.widget.textChanges
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class FtueAuthCombinedLoginFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val loginFieldsValidation: LoginFieldsValidation,
|
class FtueAuthCombinedLoginFragment :
|
||||||
private val loginErrorParser: LoginErrorParser
|
AbstractSSOFtueAuthFragment<FragmentFtueCombinedLoginBinding>() {
|
||||||
) : AbstractSSOFtueAuthFragment<FragmentFtueCombinedLoginBinding>() {
|
|
||||||
|
@Inject lateinit var loginFieldsValidation: LoginFieldsValidation
|
||||||
|
@Inject lateinit var loginErrorParser: LoginErrorParser
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentFtueCombinedLoginBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentFtueCombinedLoginBinding {
|
||||||
return FragmentFtueCombinedLoginBinding.inflate(inflater, container, false)
|
return FragmentFtueCombinedLoginBinding.inflate(inflater, container, false)
|
||||||
|
@ -27,6 +27,7 @@ import androidx.core.view.isVisible
|
|||||||
import androidx.lifecycle.lifecycleScope
|
import androidx.lifecycle.lifecycleScope
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.clearErrorOnChange
|
import im.vector.app.core.extensions.clearErrorOnChange
|
||||||
import im.vector.app.core.extensions.content
|
import im.vector.app.core.extensions.content
|
||||||
@ -60,11 +61,12 @@ import org.matrix.android.sdk.api.failure.isRegistrationDisabled
|
|||||||
import org.matrix.android.sdk.api.failure.isUsernameInUse
|
import org.matrix.android.sdk.api.failure.isUsernameInUse
|
||||||
import org.matrix.android.sdk.api.failure.isWeakPassword
|
import org.matrix.android.sdk.api.failure.isWeakPassword
|
||||||
import reactivecircus.flowbinding.android.widget.textChanges
|
import reactivecircus.flowbinding.android.widget.textChanges
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
private const val MINIMUM_PASSWORD_LENGTH = 8
|
private const val MINIMUM_PASSWORD_LENGTH = 8
|
||||||
|
|
||||||
class FtueAuthCombinedRegisterFragment @Inject constructor() : AbstractSSOFtueAuthFragment<FragmentFtueCombinedRegisterBinding>() {
|
@AndroidEntryPoint
|
||||||
|
class FtueAuthCombinedRegisterFragment :
|
||||||
|
AbstractSSOFtueAuthFragment<FragmentFtueCombinedRegisterBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentFtueCombinedRegisterBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentFtueCombinedRegisterBinding {
|
||||||
return FragmentFtueCombinedRegisterBinding.inflate(inflater, container, false)
|
return FragmentFtueCombinedRegisterBinding.inflate(inflater, container, false)
|
||||||
|
@ -20,6 +20,7 @@ import android.os.Bundle
|
|||||||
import android.view.LayoutInflater
|
import android.view.LayoutInflater
|
||||||
import android.view.View
|
import android.view.View
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.associateContentStateWith
|
import im.vector.app.core.extensions.associateContentStateWith
|
||||||
import im.vector.app.core.extensions.clearErrorOnChange
|
import im.vector.app.core.extensions.clearErrorOnChange
|
||||||
@ -37,9 +38,10 @@ import im.vector.app.features.onboarding.OnboardingFlow
|
|||||||
import im.vector.app.features.onboarding.OnboardingViewEvents
|
import im.vector.app.features.onboarding.OnboardingViewEvents
|
||||||
import im.vector.app.features.onboarding.OnboardingViewState
|
import im.vector.app.features.onboarding.OnboardingViewState
|
||||||
import org.matrix.android.sdk.api.failure.isHomeserverUnavailable
|
import org.matrix.android.sdk.api.failure.isHomeserverUnavailable
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
class FtueAuthCombinedServerSelectionFragment @Inject constructor() : AbstractFtueAuthFragment<FragmentFtueServerSelectionCombinedBinding>() {
|
@AndroidEntryPoint
|
||||||
|
class FtueAuthCombinedServerSelectionFragment :
|
||||||
|
AbstractFtueAuthFragment<FragmentFtueServerSelectionCombinedBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentFtueServerSelectionCombinedBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentFtueServerSelectionCombinedBinding {
|
||||||
return FragmentFtueServerSelectionCombinedBinding.inflate(inflater, container, false)
|
return FragmentFtueServerSelectionCombinedBinding.inflate(inflater, container, false)
|
||||||
|
@ -20,6 +20,7 @@ import android.os.Bundle
|
|||||||
import android.view.LayoutInflater
|
import android.view.LayoutInflater
|
||||||
import android.view.View
|
import android.view.View
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.associateContentStateWith
|
import im.vector.app.core.extensions.associateContentStateWith
|
||||||
import im.vector.app.core.extensions.autofillEmail
|
import im.vector.app.core.extensions.autofillEmail
|
||||||
@ -35,9 +36,10 @@ import im.vector.app.features.onboarding.OnboardingAction
|
|||||||
import im.vector.app.features.onboarding.OnboardingViewState
|
import im.vector.app.features.onboarding.OnboardingViewState
|
||||||
import im.vector.app.features.onboarding.RegisterAction
|
import im.vector.app.features.onboarding.RegisterAction
|
||||||
import org.matrix.android.sdk.api.auth.registration.RegisterThreePid
|
import org.matrix.android.sdk.api.auth.registration.RegisterThreePid
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
class FtueAuthEmailEntryFragment @Inject constructor() : AbstractFtueAuthFragment<FragmentFtueEmailInputBinding>() {
|
@AndroidEntryPoint
|
||||||
|
class FtueAuthEmailEntryFragment :
|
||||||
|
AbstractFtueAuthFragment<FragmentFtueEmailInputBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentFtueEmailInputBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentFtueEmailInputBinding {
|
||||||
return FragmentFtueEmailInputBinding.inflate(inflater, container, false)
|
return FragmentFtueEmailInputBinding.inflate(inflater, container, false)
|
||||||
|
@ -29,6 +29,7 @@ import androidx.lifecycle.lifecycleScope
|
|||||||
import com.airbnb.mvrx.args
|
import com.airbnb.mvrx.args
|
||||||
import com.google.i18n.phonenumbers.NumberParseException
|
import com.google.i18n.phonenumbers.NumberParseException
|
||||||
import com.google.i18n.phonenumbers.PhoneNumberUtil
|
import com.google.i18n.phonenumbers.PhoneNumberUtil
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.hideKeyboard
|
import im.vector.app.core.extensions.hideKeyboard
|
||||||
import im.vector.app.core.extensions.isEmail
|
import im.vector.app.core.extensions.isEmail
|
||||||
@ -44,7 +45,6 @@ import org.matrix.android.sdk.api.auth.registration.RegisterThreePid
|
|||||||
import org.matrix.android.sdk.api.failure.Failure
|
import org.matrix.android.sdk.api.failure.Failure
|
||||||
import org.matrix.android.sdk.api.failure.is401
|
import org.matrix.android.sdk.api.failure.is401
|
||||||
import reactivecircus.flowbinding.android.widget.textChanges
|
import reactivecircus.flowbinding.android.widget.textChanges
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
@Parcelize
|
@Parcelize
|
||||||
data class FtueAuthGenericTextInputFormFragmentArgument(
|
data class FtueAuthGenericTextInputFormFragmentArgument(
|
||||||
@ -56,7 +56,9 @@ data class FtueAuthGenericTextInputFormFragmentArgument(
|
|||||||
/**
|
/**
|
||||||
* In this screen, the user is asked for a text input.
|
* In this screen, the user is asked for a text input.
|
||||||
*/
|
*/
|
||||||
class FtueAuthGenericTextInputFormFragment @Inject constructor() : AbstractFtueAuthFragment<FragmentLoginGenericTextInputFormBinding>() {
|
@AndroidEntryPoint
|
||||||
|
class FtueAuthGenericTextInputFormFragment :
|
||||||
|
AbstractFtueAuthFragment<FragmentLoginGenericTextInputFormBinding>() {
|
||||||
|
|
||||||
private val params: FtueAuthGenericTextInputFormFragmentArgument by args()
|
private val params: FtueAuthGenericTextInputFormFragmentArgument by args()
|
||||||
|
|
||||||
|
@ -20,6 +20,7 @@ import android.os.Parcelable
|
|||||||
import android.view.LayoutInflater
|
import android.view.LayoutInflater
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import com.airbnb.mvrx.args
|
import com.airbnb.mvrx.args
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.databinding.FragmentLoginCaptchaBinding
|
import im.vector.app.databinding.FragmentLoginCaptchaBinding
|
||||||
import im.vector.app.features.onboarding.OnboardingAction
|
import im.vector.app.features.onboarding.OnboardingAction
|
||||||
import im.vector.app.features.onboarding.OnboardingViewState
|
import im.vector.app.features.onboarding.OnboardingViewState
|
||||||
@ -35,9 +36,11 @@ data class FtueAuthLegacyStyleCaptchaFragmentArgument(
|
|||||||
/**
|
/**
|
||||||
* In this screen, the user is asked to confirm they are not a robot.
|
* In this screen, the user is asked to confirm they are not a robot.
|
||||||
*/
|
*/
|
||||||
class FtueAuthLegacyStyleCaptchaFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val captchaWebview: CaptchaWebview
|
class FtueAuthLegacyStyleCaptchaFragment :
|
||||||
) : AbstractFtueAuthFragment<FragmentLoginCaptchaBinding>() {
|
AbstractFtueAuthFragment<FragmentLoginCaptchaBinding>() {
|
||||||
|
|
||||||
|
@Inject lateinit var captchaWebview: CaptchaWebview
|
||||||
|
|
||||||
private val params: FtueAuthLegacyStyleCaptchaFragmentArgument by args()
|
private val params: FtueAuthLegacyStyleCaptchaFragmentArgument by args()
|
||||||
private var isWebViewLoaded = false
|
private var isWebViewLoaded = false
|
||||||
|
@ -21,16 +21,18 @@ import android.view.LayoutInflater
|
|||||||
import android.view.View
|
import android.view.View
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import com.airbnb.mvrx.args
|
import com.airbnb.mvrx.args
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.databinding.FragmentLoginWaitForEmailBinding
|
import im.vector.app.databinding.FragmentLoginWaitForEmailBinding
|
||||||
import im.vector.app.features.onboarding.OnboardingAction
|
import im.vector.app.features.onboarding.OnboardingAction
|
||||||
import im.vector.app.features.onboarding.RegisterAction
|
import im.vector.app.features.onboarding.RegisterAction
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* In this screen, the user is asked to check their emails.
|
* In this screen, the user is asked to check their emails.
|
||||||
*/
|
*/
|
||||||
class FtueAuthLegacyWaitForEmailFragment @Inject constructor() : AbstractFtueAuthFragment<FragmentLoginWaitForEmailBinding>() {
|
@AndroidEntryPoint
|
||||||
|
class FtueAuthLegacyWaitForEmailFragment :
|
||||||
|
AbstractFtueAuthFragment<FragmentLoginWaitForEmailBinding>() {
|
||||||
|
|
||||||
private val params: FtueAuthWaitForEmailFragmentArgument by args()
|
private val params: FtueAuthWaitForEmailFragmentArgument by args()
|
||||||
|
|
||||||
|
@ -28,6 +28,7 @@ import androidx.core.view.isVisible
|
|||||||
import androidx.lifecycle.lifecycleScope
|
import androidx.lifecycle.lifecycleScope
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.hideKeyboard
|
import im.vector.app.core.extensions.hideKeyboard
|
||||||
import im.vector.app.core.extensions.hidePassword
|
import im.vector.app.core.extensions.hidePassword
|
||||||
@ -53,7 +54,6 @@ import org.matrix.android.sdk.api.failure.isRegistrationDisabled
|
|||||||
import org.matrix.android.sdk.api.failure.isUsernameInUse
|
import org.matrix.android.sdk.api.failure.isUsernameInUse
|
||||||
import org.matrix.android.sdk.api.failure.isWeakPassword
|
import org.matrix.android.sdk.api.failure.isWeakPassword
|
||||||
import reactivecircus.flowbinding.android.widget.textChanges
|
import reactivecircus.flowbinding.android.widget.textChanges
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* In this screen:
|
* In this screen:
|
||||||
@ -63,7 +63,9 @@ import javax.inject.Inject
|
|||||||
* In signup mode:
|
* In signup mode:
|
||||||
* - the user is asked for login and password
|
* - the user is asked for login and password
|
||||||
*/
|
*/
|
||||||
class FtueAuthLoginFragment @Inject constructor() : AbstractSSOFtueAuthFragment<FragmentLoginBinding>() {
|
@AndroidEntryPoint
|
||||||
|
class FtueAuthLoginFragment :
|
||||||
|
AbstractSSOFtueAuthFragment<FragmentLoginBinding>() {
|
||||||
|
|
||||||
private var isSignupMode = false
|
private var isSignupMode = false
|
||||||
|
|
||||||
|
@ -20,12 +20,14 @@ import android.os.Bundle
|
|||||||
import android.view.LayoutInflater
|
import android.view.LayoutInflater
|
||||||
import android.view.View
|
import android.view.View
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.databinding.FragmentFtuePersonalizationCompleteBinding
|
import im.vector.app.databinding.FragmentFtuePersonalizationCompleteBinding
|
||||||
import im.vector.app.features.onboarding.OnboardingAction
|
import im.vector.app.features.onboarding.OnboardingAction
|
||||||
import im.vector.app.features.onboarding.OnboardingViewEvents
|
import im.vector.app.features.onboarding.OnboardingViewEvents
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
class FtueAuthPersonalizationCompleteFragment @Inject constructor() : AbstractFtueAuthFragment<FragmentFtuePersonalizationCompleteBinding>() {
|
@AndroidEntryPoint
|
||||||
|
class FtueAuthPersonalizationCompleteFragment :
|
||||||
|
AbstractFtueAuthFragment<FragmentFtuePersonalizationCompleteBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentFtuePersonalizationCompleteBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentFtuePersonalizationCompleteBinding {
|
||||||
return FragmentFtuePersonalizationCompleteBinding.inflate(inflater, container, false)
|
return FragmentFtuePersonalizationCompleteBinding.inflate(inflater, container, false)
|
||||||
|
@ -22,6 +22,7 @@ import android.view.LayoutInflater
|
|||||||
import android.view.View
|
import android.view.View
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import com.airbnb.mvrx.args
|
import com.airbnb.mvrx.args
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.associateContentStateWith
|
import im.vector.app.core.extensions.associateContentStateWith
|
||||||
import im.vector.app.core.extensions.clearErrorOnChange
|
import im.vector.app.core.extensions.clearErrorOnChange
|
||||||
@ -32,14 +33,15 @@ import im.vector.app.features.onboarding.OnboardingAction
|
|||||||
import im.vector.app.features.onboarding.RegisterAction
|
import im.vector.app.features.onboarding.RegisterAction
|
||||||
import kotlinx.parcelize.Parcelize
|
import kotlinx.parcelize.Parcelize
|
||||||
import org.matrix.android.sdk.api.failure.Failure
|
import org.matrix.android.sdk.api.failure.Failure
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
@Parcelize
|
@Parcelize
|
||||||
data class FtueAuthPhoneConfirmationFragmentArgument(
|
data class FtueAuthPhoneConfirmationFragmentArgument(
|
||||||
val msisdn: String
|
val msisdn: String
|
||||||
) : Parcelable
|
) : Parcelable
|
||||||
|
|
||||||
class FtueAuthPhoneConfirmationFragment @Inject constructor() : AbstractFtueAuthFragment<FragmentFtuePhoneConfirmationBinding>() {
|
@AndroidEntryPoint
|
||||||
|
class FtueAuthPhoneConfirmationFragment :
|
||||||
|
AbstractFtueAuthFragment<FragmentFtuePhoneConfirmationBinding>() {
|
||||||
|
|
||||||
private val params: FtueAuthPhoneConfirmationFragmentArgument by args()
|
private val params: FtueAuthPhoneConfirmationFragmentArgument by args()
|
||||||
|
|
||||||
|
@ -21,6 +21,7 @@ import android.view.LayoutInflater
|
|||||||
import android.view.View
|
import android.view.View
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import androidx.lifecycle.lifecycleScope
|
import androidx.lifecycle.lifecycleScope
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.associateContentStateWith
|
import im.vector.app.core.extensions.associateContentStateWith
|
||||||
import im.vector.app.core.extensions.autofillPhoneNumber
|
import im.vector.app.core.extensions.autofillPhoneNumber
|
||||||
@ -38,9 +39,11 @@ import org.matrix.android.sdk.api.auth.registration.RegisterThreePid
|
|||||||
import reactivecircus.flowbinding.android.widget.textChanges
|
import reactivecircus.flowbinding.android.widget.textChanges
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class FtueAuthPhoneEntryFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val phoneNumberParser: PhoneNumberParser
|
class FtueAuthPhoneEntryFragment :
|
||||||
) : AbstractFtueAuthFragment<FragmentFtuePhoneInputBinding>() {
|
AbstractFtueAuthFragment<FragmentFtuePhoneInputBinding>() {
|
||||||
|
|
||||||
|
@Inject lateinit var phoneNumberParser: PhoneNumberParser
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentFtuePhoneInputBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentFtuePhoneInputBinding {
|
||||||
return FragmentFtuePhoneInputBinding.inflate(inflater, container, false)
|
return FragmentFtuePhoneInputBinding.inflate(inflater, container, false)
|
||||||
|
@ -39,7 +39,8 @@ data class FtueAuthResetPasswordBreakerArgument(
|
|||||||
) : Parcelable
|
) : Parcelable
|
||||||
|
|
||||||
@AndroidEntryPoint
|
@AndroidEntryPoint
|
||||||
class FtueAuthResetPasswordBreakerFragment : AbstractFtueAuthFragment<FragmentFtueResetPasswordBreakerBinding>() {
|
class FtueAuthResetPasswordBreakerFragment :
|
||||||
|
AbstractFtueAuthFragment<FragmentFtueResetPasswordBreakerBinding>() {
|
||||||
|
|
||||||
@Inject lateinit var themeProvider: ThemeProvider
|
@Inject lateinit var themeProvider: ThemeProvider
|
||||||
private val params: FtueAuthResetPasswordBreakerArgument by args()
|
private val params: FtueAuthResetPasswordBreakerArgument by args()
|
||||||
|
@ -33,7 +33,8 @@ import im.vector.app.features.onboarding.OnboardingAction
|
|||||||
import im.vector.app.features.onboarding.OnboardingViewState
|
import im.vector.app.features.onboarding.OnboardingViewState
|
||||||
|
|
||||||
@AndroidEntryPoint
|
@AndroidEntryPoint
|
||||||
class FtueAuthResetPasswordEmailEntryFragment : AbstractFtueAuthFragment<FragmentFtueResetPasswordEmailInputBinding>() {
|
class FtueAuthResetPasswordEmailEntryFragment :
|
||||||
|
AbstractFtueAuthFragment<FragmentFtueResetPasswordEmailInputBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentFtueResetPasswordEmailInputBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentFtueResetPasswordEmailInputBinding {
|
||||||
return FragmentFtueResetPasswordEmailInputBinding.inflate(inflater, container, false)
|
return FragmentFtueResetPasswordEmailInputBinding.inflate(inflater, container, false)
|
||||||
|
@ -34,7 +34,8 @@ import im.vector.app.features.onboarding.OnboardingViewState
|
|||||||
import org.matrix.android.sdk.api.failure.isMissingEmailVerification
|
import org.matrix.android.sdk.api.failure.isMissingEmailVerification
|
||||||
|
|
||||||
@AndroidEntryPoint
|
@AndroidEntryPoint
|
||||||
class FtueAuthResetPasswordEntryFragment : AbstractFtueAuthFragment<FragmentFtueResetPasswordInputBinding>() {
|
class FtueAuthResetPasswordEntryFragment :
|
||||||
|
AbstractFtueAuthFragment<FragmentFtueResetPasswordInputBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentFtueResetPasswordInputBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentFtueResetPasswordInputBinding {
|
||||||
return FragmentFtueResetPasswordInputBinding.inflate(inflater, container, false)
|
return FragmentFtueResetPasswordInputBinding.inflate(inflater, container, false)
|
||||||
|
@ -22,6 +22,7 @@ import android.view.View
|
|||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import androidx.lifecycle.lifecycleScope
|
import androidx.lifecycle.lifecycleScope
|
||||||
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.hideKeyboard
|
import im.vector.app.core.extensions.hideKeyboard
|
||||||
import im.vector.app.core.extensions.hidePassword
|
import im.vector.app.core.extensions.hidePassword
|
||||||
@ -35,12 +36,13 @@ import kotlinx.coroutines.flow.launchIn
|
|||||||
import kotlinx.coroutines.flow.map
|
import kotlinx.coroutines.flow.map
|
||||||
import kotlinx.coroutines.flow.onEach
|
import kotlinx.coroutines.flow.onEach
|
||||||
import reactivecircus.flowbinding.android.widget.textChanges
|
import reactivecircus.flowbinding.android.widget.textChanges
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* In this screen, the user is asked for email and new password to reset his password.
|
* In this screen, the user is asked for email and new password to reset his password.
|
||||||
*/
|
*/
|
||||||
class FtueAuthResetPasswordFragment @Inject constructor() : AbstractFtueAuthFragment<FragmentLoginResetPasswordBinding>() {
|
@AndroidEntryPoint
|
||||||
|
class FtueAuthResetPasswordFragment :
|
||||||
|
AbstractFtueAuthFragment<FragmentLoginResetPasswordBinding>() {
|
||||||
|
|
||||||
// Show warning only once
|
// Show warning only once
|
||||||
private var showWarning = true
|
private var showWarning = true
|
||||||
|
@ -21,17 +21,19 @@ import android.view.LayoutInflater
|
|||||||
import android.view.View
|
import android.view.View
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.databinding.FragmentLoginResetPasswordMailConfirmationBinding
|
import im.vector.app.databinding.FragmentLoginResetPasswordMailConfirmationBinding
|
||||||
import im.vector.app.features.onboarding.OnboardingAction
|
import im.vector.app.features.onboarding.OnboardingAction
|
||||||
import im.vector.app.features.onboarding.OnboardingViewState
|
import im.vector.app.features.onboarding.OnboardingViewState
|
||||||
import org.matrix.android.sdk.api.failure.is401
|
import org.matrix.android.sdk.api.failure.is401
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* In this screen, the user is asked to check their email and to click on a button once it's done.
|
* In this screen, the user is asked to check their email and to click on a button once it's done.
|
||||||
*/
|
*/
|
||||||
class FtueAuthResetPasswordMailConfirmationFragment @Inject constructor() : AbstractFtueAuthFragment<FragmentLoginResetPasswordMailConfirmationBinding>() {
|
@AndroidEntryPoint
|
||||||
|
class FtueAuthResetPasswordMailConfirmationFragment :
|
||||||
|
AbstractFtueAuthFragment<FragmentLoginResetPasswordMailConfirmationBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoginResetPasswordMailConfirmationBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoginResetPasswordMailConfirmationBinding {
|
||||||
return FragmentLoginResetPasswordMailConfirmationBinding.inflate(inflater, container, false)
|
return FragmentLoginResetPasswordMailConfirmationBinding.inflate(inflater, container, false)
|
||||||
|
@ -20,15 +20,17 @@ import android.os.Bundle
|
|||||||
import android.view.LayoutInflater
|
import android.view.LayoutInflater
|
||||||
import android.view.View
|
import android.view.View
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.databinding.FragmentLoginResetPasswordSuccessBinding
|
import im.vector.app.databinding.FragmentLoginResetPasswordSuccessBinding
|
||||||
import im.vector.app.features.onboarding.OnboardingAction
|
import im.vector.app.features.onboarding.OnboardingAction
|
||||||
import im.vector.app.features.onboarding.OnboardingViewEvents
|
import im.vector.app.features.onboarding.OnboardingViewEvents
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* In this screen, we confirm to the user that his password has been reset.
|
* In this screen, we confirm to the user that his password has been reset.
|
||||||
*/
|
*/
|
||||||
class FtueAuthResetPasswordSuccessFragment @Inject constructor() : AbstractFtueAuthFragment<FragmentLoginResetPasswordSuccessBinding>() {
|
@AndroidEntryPoint
|
||||||
|
class FtueAuthResetPasswordSuccessFragment :
|
||||||
|
AbstractFtueAuthFragment<FragmentLoginResetPasswordSuccessBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoginResetPasswordSuccessBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoginResetPasswordSuccessBinding {
|
||||||
return FragmentLoginResetPasswordSuccessBinding.inflate(inflater, container, false)
|
return FragmentLoginResetPasswordSuccessBinding.inflate(inflater, container, false)
|
||||||
|
@ -20,6 +20,7 @@ import android.os.Bundle
|
|||||||
import android.view.LayoutInflater
|
import android.view.LayoutInflater
|
||||||
import android.view.View
|
import android.view.View
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.utils.openUrlInChromeCustomTab
|
import im.vector.app.core.utils.openUrlInChromeCustomTab
|
||||||
import im.vector.app.databinding.FragmentLoginServerSelectionBinding
|
import im.vector.app.databinding.FragmentLoginServerSelectionBinding
|
||||||
@ -29,12 +30,13 @@ import im.vector.app.features.login.SignMode
|
|||||||
import im.vector.app.features.onboarding.OnboardingAction
|
import im.vector.app.features.onboarding.OnboardingAction
|
||||||
import im.vector.app.features.onboarding.OnboardingViewState
|
import im.vector.app.features.onboarding.OnboardingViewState
|
||||||
import me.gujun.android.span.span
|
import me.gujun.android.span.span
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* In this screen, the user will choose between matrix.org, modular or other type of homeserver.
|
* In this screen, the user will choose between matrix.org, modular or other type of homeserver.
|
||||||
*/
|
*/
|
||||||
class FtueAuthServerSelectionFragment @Inject constructor() : AbstractFtueAuthFragment<FragmentLoginServerSelectionBinding>() {
|
@AndroidEntryPoint
|
||||||
|
class FtueAuthServerSelectionFragment :
|
||||||
|
AbstractFtueAuthFragment<FragmentLoginServerSelectionBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoginServerSelectionBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoginServerSelectionBinding {
|
||||||
return FragmentLoginServerSelectionBinding.inflate(inflater, container, false)
|
return FragmentLoginServerSelectionBinding.inflate(inflater, container, false)
|
||||||
|
@ -27,6 +27,7 @@ import androidx.core.view.isInvisible
|
|||||||
import androidx.core.view.isVisible
|
import androidx.core.view.isVisible
|
||||||
import androidx.lifecycle.lifecycleScope
|
import androidx.lifecycle.lifecycleScope
|
||||||
import com.google.android.material.textfield.TextInputLayout
|
import com.google.android.material.textfield.TextInputLayout
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.hideKeyboard
|
import im.vector.app.core.extensions.hideKeyboard
|
||||||
import im.vector.app.core.resources.BuildMeta
|
import im.vector.app.core.resources.BuildMeta
|
||||||
@ -47,9 +48,11 @@ import javax.inject.Inject
|
|||||||
/**
|
/**
|
||||||
* In this screen, the user is prompted to enter a homeserver url.
|
* In this screen, the user is prompted to enter a homeserver url.
|
||||||
*/
|
*/
|
||||||
class FtueAuthServerUrlFormFragment @Inject constructor(
|
@AndroidEntryPoint
|
||||||
private val buildMeta: BuildMeta,
|
class FtueAuthServerUrlFormFragment :
|
||||||
) : AbstractFtueAuthFragment<FragmentLoginServerUrlFormBinding>() {
|
AbstractFtueAuthFragment<FragmentLoginServerUrlFormBinding>() {
|
||||||
|
|
||||||
|
@Inject lateinit var buildMeta: BuildMeta
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoginServerUrlFormBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoginServerUrlFormBinding {
|
||||||
return FragmentLoginServerUrlFormBinding.inflate(inflater, container, false)
|
return FragmentLoginServerUrlFormBinding.inflate(inflater, container, false)
|
||||||
|
@ -23,6 +23,7 @@ import android.view.ViewGroup
|
|||||||
import androidx.annotation.DrawableRes
|
import androidx.annotation.DrawableRes
|
||||||
import androidx.core.view.isVisible
|
import androidx.core.view.isVisible
|
||||||
import com.airbnb.mvrx.withState
|
import com.airbnb.mvrx.withState
|
||||||
|
import dagger.hilt.android.AndroidEntryPoint
|
||||||
import im.vector.app.R
|
import im.vector.app.R
|
||||||
import im.vector.app.core.extensions.toReducedUrl
|
import im.vector.app.core.extensions.toReducedUrl
|
||||||
import im.vector.app.databinding.FragmentLoginSignupSigninSelectionBinding
|
import im.vector.app.databinding.FragmentLoginSignupSigninSelectionBinding
|
||||||
@ -34,12 +35,13 @@ import im.vector.app.features.login.SocialLoginButtonsView.Mode
|
|||||||
import im.vector.app.features.login.render
|
import im.vector.app.features.login.render
|
||||||
import im.vector.app.features.onboarding.OnboardingAction
|
import im.vector.app.features.onboarding.OnboardingAction
|
||||||
import im.vector.app.features.onboarding.OnboardingViewState
|
import im.vector.app.features.onboarding.OnboardingViewState
|
||||||
import javax.inject.Inject
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* In this screen, the user is asked to sign up or to sign in to the homeserver.
|
* In this screen, the user is asked to sign up or to sign in to the homeserver.
|
||||||
*/
|
*/
|
||||||
class FtueAuthSignUpSignInSelectionFragment @Inject constructor() : AbstractSSOFtueAuthFragment<FragmentLoginSignupSigninSelectionBinding>() {
|
@AndroidEntryPoint
|
||||||
|
class FtueAuthSignUpSignInSelectionFragment :
|
||||||
|
AbstractSSOFtueAuthFragment<FragmentLoginSignupSigninSelectionBinding>() {
|
||||||
|
|
||||||
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoginSignupSigninSelectionBinding {
|
override fun getBinding(inflater: LayoutInflater, container: ViewGroup?): FragmentLoginSignupSigninSelectionBinding {
|
||||||
return FragmentLoginSignupSigninSelectionBinding.inflate(inflater, container, false)
|
return FragmentLoginSignupSigninSelectionBinding.inflate(inflater, container, false)
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user