Skip to content

Commit

Permalink
fix: Fixes according to PR feedback
Browse files Browse the repository at this point in the history
  • Loading branch information
PavloNetrebchuk committed Jun 21, 2024
1 parent 74072e2 commit ec16240
Show file tree
Hide file tree
Showing 31 changed files with 173 additions and 129 deletions.
14 changes: 13 additions & 1 deletion app/src/main/java/org/openedx/app/AppActivity.kt
Original file line number Diff line number Diff line change
Expand Up @@ -12,9 +12,11 @@ import androidx.core.view.WindowCompat
import androidx.core.view.WindowInsetsCompat
import androidx.core.view.WindowInsetsControllerCompat
import androidx.fragment.app.Fragment
import androidx.lifecycle.lifecycleScope
import androidx.window.layout.WindowMetricsCalculator
import io.branch.referral.Branch
import io.branch.referral.Branch.BranchUniversalReferralInitListener
import kotlinx.coroutines.launch
import org.koin.android.ext.android.inject
import org.koin.androidx.viewmodel.ext.android.viewModel
import org.openedx.app.databinding.ActivityAppBinding
Expand All @@ -28,6 +30,7 @@ import org.openedx.core.presentation.global.WindowSizeHolder
import org.openedx.core.ui.WindowSize
import org.openedx.core.ui.WindowType
import org.openedx.core.utils.Logger
import org.openedx.course.presentation.download.DownloadDialogManager
import org.openedx.profile.presentation.ProfileRouter
import org.openedx.whatsnew.WhatsNewManager
import org.openedx.whatsnew.presentation.whatsnew.WhatsNewFragment
Expand All @@ -49,6 +52,7 @@ class AppActivity : AppCompatActivity(), InsetHolder, WindowSizeHolder {
private val whatsNewManager by inject<WhatsNewManager>()
private val corePreferencesManager by inject<CorePreferences>()
private val profileRouter by inject<ProfileRouter>()
private val downloadDialogManager by inject<DownloadDialogManager>()

private val branchLogger = Logger(BRANCH_TAG)

Expand All @@ -73,7 +77,6 @@ class AppActivity : AppCompatActivity(), InsetHolder, WindowSizeHolder {
viewModel.logAppLaunchEvent()
setContentView(binding.root)
val container = binding.rootLayout
viewModel.fragmentManager = supportFragmentManager

container.addView(object : View(this) {
override fun onConfigurationChanged(newConfig: Configuration?) {
Expand Down Expand Up @@ -141,6 +144,15 @@ class AppActivity : AppCompatActivity(), InsetHolder, WindowSizeHolder {
viewModel.logoutUser.observe(this) {
profileRouter.restartApp(supportFragmentManager, viewModel.isLogistrationEnabled)
}

lifecycleScope.launch {
viewModel.downloadFailedDialog.collect {
downloadDialogManager.showDownloadFailedPopup(
downloadModel = it.downloadModel,
fragmentManager = supportFragmentManager,
)
}
}
}

override fun onStart() {
Expand Down
19 changes: 9 additions & 10 deletions app/src/main/java/org/openedx/app/AppViewModel.kt
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,9 @@ import androidx.lifecycle.LiveData
import androidx.lifecycle.viewModelScope
import androidx.room.RoomDatabase
import kotlinx.coroutines.CoroutineDispatcher
import kotlinx.coroutines.flow.MutableSharedFlow
import kotlinx.coroutines.flow.SharedFlow
import kotlinx.coroutines.flow.asSharedFlow
import kotlinx.coroutines.launch
import kotlinx.coroutines.withContext
import org.openedx.app.deeplink.DeepLink
Expand All @@ -19,7 +22,6 @@ import org.openedx.core.data.storage.CorePreferences
import org.openedx.core.system.notifier.DownloadFailed
import org.openedx.core.system.notifier.DownloadNotifier
import org.openedx.core.utils.FileUtil
import org.openedx.course.presentation.download.DownloadDialogManager

class AppViewModel(
private val config: Config,
Expand All @@ -31,22 +33,24 @@ class AppViewModel(
private val deepLinkRouter: DeepLinkRouter,
private val fileUtil: FileUtil,
private val downloadNotifier: DownloadNotifier,
private val downloadDialogManager: DownloadDialogManager,
) : BaseViewModel() {

private val _logoutUser = SingleEventLiveData<Unit>()
val logoutUser: LiveData<Unit>
get() = _logoutUser

private val _downloadFailedDialog = MutableSharedFlow<DownloadFailed>()
val downloadFailedDialog: SharedFlow<DownloadFailed>
get() = _downloadFailedDialog.asSharedFlow()


val isLogistrationEnabled get() = config.isPreLoginExperienceEnabled()

private var logoutHandledAt: Long = 0

val isBranchEnabled get() = config.getBranchConfig().enabled
private val canResetAppDirectory get() = preferencesManager.canResetAppDirectory

var fragmentManager: FragmentManager? = null

override fun onCreate(owner: LifecycleOwner) {
super.onCreate(owner)
setUserId()
Expand All @@ -69,12 +73,7 @@ class AppViewModel(
viewModelScope.launch {
downloadNotifier.notifier.collect { event ->
if (event is DownloadFailed) {
fragmentManager?.let {
downloadDialogManager.showDownloadFailedPopup(
downloadModel = event.downloadModel,
fragmentManager = it,
)
}
_downloadFailedDialog.emit(event)
}
}
}
Expand Down
3 changes: 0 additions & 3 deletions app/src/main/java/org/openedx/app/MainViewModel.kt
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,6 @@ import kotlinx.coroutines.flow.asSharedFlow
import kotlinx.coroutines.flow.distinctUntilChanged
import kotlinx.coroutines.flow.launchIn
import kotlinx.coroutines.flow.onEach
import org.openedx.app.worker.OfflineProgressSyncScheduler
import org.openedx.core.BaseViewModel
import org.openedx.core.config.Config
import org.openedx.core.system.notifier.DiscoveryNotifier
Expand All @@ -21,7 +20,6 @@ class MainViewModel(
private val config: Config,
private val notifier: DiscoveryNotifier,
private val analytics: AppAnalytics,
private val offlineProgressSyncScheduler: OfflineProgressSyncScheduler,
) : BaseViewModel() {

private val _isBottomBarEnabled = MutableLiveData(true)
Expand All @@ -37,7 +35,6 @@ class MainViewModel(

override fun onCreate(owner: LifecycleOwner) {
super.onCreate(owner)
offlineProgressSyncScheduler.scheduleHourlySync()
notifier.notifier
.onEach {
if (it is NavigationToDiscovery) {
Expand Down
2 changes: 1 addition & 1 deletion app/src/main/java/org/openedx/app/di/AppModule.kt
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,6 @@ import org.openedx.app.deeplink.DeepLinkRouter
import org.openedx.app.room.AppDatabase
import org.openedx.app.room.DATABASE_NAME
import org.openedx.app.system.notifier.AppNotifier
import org.openedx.app.worker.OfflineProgressSyncScheduler
import org.openedx.auth.presentation.AgreementProvider
import org.openedx.auth.presentation.AuthAnalytics
import org.openedx.auth.presentation.AuthRouter
Expand Down Expand Up @@ -56,6 +55,7 @@ import org.openedx.course.data.storage.CoursePreferences
import org.openedx.course.presentation.CourseAnalytics
import org.openedx.course.presentation.CourseRouter
import org.openedx.course.presentation.download.DownloadDialogManager
import org.openedx.course.worker.OfflineProgressSyncScheduler
import org.openedx.dashboard.presentation.DashboardAnalytics
import org.openedx.dashboard.presentation.DashboardRouter
import org.openedx.discovery.presentation.DiscoveryAnalytics
Expand Down
6 changes: 3 additions & 3 deletions app/src/main/java/org/openedx/app/di/ScreenModule.kt
Original file line number Diff line number Diff line change
Expand Up @@ -80,10 +80,9 @@ val screenModule = module {
get(),
get(),
get(),
get(),
)
}
viewModel { MainViewModel(get(), get(), get(), get()) }
viewModel { MainViewModel(get(), get(), get()) }

factory { AuthRepository(get(), get(), get()) }
factory { AuthInteractor(get()) }
Expand Down Expand Up @@ -438,7 +437,8 @@ val screenModule = module {
get(),
get(),
get(),
get()
get(),
get(),
)
}

Expand Down

This file was deleted.

2 changes: 1 addition & 1 deletion core/src/main/java/org/openedx/core/data/api/CourseApi.kt
Original file line number Diff line number Diff line change
Expand Up @@ -84,6 +84,6 @@ interface CourseApi {
suspend fun submitOfflineXBlockProgress(
@Path("course_id") courseId: String,
@Path("block_id") blockId: String,
@FieldMap(encoded = false) progress: Map<String, String>
@FieldMap progress: Map<String, String>
)
}
2 changes: 1 addition & 1 deletion core/src/main/java/org/openedx/core/extension/LongExt.kt
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ fun Long.toFileSize(round: Int = 2, space: Boolean = true): String {
val units = arrayOf("B", "KB", "MB", "GB", "TB", "PB", "EB", "ZB", "YB")
val digitGroups = (log10(this.toDouble()) / log10(1024.0)).toInt()
val size = this / 1024.0.pow(digitGroups.toDouble())
val formatString = if (size % 1 == 0.0) "%.0f" else "%.${round}f"
val formatString = if (size % 1 < 0.05) "%.0f" else "%.${round}f"
return String.format(formatString, size) + if (space) " " else "" + units[digitGroups]
} catch (e: Exception) {
println(e.toString())
Expand Down
11 changes: 8 additions & 3 deletions core/src/main/java/org/openedx/core/module/DownloadWorker.kt
Original file line number Diff line number Diff line change
Expand Up @@ -135,9 +135,14 @@ class DownloadWorker(
when (downloadResult) {
DownloadResult.SUCCESS -> {
val updatedModel = downloadHelper.updateDownloadStatus(downloadTask)
downloadDao.updateDownloadModel(
DownloadModelEntity.createFrom(updatedModel)
)
if (updatedModel == null) {
downloadDao.removeDownloadModel(downloadTask.id)
downloadError.add(downloadTask)
} else {
downloadDao.updateDownloadModel(
DownloadModelEntity.createFrom(updatedModel)
)
}
}

DownloadResult.CANCELED -> {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -32,4 +32,4 @@ enum class DownloadedState {

enum class FileType {
VIDEO, X_BLOCK
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -73,7 +73,6 @@ abstract class AbstractDownloader : KoinComponent {
}
}


suspend fun cancelDownloading() {
isCanceled = true
withContext(Dispatchers.IO) {
Expand All @@ -95,5 +94,4 @@ abstract class AbstractDownloader : KoinComponent {
enum class DownloadResult {
SUCCESS, CANCELED, ERROR
}

}
}
Original file line number Diff line number Diff line change
Expand Up @@ -217,17 +217,6 @@ abstract class BaseDownloadViewModel(
}
}

protected fun addDownloadableChildrenForVerticalBlock(verticalBlock: Block) {
for (unitBlockId in verticalBlock.descendants) {
val block = allBlocks[unitBlockId]
if (block?.isDownloadable == true) {
val id = verticalBlock.id
val children = downloadableChildrenMap[id] ?: listOf()
downloadableChildrenMap[id] = children + block.id
}
}
}

fun logBulkDownloadToggleEvent(toggle: Boolean) {
logEvent(
CoreAnalyticsEvent.VIDEO_BULK_DOWNLOAD_TOGGLE,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -71,7 +71,7 @@ class DownloadHelper(
}
}

suspend fun updateDownloadStatus(downloadModel: DownloadModel): DownloadModel {
suspend fun updateDownloadStatus(downloadModel: DownloadModel): DownloadModel? {
return when (downloadModel.type) {
FileType.VIDEO -> {
downloadModel.copy(
Expand All @@ -81,13 +81,33 @@ class DownloadHelper(
}

FileType.X_BLOCK -> {
val unzippedFolderPath = fileUtil.unzipFile(downloadModel.path)
val unzippedFolderPath = fileUtil.unzipFile(downloadModel.path) ?: return null
downloadModel.copy(
downloadedState = DownloadedState.DOWNLOADED,
size = File(unzippedFolderPath ?: "").length(),
path = unzippedFolderPath ?: ""
size = calculateDirectorySize(File(unzippedFolderPath)),
path = unzippedFolderPath
)
}
}
}

private fun calculateDirectorySize(directory: File): Long {
var size: Long = 0

if (directory.exists()) {
val files = directory.listFiles()

if (files != null) {
for (file in files) {
size += if (file.isDirectory) {
calculateDirectorySize(file)
} else {
file.length()
}
}
}
}

return size
}
}
1 change: 1 addition & 0 deletions core/src/main/res/values/strings.xml
Original file line number Diff line number Diff line change
Expand Up @@ -193,4 +193,5 @@
<string name="course_confirm_download">Confirm Download</string>
<string name="core_edit">Edit</string>
<string name="core_offline_progress_sync">Offline Progress Sync</string>
<string name="core_close">Close</string>
</resources>
2 changes: 1 addition & 1 deletion core/src/openedx/org/openedx/core/ui/theme/Colors.kt
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ val light_secondary = Color(0xFF94D3DD)
val light_secondary_variant = Color(0xFF94D3DD)
val light_background = Color.White
val light_surface = Color(0xFFF7F7F8)
val light_error = Color(0xFFFF3D71)
val light_error = Color(0xFFE8174F)
val light_onPrimary = Color.White
val light_onSecondary = Color.White
val light_onBackground = Color.Black
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -78,7 +78,7 @@ class DownloadConfirmDialogFragment : DialogFragment() {
id = R.string.course_download_on_cellural_dialog_description,
sizeSumString
),
icon = painterResource(id = org.openedx.core.R.drawable.core_ic_warning),
icon = painterResource(id = coreR.drawable.core_ic_warning),
)

DownloadConfirmDialogType.REMOVE -> DownloadDialogResource(
Expand Down Expand Up @@ -214,7 +214,7 @@ private fun DownloadConfirmDialogView(
)
OpenEdXOutlinedButton(
modifier = Modifier.fillMaxWidth(),
text = stringResource(id = org.openedx.core.R.string.core_cancel),
text = stringResource(id = coreR.string.core_cancel),
backgroundColor = MaterialTheme.appColors.background,
borderColor = MaterialTheme.appColors.primaryButtonBackground,
textColor = MaterialTheme.appColors.primaryButtonBackground,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,4 +6,4 @@ import kotlinx.parcelize.Parcelize
@Parcelize
enum class DownloadConfirmDialogType : Parcelable {
DOWNLOAD_ON_CELLULAR, CONFIRM, REMOVE
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ class DownloadDialogManager(
) {

companion object {
const val MAX_CELLULAR_SIZE = 100000000 // 100MB
const val MAX_CELLULAR_SIZE = 104857600 // 100MB
const val DOWNLOAD_SIZE_FACTOR = 2 // Multiplier to match required disk size
}

Expand Down Expand Up @@ -86,7 +86,7 @@ class DownloadDialogManager(
)
}

!corePreferences.videoSettings.wifiDownloadOnly && !networkConnection.isWifiConnected() && uiState.sizeSum >= MAX_CELLULAR_SIZE -> {
!corePreferences.videoSettings.wifiDownloadOnly && !networkConnection.isWifiConnected() -> {
val dialog = DownloadConfirmDialogFragment.newInstance(
dialogType = DownloadConfirmDialogType.DOWNLOAD_ON_CELLULAR,
uiState = uiState
Expand Down Expand Up @@ -220,9 +220,11 @@ class DownloadDialogManager(
) {
CoroutineScope(Dispatchers.IO).launch {
val courseStructure = interactor.getCourseStructure(courseId, false)
val downloadModels = interactor.getAllDownloadModels().map { it.id }
val downloadDialogItems = subSectionsBlocks.mapNotNull { subSectionsBlock ->
val verticalBlocks = courseStructure.blockData.filter { it.id in subSectionsBlock.descendants }
val blocks = courseStructure.blockData.filter { it.id in verticalBlocks.flatMap { it.descendants } }
val blocks =
courseStructure.blockData.filter { it.id in verticalBlocks.flatMap { it.descendants } && it.id !in downloadModels }
val size = blocks.sumOf { getFileSize(it) }
if (size > 0) DownloadDialogItem(title = subSectionsBlock.displayName, size = size) else null
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,4 +14,4 @@ data class DownloadDialogUIState(
val fragmentManager: @RawValue FragmentManager,
val removeDownloadModels: () -> Unit,
val saveDownloadModels: () -> Unit
) : Parcelable
) : Parcelable
Loading

0 comments on commit ec16240

Please sign in to comment.