Skip to content

Commit

Permalink
Merge pull request #11 from bomshteyn/master
Browse files Browse the repository at this point in the history
Multiple Fixes: Default height, ability to change zoom and vue2-leaflet upgrade

Awesome - thanks again!
  • Loading branch information
davidpiesse authored Jan 27, 2019
2 parents 399d844 + bc450db commit f116ab2
Show file tree
Hide file tree
Showing 6 changed files with 1,710 additions and 25,854 deletions.
25,318 changes: 1 addition & 25,317 deletions dist/js/field.js

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,6 @@
},
"dependencies": {
"vue": "^2.5.0",
"vue2-leaflet": "^1.0.2"
"vue2-leaflet": "^1.2.0"
}
}
5 changes: 3 additions & 2 deletions resources/js/components/DetailField.vue
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,9 @@
</div>
<div class="w-3/4 py-4">
<div class="rounded flex flex-col" :style="'height: ' + field.height">
<map-detail
:type="field.spatialType"
<map-detail
:type="field.spatialType"
:zoom="field.zoom"
:value="field.value"
:latitude_field="field.latitude_field"
:longitude_field="field.longitude_field"
Expand Down
208 changes: 104 additions & 104 deletions resources/js/components/MapDetail.vue
Original file line number Diff line number Diff line change
@@ -1,127 +1,127 @@
<template>
<l-map
class="w-full h-full rounded z-10"
ref="map"
:zoom="zoom"
:center="center"
:bounds="bounds"
:options="mapOptions"
<l-map
class="w-full h-full rounded z-10"
ref="map"
:zoom="zoom"
:center="center"
:bounds="bounds"
:options="mapOptions"
>
<l-tile-layer
v-for="tileProvider in tileProviders"
layerType="base"
:name="tileProvider.name"
:visible="tileProvider.visible"
:url="tileProvider.url"
:attribution="tileProvider.attribution"
:key="tileProvider.name"
/>
<l-tile-layer
v-for="tileProvider in tileProviders"
layerType="base"
:name="tileProvider.name"
:visible="tileProvider.visible"
:url="tileProvider.url"
:attribution="tileProvider.attribution"
:key="tileProvider.name"
/>

<l-geo-json
ref="geojsonLayer"
:geojson="geojson"
:options="options"
></l-geo-json>
<l-geo-json
ref="geojsonLayer"
:geojson="geojson"
:options="options"
></l-geo-json>

</l-map>
</template>

<script>
import {LMap, LTileLayer, LGeoJson} from 'vue2-leaflet'
import {LMap, LTileLayer, LGeoJson} from 'vue2-leaflet'
export default {
props: {
type: String,
value: {
default: null
export default {
props: {
type: String,
value: {
default: null
},
edit: {
type: Boolean,
default: false
},
latitude_field: String,
longitude_field: String,
geojson_field: String,
zoom: Number,
},
edit: {
type: Boolean,
default: false
components: {
LMap,
LTileLayer,
LGeoJson,
},
latitude_field: String,
longitude_field: String,
geojson_field: String,
},
components: {
LMap,
LTileLayer,
LGeoJson,
},
data() {
return {
map: null,
geojsonLayer: null,
center: [0, 0],
bounds: null,
zoom: 8,
tileProviders:[{
name: 'OpenStreetMap',
visible: true,
attribution: '&copy; <a target="_blank" href="http://osm.org/copyright">OpenStreetMap</a> contributors',
url: 'https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png'
}],
options: {
style: function () {
return {
weight: 2,
color: 'blue',
opacity: 0.8,
fillColor: 'blue',
fillOpacity: 0.3
}
},
pointToLayer: function (feature, latlng) {
let base64img = ""
data() {
return {
map: null,
geojsonLayer: null,
center: [0, 0],
bounds: null,
tileProviders: [{
name: 'OpenStreetMap',
visible: true,
attribution: '&copy; <a target="_blank" href="http://osm.org/copyright">OpenStreetMap</a> contributors',
url: 'https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png'
}],
options: {
style: function () {
return {
weight: 2,
color: 'blue',
opacity: 0.8,
fillColor: 'blue',
fillOpacity: 0.3
}
},
pointToLayer: function (feature, latlng) {
let base64img = ""
let icon = L.icon({
iconUrl: base64img,
iconSize: [25, 41],
iconAnchor: [13, 40],
})
let icon = L.icon({
iconUrl: base64img,
iconSize: [25, 41],
iconAnchor: [13, 40],
})
return L.marker(latlng).setIcon(icon)
}
},
mapOptions: {
},
}
},
computed: {
geojson(){
if(this.type == "LatLon" || this.type == "LatLonField"){
return {
type: 'Point',
coordinates: [
this.value.lon,
this.value.lat,
]
return L.marker(latlng).setIcon(icon)
}
},
mapOptions: {},
}
},
computed: {
geojson() {
if (this.type == "LatLon" || this.type == "LatLonField") {
return {
type: 'Point',
coordinates: [
this.value.lon,
this.value.lat,
]
}
} else if (this.type == "GeoJSON") {
return JSON.parse(this.value)
} else {
return this.value
}
}else if(this.type == "GeoJSON"){
return JSON.parse(this.value)
}else{
return this.value
}
}
},
mounted() {
this.$nextTick(() => {
this.map = this.$refs.map.mapObject
},
mounted() {
this.$nextTick(() => {
this.map = this.$refs.map.mapObject
this.geojsonLayer = this.$refs.geojsonLayer.mapObject
this.geojsonLayer = this.$refs.geojsonLayer.mapObject
this.setCenter()
})
this.setCenter()
})
},
methods: {
setCenter(){
if(this.geojson !== null){
this.map.fitBounds(L.geoJSON(this.geojson).getBounds(),{maxZoom:12})
}
},
methods: {
setCenter() {
if (this.geojson !== null) {
this.map.fitBounds(L.geoJSON(this.geojson).getBounds(), {maxZoom: 18}).setZoom(this.zoom)
}
},
}
}
}
</script>

<style scoped>
Expand Down
40 changes: 32 additions & 8 deletions src/Map.php
Original file line number Diff line number Diff line change
Expand Up @@ -14,12 +14,36 @@ class Map extends Field

public $showOnIndex = false;

public function height($height = '300px'){
return $this->withMeta([
'height' => $height
public $height = '300px';

public $zoom = 8;

public function __construct($name, $attribute = null, $resolveCallback = null)
{
parent::__construct($name, $attribute, $resolveCallback);

$this->withMeta([
'height' => $this->height,
'zoom' => $this->zoom,
]);
}

public function height($height){
if($height) {
return $this->withMeta([
'height' => $height
]);
}
}

public function zoom($zoom){
if($zoom) {
return $this->withMeta([
'zoom' => $zoom
]);
}
}

public function spatialType($type){
return $this->withMeta([
'spatialType' => $type
Expand All @@ -36,7 +60,7 @@ public function latitude($latitude_field){

public function longitude($longitude_field){
$this->attribute = null;

return $this->withMeta([
'longitude_field' => $longitude_field
]);
Expand All @@ -57,7 +81,7 @@ public function resolveAttribute($resource, $attribute = null){
'lat' => $resource->{$this->meta['latitude_field']},
'lon' => $resource->{$this->meta['longitude_field']},
];
break;
break;
case 'LatLonField':
$parts = collect(explode(',',$resource->{$attribute}))->map(function($item){
return trim($item);
Expand All @@ -67,13 +91,13 @@ public function resolveAttribute($resource, $attribute = null){
'lat' => $parts[0],
'lon' => $parts[1],
];
break;
break;
case 'GeoJSON':
return $resource->{$attribute};
break;
break;
default:
return $resource->{$attribute};
break;
break;
}
}

Expand Down
Loading

0 comments on commit f116ab2

Please sign in to comment.