Skip to content

Commit

Permalink
Fixed color parsing bug.
Browse files Browse the repository at this point in the history
  • Loading branch information
tamaskozmer committed Jun 21, 2022
1 parent 81ded70 commit 6202a9d
Show file tree
Hide file tree
Showing 3 changed files with 29 additions and 5 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,6 @@
package com.instructure.pandautils.utils

import android.content.Context
import android.graphics.Color
import android.graphics.PorterDuff
import android.graphics.drawable.Drawable
import androidx.annotation.ColorInt
Expand Down Expand Up @@ -135,11 +134,21 @@ object ColorKeeper : PrefManager(PREFERENCE_FILE_NAME) {
* @return The parsed color, or [defaultColor] if the string could not be parsed
*/
private fun parseColor(hexColor: String): Int = try {
ColorUtils.parseColor("#${hexColor.trimMargin("#")}", "")
val trimmedColorCode = getTrimmedColorCode(hexColor)
ColorUtils.parseColor(trimmedColorCode, defaultColor = defaultColor)
} catch (e: IllegalArgumentException) {
defaultColor
}

// There might be cases where the color code from the response contains whitespaces.
private fun getTrimmedColorCode(colorCode: String): String {
return if (colorCode.contains("#")) {
"#${colorCode.trimMargin("#")}"
} else {
colorCode
}
}

/**
* Generates a generic color based on the canvas context id, this will produce consistent colors for a given course
* @param canvasContext a valid canvas context
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ package com.instructure.pandautils.utils
import android.graphics.*
import android.graphics.drawable.Drawable
import android.widget.ImageView
import androidx.annotation.ColorInt
import androidx.core.graphics.drawable.DrawableCompat

object ColorUtils {
Expand Down Expand Up @@ -46,7 +47,7 @@ object ColorUtils {

@JvmStatic
@JvmOverloads
fun parseColor(colorCode: String?, defaultColorCode: String = ColorApiHelper.K5_DEFAULT_COLOR): Int {
fun parseColor(colorCode: String?, @ColorInt defaultColor: Int? = null): Int {
return try {
val fullColorCode = if (colorCode?.length == 4 && colorCode[0].toString() == "#") {
"#${colorCode[1]}${colorCode[1]}${colorCode[2]}${colorCode[2]}${colorCode[3]}${colorCode[3]}"
Expand All @@ -55,7 +56,11 @@ object ColorUtils {
}
Color.parseColor(fullColorCode)
} catch (e: Exception) {
Color.parseColor(defaultColorCode)
if (defaultColor != null) {
defaultColor
} else {
Color.parseColor(ColorApiHelper.K5_DEFAULT_COLOR)
}
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -122,10 +122,20 @@ object ThemePrefs : PrefManager("CanvasTheme") {

private fun parseColor(hexColor: String, defaultColor: Int): Int {
try {
return ColorUtils.parseColor("#${hexColor.trimMargin("#")}", "")
val trimmedColorCode = getTrimmedColorCode(hexColor)
return ColorUtils.parseColor(trimmedColorCode, defaultColor = defaultColor)
} catch (e: IllegalArgumentException) {
return defaultColor
}
}

// There might be cases where the color codes from the response contain whitespaces.
private fun getTrimmedColorCode(colorCode: String): String {
return if (colorCode.contains("#")) {
"#${colorCode.trimMargin("#")}"
} else {
colorCode
}
}

}

0 comments on commit 6202a9d

Please sign in to comment.