import { KEYS } from "./keys"; // We inline font-awesome icons in order to save on js size rather than including the font awesome react library export const SHAPES = [ { icon: ( // fa-mouse-pointer ), value: "selection", key: KEYS.V, }, { icon: ( // fa-square ), value: "rectangle", key: KEYS.R, }, { icon: ( // custom ), value: "diamond", key: KEYS.D, }, { icon: ( // fa-circle ), value: "ellipse", key: KEYS.E, }, { icon: ( // fa-long-arrow-alt-right ), value: "arrow", key: KEYS.A, }, { icon: ( // custom ), value: "line", key: [KEYS.P, KEYS.L], }, { icon: ( // fa-pencil ), value: "freedraw", key: [KEYS.X, KEYS.P.toUpperCase()], }, { icon: ( // fa-font ), value: "text", key: KEYS.T, }, { icon: ( // fa-image ), value: "image", key: null, }, ] as const; export const findShapeByKey = (key: string) => { const shape = SHAPES.find((shape, index) => { return ( key === (index + 1).toString() || (shape.key && (typeof shape.key === "string" ? shape.key === key : (shape.key as readonly string[]).includes(key))) ); }); return shape?.value || null; };