PHP Classes

File: public/assets/openlayers/ol-street-view/ol-street-view.min.js

Recommend this page to a friend!
  Classes of Aby Dahana   Aksara   public/assets/openlayers/ol-street-view/ol-street-view.min.js   Download  
File: public/assets/openlayers/ol-street-view/ol-street-view.min.js
Role: Auxiliary data
Content type: text/plain
Description: Auxiliary data
Class: Aksara
A CodeIgniter based API and CRUD generator
Author: By
Last change:
Date: 9 months ago
Size: 45,511 bytes
 

Contents

Class file image Download
/*! * ol-street-view - v2.2.3 * https://github.com/GastonZalba/ol-street-view#readme * Built: Sat Sep 30 2023 17:18:21 GMT-0300 (Argentina Standard Time) */ !function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t(require("ol/Feature.js"),require("ol/Collection.js"),require("ol/style/Icon.js"),require("ol/style/Style.js"),require("ol/source/Vector.js"),require("ol/source/XYZ.js"),require("ol/geom/Point.js"),require("ol/control/Control.js"),require("ol/proj.js"),require("ol/layer/Vector.js"),require("ol/layer/Tile.js"),require("ol/interaction/Translate.js"),require("ol/Observable.js"),require("interactjs")):"function"==typeof define&&define.amd?define(["ol/Feature.js","ol/Collection.js","ol/style/Icon.js","ol/style/Style.js","ol/source/Vector.js","ol/source/XYZ.js","ol/geom/Point.js","ol/control/Control.js","ol/proj.js","ol/layer/Vector.js","ol/layer/Tile.js","ol/interaction/Translate.js","ol/Observable.js","interactjs"],t):(e="undefined"!=typeof globalThis?globalThis:e||self).StreetView=t(e.ol.Feature,e.ol.Collection,e.ol.style.Icon,e.ol.style.Style,e.ol.source.Vector,e.ol.source.XYZ,e.ol.geom.Point,e.ol.control.Control,e.ol.proj,e.ol.layer.Vector,e.ol.layer.Tile,e.ol.interaction.Translate,e.ol.Observable,e.interact)}(this,(function(e,t,i,s,o,a,n,r,l,c,d,m,g,h){"use strict";class p{constructor(e=null,t={}){if(this.apiKey=e,this.options=t,"undefined"==typeof window)throw new Error("google-maps is supported only in browser environment")}load(){return void 0!==this.api?Promise.resolve(this.api):void 0!==this.loader?this.loader:(window[p.CALLBACK_NAME]=()=>{if(this.api=window.google,void 0===this.resolve)throw new Error("Should not happen");this.resolve(this.api)},window.gm_authFailure=()=>{if(void 0===this.reject)throw new Error("Should not happen");this.reject(new Error("google-maps: authentication error"))},this.loader=new Promise(((e,t)=>{this.resolve=e,this.reject=t;const i=document.createElement("script");i.src=this.createUrl(),i.async=!0,i.onerror=e=>t(e),document.head.appendChild(i)})))}createUrl(){const e=[`callback=${p.CALLBACK_NAME}`];this.apiKey&&e.push(`key=${this.apiKey}`);for(let t in this.options)if(this.options.hasOwnProperty(t)){let i=this.options[t];"version"===t&&(t="v"),"libraries"===t&&(i=i.join(",")),e.push(`${t}=${i}`)}return`https://maps.googleapis.com/maps/api/js?${e.join("&")}`}}p.CALLBACK_NAME="_dk_google_maps_loader_cb";var v=Object.freeze({__proto__:null,en:{exit:"Exit",exitView:"Exit Street View mode",dragToInit:"Drag and drop to initialize Google Street View",noImages:"No images found. Click on the map to move",termsOfService:"Terms of Service",expand:"Expand",minimize:"Minimize"},es:{exit:"Salir",exitView:"Salir de la vista Street View",dragToInit:"Arrastre y suelte para iniciar Google Street View",noImages:"Sin imágenes en la zona. Click en el mapa para trasladarse",termsOfService:"Condiciones del Servicio",expand:"Expandir",minimize:"Minimizar"}});const w=document.createElement("div");class u extends r{constructor(e){super({element:w,target:e.target}),this._addedXyzLayer=!1,this._loadedLib=!1,this._initialized=!1,this._options=Object.assign({apiKey:null,size:C.Large,radius:100,updatePegmanToClosestPanorama:!0,transparentButton:!1,resizable:!0,sizeToggler:!0,defaultMapSize:L.Expanded,language:A.EN,target:null,zoomOnInit:18,minZoom:null,autoLoadGoogleMaps:!0},e),this._i18n=v[this._options.language in v?this._options.language:"en"],this._i18n=Object.assign(this._i18n,e.i18n||{}),this._pegmanSelectedCoords=[],this._pegmanHeading=180,this._options.autoLoadGoogleMaps&&(this.on(z.LOAD_LIB,(()=>{this._loadedLib=!0,this.init()})),this._loadStreetView())}init(){if(!this._map)return;this._streetViewService=new google.maps.StreetViewService,this._panorama=new google.maps.StreetViewPanorama(this.streetViewPanoramaDiv,{pov:{heading:165,pitch:0},zoom:1,visible:!1,motionTracking:!1,motionTrackingControl:!1,enableCloseButton:!1,fullscreenControl:!1}),this._panorama.addListener("position_changed",(()=>{if(this._isPositionFired)return;setTimeout((()=>{this._isPositionFired=null}),400),this._isPositionFired=!0;const e=this._panorama.getPosition();this._updatePegmanPosition(e,!0)})),this._panorama.addListener("pov_changed",(()=>{const e=this._panorama.getPov().heading;e!==this._pegmanHeading&&(this._pegmanHeading=e,this._pegmanLayer.getSource().changed())}));e.onclick=this.hideStreetView.bind(this),this._panorama.controls[google.maps.ControlPosition.TOP_RIGHT].push(e),this._initialized=!0}setMap(e){super.setMap(e),e?(this._map=super.getMap(),this._view=this._map.getView(),this._viewport=this._map.getTargetElement(),this._prepareLayers(),this._createMapControls(),this._prepareLayout(),this._loadedLib&&!this._initialized&&this.init(),this._options.minZoom&&(this._maybeHideControl(),this._view.on("change:resolution",(()=>{this._maybeHideControl()})))):(w.remove(),this.hideStreetView())}_maybeHideControl(){this._view.getZoom()<=this._options.minZoom?this._isHidden&&this._showControl(!0):this._isHidden||this._showControl(!1)}_showControl(e){const t="ol-street-view--hide-control";e?this.pegmanDivControl.classList.add(t):this.pegmanDivControl.classList.remove(t),this._isHidden=!e}_prepareLayers(){const e=()=>{const e=this._pegmanHeading;let t;return e>=0&&e<22.5?t=[0,0]:e>=22.5&&e<45?t=[0,52]:e>=45&&e<67.5?t=[0,104]:e>=67.5&&e<90?t=[0,156]:e>=90&&e<112.5?t=[0,208]:e>=112.5&&e<135?t=[0,260]:e>=135&&e<157.5?t=[0,312]:e>=157.5&&e<180?t=[0,364]:e>=180&&e<205.5?t=[0,416]:e>=205.5&&e<225?t=[0,468]:e>=225&&e<247.5?t=[0,520]:e>=247.5&&e<270?t=[0,572]:e>=270&&e<292.5?t=[0,624]:e>=292.5&&e<315?t=[0,676]:e>=315&&e<337.5?t=[0,728]:e>=337.5&&(t=[0,780]),t};this._streetViewXyzLayer=new d({zIndex:10,source:new a({attributions:`&copy; ${(new Date).getFullYear()} Google Maps <a href="https://www.google.com/help/terms_maps/" target="_blank">${this._i18n.termsOfService}</a>`,maxZoom:19,url:"https://mt{0-3}.google.com/vt/?lyrs=svv|cb_client:apiv3&style=50&x={x}&y={y}&z={z}"})}),this._pegmanLayer=new c({zIndex:99,source:new o,style:()=>new s({image:new i({anchor:[.5,32],anchorXUnits:"fraction",anchorYUnits:"pixels",rotateWithView:!0,opacity:1,src:"",size:[48,48],offset:e()})})}),this._map.addLayer(this._pegmanLayer)}_addTranslateInteraction(){if(this._translatePegman)return this._translatePegman.setActive(!0);this._translatePegman=new m({features:new t([this._pegmanFeature])}),this._addTranslateInteractionEvent(),this._map.addInteraction(this._translatePegman)}_addTranslateInteractionEvent(){this._translateEventKey=this._translatePegman.on("translateend",(e=>{this._pegmanSelectedCoords=e.coordinate,this._updateStreetViewPosition(this._pegmanSelectedCoords)}))}_remvoveTranslateInteractionEvent(){g.unByKey(this._translateEventKey)}_prepareLayout(){const e=()=>{const e=document.createElement("div");e.className="ol-street-view--scroll-handler",e.innerHTML="<span></span>",this._viewport.append(e);const t=function(e,t=250){let i;return function(...s){const o=()=>{clearTimeout(i),e(...s)};clearTimeout(i),i=setTimeout(o,t)}}((()=>{this._refreshMap(!1)}),150);h(this._viewport).resizable({edges:{top:e,left:!1,bottom:!1,right:!1},onstart:()=>{this.mapContainer.classList.remove("ol-street-view--transitions")},onmove:e=>{let{y:i}=e.target.dataset;i=(parseFloat(i)||0)+e.deltaRect.top,Object.assign(e.target.style,{height:`${Math.round(e.rect.height)}px`}),Object.assign(e.target.dataset,{y:i}),t()},onend:()=>{this.mapContainer.classList.add("ol-street-view--transitions"),this._refreshMap(!1)},modifiers:[h.modifiers.restrictSize({min:{width:null,height:200}})]})};(()=>{this.streetViewPanoramaDiv=document.createElement("div"),this.streetViewPanoramaDiv.id="ol-street-view--panorama";const t=document.createElement("div");t.className="ol-street-view--no-results",t.innerHTML=`\n <div class="ol-street-view--no-results-icon">\n <img src="data:image/svg+xml,%3csvg version='1.1' xmlns='http://www.w3.org/2000/svg' width='768' height='768' viewBox='0 0 768 768'%3e%3cpath fill='white' d='M379.5 288h4.5q39 0 67.5 28.5t28.5 67.5v6zM241.5 313.5q-18 36-18 70.5 0 66 47.25 113.25t113.25 47.25q34.5 0 70.5-18l-49.5-49.5q-12 3-21 3-39 0-67.5-28.5t-28.5-67.5q0-9 3-21zM64.5 136.5l40.5-40.5 567 567-40.5 40.5q-7.5-7.5-47.25-46.5t-60.75-60q-64.5 27-139.5 27-118.5 0-214.5-66t-138-174q16.5-39 51.75-86.25t68.25-72.75q-18-18-50.25-51t-36.75-37.5zM384 223.5q-30 0-58.5 12l-69-69q58.5-22.5 127.5-22.5 118.5 0 213.75 66t137.25 174q-36 88.5-109.5 151.5l-93-93q12-28.5 12-58.5 0-66-47.25-113.25t-113.25-47.25z'%3e%3c/path%3e%3c/svg%3e"/>\n </div>\n <div class="ol-street-view--no-results-text">\n ${this._i18n.noImages}\n </div>\n `,this.streetViewPanoramaDiv.appendChild(t);const i=this._viewport.parentElement;this.mapContainer=document.createElement("div"),this.mapContainer.id="ol-street-view--map-container",this.mapContainer.className="ol-street-view--transitions",i.replaceChild(this.mapContainer,this._viewport),this.mapContainer.appendChild(this.streetViewPanoramaDiv),this.mapContainer.appendChild(this._viewport),this._viewport.classList.add("ol-street-view--map"),this._options.resizable&&e()})()}_createMapControls(){const e=()=>{let e,t=0,i=e=>{const i="changedTouches"in e?e.changedTouches[0].pageX:e.pageX;return i<t?(this.pegmanDraggable.classList.add("ol-street-view--left"),this.pegmanDraggable.classList.remove("ol-street-view--right")):i>t&&(this.pegmanDraggable.classList.add("ol-street-view--right"),this.pegmanDraggable.classList.remove("ol-street-view--left")),t=i,t};i=i.bind(this);const s=()=>{this._isDragging=!1,document.body.classList.remove("ol-street-view--activated-on-dragging"),this.pegmanDraggable.classList.remove("ol-street-view--can-drop","ol-street-view--dragged","ol-street-view--left","ol-street-view--right","ol-street-view--active","ol-street-view--dropped"),this.pegmanDraggable.removeAttribute("style"),this.pegmanDraggable.removeAttribute("data-x"),this.pegmanDraggable.removeAttribute("data-y"),this._viewport.classList.remove("ol-street-view--drop-active","ol-street-view--drop-target"),document.removeEventListener("mousemove",i),document.removeEventListener("touchmove",i)};document.addEventListener("keydown",(({key:t})=>{this._isDragging&&"Escape"===t&&(e(),s(),this._removeStreetViewXyzLayer())})),h(".ol-street-view--draggable").draggable({inertia:!1,onstart:e=>{const t=e.target,i=t.offsetWidth,s=t.getBoundingClientRect().left+i/2;t.setAttribute("data-x",-(s-e.x0))},onmove:t=>{this._isDragging=!0,e=t.interaction.stop,document.addEventListener("mousemove",i),document.addEventListener("touchmove",i),this.pegmanDraggable.classList.remove("ol-street-view--dropped");const s=t.target,o=(parseFloat(s.getAttribute("data-x"))||0)+t.dx,a=(parseFloat(s.getAttribute("data-y"))||0)+t.dy;s.style.webkitTransform=s.style.transform=`translate(${o}px, ${a}px)`,s.setAttribute("data-x",o),s.setAttribute("data-y",a)},onend:e=>{const t=this.mapContainer.getBoundingClientRect(),i=t.left,s=t.top,o=this._map.getCoordinateFromPixel([e.client.x-i,e.client.y-s+this.pegmanDraggable.clientHeight-10]);this._pegmanSelectedCoords=o,this._initPegmanOnMap()}}).styleCursor(!1),h(this._viewport).dropzone({accept:".ol-street-view--draggable",overlap:.75,ondropactivate:()=>{this._viewport.classList.add("ol-street-view--drop-active")},ondragenter:()=>{this._addStreetViewXyzLayer(),document.body.classList.add("ol-street-view--activated-on-dragging"),this.pegmanDraggable.classList.add("ol-street-view--active","ol-street-view--can-drop"),this._viewport.classList.add("ol-street-view--drop-target")},ondragleave:()=>{this._viewport.classList.remove("ol-street-view--drop-target"),this.pegmanDraggable.classList.remove("ol-street-view--can-drop")},ondrop:()=>{this.pegmanDraggable.classList.add("ol-street-view--dropped")},ondropdeactivate:()=>s()})},t=()=>{const e="ol-street-view--compact";"compact"===this._options.defaultMapSize?document.body.classList.add(e):"hidden"===this._options.defaultMapSize&&document.body.classList.add("ol-street-view--hidden");const t=document.createElement("div");t.className="ol-street-view--size-toggler ol-unselectable ol-control";const i=document.createElement("button");i.title=this._i18n.minimize,i.innerHTML='<div class="ol-street-view--size-toggler-img"></div>',i.onclick=()=>{document.body.classList.toggle(e),document.body.classList.contains(e)?(i.title=this._i18n.expand,this._lastHeight=this._viewport.style.height,this._viewport.style.height=null):(i.title=this._i18n.minimize,this._lastHeight&&(this._viewport.style.height=this._lastHeight)),setTimeout((()=>{this._refreshMap()}),150)},t.append(i),this._map.addControl(new r({element:t}))};(()=>{this.pegmanDivControl=w,this.pegmanDivControl.id="ol-street-view--pegman-button-div",this.pegmanDivControl.className=`ol-street-view--${this._options.size}-btn ol-control ${this._options.transparentButton?"ol-street-view--transparent":""}`,this.pegmanDivControl.title=this._i18n.dragToInit,this.pegmanDraggable=document.createElement("div"),this.pegmanDraggable.id="ol-street-view--pegman-draggable",this.pegmanDraggable.className="ol-street-view--draggable ol-street-view--drag-drop";const t=document.createElement("div");t.id="ol-street-view--pegman-button",this.pegmanDivControl.append(this.pegmanDraggable),this.pegmanDivControl.append(t),e()})(),this._options.sizeToggler&&t()}async _loadStreetView(){const e=new p(this._options.apiKey,{language:this._options.language});try{await e.load(),super.dispatchEvent(z.LOAD_LIB)}catch(e){console.error(e)}}_updateStreetViewPosition(e){const t=l.transform(e,this._view.getProjection(),"EPSG:4326").reverse(),i={lat:t[0],lng:t[1]};this._streetViewService.getPanoramaByLocation(i,this._options.radius,((t,s)=>{s===google.maps.StreetViewStatus.OK?(this._panorama.setPosition(i),this._panorama.setVisible(!0),this._panorama.setZoom(1),this._options.updatePegmanToClosestPanorama&&(this._remvoveTranslateInteractionEvent(),this._updatePegmanPosition(t.location.latLng,!0),this._addTranslateInteractionEvent())):(this._showNoDataMode(),this._updatePegmanPosition(e,!1))}))}_updatePegmanPosition(e,t=!0){t&&(e=l.transform([e.lng(),e.lat()],"EPSG:4326",this._view.getProjection())),this._pegmanSelectedCoords=e,this._pegmanFeature.getGeometry().setCoordinates(this._pegmanSelectedCoords),this._centerMapToPegman()}_centerMapToPegman(){this._view.animate({center:this._pegmanSelectedCoords,duration:100})}_initPegmanOnMap(){this._pegmanLayer.getSource().getFeatures().length||(document.body.classList.contains("ol-street-view--activated")||(document.body.classList.add("ol-street-view--activated"),this._map.updateSize()),Object.keys(this._pegmanSelectedCoords)||(this._pegmanSelectedCoords=this._view.getCenter()),this._pegmanFeature?this._pegmanFeature.getGeometry().setCoordinates(this._pegmanSelectedCoords):this._pegmanFeature=new e({name:"Pegman",geometry:new n(this._pegmanSelectedCoords)}),this._pegmanLayer.getSource().addFeature(this._pegmanFeature),this._addTranslateInteraction(),this._view.setCenter(this._pegmanSelectedCoords),this._view.setZoom(this._options.zoomOnInit),this._showStreetView(this._pegmanSelectedCoords))}_showNoDataMode(){this._panorama.setVisible(!1)}_addClickListener(){this._clickOnMapEventKey=this._map.on("click",(e=>{this._updateStreetViewPosition(e.coordinate),e.preventDefault(),e.stopPropagation()}))}_refreshMap(e=!0){this._map.updateSize(),window.dispatchEvent(new Event("resize")),e&&this._centerMapToPegman()}_showStreetView(e){this._lastHeight&&(this._viewport.style.height=this._lastHeight),setTimeout((()=>{this._refreshMap(!1)}),150),this._updateStreetViewPosition(e),this._panorama.setVisible(!0),this._addClickListener(),super.dispatchEvent(z.STREET_VIEW_INIT)}_addStreetViewXyzLayer(){this._addedXyzLayer||this._map.addLayer(this._streetViewXyzLayer),this._addedXyzLayer=!0}_removeStreetViewXyzLayer(){this._map.removeLayer(this._streetViewXyzLayer),this._addedXyzLayer=!1}getStreetViewPanorama(){return this._panorama}getPegmanLayer(){return this._pegmanLayer}getStreetViewLayer(){return this._streetViewXyzLayer}showStreetView(e){if(e)return this._addStreetViewXyzLayer(),this._view.setCenter(e),this._view.setZoom(18),this._pegmanSelectedCoords=e,this._initPegmanOnMap(),this.getStreetViewPanorama();console.error("Coords are empty")}hideStreetView(){this._translatePegman.setActive(!1);this._pegmanLayer.getSource().clear(),this._pegmanSelectedCoords=[],this._removeStreetViewXyzLayer(),document.body.classList.remove("ol-street-view--activated"),this._lastHeight=this._viewport.style.height,this._viewport.style.height=null,this._panorama.setVisible(!1),setTimeout((()=>{this._refreshMap(!1)}),150),g.unByKey(this._clickOnMapEventKey),document.fullscreenElement&&document.exitFullscreen(),super.dispatchEvent(z.STREET_VIEW_EXIT)}}var z,A,C,L;!function(e){e.LOAD_LIB="loadLib",e.STREET_VIEW_INIT="streetViewInit",e.STREET_VIEW_EXIT="streetViewExit"}(z||(z={})),function(e){e.ES="es",e.EN="en"}(A||(A={})),function(e){e.Small="sm",e.Medium="md",e.Large="lg"}(C||(C={})),function(e){e.Expanded="expanded",e.Compact="compact",e.Hidden="hidden"}(L||(L={}));var M=Object.freeze({__proto__:null,get BtnControlSize(){return C},get Language(){return A},get MapSize(){return L},get SVEventTypes(){return z},default:u});return Object.assign(u,M),u}));