|
@@ -13,6 +13,11 @@ import com.sambath.kunkhmer.remote.service.ApiService
|
|
import com.sambath.kunkhmer.util.PrefHelper
|
|
import com.sambath.kunkhmer.util.PrefHelper
|
|
import io.reactivex.android.schedulers.AndroidSchedulers
|
|
import io.reactivex.android.schedulers.AndroidSchedulers
|
|
import io.reactivex.schedulers.Schedulers
|
|
import io.reactivex.schedulers.Schedulers
|
|
|
|
+import okhttp3.MediaType.Companion.toMediaTypeOrNull
|
|
|
|
+import okhttp3.MultipartBody
|
|
|
|
+import okhttp3.RequestBody.Companion.asRequestBody
|
|
|
|
+import okhttp3.RequestBody.Companion.toRequestBody
|
|
|
|
+import java.io.File
|
|
import java.util.concurrent.TimeUnit
|
|
import java.util.concurrent.TimeUnit
|
|
|
|
|
|
class ShopViewModel(val apiService: ApiService, val prefHelper: PrefHelper) : BaseViewModel() {
|
|
class ShopViewModel(val apiService: ApiService, val prefHelper: PrefHelper) : BaseViewModel() {
|
|
@@ -53,25 +58,53 @@ class ShopViewModel(val apiService: ApiService, val prefHelper: PrefHelper) : Ba
|
|
|
|
|
|
fun createProduct(name: String, desc: String, price: String, upload: String) {
|
|
fun createProduct(name: String, desc: String, price: String, upload: String) {
|
|
if (_state.value!!.isProgress) return
|
|
if (_state.value!!.isProgress) return
|
|
- val request = CreateProductRequest(name, desc, price, upload)
|
|
|
|
|
|
+ //val request = CreateProductRequest(name, desc, price, upload)
|
|
_state.value = prev().copy(isProgress = true)
|
|
_state.value = prev().copy(isProgress = true)
|
|
|
|
|
|
- disposables.add(
|
|
|
|
- apiService.createProduct(request)
|
|
|
|
- .timeout(10, TimeUnit.SECONDS)
|
|
|
|
- .subscribeOn(Schedulers.io())
|
|
|
|
- .observeOn(AndroidSchedulers.mainThread())
|
|
|
|
- .subscribe({
|
|
|
|
- Log.d("login", it.toString())
|
|
|
|
- if (it.resultCode == 1) {
|
|
|
|
- _state.value = prev().copy(isProgress = false, isLoginSuccess = true)
|
|
|
|
- } else {
|
|
|
|
- _state.value = prev().copy(isProgress = false, error = "[${it.message.description}]")
|
|
|
|
- }
|
|
|
|
- }, {
|
|
|
|
- val message: String = "ប្រតិបត្តិការមិនជោគជ័យ " + it.getErrorCode() + it.message
|
|
|
|
- _state.value = prev().copy(isProgress = false, error = message)
|
|
|
|
- })
|
|
|
|
- )
|
|
|
|
|
|
+ val namePart = name.toRequestBody("text/plain".toMediaTypeOrNull())
|
|
|
|
+ val descPart = desc.toRequestBody("text/plain".toMediaTypeOrNull())
|
|
|
|
+ val pricePart = price.toRequestBody("text/plain".toMediaTypeOrNull())
|
|
|
|
+
|
|
|
|
+ if (!upload.isNullOrEmpty()) {
|
|
|
|
+ val file = File(upload)
|
|
|
|
+ val filePart = MultipartBody.Part.createFormData("upload", file.name, file.asRequestBody("image/jpg".toMediaTypeOrNull()))
|
|
|
|
+ _state.value = prev().copy(isProgress = true)
|
|
|
|
+
|
|
|
|
+ disposables.add(
|
|
|
|
+ apiService.createProduct(namePart, descPart, pricePart, filePart)
|
|
|
|
+ .timeout(10, TimeUnit.SECONDS)
|
|
|
|
+ .subscribeOn(Schedulers.io())
|
|
|
|
+ .observeOn(AndroidSchedulers.mainThread())
|
|
|
|
+ .subscribe({
|
|
|
|
+ Log.d("login", it.toString())
|
|
|
|
+ if (it.resultCode == 1) {
|
|
|
|
+ _state.value = prev().copy(isProgress = false, isLoginSuccess = true)
|
|
|
|
+ } else {
|
|
|
|
+ _state.value = prev().copy(isProgress = false, error = "[${it.message.description}]")
|
|
|
|
+ }
|
|
|
|
+ }, {
|
|
|
|
+ val message: String = "ប្រតិបត្តិការមិនជោគជ័យ " + it.getErrorCode() + it.message
|
|
|
|
+ _state.value = prev().copy(isProgress = false, error = message)
|
|
|
|
+ })
|
|
|
|
+ )
|
|
|
|
+ } else {
|
|
|
|
+ disposables.add(
|
|
|
|
+ apiService.createProduct(namePart, descPart, pricePart)
|
|
|
|
+ .timeout(10, TimeUnit.SECONDS)
|
|
|
|
+ .subscribeOn(Schedulers.io())
|
|
|
|
+ .observeOn(AndroidSchedulers.mainThread())
|
|
|
|
+ .subscribe({
|
|
|
|
+ Log.d("login", it.toString())
|
|
|
|
+ if (it.resultCode == 1) {
|
|
|
|
+ _state.value = prev().copy(isProgress = false, isLoginSuccess = true)
|
|
|
|
+ } else {
|
|
|
|
+ _state.value = prev().copy(isProgress = false, error = "[${it.message.description}]")
|
|
|
|
+ }
|
|
|
|
+ }, {
|
|
|
|
+ val message: String = "ប្រតិបត្តិការមិនជោគជ័យ " + it.getErrorCode() + it.message
|
|
|
|
+ _state.value = prev().copy(isProgress = false, error = message)
|
|
|
|
+ })
|
|
|
|
+ )
|
|
|
|
+ }
|
|
}
|
|
}
|
|
}
|
|
}
|