forked from github/plane
fix: make custom search select handle undefined options (#1094)
* fix: make search select handle undefined options * fix: kanban y-scroll
This commit is contained in:
parent
012486df11
commit
9ccc35d181
@ -152,7 +152,7 @@ export const AnalyticsSidebar: React.FC<Props> = ({
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<div key={project.id}>
|
<div key={project.id}>
|
||||||
<h5 className="text-sm flex items-center gap-1">
|
<div className="text-sm flex items-center gap-1">
|
||||||
{project.emoji ? (
|
{project.emoji ? (
|
||||||
<span className="grid h-6 w-6 flex-shrink-0 place-items-center">
|
<span className="grid h-6 w-6 flex-shrink-0 place-items-center">
|
||||||
{String.fromCodePoint(parseInt(project.emoji))}
|
{String.fromCodePoint(parseInt(project.emoji))}
|
||||||
@ -171,8 +171,13 @@ export const AnalyticsSidebar: React.FC<Props> = ({
|
|||||||
{project?.name.charAt(0)}
|
{project?.name.charAt(0)}
|
||||||
</span>
|
</span>
|
||||||
)}
|
)}
|
||||||
<span className="break-all">{project.name}</span>
|
<h5 className="break-all">
|
||||||
|
{project.name}
|
||||||
|
<span className="text-brand-secondary text-xs ml-1">
|
||||||
|
({project.identifier})
|
||||||
|
</span>
|
||||||
</h5>
|
</h5>
|
||||||
|
</div>
|
||||||
<div className="mt-4 space-y-3 pl-2">
|
<div className="mt-4 space-y-3 pl-2">
|
||||||
<div className="flex items-center justify-between gap-2 text-xs">
|
<div className="flex items-center justify-between gap-2 text-xs">
|
||||||
<div className="flex items-center gap-2">
|
<div className="flex items-center gap-2">
|
||||||
|
@ -99,7 +99,7 @@ export const SingleBoard: React.FC<Props> = ({
|
|||||||
</div>
|
</div>
|
||||||
</>
|
</>
|
||||||
)}
|
)}
|
||||||
<div className="pt-3">
|
<div className="pt-3 overflow-y-auto">
|
||||||
{groupedByIssues?.[groupTitle].map((issue, index) => (
|
{groupedByIssues?.[groupTitle].map((issue, index) => (
|
||||||
<Draggable
|
<Draggable
|
||||||
key={issue.id}
|
key={issue.id}
|
||||||
|
@ -23,12 +23,13 @@ type Props = {
|
|||||||
export const GithubImportData: FC<Props> = ({ handleStepChange, integration, control, watch }) => {
|
export const GithubImportData: FC<Props> = ({ handleStepChange, integration, control, watch }) => {
|
||||||
const { projects } = useProjects();
|
const { projects } = useProjects();
|
||||||
|
|
||||||
const options =
|
const options = projects
|
||||||
projects.map((project) => ({
|
? projects.map((project) => ({
|
||||||
value: project.id,
|
value: project.id,
|
||||||
query: project.name,
|
query: project.name,
|
||||||
content: <p>{truncateText(project.name, 25)}</p>,
|
content: <p>{truncateText(project.name, 25)}</p>,
|
||||||
})) ?? [];
|
}))
|
||||||
|
: undefined;
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="mt-6">
|
<div className="mt-6">
|
||||||
|
@ -44,8 +44,7 @@ export const SingleUserSelect: React.FC<Props> = ({ collaborator, index, users,
|
|||||||
workspaceSlug ? () => workspaceService.workspaceMembers(workspaceSlug.toString()) : null
|
workspaceSlug ? () => workspaceService.workspaceMembers(workspaceSlug.toString()) : null
|
||||||
);
|
);
|
||||||
|
|
||||||
const options =
|
const options = members?.map((member) => ({
|
||||||
members?.map((member) => ({
|
|
||||||
value: member.member.email,
|
value: member.member.email,
|
||||||
query:
|
query:
|
||||||
(member.member.first_name && member.member.first_name !== ""
|
(member.member.first_name && member.member.first_name !== ""
|
||||||
@ -61,7 +60,7 @@ export const SingleUserSelect: React.FC<Props> = ({ collaborator, index, users,
|
|||||||
: member.member.email}
|
: member.member.email}
|
||||||
</div>
|
</div>
|
||||||
),
|
),
|
||||||
})) ?? [];
|
}));
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="grid grid-cols-3 items-center gap-2 rounded-md bg-brand-surface-2 px-2 py-3">
|
<div className="grid grid-cols-3 items-center gap-2 rounded-md bg-brand-surface-2 px-2 py-3">
|
||||||
|
@ -32,8 +32,7 @@ export const JiraImportUsers: FC = () => {
|
|||||||
|
|
||||||
const { workspaceMembers: members } = useWorkspaceMembers(workspaceSlug?.toString());
|
const { workspaceMembers: members } = useWorkspaceMembers(workspaceSlug?.toString());
|
||||||
|
|
||||||
const options =
|
const options = members?.map((member) => ({
|
||||||
members?.map((member) => ({
|
|
||||||
value: member.member.email,
|
value: member.member.email,
|
||||||
query:
|
query:
|
||||||
(member.member.first_name && member.member.first_name !== ""
|
(member.member.first_name && member.member.first_name !== ""
|
||||||
@ -49,7 +48,7 @@ export const JiraImportUsers: FC = () => {
|
|||||||
: member.member.email}
|
: member.member.email}
|
||||||
</div>
|
</div>
|
||||||
),
|
),
|
||||||
})) ?? [];
|
}));
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="h-full w-full space-y-10 divide-y-2 divide-brand-base overflow-y-auto">
|
<div className="h-full w-full space-y-10 divide-y-2 divide-brand-base overflow-y-auto">
|
||||||
|
@ -29,8 +29,7 @@ export const IssueAssigneeSelect: React.FC<Props> = ({ projectId, value = [], on
|
|||||||
: null
|
: null
|
||||||
);
|
);
|
||||||
|
|
||||||
const options =
|
const options = members?.map((member) => ({
|
||||||
members?.map((member) => ({
|
|
||||||
value: member.member.id,
|
value: member.member.id,
|
||||||
query:
|
query:
|
||||||
(member.member.first_name && member.member.first_name !== ""
|
(member.member.first_name && member.member.first_name !== ""
|
||||||
@ -48,7 +47,7 @@ export const IssueAssigneeSelect: React.FC<Props> = ({ projectId, value = [], on
|
|||||||
} ${member.member.last_name ?? ""}`}
|
} ${member.member.last_name ?? ""}`}
|
||||||
</div>
|
</div>
|
||||||
),
|
),
|
||||||
})) ?? [];
|
}));
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<CustomSearchSelect
|
<CustomSearchSelect
|
||||||
|
@ -33,8 +33,7 @@ export const SidebarAssigneeSelect: React.FC<Props> = ({ value, onChange, userAu
|
|||||||
: null
|
: null
|
||||||
);
|
);
|
||||||
|
|
||||||
const options =
|
const options = members?.map((member) => ({
|
||||||
members?.map((member) => ({
|
|
||||||
value: member.member.id,
|
value: member.member.id,
|
||||||
query:
|
query:
|
||||||
(member.member.first_name && member.member.first_name !== ""
|
(member.member.first_name && member.member.first_name !== ""
|
||||||
@ -52,7 +51,7 @@ export const SidebarAssigneeSelect: React.FC<Props> = ({ value, onChange, userAu
|
|||||||
} ${member.member.last_name ?? ""}`}
|
} ${member.member.last_name ?? ""}`}
|
||||||
</div>
|
</div>
|
||||||
),
|
),
|
||||||
})) ?? [];
|
}));
|
||||||
|
|
||||||
const isNotAllowed = userAuth.isGuest || userAuth.isViewer;
|
const isNotAllowed = userAuth.isGuest || userAuth.isViewer;
|
||||||
|
|
||||||
|
@ -43,8 +43,7 @@ export const ViewAssigneeSelect: React.FC<Props> = ({
|
|||||||
: null
|
: null
|
||||||
);
|
);
|
||||||
|
|
||||||
const options =
|
const options = members?.map((member) => ({
|
||||||
members?.map((member) => ({
|
|
||||||
value: member.member.id,
|
value: member.member.id,
|
||||||
query:
|
query:
|
||||||
(member.member.first_name && member.member.first_name !== ""
|
(member.member.first_name && member.member.first_name !== ""
|
||||||
@ -62,7 +61,7 @@ export const ViewAssigneeSelect: React.FC<Props> = ({
|
|||||||
} ${member.member.last_name ?? ""}`}
|
} ${member.member.last_name ?? ""}`}
|
||||||
</div>
|
</div>
|
||||||
),
|
),
|
||||||
})) ?? [];
|
}));
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<CustomSearchSelect
|
<CustomSearchSelect
|
||||||
|
@ -30,8 +30,7 @@ export const ModuleLeadSelect: React.FC<Props> = ({ value, onChange }) => {
|
|||||||
: null
|
: null
|
||||||
);
|
);
|
||||||
|
|
||||||
const options =
|
const options = members?.map((member) => ({
|
||||||
members?.map((member) => ({
|
|
||||||
value: member.member.id,
|
value: member.member.id,
|
||||||
query:
|
query:
|
||||||
(member.member.first_name && member.member.first_name !== ""
|
(member.member.first_name && member.member.first_name !== ""
|
||||||
@ -47,7 +46,7 @@ export const ModuleLeadSelect: React.FC<Props> = ({ value, onChange }) => {
|
|||||||
: member.member.email}
|
: member.member.email}
|
||||||
</div>
|
</div>
|
||||||
),
|
),
|
||||||
})) ?? [];
|
}));
|
||||||
|
|
||||||
const selectedOption = members?.find((m) => m.member.id === value)?.member;
|
const selectedOption = members?.find((m) => m.member.id === value)?.member;
|
||||||
|
|
||||||
|
@ -28,8 +28,7 @@ export const ModuleMembersSelect: React.FC<Props> = ({ value, onChange }) => {
|
|||||||
? () => projectServices.projectMembers(workspaceSlug as string, projectId as string)
|
? () => projectServices.projectMembers(workspaceSlug as string, projectId as string)
|
||||||
: null
|
: null
|
||||||
);
|
);
|
||||||
const options =
|
const options = members?.map((member) => ({
|
||||||
members?.map((member) => ({
|
|
||||||
value: member.member.id,
|
value: member.member.id,
|
||||||
query:
|
query:
|
||||||
(member.member.first_name && member.member.first_name !== ""
|
(member.member.first_name && member.member.first_name !== ""
|
||||||
@ -45,7 +44,7 @@ export const ModuleMembersSelect: React.FC<Props> = ({ value, onChange }) => {
|
|||||||
: member.member.email}
|
: member.member.email}
|
||||||
</div>
|
</div>
|
||||||
),
|
),
|
||||||
})) ?? [];
|
}));
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<CustomSearchSelect
|
<CustomSearchSelect
|
||||||
|
@ -31,8 +31,7 @@ export const SidebarLeadSelect: React.FC<Props> = ({ value, onChange }) => {
|
|||||||
: null
|
: null
|
||||||
);
|
);
|
||||||
|
|
||||||
const options =
|
const options = members?.map((member) => ({
|
||||||
members?.map((member) => ({
|
|
||||||
value: member.member.id,
|
value: member.member.id,
|
||||||
query:
|
query:
|
||||||
(member.member.first_name && member.member.first_name !== ""
|
(member.member.first_name && member.member.first_name !== ""
|
||||||
@ -48,7 +47,7 @@ export const SidebarLeadSelect: React.FC<Props> = ({ value, onChange }) => {
|
|||||||
: member.member.email}
|
: member.member.email}
|
||||||
</div>
|
</div>
|
||||||
),
|
),
|
||||||
})) ?? [];
|
}));
|
||||||
|
|
||||||
const selectedOption = members?.find((m) => m.member.id === value)?.member;
|
const selectedOption = members?.find((m) => m.member.id === value)?.member;
|
||||||
|
|
||||||
|
@ -29,8 +29,7 @@ export const SidebarMembersSelect: React.FC<Props> = ({ value, onChange }) => {
|
|||||||
: null
|
: null
|
||||||
);
|
);
|
||||||
|
|
||||||
const options =
|
const options = members?.map((member) => ({
|
||||||
members?.map((member) => ({
|
|
||||||
value: member.member.id,
|
value: member.member.id,
|
||||||
query:
|
query:
|
||||||
(member.member.first_name && member.member.first_name !== ""
|
(member.member.first_name && member.member.first_name !== ""
|
||||||
@ -46,7 +45,7 @@ export const SidebarMembersSelect: React.FC<Props> = ({ value, onChange }) => {
|
|||||||
: member.member.email}
|
: member.member.email}
|
||||||
</div>
|
</div>
|
||||||
),
|
),
|
||||||
})) ?? [];
|
}));
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="flex items-center justify-start gap-1">
|
<div className="flex items-center justify-start gap-1">
|
||||||
|
@ -9,11 +9,13 @@ import { CheckIcon, MagnifyingGlassIcon } from "@heroicons/react/24/outline";
|
|||||||
type CustomSearchSelectProps = {
|
type CustomSearchSelectProps = {
|
||||||
value: any;
|
value: any;
|
||||||
onChange: any;
|
onChange: any;
|
||||||
options: {
|
options:
|
||||||
|
| {
|
||||||
value: any;
|
value: any;
|
||||||
query: string;
|
query: string;
|
||||||
content: JSX.Element;
|
content: JSX.Element;
|
||||||
}[];
|
}[]
|
||||||
|
| undefined;
|
||||||
label?: string | JSX.Element;
|
label?: string | JSX.Element;
|
||||||
textAlignment?: "left" | "center" | "right";
|
textAlignment?: "left" | "center" | "right";
|
||||||
height?: "sm" | "md" | "rg" | "lg";
|
height?: "sm" | "md" | "rg" | "lg";
|
||||||
|
@ -89,7 +89,7 @@ export const cosineSimilarity = (a: string, b: string) => {
|
|||||||
};
|
};
|
||||||
|
|
||||||
export const generateRandomColor = (string: string): string => {
|
export const generateRandomColor = (string: string): string => {
|
||||||
if (!string) return "var(--color-accent)";
|
if (!string) return "rgb(var(--color-accent))";
|
||||||
|
|
||||||
string = `${string}`;
|
string = `${string}`;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user