fix: analytics colors when segmented by cycle, module, dates, and assignees (#1072)

* fix: show unique colors when segmented

* chore: modify random color generator function

* chore: modify random color generator function
This commit is contained in:
Aaryan Khandelwal 2023-05-18 19:07:24 +05:30 committed by GitHub
parent 5916d6e749
commit 09cffd5498
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 45 additions and 13 deletions

View File

@ -83,8 +83,6 @@ export const AnalyticsGraph: React.FC<Props> = ({
(a) => a.assignees__email === datum.value (a) => a.assignees__email === datum.value
)?.assignees__avatar; )?.assignees__avatar;
console.log(avatar);
if (avatar && avatar !== "") if (avatar && avatar !== "")
return ( return (
<g transform={`translate(${datum.x},${datum.y})`}> <g transform={`translate(${datum.x},${datum.y})`}>

View File

@ -13,7 +13,12 @@ export const SelectProject: React.FC<Props> = ({ value, onChange, projects }) =>
const options = projects?.map((project) => ({ const options = projects?.map((project) => ({
value: project.id, value: project.id,
query: project.name + project.identifier, query: project.name + project.identifier,
content: <>{project.name}</>, content: (
<div className="flex items-center gap-2">
<span className="text-brand-secondary text-[0.65rem]">{project.identifier}</span>
{project.name}
</div>
),
})); }));
return ( return (
@ -30,7 +35,6 @@ export const SelectProject: React.FC<Props> = ({ value, onChange, projects }) =>
: "All projects" : "All projects"
} }
optionsClassName="min-w-full" optionsClassName="min-w-full"
noChevron
multiple multiple
/> />
); );

View File

@ -1,8 +1,11 @@
import React, { useState } from "react"; import React, { useState } from "react";
// headless ui // headless ui
import { Combobox, Transition } from "@headlessui/react"; import { Combobox, Transition } from "@headlessui/react";
// icons // icons
import { CheckIcon, ChevronDownIcon, MagnifyingGlassIcon } from "@heroicons/react/24/outline"; import { ChevronDownIcon } from "@heroicons/react/20/solid";
import { CheckIcon, MagnifyingGlassIcon } from "@heroicons/react/24/outline";
type CustomSearchSelectProps = { type CustomSearchSelectProps = {
value: any; value: any;
onChange: any; onChange: any;

View File

@ -1,4 +1,5 @@
import React from "react"; import React from "react";
// headless ui // headless ui
import { Listbox, Transition } from "@headlessui/react"; import { Listbox, Transition } from "@headlessui/react";
// icons // icons

View File

@ -1,7 +1,7 @@
// nivo // nivo
import { BarDatum } from "@nivo/bar"; import { BarDatum } from "@nivo/bar";
// helpers // helpers
import { capitalizeFirstLetter } from "helpers/string.helper"; import { capitalizeFirstLetter, generateRandomColor } from "helpers/string.helper";
// types // types
import { IAnalyticsData, IAnalyticsParams, IAnalyticsResponse } from "types"; import { IAnalyticsData, IAnalyticsParams, IAnalyticsResponse } from "types";
// constants // constants
@ -65,7 +65,8 @@ export const generateBarColor = (
params: IAnalyticsParams, params: IAnalyticsParams,
type: "x_axis" | "segment" type: "x_axis" | "segment"
): string => { ): string => {
let color: string | undefined = "rgb(var(--color-accent))"; let color: string | undefined = generateRandomColor(value);
console.log(value);
if (!analytics) return color; if (!analytics) return color;
@ -74,19 +75,22 @@ export const generateBarColor = (
if (params[type] === "state__group") color = STATE_GROUP_COLORS[value.toLowerCase()]; if (params[type] === "state__group") color = STATE_GROUP_COLORS[value.toLowerCase()];
if (params[type] === "priority") if (params[type] === "priority") {
const priority = value.toLowerCase();
color = color =
value === "Urgent" priority === "urgent"
? "#ef4444" ? "#ef4444"
: value === "High" : priority === "high"
? "#f97316" ? "#f97316"
: value === "Medium" : priority === "medium"
? "#eab308" ? "#eab308"
: value === "Low" : priority === "low"
? "#22c55e" ? "#22c55e"
: "#ced4da"; : "#ced4da";
}
return color ?? "rgb(var(--color-accent))"; return color ?? generateRandomColor(value);
}; };
export const renderMonthAndYear = (date: string | number | null): string => { export const renderMonthAndYear = (date: string | number | null): string => {

View File

@ -87,3 +87,25 @@ export const cosineSimilarity = (a: string, b: string) => {
return dotProduct / Math.sqrt(magnitudeA * magnitudeB); return dotProduct / Math.sqrt(magnitudeA * magnitudeB);
}; };
export const generateRandomColor = (string: string): string => {
if (!string) return "var(--color-accent)";
string = `${string}`;
const uniqueId = string.length.toString() + string; // Unique identifier based on string length
const combinedString = uniqueId + string;
const hash = Array.from(combinedString).reduce((acc, char) => {
const charCode = char.charCodeAt(0);
return (acc << 5) - acc + charCode;
}, 0);
const hue = hash % 360;
const saturation = 70; // Higher saturation for pastel colors
const lightness = 60; // Mid-range lightness for pastel colors
const randomColor = `hsl(${hue}, ${saturation}%, ${lightness}%)`;
return randomColor;
};