Remove 'show on map' for now

Signed-off-by: marcin mikołajczak <git@mkljczk.pl>
This commit is contained in:
marcin mikołajczak 2022-12-02 23:16:11 +01:00
parent ea4f7a7332
commit 46cb676822
9 changed files with 1 additions and 148 deletions

View file

@ -47,14 +47,6 @@ const EventInformation: React.FC<IEventInformation> = ({ params }) => {
setShowMedia(!showMedia); setShowMedia(!showMedia);
}; };
const handleShowMap: React.MouseEventHandler<HTMLAnchorElement> = (e) => {
e.preventDefault();
dispatch(openModal('EVENT_MAP', {
statusId: status.id,
}));
};
const renderEventLocation = useCallback(() => { const renderEventLocation = useCallback(() => {
const event = status!.event!; const event = status!.event!;
@ -73,12 +65,6 @@ const EventInformation: React.FC<IEventInformation> = ({ params }) => {
<br /> <br />
</>)} </>)}
{[event.location.get('postalCode'), event.location.get('locality'), event.location.get('country')].filter(text => text).join(', ')} {[event.location.get('postalCode'), event.location.get('locality'), event.location.get('country')].filter(text => text).join(', ')}
{event.location.get('latitude') && (<>
<br />
<a href='#' className='text-primary-600 dark:text-accent-blue hover:underline' onClick={handleShowMap}>
<FormattedMessage id='event.show_on_map' defaultMessage='Show on map' />
</a>
</>)}
</Text> </Text>
</HStack> </HStack>
</Stack> </Stack>

View file

@ -22,7 +22,7 @@ import {
Toggle, Toggle,
} from 'soapbox/components/ui'; } from 'soapbox/components/ui';
import ThemeSelector from 'soapbox/features/ui/components/theme-selector'; import ThemeSelector from 'soapbox/features/ui/components/theme-selector';
import { useAppSelector, useAppDispatch, useFeatures } from 'soapbox/hooks'; import { useAppSelector, useAppDispatch } from 'soapbox/hooks';
import { normalizeSoapboxConfig } from 'soapbox/normalizers'; import { normalizeSoapboxConfig } from 'soapbox/normalizers';
import ColorWithPicker from './components/color-with-picker'; import ColorWithPicker from './components/color-with-picker';
@ -54,8 +54,6 @@ const messages = defineMessages({
singleUserModeProfileHint: { id: 'soapbox_config.single_user_mode_profile_hint', defaultMessage: '@handle' }, singleUserModeProfileHint: { id: 'soapbox_config.single_user_mode_profile_hint', defaultMessage: '@handle' },
feedInjectionLabel: { id: 'soapbox_config.feed_injection_label', defaultMessage: 'Feed injection' }, feedInjectionLabel: { id: 'soapbox_config.feed_injection_label', defaultMessage: 'Feed injection' },
feedInjectionHint: { id: 'soapbox_config.feed_injection_hint', defaultMessage: 'Inject the feed with additional content, such as suggested profiles.' }, feedInjectionHint: { id: 'soapbox_config.feed_injection_hint', defaultMessage: 'Inject the feed with additional content, such as suggested profiles.' },
tileServerLabel: { id: 'soapbox_config.tile_server_label', defaultMessage: 'Map tile server' },
tileServerAttributionLabel: { id: 'soapbox_config.tile_server_attribution_label', defaultMessage: 'Map tiles attribution' },
}); });
type ValueGetter<T = Element> = (e: React.ChangeEvent<T>) => any; type ValueGetter<T = Element> = (e: React.ChangeEvent<T>) => any;
@ -74,8 +72,6 @@ const SoapboxConfig: React.FC = () => {
const intl = useIntl(); const intl = useIntl();
const dispatch = useAppDispatch(); const dispatch = useAppDispatch();
const features = useFeatures();
const initialData = useAppSelector(state => state.soapbox); const initialData = useAppSelector(state => state.soapbox);
const [isLoading, setLoading] = useState(false); const [isLoading, setLoading] = useState(false);
@ -349,32 +345,6 @@ const SoapboxConfig: React.FC = () => {
/> />
</FormGroup> </FormGroup>
{features.events && (
<>
<CardHeader>
<CardTitle title={<FormattedMessage id='soapbox_config.headings.events' defaultMessage='Events' />} />
</CardHeader>
<FormGroup labelText={intl.formatMessage(messages.tileServerLabel)}>
<Input
type='text'
placeholder={intl.formatMessage(messages.tileServerLabel)}
value={soapbox.tileServer}
onChange={handleChange(['tileServer'], (e) => e.target.value)}
/>
</FormGroup>
<FormGroup labelText={intl.formatMessage(messages.tileServerAttributionLabel)}>
<Input
type='text'
placeholder={intl.formatMessage(messages.tileServerAttributionLabel)}
value={soapbox.tileServerAttribution}
onChange={handleChange(['tileServerAttribution'], (e) => e.target.value)}
/>
</FormGroup>
</>
)}
<CardHeader> <CardHeader>
<CardTitle title={<FormattedMessage id='soapbox_config.headings.cryptocurrency' defaultMessage='Cryptocurrency' />} /> <CardTitle title={<FormattedMessage id='soapbox_config.headings.cryptocurrency' defaultMessage='Cryptocurrency' />} />
</CardHeader> </CardHeader>

View file

@ -33,7 +33,6 @@ import {
ComposeEventModal, ComposeEventModal,
JoinEventModal, JoinEventModal,
AccountModerationModal, AccountModerationModal,
EventMapModal,
EventParticipantsModal, EventParticipantsModal,
} from 'soapbox/features/ui/util/async-components'; } from 'soapbox/features/ui/util/async-components';
@ -75,7 +74,6 @@ const MODAL_COMPONENTS = {
'COMPOSE_EVENT': ComposeEventModal, 'COMPOSE_EVENT': ComposeEventModal,
'JOIN_EVENT': JoinEventModal, 'JOIN_EVENT': JoinEventModal,
'ACCOUNT_MODERATION': AccountModerationModal, 'ACCOUNT_MODERATION': AccountModerationModal,
'EVENT_MAP': EventMapModal,
'EVENT_PARTICIPANTS': EventParticipantsModal, 'EVENT_PARTICIPANTS': EventParticipantsModal,
}; };

View file

@ -1,75 +0,0 @@
import L from 'leaflet';
import React, { useCallback, useEffect, useRef } from 'react';
import { FormattedMessage } from 'react-intl';
import { Button, Modal, Stack } from 'soapbox/components/ui';
import { useAppSelector, useSoapboxConfig } from 'soapbox/hooks';
import { makeGetStatus } from 'soapbox/selectors';
import type { Status as StatusEntity } from 'soapbox/types/entities';
import 'leaflet/dist/leaflet.css';
L.Icon.Default.mergeOptions({
iconRetinaUrl: require('leaflet/dist/images/marker-icon-2x.png'),
iconUrl: require('leaflet/dist/images/marker-icon.png'),
shadowUrl: require('leaflet/dist/images/marker-shadow.png'),
});
interface IEventMapModal {
onClose: (type: string) => void,
statusId: string,
}
const EventMapModal: React.FC<IEventMapModal> = ({ onClose, statusId }) => {
const { tileServer, tileServerAttribution } = useSoapboxConfig();
const getStatus = useCallback(makeGetStatus(), []);
const status = useAppSelector(state => getStatus(state, { id: statusId })) as StatusEntity;
const location = status.event!.location!;
const map = useRef<L.Map>();
useEffect(() => {
const latlng: [number, number] = [+location.get('latitude'), +location.get('longitude')];
map.current = L.map('event-map').setView(latlng, 15);
L.marker(latlng, {
title: location.get('name'),
}).addTo(map.current);
L.tileLayer(tileServer, {
attribution: tileServerAttribution,
}).addTo(map.current);
return () => {
map.current?.remove();
};
}, []);
const onClickClose = () => {
onClose('EVENT_MAP');
};
const onClickNavigate = () => {
window.open(`https://www.openstreetmap.org/directions?from=&to=${location.get('latitude')},${location.get('longitude')}#map=14/${location.get('latitude')}/${location.get('longitude')}`, '_blank');
};
return (
<Modal
title={<FormattedMessage id='column.event_map' defaultMessage='Event location' />}
onClose={onClickClose}
width='2xl'
>
<Stack alignItems='center' space={6}>
<div className='h-96 w-full' id='event-map' />
<Button onClick={onClickNavigate} icon={require('@tabler/icons/gps.svg')}>
<FormattedMessage id='event_map.navigate' defaultMessage='Navigate' />
</Button>
</Stack>
</Modal>
);
};
export default EventMapModal;

View file

@ -530,10 +530,6 @@ export function EventDiscussion() {
return import(/* webpackChunkName: "features/event" */'../../event/event-discussion'); return import(/* webpackChunkName: "features/event" */'../../event/event-discussion');
} }
export function EventMapModal() {
return import(/* webpackChunkName: "modals/event-map-modal" */'../components/modals/event-map-modal');
}
export function EventParticipantsModal() { export function EventParticipantsModal() {
return import(/* webpackChunkName: "modals/event-participants-modal" */'../components/modals/event-participants-modal'); return import(/* webpackChunkName: "modals/event-participants-modal" */'../components/modals/event-participants-modal');
} }

View file

@ -114,8 +114,6 @@ export const SoapboxConfigRecord = ImmutableRecord({
displayCta: true, displayCta: true,
/** Whether to inject suggested profiles into the Home feed. */ /** Whether to inject suggested profiles into the Home feed. */
feedInjection: true, feedInjection: true,
tileServer: 'https://tile.openstreetmap.org/{z}/{x}/{y}.png',
tileServerAttribution: '© OpenStreetMap Contributors',
}, 'SoapboxConfig'); }, 'SoapboxConfig');
type SoapboxConfigMap = ImmutableMap<string, any>; type SoapboxConfigMap = ImmutableMap<string, any>;

View file

@ -75,7 +75,6 @@
"@types/escape-html": "^1.0.1", "@types/escape-html": "^1.0.1",
"@types/http-link-header": "^1.0.3", "@types/http-link-header": "^1.0.3",
"@types/jest": "^28.1.4", "@types/jest": "^28.1.4",
"@types/leaflet": "^1.8.0",
"@types/lodash": "^4.14.180", "@types/lodash": "^4.14.180",
"@types/object-assign": "^4.0.30", "@types/object-assign": "^4.0.30",
"@types/object-fit-images": "^3.2.3", "@types/object-fit-images": "^3.2.3",
@ -139,7 +138,6 @@
"intl-pluralrules": "^1.3.1", "intl-pluralrules": "^1.3.1",
"is-nan": "^1.2.1", "is-nan": "^1.2.1",
"jsdoc": "~3.6.7", "jsdoc": "~3.6.7",
"leaflet": "^1.8.0",
"libphonenumber-js": "^1.10.8", "libphonenumber-js": "^1.10.8",
"line-awesome": "^1.3.0", "line-awesome": "^1.3.0",
"localforage": "^1.10.0", "localforage": "^1.10.0",

View file

@ -13,7 +13,6 @@ const rules: RuleSetRule[] = [{
include: [ include: [
resolve('app', 'assets', 'images'), resolve('app', 'assets', 'images'),
resolve('node_modules', 'emoji-datasource'), resolve('node_modules', 'emoji-datasource'),
resolve('node_modules', 'leaflet'),
], ],
generator: { generator: {
filename: 'packs/images/[name]-[contenthash:8][ext]', filename: 'packs/images/[name]-[contenthash:8][ext]',

View file

@ -2538,11 +2538,6 @@
dependencies: dependencies:
"@types/node" "*" "@types/node" "*"
"@types/geojson@*":
version "7946.0.10"
resolved "https://registry.yarnpkg.com/@types/geojson/-/geojson-7946.0.10.tgz#6dfbf5ea17142f7f9a043809f1cd4c448cb68249"
integrity sha512-Nmh0K3iWQJzniTuPRcJn5hxXkfB1T1pgB89SBig5PlJQU5yocazeu4jATJlaA0GYFKWMqDdvYemoSnF2pXgLVA==
"@types/graceful-fs@^4.1.3": "@types/graceful-fs@^4.1.3":
version "4.1.5" version "4.1.5"
resolved "https://registry.yarnpkg.com/@types/graceful-fs/-/graceful-fs-4.1.5.tgz#21ffba0d98da4350db64891f92a9e5db3cdb4e15" resolved "https://registry.yarnpkg.com/@types/graceful-fs/-/graceful-fs-4.1.5.tgz#21ffba0d98da4350db64891f92a9e5db3cdb4e15"
@ -2651,13 +2646,6 @@
resolved "https://registry.yarnpkg.com/@types/json5/-/json5-0.0.29.tgz#ee28707ae94e11d2b827bcbe5270bcea7f3e71ee" resolved "https://registry.yarnpkg.com/@types/json5/-/json5-0.0.29.tgz#ee28707ae94e11d2b827bcbe5270bcea7f3e71ee"
integrity sha1-7ihweulOEdK4J7y+UnC86n8+ce4= integrity sha1-7ihweulOEdK4J7y+UnC86n8+ce4=
"@types/leaflet@^1.8.0":
version "1.8.0"
resolved "https://registry.yarnpkg.com/@types/leaflet/-/leaflet-1.8.0.tgz#dc92d3e868fb6d5067b4b59fa08cd4441f84fabe"
integrity sha512-+sXFmiJTFdhaXXIGFlV5re9AdqtAODoXbGAvxx02e5SHXL3ir7ClP5J7pahO8VmzKY3dth4RUS1nf2BTT+DW1A==
dependencies:
"@types/geojson" "*"
"@types/lodash@^4.14.180": "@types/lodash@^4.14.180":
version "4.14.180" version "4.14.180"
resolved "https://registry.yarnpkg.com/@types/lodash/-/lodash-4.14.180.tgz#4ab7c9ddfc92ec4a887886483bc14c79fb380670" resolved "https://registry.yarnpkg.com/@types/lodash/-/lodash-4.14.180.tgz#4ab7c9ddfc92ec4a887886483bc14c79fb380670"
@ -7953,11 +7941,6 @@ language-tags@^1.0.5:
dependencies: dependencies:
language-subtag-registry "~0.3.2" language-subtag-registry "~0.3.2"
leaflet@^1.8.0:
version "1.8.0"
resolved "https://registry.yarnpkg.com/leaflet/-/leaflet-1.8.0.tgz#4615db4a22a304e8e692cae9270b983b38a2055e"
integrity sha512-gwhMjFCQiYs3x/Sf+d49f10ERXaEFCPr+nVTryhAW8DWbMGqJqt9G4XuIaHmFW08zYvhgdzqXGr8AlW8v8dQkA==
leven@^3.1.0: leven@^3.1.0:
version "3.1.0" version "3.1.0"
resolved "https://registry.yarnpkg.com/leven/-/leven-3.1.0.tgz#77891de834064cccba82ae7842bb6b14a13ed7f2" resolved "https://registry.yarnpkg.com/leven/-/leven-3.1.0.tgz#77891de834064cccba82ae7842bb6b14a13ed7f2"