Renamed recordings fragment

This commit is contained in:
Sylvain Berfini 2024-05-17 15:04:53 +02:00
parent f8d60c1284
commit e93e6ca5cc
5 changed files with 59 additions and 49 deletions

View file

@ -82,7 +82,7 @@ class DrawerMenuFragment : GenericMainFragment() {
binding.setRecordingsClickListener { binding.setRecordingsClickListener {
val navController = (requireActivity() as MainActivity).findNavController() val navController = (requireActivity() as MainActivity).findNavController()
navController.navigate(R.id.action_global_recordingsFragment) navController.navigate(R.id.action_global_recordingsListFragment)
(requireActivity() as MainActivity).closeDrawerMenu() (requireActivity() as MainActivity).closeDrawerMenu()
} }

View file

@ -30,7 +30,7 @@ import androidx.recyclerview.widget.LinearLayoutManager
import com.google.android.material.bottomsheet.BottomSheetDialogFragment import com.google.android.material.bottomsheet.BottomSheetDialogFragment
import kotlinx.coroutines.launch import kotlinx.coroutines.launch
import org.linphone.core.tools.Log import org.linphone.core.tools.Log
import org.linphone.databinding.RecordingsFragmentBinding import org.linphone.databinding.RecordingsListFragmentBinding
import org.linphone.ui.main.fragment.GenericMainFragment import org.linphone.ui.main.fragment.GenericMainFragment
import org.linphone.ui.main.recordings.adapter.RecordingsListAdapter import org.linphone.ui.main.recordings.adapter.RecordingsListAdapter
import org.linphone.ui.main.recordings.viewmodel.RecordingsListViewModel import org.linphone.ui.main.recordings.viewmodel.RecordingsListViewModel
@ -39,12 +39,12 @@ import org.linphone.utils.hideKeyboard
import org.linphone.utils.showKeyboard import org.linphone.utils.showKeyboard
@UiThread @UiThread
class RecordingsFragment : GenericMainFragment() { class RecordingsListFragment : GenericMainFragment() {
companion object { companion object {
private const val TAG = "[Recordings List Fragment]" private const val TAG = "[Recordings List Fragment]"
} }
private lateinit var binding: RecordingsFragmentBinding private lateinit var binding: RecordingsListFragmentBinding
private lateinit var listViewModel: RecordingsListViewModel private lateinit var listViewModel: RecordingsListViewModel
@ -63,7 +63,7 @@ class RecordingsFragment : GenericMainFragment() {
container: ViewGroup?, container: ViewGroup?,
savedInstanceState: Bundle? savedInstanceState: Bundle?
): View { ): View {
binding = RecordingsFragmentBinding.inflate(layoutInflater) binding = RecordingsListFragmentBinding.inflate(layoutInflater)
return binding.root return binding.root
} }

View file

@ -16,31 +16,41 @@
<androidx.constraintlayout.widget.ConstraintLayout <androidx.constraintlayout.widget.ConstraintLayout
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="match_parent" android:layout_height="match_parent"
android:background="?attr/color_main2_000"> android:background="?attr/color_main2_000"
app:layout_constraintEnd_toStartOf="@+id/search"
app:layout_constraintStart_toStartOf="@+id/search">
<androidx.constraintlayout.widget.Group <androidx.constraintlayout.widget.Group
android:id="@+id/group"
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:layout_height="wrap_content"
app:constraint_referenced_ids="cancel_search, search, clear_field" android:visibility="@{viewModel.recordings.empty ? View.VISIBLE : View.GONE}"
android:visibility="@{viewModel.searchBarVisible ? View.VISIBLE : View.GONE, default=gone}" /> app:constraint_referenced_ids="no_recording_image, no_recording_label" />
<androidx.constraintlayout.widget.Group
android:id="@+id/group2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:visibility="@{viewModel.searchBarVisible ? View.VISIBLE : View.GONE, default=gone}"
app:constraint_referenced_ids="cancel_search, search, clear_field" />
<ImageView <ImageView
android:id="@+id/back" android:id="@+id/back"
android:onClick="@{backClickListener}"
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="0dp" android:layout_height="0dp"
android:adjustViewBounds="true" android:adjustViewBounds="true"
android:contentDescription="@string/content_description_go_back_icon"
android:onClick="@{backClickListener}"
android:padding="15dp" android:padding="15dp"
android:src="@drawable/caret_left" android:src="@drawable/caret_left"
android:contentDescription="@string/content_description_go_back_icon"
app:tint="?attr/color_main1_500"
app:layout_constraintBottom_toBottomOf="@id/title" app:layout_constraintBottom_toBottomOf="@id/title"
app:layout_constraintStart_toStartOf="parent" app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="@id/title" /> app:layout_constraintTop_toTopOf="@id/title"
app:tint="?attr/color_main1_500" />
<androidx.appcompat.widget.AppCompatTextView <androidx.appcompat.widget.AppCompatTextView
style="@style/main_page_title_style"
android:id="@+id/title" android:id="@+id/title"
style="@style/main_page_title_style"
android:layout_width="0dp" android:layout_width="0dp"
android:layout_height="@dimen/top_bar_height" android:layout_height="@dimen/top_bar_height"
android:layout_marginStart="10dp" android:layout_marginStart="10dp"
@ -49,17 +59,17 @@
android:visibility="@{viewModel.searchBarVisible ? View.GONE : View.VISIBLE}" android:visibility="@{viewModel.searchBarVisible ? View.GONE : View.VISIBLE}"
app:layout_constraintEnd_toStartOf="@id/search_toggle" app:layout_constraintEnd_toStartOf="@id/search_toggle"
app:layout_constraintStart_toEndOf="@id/back" app:layout_constraintStart_toEndOf="@id/back"
app:layout_constraintTop_toTopOf="parent"/> app:layout_constraintTop_toTopOf="parent" />
<ImageView <ImageView
android:id="@+id/search_toggle" android:id="@+id/search_toggle"
android:onClick="@{() -> viewModel.openSearchBar()}"
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="0dp" android:layout_height="0dp"
android:contentDescription="@string/content_description_open_filter"
android:onClick="@{() -> viewModel.openSearchBar()}"
android:padding="15dp" android:padding="15dp"
android:src="@drawable/magnifying_glass" android:src="@drawable/magnifying_glass"
android:visibility="@{viewModel.searchBarVisible ? View.GONE : View.VISIBLE}" android:visibility="@{viewModel.searchBarVisible ? View.GONE : View.VISIBLE}"
android:contentDescription="@string/content_description_open_filter"
app:layout_constraintBottom_toBottomOf="@id/title" app:layout_constraintBottom_toBottomOf="@id/title"
app:layout_constraintEnd_toEndOf="parent" app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintTop_toTopOf="@id/title" app:layout_constraintTop_toTopOf="@id/title"
@ -67,29 +77,29 @@
<ImageView <ImageView
android:id="@+id/cancel_search" android:id="@+id/cancel_search"
android:onClick="@{() -> viewModel.closeSearchBar()}"
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="0dp" android:layout_height="0dp"
android:contentDescription="@string/content_description_cancel_filter"
android:onClick="@{() -> viewModel.closeSearchBar()}"
android:padding="15dp" android:padding="15dp"
android:src="@drawable/caret_left" android:src="@drawable/caret_left"
android:contentDescription="@string/content_description_cancel_filter"
app:layout_constraintBottom_toBottomOf="@id/search" app:layout_constraintBottom_toBottomOf="@id/search"
app:layout_constraintStart_toStartOf="parent" app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="@id/search" app:layout_constraintTop_toTopOf="@id/search"
app:tint="?attr/color_main2_500" /> app:tint="?attr/color_main2_500" />
<com.google.android.material.textfield.TextInputLayout <com.google.android.material.textfield.TextInputLayout
style="?attr/textInputFilledStyle"
android:id="@+id/search" android:id="@+id/search"
style="?attr/textInputFilledStyle"
android:layout_width="0dp" android:layout_width="0dp"
android:layout_height="@dimen/top_bar_height" android:layout_height="@dimen/top_bar_height"
android:gravity="center_vertical" android:gravity="center_vertical"
android:textColorHint="?attr/color_main2_400" android:textColorHint="?attr/color_main2_400"
app:hintEnabled="false"
app:hintAnimationEnabled="false"
app:hintTextColor="?attr/color_main2_400"
app:boxStrokeWidth="0dp" app:boxStrokeWidth="0dp"
app:boxStrokeWidthFocused="0dp" app:boxStrokeWidthFocused="0dp"
app:hintAnimationEnabled="false"
app:hintEnabled="false"
app:hintTextColor="?attr/color_main2_400"
app:layout_constraintEnd_toStartOf="@id/clear_field" app:layout_constraintEnd_toStartOf="@id/clear_field"
app:layout_constraintStart_toEndOf="@id/cancel_search" app:layout_constraintStart_toEndOf="@id/cancel_search"
app:layout_constraintTop_toTopOf="parent"> app:layout_constraintTop_toTopOf="parent">
@ -97,25 +107,25 @@
<com.google.android.material.textfield.TextInputEditText <com.google.android.material.textfield.TextInputEditText
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="match_parent" android:layout_height="match_parent"
android:textCursorDrawable="@null" android:background="@android:color/transparent"
android:textSize="16sp"
android:inputType="text" android:inputType="text"
android:paddingVertical="1dp" android:paddingVertical="1dp"
android:text="@={viewModel.searchFilter}" android:text="@={viewModel.searchFilter}"
android:background="@android:color/transparent" /> android:textCursorDrawable="@null"
android:textSize="16sp" />
</com.google.android.material.textfield.TextInputLayout> </com.google.android.material.textfield.TextInputLayout>
<ImageView <ImageView
android:id="@+id/clear_field" android:id="@+id/clear_field"
android:onClick="@{() -> viewModel.clearFilter()}"
android:enabled="@{viewModel.searchFilter.length() > 0}"
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:padding="6dp"
android:layout_marginEnd="9dp" android:layout_marginEnd="9dp"
android:src="@drawable/x"
android:contentDescription="@string/content_description_clear_filter" android:contentDescription="@string/content_description_clear_filter"
android:enabled="@{viewModel.searchFilter.length() > 0}"
android:onClick="@{() -> viewModel.clearFilter()}"
android:padding="6dp"
android:src="@drawable/x"
app:layout_constraintBottom_toBottomOf="@id/search" app:layout_constraintBottom_toBottomOf="@id/search"
app:layout_constraintEnd_toEndOf="parent" app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintTop_toTopOf="@id/search" app:layout_constraintTop_toTopOf="@id/search"
@ -126,34 +136,34 @@
android:layout_width="0dp" android:layout_width="0dp"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_margin="10dp" android:layout_margin="10dp"
android:src="@drawable/illu"
android:contentDescription="@null" android:contentDescription="@null"
app:layout_constraintHeight_max="200dp" android:src="@drawable/illu"
app:layout_constraintBottom_toTopOf="@id/no_recording_label"
app:layout_constraintDimensionRatio="1:1" app:layout_constraintDimensionRatio="1:1"
app:layout_constraintVertical_chainStyle="packed"
app:layout_constraintTop_toBottomOf="@id/title"
app:layout_constraintEnd_toEndOf="parent" app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHeight_max="200dp"
app:layout_constraintStart_toStartOf="parent" app:layout_constraintStart_toStartOf="parent"
app:layout_constraintBottom_toTopOf="@id/no_recording_label" /> app:layout_constraintTop_toBottomOf="@id/title"
app:layout_constraintVertical_chainStyle="packed" />
<androidx.appcompat.widget.AppCompatTextView <androidx.appcompat.widget.AppCompatTextView
style="@style/section_header_style"
android:id="@+id/no_recording_label" android:id="@+id/no_recording_label"
style="@style/section_header_style"
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:text="@string/recordings_list_empty" android:text="@string/recordings_list_empty"
app:layout_constraintTop_toBottomOf="@id/no_recording_image"
app:layout_constraintBottom_toBottomOf="parent" app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent" app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent" /> app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@id/no_recording_image" />
<androidx.recyclerview.widget.RecyclerView <androidx.recyclerview.widget.RecyclerView
android:id="@+id/recordings_list" android:id="@+id/recordings_list"
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="0dp" android:layout_height="0dp"
android:layout_marginTop="@dimen/top_bar_height" android:layout_marginTop="@dimen/top_bar_height"
app:layout_constraintTop_toTopOf="parent" app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintBottom_toBottomOf="parent"/> app:layout_constraintTop_toTopOf="parent" />
<com.google.android.material.progressindicator.CircularProgressIndicator <com.google.android.material.progressindicator.CircularProgressIndicator
android:id="@+id/fetch_in_progress" android:id="@+id/fetch_in_progress"
@ -162,10 +172,10 @@
android:indeterminate="true" android:indeterminate="true"
android:visibility="@{viewModel.fetchInProgress ? View.VISIBLE : View.GONE}" android:visibility="@{viewModel.fetchInProgress ? View.VISIBLE : View.GONE}"
app:indicatorColor="@color/main1_500" app:indicatorColor="@color/main1_500"
app:layout_constraintStart_toStartOf="parent" app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent" app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintTop_toTopOf="parent" app:layout_constraintStart_toStartOf="parent"
app:layout_constraintBottom_toBottomOf="parent" /> app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout> </androidx.constraintlayout.widget.ConstraintLayout>

View file

@ -173,14 +173,14 @@
app:launchSingleTop="true"/> app:launchSingleTop="true"/>
<fragment <fragment
android:id="@+id/recordingsFragment" android:id="@+id/recordingsListFragment"
android:name="org.linphone.ui.main.recordings.fragment.RecordingsFragment" android:name="org.linphone.ui.main.recordings.fragment.RecordingsListFragment"
android:label="RecordingsFragment" android:label="RecordingsListFragment"
tools:layout="@layout/recordings_fragment" /> tools:layout="@layout/recordings_list_fragment" />
<action <action
android:id="@+id/action_global_recordingsFragment" android:id="@+id/action_global_recordingsListFragment"
app:destination="@id/recordingsFragment" app:destination="@id/recordingsListFragment"
app:enterAnim="@anim/slide_in_right" app:enterAnim="@anim/slide_in_right"
app:exitAnim="@anim/slide_out_left" app:exitAnim="@anim/slide_out_left"
app:popEnterAnim="@anim/slide_in_left" app:popEnterAnim="@anim/slide_in_left"

View file

@ -319,7 +319,7 @@
<string name="account_settings_avpf_title">AVPF</string> <string name="account_settings_avpf_title">AVPF</string>
<string name="account_settings_expire_title">Expiration</string> <string name="account_settings_expire_title">Expiration</string>
<string name="account_settings_conference_factory_uri_title">URI de l\'usine à conversations</string> <string name="account_settings_conference_factory_uri_title">URI de l\'usine à conversations</string>
<string name="account_settings_audio_video_conference_factory_uri_title">URI de l\'usine à conférences</string> <string name="account_settings_audio_video_conference_factory_uri_title">URI de l\'usine à réunions</string>
<string name="account_settings_lime_server_url_title">URL du serveur d\'échange de clés de chiffrement</string> <string name="account_settings_lime_server_url_title">URL du serveur d\'échange de clés de chiffrement</string>
<string name="account_settings_bundle_mode_title">Mode "bundle"</string> <string name="account_settings_bundle_mode_title">Mode "bundle"</string>
<string name="account_settings_cpim_in_basic_conversations_title">Utiliser CPIM dans les conversations "basiques"</string> <string name="account_settings_cpim_in_basic_conversations_title">Utiliser CPIM dans les conversations "basiques"</string>