版本更新
This commit is contained in:
parent
5c3d4f09c9
commit
f9dee274b0
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
|
@ -24,11 +24,11 @@ android {
|
||||||
buildToolsVersion "30.0.3"
|
buildToolsVersion "30.0.3"
|
||||||
|
|
||||||
defaultConfig {
|
defaultConfig {
|
||||||
applicationId "com.coldmint.rust.beta"
|
applicationId "com.coldmint.rust.pro"
|
||||||
minSdkVersion 21
|
minSdkVersion 21
|
||||||
targetSdkVersion 32
|
targetSdkVersion 32
|
||||||
versionCode 18
|
versionCode 19
|
||||||
versionName "2.1 alpha1 (2022-8-25)"
|
versionName "2.1 Beta1 (2022-9-1)"
|
||||||
|
|
||||||
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
|
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
|
||||||
}
|
}
|
||||||
|
|
20
app/release/output-metadata.json
Normal file
20
app/release/output-metadata.json
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
{
|
||||||
|
"version": 3,
|
||||||
|
"artifactType": {
|
||||||
|
"type": "APK",
|
||||||
|
"kind": "Directory"
|
||||||
|
},
|
||||||
|
"applicationId": "com.coldmint.rust.pro",
|
||||||
|
"variantName": "release",
|
||||||
|
"elements": [
|
||||||
|
{
|
||||||
|
"type": "SINGLE",
|
||||||
|
"filters": [],
|
||||||
|
"attributes": [],
|
||||||
|
"versionCode": 19,
|
||||||
|
"versionName": "2.1 Beta1 (2022-9-1)",
|
||||||
|
"outputFile": "app-release.apk"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"elementType": "File"
|
||||||
|
}
|
|
@ -65,14 +65,14 @@ class SearchActivity : BaseActivity<ActivitySearchBinding>() {
|
||||||
|
|
||||||
override fun onQueryTextChange(newText: String?): Boolean {
|
override fun onQueryTextChange(newText: String?): Boolean {
|
||||||
if (newText != null && newText.isNotBlank()) {
|
if (newText != null && newText.isNotBlank()) {
|
||||||
// viewBinding.searchSuggestionsView.setText(R.string.search_suggestions_loading)
|
viewBinding.searchSuggestionsView.setText(R.string.search_suggestions_loading)
|
||||||
Search.instance.suggestions(newText,
|
Search.instance.suggestions(newText,
|
||||||
object : ApiCallBack<SearchSuggestionsData> {
|
object : ApiCallBack<SearchSuggestionsData> {
|
||||||
override fun onResponse(t: SearchSuggestionsData) {
|
override fun onResponse(t: SearchSuggestionsData) {
|
||||||
val dataList = t.data
|
val dataList = t.data
|
||||||
if (dataList.isNullOrEmpty()) {
|
if (dataList.isEmpty()) {
|
||||||
viewBinding.recyclerView.isVisible = false
|
viewBinding.recyclerView.isVisible = false
|
||||||
// viewBinding.searchSuggestionsView.setText(R.string.search_suggestions_null)
|
viewBinding.searchSuggestionsView.setText(R.string.search_suggestions_null)
|
||||||
} else {
|
} else {
|
||||||
val adapter =
|
val adapter =
|
||||||
SearchSuggestionsAdapter(
|
SearchSuggestionsAdapter(
|
||||||
|
@ -92,20 +92,20 @@ class SearchActivity : BaseActivity<ActivitySearchBinding>() {
|
||||||
}
|
}
|
||||||
viewBinding.recyclerView.adapter = adapter
|
viewBinding.recyclerView.adapter = adapter
|
||||||
viewBinding.recyclerView.isVisible = true
|
viewBinding.recyclerView.isVisible = true
|
||||||
// val s = String.format(getString(R.string.search_suggestions_number),dataList.size)
|
val s = String.format(getString(R.string.search_suggestions_number),dataList.size)
|
||||||
// viewBinding.searchSuggestionsView.text = s
|
viewBinding.searchSuggestionsView.text = s
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onFailure(e: Exception) {
|
override fun onFailure(e: Exception) {
|
||||||
|
|
||||||
viewBinding.recyclerView.isVisible = false
|
viewBinding.recyclerView.isVisible = false
|
||||||
// viewBinding.searchSuggestionsView.setText(R.string.search_suggestions_null)
|
viewBinding.searchSuggestionsView.setText(R.string.search_suggestions_null)
|
||||||
}
|
}
|
||||||
|
|
||||||
})
|
})
|
||||||
} else {
|
} else {
|
||||||
// viewBinding.searchSuggestionsView.setText(R.string.search_suggestions_null)
|
viewBinding.searchSuggestionsView.setText(R.string.search_suggestions_null)
|
||||||
viewBinding.recyclerView.isVisible = false
|
viewBinding.recyclerView.isVisible = false
|
||||||
}
|
}
|
||||||
return true
|
return true
|
||||||
|
|
|
@ -55,7 +55,7 @@ class UserHomePageActivity : BaseActivity<ActivityUserHomePageBinding>() {
|
||||||
private fun initView() {
|
private fun initView() {
|
||||||
// immersionBar {
|
// immersionBar {
|
||||||
// transparentStatusBar().statusBarDarkFont(true)
|
// transparentStatusBar().statusBarDarkFont(true)
|
||||||
// .navigationBarColor(R.color.white_200).navigationBarDarkIcon(true)
|
// .navigationBarDarkIcon(true)
|
||||||
// }
|
// }
|
||||||
|
|
||||||
val thisIntent = intent
|
val thisIntent = intent
|
||||||
|
|
|
@ -7,6 +7,7 @@ import android.view.LayoutInflater
|
||||||
import android.view.View
|
import android.view.View
|
||||||
import android.widget.Toast
|
import android.widget.Toast
|
||||||
import androidx.core.view.isVisible
|
import androidx.core.view.isVisible
|
||||||
|
import androidx.recyclerview.widget.DividerItemDecoration
|
||||||
import androidx.recyclerview.widget.LinearLayoutManager
|
import androidx.recyclerview.widget.LinearLayoutManager
|
||||||
import com.afollestad.materialdialogs.MaterialDialog
|
import com.afollestad.materialdialogs.MaterialDialog
|
||||||
import com.afollestad.materialdialogs.checkbox.BooleanCallback
|
import com.afollestad.materialdialogs.checkbox.BooleanCallback
|
||||||
|
@ -67,6 +68,14 @@ class UserListActivity : BaseActivity<ActivityUserListBinding>() {
|
||||||
getString(R.string.fans)
|
getString(R.string.fans)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
viewBinding.recyclerView.layoutManager =
|
||||||
|
LinearLayoutManager(this@UserListActivity)
|
||||||
|
viewBinding.recyclerView.addItemDecoration(
|
||||||
|
DividerItemDecoration(
|
||||||
|
this,
|
||||||
|
DividerItemDecoration.VERTICAL
|
||||||
|
)
|
||||||
|
)
|
||||||
loadList(account, isFollowMode, canRemoveFans)
|
loadList(account, isFollowMode, canRemoveFans)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -90,8 +99,7 @@ class UserListActivity : BaseActivity<ActivityUserListBinding>() {
|
||||||
viewBinding.loadLayout.isVisible = false
|
viewBinding.loadLayout.isVisible = false
|
||||||
viewBinding.recyclerView.isVisible = true
|
viewBinding.recyclerView.isVisible = true
|
||||||
val adapter = UserAdapter(this@UserListActivity, dataList)
|
val adapter = UserAdapter(this@UserListActivity, dataList)
|
||||||
viewBinding.recyclerView.layoutManager =
|
|
||||||
LinearLayoutManager(this@UserListActivity)
|
|
||||||
adapter.setItemEvent { i, itemUserBinding, viewHolder, data ->
|
adapter.setItemEvent { i, itemUserBinding, viewHolder, data ->
|
||||||
itemUserBinding.root.setOnClickListener {
|
itemUserBinding.root.setOnClickListener {
|
||||||
val intent = Intent(
|
val intent = Intent(
|
||||||
|
|
|
@ -25,6 +25,7 @@ import com.afollestad.materialdialogs.input.getInputField
|
||||||
import com.afollestad.materialdialogs.input.input
|
import com.afollestad.materialdialogs.input.input
|
||||||
import com.bumptech.glide.Glide
|
import com.bumptech.glide.Glide
|
||||||
import com.bumptech.glide.request.RequestOptions
|
import com.bumptech.glide.request.RequestOptions
|
||||||
|
import com.coldmint.dialog.CoreDialog
|
||||||
import com.coldmint.rust.core.ModClass
|
import com.coldmint.rust.core.ModClass
|
||||||
import com.coldmint.rust.core.dataBean.ApiResponse
|
import com.coldmint.rust.core.dataBean.ApiResponse
|
||||||
import com.coldmint.rust.core.dataBean.mod.WebModCommentData
|
import com.coldmint.rust.core.dataBean.mod.WebModCommentData
|
||||||
|
@ -76,7 +77,7 @@ class WebModInfoActivity : BaseActivity<ActivityWebModInfoBinding>() {
|
||||||
val token by lazy {
|
val token by lazy {
|
||||||
AppSettings.getValue(AppSettings.Setting.Token, "")
|
AppSettings.getValue(AppSettings.Setting.Token, "")
|
||||||
}
|
}
|
||||||
lateinit var adapter :ModPageDetailsAdapter
|
lateinit var adapter: ModPageDetailsAdapter
|
||||||
|
|
||||||
private fun initView() {
|
private fun initView() {
|
||||||
setReturnButton()
|
setReturnButton()
|
||||||
|
@ -99,6 +100,9 @@ class WebModInfoActivity : BaseActivity<ActivityWebModInfoBinding>() {
|
||||||
viewBinding.button.text = getString(R.string.installated)
|
viewBinding.button.text = getString(R.string.installated)
|
||||||
}
|
}
|
||||||
adapter = ModPageDetailsAdapter(this, modId)
|
adapter = ModPageDetailsAdapter(this, modId)
|
||||||
|
adapter.modName.observe(this) {
|
||||||
|
title = it
|
||||||
|
}
|
||||||
viewBinding.viewPager2.adapter = adapter
|
viewBinding.viewPager2.adapter = adapter
|
||||||
TabLayoutMediator(viewBinding.tabLayout, viewBinding.viewPager2) { tab, i ->
|
TabLayoutMediator(viewBinding.tabLayout, viewBinding.viewPager2) { tab, i ->
|
||||||
tab.text = when (i) {
|
tab.text = when (i) {
|
||||||
|
@ -116,16 +120,16 @@ class WebModInfoActivity : BaseActivity<ActivityWebModInfoBinding>() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}.attach()
|
}.attach()
|
||||||
// viewBinding.button.setOnClickListener {
|
viewBinding.button.setOnClickListener {
|
||||||
// val type = viewBinding.button.text
|
val type = viewBinding.button.text
|
||||||
// val installation = getString(R.string.installation)
|
val installation = getString(R.string.installation)
|
||||||
// when (type) {
|
when (type) {
|
||||||
// installation -> {
|
installation -> {
|
||||||
// downloadAction(t)
|
downloadAction(adapter.getLink())
|
||||||
// }
|
}
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// }
|
}
|
||||||
// viewBinding.modCommentRecyclerView.layoutManager =
|
// viewBinding.modCommentRecyclerView.layoutManager =
|
||||||
// LinearLayoutManager(this@WebModInfoActivity)
|
// LinearLayoutManager(this@WebModInfoActivity)
|
||||||
// viewBinding.modCommentRecyclerView.addItemDecoration(
|
// viewBinding.modCommentRecyclerView.addItemDecoration(
|
||||||
|
@ -275,8 +279,11 @@ class WebModInfoActivity : BaseActivity<ActivityWebModInfoBinding>() {
|
||||||
* 下载事件
|
* 下载事件
|
||||||
* @param t WebModInfoData
|
* @param t WebModInfoData
|
||||||
*/
|
*/
|
||||||
fun downloadAction(t: WebModInfoData) {
|
fun downloadAction(link: String?) {
|
||||||
val fileLink = ServerConfiguration.getRealLink(t.data.link)
|
if (link == null) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
val fileLink = ServerConfiguration.getRealLink(link)
|
||||||
when (AppOperator.getNetworkType(this)) {
|
when (AppOperator.getNetworkType(this)) {
|
||||||
AppOperator.NetWorkType.NetWorkType_Moble -> {
|
AppOperator.NetWorkType.NetWorkType_Moble -> {
|
||||||
val useMobileNetWork =
|
val useMobileNetWork =
|
||||||
|
@ -284,19 +291,16 @@ class WebModInfoActivity : BaseActivity<ActivityWebModInfoBinding>() {
|
||||||
if (useMobileNetWork) {
|
if (useMobileNetWork) {
|
||||||
downloadWork(fileLink)
|
downloadWork(fileLink)
|
||||||
} else {
|
} else {
|
||||||
MaterialDialog(this).show {
|
CoreDialog(this).setTitle(R.string.using_mobile_networks)
|
||||||
title(R.string.using_mobile_networks).message(R.string.using_mobile_networks_msg)
|
.setMessage(R.string.using_mobile_networks_msg)
|
||||||
.positiveButton(R.string.only_one) {
|
.setPositiveButton(R.string.only_one) {
|
||||||
downloadWork(fileLink)
|
downloadWork(fileLink)
|
||||||
}
|
}.setNegativeButton(R.string.always_allow) {
|
||||||
negativeButton(R.string.always_allow) {
|
|
||||||
AppSettings.setValue(AppSettings.Setting.UseMobileNetwork, true)
|
AppSettings.setValue(AppSettings.Setting.UseMobileNetwork, true)
|
||||||
downloadWork(fileLink)
|
downloadWork(fileLink)
|
||||||
}
|
}.setNeutralButton(R.string.dialog_cancel) {
|
||||||
neutralButton(R.string.dialog_cancel) {
|
|
||||||
|
|
||||||
}
|
}.show()
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
AppOperator.NetWorkType.NetWorkType_Wifi -> {
|
AppOperator.NetWorkType.NetWorkType_Wifi -> {
|
||||||
|
@ -359,11 +363,6 @@ class WebModInfoActivity : BaseActivity<ActivityWebModInfoBinding>() {
|
||||||
val loadFileLayoutBinding = LoadFileLayoutBinding.inflate(layoutInflater)
|
val loadFileLayoutBinding = LoadFileLayoutBinding.inflate(layoutInflater)
|
||||||
loadFileLayoutBinding.LinearProgressIndicator.max = 100
|
loadFileLayoutBinding.LinearProgressIndicator.max = 100
|
||||||
var progress = 0
|
var progress = 0
|
||||||
val materialDialog = MaterialDialog(this).show {
|
|
||||||
title(R.string.downlod).customView(view = loadFileLayoutBinding.root)
|
|
||||||
.cancelable(false)
|
|
||||||
.positiveButton(R.string.dialog_close)
|
|
||||||
}
|
|
||||||
|
|
||||||
val fileLoader = FileLoader.getInstantiate(fileLink, targetFile.absolutePath)
|
val fileLoader = FileLoader.getInstantiate(fileLink, targetFile.absolutePath)
|
||||||
fileLoader.download(object : ProgressResponseBody.ResponseProgressListener {
|
fileLoader.download(object : ProgressResponseBody.ResponseProgressListener {
|
||||||
|
@ -376,25 +375,15 @@ class WebModInfoActivity : BaseActivity<ActivityWebModInfoBinding>() {
|
||||||
progress = trueProgress.toFloat().toInt()
|
progress = trueProgress.toFloat().toInt()
|
||||||
runOnUiThread {
|
runOnUiThread {
|
||||||
val progressTip = String.format(tip, progress)
|
val progressTip = String.format(tip, progress)
|
||||||
if (materialDialog.isShowing) {
|
|
||||||
loadFileLayoutBinding.LinearProgressIndicator.progress = progress
|
|
||||||
loadFileLayoutBinding.tipView.text = progressTip
|
|
||||||
}
|
|
||||||
viewBinding.button.text = progressTip
|
viewBinding.button.text = progressTip
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun downloadFail(exception: Exception?) {
|
override fun downloadFail(exception: Exception?) {
|
||||||
if (materialDialog.isShowing) {
|
|
||||||
materialDialog.dismiss()
|
|
||||||
}
|
|
||||||
viewBinding.button.setText(R.string.installation)
|
viewBinding.button.setText(R.string.installation)
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun downloadSuccess() {
|
override fun downloadSuccess() {
|
||||||
if (materialDialog.isShowing) {
|
|
||||||
materialDialog.dismiss()
|
|
||||||
}
|
|
||||||
viewBinding.button.isEnabled = false
|
viewBinding.button.isEnabled = false
|
||||||
viewBinding.button.setText(R.string.installated)
|
viewBinding.button.setText(R.string.installated)
|
||||||
WebMod.instance.addDownloadNum(modId)
|
WebMod.instance.addDownloadNum(modId)
|
||||||
|
|
|
@ -8,6 +8,7 @@ import android.view.View
|
||||||
import android.widget.PopupMenu
|
import android.widget.PopupMenu
|
||||||
import android.widget.Toast
|
import android.widget.Toast
|
||||||
import androidx.core.view.isVisible
|
import androidx.core.view.isVisible
|
||||||
|
import androidx.recyclerview.widget.DividerItemDecoration
|
||||||
import androidx.recyclerview.widget.LinearLayoutManager
|
import androidx.recyclerview.widget.LinearLayoutManager
|
||||||
import com.afollestad.materialdialogs.MaterialDialog
|
import com.afollestad.materialdialogs.MaterialDialog
|
||||||
import com.coldmint.rust.core.dataBean.ApiResponse
|
import com.coldmint.rust.core.dataBean.ApiResponse
|
||||||
|
@ -258,6 +259,12 @@ class WorkManagementActivity : BaseActivity<ActivityWorkmangementBinding>() {
|
||||||
title = getString(R.string.work_management)
|
title = getString(R.string.work_management)
|
||||||
setReturnButton()
|
setReturnButton()
|
||||||
viewBinding.recyclerView.layoutManager = LinearLayoutManager(this)
|
viewBinding.recyclerView.layoutManager = LinearLayoutManager(this)
|
||||||
|
viewBinding.recyclerView.addItemDecoration(
|
||||||
|
DividerItemDecoration(
|
||||||
|
this,
|
||||||
|
DividerItemDecoration.VERTICAL
|
||||||
|
)
|
||||||
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,52 @@
|
||||||
|
package com.coldmint.rust.pro.adapters
|
||||||
|
|
||||||
|
import android.content.Context
|
||||||
|
import android.view.LayoutInflater
|
||||||
|
import android.view.ViewGroup
|
||||||
|
import com.bumptech.glide.Glide
|
||||||
|
import com.coldmint.rust.core.dataBean.mod.InsertCoinHistoryData
|
||||||
|
import com.coldmint.rust.core.web.ServerConfiguration
|
||||||
|
import com.coldmint.rust.pro.R
|
||||||
|
import com.coldmint.rust.pro.base.BaseAdapter
|
||||||
|
import com.coldmint.rust.pro.databinding.ItemInsertCoinsBinding
|
||||||
|
import com.coldmint.rust.pro.tool.GlobalMethod
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 投币记录适配器
|
||||||
|
* @constructor
|
||||||
|
*/
|
||||||
|
class InsertCoinsAdapter(context: Context, dataList: MutableList<InsertCoinHistoryData.Data>) :
|
||||||
|
BaseAdapter<ItemInsertCoinsBinding, InsertCoinHistoryData.Data>(context, dataList) {
|
||||||
|
|
||||||
|
private val insertCoinsTip by lazy {
|
||||||
|
context.getString(R.string.insert_coins_tip)
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun getViewBindingObject(
|
||||||
|
layoutInflater: LayoutInflater,
|
||||||
|
parent: ViewGroup,
|
||||||
|
viewType: Int
|
||||||
|
): ItemInsertCoinsBinding {
|
||||||
|
return ItemInsertCoinsBinding.inflate(layoutInflater, parent, false)
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun onBingView(
|
||||||
|
data: InsertCoinHistoryData.Data,
|
||||||
|
viewBinding: ItemInsertCoinsBinding,
|
||||||
|
viewHolder: ViewHolder<ItemInsertCoinsBinding>,
|
||||||
|
position: Int
|
||||||
|
) {
|
||||||
|
val icon = data.headIcon
|
||||||
|
if (icon == null) {
|
||||||
|
Glide.with(context).load(R.drawable.head_icon).into(viewBinding.imageView)
|
||||||
|
} else {
|
||||||
|
Glide.with(context).load(ServerConfiguration.getRealLink(icon))
|
||||||
|
.apply(GlobalMethod.getRequestOptions(true)).into(viewBinding.imageView)
|
||||||
|
}
|
||||||
|
viewBinding.numberOfCoinView.text = String.format(insertCoinsTip, data.number)
|
||||||
|
viewBinding.timeView.text = data.time
|
||||||
|
viewBinding.nameView.text = data.userName
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
|
@ -2,7 +2,9 @@ package com.coldmint.rust.pro.adapters
|
||||||
|
|
||||||
import androidx.fragment.app.Fragment
|
import androidx.fragment.app.Fragment
|
||||||
import androidx.fragment.app.FragmentActivity
|
import androidx.fragment.app.FragmentActivity
|
||||||
|
import androidx.lifecycle.MutableLiveData
|
||||||
import androidx.viewpager2.adapter.FragmentStateAdapter
|
import androidx.viewpager2.adapter.FragmentStateAdapter
|
||||||
|
import com.coldmint.rust.core.dataBean.mod.WebModInfoData
|
||||||
import com.coldmint.rust.core.tool.DebugHelper
|
import com.coldmint.rust.core.tool.DebugHelper
|
||||||
import com.coldmint.rust.pro.fragments.InsertCoinsFragment
|
import com.coldmint.rust.pro.fragments.InsertCoinsFragment
|
||||||
import com.coldmint.rust.pro.fragments.ModCommentsFragment
|
import com.coldmint.rust.pro.fragments.ModCommentsFragment
|
||||||
|
@ -21,6 +23,24 @@ class ModPageDetailsAdapter(fragmentActivity: FragmentActivity, val modId: Strin
|
||||||
return 3
|
return 3
|
||||||
}
|
}
|
||||||
|
|
||||||
|
val modName: MutableLiveData<String> by lazy {
|
||||||
|
MutableLiveData()
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取下载链接
|
||||||
|
* @return String?
|
||||||
|
*/
|
||||||
|
fun getLink(): String? {
|
||||||
|
return if (this::webModDetailsFragment.isInitialized) {
|
||||||
|
webModDetailsFragment.getLink()
|
||||||
|
} else {
|
||||||
|
DebugHelper.printLog("获取下载路径", "详情碎片未初始化,返回null", isError = true)
|
||||||
|
null
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取此模组是否对外开放
|
* 获取此模组是否对外开放
|
||||||
* @return Boolean
|
* @return Boolean
|
||||||
|
@ -38,7 +58,7 @@ class ModPageDetailsAdapter(fragmentActivity: FragmentActivity, val modId: Strin
|
||||||
return when (position) {
|
return when (position) {
|
||||||
0 -> {
|
0 -> {
|
||||||
if (!this::webModDetailsFragment.isInitialized) {
|
if (!this::webModDetailsFragment.isInitialized) {
|
||||||
webModDetailsFragment = WebModDetailsFragment(modId)
|
webModDetailsFragment = WebModDetailsFragment(modId, modName)
|
||||||
}
|
}
|
||||||
webModDetailsFragment
|
webModDetailsFragment
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,9 +28,7 @@ import com.coldmint.rust.pro.tool.AppSettings
|
||||||
* @date 2021/12/28 10:23
|
* @date 2021/12/28 10:23
|
||||||
*/
|
*/
|
||||||
class FollowFragment : BaseFragment<FragmentFollowBinding>() {
|
class FollowFragment : BaseFragment<FragmentFollowBinding>() {
|
||||||
val selfAccount by lazy {
|
|
||||||
AppSettings.getValue(AppSettings.Setting.Account, "")
|
|
||||||
}
|
|
||||||
var oldSize: Int = 0
|
var oldSize: Int = 0
|
||||||
var lastIndex = 0
|
var lastIndex = 0
|
||||||
|
|
||||||
|
@ -38,6 +36,7 @@ class FollowFragment : BaseFragment<FragmentFollowBinding>() {
|
||||||
* 加载视图如果需要更新的话
|
* 加载视图如果需要更新的话
|
||||||
*/
|
*/
|
||||||
fun loadViewIfNeed() {
|
fun loadViewIfNeed() {
|
||||||
|
val selfAccount = AppSettings.getValue(AppSettings.Setting.Account, "")
|
||||||
if (selfAccount.isBlank()) {
|
if (selfAccount.isBlank()) {
|
||||||
showTip(R.string.please_login_first)
|
showTip(R.string.please_login_first)
|
||||||
} else {
|
} else {
|
||||||
|
@ -166,6 +165,7 @@ class FollowFragment : BaseFragment<FragmentFollowBinding>() {
|
||||||
*/
|
*/
|
||||||
fun loadDynamic(account: String) {
|
fun loadDynamic(account: String) {
|
||||||
if (account.isBlank()) {
|
if (account.isBlank()) {
|
||||||
|
val selfAccount = AppSettings.getValue(AppSettings.Setting.Account, "")
|
||||||
Dynamic.instance.getFollowAllDynamic(selfAccount,
|
Dynamic.instance.getFollowAllDynamic(selfAccount,
|
||||||
object : ApiCallBack<DynamicItemDataBean> {
|
object : ApiCallBack<DynamicItemDataBean> {
|
||||||
override fun onResponse(t: DynamicItemDataBean) {
|
override fun onResponse(t: DynamicItemDataBean) {
|
||||||
|
|
|
@ -0,0 +1,71 @@
|
||||||
|
package com.coldmint.rust.pro.fragments
|
||||||
|
|
||||||
|
import android.content.Context
|
||||||
|
import android.view.LayoutInflater
|
||||||
|
import com.coldmint.dialog.BaseAppDialog
|
||||||
|
import com.coldmint.rust.core.dataBean.ApiResponse
|
||||||
|
import com.coldmint.rust.core.interfaces.ApiCallBack
|
||||||
|
import com.coldmint.rust.core.interfaces.FileFinderListener
|
||||||
|
import com.coldmint.rust.core.web.ServerConfiguration
|
||||||
|
import com.coldmint.rust.core.web.WebMod
|
||||||
|
import com.coldmint.rust.pro.databinding.DialogInsertCoinsBottomBinding
|
||||||
|
import com.coldmint.rust.pro.tool.AppSettings
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 投币对话框
|
||||||
|
* @property viewBinding [@androidx.annotation.NonNull] DialogInsertCoinsBottomBinding
|
||||||
|
* @constructor
|
||||||
|
*/
|
||||||
|
class InsertCoinsDialog(context: Context, val modId: String) :
|
||||||
|
BaseAppDialog<InsertCoinsDialog>(context) {
|
||||||
|
|
||||||
|
private val token by lazy {
|
||||||
|
AppSettings.getValue(AppSettings.Setting.Token, "")
|
||||||
|
}
|
||||||
|
|
||||||
|
private val viewBinding by lazy {
|
||||||
|
DialogInsertCoinsBottomBinding.inflate(LayoutInflater.from(context))
|
||||||
|
}
|
||||||
|
|
||||||
|
private var callBackLister: ((Boolean) -> Unit)? = null
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 设置回调
|
||||||
|
* Boolean是否成功
|
||||||
|
* @param listener Function1<Boolean, Unit>?
|
||||||
|
*/
|
||||||
|
fun setCallBackListener(listener: ((Boolean) -> Unit)?): InsertCoinsDialog {
|
||||||
|
callBackLister = listener
|
||||||
|
return this
|
||||||
|
}
|
||||||
|
|
||||||
|
init {
|
||||||
|
setView(viewBinding.root)
|
||||||
|
viewBinding.positiveButton.setOnClickListener {
|
||||||
|
val number = viewBinding.slider.value.toInt()
|
||||||
|
WebMod.instance.insertCoins(token, modId, number, object : ApiCallBack<ApiResponse> {
|
||||||
|
override fun onResponse(t: ApiResponse) {
|
||||||
|
if (t.code == ServerConfiguration.Success_Code) {
|
||||||
|
dismiss()
|
||||||
|
callBackLister?.invoke(true)
|
||||||
|
} else {
|
||||||
|
viewBinding.textview.text = t.message
|
||||||
|
callBackLister?.invoke(false)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun onFailure(e: Exception) {
|
||||||
|
e.printStackTrace()
|
||||||
|
dismiss()
|
||||||
|
callBackLister?.invoke(false)
|
||||||
|
}
|
||||||
|
|
||||||
|
})
|
||||||
|
}
|
||||||
|
viewBinding.negativeButton.setOnClickListener {
|
||||||
|
dismiss()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -4,16 +4,65 @@ import android.os.Bundle
|
||||||
import android.view.LayoutInflater
|
import android.view.LayoutInflater
|
||||||
import android.view.View
|
import android.view.View
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
|
import androidx.core.view.isVisible
|
||||||
import androidx.fragment.app.Fragment
|
import androidx.fragment.app.Fragment
|
||||||
|
import androidx.recyclerview.widget.DividerItemDecoration
|
||||||
|
import androidx.recyclerview.widget.LinearLayoutManager
|
||||||
|
import com.coldmint.dialog.CoreDialog
|
||||||
|
import com.coldmint.dialog.InputDialog
|
||||||
|
import com.coldmint.rust.core.dataBean.mod.CoinStatusData
|
||||||
|
import com.coldmint.rust.core.dataBean.mod.InsertCoinHistoryData
|
||||||
|
import com.coldmint.rust.core.interfaces.ApiCallBack
|
||||||
|
import com.coldmint.rust.core.web.WebMod
|
||||||
|
import com.coldmint.rust.pro.R
|
||||||
|
import com.coldmint.rust.pro.adapters.InsertCoinsAdapter
|
||||||
import com.coldmint.rust.pro.base.BaseFragment
|
import com.coldmint.rust.pro.base.BaseFragment
|
||||||
import com.coldmint.rust.pro.databinding.FragmentInsertCoinsBinding
|
import com.coldmint.rust.pro.databinding.FragmentInsertCoinsBinding
|
||||||
|
import com.coldmint.rust.pro.tool.AppSettings
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 投币碎片
|
* 投币碎片
|
||||||
*/
|
*/
|
||||||
class InsertCoinsFragment(val modId: String) : BaseFragment<FragmentInsertCoinsBinding>() {
|
class InsertCoinsFragment(val modId: String) : BaseFragment<FragmentInsertCoinsBinding>() {
|
||||||
override fun whenViewCreated(inflater: LayoutInflater, savedInstanceState: Bundle?) {
|
private val token by lazy {
|
||||||
|
AppSettings.getValue(AppSettings.Setting.Token, "")
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun whenViewCreated(inflater: LayoutInflater, savedInstanceState: Bundle?) {
|
||||||
|
viewBinding.recyclerView.layoutManager = LinearLayoutManager(requireContext())
|
||||||
|
viewBinding.recyclerView.addItemDecoration(
|
||||||
|
DividerItemDecoration(
|
||||||
|
requireContext(),
|
||||||
|
DividerItemDecoration.VERTICAL
|
||||||
|
)
|
||||||
|
)
|
||||||
|
viewBinding.swipeRefreshLayout.setOnRefreshListener {
|
||||||
|
loadList(false)
|
||||||
|
viewBinding.swipeRefreshLayout.isRefreshing = false
|
||||||
|
}
|
||||||
|
viewBinding.button.setOnClickListener {
|
||||||
|
InsertCoinsDialog(requireContext(), modId).setCallBackListener {
|
||||||
|
if (it) {
|
||||||
|
viewBinding.button.isEnabled = false
|
||||||
|
viewBinding.tipView.text = getString(R.string.insert_coins_ok)
|
||||||
|
loadList()
|
||||||
|
}
|
||||||
|
}.show()
|
||||||
|
// InputDialog(requireContext()).setTitle(R.string.insert_coins)
|
||||||
|
// .setMessage(R.string.insert_coins_num_tip)
|
||||||
|
// .setPositiveButton(R.string.dialog_ok) { it ->
|
||||||
|
// WebMod.instance.insertCoins(token, modId)
|
||||||
|
// false
|
||||||
|
// }.setNegativeButton(R.string.dialog_cancel) {
|
||||||
|
//
|
||||||
|
// }.show()
|
||||||
|
}
|
||||||
|
loadButton()
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun onResume() {
|
||||||
|
super.onResume()
|
||||||
|
loadList()
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun getViewBindingObject(layoutInflater: LayoutInflater): FragmentInsertCoinsBinding {
|
override fun getViewBindingObject(layoutInflater: LayoutInflater): FragmentInsertCoinsBinding {
|
||||||
|
@ -21,4 +70,65 @@ class InsertCoinsFragment(val modId: String) : BaseFragment<FragmentInsertCoinsB
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
fun loadList(useLinearProgressIndicator: Boolean = true) {
|
||||||
|
if (useLinearProgressIndicator) {
|
||||||
|
viewBinding.linearProgressIndicator.isVisible = true
|
||||||
|
}
|
||||||
|
WebMod.instance.getInsertCoinHistory(modId, object : ApiCallBack<InsertCoinHistoryData> {
|
||||||
|
override fun onResponse(t: InsertCoinHistoryData) {
|
||||||
|
val dataList = t.data
|
||||||
|
if (dataList.isNullOrEmpty()) {
|
||||||
|
viewBinding.recyclerView.isVisible = false
|
||||||
|
if (useLinearProgressIndicator) {
|
||||||
|
viewBinding.linearProgressIndicator.isVisible = false
|
||||||
|
}
|
||||||
|
viewBinding.loadLayout.isVisible = true
|
||||||
|
viewBinding.coinRecordsView.text = getString(R.string.coin_records)
|
||||||
|
} else {
|
||||||
|
viewBinding.recyclerView.adapter =
|
||||||
|
InsertCoinsAdapter(requireContext(), dataList)
|
||||||
|
val data = getString(R.string.coin_records) + "(" + dataList.size + ")"
|
||||||
|
viewBinding.coinRecordsView.text = data
|
||||||
|
viewBinding.recyclerView.isVisible = true
|
||||||
|
if (useLinearProgressIndicator) {
|
||||||
|
viewBinding.linearProgressIndicator.isVisible = false
|
||||||
|
}
|
||||||
|
viewBinding.loadLayout.isVisible = false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun onFailure(e: Exception) {
|
||||||
|
e.printStackTrace()
|
||||||
|
viewBinding.recyclerView.isVisible = false
|
||||||
|
viewBinding.coinRecordsView.text = getString(R.string.coin_records)
|
||||||
|
if (useLinearProgressIndicator) {
|
||||||
|
viewBinding.linearProgressIndicator.isVisible = false
|
||||||
|
}
|
||||||
|
viewBinding.loadLayout.isVisible = true
|
||||||
|
}
|
||||||
|
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
fun loadButton() {
|
||||||
|
WebMod.instance.getCoinStatus(token, modId, object : ApiCallBack<CoinStatusData> {
|
||||||
|
override fun onResponse(t: CoinStatusData) {
|
||||||
|
viewBinding.button.isEnabled = !t.data
|
||||||
|
if (t.data) {
|
||||||
|
viewBinding.tipView.text = getString(R.string.insert_coins_ok)
|
||||||
|
} else {
|
||||||
|
viewBinding.tipView.text = getString(R.string.insert_coins_no)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun onFailure(e: Exception) {
|
||||||
|
e.printStackTrace()
|
||||||
|
viewBinding.button.isEnabled = false
|
||||||
|
viewBinding.tipView.text = getString(R.string.insert_coins_no)
|
||||||
|
}
|
||||||
|
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
|
@ -1,5 +1,6 @@
|
||||||
package com.coldmint.rust.pro.fragments
|
package com.coldmint.rust.pro.fragments
|
||||||
|
|
||||||
|
import android.content.Intent
|
||||||
import android.os.Bundle
|
import android.os.Bundle
|
||||||
import androidx.fragment.app.Fragment
|
import androidx.fragment.app.Fragment
|
||||||
import android.view.LayoutInflater
|
import android.view.LayoutInflater
|
||||||
|
@ -17,6 +18,7 @@ import com.coldmint.rust.core.tool.DebugHelper
|
||||||
import com.coldmint.rust.core.web.ServerConfiguration
|
import com.coldmint.rust.core.web.ServerConfiguration
|
||||||
import com.coldmint.rust.core.web.WebMod
|
import com.coldmint.rust.core.web.WebMod
|
||||||
import com.coldmint.rust.pro.R
|
import com.coldmint.rust.pro.R
|
||||||
|
import com.coldmint.rust.pro.UserHomePageActivity
|
||||||
import com.coldmint.rust.pro.adapters.CommentAdapter
|
import com.coldmint.rust.pro.adapters.CommentAdapter
|
||||||
import com.coldmint.rust.pro.base.BaseFragment
|
import com.coldmint.rust.pro.base.BaseFragment
|
||||||
import com.coldmint.rust.pro.databinding.FragmentModCommentsBinding
|
import com.coldmint.rust.pro.databinding.FragmentModCommentsBinding
|
||||||
|
@ -80,6 +82,21 @@ class ModCommentsFragment(val modId: String) : BaseFragment<FragmentModCommentsB
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 打开用户主页
|
||||||
|
* @param userId String
|
||||||
|
*/
|
||||||
|
fun gotoUserPage(userId: String) {
|
||||||
|
val intent = Intent(
|
||||||
|
requireContext(),
|
||||||
|
UserHomePageActivity::class.java
|
||||||
|
)
|
||||||
|
intent.putExtra("userId", userId)
|
||||||
|
startActivity(
|
||||||
|
intent
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
override fun onResume() {
|
override fun onResume() {
|
||||||
super.onResume()
|
super.onResume()
|
||||||
loadCommentList(modId)
|
loadCommentList(modId)
|
||||||
|
@ -102,16 +119,25 @@ class ModCommentsFragment(val modId: String) : BaseFragment<FragmentModCommentsB
|
||||||
if (useLinearProgressIndicator) {
|
if (useLinearProgressIndicator) {
|
||||||
viewBinding.linearProgressIndicator.isVisible = false
|
viewBinding.linearProgressIndicator.isVisible = false
|
||||||
}
|
}
|
||||||
|
viewBinding.titleView.text = getString(R.string.discussion)
|
||||||
viewBinding.recyclerView.isVisible = false
|
viewBinding.recyclerView.isVisible = false
|
||||||
viewBinding.noContentLayout.isVisible = true
|
viewBinding.noContentLayout.isVisible = true
|
||||||
} else {
|
} else {
|
||||||
DebugHelper.printLog(key, "共${list.size}条数据")
|
DebugHelper.printLog(key, "共${list.size}条数据")
|
||||||
|
viewBinding.titleView.text =
|
||||||
|
getString(R.string.discussion) + "(" + list.size + ")"
|
||||||
if (useLinearProgressIndicator) {
|
if (useLinearProgressIndicator) {
|
||||||
viewBinding.linearProgressIndicator.isVisible = false
|
viewBinding.linearProgressIndicator.isVisible = false
|
||||||
}
|
}
|
||||||
viewBinding.recyclerView.isVisible = true
|
viewBinding.recyclerView.isVisible = true
|
||||||
viewBinding.noContentLayout.isVisible = false
|
viewBinding.noContentLayout.isVisible = false
|
||||||
viewBinding.recyclerView.adapter = CommentAdapter(requireContext(), list)
|
val adapter = CommentAdapter(requireContext(), list)
|
||||||
|
adapter.setItemEvent { i, itemCommentBinding, viewHolder, data ->
|
||||||
|
itemCommentBinding.iconView.setOnClickListener {
|
||||||
|
gotoUserPage(data.account)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
viewBinding.recyclerView.adapter = adapter
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -120,6 +146,7 @@ class ModCommentsFragment(val modId: String) : BaseFragment<FragmentModCommentsB
|
||||||
if (useLinearProgressIndicator) {
|
if (useLinearProgressIndicator) {
|
||||||
viewBinding.linearProgressIndicator.isVisible = false
|
viewBinding.linearProgressIndicator.isVisible = false
|
||||||
}
|
}
|
||||||
|
viewBinding.titleView.text = getString(R.string.discussion)
|
||||||
viewBinding.recyclerView.isVisible = false
|
viewBinding.recyclerView.isVisible = false
|
||||||
viewBinding.noContentLayout.isVisible = true
|
viewBinding.noContentLayout.isVisible = true
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,6 +4,7 @@ import android.content.Intent
|
||||||
import android.os.Bundle
|
import android.os.Bundle
|
||||||
import android.view.LayoutInflater
|
import android.view.LayoutInflater
|
||||||
import androidx.core.view.isVisible
|
import androidx.core.view.isVisible
|
||||||
|
import androidx.lifecycle.MutableLiveData
|
||||||
import com.bumptech.glide.Glide
|
import com.bumptech.glide.Glide
|
||||||
import com.coldmint.rust.core.dataBean.mod.WebModInfoData
|
import com.coldmint.rust.core.dataBean.mod.WebModInfoData
|
||||||
import com.coldmint.rust.core.dataBean.user.SpaceInfoData
|
import com.coldmint.rust.core.dataBean.user.SpaceInfoData
|
||||||
|
@ -28,12 +29,22 @@ import com.youth.banner.indicator.CircleIndicator
|
||||||
/**
|
/**
|
||||||
* 模组详情碎片
|
* 模组详情碎片
|
||||||
*/
|
*/
|
||||||
class WebModDetailsFragment(val modId: String) : BaseFragment<FragmentWebModDetailsBinding>() {
|
class WebModDetailsFragment(val modId: String,val modNameLiveData: MutableLiveData<String>) : BaseFragment<FragmentWebModDetailsBinding>() {
|
||||||
var developer: String? = null
|
private var developer: String? = null
|
||||||
|
|
||||||
//此模组是否对外开放
|
//此模组是否对外开放
|
||||||
private var isOpen = false
|
private var isOpen = false
|
||||||
|
|
||||||
|
private var link: String? = null
|
||||||
|
|
||||||
|
|
||||||
|
fun getLink(): String? {
|
||||||
|
return link
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取此模组是否对外开放
|
* 获取此模组是否对外开放
|
||||||
* @return Boolean
|
* @return Boolean
|
||||||
|
@ -115,7 +126,9 @@ class WebModDetailsFragment(val modId: String) : BaseFragment<FragmentWebModDeta
|
||||||
override fun onResponse(t: WebModInfoData) {
|
override fun onResponse(t: WebModInfoData) {
|
||||||
if (t.code == ServerConfiguration.Success_Code) {
|
if (t.code == ServerConfiguration.Success_Code) {
|
||||||
developer = t.data.developer
|
developer = t.data.developer
|
||||||
|
modNameLiveData.value = t.data.name
|
||||||
isOpen = t.data.hidden == 0
|
isOpen = t.data.hidden == 0
|
||||||
|
link = t.data.link
|
||||||
viewBinding.loadLayout.isVisible = false
|
viewBinding.loadLayout.isVisible = false
|
||||||
viewBinding.contentLayout.isVisible = true
|
viewBinding.contentLayout.isVisible = true
|
||||||
val icon = t.data.icon
|
val icon = t.data.icon
|
||||||
|
|
|
@ -28,6 +28,7 @@
|
||||||
app:layout_behavior="com.google.android.material.appbar.AppBarLayout$ScrollingViewBehavior">
|
app:layout_behavior="com.google.android.material.appbar.AppBarLayout$ScrollingViewBehavior">
|
||||||
|
|
||||||
<LinearLayout
|
<LinearLayout
|
||||||
|
android:layout_marginBottom="120dp"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:orientation="vertical">
|
android:orientation="vertical">
|
||||||
|
|
|
@ -10,12 +10,12 @@
|
||||||
<androidx.coordinatorlayout.widget.CoordinatorLayout
|
<androidx.coordinatorlayout.widget.CoordinatorLayout
|
||||||
android:id="@+id/rootLayout"
|
android:id="@+id/rootLayout"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
|
android:fitsSystemWindows="true"
|
||||||
android:layout_height="match_parent">
|
android:layout_height="match_parent">
|
||||||
|
|
||||||
<com.google.android.material.appbar.AppBarLayout
|
<com.google.android.material.appbar.AppBarLayout
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content">
|
||||||
android:fitsSystemWindows="true">
|
|
||||||
|
|
||||||
<com.google.android.material.appbar.MaterialToolbar
|
<com.google.android.material.appbar.MaterialToolbar
|
||||||
android:id="@+id/toolbar"
|
android:id="@+id/toolbar"
|
||||||
|
@ -68,7 +68,6 @@
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
android:layout_gravity="start"
|
android:layout_gravity="start"
|
||||||
android:fitsSystemWindows="false"
|
|
||||||
app:elevation="2dp"
|
app:elevation="2dp"
|
||||||
app:menu="@menu/menu_drawer_left" />
|
app:menu="@menu/menu_drawer_left" />
|
||||||
|
|
||||||
|
|
|
@ -53,13 +53,13 @@
|
||||||
android:queryBackground="@null"
|
android:queryBackground="@null"
|
||||||
android:queryHint="@string/search" />
|
android:queryHint="@string/search" />
|
||||||
|
|
||||||
<!-- <TextView-->
|
<TextView
|
||||||
<!-- android:id="@+id/searchSuggestionsView"-->
|
android:id="@+id/searchSuggestionsView"
|
||||||
<!-- style="@style/TextAppearance.Material3.BodySmall"-->
|
style="@style/TextAppearance.Material3.BodySmall"
|
||||||
<!-- android:layout_width="wrap_content"-->
|
android:layout_width="wrap_content"
|
||||||
<!-- android:layout_height="wrap_content"-->
|
android:layout_height="wrap_content"
|
||||||
<!-- android:layout_marginTop="8dp"-->
|
android:layout_marginTop="16dp"
|
||||||
<!-- android:text="@string/search_suggestions_null" />-->
|
android:text="@string/search_suggestions_null" />
|
||||||
|
|
||||||
<androidx.recyclerview.widget.RecyclerView
|
<androidx.recyclerview.widget.RecyclerView
|
||||||
android:id="@+id/recyclerView"
|
android:id="@+id/recyclerView"
|
||||||
|
|
|
@ -16,6 +16,7 @@
|
||||||
<com.google.android.material.appbar.CollapsingToolbarLayout
|
<com.google.android.material.appbar.CollapsingToolbarLayout
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
|
android:fitsSystemWindows="true"
|
||||||
app:contentScrim="?android:windowBackground"
|
app:contentScrim="?android:windowBackground"
|
||||||
app:layout_scrollFlags="scroll|exitUntilCollapsed|snap"
|
app:layout_scrollFlags="scroll|exitUntilCollapsed|snap"
|
||||||
app:titleCollapseMode="scale"
|
app:titleCollapseMode="scale"
|
||||||
|
|
63
app/src/main/res/layout/dialog_insert_coins_bottom.xml
Normal file
63
app/src/main/res/layout/dialog_insert_coins_bottom.xml
Normal file
|
@ -0,0 +1,63 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
style="@style/TextAppearance.Material3.HeadlineMedium"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginHorizontal="24dp"
|
||||||
|
android:layout_marginTop="24dp"
|
||||||
|
android:text="@string/insert_coins" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/textview"
|
||||||
|
android:layout_marginTop="24dp"
|
||||||
|
style="@style/TextAppearance.Material3.BodyMedium"
|
||||||
|
android:layout_marginHorizontal="24dp"
|
||||||
|
android:text="@string/drag_the_slider_to_set_num"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"/>
|
||||||
|
|
||||||
|
<com.google.android.material.slider.Slider
|
||||||
|
android:id="@+id/slider"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginHorizontal="24dp"
|
||||||
|
android:layout_marginTop="16dp"
|
||||||
|
android:stepSize="1.0"
|
||||||
|
android:valueFrom="1.0"
|
||||||
|
android:valueTo="5.0" />
|
||||||
|
|
||||||
|
<RelativeLayout
|
||||||
|
android:layout_marginBottom="24dp"
|
||||||
|
android:layout_marginHorizontal="24dp"
|
||||||
|
android:id="@+id/buttonContainer"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginTop="24dp">
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/negativeButton"
|
||||||
|
style="@style/Widget.Material3.Button.TextButton.Dialog.Flush"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_toStartOf="@id/positiveButton"
|
||||||
|
android:text="@string/dialog_cancel" />
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/positiveButton"
|
||||||
|
style="@style/Widget.Material3.Button.TextButton.Dialog.Flush"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_alignParentEnd="true"
|
||||||
|
android:layout_marginStart="8dp"
|
||||||
|
android:text="@string/dialog_ok" />
|
||||||
|
|
||||||
|
</RelativeLayout>
|
||||||
|
|
||||||
|
|
||||||
|
</LinearLayout>
|
|
@ -13,6 +13,7 @@
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/textview"
|
android:id="@+id/textview"
|
||||||
|
style="@style/TextAppearance.Material3.HeadlineSmall"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_marginTop="8dp"
|
android:layout_marginTop="8dp"
|
||||||
|
|
|
@ -1,62 +1,97 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
<androidx.swiperefreshlayout.widget.SwipeRefreshLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
android:layout_width="match_parent"
|
|
||||||
android:layout_height="match_parent"
|
|
||||||
xmlns:app="http://schemas.android.com/apk/res-auto"
|
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:id="@+id/swipeRefreshLayout"
|
||||||
|
android:layout_height="match_parent"
|
||||||
android:orientation="vertical"
|
android:orientation="vertical"
|
||||||
android:paddingHorizontal="16dp"
|
android:paddingHorizontal="16dp"
|
||||||
android:paddingTop="8dp">
|
android:paddingTop="8dp">
|
||||||
|
|
||||||
|
|
||||||
<com.google.android.material.card.MaterialCardView
|
<LinearLayout
|
||||||
style="@style/Widget.Material3.CardView.Elevated"
|
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content">
|
android:layout_height="wrap_content"
|
||||||
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
<com.google.android.material.card.MaterialCardView
|
||||||
|
style="@style/Widget.Material3.CardView.Elevated"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content">
|
||||||
|
|
||||||
|
|
||||||
<LinearLayout
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_margin="24dp"
|
||||||
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
style="@style/TextAppearance.Material3.HeadlineSmall"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/insert_coins" />
|
||||||
|
|
||||||
|
<com.google.android.material.button.MaterialButton
|
||||||
|
android:id="@+id/button"
|
||||||
|
style="@style/Widget.Material3.Button.OutlinedButton"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginTop="16dp"
|
||||||
|
android:enabled="true"
|
||||||
|
android:text="@string/insert_coins" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tipView"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginTop="8dp"
|
||||||
|
android:text="@string/insert_coins_no" />
|
||||||
|
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
|
||||||
|
</com.google.android.material.card.MaterialCardView>
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/coinRecordsView"
|
||||||
|
style="@style/TextAppearance.Material3.HeadlineSmall"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginTop="16dp"
|
||||||
|
android:text="@string/coin_records" />
|
||||||
|
|
||||||
|
<com.google.android.material.progressindicator.LinearProgressIndicator
|
||||||
|
android:id="@+id/linearProgressIndicator"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_margin="24dp"
|
android:visibility="gone"
|
||||||
android:orientation="vertical">
|
android:indeterminate="true"
|
||||||
|
android:layout_marginTop="8dp" />
|
||||||
|
|
||||||
|
<androidx.recyclerview.widget.RecyclerView
|
||||||
|
android:id="@+id/recyclerView"
|
||||||
|
android:visibility="gone"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginTop="8dp" />
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:id="@+id/loadLayout"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:gravity="center">
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
style="@style/TextAppearance.Material3.HeadlineSmall"
|
style="@style/TextAppearance.Material3.HeadlineSmall"
|
||||||
|
android:text="@string/no_content"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"/>
|
||||||
android:text="@string/insert_coins" />
|
|
||||||
|
|
||||||
<com.google.android.material.button.MaterialButton
|
|
||||||
android:layout_width="match_parent"
|
|
||||||
android:enabled="true"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:layout_marginTop="16dp"
|
|
||||||
android:text="@string/insert_coins" />
|
|
||||||
|
|
||||||
<TextView
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:layout_marginTop="8dp"
|
|
||||||
android:text="已有5人投币。" />
|
|
||||||
|
|
||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
</com.google.android.material.card.MaterialCardView>
|
|
||||||
|
|
||||||
<TextView
|
|
||||||
style="@style/TextAppearance.Material3.HeadlineSmall"
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:layout_marginTop="16dp"
|
|
||||||
android:text="投币记录" />
|
|
||||||
|
|
||||||
<androidx.recyclerview.widget.RecyclerView
|
|
||||||
android:id="@+id/recyclerView"
|
|
||||||
android:layout_width="match_parent"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:layout_marginTop="8dp" />
|
|
||||||
|
|
||||||
|
|
||||||
</LinearLayout>
|
</androidx.swiperefreshlayout.widget.SwipeRefreshLayout>
|
|
@ -20,6 +20,7 @@
|
||||||
android:layout_height="wrap_content">
|
android:layout_height="wrap_content">
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
|
android:id="@+id/titleView"
|
||||||
style="@style/TextAppearance.Material3.HeadlineSmall"
|
style="@style/TextAppearance.Material3.HeadlineSmall"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
android:orientation="vertical">
|
android:orientation="vertical">
|
||||||
|
@ -29,27 +30,27 @@
|
||||||
|
|
||||||
<androidx.core.widget.NestedScrollView
|
<androidx.core.widget.NestedScrollView
|
||||||
android:id="@+id/contentLayout"
|
android:id="@+id/contentLayout"
|
||||||
android:visibility="gone"
|
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
android:orientation="vertical">
|
android:orientation="vertical"
|
||||||
|
android:visibility="gone">
|
||||||
|
|
||||||
<LinearLayout
|
<LinearLayout
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_marginBottom="60dp"
|
|
||||||
android:layout_marginHorizontal="16dp"
|
android:layout_marginHorizontal="16dp"
|
||||||
|
android:layout_marginBottom="60dp"
|
||||||
android:animateLayoutChanges="true"
|
android:animateLayoutChanges="true"
|
||||||
android:orientation="vertical">
|
android:orientation="vertical">
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/hideTextView"
|
android:id="@+id/hideTextView"
|
||||||
android:visibility="gone"
|
|
||||||
style="@style/TextAppearance.Material3.BodyMedium"
|
style="@style/TextAppearance.Material3.BodyMedium"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_marginTop="16dp"
|
android:layout_marginTop="16dp"
|
||||||
android:text="@string/audit" />
|
android:text="@string/audit"
|
||||||
|
android:visibility="gone" />
|
||||||
|
|
||||||
|
|
||||||
<com.google.android.material.card.MaterialCardView
|
<com.google.android.material.card.MaterialCardView
|
||||||
|
@ -68,12 +69,14 @@
|
||||||
android:layout_marginVertical="16dp"
|
android:layout_marginVertical="16dp"
|
||||||
android:orientation="vertical">
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
|
||||||
<ImageView
|
<ImageView
|
||||||
android:id="@+id/headIconView"
|
android:id="@+id/headIconView"
|
||||||
android:layout_width="50dp"
|
android:layout_width="50dp"
|
||||||
android:layout_height="50dp"
|
android:layout_height="50dp"
|
||||||
android:src="@drawable/image" />
|
android:src="@drawable/image" />
|
||||||
|
|
||||||
|
|
||||||
<LinearLayout
|
<LinearLayout
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
|
@ -127,20 +130,26 @@
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content">
|
android:layout_height="wrap_content">
|
||||||
|
|
||||||
|
<com.google.android.material.card.MaterialCardView
|
||||||
|
android:id="@+id/iconCardView"
|
||||||
|
style="@style/Widget.Material3.CardView.Filled"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content">
|
||||||
|
|
||||||
<ImageView
|
<ImageView
|
||||||
android:id="@+id/iconView"
|
android:id="@+id/iconView"
|
||||||
android:layout_width="90dp"
|
android:layout_width="90dp"
|
||||||
android:layout_height="90dp"
|
android:layout_height="90dp"
|
||||||
android:padding="8dp"
|
android:scaleType="centerCrop"
|
||||||
android:src="@drawable/image" />
|
android:src="@drawable/image" />
|
||||||
|
</com.google.android.material.card.MaterialCardView>
|
||||||
|
|
||||||
<LinearLayout
|
<LinearLayout
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_centerVertical="true"
|
android:layout_centerVertical="true"
|
||||||
android:layout_marginStart="8dp"
|
android:layout_marginStart="8dp"
|
||||||
android:layout_toEndOf="@id/iconView"
|
android:layout_toEndOf="@id/iconCardView"
|
||||||
android:gravity="center_vertical"
|
android:gravity="center_vertical"
|
||||||
android:orientation="vertical">
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
@ -176,23 +185,29 @@
|
||||||
|
|
||||||
</RelativeLayout>
|
</RelativeLayout>
|
||||||
|
|
||||||
<com.google.android.material.chip.ChipGroup
|
<HorizontalScrollView
|
||||||
android:id="@+id/chipGroup"
|
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content">
|
||||||
android:layout_marginTop="8dp" />
|
|
||||||
|
<com.google.android.material.chip.ChipGroup
|
||||||
|
android:id="@+id/chipGroup"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginTop="8dp"
|
||||||
|
app:singleLine="true" />
|
||||||
|
|
||||||
|
</HorizontalScrollView>
|
||||||
|
|
||||||
<com.google.android.material.card.MaterialCardView
|
<com.google.android.material.card.MaterialCardView
|
||||||
style="@style/Widget.Material3.CardView.Filled"
|
style="@style/Widget.Material3.CardView.Filled"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_marginTop="16dp"
|
android:layout_height="wrap_content"
|
||||||
android:layout_height="wrap_content">
|
android:layout_marginTop="16dp">
|
||||||
|
|
||||||
<com.youth.banner.Banner
|
<com.youth.banner.Banner
|
||||||
android:id="@+id/banner"
|
android:id="@+id/banner"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="180dp"
|
android:layout_height="180dp" />
|
||||||
android:layout_marginTop="8dp" />
|
|
||||||
|
|
||||||
</com.google.android.material.card.MaterialCardView>
|
</com.google.android.material.card.MaterialCardView>
|
||||||
|
|
||||||
|
|
|
@ -13,12 +13,12 @@
|
||||||
android:layout_margin="16dp">
|
android:layout_margin="16dp">
|
||||||
|
|
||||||
<ImageView
|
<ImageView
|
||||||
android:layout_centerVertical="true"
|
|
||||||
android:id="@+id/mod_icon"
|
android:id="@+id/mod_icon"
|
||||||
android:layout_width="60dp"
|
android:layout_width="60dp"
|
||||||
android:layout_height="60dp"
|
android:layout_height="60dp"
|
||||||
android:layout_alignParentStart="true"
|
android:layout_alignParentStart="true"
|
||||||
android:layout_alignParentTop="true"
|
android:layout_alignParentTop="true"
|
||||||
|
android:layout_centerVertical="true"
|
||||||
android:layout_marginTop="8dp"
|
android:layout_marginTop="8dp"
|
||||||
android:layout_marginEnd="8dp"
|
android:layout_marginEnd="8dp"
|
||||||
android:layout_marginBottom="8dp"
|
android:layout_marginBottom="8dp"
|
||||||
|
@ -49,8 +49,9 @@
|
||||||
android:text="@string/publisher_information" />
|
android:text="@string/publisher_information" />
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
style="@style/TextAppearance.Material3.BodySmall"
|
android:singleLine="true"
|
||||||
android:id="@+id/mod_introduction_view"
|
android:id="@+id/mod_introduction_view"
|
||||||
|
style="@style/TextAppearance.Material3.BodySmall"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_marginTop="8dp"
|
android:layout_marginTop="8dp"
|
||||||
|
@ -66,6 +67,7 @@
|
||||||
android:orientation="horizontal">
|
android:orientation="horizontal">
|
||||||
|
|
||||||
<Button
|
<Button
|
||||||
|
android:layout_marginRight="8dp"
|
||||||
style="@style/Widget.Material3.Button.OutlinedButton"
|
style="@style/Widget.Material3.Button.OutlinedButton"
|
||||||
android:id="@+id/refusedView"
|
android:id="@+id/refusedView"
|
||||||
android:layout_width="0dp"
|
android:layout_width="0dp"
|
||||||
|
@ -75,6 +77,7 @@
|
||||||
android:text="@string/refused" />
|
android:text="@string/refused" />
|
||||||
|
|
||||||
<Button
|
<Button
|
||||||
|
android:layout_marginLeft="8dp"
|
||||||
android:id="@+id/consentView"
|
android:id="@+id/consentView"
|
||||||
android:layout_width="0dp"
|
android:layout_width="0dp"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
|
|
|
@ -12,17 +12,17 @@
|
||||||
|
|
||||||
<ImageView
|
<ImageView
|
||||||
android:id="@+id/headIconView"
|
android:id="@+id/headIconView"
|
||||||
android:layout_width="40dp"
|
android:layout_width="48dp"
|
||||||
android:layout_height="40dp"
|
android:layout_height="48dp"
|
||||||
android:src="@drawable/head_icon" />
|
android:src="@drawable/head_icon" />
|
||||||
|
|
||||||
<LinearLayout
|
<LinearLayout
|
||||||
|
android:id="@+id/contentLayout"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_alignTop="@id/headIconView"
|
android:layout_alignTop="@id/headIconView"
|
||||||
android:layout_alignBottom="@id/headIconView"
|
android:layout_marginStart="8dp"
|
||||||
android:layout_marginLeft="8dp"
|
android:layout_toEndOf="@id/headIconView"
|
||||||
android:layout_toRightOf="@id/headIconView"
|
|
||||||
android:gravity="center_vertical"
|
android:gravity="center_vertical"
|
||||||
android:orientation="vertical">
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
@ -31,7 +31,7 @@
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:text="@string/user_name"
|
android:text="@string/user_name"
|
||||||
android:textSize="16sp" />
|
style="@style/TextAppearance.Material3.TitleMedium"/>
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/timeView"
|
android:id="@+id/timeView"
|
||||||
|
@ -39,26 +39,19 @@
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_marginTop="8dp"
|
android:layout_marginTop="8dp"
|
||||||
android:text="@string/time"
|
android:text="@string/time"
|
||||||
android:textSize="10sp" />
|
style="@style/TextAppearance.Material3.BodySmall"
|
||||||
|
/>
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/textview"
|
android:id="@+id/textview"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_below="@id/headIconView"
|
android:layout_below="@id/contentLayout"
|
||||||
android:layout_marginTop="8dp"
|
android:layout_marginTop="16dp"
|
||||||
|
style="@style/TextAppearance.Material3.BodyMedium"
|
||||||
android:text="@string/expiration_time_null" />
|
android:text="@string/expiration_time_null" />
|
||||||
|
|
||||||
<TextView
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:layout_below="@id/textview"
|
|
||||||
android:layout_alignParentRight="true"
|
|
||||||
android:layout_marginTop="8dp"
|
|
||||||
android:text="@string/dialog_ok"
|
|
||||||
android:textColor="?attr/colorPrimary"
|
|
||||||
android:visibility="gone" />
|
|
||||||
|
|
||||||
</RelativeLayout>
|
</RelativeLayout>
|
||||||
</com.google.android.material.card.MaterialCardView>
|
</com.google.android.material.card.MaterialCardView>
|
47
app/src/main/res/layout/item_insert_coins.xml
Normal file
47
app/src/main/res/layout/item_insert_coins.xml
Normal file
|
@ -0,0 +1,47 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content">
|
||||||
|
|
||||||
|
<ImageView
|
||||||
|
android:id="@+id/imageView"
|
||||||
|
android:layout_width="60dp"
|
||||||
|
android:layout_height="60dp"
|
||||||
|
android:layout_centerVertical="true"
|
||||||
|
android:src="@drawable/head_icon" />
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_toEndOf="@id/imageView"
|
||||||
|
android:orientation="vertical"
|
||||||
|
android:padding="8dp">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/nameView"
|
||||||
|
style="@style/TextAppearance.Material3.TitleMedium"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="名称" />
|
||||||
|
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/numberOfCoinView"
|
||||||
|
style="@style/TextAppearance.Material3.BodyMedium"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginTop="8dp"
|
||||||
|
android:text="@string/insert_coins_tip" />
|
||||||
|
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/timeView"
|
||||||
|
style="@style/TextAppearance.Material3.BodySmall"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginTop="8dp"
|
||||||
|
android:text="时间" />
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
|
</RelativeLayout>
|
|
@ -18,7 +18,7 @@
|
||||||
android:id="@+id/titleView"
|
android:id="@+id/titleView"
|
||||||
android:singleLine="true"
|
android:singleLine="true"
|
||||||
android:ellipsize="end"
|
android:ellipsize="end"
|
||||||
style="@style/TextAppearance.Material3.BodyMedium"
|
style="@style/TextAppearance.Material3.TitleMedium"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_marginTop="8dp"
|
android:layout_marginTop="8dp"
|
||||||
|
|
|
@ -1,26 +1,38 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content">
|
android:layout_height="wrap_content"
|
||||||
|
android:padding="8dp">
|
||||||
|
|
||||||
<ImageView
|
<com.google.android.material.card.MaterialCardView
|
||||||
android:id="@+id/mod_icon"
|
android:id="@+id/modIconCard"
|
||||||
android:layout_width="60dp"
|
style="@style/Widget.Material3.CardView.Filled"
|
||||||
android:layout_height="60dp"
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
android:layout_alignParentStart="true"
|
android:layout_alignParentStart="true"
|
||||||
android:layout_alignParentTop="true"
|
android:layout_alignParentTop="true"
|
||||||
android:layout_marginTop="8dp"
|
android:layout_marginTop="8dp"
|
||||||
android:layout_marginEnd="8dp"
|
android:layout_marginEnd="8dp"
|
||||||
android:layout_marginBottom="8dp"
|
android:layout_marginBottom="8dp">
|
||||||
android:src="@drawable/image" />
|
|
||||||
|
<ImageView
|
||||||
|
android:id="@+id/mod_icon"
|
||||||
|
android:layout_width="60dp"
|
||||||
|
android:layout_height="60dp"
|
||||||
|
|
||||||
|
android:src="@drawable/image" />
|
||||||
|
|
||||||
|
</com.google.android.material.card.MaterialCardView>
|
||||||
|
|
||||||
|
|
||||||
<LinearLayout
|
<LinearLayout
|
||||||
|
android:layout_marginLeft="8dp"
|
||||||
android:id="@+id/linearLayout"
|
android:id="@+id/linearLayout"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_centerVertical="true"
|
android:layout_centerVertical="true"
|
||||||
android:layout_toStartOf="@id/more"
|
android:layout_toStartOf="@id/more"
|
||||||
android:layout_toEndOf="@id/mod_icon"
|
android:layout_toEndOf="@id/modIconCard"
|
||||||
android:gravity="center_vertical"
|
android:gravity="center_vertical"
|
||||||
android:orientation="vertical">
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
@ -36,8 +48,10 @@
|
||||||
android:id="@+id/mod_introduction_view"
|
android:id="@+id/mod_introduction_view"
|
||||||
style="@style/TextAppearance.Material3.BodySmall"
|
style="@style/TextAppearance.Material3.BodySmall"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="26dp"
|
||||||
android:layout_marginTop="8dp"
|
android:layout_marginTop="8dp"
|
||||||
|
android:ellipsize="end"
|
||||||
|
android:singleLine="true"
|
||||||
android:text="介绍" />
|
android:text="介绍" />
|
||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
@ -54,7 +68,7 @@
|
||||||
android:id="@+id/more"
|
android:id="@+id/more"
|
||||||
android:layout_width="48dp"
|
android:layout_width="48dp"
|
||||||
android:layout_height="48dp"
|
android:layout_height="48dp"
|
||||||
android:layout_alignParentRight="true"
|
android:layout_alignParentEnd="true"
|
||||||
android:layout_centerVertical="true"
|
android:layout_centerVertical="true"
|
||||||
android:padding="12dp"
|
android:padding="12dp"
|
||||||
android:src="@drawable/more" />
|
android:src="@drawable/more" />
|
||||||
|
|
|
@ -35,6 +35,8 @@
|
||||||
android:text="模组名称" />
|
android:text="模组名称" />
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
|
android:singleLine="true"
|
||||||
|
android:ellipsize="end"
|
||||||
android:id="@+id/mod_introduction_view"
|
android:id="@+id/mod_introduction_view"
|
||||||
style="@style/TextAppearance.Material3.TitleSmall"
|
style="@style/TextAppearance.Material3.TitleSmall"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
|
|
|
@ -95,7 +95,6 @@
|
||||||
<string name="enter_file_path">Please enter a file path.</string>
|
<string name="enter_file_path">Please enter a file path.</string>
|
||||||
<string name="create_bookmark">Create bookmarks</string>
|
<string name="create_bookmark">Create bookmarks</string>
|
||||||
<string name="name_error">Please enter a mod name.</string>
|
<string name="name_error">Please enter a mod name.</string>
|
||||||
<string name="unit_name_error">Please enter a unit name.</string>
|
|
||||||
<string name="action_name_error">Please enter an event name.</string>
|
<string name="action_name_error">Please enter an event name.</string>
|
||||||
<string name="database_null">This dataset could not be loaded, error: %1$s.</string>
|
<string name="database_null">This dataset could not be loaded, error: %1$s.</string>
|
||||||
<string name="describe_error">Please enter a description.</string>
|
<string name="describe_error">Please enter a description.</string>
|
||||||
|
@ -114,7 +113,6 @@
|
||||||
<string name="mod_action1">Editing unit</string>
|
<string name="mod_action1">Editing unit</string>
|
||||||
<string name="mod_action2">Edit information</string>
|
<string name="mod_action2">Edit information</string>
|
||||||
<string name="mod_action8">decompress</string>
|
<string name="mod_action8">decompress</string>
|
||||||
<string name="mod_action9">Double naming</string>
|
|
||||||
<string name="mod_action10">Repair information file</string>
|
<string name="mod_action10">Repair information file</string>
|
||||||
<string name="open_action1">Edit text</string>
|
<string name="open_action1">Edit text</string>
|
||||||
|
|
||||||
|
@ -426,7 +424,6 @@
|
||||||
<string name="pack_directory">Package directory</string>
|
<string name="pack_directory">Package directory</string>
|
||||||
<string name="info">information</string>
|
<string name="info">information</string>
|
||||||
<string name="cut_board_operation">Shear-plate operation</string>
|
<string name="cut_board_operation">Shear-plate operation</string>
|
||||||
<string name="bookmarks_operation">Bookmarks operation</string>
|
|
||||||
<string name="bookmark_manager">Bookmark Manager</string>
|
<string name="bookmark_manager">Bookmark Manager</string>
|
||||||
<string name="jump_a_bookmark">Jump a bookmark</string>
|
<string name="jump_a_bookmark">Jump a bookmark</string>
|
||||||
<string name="remove_bookmark">Remove the bookmark</string>
|
<string name="remove_bookmark">Remove the bookmark</string>
|
||||||
|
@ -606,11 +603,6 @@
|
||||||
<string name="mod_package">Mod package</string>
|
<string name="mod_package">Mod package</string>
|
||||||
<string name="restart_to_take_effect">I found that you have changed the image. Due to Glide cache mechanism, the assistant needs to restart to display the new image. Sorry for the inconvenience.</string>
|
<string name="restart_to_take_effect">I found that you have changed the image. Due to Glide cache mechanism, the assistant needs to restart to display the new image. Sorry for the inconvenience.</string>
|
||||||
<string name="extension">extension</string>
|
<string name="extension">extension</string>
|
||||||
<string name="use_adm">Adm Multithreaded download</string>
|
|
||||||
<string name="use_adm_tip">Allows you to call the Adm downloader for multithreaded downloads.</string>
|
|
||||||
<string name="setting_use_adm">useAdm</string>
|
|
||||||
<string name="no_adm_installed">Install Adm first.</string>
|
|
||||||
<string name="from_adm">Adm Download Directory</string>
|
|
||||||
<string name="word_wrap">Word wrap</string>
|
<string name="word_wrap">Word wrap</string>
|
||||||
<string name="database_error">The length of json result set is 0</string>
|
<string name="database_error">The length of json result set is 0</string>
|
||||||
<string name="mod_icon_transition">ModIconTransition</string>
|
<string name="mod_icon_transition">ModIconTransition</string>
|
||||||
|
|
|
@ -94,7 +94,6 @@
|
||||||
<string name="enter_file_path">ファイルパスを入力してください。</string>
|
<string name="enter_file_path">ファイルパスを入力してください。</string>
|
||||||
<string name="create_bookmark">しおりを作る</string>
|
<string name="create_bookmark">しおりを作る</string>
|
||||||
<string name="name_error">モジュール名を入力してください。</string>
|
<string name="name_error">モジュール名を入力してください。</string>
|
||||||
<string name="unit_name_error">ユニット名を入力してください。</string>
|
|
||||||
<string name="action_name_error">キャンペーン名を入力してください。</string>
|
<string name="action_name_error">キャンペーン名を入力してください。</string>
|
||||||
<string name="database_null">このデータセットはロードできません、エラー原因:%1$s。</string>
|
<string name="database_null">このデータセットはロードできません、エラー原因:%1$s。</string>
|
||||||
<string name="describe_error">記述を入力してください。</string>
|
<string name="describe_error">記述を入力してください。</string>
|
||||||
|
@ -113,7 +112,6 @@
|
||||||
<string name="mod_action1">編集単位</string>
|
<string name="mod_action1">編集単位</string>
|
||||||
<string name="mod_action2">情報を編集する</string>
|
<string name="mod_action2">情報を編集する</string>
|
||||||
<string name="mod_action8">だしぬけ</string>
|
<string name="mod_action8">だしぬけ</string>
|
||||||
<string name="mod_action9">命名を改める</string>
|
|
||||||
<string name="mod_action10">リペア情報ファイル</string>
|
<string name="mod_action10">リペア情報ファイル</string>
|
||||||
<string name="open_action1">テキストを編集する</string>
|
<string name="open_action1">テキストを編集する</string>
|
||||||
|
|
||||||
|
@ -425,7 +423,6 @@
|
||||||
<string name="pack_directory">カタログを梱包する</string>
|
<string name="pack_directory">カタログを梱包する</string>
|
||||||
<string name="info">情報</string>
|
<string name="info">情報</string>
|
||||||
<string name="cut_board_operation">せん断板操作</string>
|
<string name="cut_board_operation">せん断板操作</string>
|
||||||
<string name="bookmarks_operation">しおり操作</string>
|
|
||||||
<string name="bookmark_manager">ブックマークマネージャ</string>
|
<string name="bookmark_manager">ブックマークマネージャ</string>
|
||||||
<string name="jump_a_bookmark">飛びしおり</string>
|
<string name="jump_a_bookmark">飛びしおり</string>
|
||||||
<string name="remove_bookmark">しおりを取り除く</string>
|
<string name="remove_bookmark">しおりを取り除く</string>
|
||||||
|
@ -605,11 +602,6 @@
|
||||||
<string name="mod_package">モジュールパック</string>
|
<string name="mod_package">モジュールパック</string>
|
||||||
<string name="restart_to_take_effect">画像が変更されたことを確認すると、ヘルパーはGlideキャッシュ機構のために新しい画像を表示するために再起動する必要があります。ご不便をおかけして申し訳ありません。</string>
|
<string name="restart_to_take_effect">画像が変更されたことを確認すると、ヘルパーはGlideキャッシュ機構のために新しい画像を表示するために再起動する必要があります。ご不便をおかけして申し訳ありません。</string>
|
||||||
<string name="extension">広げて</string>
|
<string name="extension">広げて</string>
|
||||||
<string name="use_adm">Admマルチスレッドダウンロード</string>
|
|
||||||
<string name="use_adm_tip">Admダウンローダを呼び出し、マルチスレッドダウンロードを可能にする。</string>
|
|
||||||
<string name="setting_use_adm">使用アドム</string>
|
|
||||||
<string name="no_adm_installed">Admをインストールしてください。</string>
|
|
||||||
<string name="from_adm">Admダウンロードディレクトリ</string>
|
|
||||||
<string name="word_wrap">自動改行</string>
|
<string name="word_wrap">自動改行</string>
|
||||||
<string name="database_error">json結果のセット長さは0である。</string>
|
<string name="database_error">json結果のセット長さは0である。</string>
|
||||||
<string name="mod_icon_transition">ModIconTransition</string>
|
<string name="mod_icon_transition">ModIconTransition</string>
|
||||||
|
|
|
@ -94,7 +94,6 @@
|
||||||
<string name="enter_file_path">Введите, пожалуйста, маршрут файла.</string>
|
<string name="enter_file_path">Введите, пожалуйста, маршрут файла.</string>
|
||||||
<string name="create_bookmark">Создавать закладку</string>
|
<string name="create_bookmark">Создавать закладку</string>
|
||||||
<string name="name_error">Пожалуйста, введите имя модуля.</string>
|
<string name="name_error">Пожалуйста, введите имя модуля.</string>
|
||||||
<string name="unit_name_error">Введите имя единицы.</string>
|
|
||||||
<string name="action_name_error">Введите имя мероприятия.</string>
|
<string name="action_name_error">Введите имя мероприятия.</string>
|
||||||
<string name="database_null">Этот набор данных не может быть загружен по ложной причине :% $.</string>
|
<string name="database_null">Этот набор данных не может быть загружен по ложной причине :% $.</string>
|
||||||
<string name="describe_error">Введите описание, пожалуйста.</string>
|
<string name="describe_error">Введите описание, пожалуйста.</string>
|
||||||
|
@ -113,7 +112,6 @@
|
||||||
<string name="mod_action1">Монтажная единица</string>
|
<string name="mod_action1">Монтажная единица</string>
|
||||||
<string name="mod_action2">Редактирование.</string>
|
<string name="mod_action2">Редактирование.</string>
|
||||||
<string name="mod_action8">декомпресс</string>
|
<string name="mod_action8">декомпресс</string>
|
||||||
<string name="mod_action9">Переименовать.</string>
|
|
||||||
<string name="mod_action10">Восстанавливать файл информации</string>
|
<string name="mod_action10">Восстанавливать файл информации</string>
|
||||||
<string name="open_action1">Редактировать текст</string>
|
<string name="open_action1">Редактировать текст</string>
|
||||||
|
|
||||||
|
@ -425,7 +423,6 @@
|
||||||
<string name="pack_directory">Паковать каталог</string>
|
<string name="pack_directory">Паковать каталог</string>
|
||||||
<string name="info">информац</string>
|
<string name="info">информац</string>
|
||||||
<string name="cut_board_operation">Операция по монтажу</string>
|
<string name="cut_board_operation">Операция по монтажу</string>
|
||||||
<string name="bookmarks_operation">Операция закладка</string>
|
|
||||||
<string name="bookmark_manager">Менеджер закладок</string>
|
<string name="bookmark_manager">Менеджер закладок</string>
|
||||||
<string name="jump_a_bookmark">закладка</string>
|
<string name="jump_a_bookmark">закладка</string>
|
||||||
<string name="remove_bookmark">Убрать закладку</string>
|
<string name="remove_bookmark">Убрать закладку</string>
|
||||||
|
@ -605,11 +602,6 @@
|
||||||
<string name="mod_package">Набор Мод</string>
|
<string name="mod_package">Набор Мод</string>
|
||||||
<string name="restart_to_take_effect">Проверка показала, что вы заменили изображение, и поскольку Glide кэш механизм, ассистенту нужна перезагрузка, чтобы показать новое. Простите за неудобства.</string>
|
<string name="restart_to_take_effect">Проверка показала, что вы заменили изображение, и поскольку Glide кэш механизм, ассистенту нужна перезагрузка, чтобы показать новое. Простите за неудобства.</string>
|
||||||
<string name="extension">расширен</string>
|
<string name="extension">расширен</string>
|
||||||
<string name="use_adm">Мультипотоковая загрузка Adm</string>
|
|
||||||
<string name="use_adm_tip">Разрешите вызвать Adm-скачиватель для многопоточного скачивания.</string>
|
|
||||||
<string name="setting_use_adm">useAdm</string>
|
|
||||||
<string name="no_adm_installed">Пожалуйста, сначала установите Adm.</string>
|
|
||||||
<string name="from_adm">Adm загружает каталог</string>
|
|
||||||
<string name="word_wrap">Автоматическое переключение строк</string>
|
<string name="word_wrap">Автоматическое переключение строк</string>
|
||||||
<string name="database_error">Набор результатов json имеет длину 0</string>
|
<string name="database_error">Набор результатов json имеет длину 0</string>
|
||||||
<string name="mod_icon_transition">Модикон-переходный период</string>
|
<string name="mod_icon_transition">Модикон-переходный период</string>
|
||||||
|
|
|
@ -28,7 +28,6 @@
|
||||||
<string name="dialog_ok">確定</string>
|
<string name="dialog_ok">確定</string>
|
||||||
<string name="dialog_cancel">取消</string>
|
<string name="dialog_cancel">取消</string>
|
||||||
<string name="search">搜索</string>
|
<string name="search">搜索</string>
|
||||||
<string name="unit_name_error">請輸入單位名稱。</string>
|
|
||||||
<string name="loading_units">加載單位...</string>
|
<string name="loading_units">加載單位...</string>
|
||||||
<string name="symbol9">整理代碼</string>
|
<string name="symbol9">整理代碼</string>
|
||||||
<string name="edit_function">保存</string>
|
<string name="edit_function">保存</string>
|
||||||
|
|
|
@ -36,6 +36,7 @@
|
||||||
<string name="pay_yes">是的,确实收到了</string>
|
<string name="pay_yes">是的,确实收到了</string>
|
||||||
<string name="pay_no">不,没有</string>
|
<string name="pay_no">不,没有</string>
|
||||||
<string name="creation_assistant">创建助理</string>
|
<string name="creation_assistant">创建助理</string>
|
||||||
|
<string name="drag_the_slider_to_set_num">拖动滑块选择数量。</string>
|
||||||
<string name="dialog_cancel">取消</string>
|
<string name="dialog_cancel">取消</string>
|
||||||
<string name="no_longer_prompt">不再提示</string>
|
<string name="no_longer_prompt">不再提示</string>
|
||||||
<string name="navigation_tip">共%1$d个项目支持快速导航。</string>
|
<string name="navigation_tip">共%1$d个项目支持快速导航。</string>
|
||||||
|
@ -469,6 +470,11 @@
|
||||||
<string name="special_thanks_to">特别鸣谢</string>
|
<string name="special_thanks_to">特别鸣谢</string>
|
||||||
<string name="email">邮箱</string>
|
<string name="email">邮箱</string>
|
||||||
<string name="coin_number">硬币:%1$d</string>
|
<string name="coin_number">硬币:%1$d</string>
|
||||||
|
<string name="insert_coins_tip">投了%1$d个硬币。</string>
|
||||||
|
<string name="insert_coins_num_tip">要投几个硬币呢?</string>
|
||||||
|
<string name="coin_records">投币记录</string>
|
||||||
|
<string name="insert_coins_no">支持一下喜欢的作品吧。</string>
|
||||||
|
<string name="insert_coins_ok">已收到您的支持了。</string>
|
||||||
<string name="register_successed">注册成功</string>
|
<string name="register_successed">注册成功</string>
|
||||||
<string name="registration_success_message">账号激活码已发送至您的邮箱。若没有收到,则邮箱可能被视为垃圾邮件了。请检查您的垃圾箱。</string>
|
<string name="registration_success_message">账号激活码已发送至您的邮箱。若没有收到,则邮箱可能被视为垃圾邮件了。请检查您的垃圾箱。</string>
|
||||||
<string name="please_login_first">请先登录。</string>
|
<string name="please_login_first">请先登录。</string>
|
||||||
|
@ -914,7 +920,8 @@
|
||||||
<string name="edit_text_color_dark">暗色主题字体颜色</string>
|
<string name="edit_text_color_dark">暗色主题字体颜色</string>
|
||||||
<string name="user_group">用户群</string>
|
<string name="user_group">用户群</string>
|
||||||
<string name="discord_group">Discord服务器</string>
|
<string name="discord_group">Discord服务器</string>
|
||||||
<!-- <string name="search_suggestions_null">无搜索建议。</string>-->
|
<string name="search_suggestions_null">无搜索建议。</string>
|
||||||
<!-- <string name="search_suggestions_number">共%1$d个搜索建议。</string>-->
|
<string name="search_suggestions_loading">获取搜索建议...</string>
|
||||||
|
<string name="search_suggestions_number">共%1$d个搜索建议。</string>
|
||||||
|
|
||||||
</resources>
|
</resources>
|
|
@ -22,7 +22,8 @@ class CodeTranslate(val context: Context) {
|
||||||
|
|
||||||
companion object {
|
companion object {
|
||||||
const val split = "\n ,:()=%{}+*/\r"
|
const val split = "\n ,:()=%{}+*/\r"
|
||||||
const val debugKey = "代码翻译器"
|
private var debugKey = "代码翻译器"
|
||||||
|
private var num = 0
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -120,9 +121,21 @@ class CodeTranslate(val context: Context) {
|
||||||
fun start(input: String, func: (String) -> Unit) {
|
fun start(input: String, func: (String) -> Unit) {
|
||||||
val handler = Handler(Looper.getMainLooper())
|
val handler = Handler(Looper.getMainLooper())
|
||||||
val scope = CoroutineScope(Job())
|
val scope = CoroutineScope(Job())
|
||||||
|
num++
|
||||||
|
debugKey = "代码翻译器-任务${num}"
|
||||||
|
DebugHelper.printLog(
|
||||||
|
CodeTranslate.debugKey,
|
||||||
|
"开始执行(英文模式${englishMode} 翻译模式${translateMode})...",
|
||||||
|
"代码翻译", isError = true
|
||||||
|
)
|
||||||
scope.launch {
|
scope.launch {
|
||||||
if (englishMode) {
|
if (englishMode) {
|
||||||
//如果是英文模式,无论是翻译还是编译都返回其本身。
|
//如果是英文模式,无论是翻译还是编译都返回其本身。
|
||||||
|
DebugHelper.printLog(
|
||||||
|
CodeTranslate.debugKey,
|
||||||
|
"是英文模式返回其本身。",
|
||||||
|
"代码翻译", isError = true
|
||||||
|
)
|
||||||
handler.post {
|
handler.post {
|
||||||
func.invoke(input)
|
func.invoke(input)
|
||||||
}
|
}
|
||||||
|
@ -260,7 +273,12 @@ class CodeTranslate(val context: Context) {
|
||||||
codeResult.append("]")
|
codeResult.append("]")
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
val codeInfo = codeDataBase.getCodeDao().findCodeByCode(code)
|
//翻译代码
|
||||||
|
val codeInfo = if (translateMode){
|
||||||
|
codeDataBase.getCodeDao().findCodeByCode(code)
|
||||||
|
}else{
|
||||||
|
codeDataBase.getCodeDao().findCodeByTranslate(code)
|
||||||
|
}
|
||||||
if (codeInfo == null) {
|
if (codeInfo == null) {
|
||||||
if (code.contains("_")) {
|
if (code.contains("_")) {
|
||||||
val lineParser = LineParser(code)
|
val lineParser = LineParser(code)
|
||||||
|
@ -307,7 +325,12 @@ class CodeTranslate(val context: Context) {
|
||||||
CodeBlockType.Reference
|
CodeBlockType.Reference
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
codeResult.append(codeInfo.translate)
|
if (translateMode)
|
||||||
|
{
|
||||||
|
codeResult.append(codeInfo.translate)
|
||||||
|
}else{
|
||||||
|
codeResult.append(codeInfo.code)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,20 @@
|
||||||
|
package com.coldmint.rust.core.dataBean.mod
|
||||||
|
|
||||||
|
|
||||||
|
import com.google.gson.annotations.SerializedName
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 投币状态
|
||||||
|
* @property code Int
|
||||||
|
* @property `data` Boolean
|
||||||
|
* @property message String
|
||||||
|
* @constructor
|
||||||
|
*/
|
||||||
|
data class CoinStatusData(
|
||||||
|
@SerializedName("code")
|
||||||
|
val code: Int,
|
||||||
|
@SerializedName("data")
|
||||||
|
val `data`: Boolean = true,
|
||||||
|
@SerializedName("message")
|
||||||
|
val message: String
|
||||||
|
)
|
|
@ -0,0 +1,26 @@
|
||||||
|
package com.coldmint.rust.core.dataBean.mod
|
||||||
|
|
||||||
|
|
||||||
|
import com.google.gson.annotations.SerializedName
|
||||||
|
|
||||||
|
data class InsertCoinHistoryData(
|
||||||
|
@SerializedName("code")
|
||||||
|
val code: Int,
|
||||||
|
@SerializedName("data")
|
||||||
|
val `data`: MutableList<Data>,
|
||||||
|
@SerializedName("message")
|
||||||
|
val message: String
|
||||||
|
) {
|
||||||
|
data class Data(
|
||||||
|
@SerializedName("account")
|
||||||
|
val account: String,
|
||||||
|
@SerializedName("headIcon")
|
||||||
|
val headIcon: String?,
|
||||||
|
@SerializedName("number")
|
||||||
|
val number: Int,
|
||||||
|
@SerializedName("time")
|
||||||
|
val time: String,
|
||||||
|
@SerializedName("userName")
|
||||||
|
val userName: String
|
||||||
|
)
|
||||||
|
}
|
|
@ -2,6 +2,7 @@ package com.coldmint.rust.core.web
|
||||||
|
|
||||||
import android.os.Handler
|
import android.os.Handler
|
||||||
import android.os.Looper
|
import android.os.Looper
|
||||||
|
import android.util.Log
|
||||||
import com.coldmint.rust.core.dataBean.HotSearchData
|
import com.coldmint.rust.core.dataBean.HotSearchData
|
||||||
import com.coldmint.rust.core.dataBean.SearchSuggestionsData
|
import com.coldmint.rust.core.dataBean.SearchSuggestionsData
|
||||||
import com.coldmint.rust.core.dataBean.user.SearchResultDataBean
|
import com.coldmint.rust.core.dataBean.user.SearchResultDataBean
|
||||||
|
@ -86,6 +87,7 @@ class Search private constructor() {
|
||||||
override fun onResponse(call: Call, response: Response) {
|
override fun onResponse(call: Call, response: Response) {
|
||||||
try {
|
try {
|
||||||
val data = response.body!!.string()
|
val data = response.body!!.string()
|
||||||
|
Log.d("搜索结果",data)
|
||||||
val finalSearchSuggestionsData =
|
val finalSearchSuggestionsData =
|
||||||
gson.fromJson(data, SearchSuggestionsData::class.java)
|
gson.fromJson(data, SearchSuggestionsData::class.java)
|
||||||
handler.post {
|
handler.post {
|
||||||
|
|
|
@ -39,6 +39,164 @@ class WebMod private constructor() {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取投币状态
|
||||||
|
* @param token String
|
||||||
|
* @param modId String
|
||||||
|
* @param apiCallBack ApiCallBack<CoinStatusData>
|
||||||
|
*/
|
||||||
|
fun getCoinStatus(token: String, modId: String, apiCallBack: ApiCallBack<CoinStatusData>) {
|
||||||
|
val okHttpClient = ServerConfiguration.initOkHttpClient()
|
||||||
|
val requestBodyBuilder: FormBody.Builder =
|
||||||
|
FormBody.Builder().add("token", token).add("modId", modId)
|
||||||
|
val requestBody = requestBodyBuilder.build()
|
||||||
|
val request =
|
||||||
|
Request.Builder()
|
||||||
|
.url(ServerConfiguration.website + "php/mod.php?action=getCoinStatus")
|
||||||
|
.post(requestBody).build()
|
||||||
|
val call = okHttpClient.newCall(request)
|
||||||
|
val handler = Handler(Looper.getMainLooper())
|
||||||
|
val gson = Gson()
|
||||||
|
call.enqueue(object : Callback {
|
||||||
|
override fun onFailure(call: Call, e: IOException) {
|
||||||
|
e.printStackTrace()
|
||||||
|
handler.post { apiCallBack.onFailure(e) }
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun onResponse(call: Call, response: Response) {
|
||||||
|
try {
|
||||||
|
val body = response.body
|
||||||
|
if (body == null) {
|
||||||
|
handler.post {
|
||||||
|
apiCallBack.onFailure(NullPointerException())
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
val data = body.string()
|
||||||
|
val finalCoinStatusData =
|
||||||
|
gson.fromJson(data, CoinStatusData::class.java)
|
||||||
|
handler.post {
|
||||||
|
apiCallBack.onResponse(finalCoinStatusData)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (e: Exception) {
|
||||||
|
e.printStackTrace()
|
||||||
|
handler.post {
|
||||||
|
apiCallBack.onFailure(e)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取投币历史
|
||||||
|
* @param token String
|
||||||
|
* @param modId String
|
||||||
|
* @param apiCallBack ApiCallBack<CoinStatusData>
|
||||||
|
*/
|
||||||
|
fun getInsertCoinHistory(modId: String, apiCallBack: ApiCallBack<InsertCoinHistoryData>) {
|
||||||
|
val okHttpClient = ServerConfiguration.initOkHttpClient()
|
||||||
|
val requestBodyBuilder: FormBody.Builder =
|
||||||
|
FormBody.Builder().add("modId", modId)
|
||||||
|
val requestBody = requestBodyBuilder.build()
|
||||||
|
val request =
|
||||||
|
Request.Builder()
|
||||||
|
.url(ServerConfiguration.website + "php/mod.php?action=getInsertCoinHistory")
|
||||||
|
.post(requestBody).build()
|
||||||
|
val call = okHttpClient.newCall(request)
|
||||||
|
val handler = Handler(Looper.getMainLooper())
|
||||||
|
val gson = Gson()
|
||||||
|
call.enqueue(object : Callback {
|
||||||
|
override fun onFailure(call: Call, e: IOException) {
|
||||||
|
e.printStackTrace()
|
||||||
|
handler.post { apiCallBack.onFailure(e) }
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun onResponse(call: Call, response: Response) {
|
||||||
|
try {
|
||||||
|
val body = response.body
|
||||||
|
if (body == null) {
|
||||||
|
handler.post {
|
||||||
|
apiCallBack.onFailure(NullPointerException())
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
val data = body.string()
|
||||||
|
val finalCoinStatusData =
|
||||||
|
gson.fromJson(data, InsertCoinHistoryData::class.java)
|
||||||
|
handler.post {
|
||||||
|
apiCallBack.onResponse(finalCoinStatusData)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (e: Exception) {
|
||||||
|
e.printStackTrace()
|
||||||
|
handler.post {
|
||||||
|
apiCallBack.onFailure(e)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 投币模组
|
||||||
|
* @param token String
|
||||||
|
* @param modId String
|
||||||
|
* @param apiCallBack ApiCallBack<CoinStatusData>
|
||||||
|
*/
|
||||||
|
fun insertCoins(
|
||||||
|
token: String,
|
||||||
|
modId: String,
|
||||||
|
number: Int,
|
||||||
|
apiCallBack: ApiCallBack<ApiResponse>
|
||||||
|
) {
|
||||||
|
val okHttpClient = ServerConfiguration.initOkHttpClient()
|
||||||
|
val requestBodyBuilder: FormBody.Builder =
|
||||||
|
FormBody.Builder().add("modId", modId).add("token", token)
|
||||||
|
.add("number", number.toString())
|
||||||
|
val requestBody = requestBodyBuilder.build()
|
||||||
|
val request =
|
||||||
|
Request.Builder()
|
||||||
|
.url(ServerConfiguration.website + "php/mod.php?action=insertCoins")
|
||||||
|
.post(requestBody).build()
|
||||||
|
val call = okHttpClient.newCall(request)
|
||||||
|
val handler = Handler(Looper.getMainLooper())
|
||||||
|
val gson = Gson()
|
||||||
|
call.enqueue(object : Callback {
|
||||||
|
override fun onFailure(call: Call, e: IOException) {
|
||||||
|
e.printStackTrace()
|
||||||
|
handler.post { apiCallBack.onFailure(e) }
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun onResponse(call: Call, response: Response) {
|
||||||
|
try {
|
||||||
|
val body = response.body
|
||||||
|
if (body == null) {
|
||||||
|
handler.post {
|
||||||
|
apiCallBack.onFailure(NullPointerException())
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
val data = body.string()
|
||||||
|
val finalApiResponse =
|
||||||
|
gson.fromJson(data, ApiResponse::class.java)
|
||||||
|
handler.post {
|
||||||
|
apiCallBack.onResponse(finalApiResponse)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (e: Exception) {
|
||||||
|
e.printStackTrace()
|
||||||
|
handler.post {
|
||||||
|
apiCallBack.onFailure(e)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 加载随机推荐
|
* 加载随机推荐
|
||||||
* @param number Int 推荐数量
|
* @param number Int 推荐数量
|
||||||
|
@ -585,7 +743,7 @@ class WebMod private constructor() {
|
||||||
override fun onResponse(call: Call, response: Response) {
|
override fun onResponse(call: Call, response: Response) {
|
||||||
try {
|
try {
|
||||||
val data = response.body!!.string()
|
val data = response.body!!.string()
|
||||||
Log.d("模组信息",data)
|
Log.d("模组信息", data)
|
||||||
val finalWebModInfoData =
|
val finalWebModInfoData =
|
||||||
gson.fromJson(data, WebModInfoData::class.java)
|
gson.fromJson(data, WebModInfoData::class.java)
|
||||||
handler.post {
|
handler.post {
|
||||||
|
@ -957,7 +1115,7 @@ class WebMod private constructor() {
|
||||||
val body = response.body
|
val body = response.body
|
||||||
if (body != null) {
|
if (body != null) {
|
||||||
val data = body.string()
|
val data = body.string()
|
||||||
Log.d("发布模组响应",data)
|
Log.d("发布模组响应", data)
|
||||||
val finalApiResponse = gson.fromJson(data, ApiResponse::class.java)
|
val finalApiResponse = gson.fromJson(data, ApiResponse::class.java)
|
||||||
handler.post {
|
handler.post {
|
||||||
apiCallBack.onResponse(finalApiResponse)
|
apiCallBack.onResponse(finalApiResponse)
|
||||||
|
|
|
@ -54,7 +54,7 @@ class CoreDialog(context: Context) : BaseAppDialog<CoreDialog>(context) {
|
||||||
* 是否选择了
|
* 是否选择了
|
||||||
* @return Boolean
|
* @return Boolean
|
||||||
*/
|
*/
|
||||||
fun isChecked():Boolean{
|
fun isChecked(): Boolean {
|
||||||
return dialogCoreBinding.checkbox.isChecked
|
return dialogCoreBinding.checkbox.isChecked
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -129,6 +129,31 @@ class CoreDialog(context: Context) : BaseAppDialog<CoreDialog>(context) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
override fun setNeutralButton(text: String, func: () -> Unit): CoreDialog {
|
||||||
|
dialogCoreBinding.buttonContainer.isVisible = true
|
||||||
|
dialogCoreBinding.neutralButton.isVisible = true
|
||||||
|
dialogCoreBinding.neutralButton.text = text
|
||||||
|
dialogCoreBinding.neutralButton.setOnClickListener {
|
||||||
|
func.invoke()
|
||||||
|
if (autoDismiss) {
|
||||||
|
dialog.dismiss()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return this
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun setNeutralButton(textRes: Int, func: () -> Unit): CoreDialog {
|
||||||
|
dialogCoreBinding.buttonContainer.isVisible = true
|
||||||
|
dialogCoreBinding.neutralButton.isVisible = true
|
||||||
|
dialogCoreBinding.neutralButton.setText(textRes)
|
||||||
|
dialogCoreBinding.neutralButton.setOnClickListener {
|
||||||
|
func.invoke()
|
||||||
|
if (autoDismiss) {
|
||||||
|
dialog.dismiss()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return this }
|
||||||
|
|
||||||
@Deprecated("无法使用。")
|
@Deprecated("无法使用。")
|
||||||
override fun setIcon(iconRes: Int): CoreDialog {
|
override fun setIcon(iconRes: Int): CoreDialog {
|
||||||
return super.setIcon(iconRes)
|
return super.setIcon(iconRes)
|
||||||
|
|
|
@ -36,30 +36,39 @@
|
||||||
|
|
||||||
|
|
||||||
<RelativeLayout
|
<RelativeLayout
|
||||||
|
android:visibility="gone"
|
||||||
android:id="@+id/buttonContainer"
|
android:id="@+id/buttonContainer"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_marginTop="24dp"
|
android:layout_marginTop="24dp">
|
||||||
android:visibility="gone">
|
|
||||||
|
|
||||||
<Button
|
<Button
|
||||||
|
android:visibility="gone"
|
||||||
|
android:id="@+id/neutralButton"
|
||||||
|
android:layout_alignParentLeft="true"
|
||||||
|
style="@style/Widget.Material3.Button.TextButton.Dialog.Flush"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/title" />
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:visibility="gone"
|
||||||
android:id="@+id/negativeButton"
|
android:id="@+id/negativeButton"
|
||||||
style="@style/Widget.Material3.Button.TextButton.Dialog.Flush"
|
style="@style/Widget.Material3.Button.TextButton.Dialog.Flush"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_toLeftOf="@id/positiveButton"
|
android:layout_toLeftOf="@id/positiveButton"
|
||||||
android:text="@string/title"
|
android:text="@string/title" />
|
||||||
android:visibility="gone" />
|
|
||||||
|
|
||||||
<Button
|
<Button
|
||||||
|
android:visibility="gone"
|
||||||
android:id="@+id/positiveButton"
|
android:id="@+id/positiveButton"
|
||||||
style="@style/Widget.Material3.Button.TextButton.Dialog.Flush"
|
style="@style/Widget.Material3.Button.TextButton.Dialog.Flush"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_alignParentEnd="true"
|
android:layout_alignParentEnd="true"
|
||||||
android:layout_marginLeft="8dp"
|
android:layout_marginLeft="8dp"
|
||||||
android:text="@string/title"
|
android:text="@string/title" />
|
||||||
android:visibility="gone" />
|
|
||||||
|
|
||||||
</RelativeLayout>
|
</RelativeLayout>
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user