Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Implement hex color conversion #1270

Merged
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
78 changes: 78 additions & 0 deletions gspread/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -695,6 +695,84 @@ def combined_merge_values(worksheet_metadata, values):
return new_values


def convert_hex_to_colors_dict(hex_color: str):
alifeee marked this conversation as resolved.
Show resolved Hide resolved
"""Convert a hex color code to RGB color values.

:param str hex_color: Hex color code in the format "#RRGGBB".

:returns: Dict containing the color's red, green and blue values between 0 and 1.
:rtype: dict

:raises:
ValueError: If the input hex string is not in the correct format or length.

Examples:
>>> convert_hex_to_color("#3300CC")
{'red': 0.2, 'green': 0.0, 'blue': 0.8}

"""
hex_color = hex_color.lstrip("#")

# Google API ColorStyle Reference:
# "The alpha value in the Color object isn't generally supported."
# https://developers.google.com/sheets/api/reference/rest/v4/spreadsheets/other#colorstyle
if len(hex_color) == 8:
hex_color = hex_color[:-2]

alifeee marked this conversation as resolved.
Show resolved Hide resolved
if len(hex_color) != 6:
raise ValueError("Hex color code must be in the format '#RRGGBB'.")

try:
rgb_color = {
"red": int(hex_color[0:2], 16) / 255,
"green": int(hex_color[2:4], 16) / 255,
"blue": int(hex_color[4:6], 16) / 255,
}

return rgb_color
except ValueError:
raise ValueError(f"Invalid character in hex color string: #{hex_color}")


def convert_colors_to_hex_value(red=0, green=0, blue=0):
alifeee marked this conversation as resolved.
Show resolved Hide resolved
"""Convert RGB color values to a hex color code.

:param int red: Red color value (0-255).
:param int green: Green color value (0-255).
:param int blue: Blue color value (0-255).

:returns: Hex color code in the format "#RRGGBB".
:rtype: str

:raises:
ValueError: If any color value is out of the accepted range (0-255).

Example:

>>> convert_colors_to_hex_value(51, 0, 204)
'#3300CC'

>>> convert_colors_to_hex_value(green=128)
'#008000'
"""

def to_hex(value):
alifeee marked this conversation as resolved.
Show resolved Hide resolved
"""
Convert an integer to a 2-digit uppercase hex string.
"""
hex_value = hex(value)[2:]
return hex_value.upper().zfill(2)

if any(value not in range(256) for value in (red, green, blue)):
raise ValueError("Color value out of accepted range 0-255.")

r_hex = to_hex(red)
g_hex = to_hex(green)
b_hex = to_hex(blue)
hex_color = f"#{r_hex}{g_hex}{b_hex}"
return hex_color
alifeee marked this conversation as resolved.
Show resolved Hide resolved


if __name__ == "__main__":
import doctest

Expand Down
10 changes: 10 additions & 0 deletions gspread/worksheet.py
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@
cast_to_a1_notation,
cell_list_to_rect,
combined_merge_values,
convert_hex_to_colors_dict,
fill_gaps,
finditem,
numericise_all,
Expand Down Expand Up @@ -1577,6 +1578,15 @@ def clear_tab_color(self) -> JSONResponse:
self._properties.pop("tabColorStyle")
return response

def set_tab_color(self, hex_color: str):
idonec marked this conversation as resolved.
Show resolved Hide resolved
"""Changes the worksheet's tab color.
Use clear_tab_color() to remove the color.

:param str hex_color: Hex color code in the format "#RRGGBB".
"""
rgb_color = convert_hex_to_colors_dict(hex_color)
return self.update_tab_color(rgb_color)

def update_index(self, index: int) -> JSONResponse:
"""Updates the ``index`` property for the worksheet.

Expand Down
Loading