|
|
@ -38,6 +38,7 @@ class BookshelfViewModel(application: Application) : BaseViewModel(application) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
fun addBookByUrl(bookUrls: String) { |
|
|
|
fun addBookByUrl(bookUrls: String) { |
|
|
|
|
|
|
|
var successCount = 0 |
|
|
|
execute { |
|
|
|
execute { |
|
|
|
var hasBookUrlPattern: List<BookSource>? = null |
|
|
|
var hasBookUrlPattern: List<BookSource>? = null |
|
|
|
val urls = bookUrls.split("\n") |
|
|
|
val urls = bookUrls.split("\n") |
|
|
@ -59,17 +60,30 @@ class BookshelfViewModel(application: Application) : BaseViewModel(application) |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
source?.let { bookSource -> |
|
|
|
source?.let { bookSource -> |
|
|
|
val book = Book(bookUrl = bookUrl) |
|
|
|
val book = Book( |
|
|
|
|
|
|
|
bookUrl = bookUrl, |
|
|
|
|
|
|
|
origin = bookSource.bookSourceUrl, |
|
|
|
|
|
|
|
originName = bookSource.bookSourceName |
|
|
|
|
|
|
|
) |
|
|
|
|
|
|
|
suspend { |
|
|
|
WebBook(bookSource).getBookInfo(book, this) |
|
|
|
WebBook(bookSource).getBookInfo(book, this) |
|
|
|
.onSuccess(IO) { |
|
|
|
.onSuccess(IO) { |
|
|
|
it?.let { book -> |
|
|
|
it?.let { book -> |
|
|
|
App.db.bookDao().insert(book) |
|
|
|
App.db.bookDao().insert(book) |
|
|
|
|
|
|
|
successCount++ |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
}.onError { |
|
|
|
|
|
|
|
throw Exception(it.localizedMessage) |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
}.onSuccess { |
|
|
|
}.onSuccess { |
|
|
|
|
|
|
|
if (successCount > 0) { |
|
|
|
toast(R.string.success) |
|
|
|
toast(R.string.success) |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
toast("ERROR") |
|
|
|
|
|
|
|
} |
|
|
|
}.onError { |
|
|
|
}.onError { |
|
|
|
toast(it.localizedMessage ?: "ERROR") |
|
|
|
toast(it.localizedMessage ?: "ERROR") |
|
|
|
} |
|
|
|
} |
|
|
|