This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
@Composable | |
fun CircleMap() { | |
// Define the coordinates for circle centers and their associated information | |
val circleData = listOf( | |
CircleInfo("Park A", LatLng(37.7749, -122.4194), "This is Park A"), | |
CircleInfo("Park B", LatLng(36.7783, -119.4179), "This is Park B"), | |
CircleInfo("Park C", LatLng(34.0522, -118.2437), "This is Park C") | |
) | |
// Create a mutable state to track the selected circle |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
val url = Uri.parse("https://www.asos.com/") | |
val browserSelectorIntent = Intent() | |
.setAction(Intent.ACTION_VIEW) | |
.addCategory(Intent.CATEGORY_BROWSABLE) | |
.setData(Uri.parse("http:")) | |
val targetIntent = Intent() | |
.setAction(Intent.ACTION_VIEW) | |
.addCategory(Intent.CATEGORY_BROWSABLE) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#!/bin/zsh | |
function get_devices() { | |
all_devices=$(command adb devices) | |
all_devices=${all_devices#"List of devices attached"} | |
# Find how many devices we have | |
num_matches=$(echo $all_devices | egrep -o "([[:alnum:]-]+[[:space:]]+device$)" | wc -l) | |
# If there are multiple, ask for which device to send the command to |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import kotlin.random.Random | |
import kotlin.reflect.KClass | |
import kotlin.reflect.KFunction | |
import kotlin.reflect.KType | |
/** | |
* You can find the method explanation here on this post: | |
* https://zaqueusantos.medium.com/an-easy-way-to-create-fixture-or-dummy-classes-for-your-android-tests-with-kotlin-9d6c619237d4 | |
*/ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
class LocationService { | |
@SuppressLint("MissingPermission") | |
suspend fun getCurrentLocation(context: Context): Location { | |
if (!context.hasPermissions( | |
Manifest.permission.ACCESS_FINE_LOCATION, | |
Manifest.permission.ACCESS_COARSE_LOCATION | |
) | |
) { |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
sealed interface SallyResponseResource<out T> { | |
data class Success<T>(val data: T) : SallyResponseResource<T> | |
data class Error(val exception: AppException, val errorCode: String? = null) : | |
SallyResponseResource<Nothing> | |
data class Loading(val status: Boolean) : SallyResponseResource<Nothing> | |
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
open class AppException(message: String? = null, cause: Throwable? = null) : | |
Throwable(message, cause) | |
class NetworkException(message: String? = null, cause: Throwable? = null) : | |
AppException(message, cause) | |
class ServerException(message: String? = null, cause: Throwable? = null) : | |
AppException(message, cause) | |
class ClientException(message: String? = null, cause: Throwable? = null) : |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
suspend fun <T> asSallyResponseResourceSuspend(apiCall: suspend () -> T): SallyResponseResource<T> { | |
return try { | |
SallyResponseResource.Loading(true) | |
val response = apiCall.invoke() | |
SallyResponseResource.Success(response) | |
} catch (error: Throwable) { | |
val exception = when (error) { | |
is HttpException -> { | |
when (error.code()) { | |
in 400..499 -> { |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
fun <T> Flow<T>.asSallyResponseResourceFlow(): Flow<SallyResponseResource<T>> { | |
return this | |
.map<T, SallyResponseResource<T>> { | |
SallyResponseResource.Success(it) | |
} | |
.onStart { emit(SallyResponseResource.Loading(true)) } | |
.onCompletion { emit(SallyResponseResource.Loading(false)) } | |
.catch { error -> | |
val exception = when (error) { | |
is HttpException -> { |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
const val CLIENT_ERROR = "Terjadi kesalahan, mohon periksa masukan anda" | |
const val SERVER_ERROR = "Terjadi kesalahan pada Server, coba lagi nanti" | |
const val NETWORK_ERROR = "Koneksi internet bermasalah, coba lagi nanti" | |
const val HTTP_UNKNOWN_ERROR = "HTTP Error tidak diketahui (exc: 4xx/5xx)" | |
const val UNKNOWN_ERROR = "Error tidak diketahui" |