refactored OpenLayers code and added documentation
This commit is contained in:
parent
6756d86118
commit
cd7934b59a
56 changed files with 15511 additions and 138 deletions
BIN
openlayers/docs/fonts/OpenSans-Bold-webfont.eot
Normal file
BIN
openlayers/docs/fonts/OpenSans-Bold-webfont.eot
Normal file
Binary file not shown.
1830
openlayers/docs/fonts/OpenSans-Bold-webfont.svg
Normal file
1830
openlayers/docs/fonts/OpenSans-Bold-webfont.svg
Normal file
File diff suppressed because it is too large
Load diff
|
After Width: | Height: | Size: 116 KiB |
BIN
openlayers/docs/fonts/OpenSans-Bold-webfont.woff
Normal file
BIN
openlayers/docs/fonts/OpenSans-Bold-webfont.woff
Normal file
Binary file not shown.
BIN
openlayers/docs/fonts/OpenSans-BoldItalic-webfont.eot
Normal file
BIN
openlayers/docs/fonts/OpenSans-BoldItalic-webfont.eot
Normal file
Binary file not shown.
1830
openlayers/docs/fonts/OpenSans-BoldItalic-webfont.svg
Normal file
1830
openlayers/docs/fonts/OpenSans-BoldItalic-webfont.svg
Normal file
File diff suppressed because it is too large
Load diff
|
After Width: | Height: | Size: 118 KiB |
BIN
openlayers/docs/fonts/OpenSans-BoldItalic-webfont.woff
Normal file
BIN
openlayers/docs/fonts/OpenSans-BoldItalic-webfont.woff
Normal file
Binary file not shown.
BIN
openlayers/docs/fonts/OpenSans-Italic-webfont.eot
Normal file
BIN
openlayers/docs/fonts/OpenSans-Italic-webfont.eot
Normal file
Binary file not shown.
1830
openlayers/docs/fonts/OpenSans-Italic-webfont.svg
Normal file
1830
openlayers/docs/fonts/OpenSans-Italic-webfont.svg
Normal file
File diff suppressed because it is too large
Load diff
|
After Width: | Height: | Size: 120 KiB |
BIN
openlayers/docs/fonts/OpenSans-Italic-webfont.woff
Normal file
BIN
openlayers/docs/fonts/OpenSans-Italic-webfont.woff
Normal file
Binary file not shown.
BIN
openlayers/docs/fonts/OpenSans-Light-webfont.eot
Normal file
BIN
openlayers/docs/fonts/OpenSans-Light-webfont.eot
Normal file
Binary file not shown.
1831
openlayers/docs/fonts/OpenSans-Light-webfont.svg
Normal file
1831
openlayers/docs/fonts/OpenSans-Light-webfont.svg
Normal file
File diff suppressed because it is too large
Load diff
|
After Width: | Height: | Size: 114 KiB |
BIN
openlayers/docs/fonts/OpenSans-Light-webfont.woff
Normal file
BIN
openlayers/docs/fonts/OpenSans-Light-webfont.woff
Normal file
Binary file not shown.
BIN
openlayers/docs/fonts/OpenSans-LightItalic-webfont.eot
Normal file
BIN
openlayers/docs/fonts/OpenSans-LightItalic-webfont.eot
Normal file
Binary file not shown.
1835
openlayers/docs/fonts/OpenSans-LightItalic-webfont.svg
Normal file
1835
openlayers/docs/fonts/OpenSans-LightItalic-webfont.svg
Normal file
File diff suppressed because it is too large
Load diff
|
After Width: | Height: | Size: 120 KiB |
BIN
openlayers/docs/fonts/OpenSans-LightItalic-webfont.woff
Normal file
BIN
openlayers/docs/fonts/OpenSans-LightItalic-webfont.woff
Normal file
Binary file not shown.
BIN
openlayers/docs/fonts/OpenSans-Regular-webfont.eot
Normal file
BIN
openlayers/docs/fonts/OpenSans-Regular-webfont.eot
Normal file
Binary file not shown.
1831
openlayers/docs/fonts/OpenSans-Regular-webfont.svg
Normal file
1831
openlayers/docs/fonts/OpenSans-Regular-webfont.svg
Normal file
File diff suppressed because it is too large
Load diff
|
After Width: | Height: | Size: 117 KiB |
BIN
openlayers/docs/fonts/OpenSans-Regular-webfont.woff
Normal file
BIN
openlayers/docs/fonts/OpenSans-Regular-webfont.woff
Normal file
Binary file not shown.
333
openlayers/docs/global.html
Normal file
333
openlayers/docs/global.html
Normal file
|
|
@ -0,0 +1,333 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<title>JSDoc: Global</title>
|
||||
|
||||
<script src="scripts/prettify/prettify.js"></script>
|
||||
<script src="scripts/prettify/lang-css.js"></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
||||
<![endif]-->
|
||||
<link
|
||||
type="text/css"
|
||||
rel="stylesheet"
|
||||
href="styles/prettify-tomorrow.css"
|
||||
/>
|
||||
<link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css" />
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div id="main">
|
||||
<h1 class="page-title">Global</h1>
|
||||
|
||||
<section>
|
||||
<header>
|
||||
<h2></h2>
|
||||
</header>
|
||||
|
||||
<article>
|
||||
<div class="container-overview">
|
||||
<dl class="details"></dl>
|
||||
</div>
|
||||
|
||||
<h3 class="subsection-title">Members</h3>
|
||||
|
||||
<h4 class="name" id="map">
|
||||
<span class="type-signature">(constant) </span>map<span
|
||||
class="type-signature"
|
||||
>
|
||||
:ol.Map</span
|
||||
>
|
||||
</h4>
|
||||
|
||||
<div class="description">Main map</div>
|
||||
|
||||
<h5>Type:</h5>
|
||||
<ul>
|
||||
<li>
|
||||
<span class="param-type">ol.Map</span>
|
||||
</li>
|
||||
</ul>
|
||||
|
||||
<dl class="details">
|
||||
<dt class="tag-source">Source:</dt>
|
||||
<dd class="tag-source">
|
||||
<ul class="dummy">
|
||||
<li>
|
||||
<a href="main.js.html">main.js</a>,
|
||||
<a href="main.js.html#line42">line 42</a>
|
||||
</li>
|
||||
</ul>
|
||||
</dd>
|
||||
</dl>
|
||||
|
||||
<h4 class="name" id="pinLayer">
|
||||
<span class="type-signature">(constant) </span>pinLayer<span
|
||||
class="type-signature"
|
||||
>
|
||||
:ol.layer.VectorLayer</span
|
||||
>
|
||||
</h4>
|
||||
|
||||
<div class="description">Vector layer for pin vector source</div>
|
||||
|
||||
<h5>Type:</h5>
|
||||
<ul>
|
||||
<li>
|
||||
<span class="param-type">ol.layer.VectorLayer</span>
|
||||
</li>
|
||||
</ul>
|
||||
|
||||
<dl class="details">
|
||||
<dt class="tag-source">Source:</dt>
|
||||
<dd class="tag-source">
|
||||
<ul class="dummy">
|
||||
<li>
|
||||
<a href="main.js.html">main.js</a>,
|
||||
<a href="main.js.html#line32">line 32</a>
|
||||
</li>
|
||||
</ul>
|
||||
</dd>
|
||||
</dl>
|
||||
|
||||
<h4 class="name" id="pinSource">
|
||||
<span class="type-signature">(constant) </span>pinSource<span
|
||||
class="type-signature"
|
||||
>
|
||||
:ol.source.VectorSource</span
|
||||
>
|
||||
</h4>
|
||||
|
||||
<div class="description">Vector source for pins</div>
|
||||
|
||||
<h5>Type:</h5>
|
||||
<ul>
|
||||
<li>
|
||||
<span class="param-type">ol.source.VectorSource</span>
|
||||
</li>
|
||||
</ul>
|
||||
|
||||
<dl class="details">
|
||||
<dt class="tag-source">Source:</dt>
|
||||
<dd class="tag-source">
|
||||
<ul class="dummy">
|
||||
<li>
|
||||
<a href="main.js.html">main.js</a>,
|
||||
<a href="main.js.html#line29">line 29</a>
|
||||
</li>
|
||||
</ul>
|
||||
</dd>
|
||||
</dl>
|
||||
|
||||
<h4 class="name" id="popup">
|
||||
<span class="type-signature">(constant) </span>popup<span
|
||||
class="type-signature"
|
||||
>
|
||||
:ol.Overlay</span
|
||||
>
|
||||
</h4>
|
||||
|
||||
<div class="description">Overlay element for pin popups</div>
|
||||
|
||||
<h5>Type:</h5>
|
||||
<ul>
|
||||
<li>
|
||||
<span class="param-type">ol.Overlay</span>
|
||||
</li>
|
||||
</ul>
|
||||
|
||||
<dl class="details">
|
||||
<dt class="tag-source">Source:</dt>
|
||||
<dd class="tag-source">
|
||||
<ul class="dummy">
|
||||
<li>
|
||||
<a href="main.js.html">main.js</a>,
|
||||
<a href="main.js.html#line65">line 65</a>
|
||||
</li>
|
||||
</ul>
|
||||
</dd>
|
||||
</dl>
|
||||
|
||||
<h3 class="subsection-title">Methods</h3>
|
||||
|
||||
<h4 class="name" id="disposePopover">
|
||||
<span class="type-signature"></span>disposePopover<span
|
||||
class="signature"
|
||||
>()</span
|
||||
><span class="type-signature"></span>
|
||||
</h4>
|
||||
|
||||
<div class="description">
|
||||
Removes store information popup from screen
|
||||
</div>
|
||||
|
||||
<dl class="details">
|
||||
<dt class="tag-source">Source:</dt>
|
||||
<dd class="tag-source">
|
||||
<ul class="dummy">
|
||||
<li>
|
||||
<a href="main.js.html">main.js</a>,
|
||||
<a href="main.js.html#line82">line 82</a>
|
||||
</li>
|
||||
</ul>
|
||||
</dd>
|
||||
</dl>
|
||||
|
||||
<h4 class="name" id="map-onclick">
|
||||
<span class="type-signature"></span>map.oncick<span
|
||||
class="signature"
|
||||
>()</span
|
||||
><span class="type-signature"></span>
|
||||
</h4>
|
||||
|
||||
<div class="description">
|
||||
Handles user clicks. If user clicks on a pixel that contains a pin,
|
||||
display popup with store information
|
||||
</div>
|
||||
|
||||
<dl class="details">
|
||||
<dt class="tag-source">Source:</dt>
|
||||
<dd class="tag-source">
|
||||
<ul class="dummy">
|
||||
<li>
|
||||
<a href="main.js.html">main.js</a>,
|
||||
<a href="main.js.html#line82">line 89</a>
|
||||
</li>
|
||||
</ul>
|
||||
</dd>
|
||||
</dl>
|
||||
|
||||
<h4 class="name" id="passlocation">
|
||||
<span class="type-signature"></span>window.passLocation<span
|
||||
class="signature"
|
||||
>(lon, lat)</span
|
||||
><span class="type-signature"></span>
|
||||
</h4>
|
||||
|
||||
<div class="description">
|
||||
Centers location on user based on location information passed in
|
||||
from expo-location
|
||||
</div>
|
||||
|
||||
<h5>Parameters:</h5>
|
||||
|
||||
<table class="params">
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Name</th>
|
||||
|
||||
<th>Type</th>
|
||||
|
||||
<th class="last">Description</th>
|
||||
</tr>
|
||||
</thead>
|
||||
|
||||
<tbody>
|
||||
<tr>
|
||||
<td class="name"><code>lon</code></td>
|
||||
|
||||
<td class="type">
|
||||
<span class="param-type">number</span>
|
||||
</td>
|
||||
|
||||
<td class="description last">User's longitude</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td class="name"><code>lat</code></td>
|
||||
|
||||
<td class="type">
|
||||
<span class="param-type">number</span>
|
||||
</td>
|
||||
|
||||
<td class="description last">User's latitude</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
|
||||
<dl class="details">
|
||||
<dt class="tag-source">Source:</dt>
|
||||
<dd class="tag-source">
|
||||
<ul class="dummy">
|
||||
<li>
|
||||
<a href="main.js.html">main.js</a>,
|
||||
<a href="main.js.html#line82">line 146</a>
|
||||
</li>
|
||||
</ul>
|
||||
</dd>
|
||||
</dl>
|
||||
|
||||
<h4 class="name" id="placepin">
|
||||
<span class="type-signature"></span>window.placePin<span
|
||||
class="signature"
|
||||
>()</span
|
||||
><span class="type-signature"></span>
|
||||
</h4>
|
||||
|
||||
<div class="description">
|
||||
Begins store creation process if user clicks on "New" button
|
||||
</div>
|
||||
|
||||
<dl class="details">
|
||||
<dt class="tag-source">Source:</dt>
|
||||
<dd class="tag-source">
|
||||
<ul class="dummy">
|
||||
<li>
|
||||
<a href="main.js.html">main.js</a>,
|
||||
<a href="main.js.html#line82">line 172</a>
|
||||
</li>
|
||||
</ul>
|
||||
</dd>
|
||||
</dl>
|
||||
</article>
|
||||
</section>
|
||||
</div>
|
||||
|
||||
<nav>
|
||||
<h2><a href="index.html">Home</a></h2>
|
||||
<h3>Modules</h3>
|
||||
<ul>
|
||||
<li>
|
||||
<a href="module-changeResolutionHandler.html"
|
||||
>changeResolutionHandler</a
|
||||
>
|
||||
</li>
|
||||
<li><a href="module-fetchPins.html">fetchPins</a></li>
|
||||
<li><a href="module-makePin.html">makePin</a></li>
|
||||
<li><a href="module-newButton.html">newButton</a></li>
|
||||
<li><a href="module-pointerMoveHandler.html">pointerMoveHandler</a></li>
|
||||
<li><a href="module-searchBar.html">searchBar</a></li>
|
||||
<li><a href="module-searchInputHander.html">searchInputHander</a></li>
|
||||
<li><a href="module-toLatLon.html">toLatLon</a></li>
|
||||
</ul>
|
||||
<h3>Classes</h3>
|
||||
<ul>
|
||||
<li><a href="module-newButton-ButtonControl.html">ButtonControl</a></li>
|
||||
</ul>
|
||||
<h3>Global</h3>
|
||||
<ul>
|
||||
<li><a href="global.html#disposePopover">disposePopover</a></li>
|
||||
<li><a href="global.html#map-onclick">map.onclick</a></li>
|
||||
<li><a href="global.html#passlocation">window.passLocation</a></li>
|
||||
<li><a href="global.html#placepin">window.placePin</a></li>
|
||||
<li><a href="global.html#map">map</a></li>
|
||||
<li><a href="global.html#pinLayer">pinLayer</a></li>
|
||||
<li><a href="global.html#pinSource">pinSource</a></li>
|
||||
<li><a href="global.html#popup">popup</a></li>
|
||||
</ul>
|
||||
</nav>
|
||||
|
||||
<br class="clear" />
|
||||
|
||||
<footer>
|
||||
Documentation generated by
|
||||
<a href="https://github.com/jsdoc/jsdoc">JSDoc 4.0.2</a> on Sun Dec 31
|
||||
2023 15:19:11 GMT-0800 (Pacific Standard Time)
|
||||
</footer>
|
||||
|
||||
<script>
|
||||
prettyPrint();
|
||||
</script>
|
||||
<script src="scripts/linenumber.js"></script>
|
||||
</body>
|
||||
</html>
|
||||
85
openlayers/docs/index.html
Normal file
85
openlayers/docs/index.html
Normal file
|
|
@ -0,0 +1,85 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<title>JSDoc: Home</title>
|
||||
|
||||
<script src="scripts/prettify/prettify.js"></script>
|
||||
<script src="scripts/prettify/lang-css.js"></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
||||
<![endif]-->
|
||||
<link
|
||||
type="text/css"
|
||||
rel="stylesheet"
|
||||
href="styles/prettify-tomorrow.css"
|
||||
/>
|
||||
<link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css" />
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div id="main">
|
||||
<h1 class="page-title">Home</h1>
|
||||
|
||||
<h3>beerbuddy 1.0.0</h3>
|
||||
|
||||
<section>
|
||||
<article>
|
||||
<h1>OpenLayers + Vite</h1>
|
||||
<p>
|
||||
First stage of the app is the creation of an OpenLayers app that is
|
||||
inlined into a single file by Vite. This is then an asset that can
|
||||
be interacted with from within React Native.
|
||||
</p>
|
||||
</article>
|
||||
</section>
|
||||
</div>
|
||||
|
||||
<nav>
|
||||
<h2><a href="index.html">Home</a></h2>
|
||||
<h3>Modules</h3>
|
||||
<ul>
|
||||
<li>
|
||||
<a href="module-changeResolutionHandler.html"
|
||||
>changeResolutionHandler</a
|
||||
>
|
||||
</li>
|
||||
<li><a href="module-fetchPins.html">fetchPins</a></li>
|
||||
<li><a href="module-makePin.html">makePin</a></li>
|
||||
<li><a href="module-newButton.html">newButton</a></li>
|
||||
<li><a href="module-pointerMoveHandler.html">pointerMoveHandler</a></li>
|
||||
<li><a href="module-searchBar.html">searchBar</a></li>
|
||||
<li><a href="module-searchInputHander.html">searchInputHander</a></li>
|
||||
<li><a href="module-toLatLon.html">toLatLon</a></li>
|
||||
</ul>
|
||||
<h3>Classes</h3>
|
||||
<ul>
|
||||
<li><a href="module-newButton-ButtonControl.html">ButtonControl</a></li>
|
||||
</ul>
|
||||
<h3>Global</h3>
|
||||
<ul>
|
||||
<li><a href="global.html#disposePopover">disposePopover</a></li>
|
||||
<li><a href="global.html#map-onclick">map.onclick</a></li>
|
||||
<li><a href="global.html#passlocation">window.passLocation</a></li>
|
||||
<li><a href="global.html#placepin">window.placePin</a></li>
|
||||
<li><a href="global.html#map">map</a></li>
|
||||
<li><a href="global.html#pinLayer">pinLayer</a></li>
|
||||
<li><a href="global.html#pinSource">pinSource</a></li>
|
||||
<li><a href="global.html#popup">popup</a></li>
|
||||
</ul>
|
||||
</nav>
|
||||
|
||||
<br class="clear" />
|
||||
|
||||
<footer>
|
||||
Documentation generated by
|
||||
<a href="https://github.com/jsdoc/jsdoc">JSDoc 4.0.2</a> on Sun Dec 31
|
||||
2023 15:19:11 GMT-0800 (Pacific Standard Time)
|
||||
</footer>
|
||||
|
||||
<script>
|
||||
prettyPrint();
|
||||
</script>
|
||||
<script src="scripts/linenumber.js"></script>
|
||||
</body>
|
||||
</html>
|
||||
277
openlayers/docs/main.js.html
Normal file
277
openlayers/docs/main.js.html
Normal file
|
|
@ -0,0 +1,277 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<title>JSDoc: Source: main.js</title>
|
||||
|
||||
<script src="scripts/prettify/prettify.js"></script>
|
||||
<script src="scripts/prettify/lang-css.js"></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
||||
<![endif]-->
|
||||
<link
|
||||
type="text/css"
|
||||
rel="stylesheet"
|
||||
href="styles/prettify-tomorrow.css"
|
||||
/>
|
||||
<link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css" />
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div id="main">
|
||||
<h1 class="page-title">Source: main.js</h1>
|
||||
|
||||
<section>
|
||||
<article>
|
||||
<pre class="prettyprint source linenums"><code>import "./style.css";
|
||||
|
||||
import { Map, View, Overlay } from "ol";
|
||||
|
||||
import { Tile as TileLayer, Vector as VectorLayer } from "ol/layer";
|
||||
import { TileJSON, Vector as VectorSource } from "ol/source";
|
||||
import { useGeographic } from "ol/proj.js";
|
||||
import { defaults as defaultControls } from "ol/control.js";
|
||||
|
||||
import { Popover } from "bootstrap";
|
||||
|
||||
import searchBar from "./modules/searchBar.js";
|
||||
import fetchPins from "./modules/fetchPins.js";
|
||||
import ButtonControl from "./modules/newButton.js";
|
||||
import changeResolutionHandler from "./modules/changeResolutionHandler.js";
|
||||
import pointerMoveHandler from "./modules/pointerMoveHandler.js";
|
||||
import searchInputHander from "./modules/searchInputHandler.js";
|
||||
|
||||
///
|
||||
|
||||
const search = searchBar;
|
||||
|
||||
let pinning = false;
|
||||
|
||||
let popover;
|
||||
|
||||
/** Vector source for pins
|
||||
* @constant {ol.source.VectorSource} */
|
||||
const pinSource = new VectorSource();
|
||||
/** Vector layer for pin vector source
|
||||
* @constant {ol.layer.VectorLayer} */
|
||||
const pinLayer = new VectorLayer({
|
||||
source: pinSource,
|
||||
});
|
||||
|
||||
useGeographic();
|
||||
|
||||
fetchPins(pinSource);
|
||||
|
||||
/** Main map
|
||||
* @constant {ol.Map} */
|
||||
const map = new Map({
|
||||
controls: defaultControls().extend([new ButtonControl()]),
|
||||
target: document.getElementById("map"),
|
||||
layers: [
|
||||
new TileLayer({
|
||||
source: new TileJSON({
|
||||
url: `https://api.maptiler.com/maps/hybrid/tiles.json?key=${
|
||||
import.meta.env.VITE_MAPTILER_KEY
|
||||
}`,
|
||||
tileSize: 512,
|
||||
crossOrigin: "anonymous",
|
||||
}),
|
||||
}),
|
||||
],
|
||||
view: new View({
|
||||
center: [0, 0],
|
||||
zoom: 2,
|
||||
maxZoom: 20,
|
||||
}),
|
||||
});
|
||||
|
||||
/** Overlay element for pin popups
|
||||
* @constant {ol.Overlay} */
|
||||
const popup = new Overlay({
|
||||
element: document.getElementById("popup"),
|
||||
positioning: "bottom-center",
|
||||
stopEvent: false,
|
||||
});
|
||||
|
||||
map.addOverlay(popup);
|
||||
|
||||
map.addControl(search);
|
||||
|
||||
const searchInput = search.getInputField();
|
||||
searchInput.onkeydown = (event) => {
|
||||
searchInputHander(event, map);
|
||||
};
|
||||
|
||||
/** Removes store information popup from screen
|
||||
*/
|
||||
const disposePopover = () => {
|
||||
if (popover) {
|
||||
popover.dispose();
|
||||
popover = undefined;
|
||||
}
|
||||
};
|
||||
|
||||
/** Handles user clicks. If user clicks on a pixel that contains a pin, display popup with store information
|
||||
* @param {Event} event - User click event
|
||||
* @param {bootstrap.Popover} popover - Popover object from Bootstrap/Popper
|
||||
* @param {ol.Overlay} popup - Overlay element for pin popups
|
||||
* @param {ol.Map} map - OpenLayers map
|
||||
*/
|
||||
|
||||
map.on("click", (event) => {
|
||||
disposePopover();
|
||||
|
||||
const feature = map.forEachFeatureAtPixel(event.pixel, (feature) => feature);
|
||||
if (!feature) return;
|
||||
|
||||
popup.setPosition(event.coordinate);
|
||||
|
||||
const element = document.querySelector("#popup");
|
||||
|
||||
popover = new Popover(element, {
|
||||
placement: "top",
|
||||
html: true,
|
||||
title: feature.get("store"),
|
||||
content: function () {
|
||||
const container = document.createElement("div");
|
||||
|
||||
const cheapestItem = document.createElement("div");
|
||||
cheapestItem.textContent = `Cheapest Item: ${feature.get(
|
||||
"cheapestItem"
|
||||
)}`;
|
||||
container.appendChild(cheapestItem);
|
||||
|
||||
const cheapestPerFloz = document.createElement("div");
|
||||
cheapestPerFloz.textContent = `$ / oz.: ${feature.get("pricePerOz")}`;
|
||||
container.appendChild(cheapestPerFloz);
|
||||
|
||||
const link = document.createElement("a");
|
||||
link.href = "#";
|
||||
link.onclick = function (event) {
|
||||
event.preventDefault();
|
||||
window.ReactNativeWebView?.postMessage(
|
||||
`open@${feature.getGeometry().getCoordinates()}`
|
||||
);
|
||||
};
|
||||
link.textContent = "More...";
|
||||
container.appendChild(link);
|
||||
|
||||
return container;
|
||||
},
|
||||
});
|
||||
|
||||
popover.show();
|
||||
});
|
||||
|
||||
map.on("pointermove", (event) => {
|
||||
pointerMoveHandler(event, map);
|
||||
});
|
||||
|
||||
map.on("movestart", disposePopover);
|
||||
|
||||
map.getView().on("change:resolution", () => {
|
||||
changeResolutionHandler(pinning, map, pinLayer);
|
||||
});
|
||||
|
||||
/** Centers location on user based on location information passed in from expo-location
|
||||
* @param {number} lon - User's longitude
|
||||
* @param {number} lat - User's latitude
|
||||
*/
|
||||
window.passLocation = (lon, lat) => {
|
||||
const view = new View({
|
||||
center: [lon, lat],
|
||||
zoom: 18,
|
||||
maxZoom: 20,
|
||||
});
|
||||
|
||||
map.setView(view);
|
||||
map.getLayers().extend([pinLayer]);
|
||||
|
||||
// sets NEW listener to listen for zoom changes
|
||||
view.on("change:resolution", () => {
|
||||
view.getZoom() < 5
|
||||
? map.getLayers().removeAt(1)
|
||||
: (() => {
|
||||
if (map.getLayers().getLength() === 1) {
|
||||
if (!pinning) map.getLayers().extend([pinLayer]);
|
||||
}
|
||||
})();
|
||||
});
|
||||
};
|
||||
|
||||
/** Begins store creation process if user clicks on "New" button
|
||||
*/
|
||||
window.placePin = () => {
|
||||
button.removeEventListener("click", newButtonHandler, false);
|
||||
pinning = true;
|
||||
map.getLayers().removeAt(1);
|
||||
// adds pin in center of view
|
||||
document.getElementById("centerPin").style.display = "block";
|
||||
// changes new button to OK button
|
||||
button.textContent = "OK";
|
||||
// OK button has event listener that on click
|
||||
function OKButtonHandler() {
|
||||
// removes listener on button in case someone wants to mash it
|
||||
button.removeEventListener("click", OKButtonHandler, false);
|
||||
// removes pin in center of view
|
||||
document.getElementById("centerPin").style.display = "none";
|
||||
// emits to RN
|
||||
window.ReactNativeWebView?.postMessage(
|
||||
`create@${map.getView().getCenter()}`
|
||||
);
|
||||
}
|
||||
button.addEventListener("click", OKButtonHandler, false);
|
||||
};
|
||||
</code></pre>
|
||||
</article>
|
||||
</section>
|
||||
</div>
|
||||
|
||||
<nav>
|
||||
<h2><a href="index.html">Home</a></h2>
|
||||
<h3>Modules</h3>
|
||||
<ul>
|
||||
<li>
|
||||
<a href="module-changeResolutionHandler.html"
|
||||
>changeResolutionHandler</a
|
||||
>
|
||||
</li>
|
||||
<li><a href="module-fetchPins.html">fetchPins</a></li>
|
||||
<li><a href="module-makePin.html">makePin</a></li>
|
||||
<li><a href="module-newButton.html">newButton</a></li>
|
||||
<li><a href="module-pointerMoveHandler.html">pointerMoveHandler</a></li>
|
||||
<li><a href="module-searchBar.html">searchBar</a></li>
|
||||
<li><a href="module-searchInputHander.html">searchInputHander</a></li>
|
||||
<li><a href="module-toLatLon.html">toLatLon</a></li>
|
||||
</ul>
|
||||
<h3>Classes</h3>
|
||||
<ul>
|
||||
<li><a href="module-newButton-ButtonControl.html">ButtonControl</a></li>
|
||||
</ul>
|
||||
<h3>Global</h3>
|
||||
<ul>
|
||||
<li><a href="global.html#disposePopover">disposePopover</a></li>
|
||||
<li><a href="global.html#map-onclick">map.onclick</a></li>
|
||||
<li><a href="global.html#passlocation">window.passLocation</a></li>
|
||||
<li><a href="global.html#placepin">window.placePin</a></li>
|
||||
<li><a href="global.html#map">map</a></li>
|
||||
<li><a href="global.html#pinLayer">pinLayer</a></li>
|
||||
<li><a href="global.html#pinSource">pinSource</a></li>
|
||||
<li><a href="global.html#popup">popup</a></li>
|
||||
</ul>
|
||||
</nav>
|
||||
|
||||
<br class="clear" />
|
||||
|
||||
<footer>
|
||||
Documentation generated by
|
||||
<a href="https://github.com/jsdoc/jsdoc">JSDoc 4.0.2</a> on Sun Dec 31
|
||||
2023 15:19:11 GMT-0800 (Pacific Standard Time)
|
||||
</footer>
|
||||
|
||||
<script>
|
||||
prettyPrint();
|
||||
</script>
|
||||
<script src="scripts/linenumber.js"></script>
|
||||
</body>
|
||||
</html>
|
||||
218
openlayers/docs/module-changeResolutionHandler.html
Normal file
218
openlayers/docs/module-changeResolutionHandler.html
Normal file
|
|
@ -0,0 +1,218 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<title>JSDoc: Module: changeResolutionHandler</title>
|
||||
|
||||
<script src="scripts/prettify/prettify.js"></script>
|
||||
<script src="scripts/prettify/lang-css.js"></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
||||
<![endif]-->
|
||||
<link
|
||||
type="text/css"
|
||||
rel="stylesheet"
|
||||
href="styles/prettify-tomorrow.css"
|
||||
/>
|
||||
<link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css" />
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div id="main">
|
||||
<h1 class="page-title">Module: changeResolutionHandler</h1>
|
||||
|
||||
<section>
|
||||
<header></header>
|
||||
|
||||
<article>
|
||||
<div class="container-overview">
|
||||
<dl class="details">
|
||||
<dt class="tag-source">Source:</dt>
|
||||
<dd class="tag-source">
|
||||
<ul class="dummy">
|
||||
<li>
|
||||
<a href="modules_changeResolutionHandler.js.html"
|
||||
>modules/changeResolutionHandler.js</a
|
||||
>,
|
||||
<a href="modules_changeResolutionHandler.js.html#line1"
|
||||
>line 1</a
|
||||
>
|
||||
</li>
|
||||
</ul>
|
||||
</dd>
|
||||
</dl>
|
||||
</div>
|
||||
|
||||
<h3 class="subsection-title">Members</h3>
|
||||
|
||||
<h4 class="name" id="~CUTOFF">
|
||||
<span class="type-signature">(inner, constant) </span>CUTOFF<span
|
||||
class="type-signature"
|
||||
>
|
||||
:number</span
|
||||
>
|
||||
</h4>
|
||||
|
||||
<div class="description">Maximum zoom level to show pins</div>
|
||||
|
||||
<h5>Type:</h5>
|
||||
<ul>
|
||||
<li>
|
||||
<span class="param-type">number</span>
|
||||
</li>
|
||||
</ul>
|
||||
|
||||
<dl class="details">
|
||||
<dt class="tag-default">Default Value:</dt>
|
||||
<dd class="tag-default">
|
||||
<ul class="dummy">
|
||||
<li>5</li>
|
||||
</ul>
|
||||
</dd>
|
||||
|
||||
<dt class="tag-source">Source:</dt>
|
||||
<dd class="tag-source">
|
||||
<ul class="dummy">
|
||||
<li>
|
||||
<a href="modules_changeResolutionHandler.js.html"
|
||||
>modules/changeResolutionHandler.js</a
|
||||
>,
|
||||
<a href="modules_changeResolutionHandler.js.html#line9"
|
||||
>line 9</a
|
||||
>
|
||||
</li>
|
||||
</ul>
|
||||
</dd>
|
||||
</dl>
|
||||
|
||||
<h3 class="subsection-title">Methods</h3>
|
||||
|
||||
<h4 class="name" id="~changeResolutionHandler">
|
||||
<span class="type-signature">(inner) </span
|
||||
>changeResolutionHandler<span class="signature"
|
||||
>(pinning, map, pinLayer)</span
|
||||
><span class="type-signature"></span>
|
||||
</h4>
|
||||
|
||||
<div class="description">
|
||||
Adds or removes pin vector layer depending on zoom level
|
||||
</div>
|
||||
|
||||
<h5>Parameters:</h5>
|
||||
|
||||
<table class="params">
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Name</th>
|
||||
|
||||
<th>Type</th>
|
||||
|
||||
<th class="last">Description</th>
|
||||
</tr>
|
||||
</thead>
|
||||
|
||||
<tbody>
|
||||
<tr>
|
||||
<td class="name"><code>pinning</code></td>
|
||||
|
||||
<td class="type">
|
||||
<span class="param-type">boolean</span>
|
||||
</td>
|
||||
|
||||
<td class="description last">
|
||||
Boolean to toggle between new pin creation and viewing
|
||||
existing pins. If this is true, existing pins are not visible.
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td class="name"><code>map</code></td>
|
||||
|
||||
<td class="type">
|
||||
<span class="param-type">ol.Map</span>
|
||||
</td>
|
||||
|
||||
<td class="description last">OpenLayers map to center</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td class="name"><code>pinLayer</code></td>
|
||||
|
||||
<td class="type">
|
||||
<span class="param-type">ol.layer.Vector</span>
|
||||
</td>
|
||||
|
||||
<td class="description last">
|
||||
OpenLayers vector layer for pins
|
||||
</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
|
||||
<dl class="details">
|
||||
<dt class="tag-source">Source:</dt>
|
||||
<dd class="tag-source">
|
||||
<ul class="dummy">
|
||||
<li>
|
||||
<a href="modules_changeResolutionHandler.js.html"
|
||||
>modules/changeResolutionHandler.js</a
|
||||
>,
|
||||
<a href="modules_changeResolutionHandler.js.html#line16"
|
||||
>line 16</a
|
||||
>
|
||||
</li>
|
||||
</ul>
|
||||
</dd>
|
||||
</dl>
|
||||
</article>
|
||||
</section>
|
||||
</div>
|
||||
|
||||
<nav>
|
||||
<h2><a href="index.html">Home</a></h2>
|
||||
<h3>Modules</h3>
|
||||
<ul>
|
||||
<li>
|
||||
<a href="module-changeResolutionHandler.html"
|
||||
>changeResolutionHandler</a
|
||||
>
|
||||
</li>
|
||||
<li><a href="module-fetchPins.html">fetchPins</a></li>
|
||||
<li><a href="module-makePin.html">makePin</a></li>
|
||||
<li><a href="module-newButton.html">newButton</a></li>
|
||||
<li><a href="module-pointerMoveHandler.html">pointerMoveHandler</a></li>
|
||||
<li><a href="module-searchBar.html">searchBar</a></li>
|
||||
<li><a href="module-searchInputHander.html">searchInputHander</a></li>
|
||||
<li><a href="module-toLatLon.html">toLatLon</a></li>
|
||||
</ul>
|
||||
<h3>Classes</h3>
|
||||
<ul>
|
||||
<li><a href="module-newButton-ButtonControl.html">ButtonControl</a></li>
|
||||
</ul>
|
||||
<h3>Global</h3>
|
||||
<ul>
|
||||
<li><a href="global.html#disposePopover">disposePopover</a></li>
|
||||
<li><a href="global.html#map-onclick">map.onclick</a></li>
|
||||
<li><a href="global.html#passlocation">window.passLocation</a></li>
|
||||
<li><a href="global.html#placepin">window.placePin</a></li>
|
||||
<li><a href="global.html#map">map</a></li>
|
||||
<li><a href="global.html#pinLayer">pinLayer</a></li>
|
||||
<li><a href="global.html#pinSource">pinSource</a></li>
|
||||
<li><a href="global.html#popup">popup</a></li>
|
||||
</ul>
|
||||
</nav>
|
||||
|
||||
<br class="clear" />
|
||||
|
||||
<footer>
|
||||
Documentation generated by
|
||||
<a href="https://github.com/jsdoc/jsdoc">JSDoc 4.0.2</a> on Sun Dec 31
|
||||
2023 15:19:11 GMT-0800 (Pacific Standard Time)
|
||||
</footer>
|
||||
|
||||
<script>
|
||||
prettyPrint();
|
||||
</script>
|
||||
<script src="scripts/linenumber.js"></script>
|
||||
</body>
|
||||
</html>
|
||||
146
openlayers/docs/module-fetchPins.html
Normal file
146
openlayers/docs/module-fetchPins.html
Normal file
|
|
@ -0,0 +1,146 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<title>JSDoc: Module: fetchPins</title>
|
||||
|
||||
<script src="scripts/prettify/prettify.js"></script>
|
||||
<script src="scripts/prettify/lang-css.js"></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
||||
<![endif]-->
|
||||
<link
|
||||
type="text/css"
|
||||
rel="stylesheet"
|
||||
href="styles/prettify-tomorrow.css"
|
||||
/>
|
||||
<link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css" />
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div id="main">
|
||||
<h1 class="page-title">Module: fetchPins</h1>
|
||||
|
||||
<section>
|
||||
<header></header>
|
||||
|
||||
<article>
|
||||
<div class="container-overview">
|
||||
<dl class="details">
|
||||
<dt class="tag-source">Source:</dt>
|
||||
<dd class="tag-source">
|
||||
<ul class="dummy">
|
||||
<li>
|
||||
<a href="modules_fetchPins.js.html">modules/fetchPins.js</a
|
||||
>, <a href="modules_fetchPins.js.html#line4">line 4</a>
|
||||
</li>
|
||||
</ul>
|
||||
</dd>
|
||||
</dl>
|
||||
</div>
|
||||
|
||||
<h3 class="subsection-title">Methods</h3>
|
||||
|
||||
<h4 class="name" id="~fetchPins">
|
||||
<span class="type-signature">(async, inner) </span>fetchPins<span
|
||||
class="signature"
|
||||
>(pinSource)</span
|
||||
><span class="type-signature"></span>
|
||||
</h4>
|
||||
|
||||
<div class="description">
|
||||
Fetches pin records from database and adds pin features to pin
|
||||
vector source layer
|
||||
</div>
|
||||
|
||||
<h5>Parameters:</h5>
|
||||
|
||||
<table class="params">
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Name</th>
|
||||
|
||||
<th>Type</th>
|
||||
|
||||
<th class="last">Description</th>
|
||||
</tr>
|
||||
</thead>
|
||||
|
||||
<tbody>
|
||||
<tr>
|
||||
<td class="name"><code>pinSource</code></td>
|
||||
|
||||
<td class="type">
|
||||
<span class="param-type">ol.source.Vector</span>
|
||||
</td>
|
||||
|
||||
<td class="description last">
|
||||
The relevant vector source layer to add pin features to
|
||||
</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
|
||||
<dl class="details">
|
||||
<dt class="tag-source">Source:</dt>
|
||||
<dd class="tag-source">
|
||||
<ul class="dummy">
|
||||
<li>
|
||||
<a href="modules_fetchPins.js.html">modules/fetchPins.js</a>,
|
||||
<a href="modules_fetchPins.js.html#line12">line 12</a>
|
||||
</li>
|
||||
</ul>
|
||||
</dd>
|
||||
</dl>
|
||||
</article>
|
||||
</section>
|
||||
</div>
|
||||
|
||||
<nav>
|
||||
<h2><a href="index.html">Home</a></h2>
|
||||
<h3>Modules</h3>
|
||||
<ul>
|
||||
<li>
|
||||
<a href="module-changeResolutionHandler.html"
|
||||
>changeResolutionHandler</a
|
||||
>
|
||||
</li>
|
||||
<li><a href="module-fetchPins.html">fetchPins</a></li>
|
||||
<li><a href="module-makePin.html">makePin</a></li>
|
||||
<li><a href="module-newButton.html">newButton</a></li>
|
||||
<li><a href="module-pointerMoveHandler.html">pointerMoveHandler</a></li>
|
||||
<li><a href="module-searchBar.html">searchBar</a></li>
|
||||
<li><a href="module-searchInputHander.html">searchInputHander</a></li>
|
||||
<li><a href="module-toLatLon.html">toLatLon</a></li>
|
||||
</ul>
|
||||
<h3>Classes</h3>
|
||||
<ul>
|
||||
<li><a href="module-newButton-ButtonControl.html">ButtonControl</a></li>
|
||||
</ul>
|
||||
<h3>Global</h3>
|
||||
<ul>
|
||||
<li><a href="global.html#disposePopover">disposePopover</a></li>
|
||||
<li><a href="global.html#map-onclick">map.onclick</a></li>
|
||||
<li><a href="global.html#passlocation">window.passLocation</a></li>
|
||||
<li><a href="global.html#placepin">window.placePin</a></li>
|
||||
<li><a href="global.html#map">map</a></li>
|
||||
<li><a href="global.html#pinLayer">pinLayer</a></li>
|
||||
<li><a href="global.html#pinSource">pinSource</a></li>
|
||||
<li><a href="global.html#popup">popup</a></li>
|
||||
</ul>
|
||||
</nav>
|
||||
|
||||
<br class="clear" />
|
||||
|
||||
<footer>
|
||||
Documentation generated by
|
||||
<a href="https://github.com/jsdoc/jsdoc">JSDoc 4.0.2</a> on Sun Dec 31
|
||||
2023 15:19:11 GMT-0800 (Pacific Standard Time)
|
||||
</footer>
|
||||
|
||||
<script>
|
||||
prettyPrint();
|
||||
</script>
|
||||
<script src="scripts/linenumber.js"></script>
|
||||
</body>
|
||||
</html>
|
||||
194
openlayers/docs/module-makePin.html
Normal file
194
openlayers/docs/module-makePin.html
Normal file
|
|
@ -0,0 +1,194 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<title>JSDoc: Module: makePin</title>
|
||||
|
||||
<script src="scripts/prettify/prettify.js"></script>
|
||||
<script src="scripts/prettify/lang-css.js"></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
||||
<![endif]-->
|
||||
<link
|
||||
type="text/css"
|
||||
rel="stylesheet"
|
||||
href="styles/prettify-tomorrow.css"
|
||||
/>
|
||||
<link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css" />
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div id="main">
|
||||
<h1 class="page-title">Module: makePin</h1>
|
||||
|
||||
<section>
|
||||
<header></header>
|
||||
|
||||
<article>
|
||||
<div class="container-overview">
|
||||
<dl class="details">
|
||||
<dt class="tag-source">Source:</dt>
|
||||
<dd class="tag-source">
|
||||
<ul class="dummy">
|
||||
<li>
|
||||
<a href="modules_makePin.js.html">modules/makePin.js</a>,
|
||||
<a href="modules_makePin.js.html#line6">line 6</a>
|
||||
</li>
|
||||
</ul>
|
||||
</dd>
|
||||
</dl>
|
||||
</div>
|
||||
|
||||
<h3 class="subsection-title">Methods</h3>
|
||||
|
||||
<h4 class="name" id="~makePin">
|
||||
<span class="type-signature">(inner) </span>makePin<span
|
||||
class="signature"
|
||||
>(lon, lat, storeName, cheapest, flozPrice)</span
|
||||
><span class="type-signature"> → {ol.Feature}</span>
|
||||
</h4>
|
||||
|
||||
<div class="description">Makes pin feature from arguments</div>
|
||||
|
||||
<h5>Parameters:</h5>
|
||||
|
||||
<table class="params">
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Name</th>
|
||||
|
||||
<th>Type</th>
|
||||
|
||||
<th class="last">Description</th>
|
||||
</tr>
|
||||
</thead>
|
||||
|
||||
<tbody>
|
||||
<tr>
|
||||
<td class="name"><code>lon</code></td>
|
||||
|
||||
<td class="type">
|
||||
<span class="param-type">number</span>
|
||||
</td>
|
||||
|
||||
<td class="description last">Longitude</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td class="name"><code>lat</code></td>
|
||||
|
||||
<td class="type">
|
||||
<span class="param-type">number</span>
|
||||
</td>
|
||||
|
||||
<td class="description last">Latitude</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td class="name"><code>storeName</code></td>
|
||||
|
||||
<td class="type">
|
||||
<span class="param-type">string</span>
|
||||
</td>
|
||||
|
||||
<td class="description last">Name of store</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td class="name"><code>cheapest</code></td>
|
||||
|
||||
<td class="type">
|
||||
<span class="param-type">string</span>
|
||||
</td>
|
||||
|
||||
<td class="description last">Cheapest item in store</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td class="name"><code>flozPrice</code></td>
|
||||
|
||||
<td class="type">
|
||||
<span class="param-type">number</span>
|
||||
</td>
|
||||
|
||||
<td class="description last">
|
||||
Price per fluid ounce of cheapest item in store
|
||||
</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
|
||||
<dl class="details">
|
||||
<dt class="tag-source">Source:</dt>
|
||||
<dd class="tag-source">
|
||||
<ul class="dummy">
|
||||
<li>
|
||||
<a href="modules_makePin.js.html">modules/makePin.js</a>,
|
||||
<a href="modules_makePin.js.html#line18">line 18</a>
|
||||
</li>
|
||||
</ul>
|
||||
</dd>
|
||||
</dl>
|
||||
|
||||
<h5>Returns:</h5>
|
||||
|
||||
<div class="param-desc">- Created pin feature</div>
|
||||
|
||||
<dl>
|
||||
<dt>Type</dt>
|
||||
<dd>
|
||||
<span class="param-type">ol.Feature</span>
|
||||
</dd>
|
||||
</dl>
|
||||
</article>
|
||||
</section>
|
||||
</div>
|
||||
|
||||
<nav>
|
||||
<h2><a href="index.html">Home</a></h2>
|
||||
<h3>Modules</h3>
|
||||
<ul>
|
||||
<li>
|
||||
<a href="module-changeResolutionHandler.html"
|
||||
>changeResolutionHandler</a
|
||||
>
|
||||
</li>
|
||||
<li><a href="module-fetchPins.html">fetchPins</a></li>
|
||||
<li><a href="module-makePin.html">makePin</a></li>
|
||||
<li><a href="module-newButton.html">newButton</a></li>
|
||||
<li><a href="module-pointerMoveHandler.html">pointerMoveHandler</a></li>
|
||||
<li><a href="module-searchBar.html">searchBar</a></li>
|
||||
<li><a href="module-searchInputHander.html">searchInputHander</a></li>
|
||||
<li><a href="module-toLatLon.html">toLatLon</a></li>
|
||||
</ul>
|
||||
<h3>Classes</h3>
|
||||
<ul>
|
||||
<li><a href="module-newButton-ButtonControl.html">ButtonControl</a></li>
|
||||
</ul>
|
||||
<h3>Global</h3>
|
||||
<ul>
|
||||
<li><a href="global.html#disposePopover">disposePopover</a></li>
|
||||
<li><a href="global.html#map-onclick">map.onclick</a></li>
|
||||
<li><a href="global.html#passlocation">window.passLocation</a></li>
|
||||
<li><a href="global.html#placepin">window.placePin</a></li>
|
||||
<li><a href="global.html#map">map</a></li>
|
||||
<li><a href="global.html#pinLayer">pinLayer</a></li>
|
||||
<li><a href="global.html#pinSource">pinSource</a></li>
|
||||
<li><a href="global.html#popup">popup</a></li>
|
||||
</ul>
|
||||
</nav>
|
||||
|
||||
<br class="clear" />
|
||||
|
||||
<footer>
|
||||
Documentation generated by
|
||||
<a href="https://github.com/jsdoc/jsdoc">JSDoc 4.0.2</a> on Sun Dec 31
|
||||
2023 15:19:11 GMT-0800 (Pacific Standard Time)
|
||||
</footer>
|
||||
|
||||
<script>
|
||||
prettyPrint();
|
||||
</script>
|
||||
<script src="scripts/linenumber.js"></script>
|
||||
</body>
|
||||
</html>
|
||||
120
openlayers/docs/module-newButton-ButtonControl.html
Normal file
120
openlayers/docs/module-newButton-ButtonControl.html
Normal file
|
|
@ -0,0 +1,120 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<title>JSDoc: Class: ButtonControl</title>
|
||||
|
||||
<script src="scripts/prettify/prettify.js"></script>
|
||||
<script src="scripts/prettify/lang-css.js"></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
||||
<![endif]-->
|
||||
<link
|
||||
type="text/css"
|
||||
rel="stylesheet"
|
||||
href="styles/prettify-tomorrow.css"
|
||||
/>
|
||||
<link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css" />
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div id="main">
|
||||
<h1 class="page-title">Class: ButtonControl</h1>
|
||||
|
||||
<section>
|
||||
<header>
|
||||
<h2>
|
||||
<span class="attribs"><span class="type-signature"></span></span>
|
||||
<span class="ancestors"
|
||||
><a href="module-newButton.html">newButton</a>~</span
|
||||
>ButtonControl<span class="signature">()</span
|
||||
><span class="type-signature"></span>
|
||||
</h2>
|
||||
|
||||
<div class="class-description">
|
||||
Extends OpenLayers default Control class to provide button for pin
|
||||
creation process
|
||||
</div>
|
||||
</header>
|
||||
|
||||
<article>
|
||||
<div class="container-overview">
|
||||
<h2>Constructor</h2>
|
||||
|
||||
<h4 class="name" id="ButtonControl">
|
||||
<span class="type-signature"></span>new ButtonControl<span
|
||||
class="signature"
|
||||
>()</span
|
||||
><span class="type-signature"></span>
|
||||
</h4>
|
||||
|
||||
<dl class="details">
|
||||
<dt class="tag-source">Source:</dt>
|
||||
<dd class="tag-source">
|
||||
<ul class="dummy">
|
||||
<li>
|
||||
<a href="modules_newButton.js.html">modules/newButton.js</a
|
||||
>, <a href="modules_newButton.js.html#line10">line 10</a>
|
||||
</li>
|
||||
</ul>
|
||||
</dd>
|
||||
</dl>
|
||||
</div>
|
||||
|
||||
<h3 class="subsection-title">Extends</h3>
|
||||
|
||||
<ul>
|
||||
<li>ol.control.Control</li>
|
||||
</ul>
|
||||
</article>
|
||||
</section>
|
||||
</div>
|
||||
|
||||
<nav>
|
||||
<h2><a href="index.html">Home</a></h2>
|
||||
<h3>Modules</h3>
|
||||
<ul>
|
||||
<li>
|
||||
<a href="module-changeResolutionHandler.html"
|
||||
>changeResolutionHandler</a
|
||||
>
|
||||
</li>
|
||||
<li><a href="module-fetchPins.html">fetchPins</a></li>
|
||||
<li><a href="module-makePin.html">makePin</a></li>
|
||||
<li><a href="module-newButton.html">newButton</a></li>
|
||||
<li><a href="module-pointerMoveHandler.html">pointerMoveHandler</a></li>
|
||||
<li><a href="module-searchBar.html">searchBar</a></li>
|
||||
<li><a href="module-searchInputHander.html">searchInputHander</a></li>
|
||||
<li><a href="module-toLatLon.html">toLatLon</a></li>
|
||||
</ul>
|
||||
<h3>Classes</h3>
|
||||
<ul>
|
||||
<li><a href="module-newButton-ButtonControl.html">ButtonControl</a></li>
|
||||
</ul>
|
||||
<h3>Global</h3>
|
||||
<ul>
|
||||
<li><a href="global.html#disposePopover">disposePopover</a></li>
|
||||
<li><a href="global.html#map-onclick">map.onclick</a></li>
|
||||
<li><a href="global.html#passlocation">window.passLocation</a></li>
|
||||
<li><a href="global.html#placepin">window.placePin</a></li>
|
||||
<li><a href="global.html#map">map</a></li>
|
||||
<li><a href="global.html#pinLayer">pinLayer</a></li>
|
||||
<li><a href="global.html#pinSource">pinSource</a></li>
|
||||
<li><a href="global.html#popup">popup</a></li>
|
||||
</ul>
|
||||
</nav>
|
||||
|
||||
<br class="clear" />
|
||||
|
||||
<footer>
|
||||
Documentation generated by
|
||||
<a href="https://github.com/jsdoc/jsdoc">JSDoc 4.0.2</a> on Sun Dec 31
|
||||
2023 15:19:11 GMT-0800 (Pacific Standard Time)
|
||||
</footer>
|
||||
|
||||
<script>
|
||||
prettyPrint();
|
||||
</script>
|
||||
<script src="scripts/linenumber.js"></script>
|
||||
</body>
|
||||
</html>
|
||||
101
openlayers/docs/module-newButton.html
Normal file
101
openlayers/docs/module-newButton.html
Normal file
|
|
@ -0,0 +1,101 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<title>JSDoc: Module: newButton</title>
|
||||
|
||||
<script src="scripts/prettify/prettify.js"></script>
|
||||
<script src="scripts/prettify/lang-css.js"></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
||||
<![endif]-->
|
||||
<link
|
||||
type="text/css"
|
||||
rel="stylesheet"
|
||||
href="styles/prettify-tomorrow.css"
|
||||
/>
|
||||
<link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css" />
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div id="main">
|
||||
<h1 class="page-title">Module: newButton</h1>
|
||||
|
||||
<section>
|
||||
<header></header>
|
||||
|
||||
<article>
|
||||
<div class="container-overview">
|
||||
<dl class="details">
|
||||
<dt class="tag-source">Source:</dt>
|
||||
<dd class="tag-source">
|
||||
<ul class="dummy">
|
||||
<li>
|
||||
<a href="modules_newButton.js.html">modules/newButton.js</a
|
||||
>, <a href="modules_newButton.js.html#line3">line 3</a>
|
||||
</li>
|
||||
</ul>
|
||||
</dd>
|
||||
</dl>
|
||||
</div>
|
||||
|
||||
<h3 class="subsection-title">Classes</h3>
|
||||
|
||||
<dl>
|
||||
<dt>
|
||||
<a href="module-newButton-ButtonControl.html">ButtonControl</a>
|
||||
</dt>
|
||||
<dd></dd>
|
||||
</dl>
|
||||
</article>
|
||||
</section>
|
||||
</div>
|
||||
|
||||
<nav>
|
||||
<h2><a href="index.html">Home</a></h2>
|
||||
<h3>Modules</h3>
|
||||
<ul>
|
||||
<li>
|
||||
<a href="module-changeResolutionHandler.html"
|
||||
>changeResolutionHandler</a
|
||||
>
|
||||
</li>
|
||||
<li><a href="module-fetchPins.html">fetchPins</a></li>
|
||||
<li><a href="module-makePin.html">makePin</a></li>
|
||||
<li><a href="module-newButton.html">newButton</a></li>
|
||||
<li><a href="module-pointerMoveHandler.html">pointerMoveHandler</a></li>
|
||||
<li><a href="module-searchBar.html">searchBar</a></li>
|
||||
<li><a href="module-searchInputHander.html">searchInputHander</a></li>
|
||||
<li><a href="module-toLatLon.html">toLatLon</a></li>
|
||||
</ul>
|
||||
<h3>Classes</h3>
|
||||
<ul>
|
||||
<li><a href="module-newButton-ButtonControl.html">ButtonControl</a></li>
|
||||
</ul>
|
||||
<h3>Global</h3>
|
||||
<ul>
|
||||
<li><a href="global.html#disposePopover">disposePopover</a></li>
|
||||
<li><a href="global.html#map-onclick">map.onclick</a></li>
|
||||
<li><a href="global.html#passlocation">window.passLocation</a></li>
|
||||
<li><a href="global.html#placepin">window.placePin</a></li>
|
||||
<li><a href="global.html#map">map</a></li>
|
||||
<li><a href="global.html#pinLayer">pinLayer</a></li>
|
||||
<li><a href="global.html#pinSource">pinSource</a></li>
|
||||
<li><a href="global.html#popup">popup</a></li>
|
||||
</ul>
|
||||
</nav>
|
||||
|
||||
<br class="clear" />
|
||||
|
||||
<footer>
|
||||
Documentation generated by
|
||||
<a href="https://github.com/jsdoc/jsdoc">JSDoc 4.0.2</a> on Sun Dec 31
|
||||
2023 15:19:11 GMT-0800 (Pacific Standard Time)
|
||||
</footer>
|
||||
|
||||
<script>
|
||||
prettyPrint();
|
||||
</script>
|
||||
<script src="scripts/linenumber.js"></script>
|
||||
</body>
|
||||
</html>
|
||||
161
openlayers/docs/module-pointerMoveHandler.html
Normal file
161
openlayers/docs/module-pointerMoveHandler.html
Normal file
|
|
@ -0,0 +1,161 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<title>JSDoc: Module: pointerMoveHandler</title>
|
||||
|
||||
<script src="scripts/prettify/prettify.js"></script>
|
||||
<script src="scripts/prettify/lang-css.js"></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
||||
<![endif]-->
|
||||
<link
|
||||
type="text/css"
|
||||
rel="stylesheet"
|
||||
href="styles/prettify-tomorrow.css"
|
||||
/>
|
||||
<link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css" />
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div id="main">
|
||||
<h1 class="page-title">Module: pointerMoveHandler</h1>
|
||||
|
||||
<section>
|
||||
<header></header>
|
||||
|
||||
<article>
|
||||
<div class="container-overview">
|
||||
<dl class="details">
|
||||
<dt class="tag-source">Source:</dt>
|
||||
<dd class="tag-source">
|
||||
<ul class="dummy">
|
||||
<li>
|
||||
<a href="modules_pointerMoveHandler.js.html"
|
||||
>modules/pointerMoveHandler.js</a
|
||||
>,
|
||||
<a href="modules_pointerMoveHandler.js.html#line1"
|
||||
>line 1</a
|
||||
>
|
||||
</li>
|
||||
</ul>
|
||||
</dd>
|
||||
</dl>
|
||||
</div>
|
||||
|
||||
<h3 class="subsection-title">Methods</h3>
|
||||
|
||||
<h4 class="name" id="~pointerMoveHandler">
|
||||
<span class="type-signature">(inner) </span>pointerMoveHandler<span
|
||||
class="signature"
|
||||
>(event, map)</span
|
||||
><span class="type-signature"></span>
|
||||
</h4>
|
||||
|
||||
<div class="description">
|
||||
Changes cursor depending on if user is hovering over a pin
|
||||
</div>
|
||||
|
||||
<h5>Parameters:</h5>
|
||||
|
||||
<table class="params">
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Name</th>
|
||||
|
||||
<th>Type</th>
|
||||
|
||||
<th class="last">Description</th>
|
||||
</tr>
|
||||
</thead>
|
||||
|
||||
<tbody>
|
||||
<tr>
|
||||
<td class="name"><code>event</code></td>
|
||||
|
||||
<td class="type">
|
||||
<span class="param-type">Event</span>
|
||||
</td>
|
||||
|
||||
<td class="description last">Pointer move event</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td class="name"><code>map</code></td>
|
||||
|
||||
<td class="type">
|
||||
<span class="param-type">ol.Map</span>
|
||||
</td>
|
||||
|
||||
<td class="description last">OpenLayers map</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
|
||||
<dl class="details">
|
||||
<dt class="tag-source">Source:</dt>
|
||||
<dd class="tag-source">
|
||||
<ul class="dummy">
|
||||
<li>
|
||||
<a href="modules_pointerMoveHandler.js.html"
|
||||
>modules/pointerMoveHandler.js</a
|
||||
>,
|
||||
<a href="modules_pointerMoveHandler.js.html#line10"
|
||||
>line 10</a
|
||||
>
|
||||
</li>
|
||||
</ul>
|
||||
</dd>
|
||||
</dl>
|
||||
</article>
|
||||
</section>
|
||||
</div>
|
||||
|
||||
<nav>
|
||||
<h2><a href="index.html">Home</a></h2>
|
||||
<h3>Modules</h3>
|
||||
<ul>
|
||||
<li>
|
||||
<a href="module-changeResolutionHandler.html"
|
||||
>changeResolutionHandler</a
|
||||
>
|
||||
</li>
|
||||
<li><a href="module-fetchPins.html">fetchPins</a></li>
|
||||
<li><a href="module-makePin.html">makePin</a></li>
|
||||
<li><a href="module-newButton.html">newButton</a></li>
|
||||
<li><a href="module-pointerMoveHandler.html">pointerMoveHandler</a></li>
|
||||
<li><a href="module-searchBar.html">searchBar</a></li>
|
||||
<li><a href="module-searchInputHander.html">searchInputHander</a></li>
|
||||
<li><a href="module-toLatLon.html">toLatLon</a></li>
|
||||
</ul>
|
||||
<h3>Classes</h3>
|
||||
<ul>
|
||||
<li><a href="module-newButton-ButtonControl.html">ButtonControl</a></li>
|
||||
</ul>
|
||||
<h3>Global</h3>
|
||||
<ul>
|
||||
<li><a href="global.html#disposePopover">disposePopover</a></li>
|
||||
<li><a href="global.html#map-onclick">map.onclick</a></li>
|
||||
<li><a href="global.html#passlocation">window.passLocation</a></li>
|
||||
<li><a href="global.html#placepin">window.placePin</a></li>
|
||||
<li><a href="global.html#map">map</a></li>
|
||||
<li><a href="global.html#pinLayer">pinLayer</a></li>
|
||||
<li><a href="global.html#pinSource">pinSource</a></li>
|
||||
<li><a href="global.html#popup">popup</a></li>
|
||||
</ul>
|
||||
</nav>
|
||||
|
||||
<br class="clear" />
|
||||
|
||||
<footer>
|
||||
Documentation generated by
|
||||
<a href="https://github.com/jsdoc/jsdoc">JSDoc 4.0.2</a> on Sun Dec 31
|
||||
2023 15:19:11 GMT-0800 (Pacific Standard Time)
|
||||
</footer>
|
||||
|
||||
<script>
|
||||
prettyPrint();
|
||||
</script>
|
||||
<script src="scripts/linenumber.js"></script>
|
||||
</body>
|
||||
</html>
|
||||
123
openlayers/docs/module-searchBar.html
Normal file
123
openlayers/docs/module-searchBar.html
Normal file
|
|
@ -0,0 +1,123 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<title>JSDoc: Module: searchBar</title>
|
||||
|
||||
<script src="scripts/prettify/prettify.js"></script>
|
||||
<script src="scripts/prettify/lang-css.js"></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
||||
<![endif]-->
|
||||
<link
|
||||
type="text/css"
|
||||
rel="stylesheet"
|
||||
href="styles/prettify-tomorrow.css"
|
||||
/>
|
||||
<link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css" />
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div id="main">
|
||||
<h1 class="page-title">Module: searchBar</h1>
|
||||
|
||||
<section>
|
||||
<header></header>
|
||||
|
||||
<article>
|
||||
<div class="container-overview">
|
||||
<dl class="details">
|
||||
<dt class="tag-source">Source:</dt>
|
||||
<dd class="tag-source">
|
||||
<ul class="dummy">
|
||||
<li>
|
||||
<a href="modules_searchBar.js.html">modules/searchBar.js</a
|
||||
>, <a href="modules_searchBar.js.html#line3">line 3</a>
|
||||
</li>
|
||||
</ul>
|
||||
</dd>
|
||||
</dl>
|
||||
</div>
|
||||
|
||||
<h3 class="subsection-title">Members</h3>
|
||||
|
||||
<h4 class="name" id="~searchBar">
|
||||
<span class="type-signature">(inner, constant) </span>searchBar<span
|
||||
class="type-signature"
|
||||
>
|
||||
:ol-ext.control.Search</span
|
||||
>
|
||||
</h4>
|
||||
|
||||
<div class="description">Search bar component</div>
|
||||
|
||||
<h5>Type:</h5>
|
||||
<ul>
|
||||
<li>
|
||||
<span class="param-type">ol-ext.control.Search</span>
|
||||
</li>
|
||||
</ul>
|
||||
|
||||
<dl class="details">
|
||||
<dt class="tag-source">Source:</dt>
|
||||
<dd class="tag-source">
|
||||
<ul class="dummy">
|
||||
<li>
|
||||
<a href="modules_searchBar.js.html">modules/searchBar.js</a>,
|
||||
<a href="modules_searchBar.js.html#line10">line 10</a>
|
||||
</li>
|
||||
</ul>
|
||||
</dd>
|
||||
</dl>
|
||||
</article>
|
||||
</section>
|
||||
</div>
|
||||
|
||||
<nav>
|
||||
<h2><a href="index.html">Home</a></h2>
|
||||
<h3>Modules</h3>
|
||||
<ul>
|
||||
<li>
|
||||
<a href="module-changeResolutionHandler.html"
|
||||
>changeResolutionHandler</a
|
||||
>
|
||||
</li>
|
||||
<li><a href="module-fetchPins.html">fetchPins</a></li>
|
||||
<li><a href="module-makePin.html">makePin</a></li>
|
||||
<li><a href="module-newButton.html">newButton</a></li>
|
||||
<li><a href="module-pointerMoveHandler.html">pointerMoveHandler</a></li>
|
||||
<li><a href="module-searchBar.html">searchBar</a></li>
|
||||
<li><a href="module-searchInputHander.html">searchInputHander</a></li>
|
||||
<li><a href="module-toLatLon.html">toLatLon</a></li>
|
||||
</ul>
|
||||
<h3>Classes</h3>
|
||||
<ul>
|
||||
<li><a href="module-newButton-ButtonControl.html">ButtonControl</a></li>
|
||||
</ul>
|
||||
<h3>Global</h3>
|
||||
<ul>
|
||||
<li><a href="global.html#disposePopover">disposePopover</a></li>
|
||||
<li><a href="global.html#map-onclick">map.onclick</a></li>
|
||||
<li><a href="global.html#passlocation">window.passLocation</a></li>
|
||||
<li><a href="global.html#placepin">window.placePin</a></li>
|
||||
<li><a href="global.html#map">map</a></li>
|
||||
<li><a href="global.html#pinLayer">pinLayer</a></li>
|
||||
<li><a href="global.html#pinSource">pinSource</a></li>
|
||||
<li><a href="global.html#popup">popup</a></li>
|
||||
</ul>
|
||||
</nav>
|
||||
|
||||
<br class="clear" />
|
||||
|
||||
<footer>
|
||||
Documentation generated by
|
||||
<a href="https://github.com/jsdoc/jsdoc">JSDoc 4.0.2</a> on Sun Dec 31
|
||||
2023 15:19:11 GMT-0800 (Pacific Standard Time)
|
||||
</footer>
|
||||
|
||||
<script>
|
||||
prettyPrint();
|
||||
</script>
|
||||
<script src="scripts/linenumber.js"></script>
|
||||
</body>
|
||||
</html>
|
||||
163
openlayers/docs/module-searchInputHander.html
Normal file
163
openlayers/docs/module-searchInputHander.html
Normal file
|
|
@ -0,0 +1,163 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<title>JSDoc: Module: searchInputHander</title>
|
||||
|
||||
<script src="scripts/prettify/prettify.js"></script>
|
||||
<script src="scripts/prettify/lang-css.js"></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
||||
<![endif]-->
|
||||
<link
|
||||
type="text/css"
|
||||
rel="stylesheet"
|
||||
href="styles/prettify-tomorrow.css"
|
||||
/>
|
||||
<link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css" />
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div id="main">
|
||||
<h1 class="page-title">Module: searchInputHander</h1>
|
||||
|
||||
<section>
|
||||
<header></header>
|
||||
|
||||
<article>
|
||||
<div class="container-overview">
|
||||
<dl class="details">
|
||||
<dt class="tag-source">Source:</dt>
|
||||
<dd class="tag-source">
|
||||
<ul class="dummy">
|
||||
<li>
|
||||
<a href="modules_searchInputHandler.js.html"
|
||||
>modules/searchInputHandler.js</a
|
||||
>,
|
||||
<a href="modules_searchInputHandler.js.html#line1"
|
||||
>line 1</a
|
||||
>
|
||||
</li>
|
||||
</ul>
|
||||
</dd>
|
||||
</dl>
|
||||
</div>
|
||||
|
||||
<h3 class="subsection-title">Methods</h3>
|
||||
|
||||
<h4 class="name" id="~searchInputHander">
|
||||
<span class="type-signature">(inner) </span>searchInputHander<span
|
||||
class="signature"
|
||||
>(event, map)</span
|
||||
><span class="type-signature"></span>
|
||||
</h4>
|
||||
|
||||
<div class="description">
|
||||
Handles user pressing Enter key in search input field by sending
|
||||
current coordinates and contents of field to React Native for
|
||||
processing
|
||||
</div>
|
||||
|
||||
<h5>Parameters:</h5>
|
||||
|
||||
<table class="params">
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Name</th>
|
||||
|
||||
<th>Type</th>
|
||||
|
||||
<th class="last">Description</th>
|
||||
</tr>
|
||||
</thead>
|
||||
|
||||
<tbody>
|
||||
<tr>
|
||||
<td class="name"><code>event</code></td>
|
||||
|
||||
<td class="type">
|
||||
<span class="param-type">Event</span>
|
||||
</td>
|
||||
|
||||
<td class="description last">
|
||||
Keydown event in search input field
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td class="name"><code>map</code></td>
|
||||
|
||||
<td class="type">
|
||||
<span class="param-type">ol.Map</span>
|
||||
</td>
|
||||
|
||||
<td class="description last">OpenLayers map</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
|
||||
<dl class="details">
|
||||
<dt class="tag-source">Source:</dt>
|
||||
<dd class="tag-source">
|
||||
<ul class="dummy">
|
||||
<li>
|
||||
<a href="modules_searchInputHandler.js.html"
|
||||
>modules/searchInputHandler.js</a
|
||||
>,
|
||||
<a href="modules_searchInputHandler.js.html#line9">line 9</a>
|
||||
</li>
|
||||
</ul>
|
||||
</dd>
|
||||
</dl>
|
||||
</article>
|
||||
</section>
|
||||
</div>
|
||||
|
||||
<nav>
|
||||
<h2><a href="index.html">Home</a></h2>
|
||||
<h3>Modules</h3>
|
||||
<ul>
|
||||
<li>
|
||||
<a href="module-changeResolutionHandler.html"
|
||||
>changeResolutionHandler</a
|
||||
>
|
||||
</li>
|
||||
<li><a href="module-fetchPins.html">fetchPins</a></li>
|
||||
<li><a href="module-makePin.html">makePin</a></li>
|
||||
<li><a href="module-newButton.html">newButton</a></li>
|
||||
<li><a href="module-pointerMoveHandler.html">pointerMoveHandler</a></li>
|
||||
<li><a href="module-searchBar.html">searchBar</a></li>
|
||||
<li><a href="module-searchInputHander.html">searchInputHander</a></li>
|
||||
<li><a href="module-toLatLon.html">toLatLon</a></li>
|
||||
</ul>
|
||||
<h3>Classes</h3>
|
||||
<ul>
|
||||
<li><a href="module-newButton-ButtonControl.html">ButtonControl</a></li>
|
||||
</ul>
|
||||
<h3>Global</h3>
|
||||
<ul>
|
||||
<li><a href="global.html#disposePopover">disposePopover</a></li>
|
||||
<li><a href="global.html#map-onclick">map.onclick</a></li>
|
||||
<li><a href="global.html#passlocation">window.passLocation</a></li>
|
||||
<li><a href="global.html#placepin">window.placePin</a></li>
|
||||
<li><a href="global.html#map">map</a></li>
|
||||
<li><a href="global.html#pinLayer">pinLayer</a></li>
|
||||
<li><a href="global.html#pinSource">pinSource</a></li>
|
||||
<li><a href="global.html#popup">popup</a></li>
|
||||
</ul>
|
||||
</nav>
|
||||
|
||||
<br class="clear" />
|
||||
|
||||
<footer>
|
||||
Documentation generated by
|
||||
<a href="https://github.com/jsdoc/jsdoc">JSDoc 4.0.2</a> on Sun Dec 31
|
||||
2023 15:19:11 GMT-0800 (Pacific Standard Time)
|
||||
</footer>
|
||||
|
||||
<script>
|
||||
prettyPrint();
|
||||
</script>
|
||||
<script src="scripts/linenumber.js"></script>
|
||||
</body>
|
||||
</html>
|
||||
187
openlayers/docs/module-toLatLon.html
Normal file
187
openlayers/docs/module-toLatLon.html
Normal file
|
|
@ -0,0 +1,187 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<title>JSDoc: Module: toLatLon</title>
|
||||
|
||||
<script src="scripts/prettify/prettify.js"></script>
|
||||
<script src="scripts/prettify/lang-css.js"></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
||||
<![endif]-->
|
||||
<link
|
||||
type="text/css"
|
||||
rel="stylesheet"
|
||||
href="styles/prettify-tomorrow.css"
|
||||
/>
|
||||
<link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css" />
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div id="main">
|
||||
<h1 class="page-title">Module: toLatLon</h1>
|
||||
|
||||
<section>
|
||||
<header></header>
|
||||
|
||||
<article>
|
||||
<div class="container-overview">
|
||||
<dl class="details">
|
||||
<dt class="tag-source">Source:</dt>
|
||||
<dd class="tag-source">
|
||||
<ul class="dummy">
|
||||
<li>
|
||||
<a href="modules_toLatLon.js.html">modules/toLatLon.js</a>,
|
||||
<a href="modules_toLatLon.js.html#line5">line 5</a>
|
||||
</li>
|
||||
</ul>
|
||||
</dd>
|
||||
</dl>
|
||||
</div>
|
||||
|
||||
<h3 class="subsection-title">Methods</h3>
|
||||
|
||||
<h4 class="name" id="~toLatLon">
|
||||
<span class="type-signature">(inner) </span>toLatLon<span
|
||||
class="signature"
|
||||
>(easting, northing, zone, zoneLetter)</span
|
||||
><span class="type-signature"> → {Array}</span>
|
||||
</h4>
|
||||
|
||||
<div class="description">
|
||||
Converts UTM coordinates in database store records to
|
||||
latitude/longitude for use with the map
|
||||
</div>
|
||||
|
||||
<h5>Parameters:</h5>
|
||||
|
||||
<table class="params">
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Name</th>
|
||||
|
||||
<th>Type</th>
|
||||
|
||||
<th class="last">Description</th>
|
||||
</tr>
|
||||
</thead>
|
||||
|
||||
<tbody>
|
||||
<tr>
|
||||
<td class="name"><code>easting</code></td>
|
||||
|
||||
<td class="type">
|
||||
<span class="param-type">number</span>
|
||||
</td>
|
||||
|
||||
<td class="description last">UTM easting of store</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td class="name"><code>northing</code></td>
|
||||
|
||||
<td class="type">
|
||||
<span class="param-type">number</span>
|
||||
</td>
|
||||
|
||||
<td class="description last">UTM northing of store</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td class="name"><code>zone</code></td>
|
||||
|
||||
<td class="type">
|
||||
<span class="param-type">string</span>
|
||||
</td>
|
||||
|
||||
<td class="description last">UTM zone of store</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td class="name"><code>zoneLetter</code></td>
|
||||
|
||||
<td class="type">
|
||||
<span class="param-type">string</span>
|
||||
</td>
|
||||
|
||||
<td class="description last">UTM zone letter of store</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
|
||||
<dl class="details">
|
||||
<dt class="tag-source">Source:</dt>
|
||||
<dd class="tag-source">
|
||||
<ul class="dummy">
|
||||
<li>
|
||||
<a href="modules_toLatLon.js.html">modules/toLatLon.js</a>,
|
||||
<a href="modules_toLatLon.js.html#line16">line 16</a>
|
||||
</li>
|
||||
</ul>
|
||||
</dd>
|
||||
</dl>
|
||||
|
||||
<h5>Returns:</h5>
|
||||
|
||||
<div class="param-desc">
|
||||
- Array of coordinates as [latitude, longitude]
|
||||
</div>
|
||||
|
||||
<dl>
|
||||
<dt>Type</dt>
|
||||
<dd>
|
||||
<span class="param-type">Array</span>
|
||||
</dd>
|
||||
</dl>
|
||||
</article>
|
||||
</section>
|
||||
</div>
|
||||
|
||||
<nav>
|
||||
<h2><a href="index.html">Home</a></h2>
|
||||
<h3>Modules</h3>
|
||||
<ul>
|
||||
<li>
|
||||
<a href="module-changeResolutionHandler.html"
|
||||
>changeResolutionHandler</a
|
||||
>
|
||||
</li>
|
||||
<li><a href="module-fetchPins.html">fetchPins</a></li>
|
||||
<li><a href="module-makePin.html">makePin</a></li>
|
||||
<li><a href="module-newButton.html">newButton</a></li>
|
||||
<li><a href="module-pointerMoveHandler.html">pointerMoveHandler</a></li>
|
||||
<li><a href="module-searchBar.html">searchBar</a></li>
|
||||
<li><a href="module-searchInputHander.html">searchInputHander</a></li>
|
||||
<li><a href="module-toLatLon.html">toLatLon</a></li>
|
||||
</ul>
|
||||
<h3>Classes</h3>
|
||||
<ul>
|
||||
<li><a href="module-newButton-ButtonControl.html">ButtonControl</a></li>
|
||||
</ul>
|
||||
<h3>Global</h3>
|
||||
<ul>
|
||||
<li><a href="global.html#disposePopover">disposePopover</a></li>
|
||||
<li><a href="global.html#map-onclick">map.onclick</a></li>
|
||||
<li><a href="global.html#passlocation">window.passLocation</a></li>
|
||||
<li><a href="global.html#placepin">window.placePin</a></li>
|
||||
<li><a href="global.html#map">map</a></li>
|
||||
<li><a href="global.html#pinLayer">pinLayer</a></li>
|
||||
<li><a href="global.html#pinSource">pinSource</a></li>
|
||||
<li><a href="global.html#popup">popup</a></li>
|
||||
</ul>
|
||||
</nav>
|
||||
|
||||
<br class="clear" />
|
||||
|
||||
<footer>
|
||||
Documentation generated by
|
||||
<a href="https://github.com/jsdoc/jsdoc">JSDoc 4.0.2</a> on Sun Dec 31
|
||||
2023 15:19:11 GMT-0800 (Pacific Standard Time)
|
||||
</footer>
|
||||
|
||||
<script>
|
||||
prettyPrint();
|
||||
</script>
|
||||
<script src="scripts/linenumber.js"></script>
|
||||
</body>
|
||||
</html>
|
||||
104
openlayers/docs/modules_changeResolutionHandler.js.html
Normal file
104
openlayers/docs/modules_changeResolutionHandler.js.html
Normal file
|
|
@ -0,0 +1,104 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<title>JSDoc: Source: modules/changeResolutionHandler.js</title>
|
||||
|
||||
<script src="scripts/prettify/prettify.js"></script>
|
||||
<script src="scripts/prettify/lang-css.js"></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
||||
<![endif]-->
|
||||
<link
|
||||
type="text/css"
|
||||
rel="stylesheet"
|
||||
href="styles/prettify-tomorrow.css"
|
||||
/>
|
||||
<link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css" />
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div id="main">
|
||||
<h1 class="page-title">Source: modules/changeResolutionHandler.js</h1>
|
||||
|
||||
<section>
|
||||
<article>
|
||||
<pre class="prettyprint source linenums"><code>/**
|
||||
* @module changeResolutionHandler
|
||||
*/
|
||||
|
||||
/** Maximum zoom level to show pins
|
||||
* @constant {number}
|
||||
* @default 5
|
||||
*/
|
||||
const CUTOFF = 5;
|
||||
|
||||
/** Adds or removes pin vector layer depending on zoom level
|
||||
* @param {boolean} pinning - Boolean to toggle between new pin creation and viewing existing pins. If this is true, existing pins are not visible.
|
||||
* @param {ol.Map} map - OpenLayers map to center
|
||||
* @param {ol.layer.Vector} pinLayer - OpenLayers vector layer for pins
|
||||
*/
|
||||
const changeResolutionHandler = (pinning, map, pinLayer) => {
|
||||
map.getView().getZoom() < CUTOFF
|
||||
? map.getLayers().removeAt(1)
|
||||
: (() => {
|
||||
if (map.getLayers().getLength() === 1) {
|
||||
if (!pinning) map.getLayers().extend([pinLayer]);
|
||||
}
|
||||
})();
|
||||
};
|
||||
|
||||
export default changeResolutionHandler;
|
||||
</code></pre>
|
||||
</article>
|
||||
</section>
|
||||
</div>
|
||||
|
||||
<nav>
|
||||
<h2><a href="index.html">Home</a></h2>
|
||||
<h3>Modules</h3>
|
||||
<ul>
|
||||
<li>
|
||||
<a href="module-changeResolutionHandler.html"
|
||||
>changeResolutionHandler</a
|
||||
>
|
||||
</li>
|
||||
<li><a href="module-fetchPins.html">fetchPins</a></li>
|
||||
<li><a href="module-makePin.html">makePin</a></li>
|
||||
<li><a href="module-newButton.html">newButton</a></li>
|
||||
<li><a href="module-pointerMoveHandler.html">pointerMoveHandler</a></li>
|
||||
<li><a href="module-searchBar.html">searchBar</a></li>
|
||||
<li><a href="module-searchInputHander.html">searchInputHander</a></li>
|
||||
<li><a href="module-toLatLon.html">toLatLon</a></li>
|
||||
</ul>
|
||||
<h3>Classes</h3>
|
||||
<ul>
|
||||
<li><a href="module-newButton-ButtonControl.html">ButtonControl</a></li>
|
||||
</ul>
|
||||
<h3>Global</h3>
|
||||
<ul>
|
||||
<li><a href="global.html#disposePopover">disposePopover</a></li>
|
||||
<li><a href="global.html#map-onclick">map.onclick</a></li>
|
||||
<li><a href="global.html#passlocation">window.passLocation</a></li>
|
||||
<li><a href="global.html#placepin">window.placePin</a></li>
|
||||
<li><a href="global.html#map">map</a></li>
|
||||
<li><a href="global.html#pinLayer">pinLayer</a></li>
|
||||
<li><a href="global.html#pinSource">pinSource</a></li>
|
||||
<li><a href="global.html#popup">popup</a></li>
|
||||
</ul>
|
||||
</nav>
|
||||
|
||||
<br class="clear" />
|
||||
|
||||
<footer>
|
||||
Documentation generated by
|
||||
<a href="https://github.com/jsdoc/jsdoc">JSDoc 4.0.2</a> on Sun Dec 31
|
||||
2023 15:19:11 GMT-0800 (Pacific Standard Time)
|
||||
</footer>
|
||||
|
||||
<script>
|
||||
prettyPrint();
|
||||
</script>
|
||||
<script src="scripts/linenumber.js"></script>
|
||||
</body>
|
||||
</html>
|
||||
116
openlayers/docs/modules_fetchPins.js.html
Normal file
116
openlayers/docs/modules_fetchPins.js.html
Normal file
|
|
@ -0,0 +1,116 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<title>JSDoc: Source: modules/fetchPins.js</title>
|
||||
|
||||
<script src="scripts/prettify/prettify.js"></script>
|
||||
<script src="scripts/prettify/lang-css.js"></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
||||
<![endif]-->
|
||||
<link
|
||||
type="text/css"
|
||||
rel="stylesheet"
|
||||
href="styles/prettify-tomorrow.css"
|
||||
/>
|
||||
<link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css" />
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div id="main">
|
||||
<h1 class="page-title">Source: modules/fetchPins.js</h1>
|
||||
|
||||
<section>
|
||||
<article>
|
||||
<pre
|
||||
class="prettyprint source linenums"
|
||||
><code>import makePin from "./makePin.js";
|
||||
import toLatLon from "./toLatLon.js";
|
||||
|
||||
/**
|
||||
* @module fetchPins
|
||||
*/
|
||||
|
||||
/** Fetches pin records from database and adds pin features to pin vector source layer
|
||||
* @async
|
||||
* @param {ol.source.Vector} pinSource - The relevant vector source layer to add pin features to
|
||||
*/
|
||||
const fetchPins = async (pinSource) => {
|
||||
const res = await fetch(import.meta.env.VITE_BACKEND_URL);
|
||||
const pinRecords = await res.json();
|
||||
|
||||
pinRecords.forEach((pinRecord) => {
|
||||
const [latitude, longitude] = toLatLon(
|
||||
pinRecord.easting,
|
||||
pinRecord.northing,
|
||||
pinRecord.zone,
|
||||
pinRecord.zoneLetter
|
||||
);
|
||||
|
||||
const pin = makePin(
|
||||
longitude.toFixed(5),
|
||||
latitude.toFixed(5),
|
||||
pinRecord.name,
|
||||
pinRecord.cheapestItem,
|
||||
pinRecord.cheapestFloz
|
||||
);
|
||||
|
||||
pinSource.addFeature(pin);
|
||||
});
|
||||
};
|
||||
|
||||
export default fetchPins;
|
||||
</code></pre>
|
||||
</article>
|
||||
</section>
|
||||
</div>
|
||||
|
||||
<nav>
|
||||
<h2><a href="index.html">Home</a></h2>
|
||||
<h3>Modules</h3>
|
||||
<ul>
|
||||
<li>
|
||||
<a href="module-changeResolutionHandler.html"
|
||||
>changeResolutionHandler</a
|
||||
>
|
||||
</li>
|
||||
<li><a href="module-fetchPins.html">fetchPins</a></li>
|
||||
<li><a href="module-makePin.html">makePin</a></li>
|
||||
<li><a href="module-newButton.html">newButton</a></li>
|
||||
<li><a href="module-pointerMoveHandler.html">pointerMoveHandler</a></li>
|
||||
<li><a href="module-searchBar.html">searchBar</a></li>
|
||||
<li><a href="module-searchInputHander.html">searchInputHander</a></li>
|
||||
<li><a href="module-toLatLon.html">toLatLon</a></li>
|
||||
</ul>
|
||||
<h3>Classes</h3>
|
||||
<ul>
|
||||
<li><a href="module-newButton-ButtonControl.html">ButtonControl</a></li>
|
||||
</ul>
|
||||
<h3>Global</h3>
|
||||
<ul>
|
||||
<li><a href="global.html#disposePopover">disposePopover</a></li>
|
||||
<li><a href="global.html#map-onclick">map.onclick</a></li>
|
||||
<li><a href="global.html#passlocation">window.passLocation</a></li>
|
||||
<li><a href="global.html#placepin">window.placePin</a></li>
|
||||
<li><a href="global.html#map">map</a></li>
|
||||
<li><a href="global.html#pinLayer">pinLayer</a></li>
|
||||
<li><a href="global.html#pinSource">pinSource</a></li>
|
||||
<li><a href="global.html#popup">popup</a></li>
|
||||
</ul>
|
||||
</nav>
|
||||
|
||||
<br class="clear" />
|
||||
|
||||
<footer>
|
||||
Documentation generated by
|
||||
<a href="https://github.com/jsdoc/jsdoc">JSDoc 4.0.2</a> on Sun Dec 31
|
||||
2023 15:19:11 GMT-0800 (Pacific Standard Time)
|
||||
</footer>
|
||||
|
||||
<script>
|
||||
prettyPrint();
|
||||
</script>
|
||||
<script src="scripts/linenumber.js"></script>
|
||||
</body>
|
||||
</html>
|
||||
126
openlayers/docs/modules_makePin.js.html
Normal file
126
openlayers/docs/modules_makePin.js.html
Normal file
|
|
@ -0,0 +1,126 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<title>JSDoc: Source: modules/makePin.js</title>
|
||||
|
||||
<script src="scripts/prettify/prettify.js"></script>
|
||||
<script src="scripts/prettify/lang-css.js"></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
||||
<![endif]-->
|
||||
<link
|
||||
type="text/css"
|
||||
rel="stylesheet"
|
||||
href="styles/prettify-tomorrow.css"
|
||||
/>
|
||||
<link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css" />
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div id="main">
|
||||
<h1 class="page-title">Source: modules/makePin.js</h1>
|
||||
|
||||
<section>
|
||||
<article>
|
||||
<pre class="prettyprint source linenums"><code>// creates pins
|
||||
import { Feature } from "ol";
|
||||
import { Icon, Style } from "ol/style";
|
||||
import Point from "ol/geom/Point.js";
|
||||
|
||||
/**
|
||||
* @module makePin
|
||||
*/
|
||||
|
||||
/** Makes pin feature from arguments
|
||||
* @param {number} lon - Longitude
|
||||
* @param {number} lat - Latitude
|
||||
* @param {string} storeName - Name of store
|
||||
* @param {string} cheapest - Cheapest item in store
|
||||
* @param {number} flozPrice - Price per fluid ounce of cheapest item in store
|
||||
* @returns {ol.Feature} - Created pin feature
|
||||
*/
|
||||
const makePin = (lon, lat, storeName, cheapest, flozPrice) => {
|
||||
// define pin graphics (since this is all inline)
|
||||
const pinSVG = `<svg width="32px" height="32px" viewBox="-0.12 -0.12 12.24 12.24" enable-background="new 0 0 12 12" id="Слой_1" version="1.1" xml:space="preserve" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" fill="#000000" stroke="#000000" stroke-width="0.12000000000000002"><g id="SVGRepo_bgCarrier" stroke-width="0"></g><g id="SVGRepo_tracerCarrier" stroke-linecap="round" stroke-linejoin="round"></g><g id="SVGRepo_iconCarrier"><path d="M6,0C3.2385864,0,1,2.2385864,1,5s2.5,5,5,7c2.5-2,5-4.2385864,5-7S8.7614136,0,6,0z M6,7 C4.8954468,7,4,6.1045532,4,5s0.8954468-2,2-2s2,0.8954468,2,2S7.1045532,7,6,7z" fill="#ed333b"></path></g></svg>`;
|
||||
const pinSVGBlob = new Blob([pinSVG], {
|
||||
type: "image/svg+xml",
|
||||
});
|
||||
const pinImageURL = URL.createObjectURL(pinSVGBlob);
|
||||
|
||||
// define style for all pins
|
||||
const pinStyle = new Style({
|
||||
image: new Icon({
|
||||
src: pinImageURL,
|
||||
anchor: [0.5, 1],
|
||||
}),
|
||||
});
|
||||
|
||||
// create pin as feature
|
||||
const pin = new Feature({
|
||||
geometry: new Point([lon, lat]),
|
||||
store: storeName,
|
||||
cheapestItem: cheapest,
|
||||
pricePerOz: flozPrice,
|
||||
});
|
||||
|
||||
// set style for pin
|
||||
pin.setStyle(pinStyle);
|
||||
|
||||
return pin;
|
||||
};
|
||||
|
||||
export default makePin;
|
||||
</code></pre>
|
||||
</article>
|
||||
</section>
|
||||
</div>
|
||||
|
||||
<nav>
|
||||
<h2><a href="index.html">Home</a></h2>
|
||||
<h3>Modules</h3>
|
||||
<ul>
|
||||
<li>
|
||||
<a href="module-changeResolutionHandler.html"
|
||||
>changeResolutionHandler</a
|
||||
>
|
||||
</li>
|
||||
<li><a href="module-fetchPins.html">fetchPins</a></li>
|
||||
<li><a href="module-makePin.html">makePin</a></li>
|
||||
<li><a href="module-newButton.html">newButton</a></li>
|
||||
<li><a href="module-pointerMoveHandler.html">pointerMoveHandler</a></li>
|
||||
<li><a href="module-searchBar.html">searchBar</a></li>
|
||||
<li><a href="module-searchInputHander.html">searchInputHander</a></li>
|
||||
<li><a href="module-toLatLon.html">toLatLon</a></li>
|
||||
</ul>
|
||||
<h3>Classes</h3>
|
||||
<ul>
|
||||
<li><a href="module-newButton-ButtonControl.html">ButtonControl</a></li>
|
||||
</ul>
|
||||
<h3>Global</h3>
|
||||
<ul>
|
||||
<li><a href="global.html#disposePopover">disposePopover</a></li>
|
||||
<li><a href="global.html#map-onclick">map.onclick</a></li>
|
||||
<li><a href="global.html#passlocation">window.passLocation</a></li>
|
||||
<li><a href="global.html#placepin">window.placePin</a></li>
|
||||
<li><a href="global.html#map">map</a></li>
|
||||
<li><a href="global.html#pinLayer">pinLayer</a></li>
|
||||
<li><a href="global.html#pinSource">pinSource</a></li>
|
||||
<li><a href="global.html#popup">popup</a></li>
|
||||
</ul>
|
||||
</nav>
|
||||
|
||||
<br class="clear" />
|
||||
|
||||
<footer>
|
||||
Documentation generated by
|
||||
<a href="https://github.com/jsdoc/jsdoc">JSDoc 4.0.2</a> on Sun Dec 31
|
||||
2023 15:19:11 GMT-0800 (Pacific Standard Time)
|
||||
</footer>
|
||||
|
||||
<script>
|
||||
prettyPrint();
|
||||
</script>
|
||||
<script src="scripts/linenumber.js"></script>
|
||||
</body>
|
||||
</html>
|
||||
113
openlayers/docs/modules_newButton.js.html
Normal file
113
openlayers/docs/modules_newButton.js.html
Normal file
|
|
@ -0,0 +1,113 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<title>JSDoc: Source: modules/newButton.js</title>
|
||||
|
||||
<script src="scripts/prettify/prettify.js"></script>
|
||||
<script src="scripts/prettify/lang-css.js"></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
||||
<![endif]-->
|
||||
<link
|
||||
type="text/css"
|
||||
rel="stylesheet"
|
||||
href="styles/prettify-tomorrow.css"
|
||||
/>
|
||||
<link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css" />
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div id="main">
|
||||
<h1 class="page-title">Source: modules/newButton.js</h1>
|
||||
|
||||
<section>
|
||||
<article>
|
||||
<pre
|
||||
class="prettyprint source linenums"
|
||||
><code>import { Control } from "ol/control.js";
|
||||
|
||||
/**
|
||||
* @module newButton
|
||||
*/
|
||||
|
||||
/** Extends OpenLayers default Control class to provide button for pin creation process
|
||||
* @extends ol.control.Control
|
||||
*/
|
||||
class ButtonControl extends Control {
|
||||
constructor(opt_options) {
|
||||
const options = opt_options || {};
|
||||
|
||||
const button = document.createElement("button");
|
||||
button.textContent = "New";
|
||||
button.addEventListener("click", newButtonHandler, false);
|
||||
|
||||
function newButtonHandler() {
|
||||
window.ReactNativeWebView?.postMessage("new pin start");
|
||||
}
|
||||
|
||||
const element = document.createElement("div");
|
||||
element.className = "new-button ol-unselectable ol-control";
|
||||
element.appendChild(button);
|
||||
|
||||
super({
|
||||
element: element,
|
||||
target: options.target,
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
export default ButtonControl;
|
||||
</code></pre>
|
||||
</article>
|
||||
</section>
|
||||
</div>
|
||||
|
||||
<nav>
|
||||
<h2><a href="index.html">Home</a></h2>
|
||||
<h3>Modules</h3>
|
||||
<ul>
|
||||
<li>
|
||||
<a href="module-changeResolutionHandler.html"
|
||||
>changeResolutionHandler</a
|
||||
>
|
||||
</li>
|
||||
<li><a href="module-fetchPins.html">fetchPins</a></li>
|
||||
<li><a href="module-makePin.html">makePin</a></li>
|
||||
<li><a href="module-newButton.html">newButton</a></li>
|
||||
<li><a href="module-pointerMoveHandler.html">pointerMoveHandler</a></li>
|
||||
<li><a href="module-searchBar.html">searchBar</a></li>
|
||||
<li><a href="module-searchInputHander.html">searchInputHander</a></li>
|
||||
<li><a href="module-toLatLon.html">toLatLon</a></li>
|
||||
</ul>
|
||||
<h3>Classes</h3>
|
||||
<ul>
|
||||
<li><a href="module-newButton-ButtonControl.html">ButtonControl</a></li>
|
||||
</ul>
|
||||
<h3>Global</h3>
|
||||
<ul>
|
||||
<li><a href="global.html#disposePopover">disposePopover</a></li>
|
||||
<li><a href="global.html#map-onclick">map.onclick</a></li>
|
||||
<li><a href="global.html#passlocation">window.passLocation</a></li>
|
||||
<li><a href="global.html#placepin">window.placePin</a></li>
|
||||
<li><a href="global.html#map">map</a></li>
|
||||
<li><a href="global.html#pinLayer">pinLayer</a></li>
|
||||
<li><a href="global.html#pinSource">pinSource</a></li>
|
||||
<li><a href="global.html#popup">popup</a></li>
|
||||
</ul>
|
||||
</nav>
|
||||
|
||||
<br class="clear" />
|
||||
|
||||
<footer>
|
||||
Documentation generated by
|
||||
<a href="https://github.com/jsdoc/jsdoc">JSDoc 4.0.2</a> on Sun Dec 31
|
||||
2023 15:19:11 GMT-0800 (Pacific Standard Time)
|
||||
</footer>
|
||||
|
||||
<script>
|
||||
prettyPrint();
|
||||
</script>
|
||||
<script src="scripts/linenumber.js"></script>
|
||||
</body>
|
||||
</html>
|
||||
95
openlayers/docs/modules_pointerMoveHandler.js.html
Normal file
95
openlayers/docs/modules_pointerMoveHandler.js.html
Normal file
|
|
@ -0,0 +1,95 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<title>JSDoc: Source: modules/pointerMoveHandler.js</title>
|
||||
|
||||
<script src="scripts/prettify/prettify.js"></script>
|
||||
<script src="scripts/prettify/lang-css.js"></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
||||
<![endif]-->
|
||||
<link
|
||||
type="text/css"
|
||||
rel="stylesheet"
|
||||
href="styles/prettify-tomorrow.css"
|
||||
/>
|
||||
<link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css" />
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div id="main">
|
||||
<h1 class="page-title">Source: modules/pointerMoveHandler.js</h1>
|
||||
|
||||
<section>
|
||||
<article>
|
||||
<pre class="prettyprint source linenums"><code>/**
|
||||
* @module pointerMoveHandler
|
||||
*/
|
||||
|
||||
/** Changes cursor depending on if user is hovering over a pin
|
||||
* @param {Event} event - Pointer move event
|
||||
* @param {ol.Map} map - OpenLayers map
|
||||
*/
|
||||
|
||||
const pointerMoveHandler = (event, map) => {
|
||||
const currentPixel = map.getEventPixel(event.originalEvent);
|
||||
if (map.hasFeatureAtPixel(currentPixel)) {
|
||||
map.getTarget().style.cursor = "pointer";
|
||||
} else map.getTarget().style.cursor = "";
|
||||
};
|
||||
|
||||
export default pointerMoveHandler;
|
||||
</code></pre>
|
||||
</article>
|
||||
</section>
|
||||
</div>
|
||||
|
||||
<nav>
|
||||
<h2><a href="index.html">Home</a></h2>
|
||||
<h3>Modules</h3>
|
||||
<ul>
|
||||
<li>
|
||||
<a href="module-changeResolutionHandler.html"
|
||||
>changeResolutionHandler</a
|
||||
>
|
||||
</li>
|
||||
<li><a href="module-fetchPins.html">fetchPins</a></li>
|
||||
<li><a href="module-makePin.html">makePin</a></li>
|
||||
<li><a href="module-newButton.html">newButton</a></li>
|
||||
<li><a href="module-pointerMoveHandler.html">pointerMoveHandler</a></li>
|
||||
<li><a href="module-searchBar.html">searchBar</a></li>
|
||||
<li><a href="module-searchInputHander.html">searchInputHander</a></li>
|
||||
<li><a href="module-toLatLon.html">toLatLon</a></li>
|
||||
</ul>
|
||||
<h3>Classes</h3>
|
||||
<ul>
|
||||
<li><a href="module-newButton-ButtonControl.html">ButtonControl</a></li>
|
||||
</ul>
|
||||
<h3>Global</h3>
|
||||
<ul>
|
||||
<li><a href="global.html#disposePopover">disposePopover</a></li>
|
||||
<li><a href="global.html#map-onclick">map.onclick</a></li>
|
||||
<li><a href="global.html#passlocation">window.passLocation</a></li>
|
||||
<li><a href="global.html#placepin">window.placePin</a></li>
|
||||
<li><a href="global.html#map">map</a></li>
|
||||
<li><a href="global.html#pinLayer">pinLayer</a></li>
|
||||
<li><a href="global.html#pinSource">pinSource</a></li>
|
||||
<li><a href="global.html#popup">popup</a></li>
|
||||
</ul>
|
||||
</nav>
|
||||
|
||||
<br class="clear" />
|
||||
|
||||
<footer>
|
||||
Documentation generated by
|
||||
<a href="https://github.com/jsdoc/jsdoc">JSDoc 4.0.2</a> on Sun Dec 31
|
||||
2023 15:19:11 GMT-0800 (Pacific Standard Time)
|
||||
</footer>
|
||||
|
||||
<script>
|
||||
prettyPrint();
|
||||
</script>
|
||||
<script src="scripts/linenumber.js"></script>
|
||||
</body>
|
||||
</html>
|
||||
98
openlayers/docs/modules_searchBar.js.html
Normal file
98
openlayers/docs/modules_searchBar.js.html
Normal file
|
|
@ -0,0 +1,98 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<title>JSDoc: Source: modules/searchBar.js</title>
|
||||
|
||||
<script src="scripts/prettify/prettify.js"></script>
|
||||
<script src="scripts/prettify/lang-css.js"></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
||||
<![endif]-->
|
||||
<link
|
||||
type="text/css"
|
||||
rel="stylesheet"
|
||||
href="styles/prettify-tomorrow.css"
|
||||
/>
|
||||
<link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css" />
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div id="main">
|
||||
<h1 class="page-title">Source: modules/searchBar.js</h1>
|
||||
|
||||
<section>
|
||||
<article>
|
||||
<pre
|
||||
class="prettyprint source linenums"
|
||||
><code>import Search from "ol-ext/control/Search.js";
|
||||
|
||||
/**
|
||||
* @module searchBar
|
||||
*/
|
||||
|
||||
/** Search bar component
|
||||
* @constant {ol-ext.control.Search}
|
||||
*/
|
||||
const searchBar = new Search({
|
||||
// disable autocompletion
|
||||
typing: -1,
|
||||
placeholder: "Search for products...",
|
||||
collapsed: "false",
|
||||
className: "searchBar",
|
||||
});
|
||||
|
||||
export default searchBar;
|
||||
</code></pre>
|
||||
</article>
|
||||
</section>
|
||||
</div>
|
||||
|
||||
<nav>
|
||||
<h2><a href="index.html">Home</a></h2>
|
||||
<h3>Modules</h3>
|
||||
<ul>
|
||||
<li>
|
||||
<a href="module-changeResolutionHandler.html"
|
||||
>changeResolutionHandler</a
|
||||
>
|
||||
</li>
|
||||
<li><a href="module-fetchPins.html">fetchPins</a></li>
|
||||
<li><a href="module-makePin.html">makePin</a></li>
|
||||
<li><a href="module-newButton.html">newButton</a></li>
|
||||
<li><a href="module-pointerMoveHandler.html">pointerMoveHandler</a></li>
|
||||
<li><a href="module-searchBar.html">searchBar</a></li>
|
||||
<li><a href="module-searchInputHander.html">searchInputHander</a></li>
|
||||
<li><a href="module-toLatLon.html">toLatLon</a></li>
|
||||
</ul>
|
||||
<h3>Classes</h3>
|
||||
<ul>
|
||||
<li><a href="module-newButton-ButtonControl.html">ButtonControl</a></li>
|
||||
</ul>
|
||||
<h3>Global</h3>
|
||||
<ul>
|
||||
<li><a href="global.html#disposePopover">disposePopover</a></li>
|
||||
<li><a href="global.html#map-onclick">map.onclick</a></li>
|
||||
<li><a href="global.html#passlocation">window.passLocation</a></li>
|
||||
<li><a href="global.html#placepin">window.placePin</a></li>
|
||||
<li><a href="global.html#map">map</a></li>
|
||||
<li><a href="global.html#pinLayer">pinLayer</a></li>
|
||||
<li><a href="global.html#pinSource">pinSource</a></li>
|
||||
<li><a href="global.html#popup">popup</a></li>
|
||||
</ul>
|
||||
</nav>
|
||||
|
||||
<br class="clear" />
|
||||
|
||||
<footer>
|
||||
Documentation generated by
|
||||
<a href="https://github.com/jsdoc/jsdoc">JSDoc 4.0.2</a> on Sun Dec 31
|
||||
2023 15:19:11 GMT-0800 (Pacific Standard Time)
|
||||
</footer>
|
||||
|
||||
<script>
|
||||
prettyPrint();
|
||||
</script>
|
||||
<script src="scripts/linenumber.js"></script>
|
||||
</body>
|
||||
</html>
|
||||
95
openlayers/docs/modules_searchInputHandler.js.html
Normal file
95
openlayers/docs/modules_searchInputHandler.js.html
Normal file
|
|
@ -0,0 +1,95 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<title>JSDoc: Source: modules/searchInputHandler.js</title>
|
||||
|
||||
<script src="scripts/prettify/prettify.js"></script>
|
||||
<script src="scripts/prettify/lang-css.js"></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
||||
<![endif]-->
|
||||
<link
|
||||
type="text/css"
|
||||
rel="stylesheet"
|
||||
href="styles/prettify-tomorrow.css"
|
||||
/>
|
||||
<link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css" />
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div id="main">
|
||||
<h1 class="page-title">Source: modules/searchInputHandler.js</h1>
|
||||
|
||||
<section>
|
||||
<article>
|
||||
<pre class="prettyprint source linenums"><code>/**
|
||||
* @module searchInputHander
|
||||
*/
|
||||
|
||||
/** Handles user pressing Enter key in search input field by sending current coordinates and contents of field to React Native for processing
|
||||
* @param {Event} event - Keydown event in search input field
|
||||
* @param {ol.Map} map - OpenLayers map
|
||||
*/
|
||||
const searchInputHander = (event, map) => {
|
||||
if (event.key === "Enter") {
|
||||
const coords = map.getView().getCenter();
|
||||
const query = event.target.value;
|
||||
window.ReactNativeWebView?.postMessage(`search@${coords}:${query}`);
|
||||
}
|
||||
};
|
||||
|
||||
export default searchInputHander;
|
||||
</code></pre>
|
||||
</article>
|
||||
</section>
|
||||
</div>
|
||||
|
||||
<nav>
|
||||
<h2><a href="index.html">Home</a></h2>
|
||||
<h3>Modules</h3>
|
||||
<ul>
|
||||
<li>
|
||||
<a href="module-changeResolutionHandler.html"
|
||||
>changeResolutionHandler</a
|
||||
>
|
||||
</li>
|
||||
<li><a href="module-fetchPins.html">fetchPins</a></li>
|
||||
<li><a href="module-makePin.html">makePin</a></li>
|
||||
<li><a href="module-newButton.html">newButton</a></li>
|
||||
<li><a href="module-pointerMoveHandler.html">pointerMoveHandler</a></li>
|
||||
<li><a href="module-searchBar.html">searchBar</a></li>
|
||||
<li><a href="module-searchInputHander.html">searchInputHander</a></li>
|
||||
<li><a href="module-toLatLon.html">toLatLon</a></li>
|
||||
</ul>
|
||||
<h3>Classes</h3>
|
||||
<ul>
|
||||
<li><a href="module-newButton-ButtonControl.html">ButtonControl</a></li>
|
||||
</ul>
|
||||
<h3>Global</h3>
|
||||
<ul>
|
||||
<li><a href="global.html#disposePopover">disposePopover</a></li>
|
||||
<li><a href="global.html#map-onclick">map.onclick</a></li>
|
||||
<li><a href="global.html#passlocation">window.passLocation</a></li>
|
||||
<li><a href="global.html#placepin">window.placePin</a></li>
|
||||
<li><a href="global.html#map">map</a></li>
|
||||
<li><a href="global.html#pinLayer">pinLayer</a></li>
|
||||
<li><a href="global.html#pinSource">pinSource</a></li>
|
||||
<li><a href="global.html#popup">popup</a></li>
|
||||
</ul>
|
||||
</nav>
|
||||
|
||||
<br class="clear" />
|
||||
|
||||
<footer>
|
||||
Documentation generated by
|
||||
<a href="https://github.com/jsdoc/jsdoc">JSDoc 4.0.2</a> on Sun Dec 31
|
||||
2023 15:19:11 GMT-0800 (Pacific Standard Time)
|
||||
</footer>
|
||||
|
||||
<script>
|
||||
prettyPrint();
|
||||
</script>
|
||||
<script src="scripts/linenumber.js"></script>
|
||||
</body>
|
||||
</html>
|
||||
106
openlayers/docs/modules_toLatLon.js.html
Normal file
106
openlayers/docs/modules_toLatLon.js.html
Normal file
|
|
@ -0,0 +1,106 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<title>JSDoc: Source: modules/toLatLon.js</title>
|
||||
|
||||
<script src="scripts/prettify/prettify.js"></script>
|
||||
<script src="scripts/prettify/lang-css.js"></script>
|
||||
<!--[if lt IE 9]>
|
||||
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
||||
<![endif]-->
|
||||
<link
|
||||
type="text/css"
|
||||
rel="stylesheet"
|
||||
href="styles/prettify-tomorrow.css"
|
||||
/>
|
||||
<link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css" />
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div id="main">
|
||||
<h1 class="page-title">Source: modules/toLatLon.js</h1>
|
||||
|
||||
<section>
|
||||
<article>
|
||||
<pre
|
||||
class="prettyprint source linenums"
|
||||
><code>import utmObj from "utm-latlng";
|
||||
|
||||
const utm = new utmObj();
|
||||
|
||||
/**
|
||||
* @module toLatLon
|
||||
*/
|
||||
|
||||
/** Converts UTM coordinates in database store records to latitude/longitude for use with the map
|
||||
* @param {number} easting - UTM easting of store
|
||||
* @param {number} northing - UTM northing of store
|
||||
* @param {string} zone - UTM zone of store
|
||||
* @param {string} zoneLetter - UTM zone letter of store
|
||||
* @returns {Array} - Array of coordinates as [latitude, longitude]
|
||||
*/
|
||||
const toLatLon = (easting, northing, zone, zoneLetter) => {
|
||||
const convertedCoordinates = utm.convertUtmToLatLng(
|
||||
easting,
|
||||
northing,
|
||||
zone,
|
||||
zoneLetter
|
||||
);
|
||||
return [convertedCoordinates.lat, convertedCoordinates.lng];
|
||||
};
|
||||
|
||||
export default toLatLon;
|
||||
</code></pre>
|
||||
</article>
|
||||
</section>
|
||||
</div>
|
||||
|
||||
<nav>
|
||||
<h2><a href="index.html">Home</a></h2>
|
||||
<h3>Modules</h3>
|
||||
<ul>
|
||||
<li>
|
||||
<a href="module-changeResolutionHandler.html"
|
||||
>changeResolutionHandler</a
|
||||
>
|
||||
</li>
|
||||
<li><a href="module-fetchPins.html">fetchPins</a></li>
|
||||
<li><a href="module-makePin.html">makePin</a></li>
|
||||
<li><a href="module-newButton.html">newButton</a></li>
|
||||
<li><a href="module-pointerMoveHandler.html">pointerMoveHandler</a></li>
|
||||
<li><a href="module-searchBar.html">searchBar</a></li>
|
||||
<li><a href="module-searchInputHander.html">searchInputHander</a></li>
|
||||
<li><a href="module-toLatLon.html">toLatLon</a></li>
|
||||
</ul>
|
||||
<h3>Classes</h3>
|
||||
<ul>
|
||||
<li><a href="module-newButton-ButtonControl.html">ButtonControl</a></li>
|
||||
</ul>
|
||||
<h3>Global</h3>
|
||||
<ul>
|
||||
<li><a href="global.html#disposePopover">disposePopover</a></li>
|
||||
<li><a href="global.html#map-onclick">map.onclick</a></li>
|
||||
<li><a href="global.html#passlocation">window.passLocation</a></li>
|
||||
<li><a href="global.html#placepin">window.placePin</a></li>
|
||||
<li><a href="global.html#map">map</a></li>
|
||||
<li><a href="global.html#pinLayer">pinLayer</a></li>
|
||||
<li><a href="global.html#pinSource">pinSource</a></li>
|
||||
<li><a href="global.html#popup">popup</a></li>
|
||||
</ul>
|
||||
</nav>
|
||||
|
||||
<br class="clear" />
|
||||
|
||||
<footer>
|
||||
Documentation generated by
|
||||
<a href="https://github.com/jsdoc/jsdoc">JSDoc 4.0.2</a> on Sun Dec 31
|
||||
2023 15:19:11 GMT-0800 (Pacific Standard Time)
|
||||
</footer>
|
||||
|
||||
<script>
|
||||
prettyPrint();
|
||||
</script>
|
||||
<script src="scripts/linenumber.js"></script>
|
||||
</body>
|
||||
</html>
|
||||
25
openlayers/docs/scripts/linenumber.js
Normal file
25
openlayers/docs/scripts/linenumber.js
Normal file
|
|
@ -0,0 +1,25 @@
|
|||
/*global document */
|
||||
(() => {
|
||||
const source = document.getElementsByClassName('prettyprint source linenums');
|
||||
let i = 0;
|
||||
let lineNumber = 0;
|
||||
let lineId;
|
||||
let lines;
|
||||
let totalLines;
|
||||
let anchorHash;
|
||||
|
||||
if (source && source[0]) {
|
||||
anchorHash = document.location.hash.substring(1);
|
||||
lines = source[0].getElementsByTagName('li');
|
||||
totalLines = lines.length;
|
||||
|
||||
for (; i < totalLines; i++) {
|
||||
lineNumber++;
|
||||
lineId = `line${lineNumber}`;
|
||||
lines[i].id = lineId;
|
||||
if (lineId === anchorHash) {
|
||||
lines[i].className += ' selected';
|
||||
}
|
||||
}
|
||||
}
|
||||
})();
|
||||
202
openlayers/docs/scripts/prettify/Apache-License-2.0.txt
Normal file
202
openlayers/docs/scripts/prettify/Apache-License-2.0.txt
Normal file
|
|
@ -0,0 +1,202 @@
|
|||
|
||||
Apache License
|
||||
Version 2.0, January 2004
|
||||
http://www.apache.org/licenses/
|
||||
|
||||
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
|
||||
|
||||
1. Definitions.
|
||||
|
||||
"License" shall mean the terms and conditions for use, reproduction,
|
||||
and distribution as defined by Sections 1 through 9 of this document.
|
||||
|
||||
"Licensor" shall mean the copyright owner or entity authorized by
|
||||
the copyright owner that is granting the License.
|
||||
|
||||
"Legal Entity" shall mean the union of the acting entity and all
|
||||
other entities that control, are controlled by, or are under common
|
||||
control with that entity. For the purposes of this definition,
|
||||
"control" means (i) the power, direct or indirect, to cause the
|
||||
direction or management of such entity, whether by contract or
|
||||
otherwise, or (ii) ownership of fifty percent (50%) or more of the
|
||||
outstanding shares, or (iii) beneficial ownership of such entity.
|
||||
|
||||
"You" (or "Your") shall mean an individual or Legal Entity
|
||||
exercising permissions granted by this License.
|
||||
|
||||
"Source" form shall mean the preferred form for making modifications,
|
||||
including but not limited to software source code, documentation
|
||||
source, and configuration files.
|
||||
|
||||
"Object" form shall mean any form resulting from mechanical
|
||||
transformation or translation of a Source form, including but
|
||||
not limited to compiled object code, generated documentation,
|
||||
and conversions to other media types.
|
||||
|
||||
"Work" shall mean the work of authorship, whether in Source or
|
||||
Object form, made available under the License, as indicated by a
|
||||
copyright notice that is included in or attached to the work
|
||||
(an example is provided in the Appendix below).
|
||||
|
||||
"Derivative Works" shall mean any work, whether in Source or Object
|
||||
form, that is based on (or derived from) the Work and for which the
|
||||
editorial revisions, annotations, elaborations, or other modifications
|
||||
represent, as a whole, an original work of authorship. For the purposes
|
||||
of this License, Derivative Works shall not include works that remain
|
||||
separable from, or merely link (or bind by name) to the interfaces of,
|
||||
the Work and Derivative Works thereof.
|
||||
|
||||
"Contribution" shall mean any work of authorship, including
|
||||
the original version of the Work and any modifications or additions
|
||||
to that Work or Derivative Works thereof, that is intentionally
|
||||
submitted to Licensor for inclusion in the Work by the copyright owner
|
||||
or by an individual or Legal Entity authorized to submit on behalf of
|
||||
the copyright owner. For the purposes of this definition, "submitted"
|
||||
means any form of electronic, verbal, or written communication sent
|
||||
to the Licensor or its representatives, including but not limited to
|
||||
communication on electronic mailing lists, source code control systems,
|
||||
and issue tracking systems that are managed by, or on behalf of, the
|
||||
Licensor for the purpose of discussing and improving the Work, but
|
||||
excluding communication that is conspicuously marked or otherwise
|
||||
designated in writing by the copyright owner as "Not a Contribution."
|
||||
|
||||
"Contributor" shall mean Licensor and any individual or Legal Entity
|
||||
on behalf of whom a Contribution has been received by Licensor and
|
||||
subsequently incorporated within the Work.
|
||||
|
||||
2. Grant of Copyright License. Subject to the terms and conditions of
|
||||
this License, each Contributor hereby grants to You a perpetual,
|
||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||
copyright license to reproduce, prepare Derivative Works of,
|
||||
publicly display, publicly perform, sublicense, and distribute the
|
||||
Work and such Derivative Works in Source or Object form.
|
||||
|
||||
3. Grant of Patent License. Subject to the terms and conditions of
|
||||
this License, each Contributor hereby grants to You a perpetual,
|
||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||
(except as stated in this section) patent license to make, have made,
|
||||
use, offer to sell, sell, import, and otherwise transfer the Work,
|
||||
where such license applies only to those patent claims licensable
|
||||
by such Contributor that are necessarily infringed by their
|
||||
Contribution(s) alone or by combination of their Contribution(s)
|
||||
with the Work to which such Contribution(s) was submitted. If You
|
||||
institute patent litigation against any entity (including a
|
||||
cross-claim or counterclaim in a lawsuit) alleging that the Work
|
||||
or a Contribution incorporated within the Work constitutes direct
|
||||
or contributory patent infringement, then any patent licenses
|
||||
granted to You under this License for that Work shall terminate
|
||||
as of the date such litigation is filed.
|
||||
|
||||
4. Redistribution. You may reproduce and distribute copies of the
|
||||
Work or Derivative Works thereof in any medium, with or without
|
||||
modifications, and in Source or Object form, provided that You
|
||||
meet the following conditions:
|
||||
|
||||
(a) You must give any other recipients of the Work or
|
||||
Derivative Works a copy of this License; and
|
||||
|
||||
(b) You must cause any modified files to carry prominent notices
|
||||
stating that You changed the files; and
|
||||
|
||||
(c) You must retain, in the Source form of any Derivative Works
|
||||
that You distribute, all copyright, patent, trademark, and
|
||||
attribution notices from the Source form of the Work,
|
||||
excluding those notices that do not pertain to any part of
|
||||
the Derivative Works; and
|
||||
|
||||
(d) If the Work includes a "NOTICE" text file as part of its
|
||||
distribution, then any Derivative Works that You distribute must
|
||||
include a readable copy of the attribution notices contained
|
||||
within such NOTICE file, excluding those notices that do not
|
||||
pertain to any part of the Derivative Works, in at least one
|
||||
of the following places: within a NOTICE text file distributed
|
||||
as part of the Derivative Works; within the Source form or
|
||||
documentation, if provided along with the Derivative Works; or,
|
||||
within a display generated by the Derivative Works, if and
|
||||
wherever such third-party notices normally appear. The contents
|
||||
of the NOTICE file are for informational purposes only and
|
||||
do not modify the License. You may add Your own attribution
|
||||
notices within Derivative Works that You distribute, alongside
|
||||
or as an addendum to the NOTICE text from the Work, provided
|
||||
that such additional attribution notices cannot be construed
|
||||
as modifying the License.
|
||||
|
||||
You may add Your own copyright statement to Your modifications and
|
||||
may provide additional or different license terms and conditions
|
||||
for use, reproduction, or distribution of Your modifications, or
|
||||
for any such Derivative Works as a whole, provided Your use,
|
||||
reproduction, and distribution of the Work otherwise complies with
|
||||
the conditions stated in this License.
|
||||
|
||||
5. Submission of Contributions. Unless You explicitly state otherwise,
|
||||
any Contribution intentionally submitted for inclusion in the Work
|
||||
by You to the Licensor shall be under the terms and conditions of
|
||||
this License, without any additional terms or conditions.
|
||||
Notwithstanding the above, nothing herein shall supersede or modify
|
||||
the terms of any separate license agreement you may have executed
|
||||
with Licensor regarding such Contributions.
|
||||
|
||||
6. Trademarks. This License does not grant permission to use the trade
|
||||
names, trademarks, service marks, or product names of the Licensor,
|
||||
except as required for reasonable and customary use in describing the
|
||||
origin of the Work and reproducing the content of the NOTICE file.
|
||||
|
||||
7. Disclaimer of Warranty. Unless required by applicable law or
|
||||
agreed to in writing, Licensor provides the Work (and each
|
||||
Contributor provides its Contributions) on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||
implied, including, without limitation, any warranties or conditions
|
||||
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
|
||||
PARTICULAR PURPOSE. You are solely responsible for determining the
|
||||
appropriateness of using or redistributing the Work and assume any
|
||||
risks associated with Your exercise of permissions under this License.
|
||||
|
||||
8. Limitation of Liability. In no event and under no legal theory,
|
||||
whether in tort (including negligence), contract, or otherwise,
|
||||
unless required by applicable law (such as deliberate and grossly
|
||||
negligent acts) or agreed to in writing, shall any Contributor be
|
||||
liable to You for damages, including any direct, indirect, special,
|
||||
incidental, or consequential damages of any character arising as a
|
||||
result of this License or out of the use or inability to use the
|
||||
Work (including but not limited to damages for loss of goodwill,
|
||||
work stoppage, computer failure or malfunction, or any and all
|
||||
other commercial damages or losses), even if such Contributor
|
||||
has been advised of the possibility of such damages.
|
||||
|
||||
9. Accepting Warranty or Additional Liability. While redistributing
|
||||
the Work or Derivative Works thereof, You may choose to offer,
|
||||
and charge a fee for, acceptance of support, warranty, indemnity,
|
||||
or other liability obligations and/or rights consistent with this
|
||||
License. However, in accepting such obligations, You may act only
|
||||
on Your own behalf and on Your sole responsibility, not on behalf
|
||||
of any other Contributor, and only if You agree to indemnify,
|
||||
defend, and hold each Contributor harmless for any liability
|
||||
incurred by, or claims asserted against, such Contributor by reason
|
||||
of your accepting any such warranty or additional liability.
|
||||
|
||||
END OF TERMS AND CONDITIONS
|
||||
|
||||
APPENDIX: How to apply the Apache License to your work.
|
||||
|
||||
To apply the Apache License to your work, attach the following
|
||||
boilerplate notice, with the fields enclosed by brackets "[]"
|
||||
replaced with your own identifying information. (Don't include
|
||||
the brackets!) The text should be enclosed in the appropriate
|
||||
comment syntax for the file format. We also recommend that a
|
||||
file or class name and description of purpose be included on the
|
||||
same "printed page" as the copyright notice for easier
|
||||
identification within third-party archives.
|
||||
|
||||
Copyright [yyyy] [name of copyright owner]
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
2
openlayers/docs/scripts/prettify/lang-css.js
Normal file
2
openlayers/docs/scripts/prettify/lang-css.js
Normal file
|
|
@ -0,0 +1,2 @@
|
|||
PR.registerLangHandler(PR.createSimpleLexer([["pln",/^[\t\n\f\r ]+/,null," \t\r\n"]],[["str",/^"(?:[^\n\f\r"\\]|\\(?:\r\n?|\n|\f)|\\[\S\s])*"/,null],["str",/^'(?:[^\n\f\r'\\]|\\(?:\r\n?|\n|\f)|\\[\S\s])*'/,null],["lang-css-str",/^url\(([^"')]*)\)/i],["kwd",/^(?:url|rgb|!important|@import|@page|@media|@charset|inherit)(?=[^\w-]|$)/i,null],["lang-css-kw",/^(-?(?:[_a-z]|\\[\da-f]+ ?)(?:[\w-]|\\\\[\da-f]+ ?)*)\s*:/i],["com",/^\/\*[^*]*\*+(?:[^*/][^*]*\*+)*\//],["com",
|
||||
/^(?:<\!--|--\>)/],["lit",/^(?:\d+|\d*\.\d+)(?:%|[a-z]+)?/i],["lit",/^#[\da-f]{3,6}/i],["pln",/^-?(?:[_a-z]|\\[\da-f]+ ?)(?:[\w-]|\\\\[\da-f]+ ?)*/i],["pun",/^[^\s\w"']+/]]),["css"]);PR.registerLangHandler(PR.createSimpleLexer([],[["kwd",/^-?(?:[_a-z]|\\[\da-f]+ ?)(?:[\w-]|\\\\[\da-f]+ ?)*/i]]),["css-kw"]);PR.registerLangHandler(PR.createSimpleLexer([],[["str",/^[^"')]+/]]),["css-str"]);
|
||||
28
openlayers/docs/scripts/prettify/prettify.js
Normal file
28
openlayers/docs/scripts/prettify/prettify.js
Normal file
|
|
@ -0,0 +1,28 @@
|
|||
var q=null;window.PR_SHOULD_USE_CONTINUATION=!0;
|
||||
(function(){function L(a){function m(a){var f=a.charCodeAt(0);if(f!==92)return f;var b=a.charAt(1);return(f=r[b])?f:"0"<=b&&b<="7"?parseInt(a.substring(1),8):b==="u"||b==="x"?parseInt(a.substring(2),16):a.charCodeAt(1)}function e(a){if(a<32)return(a<16?"\\x0":"\\x")+a.toString(16);a=String.fromCharCode(a);if(a==="\\"||a==="-"||a==="["||a==="]")a="\\"+a;return a}function h(a){for(var f=a.substring(1,a.length-1).match(/\\u[\dA-Fa-f]{4}|\\x[\dA-Fa-f]{2}|\\[0-3][0-7]{0,2}|\\[0-7]{1,2}|\\[\S\s]|[^\\]/g),a=
|
||||
[],b=[],o=f[0]==="^",c=o?1:0,i=f.length;c<i;++c){var j=f[c];if(/\\[bdsw]/i.test(j))a.push(j);else{var j=m(j),d;c+2<i&&"-"===f[c+1]?(d=m(f[c+2]),c+=2):d=j;b.push([j,d]);d<65||j>122||(d<65||j>90||b.push([Math.max(65,j)|32,Math.min(d,90)|32]),d<97||j>122||b.push([Math.max(97,j)&-33,Math.min(d,122)&-33]))}}b.sort(function(a,f){return a[0]-f[0]||f[1]-a[1]});f=[];j=[NaN,NaN];for(c=0;c<b.length;++c)i=b[c],i[0]<=j[1]+1?j[1]=Math.max(j[1],i[1]):f.push(j=i);b=["["];o&&b.push("^");b.push.apply(b,a);for(c=0;c<
|
||||
f.length;++c)i=f[c],b.push(e(i[0])),i[1]>i[0]&&(i[1]+1>i[0]&&b.push("-"),b.push(e(i[1])));b.push("]");return b.join("")}function y(a){for(var f=a.source.match(/\[(?:[^\\\]]|\\[\S\s])*]|\\u[\dA-Fa-f]{4}|\\x[\dA-Fa-f]{2}|\\\d+|\\[^\dux]|\(\?[!:=]|[()^]|[^()[\\^]+/g),b=f.length,d=[],c=0,i=0;c<b;++c){var j=f[c];j==="("?++i:"\\"===j.charAt(0)&&(j=+j.substring(1))&&j<=i&&(d[j]=-1)}for(c=1;c<d.length;++c)-1===d[c]&&(d[c]=++t);for(i=c=0;c<b;++c)j=f[c],j==="("?(++i,d[i]===void 0&&(f[c]="(?:")):"\\"===j.charAt(0)&&
|
||||
(j=+j.substring(1))&&j<=i&&(f[c]="\\"+d[i]);for(i=c=0;c<b;++c)"^"===f[c]&&"^"!==f[c+1]&&(f[c]="");if(a.ignoreCase&&s)for(c=0;c<b;++c)j=f[c],a=j.charAt(0),j.length>=2&&a==="["?f[c]=h(j):a!=="\\"&&(f[c]=j.replace(/[A-Za-z]/g,function(a){a=a.charCodeAt(0);return"["+String.fromCharCode(a&-33,a|32)+"]"}));return f.join("")}for(var t=0,s=!1,l=!1,p=0,d=a.length;p<d;++p){var g=a[p];if(g.ignoreCase)l=!0;else if(/[a-z]/i.test(g.source.replace(/\\u[\da-f]{4}|\\x[\da-f]{2}|\\[^UXux]/gi,""))){s=!0;l=!1;break}}for(var r=
|
||||
{b:8,t:9,n:10,v:11,f:12,r:13},n=[],p=0,d=a.length;p<d;++p){g=a[p];if(g.global||g.multiline)throw Error(""+g);n.push("(?:"+y(g)+")")}return RegExp(n.join("|"),l?"gi":"g")}function M(a){function m(a){switch(a.nodeType){case 1:if(e.test(a.className))break;for(var g=a.firstChild;g;g=g.nextSibling)m(g);g=a.nodeName;if("BR"===g||"LI"===g)h[s]="\n",t[s<<1]=y++,t[s++<<1|1]=a;break;case 3:case 4:g=a.nodeValue,g.length&&(g=p?g.replace(/\r\n?/g,"\n"):g.replace(/[\t\n\r ]+/g," "),h[s]=g,t[s<<1]=y,y+=g.length,
|
||||
t[s++<<1|1]=a)}}var e=/(?:^|\s)nocode(?:\s|$)/,h=[],y=0,t=[],s=0,l;a.currentStyle?l=a.currentStyle.whiteSpace:window.getComputedStyle&&(l=document.defaultView.getComputedStyle(a,q).getPropertyValue("white-space"));var p=l&&"pre"===l.substring(0,3);m(a);return{a:h.join("").replace(/\n$/,""),c:t}}function B(a,m,e,h){m&&(a={a:m,d:a},e(a),h.push.apply(h,a.e))}function x(a,m){function e(a){for(var l=a.d,p=[l,"pln"],d=0,g=a.a.match(y)||[],r={},n=0,z=g.length;n<z;++n){var f=g[n],b=r[f],o=void 0,c;if(typeof b===
|
||||
"string")c=!1;else{var i=h[f.charAt(0)];if(i)o=f.match(i[1]),b=i[0];else{for(c=0;c<t;++c)if(i=m[c],o=f.match(i[1])){b=i[0];break}o||(b="pln")}if((c=b.length>=5&&"lang-"===b.substring(0,5))&&!(o&&typeof o[1]==="string"))c=!1,b="src";c||(r[f]=b)}i=d;d+=f.length;if(c){c=o[1];var j=f.indexOf(c),k=j+c.length;o[2]&&(k=f.length-o[2].length,j=k-c.length);b=b.substring(5);B(l+i,f.substring(0,j),e,p);B(l+i+j,c,C(b,c),p);B(l+i+k,f.substring(k),e,p)}else p.push(l+i,b)}a.e=p}var h={},y;(function(){for(var e=a.concat(m),
|
||||
l=[],p={},d=0,g=e.length;d<g;++d){var r=e[d],n=r[3];if(n)for(var k=n.length;--k>=0;)h[n.charAt(k)]=r;r=r[1];n=""+r;p.hasOwnProperty(n)||(l.push(r),p[n]=q)}l.push(/[\S\s]/);y=L(l)})();var t=m.length;return e}function u(a){var m=[],e=[];a.tripleQuotedStrings?m.push(["str",/^(?:'''(?:[^'\\]|\\[\S\s]|''?(?=[^']))*(?:'''|$)|"""(?:[^"\\]|\\[\S\s]|""?(?=[^"]))*(?:"""|$)|'(?:[^'\\]|\\[\S\s])*(?:'|$)|"(?:[^"\\]|\\[\S\s])*(?:"|$))/,q,"'\""]):a.multiLineStrings?m.push(["str",/^(?:'(?:[^'\\]|\\[\S\s])*(?:'|$)|"(?:[^"\\]|\\[\S\s])*(?:"|$)|`(?:[^\\`]|\\[\S\s])*(?:`|$))/,
|
||||
q,"'\"`"]):m.push(["str",/^(?:'(?:[^\n\r'\\]|\\.)*(?:'|$)|"(?:[^\n\r"\\]|\\.)*(?:"|$))/,q,"\"'"]);a.verbatimStrings&&e.push(["str",/^@"(?:[^"]|"")*(?:"|$)/,q]);var h=a.hashComments;h&&(a.cStyleComments?(h>1?m.push(["com",/^#(?:##(?:[^#]|#(?!##))*(?:###|$)|.*)/,q,"#"]):m.push(["com",/^#(?:(?:define|elif|else|endif|error|ifdef|include|ifndef|line|pragma|undef|warning)\b|[^\n\r]*)/,q,"#"]),e.push(["str",/^<(?:(?:(?:\.\.\/)*|\/?)(?:[\w-]+(?:\/[\w-]+)+)?[\w-]+\.h|[a-z]\w*)>/,q])):m.push(["com",/^#[^\n\r]*/,
|
||||
q,"#"]));a.cStyleComments&&(e.push(["com",/^\/\/[^\n\r]*/,q]),e.push(["com",/^\/\*[\S\s]*?(?:\*\/|$)/,q]));a.regexLiterals&&e.push(["lang-regex",/^(?:^^\.?|[!+-]|!=|!==|#|%|%=|&|&&|&&=|&=|\(|\*|\*=|\+=|,|-=|->|\/|\/=|:|::|;|<|<<|<<=|<=|=|==|===|>|>=|>>|>>=|>>>|>>>=|[?@[^]|\^=|\^\^|\^\^=|{|\||\|=|\|\||\|\|=|~|break|case|continue|delete|do|else|finally|instanceof|return|throw|try|typeof)\s*(\/(?=[^*/])(?:[^/[\\]|\\[\S\s]|\[(?:[^\\\]]|\\[\S\s])*(?:]|$))+\/)/]);(h=a.types)&&e.push(["typ",h]);a=(""+a.keywords).replace(/^ | $/g,
|
||||
"");a.length&&e.push(["kwd",RegExp("^(?:"+a.replace(/[\s,]+/g,"|")+")\\b"),q]);m.push(["pln",/^\s+/,q," \r\n\t\xa0"]);e.push(["lit",/^@[$_a-z][\w$@]*/i,q],["typ",/^(?:[@_]?[A-Z]+[a-z][\w$@]*|\w+_t\b)/,q],["pln",/^[$_a-z][\w$@]*/i,q],["lit",/^(?:0x[\da-f]+|(?:\d(?:_\d+)*\d*(?:\.\d*)?|\.\d\+)(?:e[+-]?\d+)?)[a-z]*/i,q,"0123456789"],["pln",/^\\[\S\s]?/,q],["pun",/^.[^\s\w"-$'./@\\`]*/,q]);return x(m,e)}function D(a,m){function e(a){switch(a.nodeType){case 1:if(k.test(a.className))break;if("BR"===a.nodeName)h(a),
|
||||
a.parentNode&&a.parentNode.removeChild(a);else for(a=a.firstChild;a;a=a.nextSibling)e(a);break;case 3:case 4:if(p){var b=a.nodeValue,d=b.match(t);if(d){var c=b.substring(0,d.index);a.nodeValue=c;(b=b.substring(d.index+d[0].length))&&a.parentNode.insertBefore(s.createTextNode(b),a.nextSibling);h(a);c||a.parentNode.removeChild(a)}}}}function h(a){function b(a,d){var e=d?a.cloneNode(!1):a,f=a.parentNode;if(f){var f=b(f,1),g=a.nextSibling;f.appendChild(e);for(var h=g;h;h=g)g=h.nextSibling,f.appendChild(h)}return e}
|
||||
for(;!a.nextSibling;)if(a=a.parentNode,!a)return;for(var a=b(a.nextSibling,0),e;(e=a.parentNode)&&e.nodeType===1;)a=e;d.push(a)}var k=/(?:^|\s)nocode(?:\s|$)/,t=/\r\n?|\n/,s=a.ownerDocument,l;a.currentStyle?l=a.currentStyle.whiteSpace:window.getComputedStyle&&(l=s.defaultView.getComputedStyle(a,q).getPropertyValue("white-space"));var p=l&&"pre"===l.substring(0,3);for(l=s.createElement("LI");a.firstChild;)l.appendChild(a.firstChild);for(var d=[l],g=0;g<d.length;++g)e(d[g]);m===(m|0)&&d[0].setAttribute("value",
|
||||
m);var r=s.createElement("OL");r.className="linenums";for(var n=Math.max(0,m-1|0)||0,g=0,z=d.length;g<z;++g)l=d[g],l.className="L"+(g+n)%10,l.firstChild||l.appendChild(s.createTextNode("\xa0")),r.appendChild(l);a.appendChild(r)}function k(a,m){for(var e=m.length;--e>=0;){var h=m[e];A.hasOwnProperty(h)?window.console&&console.warn("cannot override language handler %s",h):A[h]=a}}function C(a,m){if(!a||!A.hasOwnProperty(a))a=/^\s*</.test(m)?"default-markup":"default-code";return A[a]}function E(a){var m=
|
||||
a.g;try{var e=M(a.h),h=e.a;a.a=h;a.c=e.c;a.d=0;C(m,h)(a);var k=/\bMSIE\b/.test(navigator.userAgent),m=/\n/g,t=a.a,s=t.length,e=0,l=a.c,p=l.length,h=0,d=a.e,g=d.length,a=0;d[g]=s;var r,n;for(n=r=0;n<g;)d[n]!==d[n+2]?(d[r++]=d[n++],d[r++]=d[n++]):n+=2;g=r;for(n=r=0;n<g;){for(var z=d[n],f=d[n+1],b=n+2;b+2<=g&&d[b+1]===f;)b+=2;d[r++]=z;d[r++]=f;n=b}for(d.length=r;h<p;){var o=l[h+2]||s,c=d[a+2]||s,b=Math.min(o,c),i=l[h+1],j;if(i.nodeType!==1&&(j=t.substring(e,b))){k&&(j=j.replace(m,"\r"));i.nodeValue=
|
||||
j;var u=i.ownerDocument,v=u.createElement("SPAN");v.className=d[a+1];var x=i.parentNode;x.replaceChild(v,i);v.appendChild(i);e<o&&(l[h+1]=i=u.createTextNode(t.substring(b,o)),x.insertBefore(i,v.nextSibling))}e=b;e>=o&&(h+=2);e>=c&&(a+=2)}}catch(w){"console"in window&&console.log(w&&w.stack?w.stack:w)}}var v=["break,continue,do,else,for,if,return,while"],w=[[v,"auto,case,char,const,default,double,enum,extern,float,goto,int,long,register,short,signed,sizeof,static,struct,switch,typedef,union,unsigned,void,volatile"],
|
||||
"catch,class,delete,false,import,new,operator,private,protected,public,this,throw,true,try,typeof"],F=[w,"alignof,align_union,asm,axiom,bool,concept,concept_map,const_cast,constexpr,decltype,dynamic_cast,explicit,export,friend,inline,late_check,mutable,namespace,nullptr,reinterpret_cast,static_assert,static_cast,template,typeid,typename,using,virtual,where"],G=[w,"abstract,boolean,byte,extends,final,finally,implements,import,instanceof,null,native,package,strictfp,super,synchronized,throws,transient"],
|
||||
H=[G,"as,base,by,checked,decimal,delegate,descending,dynamic,event,fixed,foreach,from,group,implicit,in,interface,internal,into,is,lock,object,out,override,orderby,params,partial,readonly,ref,sbyte,sealed,stackalloc,string,select,uint,ulong,unchecked,unsafe,ushort,var"],w=[w,"debugger,eval,export,function,get,null,set,undefined,var,with,Infinity,NaN"],I=[v,"and,as,assert,class,def,del,elif,except,exec,finally,from,global,import,in,is,lambda,nonlocal,not,or,pass,print,raise,try,with,yield,False,True,None"],
|
||||
J=[v,"alias,and,begin,case,class,def,defined,elsif,end,ensure,false,in,module,next,nil,not,or,redo,rescue,retry,self,super,then,true,undef,unless,until,when,yield,BEGIN,END"],v=[v,"case,done,elif,esac,eval,fi,function,in,local,set,then,until"],K=/^(DIR|FILE|vector|(de|priority_)?queue|list|stack|(const_)?iterator|(multi)?(set|map)|bitset|u?(int|float)\d*)/,N=/\S/,O=u({keywords:[F,H,w,"caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END"+
|
||||
I,J,v],hashComments:!0,cStyleComments:!0,multiLineStrings:!0,regexLiterals:!0}),A={};k(O,["default-code"]);k(x([],[["pln",/^[^<?]+/],["dec",/^<!\w[^>]*(?:>|$)/],["com",/^<\!--[\S\s]*?(?:--\>|$)/],["lang-",/^<\?([\S\s]+?)(?:\?>|$)/],["lang-",/^<%([\S\s]+?)(?:%>|$)/],["pun",/^(?:<[%?]|[%?]>)/],["lang-",/^<xmp\b[^>]*>([\S\s]+?)<\/xmp\b[^>]*>/i],["lang-js",/^<script\b[^>]*>([\S\s]*?)(<\/script\b[^>]*>)/i],["lang-css",/^<style\b[^>]*>([\S\s]*?)(<\/style\b[^>]*>)/i],["lang-in.tag",/^(<\/?[a-z][^<>]*>)/i]]),
|
||||
["default-markup","htm","html","mxml","xhtml","xml","xsl"]);k(x([["pln",/^\s+/,q," \t\r\n"],["atv",/^(?:"[^"]*"?|'[^']*'?)/,q,"\"'"]],[["tag",/^^<\/?[a-z](?:[\w-.:]*\w)?|\/?>$/i],["atn",/^(?!style[\s=]|on)[a-z](?:[\w:-]*\w)?/i],["lang-uq.val",/^=\s*([^\s"'>]*(?:[^\s"'/>]|\/(?=\s)))/],["pun",/^[/<->]+/],["lang-js",/^on\w+\s*=\s*"([^"]+)"/i],["lang-js",/^on\w+\s*=\s*'([^']+)'/i],["lang-js",/^on\w+\s*=\s*([^\s"'>]+)/i],["lang-css",/^style\s*=\s*"([^"]+)"/i],["lang-css",/^style\s*=\s*'([^']+)'/i],["lang-css",
|
||||
/^style\s*=\s*([^\s"'>]+)/i]]),["in.tag"]);k(x([],[["atv",/^[\S\s]+/]]),["uq.val"]);k(u({keywords:F,hashComments:!0,cStyleComments:!0,types:K}),["c","cc","cpp","cxx","cyc","m"]);k(u({keywords:"null,true,false"}),["json"]);k(u({keywords:H,hashComments:!0,cStyleComments:!0,verbatimStrings:!0,types:K}),["cs"]);k(u({keywords:G,cStyleComments:!0}),["java"]);k(u({keywords:v,hashComments:!0,multiLineStrings:!0}),["bsh","csh","sh"]);k(u({keywords:I,hashComments:!0,multiLineStrings:!0,tripleQuotedStrings:!0}),
|
||||
["cv","py"]);k(u({keywords:"caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END",hashComments:!0,multiLineStrings:!0,regexLiterals:!0}),["perl","pl","pm"]);k(u({keywords:J,hashComments:!0,multiLineStrings:!0,regexLiterals:!0}),["rb"]);k(u({keywords:w,cStyleComments:!0,regexLiterals:!0}),["js"]);k(u({keywords:"all,and,by,catch,class,else,extends,false,finally,for,if,in,is,isnt,loop,new,no,not,null,of,off,on,or,return,super,then,true,try,unless,until,when,while,yes",
|
||||
hashComments:3,cStyleComments:!0,multilineStrings:!0,tripleQuotedStrings:!0,regexLiterals:!0}),["coffee"]);k(x([],[["str",/^[\S\s]+/]]),["regex"]);window.prettyPrintOne=function(a,m,e){var h=document.createElement("PRE");h.innerHTML=a;e&&D(h,e);E({g:m,i:e,h:h});return h.innerHTML};window.prettyPrint=function(a){function m(){for(var e=window.PR_SHOULD_USE_CONTINUATION?l.now()+250:Infinity;p<h.length&&l.now()<e;p++){var n=h[p],k=n.className;if(k.indexOf("prettyprint")>=0){var k=k.match(g),f,b;if(b=
|
||||
!k){b=n;for(var o=void 0,c=b.firstChild;c;c=c.nextSibling)var i=c.nodeType,o=i===1?o?b:c:i===3?N.test(c.nodeValue)?b:o:o;b=(f=o===b?void 0:o)&&"CODE"===f.tagName}b&&(k=f.className.match(g));k&&(k=k[1]);b=!1;for(o=n.parentNode;o;o=o.parentNode)if((o.tagName==="pre"||o.tagName==="code"||o.tagName==="xmp")&&o.className&&o.className.indexOf("prettyprint")>=0){b=!0;break}b||((b=(b=n.className.match(/\blinenums\b(?::(\d+))?/))?b[1]&&b[1].length?+b[1]:!0:!1)&&D(n,b),d={g:k,h:n,i:b},E(d))}}p<h.length?setTimeout(m,
|
||||
250):a&&a()}for(var e=[document.getElementsByTagName("pre"),document.getElementsByTagName("code"),document.getElementsByTagName("xmp")],h=[],k=0;k<e.length;++k)for(var t=0,s=e[k].length;t<s;++t)h.push(e[k][t]);var e=q,l=Date;l.now||(l={now:function(){return+new Date}});var p=0,d,g=/\blang(?:uage)?-([\w.]+)(?!\S)/;m()};window.PR={createSimpleLexer:x,registerLangHandler:k,sourceDecorator:u,PR_ATTRIB_NAME:"atn",PR_ATTRIB_VALUE:"atv",PR_COMMENT:"com",PR_DECLARATION:"dec",PR_KEYWORD:"kwd",PR_LITERAL:"lit",
|
||||
PR_NOCODE:"nocode",PR_PLAIN:"pln",PR_PUNCTUATION:"pun",PR_SOURCE:"src",PR_STRING:"str",PR_TAG:"tag",PR_TYPE:"typ"}})();
|
||||
358
openlayers/docs/styles/jsdoc-default.css
Normal file
358
openlayers/docs/styles/jsdoc-default.css
Normal file
|
|
@ -0,0 +1,358 @@
|
|||
@font-face {
|
||||
font-family: 'Open Sans';
|
||||
font-weight: normal;
|
||||
font-style: normal;
|
||||
src: url('../fonts/OpenSans-Regular-webfont.eot');
|
||||
src:
|
||||
local('Open Sans'),
|
||||
local('OpenSans'),
|
||||
url('../fonts/OpenSans-Regular-webfont.eot?#iefix') format('embedded-opentype'),
|
||||
url('../fonts/OpenSans-Regular-webfont.woff') format('woff'),
|
||||
url('../fonts/OpenSans-Regular-webfont.svg#open_sansregular') format('svg');
|
||||
}
|
||||
|
||||
@font-face {
|
||||
font-family: 'Open Sans Light';
|
||||
font-weight: normal;
|
||||
font-style: normal;
|
||||
src: url('../fonts/OpenSans-Light-webfont.eot');
|
||||
src:
|
||||
local('Open Sans Light'),
|
||||
local('OpenSans Light'),
|
||||
url('../fonts/OpenSans-Light-webfont.eot?#iefix') format('embedded-opentype'),
|
||||
url('../fonts/OpenSans-Light-webfont.woff') format('woff'),
|
||||
url('../fonts/OpenSans-Light-webfont.svg#open_sanslight') format('svg');
|
||||
}
|
||||
|
||||
html
|
||||
{
|
||||
overflow: auto;
|
||||
background-color: #fff;
|
||||
font-size: 14px;
|
||||
}
|
||||
|
||||
body
|
||||
{
|
||||
font-family: 'Open Sans', sans-serif;
|
||||
line-height: 1.5;
|
||||
color: #4d4e53;
|
||||
background-color: white;
|
||||
}
|
||||
|
||||
a, a:visited, a:active {
|
||||
color: #0095dd;
|
||||
text-decoration: none;
|
||||
}
|
||||
|
||||
a:hover {
|
||||
text-decoration: underline;
|
||||
}
|
||||
|
||||
header
|
||||
{
|
||||
display: block;
|
||||
padding: 0px 4px;
|
||||
}
|
||||
|
||||
tt, code, kbd, samp {
|
||||
font-family: Consolas, Monaco, 'Andale Mono', monospace;
|
||||
}
|
||||
|
||||
.class-description {
|
||||
font-size: 130%;
|
||||
line-height: 140%;
|
||||
margin-bottom: 1em;
|
||||
margin-top: 1em;
|
||||
}
|
||||
|
||||
.class-description:empty {
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
#main {
|
||||
float: left;
|
||||
width: 70%;
|
||||
}
|
||||
|
||||
article dl {
|
||||
margin-bottom: 40px;
|
||||
}
|
||||
|
||||
article img {
|
||||
max-width: 100%;
|
||||
}
|
||||
|
||||
section
|
||||
{
|
||||
display: block;
|
||||
background-color: #fff;
|
||||
padding: 12px 24px;
|
||||
border-bottom: 1px solid #ccc;
|
||||
margin-right: 30px;
|
||||
}
|
||||
|
||||
.variation {
|
||||
display: none;
|
||||
}
|
||||
|
||||
.signature-attributes {
|
||||
font-size: 60%;
|
||||
color: #aaa;
|
||||
font-style: italic;
|
||||
font-weight: lighter;
|
||||
}
|
||||
|
||||
nav
|
||||
{
|
||||
display: block;
|
||||
float: right;
|
||||
margin-top: 28px;
|
||||
width: 30%;
|
||||
box-sizing: border-box;
|
||||
border-left: 1px solid #ccc;
|
||||
padding-left: 16px;
|
||||
}
|
||||
|
||||
nav ul {
|
||||
font-family: 'Lucida Grande', 'Lucida Sans Unicode', arial, sans-serif;
|
||||
font-size: 100%;
|
||||
line-height: 17px;
|
||||
padding: 0;
|
||||
margin: 0;
|
||||
list-style-type: none;
|
||||
}
|
||||
|
||||
nav ul a, nav ul a:visited, nav ul a:active {
|
||||
font-family: Consolas, Monaco, 'Andale Mono', monospace;
|
||||
line-height: 18px;
|
||||
color: #4D4E53;
|
||||
}
|
||||
|
||||
nav h3 {
|
||||
margin-top: 12px;
|
||||
}
|
||||
|
||||
nav li {
|
||||
margin-top: 6px;
|
||||
}
|
||||
|
||||
footer {
|
||||
display: block;
|
||||
padding: 6px;
|
||||
margin-top: 12px;
|
||||
font-style: italic;
|
||||
font-size: 90%;
|
||||
}
|
||||
|
||||
h1, h2, h3, h4 {
|
||||
font-weight: 200;
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
h1
|
||||
{
|
||||
font-family: 'Open Sans Light', sans-serif;
|
||||
font-size: 48px;
|
||||
letter-spacing: -2px;
|
||||
margin: 12px 24px 20px;
|
||||
}
|
||||
|
||||
h2, h3.subsection-title
|
||||
{
|
||||
font-size: 30px;
|
||||
font-weight: 700;
|
||||
letter-spacing: -1px;
|
||||
margin-bottom: 12px;
|
||||
}
|
||||
|
||||
h3
|
||||
{
|
||||
font-size: 24px;
|
||||
letter-spacing: -0.5px;
|
||||
margin-bottom: 12px;
|
||||
}
|
||||
|
||||
h4
|
||||
{
|
||||
font-size: 18px;
|
||||
letter-spacing: -0.33px;
|
||||
margin-bottom: 12px;
|
||||
color: #4d4e53;
|
||||
}
|
||||
|
||||
h5, .container-overview .subsection-title
|
||||
{
|
||||
font-size: 120%;
|
||||
font-weight: bold;
|
||||
letter-spacing: -0.01em;
|
||||
margin: 8px 0 3px 0;
|
||||
}
|
||||
|
||||
h6
|
||||
{
|
||||
font-size: 100%;
|
||||
letter-spacing: -0.01em;
|
||||
margin: 6px 0 3px 0;
|
||||
font-style: italic;
|
||||
}
|
||||
|
||||
table
|
||||
{
|
||||
border-spacing: 0;
|
||||
border: 0;
|
||||
border-collapse: collapse;
|
||||
}
|
||||
|
||||
td, th
|
||||
{
|
||||
border: 1px solid #ddd;
|
||||
margin: 0px;
|
||||
text-align: left;
|
||||
vertical-align: top;
|
||||
padding: 4px 6px;
|
||||
display: table-cell;
|
||||
}
|
||||
|
||||
thead tr
|
||||
{
|
||||
background-color: #ddd;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
th { border-right: 1px solid #aaa; }
|
||||
tr > th:last-child { border-right: 1px solid #ddd; }
|
||||
|
||||
.ancestors, .attribs { color: #999; }
|
||||
.ancestors a, .attribs a
|
||||
{
|
||||
color: #999 !important;
|
||||
text-decoration: none;
|
||||
}
|
||||
|
||||
.clear
|
||||
{
|
||||
clear: both;
|
||||
}
|
||||
|
||||
.important
|
||||
{
|
||||
font-weight: bold;
|
||||
color: #950B02;
|
||||
}
|
||||
|
||||
.yes-def {
|
||||
text-indent: -1000px;
|
||||
}
|
||||
|
||||
.type-signature {
|
||||
color: #aaa;
|
||||
}
|
||||
|
||||
.name, .signature {
|
||||
font-family: Consolas, Monaco, 'Andale Mono', monospace;
|
||||
}
|
||||
|
||||
.details { margin-top: 14px; border-left: 2px solid #DDD; }
|
||||
.details dt { width: 120px; float: left; padding-left: 10px; padding-top: 6px; }
|
||||
.details dd { margin-left: 70px; }
|
||||
.details ul { margin: 0; }
|
||||
.details ul { list-style-type: none; }
|
||||
.details li { margin-left: 30px; padding-top: 6px; }
|
||||
.details pre.prettyprint { margin: 0 }
|
||||
.details .object-value { padding-top: 0; }
|
||||
|
||||
.description {
|
||||
margin-bottom: 1em;
|
||||
margin-top: 1em;
|
||||
}
|
||||
|
||||
.code-caption
|
||||
{
|
||||
font-style: italic;
|
||||
font-size: 107%;
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
.source
|
||||
{
|
||||
border: 1px solid #ddd;
|
||||
width: 80%;
|
||||
overflow: auto;
|
||||
}
|
||||
|
||||
.prettyprint.source {
|
||||
width: inherit;
|
||||
}
|
||||
|
||||
.source code
|
||||
{
|
||||
font-size: 100%;
|
||||
line-height: 18px;
|
||||
display: block;
|
||||
padding: 4px 12px;
|
||||
margin: 0;
|
||||
background-color: #fff;
|
||||
color: #4D4E53;
|
||||
}
|
||||
|
||||
.prettyprint code span.line
|
||||
{
|
||||
display: inline-block;
|
||||
}
|
||||
|
||||
.prettyprint.linenums
|
||||
{
|
||||
padding-left: 70px;
|
||||
-webkit-user-select: none;
|
||||
-moz-user-select: none;
|
||||
-ms-user-select: none;
|
||||
user-select: none;
|
||||
}
|
||||
|
||||
.prettyprint.linenums ol
|
||||
{
|
||||
padding-left: 0;
|
||||
}
|
||||
|
||||
.prettyprint.linenums li
|
||||
{
|
||||
border-left: 3px #ddd solid;
|
||||
}
|
||||
|
||||
.prettyprint.linenums li.selected,
|
||||
.prettyprint.linenums li.selected *
|
||||
{
|
||||
background-color: lightyellow;
|
||||
}
|
||||
|
||||
.prettyprint.linenums li *
|
||||
{
|
||||
-webkit-user-select: text;
|
||||
-moz-user-select: text;
|
||||
-ms-user-select: text;
|
||||
user-select: text;
|
||||
}
|
||||
|
||||
.params .name, .props .name, .name code {
|
||||
color: #4D4E53;
|
||||
font-family: Consolas, Monaco, 'Andale Mono', monospace;
|
||||
font-size: 100%;
|
||||
}
|
||||
|
||||
.params td.description > p:first-child,
|
||||
.props td.description > p:first-child
|
||||
{
|
||||
margin-top: 0;
|
||||
padding-top: 0;
|
||||
}
|
||||
|
||||
.params td.description > p:last-child,
|
||||
.props td.description > p:last-child
|
||||
{
|
||||
margin-bottom: 0;
|
||||
padding-bottom: 0;
|
||||
}
|
||||
|
||||
.disabled {
|
||||
color: #454545;
|
||||
}
|
||||
111
openlayers/docs/styles/prettify-jsdoc.css
Normal file
111
openlayers/docs/styles/prettify-jsdoc.css
Normal file
|
|
@ -0,0 +1,111 @@
|
|||
/* JSDoc prettify.js theme */
|
||||
|
||||
/* plain text */
|
||||
.pln {
|
||||
color: #000000;
|
||||
font-weight: normal;
|
||||
font-style: normal;
|
||||
}
|
||||
|
||||
/* string content */
|
||||
.str {
|
||||
color: #006400;
|
||||
font-weight: normal;
|
||||
font-style: normal;
|
||||
}
|
||||
|
||||
/* a keyword */
|
||||
.kwd {
|
||||
color: #000000;
|
||||
font-weight: bold;
|
||||
font-style: normal;
|
||||
}
|
||||
|
||||
/* a comment */
|
||||
.com {
|
||||
font-weight: normal;
|
||||
font-style: italic;
|
||||
}
|
||||
|
||||
/* a type name */
|
||||
.typ {
|
||||
color: #000000;
|
||||
font-weight: normal;
|
||||
font-style: normal;
|
||||
}
|
||||
|
||||
/* a literal value */
|
||||
.lit {
|
||||
color: #006400;
|
||||
font-weight: normal;
|
||||
font-style: normal;
|
||||
}
|
||||
|
||||
/* punctuation */
|
||||
.pun {
|
||||
color: #000000;
|
||||
font-weight: bold;
|
||||
font-style: normal;
|
||||
}
|
||||
|
||||
/* lisp open bracket */
|
||||
.opn {
|
||||
color: #000000;
|
||||
font-weight: bold;
|
||||
font-style: normal;
|
||||
}
|
||||
|
||||
/* lisp close bracket */
|
||||
.clo {
|
||||
color: #000000;
|
||||
font-weight: bold;
|
||||
font-style: normal;
|
||||
}
|
||||
|
||||
/* a markup tag name */
|
||||
.tag {
|
||||
color: #006400;
|
||||
font-weight: normal;
|
||||
font-style: normal;
|
||||
}
|
||||
|
||||
/* a markup attribute name */
|
||||
.atn {
|
||||
color: #006400;
|
||||
font-weight: normal;
|
||||
font-style: normal;
|
||||
}
|
||||
|
||||
/* a markup attribute value */
|
||||
.atv {
|
||||
color: #006400;
|
||||
font-weight: normal;
|
||||
font-style: normal;
|
||||
}
|
||||
|
||||
/* a declaration */
|
||||
.dec {
|
||||
color: #000000;
|
||||
font-weight: bold;
|
||||
font-style: normal;
|
||||
}
|
||||
|
||||
/* a variable name */
|
||||
.var {
|
||||
color: #000000;
|
||||
font-weight: normal;
|
||||
font-style: normal;
|
||||
}
|
||||
|
||||
/* a function name */
|
||||
.fun {
|
||||
color: #000000;
|
||||
font-weight: bold;
|
||||
font-style: normal;
|
||||
}
|
||||
|
||||
/* Specify class=linenums on a pre to get line numbering */
|
||||
ol.linenums {
|
||||
margin-top: 0;
|
||||
margin-bottom: 0;
|
||||
}
|
||||
132
openlayers/docs/styles/prettify-tomorrow.css
Normal file
132
openlayers/docs/styles/prettify-tomorrow.css
Normal file
|
|
@ -0,0 +1,132 @@
|
|||
/* Tomorrow Theme */
|
||||
/* Original theme - https://github.com/chriskempson/tomorrow-theme */
|
||||
/* Pretty printing styles. Used with prettify.js. */
|
||||
/* SPAN elements with the classes below are added by prettyprint. */
|
||||
/* plain text */
|
||||
.pln {
|
||||
color: #4d4d4c; }
|
||||
|
||||
@media screen {
|
||||
/* string content */
|
||||
.str {
|
||||
color: #718c00; }
|
||||
|
||||
/* a keyword */
|
||||
.kwd {
|
||||
color: #8959a8; }
|
||||
|
||||
/* a comment */
|
||||
.com {
|
||||
color: #8e908c; }
|
||||
|
||||
/* a type name */
|
||||
.typ {
|
||||
color: #4271ae; }
|
||||
|
||||
/* a literal value */
|
||||
.lit {
|
||||
color: #f5871f; }
|
||||
|
||||
/* punctuation */
|
||||
.pun {
|
||||
color: #4d4d4c; }
|
||||
|
||||
/* lisp open bracket */
|
||||
.opn {
|
||||
color: #4d4d4c; }
|
||||
|
||||
/* lisp close bracket */
|
||||
.clo {
|
||||
color: #4d4d4c; }
|
||||
|
||||
/* a markup tag name */
|
||||
.tag {
|
||||
color: #c82829; }
|
||||
|
||||
/* a markup attribute name */
|
||||
.atn {
|
||||
color: #f5871f; }
|
||||
|
||||
/* a markup attribute value */
|
||||
.atv {
|
||||
color: #3e999f; }
|
||||
|
||||
/* a declaration */
|
||||
.dec {
|
||||
color: #f5871f; }
|
||||
|
||||
/* a variable name */
|
||||
.var {
|
||||
color: #c82829; }
|
||||
|
||||
/* a function name */
|
||||
.fun {
|
||||
color: #4271ae; } }
|
||||
/* Use higher contrast and text-weight for printable form. */
|
||||
@media print, projection {
|
||||
.str {
|
||||
color: #060; }
|
||||
|
||||
.kwd {
|
||||
color: #006;
|
||||
font-weight: bold; }
|
||||
|
||||
.com {
|
||||
color: #600;
|
||||
font-style: italic; }
|
||||
|
||||
.typ {
|
||||
color: #404;
|
||||
font-weight: bold; }
|
||||
|
||||
.lit {
|
||||
color: #044; }
|
||||
|
||||
.pun, .opn, .clo {
|
||||
color: #440; }
|
||||
|
||||
.tag {
|
||||
color: #006;
|
||||
font-weight: bold; }
|
||||
|
||||
.atn {
|
||||
color: #404; }
|
||||
|
||||
.atv {
|
||||
color: #060; } }
|
||||
/* Style */
|
||||
/*
|
||||
pre.prettyprint {
|
||||
background: white;
|
||||
font-family: Consolas, Monaco, 'Andale Mono', monospace;
|
||||
font-size: 12px;
|
||||
line-height: 1.5;
|
||||
border: 1px solid #ccc;
|
||||
padding: 10px; }
|
||||
*/
|
||||
|
||||
/* Specify class=linenums on a pre to get line numbering */
|
||||
ol.linenums {
|
||||
margin-top: 0;
|
||||
margin-bottom: 0; }
|
||||
|
||||
/* IE indents via margin-left */
|
||||
li.L0,
|
||||
li.L1,
|
||||
li.L2,
|
||||
li.L3,
|
||||
li.L4,
|
||||
li.L5,
|
||||
li.L6,
|
||||
li.L7,
|
||||
li.L8,
|
||||
li.L9 {
|
||||
/* */ }
|
||||
|
||||
/* Alternate shading for lines */
|
||||
li.L1,
|
||||
li.L3,
|
||||
li.L5,
|
||||
li.L7,
|
||||
li.L9 {
|
||||
/* */ }
|
||||
|
|
@ -5,98 +5,40 @@ import { Map, View, Overlay } from "ol";
|
|||
import { Tile as TileLayer, Vector as VectorLayer } from "ol/layer";
|
||||
import { TileJSON, Vector as VectorSource } from "ol/source";
|
||||
import { useGeographic } from "ol/proj.js";
|
||||
import { Control, defaults as defaultControls } from "ol/control.js";
|
||||
|
||||
import Search from "ol-ext/control/Search.js";
|
||||
import { defaults as defaultControls } from "ol/control.js";
|
||||
|
||||
import { Popover } from "bootstrap";
|
||||
import utmObj from "utm-latlng";
|
||||
|
||||
import makePin from "./modules/makePin.js";
|
||||
import searchBar from "./modules/searchBar.js";
|
||||
import fetchPins from "./modules/fetchPins.js";
|
||||
import ButtonControl from "./modules/newButton.js";
|
||||
import changeResolutionHandler from "./modules/changeResolutionHandler.js";
|
||||
import pointerMoveHandler from "./modules/pointerMoveHandler.js";
|
||||
import searchInputHander from "./modules/searchInputHandler.js";
|
||||
|
||||
// utm converter
|
||||
const utm = new utmObj();
|
||||
///
|
||||
|
||||
// specify to use real lon/lat coordinates
|
||||
useGeographic();
|
||||
const search = searchBar;
|
||||
|
||||
// state bool for locking pin overlay while adding pin
|
||||
let pinning = false;
|
||||
// create new VectorSource for pins
|
||||
|
||||
let popover;
|
||||
|
||||
/** Vector source for pins
|
||||
* @constant {ol.source.VectorSource} */
|
||||
const pinSource = new VectorSource();
|
||||
// create vector layer for rendering pins and popups
|
||||
/** Vector layer for pin vector source
|
||||
* @constant {ol.layer.VectorLayer} */
|
||||
const pinLayer = new VectorLayer({
|
||||
source: pinSource,
|
||||
});
|
||||
|
||||
// pull data from flask
|
||||
fetch(import.meta.env.VITE_BACKEND_URL)
|
||||
.then((res) => res.json())
|
||||
.then((dbPins) => {
|
||||
dbPins.forEach((dbPin) => {
|
||||
// convert to lat/lon
|
||||
const [lat, lon] = [
|
||||
utm.convertUtmToLatLng(
|
||||
dbPin.easting,
|
||||
dbPin.northing,
|
||||
dbPin.zone,
|
||||
dbPin.zoneLetter
|
||||
).lat,
|
||||
utm.convertUtmToLatLng(
|
||||
dbPin.easting,
|
||||
dbPin.northing,
|
||||
dbPin.zone,
|
||||
dbPin.zoneLetter
|
||||
).lng,
|
||||
];
|
||||
// make pin feature
|
||||
const pin = makePin(
|
||||
lon.toFixed(5),
|
||||
lat.toFixed(5),
|
||||
dbPin.name,
|
||||
dbPin.cheapestItem,
|
||||
dbPin.cheapestFloz
|
||||
);
|
||||
// add
|
||||
pinSource.addFeature(pin);
|
||||
});
|
||||
});
|
||||
useGeographic();
|
||||
|
||||
// create button
|
||||
// made in global scope so it can be modified
|
||||
const button = document.createElement("button");
|
||||
button.textContent = "New";
|
||||
button.addEventListener("click", newButtonHandler, false);
|
||||
function newButtonHandler() {
|
||||
window.ReactNativeWebView?.postMessage("new pin start");
|
||||
}
|
||||
fetchPins(pinSource);
|
||||
|
||||
// add button to control
|
||||
class ButtonControl extends Control {
|
||||
constructor(opt_options) {
|
||||
const options = opt_options || {};
|
||||
|
||||
const element = document.createElement("div");
|
||||
element.className = "new-button ol-unselectable ol-control";
|
||||
element.appendChild(button);
|
||||
|
||||
super({
|
||||
element: element,
|
||||
target: options.target,
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
// create search bar
|
||||
const search = new Search({
|
||||
// disable autocompletion
|
||||
typing: -1,
|
||||
placeholder: "Search for products...",
|
||||
collapsed: "false",
|
||||
className: "searchBar",
|
||||
});
|
||||
|
||||
// create OSM map
|
||||
/** Main map
|
||||
* @constant {ol.Map} */
|
||||
const map = new Map({
|
||||
controls: defaultControls().extend([new ButtonControl()]),
|
||||
target: document.getElementById("map"),
|
||||
|
|
@ -111,7 +53,6 @@ const map = new Map({
|
|||
}),
|
||||
}),
|
||||
],
|
||||
// initially view at Null Point, 2x zoom
|
||||
view: new View({
|
||||
center: [0, 0],
|
||||
zoom: 2,
|
||||
|
|
@ -119,33 +60,25 @@ const map = new Map({
|
|||
}),
|
||||
});
|
||||
|
||||
// popup element to display when pin clicked
|
||||
const element = document.getElementById("popup");
|
||||
/** Overlay element for pin popups
|
||||
* @constant {ol.Overlay} */
|
||||
const popup = new Overlay({
|
||||
element: element,
|
||||
element: document.getElementById("popup"),
|
||||
positioning: "bottom-center",
|
||||
stopEvent: false,
|
||||
});
|
||||
|
||||
// add popup overlay to map
|
||||
map.addOverlay(popup);
|
||||
|
||||
// add search
|
||||
map.addControl(search);
|
||||
|
||||
// get search input field
|
||||
const searchInput = search.getInputField();
|
||||
searchInput.onkeydown = (event) => {
|
||||
if (event.key === "Enter") {
|
||||
// emits to RN
|
||||
window.ReactNativeWebView?.postMessage(
|
||||
`search@${map.getView().getCenter()}:${event.target.value}`
|
||||
);
|
||||
}
|
||||
searchInputHander(event, map);
|
||||
};
|
||||
|
||||
// set state for popup visibility
|
||||
let popover;
|
||||
/** Removes store information popup from screen
|
||||
*/
|
||||
const disposePopover = () => {
|
||||
if (popover) {
|
||||
popover.dispose();
|
||||
|
|
@ -153,29 +86,35 @@ const disposePopover = () => {
|
|||
}
|
||||
};
|
||||
|
||||
// on click events
|
||||
/** Handles user clicks. If user clicks on a pixel that contains a pin, display popup with store information */
|
||||
|
||||
map.on("click", (event) => {
|
||||
// get features at pixel
|
||||
const feature = map.forEachFeatureAtPixel(event.pixel, (feature) => feature);
|
||||
// preemptively remove any previous popup overlays
|
||||
disposePopover();
|
||||
// if no pins at location, do nothing
|
||||
|
||||
const feature = map.forEachFeatureAtPixel(event.pixel, (feature) => feature);
|
||||
if (!feature) return;
|
||||
// set popup window position
|
||||
|
||||
popup.setPosition(event.coordinate);
|
||||
// create popover at position
|
||||
|
||||
const element = document.querySelector("#popup");
|
||||
|
||||
popover = new Popover(element, {
|
||||
placement: "top",
|
||||
html: true,
|
||||
title: feature.get("store"),
|
||||
content: function () {
|
||||
const holder = document.createElement("div");
|
||||
const one = document.createElement("div");
|
||||
one.textContent = `Cheapest Item: ${feature.get("cheapestItem")}`;
|
||||
holder.appendChild(one);
|
||||
const two = document.createElement("div");
|
||||
two.textContent = `$ / oz.: ${feature.get("pricePerOz")}`;
|
||||
holder.appendChild(two);
|
||||
const container = document.createElement("div");
|
||||
|
||||
const cheapestItem = document.createElement("div");
|
||||
cheapestItem.textContent = `Cheapest Item: ${feature.get(
|
||||
"cheapestItem"
|
||||
)}`;
|
||||
container.appendChild(cheapestItem);
|
||||
|
||||
const cheapestPerFloz = document.createElement("div");
|
||||
cheapestPerFloz.textContent = `$ / oz.: ${feature.get("pricePerOz")}`;
|
||||
container.appendChild(cheapestPerFloz);
|
||||
|
||||
const link = document.createElement("a");
|
||||
link.href = "#";
|
||||
link.onclick = function (event) {
|
||||
|
|
@ -185,40 +124,29 @@ map.on("click", (event) => {
|
|||
);
|
||||
};
|
||||
link.textContent = "More...";
|
||||
holder.appendChild(link);
|
||||
return holder;
|
||||
container.appendChild(link);
|
||||
|
||||
return container;
|
||||
},
|
||||
});
|
||||
// show popover
|
||||
|
||||
popover.show();
|
||||
});
|
||||
|
||||
// set pointer to cursor when hovering over pin
|
||||
map.on("pointermove", (event) => {
|
||||
// if there is a pin at the pixel the user is hovering over
|
||||
if (map.hasFeatureAtPixel(map.getEventPixel(event.originalEvent))) {
|
||||
// set the cursor to pointer cursor
|
||||
map.getTarget().style.cursor = "pointer";
|
||||
}
|
||||
// otherwise make cursor normal again
|
||||
else map.getTarget().style.cursor = "";
|
||||
pointerMoveHandler(event, map);
|
||||
});
|
||||
|
||||
// close popup when map moved
|
||||
map.on("movestart", disposePopover);
|
||||
|
||||
// sets listener to listen for zoom changes
|
||||
map.getView().on("change:resolution", () => {
|
||||
map.getView().getZoom() < 5
|
||||
? map.getLayers().removeAt(1)
|
||||
: (() => {
|
||||
if (map.getLayers().getLength() === 1) {
|
||||
if (!pinning) map.getLayers().extend([pinLayer]);
|
||||
}
|
||||
})();
|
||||
changeResolutionHandler(pinning, map, pinLayer);
|
||||
});
|
||||
|
||||
// centers location on user based on location information passed in from expo-location
|
||||
/** Centers location on user based on location information passed in from expo-location
|
||||
* @param {number} lon - User's longitude
|
||||
* @param {number} lat - User's latitude
|
||||
*/
|
||||
window.passLocation = (lon, lat) => {
|
||||
const view = new View({
|
||||
center: [lon, lat],
|
||||
|
|
@ -241,24 +169,22 @@ window.passLocation = (lon, lat) => {
|
|||
});
|
||||
};
|
||||
|
||||
// place pin interaction
|
||||
/** Begins store creation process if user clicks on "New" button */
|
||||
window.placePin = () => {
|
||||
// removes listener on button in case someone wants to mash it
|
||||
button.removeEventListener("click", newButtonHandler, false);
|
||||
// removes pin layer
|
||||
const oldButton = document.querySelector(".new-button > button");
|
||||
const button = oldButton.cloneNode(true);
|
||||
oldButton.parentNode.replaceChild(button, oldButton);
|
||||
pinning = true;
|
||||
|
||||
map.getLayers().removeAt(1);
|
||||
// adds pin in center of view
|
||||
document.getElementById("centerPin").style.display = "block";
|
||||
// changes new button to OK button
|
||||
|
||||
button.textContent = "OK";
|
||||
// OK button has event listener that on click
|
||||
|
||||
function OKButtonHandler() {
|
||||
// removes listener on button in case someone wants to mash it
|
||||
button.removeEventListener("click", OKButtonHandler, false);
|
||||
// removes pin in center of view
|
||||
document.getElementById("centerPin").style.display = "none";
|
||||
// emits to RN
|
||||
|
||||
window.ReactNativeWebView?.postMessage(
|
||||
`create@${map.getView().getCenter()}`
|
||||
);
|
||||
|
|
|
|||
26
openlayers/modules/changeResolutionHandler.js
Normal file
26
openlayers/modules/changeResolutionHandler.js
Normal file
|
|
@ -0,0 +1,26 @@
|
|||
/**
|
||||
* @module changeResolutionHandler
|
||||
*/
|
||||
|
||||
/** Maximum zoom level to show pins
|
||||
* @constant {number}
|
||||
* @default 5
|
||||
*/
|
||||
const CUTOFF = 5;
|
||||
|
||||
/** Adds or removes pin vector layer depending on zoom level
|
||||
* @param {boolean} pinning - Boolean to toggle between new pin creation and viewing existing pins. If this is true, existing pins are not visible.
|
||||
* @param {ol.Map} map - OpenLayers map to center
|
||||
* @param {ol.layer.Vector} pinLayer - OpenLayers vector layer for pins
|
||||
*/
|
||||
const changeResolutionHandler = (pinning, map, pinLayer) => {
|
||||
map.getView().getZoom() < CUTOFF
|
||||
? map.getLayers().removeAt(1)
|
||||
: (() => {
|
||||
if (map.getLayers().getLength() === 1) {
|
||||
if (!pinning) map.getLayers().extend([pinLayer]);
|
||||
}
|
||||
})();
|
||||
};
|
||||
|
||||
export default changeResolutionHandler;
|
||||
36
openlayers/modules/fetchPins.js
Normal file
36
openlayers/modules/fetchPins.js
Normal file
|
|
@ -0,0 +1,36 @@
|
|||
import makePin from "./makePin.js";
|
||||
import toLatLon from "./toLatLon.js";
|
||||
|
||||
/**
|
||||
* @module fetchPins
|
||||
*/
|
||||
|
||||
/** Fetches pin records from database and adds pin features to pin vector source layer
|
||||
* @async
|
||||
* @param {ol.source.Vector} pinSource - The relevant vector source layer to add pin features to
|
||||
*/
|
||||
const fetchPins = async (pinSource) => {
|
||||
const res = await fetch(import.meta.env.VITE_BACKEND_URL);
|
||||
const pinRecords = await res.json();
|
||||
|
||||
pinRecords.forEach((pinRecord) => {
|
||||
const [latitude, longitude] = toLatLon(
|
||||
pinRecord.easting,
|
||||
pinRecord.northing,
|
||||
pinRecord.zone,
|
||||
pinRecord.zoneLetter
|
||||
);
|
||||
|
||||
const pin = makePin(
|
||||
longitude.toFixed(5),
|
||||
latitude.toFixed(5),
|
||||
pinRecord.name,
|
||||
pinRecord.cheapestItem,
|
||||
pinRecord.cheapestFloz
|
||||
);
|
||||
|
||||
pinSource.addFeature(pin);
|
||||
});
|
||||
};
|
||||
|
||||
export default fetchPins;
|
||||
|
|
@ -3,6 +3,18 @@ import { Feature } from "ol";
|
|||
import { Icon, Style } from "ol/style";
|
||||
import Point from "ol/geom/Point.js";
|
||||
|
||||
/**
|
||||
* @module makePin
|
||||
*/
|
||||
|
||||
/** Makes pin feature from arguments
|
||||
* @param {number} lon - Longitude
|
||||
* @param {number} lat - Latitude
|
||||
* @param {string} storeName - Name of store
|
||||
* @param {string} cheapest - Cheapest item in store
|
||||
* @param {number} flozPrice - Price per fluid ounce of cheapest item in store
|
||||
* @returns {ol.Feature} - Created pin feature
|
||||
*/
|
||||
const makePin = (lon, lat, storeName, cheapest, flozPrice) => {
|
||||
// define pin graphics (since this is all inline)
|
||||
const pinSVG = `<svg width="32px" height="32px" viewBox="-0.12 -0.12 12.24 12.24" enable-background="new 0 0 12 12" id="Слой_1" version="1.1" xml:space="preserve" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" fill="#000000" stroke="#000000" stroke-width="0.12000000000000002"><g id="SVGRepo_bgCarrier" stroke-width="0"></g><g id="SVGRepo_tracerCarrier" stroke-linecap="round" stroke-linejoin="round"></g><g id="SVGRepo_iconCarrier"><path d="M6,0C3.2385864,0,1,2.2385864,1,5s2.5,5,5,7c2.5-2,5-4.2385864,5-7S8.7614136,0,6,0z M6,7 C4.8954468,7,4,6.1045532,4,5s0.8954468-2,2-2s2,0.8954468,2,2S7.1045532,7,6,7z" fill="#ed333b"></path></g></svg>`;
|
||||
|
|
|
|||
33
openlayers/modules/newButton.js
Normal file
33
openlayers/modules/newButton.js
Normal file
|
|
@ -0,0 +1,33 @@
|
|||
import { Control } from "ol/control.js";
|
||||
|
||||
/**
|
||||
* @module newButton
|
||||
*/
|
||||
|
||||
/** Extends OpenLayers default Control class to provide button for pin creation process
|
||||
* @extends ol.control.Control
|
||||
*/
|
||||
class ButtonControl extends Control {
|
||||
constructor(opt_options) {
|
||||
const options = opt_options || {};
|
||||
|
||||
const button = document.createElement("button");
|
||||
button.textContent = "New";
|
||||
button.addEventListener("click", newButtonHandler, false);
|
||||
|
||||
function newButtonHandler() {
|
||||
window.ReactNativeWebView?.postMessage("new pin start");
|
||||
}
|
||||
|
||||
const element = document.createElement("div");
|
||||
element.className = "new-button ol-unselectable ol-control";
|
||||
element.appendChild(button);
|
||||
|
||||
super({
|
||||
element: element,
|
||||
target: options.target,
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
export default ButtonControl;
|
||||
17
openlayers/modules/pointerMoveHandler.js
Normal file
17
openlayers/modules/pointerMoveHandler.js
Normal file
|
|
@ -0,0 +1,17 @@
|
|||
/**
|
||||
* @module pointerMoveHandler
|
||||
*/
|
||||
|
||||
/** Changes cursor depending on if user is hovering over a pin
|
||||
* @param {Event} event - Pointer move event
|
||||
* @param {ol.Map} map - OpenLayers map
|
||||
*/
|
||||
|
||||
const pointerMoveHandler = (event, map) => {
|
||||
const currentPixel = map.getEventPixel(event.originalEvent);
|
||||
if (map.hasFeatureAtPixel(currentPixel)) {
|
||||
map.getTarget().style.cursor = "pointer";
|
||||
} else map.getTarget().style.cursor = "";
|
||||
};
|
||||
|
||||
export default pointerMoveHandler;
|
||||
18
openlayers/modules/searchBar.js
Normal file
18
openlayers/modules/searchBar.js
Normal file
|
|
@ -0,0 +1,18 @@
|
|||
import Search from "ol-ext/control/Search.js";
|
||||
|
||||
/**
|
||||
* @module searchBar
|
||||
*/
|
||||
|
||||
/** Search bar component
|
||||
* @constant {ol-ext.control.Search}
|
||||
*/
|
||||
const searchBar = new Search({
|
||||
// disable autocompletion
|
||||
typing: -1,
|
||||
placeholder: "Search for products...",
|
||||
collapsed: "false",
|
||||
className: "searchBar",
|
||||
});
|
||||
|
||||
export default searchBar;
|
||||
17
openlayers/modules/searchInputHandler.js
Normal file
17
openlayers/modules/searchInputHandler.js
Normal file
|
|
@ -0,0 +1,17 @@
|
|||
/**
|
||||
* @module searchInputHander
|
||||
*/
|
||||
|
||||
/** Handles user pressing Enter key in search input field by sending current coordinates and contents of field to React Native for processing
|
||||
* @param {Event} event - Keydown event in search input field
|
||||
* @param {ol.Map} map - OpenLayers map
|
||||
*/
|
||||
const searchInputHander = (event, map) => {
|
||||
if (event.key === "Enter") {
|
||||
const coords = map.getView().getCenter();
|
||||
const query = event.target.value;
|
||||
window.ReactNativeWebView?.postMessage(`search@${coords}:${query}`);
|
||||
}
|
||||
};
|
||||
|
||||
export default searchInputHander;
|
||||
26
openlayers/modules/toLatLon.js
Normal file
26
openlayers/modules/toLatLon.js
Normal file
|
|
@ -0,0 +1,26 @@
|
|||
import utmObj from "utm-latlng";
|
||||
|
||||
const utm = new utmObj();
|
||||
|
||||
/**
|
||||
* @module toLatLon
|
||||
*/
|
||||
|
||||
/** Converts UTM coordinates in database store records to latitude/longitude for use with the map
|
||||
* @param {number} easting - UTM easting of store
|
||||
* @param {number} northing - UTM northing of store
|
||||
* @param {string} zone - UTM zone of store
|
||||
* @param {string} zoneLetter - UTM zone letter of store
|
||||
* @returns {Array} - Array of coordinates as [latitude, longitude]
|
||||
*/
|
||||
const toLatLon = (easting, northing, zone, zoneLetter) => {
|
||||
const convertedCoordinates = utm.convertUtmToLatLng(
|
||||
easting,
|
||||
northing,
|
||||
zone,
|
||||
zoneLetter
|
||||
);
|
||||
return [convertedCoordinates.lat, convertedCoordinates.lng];
|
||||
};
|
||||
|
||||
export default toLatLon;
|
||||
455
openlayers/package-lock.json
generated
455
openlayers/package-lock.json
generated
|
|
@ -16,9 +16,22 @@
|
|||
"vite-plugin-singlefile": "^0.13.5"
|
||||
},
|
||||
"devDependencies": {
|
||||
"jsdoc": "^4.0.2",
|
||||
"vite": "^4.0.4"
|
||||
}
|
||||
},
|
||||
"node_modules/@babel/parser": {
|
||||
"version": "7.23.6",
|
||||
"resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.23.6.tgz",
|
||||
"integrity": "sha512-Z2uID7YJ7oNvAI20O9X0bblw7Qqs8Q2hFy0R9tAfnfLkp5MW0UH9eUvnDSnFwKZ0AvgS1ucqR4KzvVHgnke1VQ==",
|
||||
"dev": true,
|
||||
"bin": {
|
||||
"parser": "bin/babel-parser.js"
|
||||
},
|
||||
"engines": {
|
||||
"node": ">=6.0.0"
|
||||
}
|
||||
},
|
||||
"node_modules/@esbuild/android-arm": {
|
||||
"version": "0.16.17",
|
||||
"resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.16.17.tgz",
|
||||
|
|
@ -349,6 +362,18 @@
|
|||
"node": ">=12"
|
||||
}
|
||||
},
|
||||
"node_modules/@jsdoc/salty": {
|
||||
"version": "0.2.7",
|
||||
"resolved": "https://registry.npmjs.org/@jsdoc/salty/-/salty-0.2.7.tgz",
|
||||
"integrity": "sha512-mh8LbS9d4Jq84KLw8pzho7XC2q2/IJGiJss3xwRoLD1A+EE16SjN4PfaG4jRCzKegTFLlN0Zd8SdUPE6XdoPFg==",
|
||||
"dev": true,
|
||||
"dependencies": {
|
||||
"lodash": "^4.17.21"
|
||||
},
|
||||
"engines": {
|
||||
"node": ">=v12.0.0"
|
||||
}
|
||||
},
|
||||
"node_modules/@mapbox/jsonlint-lines-primitives": {
|
||||
"version": "2.0.2",
|
||||
"resolved": "https://registry.npmjs.org/@mapbox/jsonlint-lines-primitives/-/jsonlint-lines-primitives-2.0.2.tgz",
|
||||
|
|
@ -403,6 +428,40 @@
|
|||
"url": "https://opencollective.com/popperjs"
|
||||
}
|
||||
},
|
||||
"node_modules/@types/linkify-it": {
|
||||
"version": "3.0.5",
|
||||
"resolved": "https://registry.npmjs.org/@types/linkify-it/-/linkify-it-3.0.5.tgz",
|
||||
"integrity": "sha512-yg6E+u0/+Zjva+buc3EIb+29XEg4wltq7cSmd4Uc2EE/1nUVmxyzpX6gUXD0V8jIrG0r7YeOGVIbYRkxeooCtw==",
|
||||
"dev": true
|
||||
},
|
||||
"node_modules/@types/markdown-it": {
|
||||
"version": "12.2.3",
|
||||
"resolved": "https://registry.npmjs.org/@types/markdown-it/-/markdown-it-12.2.3.tgz",
|
||||
"integrity": "sha512-GKMHFfv3458yYy+v/N8gjufHO6MSZKCOXpZc5GXIWWy8uldwfmPn98vp81gZ5f9SVw8YYBctgfJ22a2d7AOMeQ==",
|
||||
"dev": true,
|
||||
"dependencies": {
|
||||
"@types/linkify-it": "*",
|
||||
"@types/mdurl": "*"
|
||||
}
|
||||
},
|
||||
"node_modules/@types/mdurl": {
|
||||
"version": "1.0.5",
|
||||
"resolved": "https://registry.npmjs.org/@types/mdurl/-/mdurl-1.0.5.tgz",
|
||||
"integrity": "sha512-6L6VymKTzYSrEf4Nev4Xa1LCHKrlTlYCBMTlQKFuddo1CvQcE52I0mwfOJayueUC7MJuXOeHTcIU683lzd0cUA==",
|
||||
"dev": true
|
||||
},
|
||||
"node_modules/argparse": {
|
||||
"version": "2.0.1",
|
||||
"resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz",
|
||||
"integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==",
|
||||
"dev": true
|
||||
},
|
||||
"node_modules/bluebird": {
|
||||
"version": "3.7.2",
|
||||
"resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.7.2.tgz",
|
||||
"integrity": "sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg==",
|
||||
"dev": true
|
||||
},
|
||||
"node_modules/bootstrap": {
|
||||
"version": "5.3.2",
|
||||
"resolved": "https://registry.npmjs.org/bootstrap/-/bootstrap-5.3.2.tgz",
|
||||
|
|
@ -432,6 +491,18 @@
|
|||
"node": ">=8"
|
||||
}
|
||||
},
|
||||
"node_modules/catharsis": {
|
||||
"version": "0.9.0",
|
||||
"resolved": "https://registry.npmjs.org/catharsis/-/catharsis-0.9.0.tgz",
|
||||
"integrity": "sha512-prMTQVpcns/tzFgFVkVp6ak6RykZyWb3gu8ckUpd6YkTlacOd3DXGJjIpD4Q6zJirizvaiAjSSHlOsA+6sNh2A==",
|
||||
"dev": true,
|
||||
"dependencies": {
|
||||
"lodash": "^4.17.15"
|
||||
},
|
||||
"engines": {
|
||||
"node": ">= 10"
|
||||
}
|
||||
},
|
||||
"node_modules/csscolorparser": {
|
||||
"version": "1.0.3",
|
||||
"resolved": "https://registry.npmjs.org/csscolorparser/-/csscolorparser-1.0.3.tgz",
|
||||
|
|
@ -453,6 +524,15 @@
|
|||
"resolved": "https://registry.npmjs.org/earcut/-/earcut-2.2.4.tgz",
|
||||
"integrity": "sha512-/pjZsA1b4RPHbeWZQn66SWS8nZZWLQQ23oE3Eam7aroEFGEvwKAsJfZ9ytiEMycfzXWpca4FA9QIOehf7PocBQ=="
|
||||
},
|
||||
"node_modules/entities": {
|
||||
"version": "2.1.0",
|
||||
"resolved": "https://registry.npmjs.org/entities/-/entities-2.1.0.tgz",
|
||||
"integrity": "sha512-hCx1oky9PFrJ611mf0ifBLBRW8lUUVRlFolb5gWRfIELabBlbp9xZvrqZLZAs+NxFnbfQoeGd8wDkygjg7U85w==",
|
||||
"dev": true,
|
||||
"funding": {
|
||||
"url": "https://github.com/fb55/entities?sponsor=1"
|
||||
}
|
||||
},
|
||||
"node_modules/esbuild": {
|
||||
"version": "0.16.17",
|
||||
"resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.16.17.tgz",
|
||||
|
|
@ -489,6 +569,15 @@
|
|||
"@esbuild/win32-x64": "0.16.17"
|
||||
}
|
||||
},
|
||||
"node_modules/escape-string-regexp": {
|
||||
"version": "2.0.0",
|
||||
"resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz",
|
||||
"integrity": "sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==",
|
||||
"dev": true,
|
||||
"engines": {
|
||||
"node": ">=8"
|
||||
}
|
||||
},
|
||||
"node_modules/fill-range": {
|
||||
"version": "7.0.1",
|
||||
"resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz",
|
||||
|
|
@ -536,6 +625,12 @@
|
|||
"node": ">=10.19"
|
||||
}
|
||||
},
|
||||
"node_modules/graceful-fs": {
|
||||
"version": "4.2.11",
|
||||
"resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz",
|
||||
"integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==",
|
||||
"dev": true
|
||||
},
|
||||
"node_modules/has": {
|
||||
"version": "1.0.3",
|
||||
"resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz",
|
||||
|
|
@ -585,16 +680,78 @@
|
|||
"node": ">=0.12.0"
|
||||
}
|
||||
},
|
||||
"node_modules/js2xmlparser": {
|
||||
"version": "4.0.2",
|
||||
"resolved": "https://registry.npmjs.org/js2xmlparser/-/js2xmlparser-4.0.2.tgz",
|
||||
"integrity": "sha512-6n4D8gLlLf1n5mNLQPRfViYzu9RATblzPEtm1SthMX1Pjao0r9YI9nw7ZIfRxQMERS87mcswrg+r/OYrPRX6jA==",
|
||||
"dev": true,
|
||||
"dependencies": {
|
||||
"xmlcreate": "^2.0.4"
|
||||
}
|
||||
},
|
||||
"node_modules/jsdoc": {
|
||||
"version": "4.0.2",
|
||||
"resolved": "https://registry.npmjs.org/jsdoc/-/jsdoc-4.0.2.tgz",
|
||||
"integrity": "sha512-e8cIg2z62InH7azBBi3EsSEqrKx+nUtAS5bBcYTSpZFA+vhNPyhv8PTFZ0WsjOPDj04/dOLlm08EDcQJDqaGQg==",
|
||||
"dev": true,
|
||||
"dependencies": {
|
||||
"@babel/parser": "^7.20.15",
|
||||
"@jsdoc/salty": "^0.2.1",
|
||||
"@types/markdown-it": "^12.2.3",
|
||||
"bluebird": "^3.7.2",
|
||||
"catharsis": "^0.9.0",
|
||||
"escape-string-regexp": "^2.0.0",
|
||||
"js2xmlparser": "^4.0.2",
|
||||
"klaw": "^3.0.0",
|
||||
"markdown-it": "^12.3.2",
|
||||
"markdown-it-anchor": "^8.4.1",
|
||||
"marked": "^4.0.10",
|
||||
"mkdirp": "^1.0.4",
|
||||
"requizzle": "^0.2.3",
|
||||
"strip-json-comments": "^3.1.0",
|
||||
"underscore": "~1.13.2"
|
||||
},
|
||||
"bin": {
|
||||
"jsdoc": "jsdoc.js"
|
||||
},
|
||||
"engines": {
|
||||
"node": ">=12.0.0"
|
||||
}
|
||||
},
|
||||
"node_modules/json-stringify-pretty-compact": {
|
||||
"version": "2.0.0",
|
||||
"resolved": "https://registry.npmjs.org/json-stringify-pretty-compact/-/json-stringify-pretty-compact-2.0.0.tgz",
|
||||
"integrity": "sha512-WRitRfs6BGq4q8gTgOy4ek7iPFXjbra0H3PmDLKm2xnZ+Gh1HUhiKGgCZkSPNULlP7mvfu6FV/mOLhCarspADQ=="
|
||||
},
|
||||
"node_modules/klaw": {
|
||||
"version": "3.0.0",
|
||||
"resolved": "https://registry.npmjs.org/klaw/-/klaw-3.0.0.tgz",
|
||||
"integrity": "sha512-0Fo5oir+O9jnXu5EefYbVK+mHMBeEVEy2cmctR1O1NECcCkPRreJKrS6Qt/j3KC2C148Dfo9i3pCmCMsdqGr0g==",
|
||||
"dev": true,
|
||||
"dependencies": {
|
||||
"graceful-fs": "^4.1.9"
|
||||
}
|
||||
},
|
||||
"node_modules/lerc": {
|
||||
"version": "3.0.0",
|
||||
"resolved": "https://registry.npmjs.org/lerc/-/lerc-3.0.0.tgz",
|
||||
"integrity": "sha512-Rm4J/WaHhRa93nCN2mwWDZFoRVF18G1f47C+kvQWyHGEZxFpTUi73p7lMVSAndyxGt6lJ2/CFbOcf9ra5p8aww=="
|
||||
},
|
||||
"node_modules/linkify-it": {
|
||||
"version": "3.0.3",
|
||||
"resolved": "https://registry.npmjs.org/linkify-it/-/linkify-it-3.0.3.tgz",
|
||||
"integrity": "sha512-ynTsyrFSdE5oZ/O9GEf00kPngmOfVwazR5GKDq6EYfhlpFug3J2zybX56a2PRRpc9P+FuSoGNAwjlbDs9jJBPQ==",
|
||||
"dev": true,
|
||||
"dependencies": {
|
||||
"uc.micro": "^1.0.1"
|
||||
}
|
||||
},
|
||||
"node_modules/lodash": {
|
||||
"version": "4.17.21",
|
||||
"resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz",
|
||||
"integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==",
|
||||
"dev": true
|
||||
},
|
||||
"node_modules/lru-cache": {
|
||||
"version": "6.0.0",
|
||||
"resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz",
|
||||
|
|
@ -611,6 +768,50 @@
|
|||
"resolved": "https://registry.npmjs.org/mapbox-to-css-font/-/mapbox-to-css-font-2.4.1.tgz",
|
||||
"integrity": "sha512-QQ/iKiM43DM9+aujTL45Iz5o7gDeSFmy4LPl3HZmNcwCE++NxGazf+yFpY+wCb+YS23sDa1ghpo3zrNFOcHlow=="
|
||||
},
|
||||
"node_modules/markdown-it": {
|
||||
"version": "12.3.2",
|
||||
"resolved": "https://registry.npmjs.org/markdown-it/-/markdown-it-12.3.2.tgz",
|
||||
"integrity": "sha512-TchMembfxfNVpHkbtriWltGWc+m3xszaRD0CZup7GFFhzIgQqxIfn3eGj1yZpfuflzPvfkt611B2Q/Bsk1YnGg==",
|
||||
"dev": true,
|
||||
"dependencies": {
|
||||
"argparse": "^2.0.1",
|
||||
"entities": "~2.1.0",
|
||||
"linkify-it": "^3.0.1",
|
||||
"mdurl": "^1.0.1",
|
||||
"uc.micro": "^1.0.5"
|
||||
},
|
||||
"bin": {
|
||||
"markdown-it": "bin/markdown-it.js"
|
||||
}
|
||||
},
|
||||
"node_modules/markdown-it-anchor": {
|
||||
"version": "8.6.7",
|
||||
"resolved": "https://registry.npmjs.org/markdown-it-anchor/-/markdown-it-anchor-8.6.7.tgz",
|
||||
"integrity": "sha512-FlCHFwNnutLgVTflOYHPW2pPcl2AACqVzExlkGQNsi4CJgqOHN7YTgDd4LuhgN1BFO3TS0vLAruV1Td6dwWPJA==",
|
||||
"dev": true,
|
||||
"peerDependencies": {
|
||||
"@types/markdown-it": "*",
|
||||
"markdown-it": "*"
|
||||
}
|
||||
},
|
||||
"node_modules/marked": {
|
||||
"version": "4.3.0",
|
||||
"resolved": "https://registry.npmjs.org/marked/-/marked-4.3.0.tgz",
|
||||
"integrity": "sha512-PRsaiG84bK+AMvxziE/lCFss8juXjNaWzVbN5tXAm4XjeaS9NAHhop+PjQxz2A9h8Q4M/xGmzP8vqNwy6JeK0A==",
|
||||
"dev": true,
|
||||
"bin": {
|
||||
"marked": "bin/marked.js"
|
||||
},
|
||||
"engines": {
|
||||
"node": ">= 12"
|
||||
}
|
||||
},
|
||||
"node_modules/mdurl": {
|
||||
"version": "1.0.1",
|
||||
"resolved": "https://registry.npmjs.org/mdurl/-/mdurl-1.0.1.tgz",
|
||||
"integrity": "sha512-/sKlQJCBYVY9Ers9hqzKou4H6V5UWc/M59TH2dvkt+84itfnq7uFOMLpOiOS4ujvHP4etln18fmIxA5R5fll0g==",
|
||||
"dev": true
|
||||
},
|
||||
"node_modules/micromatch": {
|
||||
"version": "4.0.5",
|
||||
"resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz",
|
||||
|
|
@ -628,6 +829,18 @@
|
|||
"resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz",
|
||||
"integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q=="
|
||||
},
|
||||
"node_modules/mkdirp": {
|
||||
"version": "1.0.4",
|
||||
"resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz",
|
||||
"integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==",
|
||||
"dev": true,
|
||||
"bin": {
|
||||
"mkdirp": "bin/cmd.js"
|
||||
},
|
||||
"engines": {
|
||||
"node": ">=10"
|
||||
}
|
||||
},
|
||||
"node_modules/nanoid": {
|
||||
"version": "3.3.4",
|
||||
"resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.4.tgz",
|
||||
|
|
@ -756,6 +969,15 @@
|
|||
"quickselect": "^2.0.0"
|
||||
}
|
||||
},
|
||||
"node_modules/requizzle": {
|
||||
"version": "0.2.4",
|
||||
"resolved": "https://registry.npmjs.org/requizzle/-/requizzle-0.2.4.tgz",
|
||||
"integrity": "sha512-JRrFk1D4OQ4SqovXOgdav+K8EAhSB/LJZqCz8tbX0KObcdeM15Ss59ozWMBWmmINMagCwmqn4ZNryUGpBsl6Jw==",
|
||||
"dev": true,
|
||||
"dependencies": {
|
||||
"lodash": "^4.17.21"
|
||||
}
|
||||
},
|
||||
"node_modules/resolve": {
|
||||
"version": "1.22.1",
|
||||
"resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.1.tgz",
|
||||
|
|
@ -836,6 +1058,18 @@
|
|||
"node": ">=0.10.0"
|
||||
}
|
||||
},
|
||||
"node_modules/strip-json-comments": {
|
||||
"version": "3.1.1",
|
||||
"resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz",
|
||||
"integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==",
|
||||
"dev": true,
|
||||
"engines": {
|
||||
"node": ">=8"
|
||||
},
|
||||
"funding": {
|
||||
"url": "https://github.com/sponsors/sindresorhus"
|
||||
}
|
||||
},
|
||||
"node_modules/supports-preserve-symlinks-flag": {
|
||||
"version": "1.0.0",
|
||||
"resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz",
|
||||
|
|
@ -858,6 +1092,18 @@
|
|||
"node": ">=8.0"
|
||||
}
|
||||
},
|
||||
"node_modules/uc.micro": {
|
||||
"version": "1.0.6",
|
||||
"resolved": "https://registry.npmjs.org/uc.micro/-/uc.micro-1.0.6.tgz",
|
||||
"integrity": "sha512-8Y75pvTYkLJW2hWQHXxoqRgV7qb9B+9vFEtidML+7koHUFapnVJAZ6cKs+Qjz5Aw3aZWHMC6u0wJE3At+nSGwA==",
|
||||
"dev": true
|
||||
},
|
||||
"node_modules/underscore": {
|
||||
"version": "1.13.6",
|
||||
"resolved": "https://registry.npmjs.org/underscore/-/underscore-1.13.6.tgz",
|
||||
"integrity": "sha512-+A5Sja4HP1M08MaXya7p5LvjuM7K6q/2EaC0+iovj/wOcMsTzMvDFbasi/oSapiwOlt252IqsKqPjCl7huKS0A==",
|
||||
"dev": true
|
||||
},
|
||||
"node_modules/utm-latlng": {
|
||||
"version": "1.0.7",
|
||||
"resolved": "https://registry.npmjs.org/utm-latlng/-/utm-latlng-1.0.7.tgz",
|
||||
|
|
@ -936,6 +1182,12 @@
|
|||
"resolved": "https://registry.npmjs.org/xml-utils/-/xml-utils-1.2.0.tgz",
|
||||
"integrity": "sha512-z4unVPZruEDC3tfyd7wvWfjclnMz34iwQpv8H28H+qREpjKkR083MBvcrWXfJrIcrSmHR5ghguOcgQqWdnBpVA=="
|
||||
},
|
||||
"node_modules/xmlcreate": {
|
||||
"version": "2.0.4",
|
||||
"resolved": "https://registry.npmjs.org/xmlcreate/-/xmlcreate-2.0.4.tgz",
|
||||
"integrity": "sha512-nquOebG4sngPmGPICTS5EnxqhKbCmz5Ox5hsszI2T6U5qdrJizBc+0ilYSEjTSzU0yZcmvppztXe/5Al5fUwdg==",
|
||||
"dev": true
|
||||
},
|
||||
"node_modules/yallist": {
|
||||
"version": "4.0.0",
|
||||
"resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
|
||||
|
|
@ -943,6 +1195,12 @@
|
|||
}
|
||||
},
|
||||
"dependencies": {
|
||||
"@babel/parser": {
|
||||
"version": "7.23.6",
|
||||
"resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.23.6.tgz",
|
||||
"integrity": "sha512-Z2uID7YJ7oNvAI20O9X0bblw7Qqs8Q2hFy0R9tAfnfLkp5MW0UH9eUvnDSnFwKZ0AvgS1ucqR4KzvVHgnke1VQ==",
|
||||
"dev": true
|
||||
},
|
||||
"@esbuild/android-arm": {
|
||||
"version": "0.16.17",
|
||||
"resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.16.17.tgz",
|
||||
|
|
@ -1075,6 +1333,15 @@
|
|||
"integrity": "sha512-y+EHuSchhL7FjHgvQL/0fnnFmO4T1bhvWANX6gcnqTjtnKWbTvUMCpGnv2+t+31d7RzyEAYAd4u2fnIhHL6N/Q==",
|
||||
"optional": true
|
||||
},
|
||||
"@jsdoc/salty": {
|
||||
"version": "0.2.7",
|
||||
"resolved": "https://registry.npmjs.org/@jsdoc/salty/-/salty-0.2.7.tgz",
|
||||
"integrity": "sha512-mh8LbS9d4Jq84KLw8pzho7XC2q2/IJGiJss3xwRoLD1A+EE16SjN4PfaG4jRCzKegTFLlN0Zd8SdUPE6XdoPFg==",
|
||||
"dev": true,
|
||||
"requires": {
|
||||
"lodash": "^4.17.21"
|
||||
}
|
||||
},
|
||||
"@mapbox/jsonlint-lines-primitives": {
|
||||
"version": "2.0.2",
|
||||
"resolved": "https://registry.npmjs.org/@mapbox/jsonlint-lines-primitives/-/jsonlint-lines-primitives-2.0.2.tgz",
|
||||
|
|
@ -1116,6 +1383,40 @@
|
|||
"integrity": "sha512-P1st0aksCrn9sGZhp8GMYwBnQsbvAWsZAX44oXNNvLHGqAOcoVxmjZiohstwQ7SqKnbR47akdNi+uleWD8+g6A==",
|
||||
"peer": true
|
||||
},
|
||||
"@types/linkify-it": {
|
||||
"version": "3.0.5",
|
||||
"resolved": "https://registry.npmjs.org/@types/linkify-it/-/linkify-it-3.0.5.tgz",
|
||||
"integrity": "sha512-yg6E+u0/+Zjva+buc3EIb+29XEg4wltq7cSmd4Uc2EE/1nUVmxyzpX6gUXD0V8jIrG0r7YeOGVIbYRkxeooCtw==",
|
||||
"dev": true
|
||||
},
|
||||
"@types/markdown-it": {
|
||||
"version": "12.2.3",
|
||||
"resolved": "https://registry.npmjs.org/@types/markdown-it/-/markdown-it-12.2.3.tgz",
|
||||
"integrity": "sha512-GKMHFfv3458yYy+v/N8gjufHO6MSZKCOXpZc5GXIWWy8uldwfmPn98vp81gZ5f9SVw8YYBctgfJ22a2d7AOMeQ==",
|
||||
"dev": true,
|
||||
"requires": {
|
||||
"@types/linkify-it": "*",
|
||||
"@types/mdurl": "*"
|
||||
}
|
||||
},
|
||||
"@types/mdurl": {
|
||||
"version": "1.0.5",
|
||||
"resolved": "https://registry.npmjs.org/@types/mdurl/-/mdurl-1.0.5.tgz",
|
||||
"integrity": "sha512-6L6VymKTzYSrEf4Nev4Xa1LCHKrlTlYCBMTlQKFuddo1CvQcE52I0mwfOJayueUC7MJuXOeHTcIU683lzd0cUA==",
|
||||
"dev": true
|
||||
},
|
||||
"argparse": {
|
||||
"version": "2.0.1",
|
||||
"resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz",
|
||||
"integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==",
|
||||
"dev": true
|
||||
},
|
||||
"bluebird": {
|
||||
"version": "3.7.2",
|
||||
"resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.7.2.tgz",
|
||||
"integrity": "sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg==",
|
||||
"dev": true
|
||||
},
|
||||
"bootstrap": {
|
||||
"version": "5.3.2",
|
||||
"resolved": "https://registry.npmjs.org/bootstrap/-/bootstrap-5.3.2.tgz",
|
||||
|
|
@ -1130,6 +1431,15 @@
|
|||
"fill-range": "^7.0.1"
|
||||
}
|
||||
},
|
||||
"catharsis": {
|
||||
"version": "0.9.0",
|
||||
"resolved": "https://registry.npmjs.org/catharsis/-/catharsis-0.9.0.tgz",
|
||||
"integrity": "sha512-prMTQVpcns/tzFgFVkVp6ak6RykZyWb3gu8ckUpd6YkTlacOd3DXGJjIpD4Q6zJirizvaiAjSSHlOsA+6sNh2A==",
|
||||
"dev": true,
|
||||
"requires": {
|
||||
"lodash": "^4.17.15"
|
||||
}
|
||||
},
|
||||
"csscolorparser": {
|
||||
"version": "1.0.3",
|
||||
"resolved": "https://registry.npmjs.org/csscolorparser/-/csscolorparser-1.0.3.tgz",
|
||||
|
|
@ -1145,6 +1455,12 @@
|
|||
"resolved": "https://registry.npmjs.org/earcut/-/earcut-2.2.4.tgz",
|
||||
"integrity": "sha512-/pjZsA1b4RPHbeWZQn66SWS8nZZWLQQ23oE3Eam7aroEFGEvwKAsJfZ9ytiEMycfzXWpca4FA9QIOehf7PocBQ=="
|
||||
},
|
||||
"entities": {
|
||||
"version": "2.1.0",
|
||||
"resolved": "https://registry.npmjs.org/entities/-/entities-2.1.0.tgz",
|
||||
"integrity": "sha512-hCx1oky9PFrJ611mf0ifBLBRW8lUUVRlFolb5gWRfIELabBlbp9xZvrqZLZAs+NxFnbfQoeGd8wDkygjg7U85w==",
|
||||
"dev": true
|
||||
},
|
||||
"esbuild": {
|
||||
"version": "0.16.17",
|
||||
"resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.16.17.tgz",
|
||||
|
|
@ -1174,6 +1490,12 @@
|
|||
"@esbuild/win32-x64": "0.16.17"
|
||||
}
|
||||
},
|
||||
"escape-string-regexp": {
|
||||
"version": "2.0.0",
|
||||
"resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz",
|
||||
"integrity": "sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==",
|
||||
"dev": true
|
||||
},
|
||||
"fill-range": {
|
||||
"version": "7.0.1",
|
||||
"resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz",
|
||||
|
|
@ -1207,6 +1529,12 @@
|
|||
"xml-utils": "^1.0.2"
|
||||
}
|
||||
},
|
||||
"graceful-fs": {
|
||||
"version": "4.2.11",
|
||||
"resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz",
|
||||
"integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==",
|
||||
"dev": true
|
||||
},
|
||||
"has": {
|
||||
"version": "1.0.3",
|
||||
"resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz",
|
||||
|
|
@ -1233,16 +1561,72 @@
|
|||
"resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz",
|
||||
"integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng=="
|
||||
},
|
||||
"js2xmlparser": {
|
||||
"version": "4.0.2",
|
||||
"resolved": "https://registry.npmjs.org/js2xmlparser/-/js2xmlparser-4.0.2.tgz",
|
||||
"integrity": "sha512-6n4D8gLlLf1n5mNLQPRfViYzu9RATblzPEtm1SthMX1Pjao0r9YI9nw7ZIfRxQMERS87mcswrg+r/OYrPRX6jA==",
|
||||
"dev": true,
|
||||
"requires": {
|
||||
"xmlcreate": "^2.0.4"
|
||||
}
|
||||
},
|
||||
"jsdoc": {
|
||||
"version": "4.0.2",
|
||||
"resolved": "https://registry.npmjs.org/jsdoc/-/jsdoc-4.0.2.tgz",
|
||||
"integrity": "sha512-e8cIg2z62InH7azBBi3EsSEqrKx+nUtAS5bBcYTSpZFA+vhNPyhv8PTFZ0WsjOPDj04/dOLlm08EDcQJDqaGQg==",
|
||||
"dev": true,
|
||||
"requires": {
|
||||
"@babel/parser": "^7.20.15",
|
||||
"@jsdoc/salty": "^0.2.1",
|
||||
"@types/markdown-it": "^12.2.3",
|
||||
"bluebird": "^3.7.2",
|
||||
"catharsis": "^0.9.0",
|
||||
"escape-string-regexp": "^2.0.0",
|
||||
"js2xmlparser": "^4.0.2",
|
||||
"klaw": "^3.0.0",
|
||||
"markdown-it": "^12.3.2",
|
||||
"markdown-it-anchor": "^8.4.1",
|
||||
"marked": "^4.0.10",
|
||||
"mkdirp": "^1.0.4",
|
||||
"requizzle": "^0.2.3",
|
||||
"strip-json-comments": "^3.1.0",
|
||||
"underscore": "~1.13.2"
|
||||
}
|
||||
},
|
||||
"json-stringify-pretty-compact": {
|
||||
"version": "2.0.0",
|
||||
"resolved": "https://registry.npmjs.org/json-stringify-pretty-compact/-/json-stringify-pretty-compact-2.0.0.tgz",
|
||||
"integrity": "sha512-WRitRfs6BGq4q8gTgOy4ek7iPFXjbra0H3PmDLKm2xnZ+Gh1HUhiKGgCZkSPNULlP7mvfu6FV/mOLhCarspADQ=="
|
||||
},
|
||||
"klaw": {
|
||||
"version": "3.0.0",
|
||||
"resolved": "https://registry.npmjs.org/klaw/-/klaw-3.0.0.tgz",
|
||||
"integrity": "sha512-0Fo5oir+O9jnXu5EefYbVK+mHMBeEVEy2cmctR1O1NECcCkPRreJKrS6Qt/j3KC2C148Dfo9i3pCmCMsdqGr0g==",
|
||||
"dev": true,
|
||||
"requires": {
|
||||
"graceful-fs": "^4.1.9"
|
||||
}
|
||||
},
|
||||
"lerc": {
|
||||
"version": "3.0.0",
|
||||
"resolved": "https://registry.npmjs.org/lerc/-/lerc-3.0.0.tgz",
|
||||
"integrity": "sha512-Rm4J/WaHhRa93nCN2mwWDZFoRVF18G1f47C+kvQWyHGEZxFpTUi73p7lMVSAndyxGt6lJ2/CFbOcf9ra5p8aww=="
|
||||
},
|
||||
"linkify-it": {
|
||||
"version": "3.0.3",
|
||||
"resolved": "https://registry.npmjs.org/linkify-it/-/linkify-it-3.0.3.tgz",
|
||||
"integrity": "sha512-ynTsyrFSdE5oZ/O9GEf00kPngmOfVwazR5GKDq6EYfhlpFug3J2zybX56a2PRRpc9P+FuSoGNAwjlbDs9jJBPQ==",
|
||||
"dev": true,
|
||||
"requires": {
|
||||
"uc.micro": "^1.0.1"
|
||||
}
|
||||
},
|
||||
"lodash": {
|
||||
"version": "4.17.21",
|
||||
"resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz",
|
||||
"integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==",
|
||||
"dev": true
|
||||
},
|
||||
"lru-cache": {
|
||||
"version": "6.0.0",
|
||||
"resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz",
|
||||
|
|
@ -1256,6 +1640,38 @@
|
|||
"resolved": "https://registry.npmjs.org/mapbox-to-css-font/-/mapbox-to-css-font-2.4.1.tgz",
|
||||
"integrity": "sha512-QQ/iKiM43DM9+aujTL45Iz5o7gDeSFmy4LPl3HZmNcwCE++NxGazf+yFpY+wCb+YS23sDa1ghpo3zrNFOcHlow=="
|
||||
},
|
||||
"markdown-it": {
|
||||
"version": "12.3.2",
|
||||
"resolved": "https://registry.npmjs.org/markdown-it/-/markdown-it-12.3.2.tgz",
|
||||
"integrity": "sha512-TchMembfxfNVpHkbtriWltGWc+m3xszaRD0CZup7GFFhzIgQqxIfn3eGj1yZpfuflzPvfkt611B2Q/Bsk1YnGg==",
|
||||
"dev": true,
|
||||
"requires": {
|
||||
"argparse": "^2.0.1",
|
||||
"entities": "~2.1.0",
|
||||
"linkify-it": "^3.0.1",
|
||||
"mdurl": "^1.0.1",
|
||||
"uc.micro": "^1.0.5"
|
||||
}
|
||||
},
|
||||
"markdown-it-anchor": {
|
||||
"version": "8.6.7",
|
||||
"resolved": "https://registry.npmjs.org/markdown-it-anchor/-/markdown-it-anchor-8.6.7.tgz",
|
||||
"integrity": "sha512-FlCHFwNnutLgVTflOYHPW2pPcl2AACqVzExlkGQNsi4CJgqOHN7YTgDd4LuhgN1BFO3TS0vLAruV1Td6dwWPJA==",
|
||||
"dev": true,
|
||||
"requires": {}
|
||||
},
|
||||
"marked": {
|
||||
"version": "4.3.0",
|
||||
"resolved": "https://registry.npmjs.org/marked/-/marked-4.3.0.tgz",
|
||||
"integrity": "sha512-PRsaiG84bK+AMvxziE/lCFss8juXjNaWzVbN5tXAm4XjeaS9NAHhop+PjQxz2A9h8Q4M/xGmzP8vqNwy6JeK0A==",
|
||||
"dev": true
|
||||
},
|
||||
"mdurl": {
|
||||
"version": "1.0.1",
|
||||
"resolved": "https://registry.npmjs.org/mdurl/-/mdurl-1.0.1.tgz",
|
||||
"integrity": "sha512-/sKlQJCBYVY9Ers9hqzKou4H6V5UWc/M59TH2dvkt+84itfnq7uFOMLpOiOS4ujvHP4etln18fmIxA5R5fll0g==",
|
||||
"dev": true
|
||||
},
|
||||
"micromatch": {
|
||||
"version": "4.0.5",
|
||||
"resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz",
|
||||
|
|
@ -1270,6 +1686,12 @@
|
|||
"resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz",
|
||||
"integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q=="
|
||||
},
|
||||
"mkdirp": {
|
||||
"version": "1.0.4",
|
||||
"resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz",
|
||||
"integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==",
|
||||
"dev": true
|
||||
},
|
||||
"nanoid": {
|
||||
"version": "3.3.4",
|
||||
"resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.4.tgz",
|
||||
|
|
@ -1366,6 +1788,15 @@
|
|||
"quickselect": "^2.0.0"
|
||||
}
|
||||
},
|
||||
"requizzle": {
|
||||
"version": "0.2.4",
|
||||
"resolved": "https://registry.npmjs.org/requizzle/-/requizzle-0.2.4.tgz",
|
||||
"integrity": "sha512-JRrFk1D4OQ4SqovXOgdav+K8EAhSB/LJZqCz8tbX0KObcdeM15Ss59ozWMBWmmINMagCwmqn4ZNryUGpBsl6Jw==",
|
||||
"dev": true,
|
||||
"requires": {
|
||||
"lodash": "^4.17.21"
|
||||
}
|
||||
},
|
||||
"resolve": {
|
||||
"version": "1.22.1",
|
||||
"resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.1.tgz",
|
||||
|
|
@ -1421,6 +1852,12 @@
|
|||
"resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.2.tgz",
|
||||
"integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw=="
|
||||
},
|
||||
"strip-json-comments": {
|
||||
"version": "3.1.1",
|
||||
"resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz",
|
||||
"integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==",
|
||||
"dev": true
|
||||
},
|
||||
"supports-preserve-symlinks-flag": {
|
||||
"version": "1.0.0",
|
||||
"resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz",
|
||||
|
|
@ -1434,6 +1871,18 @@
|
|||
"is-number": "^7.0.0"
|
||||
}
|
||||
},
|
||||
"uc.micro": {
|
||||
"version": "1.0.6",
|
||||
"resolved": "https://registry.npmjs.org/uc.micro/-/uc.micro-1.0.6.tgz",
|
||||
"integrity": "sha512-8Y75pvTYkLJW2hWQHXxoqRgV7qb9B+9vFEtidML+7koHUFapnVJAZ6cKs+Qjz5Aw3aZWHMC6u0wJE3At+nSGwA==",
|
||||
"dev": true
|
||||
},
|
||||
"underscore": {
|
||||
"version": "1.13.6",
|
||||
"resolved": "https://registry.npmjs.org/underscore/-/underscore-1.13.6.tgz",
|
||||
"integrity": "sha512-+A5Sja4HP1M08MaXya7p5LvjuM7K6q/2EaC0+iovj/wOcMsTzMvDFbasi/oSapiwOlt252IqsKqPjCl7huKS0A==",
|
||||
"dev": true
|
||||
},
|
||||
"utm-latlng": {
|
||||
"version": "1.0.7",
|
||||
"resolved": "https://registry.npmjs.org/utm-latlng/-/utm-latlng-1.0.7.tgz",
|
||||
|
|
@ -1469,6 +1918,12 @@
|
|||
"resolved": "https://registry.npmjs.org/xml-utils/-/xml-utils-1.2.0.tgz",
|
||||
"integrity": "sha512-z4unVPZruEDC3tfyd7wvWfjclnMz34iwQpv8H28H+qREpjKkR083MBvcrWXfJrIcrSmHR5ghguOcgQqWdnBpVA=="
|
||||
},
|
||||
"xmlcreate": {
|
||||
"version": "2.0.4",
|
||||
"resolved": "https://registry.npmjs.org/xmlcreate/-/xmlcreate-2.0.4.tgz",
|
||||
"integrity": "sha512-nquOebG4sngPmGPICTS5EnxqhKbCmz5Ox5hsszI2T6U5qdrJizBc+0ilYSEjTSzU0yZcmvppztXe/5Al5fUwdg==",
|
||||
"dev": true
|
||||
},
|
||||
"yallist": {
|
||||
"version": "4.0.0",
|
||||
"resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
|
||||
|
|
|
|||
|
|
@ -7,6 +7,7 @@
|
|||
"serve": "vite preview"
|
||||
},
|
||||
"devDependencies": {
|
||||
"jsdoc": "^4.0.2",
|
||||
"vite": "^4.0.4"
|
||||
},
|
||||
"dependencies": {
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue