Skip to content
Snippets Groups Projects
Commit fd44e68b authored by M3034's avatar M3034
Browse files

Merge branch 'development' into '25-pelinluontilomake'

# Conflicts:
#   src/App.css
parents 8044b0a4 09483065
No related branches found
No related tags found
3 merge requests!21Development,!15Get game creation to user-marker-database-interactions,!13Resolve "Pelinluontilomake"
...@@ -60,22 +60,22 @@ div.fade-main { ...@@ -60,22 +60,22 @@ div.fade-main {
} }
div.sticky { div.sticky {
position: fixed; position: fixed;
top: 0px; top: 0px;
right: 0px; right: 0px;
height: 100px; height: 100px;
width: 100px; width: 100px;
margin-right: 150px; margin-right: 150px;
} }
.close { .close {
position: fixed; position: fixed;
color: #f1f1f1; color: #f1f1f1;
height: 85px; height: 85px;
font-size: 100px; font-size: 100px;
font-weight: bold; font-weight: bold;
transition: transform 0.4s ease-in-out; transition: transform 0.4s ease-in-out;
line-height: 70%; line-height: 70%;
} }
.close:hover, .close:hover,
...@@ -155,3 +155,44 @@ div.login button:hover { ...@@ -155,3 +155,44 @@ div.login button:hover {
margin-right: 20%; margin-right: 20%;
} }
/* Editing text button in the toolbar */
.leaflet-draw-toolbar .leaflet-draw-draw-textbox {
background-image: url("icons/button-textbox.png");
background-size: 30px 30px;
}
/* Editing tooltips */
.leaflet-tooltip {
font-size: 18px;
/* Overriding tooltip layout by making it invisible */
background-color: transparent;
box-shadow: none;
border: none;
padding: 0;
}
/* remove the small triangle on tooltip */
.leaflet-tooltip-bottom:before {
border: 0;
}
/* Editing editable tooltips */
.editable {
cursor: text; /* the cursor icon doesn't change by default when hovering on top of the text; overriding */
min-width: 154px;
min-height: 18px;
color: #fff;
font-weight: bold;
/* text borders */
text-shadow: -1px -1px 0 #000, 1px -1px 0 #000, -1px 1px 0 #000,
1px 1px 0 #000;
}
/* placeholder text for tooltip */
[contenteditable="true"]:empty:before {
content: attr(placeholder);
display: block; /* For Firefox */
color: #777;
text-shadow: none;
font-weight: normal;
}
import React, {Component} from 'react'; import React, { Component } from "react";
import { EditControl } from "react-leaflet-draw" import { EditControl } from "react-leaflet-draw";
import { import L from "leaflet";
FeatureGroup, import "leaflet-draw";
} from 'react-leaflet' import { FeatureGroup } from "react-leaflet";
// class for text field
L.Draw.MarkerTextBox = L.Draw.Marker.extend({
options: {
icon: L.divIcon({
className: "", // empty class to override default styling
iconSize: [20, 20],
iconAnchor: [10, 20]
}),
repeatMode: false,
interactive: true
},
initialize: function(map, options) {
this.type = "textbox"; // important to have a unique type, so that it won't get mixed up with other elements
this.featureTypeCode = "textbox";
L.Draw.Feature.prototype.initialize.call(this, map, options);
}
});
// Overriding default toolbar
// Just adding one new button though lol
L.DrawToolbar.include({
getModeHandlers: function(map) {
return [
{
enabled: this.options.polyline,
handler: new L.Draw.Polyline(map, this.options.polyline),
title: L.drawLocal.draw.toolbar.buttons.polyline
},
{
enabled: this.options.polygon,
handler: new L.Draw.Polygon(map, this.options.polygon),
title: L.drawLocal.draw.toolbar.buttons.polygon
},
{
enabled: this.options.rectangle,
handler: new L.Draw.Rectangle(map, this.options.rectangle),
title: L.drawLocal.draw.toolbar.buttons.rectangle
},
{
enabled: this.options.circle,
handler: new L.Draw.Circle(map, this.options.circle),
title: L.drawLocal.draw.toolbar.buttons.circle
},
{
enabled: this.options.marker,
handler: new L.Draw.Marker(map, this.options.marker),
title: L.drawLocal.draw.toolbar.buttons.marker
},
{
enabled: this.options.marker,
handler: new L.Draw.MarkerTextBox(map, this.options.marker),
title: "Write text"
}
];
}
});
class DrawTools extends Component { class DrawTools extends Component {
_onCreated = (e) => { constructor(props) {
let type = e.layerType; // from the example; isn't used right now, but may be relevant in the future super(props);
let layer = e.layer; this.state = {
let geoJSON = layer.toGeoJSON(); geoJSONAll: [] // property for all GeoJSON data in the map
console.log(JSON.stringify(geoJSON, null, 4)); // makes the output readable in the console };
} }
render() { _onCreated = e => {
return ( // check if a drawn polyline has just one point in it
// "It's important to wrap EditControl component into FeatureGroup component from react-leaflet. The elements you draw will be added to this FeatureGroup layer, when you hit edit button only items in this layer will be edited." if (e.layerType === "polyline" && e.layer.getLatLngs().length === 1) {
<FeatureGroup> e.layer.remove();
<EditControl return;
position='topright' }
onCreated={this._onCreated}
draw={{ if (e.layerType === "textbox") {
circle: { // have to create tooltip as a DOM element to allow text selecting. maybe
repeatMode: true, // allows using the tool again after finishing the previous shape let tooltip = L.DomUtil.create("div", "editable");
shapeOptions: { tooltip.innerHTML =
color: '#f9f10c', '<div contenteditable="true" placeholder="Click here and type"></div>';
opacity: 100
} e.layer.bindTooltip(tooltip, {
}, permanent: true,
rectangle: { direction: "bottom",
repeatMode: true interactive: true
}, });
polygon: {
repeatMode: true, // disable dragging when cursor is over marker (tooltip)
allowIntersection: false, // Restricts shapes to simple polygons // clicking on tooltip fires the marker's click handler, hence e.layer.on
drawError: { e.layer.on("mouseover", function() {
color: '#e1e100', // Color the shape will turn when intersects e.layer._map.dragging.disable();
message: '<strong>Oh snap!<strong> you can\'t draw that!' // Message that will show when intersect });
},
shapeOptions: { // enable dragging again when cursor is out of marker (tooltip)
color: '#ed2572', e.layer.on("mouseout", function() {
opacity: 100 e.layer._map.dragging.enable();
} });
},
polyline: { // show placeholder text again upon emptying textbox
repeatMode: true, e.layer.on("keyup", function() {
shapeOptions: { // when the text area is emptied, a <br> appears
color: '#ed2572', // manually removing it so that the placeholder text can show
opacity: 100 if (
} tooltip.innerHTML ===
}, '<div placeholder="Click here and type" contenteditable="true"><br></div>' ||
marker: { tooltip.innerHTML ===
repeatMode: true '<div placeholder="Click here and type" contenteditable="true"><div><br></div></div>'
}, ) {
circlemarker: false tooltip.innerHTML =
}} '<div placeholder="Click here and type" contenteditable="true"></div>';
/> }
</FeatureGroup> });
) } // end if (e.layerType === "textbox")
}
// turning layer data to GeoJSON
this.makeGeoJSON(e.layer);
}; // end _onCreated
makeGeoJSON = e => {
let geoJSON = e.toGeoJSON();
let newGeoJSONAll = this.state.geoJSONAll;
newGeoJSONAll.push(geoJSON); // can't do +=, need to use push function
console.log(JSON.stringify(newGeoJSONAll, null, 4));
this.setState({ geoJSONAll: newGeoJSONAll });
};
render() {
return (
// "It's important to wrap EditControl component into FeatureGroup component from react-leaflet. The elements you draw will be added to this FeatureGroup layer, when you hit edit button only items in this layer will be edited."
<FeatureGroup>
<EditControl
position="topright"
onCreated={this._onCreated}
draw={{
circle: {
repeatMode: true, // allows using the tool again after finishing the previous shape
shapeOptions: {
color: "#f9f10c",
opacity: 1 // affects the outline only. for some reason it wasn't at full opacity, so this is needed for more clarity
}
},
rectangle: {
repeatMode: true
},
polygon: {
repeatMode: true,
allowIntersection: false, // Restricts shapes to simple polygons
drawError: {
color: "#e1e100", // Color the shape will turn when intersects
message: "<strong>Oh snap!<strong> you can't draw that!" // Message that will show when intersect
},
shapeOptions: {
color: "#ed2572",
opacity: 1
}
},
polyline: {
repeatMode: true,
shapeOptions: {
color: "#ed2572",
opacity: 1
}
},
marker: {
repeatMode: false
},
circlemarker: false
}}
/>
</FeatureGroup>
);
}
} }
export default DrawTools; export default DrawTools;
\ No newline at end of file
import React, {Component} from 'react'; import React, { Component } from "react";
import { import { Map, TileLayer, ZoomControl, Marker, Popup } from "react-leaflet";
Map, import L from "leaflet";
TileLayer, import DrawTools from "./DrawTools.js";
ZoomControl,
Marker,
Popup
} from 'react-leaflet'
import DrawTools from './DrawTools.js'
class UserMap extends Component { class UserMap extends Component {
constructor(props){ constructor(props) {
super(props); super(props);
this.state = { this.state = {
ownLat: null, ownLat: null,
ownLng: null, ownLng: null,
mapUrl: 'https://tiles.kartat.kapsi.fi/taustakartta/{z}/{x}/{y}.jpg' mapUrl: "https://tiles.kartat.kapsi.fi/taustakartta/{z}/{x}/{y}.jpg"
} };
this.watchPositionId = null; this.watchPositionId = null;
} }
componentDidMount(){ componentDidMount() {
this.getCurrentPosition((position) => { this.getCurrentPosition(position => {
this.setCurrentPosition(position); this.setCurrentPosition(position);
}); });
} }
componentWillUnmount(){ componentWillUnmount() {
if(this.watchPositionId != null){ if (this.watchPositionId != null) {
navigator.geolocation.clearWatch(this.watchPositionId); navigator.geolocation.clearWatch(this.watchPositionId);
} }
} }
setCurrentPosition(position){ setCurrentPosition(position) {
this.setState({ this.setState({
ownLat: position.coords.latitude, ownLat: position.coords.latitude,
ownLng: position.coords.longitude, ownLng: position.coords.longitude
}); });
} }
getCurrentPosition(callback){ getCurrentPosition(callback) {
if(!navigator.geolocation){ if (!navigator.geolocation) {
console.log("Can't get geolocation :/"); console.log("Can't get geolocation :/");
} } else {
else{
// Position tracking options // Position tracking options
const options = { const options = {
enableHighAccuracy: true, enableHighAccuracy: true,
timeout: 30000, timeout: 30000,
maximumAge: 0 maximumAge: 0
};
if (this.watchPositionId != null) {
navigator.geolocation.clearWatch(this.watchPositionId);
} }
if(this.watchPositionId != null){navigator.geolocation.clearWatch(this.watchPositionId);} if(this.watchPositionId != null){navigator.geolocation.clearWatch(this.watchPositionId);}
...@@ -60,11 +58,15 @@ class UserMap extends Component { ...@@ -60,11 +58,15 @@ class UserMap extends Component {
} }
}, (error) =>{ }, (error) =>{
console.log(error); console.log(error);
// disable tracking
if(this.watchPositionId != null){
navigator.geolocation.clearWatch(this.watchPositionId);
}
}, options); }, options);
} }
} }
positionToGeoJSON(position){ positionToGeoJSON(position) {
let geoJSON = { let geoJSON = {
type: "Feature", type: "Feature",
properties: {}, properties: {},
...@@ -72,33 +74,47 @@ class UserMap extends Component { ...@@ -72,33 +74,47 @@ class UserMap extends Component {
type: "Point", type: "Point",
coordinates: [position.coords.longitude, position.coords.latitude] coordinates: [position.coords.longitude, position.coords.latitude]
} }
} };
return JSON.stringify(geoJSON); return JSON.stringify(geoJSON);
} }
testers = asd => {
console.log(asd.target.getZoom());
};
render() { render() {
return ( return (
<Map className='map' center={this.props.position} zoom={this.props.zoom}> <Map
className='map'
center={this.props.position}
zoom={this.props.zoom}
minZoom='7'
maxZoom='17'
zoomControl={false}>
<TileLayer <TileLayer
attribution='&copy; <a href="https://www.maanmittauslaitos.fi/">Maanmittauslaitos</a>' attribution='&copy; <a href="https://www.maanmittauslaitos.fi/">Maanmittauslaitos</a>'
url={this.props.mapUrl} url={this.props.mapUrl}
/> />
<ZoomControl position='topright' />
<DrawTools position={this.props.position} /> <ZoomControl position="topright" />
<DrawTools position={this.props.position} />
<Marker position={this.props.position}> <Marker position={this.props.position}>
<Popup> <Popup>
Se on perjantai, my dudes <br /> Se on perjantai, my dudes <br />
</Popup> </Popup>
</Marker> </Marker>
{this.state.ownLat !== null && <Marker position={[this.state.ownLat, this.state.ownLng]}> {this.state.ownLat !== null && (
<Popup> <Marker position={[this.state.ownLat, this.state.ownLng]}>
User's real position.<br /> <Popup>
</Popup> User's real position.
</Marker>} <br />
</Popup>
</Marker>
)}
</Map> </Map>
); );
} }
} }
export default UserMap; export default UserMap;
\ No newline at end of file
src/icons/button-textbox.png

793 B

src/icons/nil.png

564 B

0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment