Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Course bars: Download videos to device and Select download quality bars #239

Merged
Merged
Changes from 1 commit
Commits
Show all changes
76 commits
Select commit Hold shift + click to select a range
5370d1d
chore: add videos downloading bar view
eyatsenkoperpetio Dec 15, 2023
9e16130
chore: add view and logic
eyatsenkoperpetio Dec 15, 2023
32ad2ea
chore: add progress to download data
eyatsenkoperpetio Dec 18, 2023
f88fe44
chore: downloads view
eyatsenkoperpetio Dec 19, 2023
82bb2ff
chore: add strings and fix delete video notif
eyatsenkoperpetio Dec 20, 2023
f1d9872
chore: add total progress for bar
eyatsenkoperpetio Dec 20, 2023
f191a36
chore: changes for no nested list flow
eyatsenkoperpetio Dec 20, 2023
fdca041
fix: showing all downloaded item if open from current course
eyatsenkoperpetio Dec 21, 2023
e6a448a
fix: bar progress
eyatsenkoperpetio Dec 21, 2023
d2258ef
chore: add large file alert and show all downloads in download view
eyatsenkoperpetio Dec 26, 2023
68b6e17
chore: change logic and remove extra code
eyatsenkoperpetio Dec 27, 2023
4030157
refactor: remove extra code
eyatsenkoperpetio Dec 27, 2023
ae7db32
chore: remove extra code
eyatsenkoperpetio Dec 27, 2023
02ccce8
chore: add course storage, refactor
eyatsenkoperpetio Dec 28, 2023
1f40b96
chore: add new video formats
eyatsenkoperpetio Dec 28, 2023
ebc81cd
chore: and video to course block
eyatsenkoperpetio Dec 29, 2023
0b1a83e
chore: add new core data models
eyatsenkoperpetio Dec 29, 2023
451ee45
chore: download manager to async await
eyatsenkoperpetio Dec 29, 2023
4b5ea44
chore: add calculate total size download bar
eyatsenkoperpetio Jan 2, 2024
0f8a930
chore: hide total if zero
eyatsenkoperpetio Jan 3, 2024
16b956f
chore: clean up and fix transparent downloads bar when scroll
eyatsenkoperpetio Jan 3, 2024
930b1c8
chore: add new logic check is downloadable video
eyatsenkoperpetio Jan 3, 2024
7e6c218
chore: add download quality view
eyatsenkoperpetio Jan 4, 2024
24983d2
chore: add select quality for download
eyatsenkoperpetio Jan 5, 2024
6d9e3cb
chore: show alert about change download quality when downloading all …
eyatsenkoperpetio Jan 5, 2024
a868a69
chore: remove extra and add strings
eyatsenkoperpetio Jan 8, 2024
fcdb31d
Merge branch 'feat/166_progress_downloads' into feat/video_download_q…
eyatsenkoperpetio Jan 8, 2024
348b1bc
chore: remove empty line
eyatsenkoperpetio Jan 8, 2024
5257f37
chore: add cancel all download when move to background
eyatsenkoperpetio Jan 8, 2024
23b01a4
Merge branch 'develop' into feat/course_download_quality_bars_dev
eyatsenkoperpetio Jan 9, 2024
269a084
Merge branch 'develop' into feat/course_download_quality_bars_dev
rnr Jan 9, 2024
a1f9f1d
chore: add resume downloading
eyatsenkoperpetio Jan 9, 2024
f288e68
fix: remaining count in bar
eyatsenkoperpetio Jan 9, 2024
d50e4d1
chore: add new logic get quality video
eyatsenkoperpetio Jan 15, 2024
acfc9c8
chore: remove extra code
eyatsenkoperpetio Jan 15, 2024
c1d65e4
chore: improve download quality names
eyatsenkoperpetio Jan 15, 2024
2f8709a
Merge branch 'feat/course_download_quality_bars' into feat/course_dow…
eyatsenkoperpetio Jan 15, 2024
b5761cc
chore: new logic
eyatsenkoperpetio Jan 15, 2024
bb69379
chore: update logic
eyatsenkoperpetio Jan 15, 2024
a3972ad
chore: remove extra code
eyatsenkoperpetio Jan 15, 2024
02a59d0
chore: remove extra
eyatsenkoperpetio Jan 15, 2024
71460e1
chore: change strings
eyatsenkoperpetio Jan 15, 2024
209c1a0
chore: add string
eyatsenkoperpetio Jan 15, 2024
6298260
chore: show remaining files in download bar
eyatsenkoperpetio Jan 15, 2024
475328e
chore: verticals blocks downloadable count nested list
eyatsenkoperpetio Jan 15, 2024
7b30bf0
chore: count of files
eyatsenkoperpetio Jan 15, 2024
8b7723b
chore: add disable download when offline
eyatsenkoperpetio Jan 16, 2024
86c9d48
chore: remove empty line
eyatsenkoperpetio Jan 16, 2024
5f698fe
chore: show delete file when offline
eyatsenkoperpetio Jan 16, 2024
e18a7f1
chore: add Untitled title to download cell view
eyatsenkoperpetio Jan 17, 2024
320daf6
Merge branch 'develop' into feat/course_download_quality_bars_dev_alp…
eyatsenkoperpetio Jan 17, 2024
63512f7
Merge branch 'develop' into feat/course-download-quality-bars
eyatsenkoperpetio Jan 17, 2024
0c3a656
fix: tests
eyatsenkoperpetio Jan 17, 2024
19c3564
chore: PR issues and add accessibility labels
eyatsenkoperpetio Jan 18, 2024
6125d9a
chore: add accessibility identifiers
eyatsenkoperpetio Jan 18, 2024
6b635c2
chore: move video download quality view and refactor
eyatsenkoperpetio Jan 19, 2024
0b16dc6
chore: add cancel all for course
eyatsenkoperpetio Jan 19, 2024
8dc472b
chore: show large alert
eyatsenkoperpetio Jan 19, 2024
50b1649
chore: resolve PR comments
eyatsenkoperpetio Jan 19, 2024
ab1792a
chore: resolve PR comments
eyatsenkoperpetio Jan 19, 2024
e7c3b61
chore: resolve PR comments
eyatsenkoperpetio Jan 19, 2024
ccca6a7
fix: tests
eyatsenkoperpetio Jan 20, 2024
fb20cae
chore: resolve PR comments
eyatsenkoperpetio Jan 29, 2024
d5f904b
chore: resolve PR commnets
eyatsenkoperpetio Jan 29, 2024
318b1ab
chore: rename DownloadData to DownloadDataTask
eyatsenkoperpetio Jan 29, 2024
d4c88cf
chore: use app alert and tests
eyatsenkoperpetio Jan 29, 2024
d67ef53
chore: add confirmation alert when deleting video
eyatsenkoperpetio Jan 30, 2024
d705e59
chore: remove empty line
eyatsenkoperpetio Jan 30, 2024
57aad7f
chore: add strings
eyatsenkoperpetio Jan 30, 2024
baca08c
fix: line length
eyatsenkoperpetio Jan 31, 2024
3c099bf
Merge branch 'develop' into feat/course-download-quality-bars
eyatsenkoperpetio Jan 31, 2024
376368d
Merge branch 'develop' into feat/course-download-quality-bars
eyatsenkoperpetio Jan 31, 2024
81a4512
fix: repeat download
eyatsenkoperpetio Jan 31, 2024
22fa31f
chore: add alert when disable downloading
eyatsenkoperpetio Jan 31, 2024
f7f1ad5
chore: resolve PR commnets
eyatsenkoperpetio Jan 31, 2024
a64de26
chore: update pod version
eyatsenkoperpetio Feb 1, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
chore: changes for no nested list flow
  • Loading branch information
eyatsenkoperpetio committed Dec 20, 2023

Verified

This commit was created on GitHub.com and signed with GitHub’s verified signature.
commit f191a36a5e23a071a734f0ed7f2bdef35cf7264f
14 changes: 8 additions & 6 deletions Core/Core/Network/DownloadManager.swift
Original file line number Diff line number Diff line change
@@ -90,13 +90,14 @@ public protocol DownloadManagerProtocol {
}

public enum DownloadManagerEvent {
case start(DownloadData)
case added
case started(DownloadData)
case progress(Double, DownloadData)
case paused(DownloadData)
case canceled(DownloadData)
case finished(DownloadData)
case deleteFile(String)
case cleared
case deletedFile(String)
case clearedAll
}

public class DownloadManager: DownloadManagerProtocol {
@@ -132,6 +133,7 @@ public class DownloadManager: DownloadManagerProtocol {
public func addToDownloadQueue(blocks: [CourseBlock]) throws {
if userCanDownload() {
persistence.addToDownloadQueue(blocks: blocks)
currentDownloadEventPublisher.send(.added)
guard !isDownloadingInProgress else { return }
try newDownload()
} else {
@@ -147,7 +149,7 @@ public class DownloadManager: DownloadManagerProtocol {
}
currentDownload = download
try downloadFileWithProgress(download)
currentDownloadEventPublisher.send(.start(download))
currentDownloadEventPublisher.send(.started(download))
} else {
throw NoWiFiError()
}
@@ -263,7 +265,7 @@ public class DownloadManager: DownloadManagerProtocol {
for block in blocks {
do {
try persistence.deleteDownloadData(id: block.id)
currentDownloadEventPublisher.send(.deleteFile(block.id))
currentDownloadEventPublisher.send(.deletedFile(block.id))
if let fileURL = fileUrl(for: block.id) {
try FileManager.default.removeItem(at: fileURL)
}
@@ -275,7 +277,7 @@ public class DownloadManager: DownloadManagerProtocol {

public func deleteAllFiles() {
let downloadData = persistence.getAllDownloadData()
currentDownloadEventPublisher.send(.cleared)
currentDownloadEventPublisher.send(.clearedAll)
downloadData.forEach {
if let fileURL = fileUrl(for: $0.id) {
do {
Original file line number Diff line number Diff line change
@@ -72,9 +72,10 @@ public class CourseContainerViewModel: BaseCourseViewModel {

super.init(manager: manager)

manager.publisher()
.sink(receiveValue: { [weak self] _ in
manager.eventPublisher()
.sink(receiveValue: { [weak self] state in
guard let self else { return }
if case .progress = state { return }
DispatchQueue.main.async {
self.setDownloadsStates()
}
@@ -143,22 +144,33 @@ public class CourseContainerViewModel: BaseCourseViewModel {
}

func onDownloadViewTap(chapter: CourseChapter, blockId: String, state: DownloadViewState) {
let blocks = chapter.childs
let verticals = chapter.childs
.first(where: { $0.id == blockId })?.childs
.flatMap { $0.childs }
.filter { $0.isDownloadable } ?? []


let blocks = verticals.flatMap { $0.childs }
.filter { $0.isDownloadable }

do {
switch state {
case .available:
try manager.addToDownloadQueue(blocks: blocks)
sequentialsDownloadState[blockId] = .downloading
verticals.forEach {
verticalsDownloadState[$0.id] = .downloading
}
case .downloading:
try manager.cancelDownloading(courseId: courseStructure?.id ?? "", blocks: blocks)
sequentialsDownloadState[blockId] = .available
verticals.forEach {
verticalsDownloadState[$0.id] = .available
}
case .finished:
manager.deleteFile(blocks: blocks)
sequentialsDownloadState[blockId] = .available
verticals.forEach {
verticalsDownloadState[$0.id] = .available
}
}
} catch let error {
if error is NoWiFiError {
Original file line number Diff line number Diff line change
@@ -96,10 +96,10 @@ final class CourseVideoDownloadBarViewModel: ObservableObject {

private func toggleStateIsOn() {
// Sequentials
let totalCount = courseViewModel.sequentialsDownloadState.count
let availableCount = courseViewModel.sequentialsDownloadState.filter { $0.value == .available }.count
let finishedCount = courseViewModel.sequentialsDownloadState.filter { $0.value == .finished }.count
let downloadingCount = courseViewModel.sequentialsDownloadState.filter { $0.value == .downloading }.count
let totalCount = courseViewModel.verticalsDownloadState.count
let availableCount = courseViewModel.verticalsDownloadState.filter { $0.value == .available }.count
let finishedCount = courseViewModel.verticalsDownloadState.filter { $0.value == .finished }.count
let downloadingCount = courseViewModel.verticalsDownloadState.filter { $0.value == .downloading }.count
if downloadingCount == totalCount {
self.isOn = true
return