All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.mware.web.product.map.detail.geoShapePreview.js Maven / Gradle / Ivy

The newest version!
/*
 * This file is part of the BigConnect project.
 *
 * Copyright (c) 2013-2020 MWARE SOLUTIONS SRL
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU Affero General Public License version 3
 * as published by the Free Software Foundation with the addition of the
 * following permission added to Section 15 as permitted in Section 7(a):
 * FOR ANY PART OF THE COVERED WORK IN WHICH THE COPYRIGHT IS OWNED BY
 * MWARE SOLUTIONS SRL, MWARE SOLUTIONS SRL DISCLAIMS THE WARRANTY OF
 * NON INFRINGEMENT OF THIRD PARTY RIGHTS
 *
 * This program is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
 * or FITNESS FOR A PARTICULAR PURPOSE.
 * See the GNU Affero General Public License for more details.
 * You should have received a copy of the GNU Affero General Public License
 * along with this program; if not, see http://www.gnu.org/licenses or write to
 * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
 * Boston, MA, 02110-1301 USA, or download the license from the following URL:
 * https://www.gnu.org/licenses/agpl-3.0.txt
 *
 * The interactive user interfaces in modified source and object code versions
 * of this program must display Appropriate Legal Notices, as required under
 * Section 5 of the GNU Affero General Public License.
 *
 * You can be released from the requirements of the license by purchasing
 * a commercial license. Buying such a license is mandatory as soon as you
 * develop commercial activities involving the BigConnect software without
 * disclosing the source code of your own applications.
 *
 * These activities include: offering paid services to customers as an ASP,
 * embedding the product in a web application, shipping BigConnect with a
 * closed source product.
 */
define([
    'public/v1/api',
    'openlayers',
    '../util/layerHelpers',
    'util/mapConfig',
    'util/vertex/formatters'
], function(
    api,
    ol,
    layerHelpers,
    mapConfig,
    F) {
    'use strict';

    const featureCache = {};

    return api.defineComponent(GeoShapePreview);

    function GeoShapePreview() {

        this.attributes({
            ignoreUpdateModelNotImplemented: true
        })

        this.before('initialize', function(node, config) {
            this.element = config.model;
        });

        this.after('initialize', function() {
            this.setupMap();
        })

        this.setupMap = function() {
            const { vectorXhr: layerHelper, tile } = layerHelpers.byType;
            const { source, sourceOptions } = mapConfig();

            const { layer: tileLayer } = tile.configure('base', { source, sourceOptions });
            const { source: olSource, layer: geoShapeLayer } = layerHelper.configure(this.element.id, {
                id: this.element.id,
                element: this.element,
                propName: ONTOLOGY_CONSTANTS.PROP_RAW,
                propKey: '',
                mimeType: F.vertex.prop(this.element, ONTOLOGY_CONSTANTS.PROP_MIME_TYPE),
                sourceOptions: {
                    wrapX: false
                }
            });

            const map = new ol.Map({
                target: this.node,
                layers: [
                    tileLayer,
                    geoShapeLayer
                ],
                controls: [new ol.control.Zoom()],
                view: new ol.View({
                    zoom: 2,
                    minZoom: 1,
                    center: [0, 0],
                })
            });

            this.geoShapeLayer = geoShapeLayer;
            this.map = map;

            let featurePromise = featureCache[this.element.id] || layerHelper.loadFeatures(olSource, geoShapeLayer);

            Promise.resolve(featurePromise).then((features) => {
                const view = this.map.getView();
                const olSource = this.geoShapeLayer.getSource();

                olSource.addFeatures(features);
                this.geoShapeLayer.set('status', 'loaded');

                view.fit(olSource.getExtent());

                if (!featureCache[this.element.id]) {
                    featureCache[this.element.id] = features;
                }
            });
        };

        this.onDetailPaneResize = function() {
            if (this.map) {
                this.map.updateSize();
            }
        }
    }
});




© 2015 - 2024 Weber Informatics LLC | Privacy Policy