UNPKG

@seasketch/geoprocessing

Version:

Geoprocessing and reporting framework for SeaSketch 2.0

49 lines 2.3 kB
import React from "react"; import { StyledCircle } from "../../components/Circle.js"; import { styled } from "styled-components"; const StyledClassCircle = styled(StyledCircle) ` border: 3px solid white; border-top-left-radius: ${(props) => props.size ? `${props.size}px` : "17px"}; border-top-right-radius: 0; border-bottom-left-radius: ${(props) => props.size ? `${props.size}px` : "17px"}; border-bottom-right-radius: ${(props) => props.size ? `${props.size}px` : "17px"}; box-shadow: 1px 1px 3px 2px rgba(0, 0, 0, 0.15); color: white; font-weight: bold; text-shadow: 0px 0px 2px #333; `; /** Circle with pointy top right corner */ export const PointyCircle = ({ children, color, size, }) => { return (React.createElement(StyledClassCircle, { color: color, size: size }, children)); }; export const StyledTwoColorPointyCircle = styled.span ` background-color: green; background-image: linear-gradient( ${(props) => props.$bottomColor || "#aaa"} ${(props) => `${100 - props.$perc}%`}, ${(props) => props.$topColor || "green"} ${(props) => `${100 - props.$perc}%`} ); padding: 3px 5px; border-radius: ${(props) => (props.$size ? `${props.$size}px` : "17px")}; min-width: ${(props) => (props.$size ? `${props.$size}px` : "17px")}; max-width: ${(props) => (props.$size ? `${props.$size}px` : "17px")}; height: ${(props) => (props.$size ? `${props.$size + 4}px` : "21px")}; display: flex; justify-content: center; align-items: center; border: 3px solid white; border-top-left-radius: ${(props) => props.$size ? `${props.$size}px` : "17px"}; border-top-right-radius: 0; border-bottom-left-radius: ${(props) => props.$size ? `${props.$size}px` : "17px"}; border-bottom-right-radius: ${(props) => props.$size ? `${props.$size}px` : "17px"}; box-shadow: 1px 1px 3px 2px rgba(0, 0, 0, 0.15); color: white; font-weight: bold; text-shadow: 0px 0px 2px #333; `; /** Two-color reg-based classification circle for collection index value */ export const TwoColorPointyCircle = ({ children, topColor, bottomColor, perc, size }) => { return (React.createElement(StyledTwoColorPointyCircle, { "$topColor": topColor, "$bottomColor": bottomColor, "$perc": perc, "$size": size }, children)); }; //# sourceMappingURL=PointyCircle.js.map