ol-ext
Version:
A set of cool extensions for OpenLayers (ol) in node modules structure
105 lines (94 loc) • 4.4 kB
JavaScript
import ol_interaction_Interaction from 'ol/interaction/Interaction.js'
import ol_format_GPX from 'ol/format/GPX.js'
import ol_format_GeoJSON from 'ol/format/GeoJSON.js'
import ol_format_IGC from 'ol/format/IGC.js'
import ol_format_KML from 'ol/format/KML.js'
import ol_format_TopoJSON from 'ol/format/TopoJSON.js'
import ol_format_GeoJSONX from '../format/GeoJSONX.js'
import ol_format_GeoJSONP from '../format/GeoJSONP.js'
/** Extend DragAndDrop choose drop zone + fires loadstart, loadend
* @constructor
* @extends {ol_interaction_Interaction}
* @fires loadstart, loadend, addfeatures
* @param {*} options
* @param {string} options.zone selector for the drop zone, default document
* @param{ol.projection} options.projection default projection of the map
* @param {Array<function(new:ol.format.Feature)>|undefined} options.formatConstructors Format constructors, default [ ol.format.GPX, ol.format.GeoJSONX, ol.format.GeoJSONP, ol.format.GeoJSON, ol.format.IGC, ol.format.KML, ol.format.TopoJSON ]
* @param {Array<string>|undefined} options.accept list of accepted format, default ["gpx","json","geojsonx","geojsonp","geojson","igc","kml","topojson"]
*/
var ol_interaction_DropFile = class olinteractionDropFile extends ol_interaction_Interaction {
constructor(options) {
options = options || {}
super({})
var zone = options.zone || document
zone.addEventListener('dragenter', this.onstop)
zone.addEventListener('dragover', this.onstop)
zone.addEventListener('dragleave', this.onstop)
// Options
this.formatConstructors_ = options.formatConstructors || [ol_format_GPX, ol_format_GeoJSONX, ol_format_GeoJSONP, ol_format_GeoJSON, ol_format_IGC, ol_format_KML, ol_format_TopoJSON]
this.projection_ = options.projection
this.accept_ = options.accept || ["gpx", "json", "geojsonx", "geojsonp", "geojson", "igc", "kml", "topojson"]
zone.addEventListener('drop', function (e) {
return this.ondrop(e)
}.bind(this))
}
/** Set the map
*/
setMap(map) {
super.setMap(map)
}
/** Do something when over
*/
onstop(e) {
e.preventDefault()
e.stopPropagation()
return false
}
/** Do something when over
*/
ondrop(e) {
e.preventDefault()
if (e.dataTransfer && e.dataTransfer.files.length) {
var projection = this.projection_ || (this.getMap() ? this.getMap().getView().getProjection() : null)
// fetch FileList object
var files = e.dataTransfer.files // e.originalEvent.target.files ?
// process all File objects
var pat = /\.([0-9a-z]+)(?=[?#])|(\.)(?:[\w]+)$/
Array.prototype.forEach.call(files, function(file) {
var ex = file.name.match(pat)[0]
var isok = (this.accept_.indexOf(ex.toLocaleLowerCase()) >= 0)
this.dispatchEvent({ type: 'loadstart', file: file, filesize: file.size, filetype: file.type, fileextension: ex, projection: projection, isok: isok })
// Don't load file
if (this.formatConstructors_.length) {
// Load file
var reader = new FileReader()
var formatConstructors = this.formatConstructors_
var theFile = file
reader.onload = function (e) {
var result = e.target.result
var features = []
var i, ii
for (i = 0, ii = formatConstructors.length; i < ii; ++i) {
var formatConstructor = formatConstructors[i]
try {
var format = new formatConstructor()
features = format.readFeatures(result, { featureProjection: projection })
if (features && features.length > 0) {
this.dispatchEvent({ type: 'addfeatures', features: features, file: theFile, projection: projection })
this.dispatchEvent({ type: 'loadend', features: features, file: theFile, projection: projection })
return
}
} catch (e) { /* ok */ }
}
// Nothing match, try to load by yourself
this.dispatchEvent({ type: 'loadend', file: theFile, result: result })
}.bind(this)
// Start loading
reader.readAsText(file)
}
}.bind(this))
}
return false
}
}
export default ol_interaction_DropFile