pull/32/head
kunfei 5 years ago
parent ee88472077
commit 29c03d799a
  1. 179
      app/src/main/java/io/legado/app/ui/sourceedit/SourceEditActivity.kt
  2. 24
      app/src/main/java/io/legado/app/ui/sourceedit/SourceEditViewModel.kt
  3. 12
      app/src/main/res/menu/source_edit.xml

@ -1,6 +1,9 @@
package io.legado.app.ui.sourceedit
import android.app.Activity
import android.content.ClipData
import android.content.ClipboardManager
import android.content.Context
import android.graphics.Rect
import android.os.Bundle
import android.view.Gravity
@ -27,18 +30,19 @@ import org.jetbrains.anko.startActivity
import org.jetbrains.anko.toast
import kotlin.math.abs
class SourceEditActivity : VMBaseActivity<SourceEditViewModel>(R.layout.activity_source_edit, false),
class SourceEditActivity :
VMBaseActivity<SourceEditViewModel>(R.layout.activity_source_edit, false),
KeyboardToolPop.OnClickListener {
override val viewModel: SourceEditViewModel
get() = getViewModel(SourceEditViewModel::class.java)
private val adapter = SourceEditAdapter()
private val sourceEditList: ArrayList<EditEntity> = ArrayList()
private val searchEditList: ArrayList<EditEntity> = ArrayList()
private val findEditList: ArrayList<EditEntity> = ArrayList()
private val infoEditList: ArrayList<EditEntity> = ArrayList()
private val tocEditList: ArrayList<EditEntity> = ArrayList()
private val contentEditList: ArrayList<EditEntity> = ArrayList()
private val sourceEntities: ArrayList<EditEntity> = ArrayList()
private val searchEntities: ArrayList<EditEntity> = ArrayList()
private val findEntities: ArrayList<EditEntity> = ArrayList()
private val infoEntities: ArrayList<EditEntity> = ArrayList()
private val tocEntities: ArrayList<EditEntity> = ArrayList()
private val contentEntities: ArrayList<EditEntity> = ArrayList()
private var mSoftKeyboardTool: PopupWindow? = null
private var mIsSoftKeyBoardShowing = false
@ -80,7 +84,7 @@ class SourceEditActivity : VMBaseActivity<SourceEditViewModel>(R.layout.activity
viewModel.save(bookSource) { setResult(Activity.RESULT_OK); finish() }
}
}
R.id.action_debug_source -> {
R.id.menu_debug_source -> {
val bookSource = getSource()
if (bookSource == null) {
toast("书源名称和URL不能为空")
@ -90,6 +94,13 @@ class SourceEditActivity : VMBaseActivity<SourceEditViewModel>(R.layout.activity
}
}
}
R.id.menu_copy_source -> {
GSON.toJson(getSource())?.let { sourceStr ->
val clipboard = getSystemService(Context.CLIPBOARD_SERVICE) as ClipboardManager?
clipboard?.primaryClip = ClipData.newPlainText(null, sourceStr)
}
}
R.id.menu_paste_source -> viewModel.pasteSource()
}
return super.onCompatOptionsItemSelected(item)
}
@ -117,12 +128,12 @@ class SourceEditActivity : VMBaseActivity<SourceEditViewModel>(R.layout.activity
private fun setEditEntities(tabPosition: Int?) {
when (tabPosition) {
1 -> adapter.editEntities = searchEditList
2 -> adapter.editEntities = findEditList
3 -> adapter.editEntities = infoEditList
4 -> adapter.editEntities = tocEditList
5 -> adapter.editEntities = contentEditList
else -> adapter.editEntities = sourceEditList
1 -> adapter.editEntities = searchEntities
2 -> adapter.editEntities = findEntities
3 -> adapter.editEntities = infoEntities
4 -> adapter.editEntities = tocEntities
5 -> adapter.editEntities = contentEntities
else -> adapter.editEntities = sourceEntities
}
recycler_view.scrollToPosition(0)
}
@ -134,81 +145,89 @@ class SourceEditActivity : VMBaseActivity<SourceEditViewModel>(R.layout.activity
}
//基本信息
with(bookSource) {
sourceEditList.clear()
sourceEditList.add(EditEntity("bookSourceUrl", this?.bookSourceUrl, R.string.book_source_url))
sourceEditList.add(EditEntity("bookSourceName", this?.bookSourceName, R.string.book_source_name))
sourceEditList.add(EditEntity("bookSourceGroup", this?.bookSourceGroup, R.string.book_source_group))
sourceEditList.add(EditEntity("loginUrl", this?.loginUrl, R.string.book_source_login_url))
sourceEditList.add(EditEntity("bookUrlPattern", this?.bookUrlPattern, R.string.book_url_pattern))
sourceEditList.add(EditEntity("header", this?.header, R.string.source_http_header))
sourceEntities.clear()
sourceEntities
.add(EditEntity("bookSourceUrl", this?.bookSourceUrl, R.string.book_source_url))
sourceEntities
.add(EditEntity("bookSourceName", this?.bookSourceName, R.string.book_source_name))
sourceEntities.add(
EditEntity("bookSourceGroup", this?.bookSourceGroup, R.string.book_source_group)
)
sourceEntities
.add(EditEntity("loginUrl", this?.loginUrl, R.string.book_source_login_url))
sourceEntities
.add(EditEntity("bookUrlPattern", this?.bookUrlPattern, R.string.book_url_pattern))
sourceEntities.add(EditEntity("header", this?.header, R.string.source_http_header))
}
//搜索
with(bookSource?.getSearchRule()) {
searchEditList.clear()
searchEditList.add(
EditEntity(
"searchUrl",
bookSource?.searchUrl,
R.string.rule_search_url
)
)
searchEditList.add(EditEntity("bookList", this?.bookList, R.string.rule_book_list))
searchEditList.add(EditEntity("name", this?.name, R.string.rule_book_name))
searchEditList.add(EditEntity("author", this?.author, R.string.rule_book_author))
searchEditList.add(EditEntity("kind", this?.kind, R.string.rule_book_kind))
searchEditList.add(EditEntity("wordCount", this?.wordCount, R.string.rule_word_count))
searchEditList.add(EditEntity("lastChapter", this?.lastChapter, R.string.rule_last_chapter))
searchEditList.add(EditEntity("intro", this?.intro, R.string.rule_book_intro))
searchEditList.add(EditEntity("coverUrl", this?.coverUrl, R.string.rule_cover_url))
searchEditList.add(EditEntity("bookUrl", this?.bookUrl, R.string.rule_book_url))
searchEntities.clear()
searchEntities
.add(EditEntity("searchUrl", bookSource?.searchUrl, R.string.rule_search_url))
searchEntities.add(EditEntity("bookList", this?.bookList, R.string.rule_book_list))
searchEntities.add(EditEntity("name", this?.name, R.string.rule_book_name))
searchEntities.add(EditEntity("author", this?.author, R.string.rule_book_author))
searchEntities.add(EditEntity("kind", this?.kind, R.string.rule_book_kind))
searchEntities.add(EditEntity("wordCount", this?.wordCount, R.string.rule_word_count))
searchEntities
.add(EditEntity("lastChapter", this?.lastChapter, R.string.rule_last_chapter))
searchEntities.add(EditEntity("intro", this?.intro, R.string.rule_book_intro))
searchEntities.add(EditEntity("coverUrl", this?.coverUrl, R.string.rule_cover_url))
searchEntities.add(EditEntity("bookUrl", this?.bookUrl, R.string.rule_book_url))
}
//详情页
with(bookSource?.getBookInfoRule()) {
infoEditList.clear()
infoEditList.add(EditEntity("init", this?.init, R.string.rule_book_info_init))
infoEditList.add(EditEntity("name", this?.name, R.string.rule_book_name))
infoEditList.add(EditEntity("author", this?.author, R.string.rule_book_author))
infoEditList.add(EditEntity("coverUrl", this?.coverUrl, R.string.rule_cover_url))
infoEditList.add(EditEntity("intro", this?.intro, R.string.rule_book_intro))
infoEditList.add(EditEntity("kind", this?.kind, R.string.rule_book_kind))
infoEditList.add(EditEntity("wordCount", this?.wordCount, R.string.rule_word_count))
infoEditList.add(EditEntity("lastChapter", this?.lastChapter, R.string.rule_last_chapter))
infoEditList.add(EditEntity("tocUrl", this?.tocUrl, R.string.rule_toc_url))
infoEntities.clear()
infoEntities.add(EditEntity("init", this?.init, R.string.rule_book_info_init))
infoEntities.add(EditEntity("name", this?.name, R.string.rule_book_name))
infoEntities.add(EditEntity("author", this?.author, R.string.rule_book_author))
infoEntities.add(EditEntity("coverUrl", this?.coverUrl, R.string.rule_cover_url))
infoEntities.add(EditEntity("intro", this?.intro, R.string.rule_book_intro))
infoEntities.add(EditEntity("kind", this?.kind, R.string.rule_book_kind))
infoEntities.add(EditEntity("wordCount", this?.wordCount, R.string.rule_word_count))
infoEntities.add(
EditEntity("lastChapter", this?.lastChapter, R.string.rule_last_chapter)
)
infoEntities.add(EditEntity("tocUrl", this?.tocUrl, R.string.rule_toc_url))
}
//目录页
with(bookSource?.getTocRule()) {
tocEditList.clear()
tocEditList.add(EditEntity("chapterList", this?.chapterList, R.string.rule_chapter_list))
tocEditList.add(EditEntity("chapterName", this?.chapterName, R.string.rule_chapter_name))
tocEditList.add(EditEntity("chapterUrl", this?.chapterUrl, R.string.rule_chapter_url))
tocEditList.add(EditEntity("nextTocUrl", this?.nextTocUrl, R.string.rule_next_toc_url))
tocEntities.clear()
tocEntities.add(
EditEntity("chapterList", this?.chapterList, R.string.rule_chapter_list)
)
tocEntities.add(
EditEntity("chapterName", this?.chapterName, R.string.rule_chapter_name)
)
tocEntities.add(EditEntity("chapterUrl", this?.chapterUrl, R.string.rule_chapter_url))
tocEntities.add(EditEntity("nextTocUrl", this?.nextTocUrl, R.string.rule_next_toc_url))
}
//正文页
with(bookSource?.getContentRule()) {
contentEditList.clear()
contentEditList.add(EditEntity("content", this?.content, R.string.rule_book_content))
contentEditList.add(EditEntity("nextContentUrl", this?.nextContentUrl, R.string.rule_content_url_next))
contentEntities.clear()
contentEntities.add(EditEntity("content", this?.content, R.string.rule_book_content))
contentEntities.add(
EditEntity("nextContentUrl", this?.nextContentUrl, R.string.rule_content_url_next)
)
}
//发现
with(bookSource?.getExploreRule()) {
findEditList.clear()
findEditList.add(
EditEntity(
"exploreUrl",
bookSource?.exploreUrl,
R.string.rule_find_url
)
findEntities.clear()
findEntities.add(
EditEntity("exploreUrl", bookSource?.exploreUrl, R.string.rule_find_url)
)
findEntities.add(EditEntity("bookList", this?.bookList, R.string.rule_book_list))
findEntities.add(EditEntity("name", this?.name, R.string.rule_book_name))
findEntities.add(EditEntity("author", this?.author, R.string.rule_book_author))
findEntities.add(EditEntity("kind", this?.kind, R.string.rule_book_kind))
findEntities.add(EditEntity("wordCount", this?.wordCount, R.string.rule_word_count))
findEntities.add(EditEntity("intro", this?.intro, R.string.rule_book_intro))
findEntities.add(
EditEntity("lastChapter", this?.lastChapter, R.string.rule_last_chapter)
)
findEditList.add(EditEntity("bookList", this?.bookList, R.string.rule_book_list))
findEditList.add(EditEntity("name", this?.name, R.string.rule_book_name))
findEditList.add(EditEntity("author", this?.author, R.string.rule_book_author))
findEditList.add(EditEntity("kind", this?.kind, R.string.rule_book_kind))
findEditList.add(EditEntity("wordCount", this?.wordCount, R.string.rule_word_count))
findEditList.add(EditEntity("intro", this?.intro, R.string.rule_book_intro))
findEditList.add(EditEntity("lastChapter", this?.lastChapter, R.string.rule_last_chapter))
findEditList.add(EditEntity("coverUrl", this?.coverUrl, R.string.rule_cover_url))
findEditList.add(EditEntity("bookUrl", this?.bookUrl, R.string.rule_book_url))
findEntities.add(EditEntity("coverUrl", this?.coverUrl, R.string.rule_cover_url))
findEntities.add(EditEntity("bookUrl", this?.bookUrl, R.string.rule_book_url))
}
setEditEntities(0)
}
@ -226,11 +245,11 @@ class SourceEditActivity : VMBaseActivity<SourceEditViewModel>(R.layout.activity
val bookInfoRule = BookInfoRule()
val tocRule = TocRule()
val contentRule = ContentRule()
for (entity in sourceEditList) {
for (entity in sourceEntities) {
with(entity) {
when (key) {
"bookSourceUrl" -> if (value != null) source.bookSourceUrl = value!! else return null
"bookSourceName" -> if (value != null) source.bookSourceName = value!! else return null
"bookSourceUrl" -> value?.let { source.bookSourceUrl = it } ?: return null
"bookSourceName" -> value?.let { source.bookSourceName = it } ?: return null
"bookSourceGroup" -> source.bookSourceGroup = value
"loginUrl" -> source.loginUrl = value
"bookUrlPattern" -> source.bookUrlPattern = value
@ -238,7 +257,7 @@ class SourceEditActivity : VMBaseActivity<SourceEditViewModel>(R.layout.activity
}
}
}
for (entity in searchEditList) {
for (entity in searchEntities) {
with(entity) {
when (key) {
"searchUrl" -> source.searchUrl = value
@ -255,7 +274,7 @@ class SourceEditActivity : VMBaseActivity<SourceEditViewModel>(R.layout.activity
}
}
}
for (entity in findEditList) {
for (entity in findEntities) {
with(entity) {
when (key) {
"exploreUrl" -> source.exploreUrl = value
@ -272,7 +291,7 @@ class SourceEditActivity : VMBaseActivity<SourceEditViewModel>(R.layout.activity
}
}
}
for (entity in infoEditList) {
for (entity in infoEntities) {
with(entity) {
when (key) {
"init" -> bookInfoRule.init = value
@ -288,7 +307,7 @@ class SourceEditActivity : VMBaseActivity<SourceEditViewModel>(R.layout.activity
}
}
}
for (entity in tocEditList) {
for (entity in tocEntities) {
with(entity) {
when (key) {
"chapterList" -> tocRule.chapterList = value
@ -298,7 +317,7 @@ class SourceEditActivity : VMBaseActivity<SourceEditViewModel>(R.layout.activity
}
}
}
for (entity in contentEditList) {
for (entity in contentEntities) {
with(entity) {
when (key) {
"content" -> contentRule.content = value

@ -1,19 +1,20 @@
package io.legado.app.ui.sourceedit
import android.app.Application
import android.content.ClipboardManager
import android.content.Context
import androidx.lifecycle.MutableLiveData
import io.legado.app.App
import io.legado.app.base.BaseViewModel
import io.legado.app.data.entities.BookSource
import kotlinx.coroutines.Dispatchers.IO
import kotlinx.coroutines.launch
import io.legado.app.help.storage.OldRule
class SourceEditViewModel(application: Application) : BaseViewModel(application) {
val sourceLiveData: MutableLiveData<BookSource> = MutableLiveData()
fun setBookSource(key: String) {
launch(IO) {
execute {
App.db.bookSourceDao().getBookSource(key)?.let {
sourceLiveData.postValue(it)
} ?: sourceLiveData.postValue(BookSource())
@ -21,14 +22,27 @@ class SourceEditViewModel(application: Application) : BaseViewModel(application)
}
fun save(bookSource: BookSource, finally: (() -> Unit)? = null) {
launch(IO) {
execute {
if (bookSource.customOrder == 0) {
bookSource.customOrder = App.db.bookSourceDao().allCount()
}
App.db.bookSourceDao().insert(bookSource)
}.onFinally {
finally?.let { it() }
}
}
fun pasteSource() {
execute {
val clipboard = context.getSystemService(Context.CLIPBOARD_SERVICE) as ClipboardManager?
clipboard?.primaryClip?.let {
if (it.itemCount > 0) {
val json = it.getItemAt(0).text.toString()
OldRule.jsonToBookSource(json)?.let { source ->
sourceLiveData.postValue(source)
} ?: toast("格式不对")
}
}
}
}
}

@ -9,7 +9,7 @@
app:showAsAction="ifRoom" />
<item
android:id="@+id/action_debug_source"
android:id="@+id/menu_debug_source"
android:icon="@drawable/ic_bug_report"
android:title="@string/debug_source"
app:showAsAction="ifRoom" />
@ -20,22 +20,22 @@
app:showAsAction="never" />
<item
android:id="@+id/action_copy_source"
android:id="@+id/menu_copy_source"
android:title="@string/copy_source"
app:showAsAction="never" />
<item
android:id="@+id/action_paste_source"
android:id="@+id/menu_paste_source"
android:title="@string/paste_source"
app:showAsAction="never" />
<item
android:id="@+id/action_qr_code_camera"
android:id="@+id/menu_qr_code_camera"
android:title="@string/import_by_qr_code"
app:showAsAction="never" />
<item
android:id="@+id/action_share_it"
android:id="@+id/menu_share_it"
android:title="@string/qr_share"
app:showAsAction="never" />
@ -45,7 +45,7 @@
app:showAsAction="never" />
<item
android:id="@+id/action_rule_summary"
android:id="@+id/menu_rule_summary"
android:title="@string/rule_summary"
app:showAsAction="never" />

Loading…
Cancel
Save