mirror of
https://github.com/RoboSats/robosats.git
synced 2025-01-22 06:01:35 +00:00
Fix use programatic colors for map marker
This commit is contained in:
parent
1eadde7dfa
commit
cd42e90205
@ -1,7 +0,0 @@
|
|||||||
import React from 'react';
|
|
||||||
|
|
||||||
export default function MapPin(color: 'Blue' | 'Lilac') {
|
|
||||||
const lightHex = color === 'Blue' ? '#bde4f8;' : '#c55fcc';
|
|
||||||
|
|
||||||
return `<svg id='Capa_1' data-name='Capa 1' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 18.66 29.68'><defs><style>.cls-1{fill:${lightHex};}.cls-2{fill:#fff;}</style></defs><path class='cls-1' d='M18,8A9.13,9.13,0,0,0,10.89.62,10.88,10.88,0,0,0,9.33.49,10.88,10.88,0,0,0,7.77.62,9.13,9.13,0,0,0,.66,8a12.92,12.92,0,0,0,1.19,8.25C2.68,18.09,7.47,27.6,9.07,29c0,.12.11.19.19.19l.07,0,.07,0c.08,0,.15-.07.19-.19,1.6-1.41,6.39-10.92,7.22-12.8A12.92,12.92,0,0,0,18,8Z'/><path d='M9.23,29.6a.57.57,0,0,1-.5-.35C7,27.57,2.24,18.09,1.48,16.38A13.57,13.57,0,0,1,.26,7.87C1.18,3.78,4,.92,7.7.23h0A8.38,8.38,0,0,1,11,.24h0c3.74.69,6.52,3.55,7.44,7.64a13.57,13.57,0,0,1-1.22,8.51c-.76,1.71-5.5,11.19-7.25,12.87a.57.57,0,0,1-.55.35H9.23ZM8,1,7.85,1a8.68,8.68,0,0,0-6.8,7C.5,10.52.86,13,2.22,16.05c.9,2,5.62,11.32,7.11,12.65,1.49-1.33,6.21-10.63,7.11-12.65,1.36-3.07,1.72-5.53,1.17-8h0a8.68,8.68,0,0,0-6.8-7l-.12,0A10.47,10.47,0,0,0,9.33.89,10.3,10.3,0,0,0,8,1Z'/><rect x='3.12' y='6.34' width='12.53' height='7.76' rx='3.88'/><rect class='cls-2' x='5.02' y='7.82' width='2.16' height='2.34' rx='1.02'/><rect class='cls-2' x='11.25' y='7.82' width='2.16' height='2.34' rx='1.02'/><path class='cls-2' d='M9.24,12.76A3.57,3.57,0,0,1,7,12a.4.4,0,1,1,.53-.61,2.78,2.78,0,0,0,3.49,0,.4.4,0,0,1,.48.65A3.71,3.71,0,0,1,9.24,12.76Z'/></svg>`;
|
|
||||||
}
|
|
@ -17,7 +17,6 @@ export { default as UserNinjaIcon } from './UserNinja';
|
|||||||
export { default as TorIcon } from './Tor';
|
export { default as TorIcon } from './Tor';
|
||||||
export { default as SimplexIcon } from './Simplex';
|
export { default as SimplexIcon } from './Simplex';
|
||||||
export { default as NostrIcon } from './Nostr';
|
export { default as NostrIcon } from './Nostr';
|
||||||
export { default as MapPin } from './MapPin';
|
|
||||||
|
|
||||||
// Flags with props
|
// Flags with props
|
||||||
export { default as FlagWithProps } from './WorldFlags';
|
export { default as FlagWithProps } from './WorldFlags';
|
||||||
|
@ -9,7 +9,17 @@ import { PublicOrder } from '../../models';
|
|||||||
import OrderTooltip from '../Charts/helpers/OrderTooltip';
|
import OrderTooltip from '../Charts/helpers/OrderTooltip';
|
||||||
import getWorldmapGeojson from '../../geo/Web';
|
import getWorldmapGeojson from '../../geo/Web';
|
||||||
import MarkerClusterGroup from '@christopherpickering/react-leaflet-markercluster';
|
import MarkerClusterGroup from '@christopherpickering/react-leaflet-markercluster';
|
||||||
import { MapPin } from '../Icons';
|
|
||||||
|
interface MapPinProps {
|
||||||
|
fillColor: string;
|
||||||
|
outlineColor: string;
|
||||||
|
eyesColor: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
const MapPin = ({ fillColor, outlineColor, eyesColor }: MapPinProps): string => {
|
||||||
|
console.log(fillColor, outlineColor);
|
||||||
|
return `<svg id='robot_pin' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 18.66 29.68'><defs><style>.body{fill:${fillColor};}.eyes{fill:${eyesColor};}.outline{fill:${outlineColor};}</style></defs><path class='body' d='M18,8A9.13,9.13,0,0,0,10.89.62,10.88,10.88,0,0,0,9.33.49,10.88,10.88,0,0,0,7.77.62,9.13,9.13,0,0,0,.66,8a12.92,12.92,0,0,0,1.19,8.25C2.68,18.09,7.47,27.6,9.07,29c0,.12.11.19.19.19l.07,0,.07,0c.08,0,.15-.07.19-.19,1.6-1.41,6.39-10.92,7.22-12.8A12.92,12.92,0,0,0,18,8Z'/><path class='outline' d='M9.23,29.6a.57.57,0,0,1-.5-.35C7,27.57,2.24,18.09,1.48,16.38A13.57,13.57,0,0,1,.26,7.87C1.18,3.78,4,.92,7.7.23h0A8.38,8.38,0,0,1,11,.24h0c3.74.69,6.52,3.55,7.44,7.64a13.57,13.57,0,0,1-1.22,8.51c-.76,1.71-5.5,11.19-7.25,12.87a.57.57,0,0,1-.55.35H9.23ZM8,1,7.85,1a8.68,8.68,0,0,0-6.8,7C.5,10.52.86,13,2.22,16.05c.9,2,5.62,11.32,7.11,12.65,1.49-1.33,6.21-10.63,7.11-12.65,1.36-3.07,1.72-5.53,1.17-8h0a8.68,8.68,0,0,0-6.8-7l-.12,0A10.47,10.47,0,0,0,9.33.89,10.3,10.3,0,0,0,8,1Z'/><rect class='outline' x='3.12' y='6.34' width='12.53' height='7.76' rx='3.88'/><rect class='eyes' x='5.02' y='7.82' width='2.16' height='2.34' rx='1.02'/><rect class='eyes' x='11.25' y='7.82' width='2.16' height='2.34' rx='1.02'/><path class='eyes' d='M9.24,12.76A3.57,3.57,0,0,1,7,12a.4.4,0,1,1,.53-.61,2.78,2.78,0,0,0,3.49,0,.4.4,0,0,1,.48.65A3.71,3.71,0,0,1,9.24,12.76Z'/></svg>`;
|
||||||
|
};
|
||||||
|
|
||||||
interface Props {
|
interface Props {
|
||||||
orderType?: number;
|
orderType?: number;
|
||||||
@ -50,7 +60,9 @@ const Map = ({
|
|||||||
orderType: number,
|
orderType: number,
|
||||||
order?: PublicOrder,
|
order?: PublicOrder,
|
||||||
) => {
|
) => {
|
||||||
const color = orderType == 1 ? 'Blue' : 'Lilac';
|
const fillColor = orderType == 1 ? theme.palette.primary.main : theme.palette.secondary.main;
|
||||||
|
const outlineColor = 'black';
|
||||||
|
const eyesColor = 'white';
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Marker
|
<Marker
|
||||||
@ -58,7 +70,7 @@ const Map = ({
|
|||||||
position={position}
|
position={position}
|
||||||
icon={
|
icon={
|
||||||
new DivIcon({
|
new DivIcon({
|
||||||
html: MapPin(color),
|
html: MapPin({ fillColor, outlineColor, eyesColor }),
|
||||||
iconAnchor: [14, 38],
|
iconAnchor: [14, 38],
|
||||||
iconSize: [24, 24],
|
iconSize: [24, 24],
|
||||||
className: '',
|
className: '',
|
||||||
@ -92,7 +104,7 @@ const Map = ({
|
|||||||
const getOrderMarkers = () => {
|
const getOrderMarkers = () => {
|
||||||
if (orders.length < 1) return <></>;
|
if (orders.length < 1) return <></>;
|
||||||
return (
|
return (
|
||||||
<MarkerClusterGroup showCoverageOnHover={false} disableClusteringAtZoom={14}>
|
<MarkerClusterGroup showCoverageOnHover={true} disableClusteringAtZoom={14}>
|
||||||
{orders.map((order) => {
|
{orders.map((order) => {
|
||||||
if (!order.latitude || !order.longitude) return <></>;
|
if (!order.latitude || !order.longitude) return <></>;
|
||||||
return RobotMarker(order.id, [order.latitude, order.longitude], order.type || 0, order);
|
return RobotMarker(order.id, [order.latitude, order.longitude], order.type || 0, order);
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
README.md
|
README.md
|
||||||
assets
|
assets
|
||||||
static/assets/vector
|
static/assets/vector
|
||||||
!static/assets/vector/Location_robot_*.svg
|
|
||||||
static/assets/images/Ba*
|
static/assets/images/Ba*
|
||||||
static/assets/images/bot*
|
static/assets/images/bot*
|
||||||
static/assets/images/robo*
|
static/assets/images/robo*
|
||||||
|
Loading…
Reference in New Issue
Block a user