From 5edb166b3d7e4b389f0704f24c1caddfb25fe089 Mon Sep 17 00:00:00 2001
From: Glenn Vorhes <gavorhes@wisc.edu>
Date: Fri, 10 Mar 2017 20:45:21 -0600
Subject: [PATCH] added no param geojson vector layer

---
 dist/domUtil/media-control.js                 |   2 +-
 dist/layers/LayerBaseVectorGeoJson.d.ts       |   4 +-
 dist/layers/LayerBaseVectorGeoJson.js         |   4 +-
 src/layers/LayerBaseVectorGeoJson.ts          |   5 +-
 test/data/geoJsonFeatures.ts                  | 968 ++++++++++++++++++
 .../layers/LayerBaseVectorGeoJsonSpec.ts      |  44 +
 test/specs/spec.ts                            |  19 +-
 7 files changed, 1020 insertions(+), 26 deletions(-)
 create mode 100644 test/data/geoJsonFeatures.ts
 create mode 100644 test/specs/layers/LayerBaseVectorGeoJsonSpec.ts

diff --git a/dist/domUtil/media-control.js b/dist/domUtil/media-control.js
index 5140cbc..7dd6480 100644
--- a/dist/domUtil/media-control.js
+++ b/dist/domUtil/media-control.js
@@ -208,4 +208,4 @@ var MediaControl = (function () {
 }());
 exports.MediaControl = MediaControl;
 nm.MediaControl = MediaControl;
-//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"media-control.js","sourceRoot":"","sources":["../../src/domUtil/media-control.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Created by gavorhes on 11/2/2015.\r\n */\r\n\r\nimport provide from '../util/provide';\r\nimport {rangeChange} from './range-change';\r\nimport $ = require('jquery');\r\n\r\nlet nm = provide('domUtil');\r\n\r\n/**\r\n * @callback mediaCallback\r\n * @param {number} tm\r\n */\r\n\r\nfunction timeToLocalDateString(tm) {\r\n    \"use strict\";\r\n    let d = new Date(tm);\r\n    let p1 = d.toLocaleTimeString().split(' ');\r\n    let p2 = p1[0].split(':');\r\n    p2 = p2.slice(0, 2);\r\n\r\n    return d.toLocaleDateString() + '<br>' + p2.join(':') + ' ' + p1[1];\r\n}\r\n\r\nexport interface changeFunction{\r\n    (newVal?: number): void;\r\n}\r\n\r\nexport interface mediaRangeConfig{\r\n    min?: number;\r\n    max?: number;\r\n    val?: number;\r\n    step?: number;\r\n    playInterval?: number;\r\n    showAsDate?: boolean;\r\n}\r\n\r\n\r\n\r\nexport class MediaControl {\r\n    _container: JQuery;\r\n    _min: number;\r\n    _max: number;\r\n    _playInterval: number;\r\n    _step: number;\r\n    _currentValue: number;\r\n\r\n    _playing: boolean;\r\n\r\n    _$btnStop: JQuery;\r\n    _$slider: JQuery;\r\n    _$valLabelVal: JQuery;\r\n    _$valLabelMin: JQuery;\r\n    _$valLabelMax: JQuery;\r\n    _interval: number;\r\n    _showAsDate: boolean;\r\n\r\n    _changeFunc: changeFunction;\r\n\r\n    /**\r\n     *\r\n     * @param element\r\n     * @param changeFunc\r\n     * @param mediaConfig\r\n     */\r\n    constructor(\r\n        element: JQuery|HTMLElement|string,\r\n        changeFunc: changeFunction = (): void => {return;},\r\n        mediaConfig: mediaRangeConfig = {}) {\r\n\r\n        mediaConfig.min = typeof mediaConfig.min == 'number' ? mediaConfig.min : 0;\r\n        mediaConfig.max = typeof mediaConfig.max == 'number' ? mediaConfig.max : 100;\r\n        mediaConfig.val = typeof mediaConfig.val == 'number' ? mediaConfig.val : 0;\r\n        mediaConfig.step = typeof mediaConfig.step == 'number' ? mediaConfig.step : 5;\r\n        mediaConfig.playInterval = typeof mediaConfig.playInterval == 'number' ? mediaConfig.playInterval : 500;\r\n        mediaConfig.showAsDate = typeof mediaConfig.showAsDate == 'boolean' ? mediaConfig.showAsDate : false;\r\n\r\n        if (typeof  element == 'string'){\r\n            this._container = $('#' + element);\r\n        }\r\n        else if (typeof element['style'] !== 'undefined'){\r\n            this._container = $(element);\r\n        } else {\r\n            this._container = element as JQuery;\r\n        }\r\n\r\n        this._container.addClass('media-control-container');\r\n        this._playInterval = mediaConfig.playInterval;\r\n        this._changeFunc = changeFunc;\r\n\r\n        this._showAsDate = mediaConfig.showAsDate;\r\n\r\n        this._currentValue = undefined;\r\n        this._min = undefined;\r\n        this._max = undefined;\r\n        this._step = undefined;\r\n        this._playing = false;\r\n\r\n        let htmlStr =\r\n            '<span class=\"media-player-button media-back\"></span>' +\r\n            '<span class=\"media-player-button media-play\"></span>' +\r\n            '<span class=\"media-player-button media-pause media-disabled\"></span>' +\r\n            '<span class=\"media-player-button media-stop media-disabled\" ></span>' +\r\n            '<span class=\"media-player-button media-ahead\"></span>' +\r\n            `<input type=\"range\">` +\r\n            `<div class=\"media-control-value-label-container\">` +\r\n            `<span class=\"media-control-value-label-min\"></span>` +\r\n            `<span class=\"media-control-value-label-val\"></span>` +\r\n            `<span class=\"media-control-value-label-max\"></span>` +\r\n            `</div>`;\r\n\r\n        this._container.append(htmlStr);\r\n\r\n        // let btnPause = this._container.find('.media-pause');\r\n        let btnPlay = this._container.find('.media-play');\r\n        this._$btnStop = this._container.find('.media-stop');\r\n        let btnAhead = this._container.find('.media-ahead');\r\n        let btnBack = this._container.find('.media-back');\r\n        this._$slider = this._container.find('input[type=range]');\r\n\r\n        this._$valLabelMin = this._container.find('.media-control-value-label-min');\r\n        this._$valLabelVal = this._container.find('.media-control-value-label-val');\r\n        this._$valLabelMax = this._container.find('.media-control-value-label-max');\r\n\r\n        this.setMinMaxValueStep(mediaConfig.min, mediaConfig.max, mediaConfig.val, mediaConfig.step);\r\n\r\n        rangeChange(this._$slider,(newVal) => { this.currentValue = newVal;}, 100);\r\n\r\n        let ___this = this;\r\n\r\n        btnPlay.click(function () {\r\n            let $this = $(this);\r\n            $this.addClass('media-disabled');\r\n            ___this._$btnStop.removeClass('media-disabled');\r\n            btnAhead.addClass('media-locked');\r\n            btnBack.addClass('media-locked');\r\n            ___this._$slider.prop('disabled', true);\r\n            ___this._playing = true;\r\n\r\n            ___this._interval = setInterval(function () {\r\n                ___this.currentValue += ___this._step;\r\n            }, ___this._playInterval) as number;\r\n        }) ;\r\n\r\n        this._$btnStop.click(function () {\r\n            clearInterval(___this._interval);\r\n            let $this = $(this);\r\n            $this.addClass('media-disabled');\r\n            btnPlay.removeClass('media-disabled');\r\n            btnAhead.removeClass('media-locked');\r\n            btnBack.removeClass('media-locked');\r\n            ___this._$slider.prop('disabled', false);\r\n            ___this._playing = false;\r\n        });\r\n\r\n        btnAhead.click(function () {\r\n            ___this.currentValue = ___this.currentValue + ___this._step;\r\n        });\r\n\r\n        btnBack.click(function () {\r\n            ___this.currentValue = ___this.currentValue - ___this._step;\r\n        });\r\n    }\r\n\r\n    stopPlaying(){\r\n        if (this._playing){\r\n            this._$btnStop.trigger('click');\r\n        }\r\n    }\r\n\r\n    get playing(){\r\n        return this._playing;\r\n    }\r\n\r\n    get min() {\r\n        return this._min;\r\n    }\r\n\r\n    get max() {\r\n        return this._max;\r\n    }\r\n\r\n    get step() {\r\n        return this._step;\r\n    }\r\n\r\n    get currentValue() {\r\n        return this._currentValue;\r\n    }\r\n\r\n    set currentValue(newValue) {\r\n        if (newValue > this._max) {\r\n            newValue = this._min;\r\n        } else if (newValue < this._min) {\r\n            newValue = this._max;\r\n        }\r\n        this._currentValue = newValue;\r\n        this._$slider.val(this._currentValue.toFixed(2));\r\n\r\n        if (this._showAsDate) {\r\n            this._$valLabelVal.html(timeToLocalDateString(this.currentValue));\r\n        } else {\r\n            this._$valLabelVal.html(this.currentValue.toString());\r\n        }\r\n\r\n        this._changeFunc(newValue);\r\n    }\r\n\r\n    /**\r\n     * set min and max value with step\r\n     * @param {number} newMin the new min\r\n     * @param {number} newMax the new mas\r\n     * @param {number} [newValue=newMin] the value to set\r\n     * @param {number} [newStep=(newMax-newMin)/20] step value\r\n     */\r\n    setMinMaxValueStep(newMin, newMax, newValue, newStep) {\r\n        this._min = newMin;\r\n        this._max = newMax;\r\n\r\n        newValue = typeof newValue == 'number' ? newValue : newMin;\r\n        newStep = typeof newStep == 'number' ? newStep : (newMax-newMin)/20;\r\n\r\n        this._currentValue = newValue;\r\n        this._step = newStep;\r\n\r\n        this._$slider.prop('min', this.min.toString());\r\n        this._$slider.prop('max', this.max.toString());\r\n        this._$slider.prop('step', this.step.toString());\r\n        this._$slider.val(this.currentValue.toString());\r\n\r\n        if (this._showAsDate) {\r\n            this._$valLabelMin.html(timeToLocalDateString(this._min));\r\n            this._$valLabelVal.html(timeToLocalDateString(this.currentValue));\r\n            this._$valLabelMax.html(timeToLocalDateString(this._max));\r\n        } else {\r\n            this._$valLabelMin.html(this._min.toString());\r\n            this._$valLabelVal.html(this.currentValue.toString());\r\n            this._$valLabelMax.html(this._max.toString());\r\n        }\r\n    }\r\n\r\n    /**\r\n     *\r\n     * @param {mediaCallback} newFunc the callback on change\r\n     */\r\n    set changeFunction(newFunc: changeFunction) {\r\n        this._changeFunc = newFunc;\r\n    }\r\n}\r\n\r\nnm.MediaControl = MediaControl;\r\n\r\n"]}
\ No newline at end of file
+//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"media-control.js","sourceRoot":"","sources":["../../src/domUtil/media-control.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Created by gavorhes on 11/2/2015.\r\n */\r\n\r\nimport provide from '../util/provide';\r\nimport {rangeChange} from './range-change';\r\nimport $ = require('jquery');\r\n\r\nlet nm = provide('domUtil');\r\n\r\n/**\r\n * @callback mediaCallback\r\n * @param {number} tm\r\n */\r\n\r\nfunction timeToLocalDateString(tm) {\r\n    \"use strict\";\r\n    let d = new Date(tm);\r\n    let p1 = d.toLocaleTimeString().split(' ');\r\n    let p2 = p1[0].split(':');\r\n    p2 = p2.slice(0, 2);\r\n\r\n    return d.toLocaleDateString() + '<br>' + p2.join(':') + ' ' + p1[1];\r\n}\r\n\r\nexport interface changeFunction{\r\n    (newVal?: number): void;\r\n}\r\n\r\nexport interface mediaRangeConfig{\r\n    min?: number;\r\n    max?: number;\r\n    val?: number;\r\n    step?: number;\r\n    playInterval?: number;\r\n    showAsDate?: boolean;\r\n}\r\n\r\n\r\n\r\nexport class MediaControl {\r\n    _container: JQuery;\r\n    _min: number;\r\n    _max: number;\r\n    _playInterval: number;\r\n    _step: number;\r\n    _currentValue: number;\r\n\r\n    _playing: boolean;\r\n\r\n    _$btnStop: JQuery;\r\n    _$slider: JQuery;\r\n    _$valLabelVal: JQuery;\r\n    _$valLabelMin: JQuery;\r\n    _$valLabelMax: JQuery;\r\n    _interval: number;\r\n    _showAsDate: boolean;\r\n\r\n    _changeFunc: changeFunction;\r\n\r\n    /**\r\n     *\r\n     * @param element\r\n     * @param changeFunc\r\n     * @param mediaConfig\r\n     */\r\n    constructor(\r\n        element: JQuery|HTMLElement|string,\r\n        changeFunc: changeFunction = (): void => {return;},\r\n        mediaConfig: mediaRangeConfig = {}) {\r\n\r\n        mediaConfig.min = typeof mediaConfig.min == 'number' ? mediaConfig.min : 0;\r\n        mediaConfig.max = typeof mediaConfig.max == 'number' ? mediaConfig.max : 100;\r\n        mediaConfig.val = typeof mediaConfig.val == 'number' ? mediaConfig.val : 0;\r\n        mediaConfig.step = typeof mediaConfig.step == 'number' ? mediaConfig.step : 5;\r\n        mediaConfig.playInterval = typeof mediaConfig.playInterval == 'number' ? mediaConfig.playInterval : 500;\r\n        mediaConfig.showAsDate = typeof mediaConfig.showAsDate == 'boolean' ? mediaConfig.showAsDate : false;\r\n\r\n        if (typeof  element == 'string'){\r\n            this._container = $('#' + element);\r\n        }\r\n        else if (typeof element['style'] !== 'undefined'){\r\n            this._container = $(element);\r\n        } else {\r\n            this._container = element as JQuery;\r\n        }\r\n\r\n        this._container.addClass('media-control-container');\r\n        this._playInterval = mediaConfig.playInterval;\r\n        this._changeFunc = changeFunc;\r\n\r\n        this._showAsDate = mediaConfig.showAsDate;\r\n\r\n        this._currentValue = undefined;\r\n        this._min = undefined;\r\n        this._max = undefined;\r\n        this._step = undefined;\r\n        this._playing = false;\r\n\r\n        let htmlStr =\r\n            '<span class=\"media-player-button media-back\"></span>' +\r\n            '<span class=\"media-player-button media-play\"></span>' +\r\n            '<span class=\"media-player-button media-pause media-disabled\"></span>' +\r\n            '<span class=\"media-player-button media-stop media-disabled\" ></span>' +\r\n            '<span class=\"media-player-button media-ahead\"></span>' +\r\n            `<input type=\"range\">` +\r\n            `<div class=\"media-control-value-label-container\">` +\r\n            `<span class=\"media-control-value-label-min\"></span>` +\r\n            `<span class=\"media-control-value-label-val\"></span>` +\r\n            `<span class=\"media-control-value-label-max\"></span>` +\r\n            `</div>`;\r\n\r\n        this._container.append(htmlStr);\r\n\r\n        // let btnPause = this._container.find('.media-pause');\r\n        let btnPlay = this._container.find('.media-play');\r\n        this._$btnStop = this._container.find('.media-stop');\r\n        let btnAhead = this._container.find('.media-ahead');\r\n        let btnBack = this._container.find('.media-back');\r\n        this._$slider = this._container.find('input[type=range]');\r\n\r\n        this._$valLabelMin = this._container.find('.media-control-value-label-min');\r\n        this._$valLabelVal = this._container.find('.media-control-value-label-val');\r\n        this._$valLabelMax = this._container.find('.media-control-value-label-max');\r\n\r\n        this.setMinMaxValueStep(mediaConfig.min, mediaConfig.max, mediaConfig.val, mediaConfig.step);\r\n\r\n        rangeChange(this._$slider,(newVal) => { this.currentValue = newVal;}, 100);\r\n\r\n        let ___this = this;\r\n\r\n        btnPlay.click(function () {\r\n            let $this = $(this);\r\n            $this.addClass('media-disabled');\r\n            ___this._$btnStop.removeClass('media-disabled');\r\n            btnAhead.addClass('media-locked');\r\n            btnBack.addClass('media-locked');\r\n            ___this._$slider.prop('disabled', true);\r\n            ___this._playing = true;\r\n\r\n            ___this._interval = setInterval(function () {\r\n                ___this.currentValue += ___this._step;\r\n            }, ___this._playInterval);\r\n        });\r\n\r\n        this._$btnStop.click(function () {\r\n            clearInterval(___this._interval);\r\n            let $this = $(this);\r\n            $this.addClass('media-disabled');\r\n            btnPlay.removeClass('media-disabled');\r\n            btnAhead.removeClass('media-locked');\r\n            btnBack.removeClass('media-locked');\r\n            ___this._$slider.prop('disabled', false);\r\n            ___this._playing = false;\r\n        });\r\n\r\n        btnAhead.click(function () {\r\n            ___this.currentValue = ___this.currentValue + ___this._step;\r\n        });\r\n\r\n        btnBack.click(function () {\r\n            ___this.currentValue = ___this.currentValue - ___this._step;\r\n        });\r\n    }\r\n\r\n    stopPlaying(){\r\n        if (this._playing){\r\n            this._$btnStop.trigger('click');\r\n        }\r\n    }\r\n\r\n    get playing(){\r\n        return this._playing;\r\n    }\r\n\r\n    get min() {\r\n        return this._min;\r\n    }\r\n\r\n    get max() {\r\n        return this._max;\r\n    }\r\n\r\n    get step() {\r\n        return this._step;\r\n    }\r\n\r\n    get currentValue() {\r\n        return this._currentValue;\r\n    }\r\n\r\n    set currentValue(newValue) {\r\n        if (newValue > this._max) {\r\n            newValue = this._min;\r\n        } else if (newValue < this._min) {\r\n            newValue = this._max;\r\n        }\r\n        this._currentValue = newValue;\r\n        this._$slider.val(this._currentValue.toFixed(2));\r\n\r\n        if (this._showAsDate) {\r\n            this._$valLabelVal.html(timeToLocalDateString(this.currentValue));\r\n        } else {\r\n            this._$valLabelVal.html(this.currentValue.toString());\r\n        }\r\n\r\n        this._changeFunc(newValue);\r\n    }\r\n\r\n    /**\r\n     * set min and max value with step\r\n     * @param {number} newMin the new min\r\n     * @param {number} newMax the new mas\r\n     * @param {number} [newValue=newMin] the value to set\r\n     * @param {number} [newStep=(newMax-newMin)/20] step value\r\n     */\r\n    setMinMaxValueStep(newMin, newMax, newValue, newStep) {\r\n        this._min = newMin;\r\n        this._max = newMax;\r\n\r\n        newValue = typeof newValue == 'number' ? newValue : newMin;\r\n        newStep = typeof newStep == 'number' ? newStep : (newMax-newMin)/20;\r\n\r\n        this._currentValue = newValue;\r\n        this._step = newStep;\r\n\r\n        this._$slider.prop('min', this.min.toString());\r\n        this._$slider.prop('max', this.max.toString());\r\n        this._$slider.prop('step', this.step.toString());\r\n        this._$slider.val(this.currentValue.toString());\r\n\r\n        if (this._showAsDate) {\r\n            this._$valLabelMin.html(timeToLocalDateString(this._min));\r\n            this._$valLabelVal.html(timeToLocalDateString(this.currentValue));\r\n            this._$valLabelMax.html(timeToLocalDateString(this._max));\r\n        } else {\r\n            this._$valLabelMin.html(this._min.toString());\r\n            this._$valLabelVal.html(this.currentValue.toString());\r\n            this._$valLabelMax.html(this._max.toString());\r\n        }\r\n    }\r\n\r\n    /**\r\n     *\r\n     * @param {mediaCallback} newFunc the callback on change\r\n     */\r\n    set changeFunction(newFunc: changeFunction) {\r\n        this._changeFunc = newFunc;\r\n    }\r\n}\r\n\r\nnm.MediaControl = MediaControl;\r\n\r\n"]}
\ No newline at end of file
diff --git a/dist/layers/LayerBaseVectorGeoJson.d.ts b/dist/layers/LayerBaseVectorGeoJson.d.ts
index b6268cf..4b37c5c 100644
--- a/dist/layers/LayerBaseVectorGeoJson.d.ts
+++ b/dist/layers/LayerBaseVectorGeoJson.d.ts
@@ -20,7 +20,7 @@ export declare class LayerBaseVectorGeoJson extends LayerBaseVector {
     _geoJsonFormat: ol.format.GeoJSON;
     _transform: crsTransform;
     /**
-     * @param {string|undefined|null} url - resource url, set to '' to make blank layer
+     * @param {string|null} url - resource url, set to '' to make blank layer
      * @param {object} options - config
      * @param {string} [options.id] - layer id
      * @param {string} [options.name=Unnamed Layer] - layer name
@@ -46,7 +46,7 @@ export declare class LayerBaseVectorGeoJson extends LayerBaseVector {
      * @param {mapMoveMakeGetParams} [options.mapMoveMakeGetParams=function(lyr, extent, zoomLevel){}] function to create additional map move params
      * @param {MapMoveCls} [options.mapMoveObj=mapMove] alternate map move object for use with multi map pages
      */
-    constructor(url: any, options?: LayerBaseVectorGeoJsonOptions);
+    constructor(url?: string, options?: LayerBaseVectorGeoJsonOptions);
     /**
      * add feature collection
      * @param {object} featureCollection - as geojson object
diff --git a/dist/layers/LayerBaseVectorGeoJson.js b/dist/layers/LayerBaseVectorGeoJson.js
index 80de494..ece4cc0 100644
--- a/dist/layers/LayerBaseVectorGeoJson.js
+++ b/dist/layers/LayerBaseVectorGeoJson.js
@@ -27,7 +27,7 @@ var nm = provide_1.default('layers');
 var LayerBaseVectorGeoJson = (function (_super) {
     __extends(LayerBaseVectorGeoJson, _super);
     /**
-     * @param {string|undefined|null} url - resource url, set to '' to make blank layer
+     * @param {string|null} url - resource url, set to '' to make blank layer
      * @param {object} options - config
      * @param {string} [options.id] - layer id
      * @param {string} [options.name=Unnamed Layer] - layer name
@@ -106,4 +106,4 @@ var LayerBaseVectorGeoJson = (function (_super) {
 exports.LayerBaseVectorGeoJson = LayerBaseVectorGeoJson;
 nm.LayerBaseVectorGeoJson = LayerBaseVectorGeoJson;
 exports.default = LayerBaseVectorGeoJson;
-//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"LayerBaseVectorGeoJson.js","sourceRoot":"","sources":["../../src/layers/LayerBaseVectorGeoJson.ts"],"names":[],"mappings":"AAAA;;GAEG;;;;;;;;;;;;;AAEH,qDAA0E;AAC1E,2CAAsC;AACtC,8BAAiC;AACjC,0BAA6B;AAE7B,+CAAiD;AACjD,wDAAkD;AAElD,IAAI,EAAE,GAAG,iBAAO,CAAC,QAAQ,CAAC,CAAC;AAc3B;;;GAGG;AACH;IAA4C,0CAAe;IAIvD;;;;;;;;;;;;;;;;;;;;;;;;;;OA0BG;IACH,gCAAY,GAAG,EAAE,OAA2C;QAA3C,wBAAA,EAAA,YAA2C;QAA5D,iBAaC;QAZG,GAAG,GAAG,OAAO,GAAG,IAAI,QAAQ,GAAG,GAAG,GAAG,EAAE,CAAC;QACxC,QAAA,kBAAM,GAAG,EAAE,OAAO,CAAC,SAAC;QAEpB,KAAI,CAAC,cAAc,GAAG,IAAI,EAAE,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;QAE9C,KAAI,CAAC,UAAU,GAAG,OAAO,CAAC,SAAS,IAAI,EAAE,CAAC;QAC1C,KAAI,CAAC,UAAU,CAAC,cAAc,GAAG,KAAI,CAAC,UAAU,CAAC,cAAc,IAAI,IAAI,CAAC,QAAQ,CAAC;QACjF,KAAI,CAAC,UAAU,CAAC,iBAAiB,GAAG,KAAI,CAAC,UAAU,CAAC,iBAAiB,IAAI,sBAAQ,CAAC;QAElF,EAAE,CAAC,CAAC,KAAI,CAAC,QAAQ,IAAI,KAAI,CAAC,OAAO,CAAC,CAAC,CAAC;YAChC,KAAI,CAAC,KAAK,EAAE,CAAC;QACjB,CAAC;;IACL,CAAC;IAED;;;OAGG;IACH,4CAAW,GAAX,UAAY,iBAAsB;QAE9B,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC,iBAAiB,CAAC,CAAC,CAAC;IACjF,CAAC;IAGD;;;;OAIG;IACH,sCAAK,GAAL;QAAA,iBAkBC;QAhBG,EAAE,CAAC,CAAC,iBAAM,KAAK,WAAE,CAAC,CAAC,CAAC;YAChB,MAAM,CAAC,IAAI,CAAC;QAChB,CAAC;QAED,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EACX,IAAI,CAAC,OAAO,EACZ,UAAC,CAAC;YACE,KAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;YACpB,KAAI,CAAC,YAAY,CAAC,KAAI,CAAC,CAAC;QAC5B,CAAC,EAAE,MAAM,CAAC,CAAC,IAAI,CACf;YACI,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACzB,CAAC,CACJ,CAAC;QAEF,MAAM,CAAC,KAAK,CAAC;IACjB,CAAC;IAED;;;;OAIG;IACH,gDAAe,GAAf,UAAgB,CAAC;QACb,iBAAM,eAAe,YAAC,CAAC,CAAC,CAAC;QACzB,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC,CAAC,EACvD,EAAC,iBAAiB,EAAE,IAAI,CAAC,UAAU,CAAC,iBAAiB,EAAE,cAAc,EAAE,IAAI,CAAC,UAAU,CAAC,cAAc,EAAC,CAAC,CAAC,CAAC;IACjH,CAAC;IACL,6BAAC;AAAD,CAAC,AA3FD,CAA4C,iCAAe,GA2F1D;AA3FY,wDAAsB;AA6FnC,EAAE,CAAC,sBAAsB,GAAG,sBAAsB,CAAC;AACnD,kBAAe,sBAAsB,CAAC","sourcesContent":["/**\r\n * Created by gavorhes on 11/2/2015.\r\n */\r\n\r\nimport {LayerBaseVector, LayerBaseVectorOptions} from './LayerBaseVector';\r\nimport provide from '../util/provide';\r\nimport ol = require('custom-ol');\r\nimport $ = require('jquery');\r\nimport {MapMoveCls} from \"../olHelpers/mapMoveCls\";\r\nimport * as proj from '../olHelpers/projections';\r\nimport {proj3857} from \"../olHelpers/projections\";\r\n\r\nlet nm = provide('layers');\r\n\r\n\r\nexport interface crsTransform {\r\n    dataProjection?: ol.proj.Projection;\r\n    featureProjection?: ol.proj.Projection;\r\n}\r\n\r\n\r\nexport interface LayerBaseVectorGeoJsonOptions extends LayerBaseVectorOptions {\r\n    transform?: crsTransform;\r\n    mapMoveObj?: MapMoveCls;\r\n}\r\n\r\n/**\r\n * The Vector GeoJson Layer\r\n * @augments LayerBaseVector\r\n */\r\nexport class LayerBaseVectorGeoJson extends LayerBaseVector {\r\n    _geoJsonFormat: ol.format.GeoJSON;\r\n    _transform: crsTransform;\r\n\r\n    /**\r\n     * @param {string|undefined|null} url - resource url, set to '' to make blank layer\r\n     * @param {object} options - config\r\n     * @param {string} [options.id] - layer id\r\n     * @param {string} [options.name=Unnamed Layer] - layer name\r\n     * @param {number} [options.opacity=1] - opacity\r\n     * @param {boolean} [options.visible=true] - default visible\r\n     * @param {number} [options.minZoom=undefined] - min zoom level, 0 - 28\r\n     * @param {number} [options.maxZoom=undefined] - max zoom level, 0 - 28\r\n     * @param {object} [options.params={}] the get parameters to include to retrieve the layer\r\n     * @param {number} [options.zIndex=0] the z index for the layer\r\n     * @param {function} [options.loadCallback] function to call on load, context this is the layer object\r\n     * @param {boolean} [options.legendCollapse=false] if the legend item should be initially collapsed\r\n     * @param {boolean} [options.legendCheckbox=true] if the legend item should have a checkbox for visibility\r\n     * @param {boolean} [options.legendContent] additional content to add to the legend\r\n     *\r\n     * @param {boolean} [options.autoLoad=false] if the layer should auto load if not visible\r\n     * @param {object} [options.style=undefined] the layer style, use openlayers default style if not defined\r\n     * @param {boolean} [options.onDemand=false] if the layer should be loaded by extent on map move\r\n     * @param {number} [options.onDemandDelay=300] delay before the map move callback should be called\r\n     *\r\n     * @param {object} [options.transform={}] SR transform, set as false for no transform\r\n     * @param {string} options.transform.dataProjection=EPSG:4326 the data CRS\r\n     * @param {string} options.transform.featureProjection=EPSG:3857 the feature/map CRS\r\n     * @param {mapMoveMakeGetParams} [options.mapMoveMakeGetParams=function(lyr, extent, zoomLevel){}] function to create additional map move params\r\n     * @param {MapMoveCls} [options.mapMoveObj=mapMove] alternate map move object for use with multi map pages\r\n     */\r\n    constructor(url, options: LayerBaseVectorGeoJsonOptions = {}) {\r\n        url = typeof url == 'string' ? url : '';\r\n        super(url, options);\r\n\r\n        this._geoJsonFormat = new ol.format.GeoJSON();\r\n\r\n        this._transform = options.transform || {};\r\n        this._transform.dataProjection = this._transform.dataProjection || proj.proj4326;\r\n        this._transform.featureProjection = this._transform.featureProjection || proj3857;\r\n\r\n        if (this.autoLoad || this.visible) {\r\n            this._load();\r\n        }\r\n    }\r\n\r\n    /**\r\n     * add feature collection\r\n     * @param {object} featureCollection - as geojson object\r\n     */\r\n    addFeatures(featureCollection: any) {\r\n\r\n        this.source.addFeatures(this._geoJsonFormat.readFeatures(featureCollection));\r\n    }\r\n\r\n\r\n    /**\r\n     * trigger load features\r\n     * @protected\r\n     * @returns {boolean} if already loaded\r\n     */\r\n    _load() {\r\n\r\n        if (super._load()) {\r\n            return true;\r\n        }\r\n\r\n        $.get(this._url,\r\n            this._params,\r\n            (d) => {\r\n                this.addFeatures(d);\r\n                this.loadCallback(this);\r\n            }, 'json').fail(\r\n            function () {\r\n                this._loaded = false;\r\n            }\r\n        );\r\n\r\n        return false;\r\n    }\r\n\r\n    /**\r\n     * callback function on map move\r\n     * @param {object} d the json response\r\n     * @override\r\n     */\r\n    mapMoveCallback(d) {\r\n        super.mapMoveCallback(d);\r\n        this._source.addFeatures(this._geoJsonFormat.readFeatures(d,\r\n            {featureProjection: this._transform.featureProjection, dataProjection: this._transform.dataProjection}));\r\n    }\r\n}\r\n\r\nnm.LayerBaseVectorGeoJson = LayerBaseVectorGeoJson;\r\nexport default LayerBaseVectorGeoJson;\r\n"]}
\ No newline at end of file
+//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"LayerBaseVectorGeoJson.js","sourceRoot":"","sources":["../../src/layers/LayerBaseVectorGeoJson.ts"],"names":[],"mappings":"AAAA;;GAEG;;;;;;;;;;;;;AAEH,qDAA0E;AAC1E,2CAAsC;AACtC,8BAAiC;AACjC,0BAA6B;AAE7B,+CAAiD;AACjD,wDAAkD;AAElD,IAAI,EAAE,GAAG,iBAAO,CAAC,QAAQ,CAAC,CAAC;AAa3B;;;GAGG;AACH;IAA4C,0CAAe;IAIvD;;;;;;;;;;;;;;;;;;;;;;;;;;OA0BG;IACH,gCAAY,GAAY,EAAE,OAA2C;QAA3C,wBAAA,EAAA,YAA2C;QAArE,iBAaC;QAZG,GAAG,GAAG,OAAO,GAAG,IAAI,QAAQ,GAAG,GAAG,GAAG,EAAE,CAAC;QACxC,QAAA,kBAAM,GAAG,EAAE,OAAO,CAAC,SAAC;QAEpB,KAAI,CAAC,cAAc,GAAG,IAAI,EAAE,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;QAE9C,KAAI,CAAC,UAAU,GAAG,OAAO,CAAC,SAAS,IAAI,EAAE,CAAC;QAC1C,KAAI,CAAC,UAAU,CAAC,cAAc,GAAG,KAAI,CAAC,UAAU,CAAC,cAAc,IAAI,IAAI,CAAC,QAAQ,CAAC;QACjF,KAAI,CAAC,UAAU,CAAC,iBAAiB,GAAG,KAAI,CAAC,UAAU,CAAC,iBAAiB,IAAI,sBAAQ,CAAC;QAElF,EAAE,CAAC,CAAC,KAAI,CAAC,QAAQ,IAAI,KAAI,CAAC,OAAO,CAAC,CAAC,CAAC;YAChC,KAAI,CAAC,KAAK,EAAE,CAAC;QACjB,CAAC;;IACL,CAAC;IAED;;;OAGG;IACH,4CAAW,GAAX,UAAY,iBAAsB;QAE9B,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC,iBAAiB,CAAC,CAAC,CAAC;IACjF,CAAC;IAGD;;;;OAIG;IACH,sCAAK,GAAL;QAAA,iBAkBC;QAhBG,EAAE,CAAC,CAAC,iBAAM,KAAK,WAAE,CAAC,CAAC,CAAC;YAChB,MAAM,CAAC,IAAI,CAAC;QAChB,CAAC;QAED,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EACX,IAAI,CAAC,OAAO,EACZ,UAAC,CAAC;YACE,KAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;YACpB,KAAI,CAAC,YAAY,CAAC,KAAI,CAAC,CAAC;QAC5B,CAAC,EAAE,MAAM,CAAC,CAAC,IAAI,CACf;YACI,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACzB,CAAC,CACJ,CAAC;QAEF,MAAM,CAAC,KAAK,CAAC;IACjB,CAAC;IAED;;;;OAIG;IACH,gDAAe,GAAf,UAAgB,CAAC;QACb,iBAAM,eAAe,YAAC,CAAC,CAAC,CAAC;QACzB,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC,CAAC,EACvD,EAAC,iBAAiB,EAAE,IAAI,CAAC,UAAU,CAAC,iBAAiB,EAAE,cAAc,EAAE,IAAI,CAAC,UAAU,CAAC,cAAc,EAAC,CAAC,CAAC,CAAC;IACjH,CAAC;IACL,6BAAC;AAAD,CAAC,AA3FD,CAA4C,iCAAe,GA2F1D;AA3FY,wDAAsB;AA6FnC,EAAE,CAAC,sBAAsB,GAAG,sBAAsB,CAAC;AACnD,kBAAe,sBAAsB,CAAC","sourcesContent":["/**\r\n * Created by gavorhes on 11/2/2015.\r\n */\r\n\r\nimport {LayerBaseVector, LayerBaseVectorOptions} from './LayerBaseVector';\r\nimport provide from '../util/provide';\r\nimport ol = require('custom-ol');\r\nimport $ = require('jquery');\r\nimport {MapMoveCls} from \"../olHelpers/mapMoveCls\";\r\nimport * as proj from '../olHelpers/projections';\r\nimport {proj3857} from \"../olHelpers/projections\";\r\n\r\nlet nm = provide('layers');\r\n\r\nexport interface crsTransform {\r\n    dataProjection?: ol.proj.Projection;\r\n    featureProjection?: ol.proj.Projection;\r\n}\r\n\r\n\r\nexport interface LayerBaseVectorGeoJsonOptions extends LayerBaseVectorOptions {\r\n    transform?: crsTransform;\r\n    mapMoveObj?: MapMoveCls;\r\n}\r\n\r\n/**\r\n * The Vector GeoJson Layer\r\n * @augments LayerBaseVector\r\n */\r\nexport class LayerBaseVectorGeoJson extends LayerBaseVector {\r\n    _geoJsonFormat: ol.format.GeoJSON;\r\n    _transform: crsTransform;\r\n\r\n    /**\r\n     * @param {string|null} url - resource url, set to '' to make blank layer\r\n     * @param {object} options - config\r\n     * @param {string} [options.id] - layer id\r\n     * @param {string} [options.name=Unnamed Layer] - layer name\r\n     * @param {number} [options.opacity=1] - opacity\r\n     * @param {boolean} [options.visible=true] - default visible\r\n     * @param {number} [options.minZoom=undefined] - min zoom level, 0 - 28\r\n     * @param {number} [options.maxZoom=undefined] - max zoom level, 0 - 28\r\n     * @param {object} [options.params={}] the get parameters to include to retrieve the layer\r\n     * @param {number} [options.zIndex=0] the z index for the layer\r\n     * @param {function} [options.loadCallback] function to call on load, context this is the layer object\r\n     * @param {boolean} [options.legendCollapse=false] if the legend item should be initially collapsed\r\n     * @param {boolean} [options.legendCheckbox=true] if the legend item should have a checkbox for visibility\r\n     * @param {boolean} [options.legendContent] additional content to add to the legend\r\n     *\r\n     * @param {boolean} [options.autoLoad=false] if the layer should auto load if not visible\r\n     * @param {object} [options.style=undefined] the layer style, use openlayers default style if not defined\r\n     * @param {boolean} [options.onDemand=false] if the layer should be loaded by extent on map move\r\n     * @param {number} [options.onDemandDelay=300] delay before the map move callback should be called\r\n     *\r\n     * @param {object} [options.transform={}] SR transform, set as false for no transform\r\n     * @param {string} options.transform.dataProjection=EPSG:4326 the data CRS\r\n     * @param {string} options.transform.featureProjection=EPSG:3857 the feature/map CRS\r\n     * @param {mapMoveMakeGetParams} [options.mapMoveMakeGetParams=function(lyr, extent, zoomLevel){}] function to create additional map move params\r\n     * @param {MapMoveCls} [options.mapMoveObj=mapMove] alternate map move object for use with multi map pages\r\n     */\r\n    constructor(url?: string, options: LayerBaseVectorGeoJsonOptions = {}) {\r\n        url = typeof url == 'string' ? url : '';\r\n        super(url, options);\r\n\r\n        this._geoJsonFormat = new ol.format.GeoJSON();\r\n\r\n        this._transform = options.transform || {};\r\n        this._transform.dataProjection = this._transform.dataProjection || proj.proj4326;\r\n        this._transform.featureProjection = this._transform.featureProjection || proj3857;\r\n\r\n        if (this.autoLoad || this.visible) {\r\n            this._load();\r\n        }\r\n    }\r\n\r\n    /**\r\n     * add feature collection\r\n     * @param {object} featureCollection - as geojson object\r\n     */\r\n    addFeatures(featureCollection: any) {\r\n\r\n        this.source.addFeatures(this._geoJsonFormat.readFeatures(featureCollection));\r\n    }\r\n\r\n\r\n    /**\r\n     * trigger load features\r\n     * @protected\r\n     * @returns {boolean} if already loaded\r\n     */\r\n    _load() {\r\n\r\n        if (super._load()) {\r\n            return true;\r\n        }\r\n\r\n        $.get(this._url,\r\n            this._params,\r\n            (d) => {\r\n                this.addFeatures(d);\r\n                this.loadCallback(this);\r\n            }, 'json').fail(\r\n            function () {\r\n                this._loaded = false;\r\n            }\r\n        );\r\n\r\n        return false;\r\n    }\r\n\r\n    /**\r\n     * callback function on map move\r\n     * @param {object} d the json response\r\n     * @override\r\n     */\r\n    mapMoveCallback(d) {\r\n        super.mapMoveCallback(d);\r\n        this._source.addFeatures(this._geoJsonFormat.readFeatures(d,\r\n            {featureProjection: this._transform.featureProjection, dataProjection: this._transform.dataProjection}));\r\n    }\r\n}\r\n\r\nnm.LayerBaseVectorGeoJson = LayerBaseVectorGeoJson;\r\nexport default LayerBaseVectorGeoJson;\r\n"]}
\ No newline at end of file
diff --git a/src/layers/LayerBaseVectorGeoJson.ts b/src/layers/LayerBaseVectorGeoJson.ts
index 3ac4c63..c7b6e40 100644
--- a/src/layers/LayerBaseVectorGeoJson.ts
+++ b/src/layers/LayerBaseVectorGeoJson.ts
@@ -12,7 +12,6 @@ import {proj3857} from "../olHelpers/projections";
 
 let nm = provide('layers');
 
-
 export interface crsTransform {
     dataProjection?: ol.proj.Projection;
     featureProjection?: ol.proj.Projection;
@@ -33,7 +32,7 @@ export class LayerBaseVectorGeoJson extends LayerBaseVector {
     _transform: crsTransform;
 
     /**
-     * @param {string|undefined|null} url - resource url, set to '' to make blank layer
+     * @param {string|null} url - resource url, set to '' to make blank layer
      * @param {object} options - config
      * @param {string} [options.id] - layer id
      * @param {string} [options.name=Unnamed Layer] - layer name
@@ -59,7 +58,7 @@ export class LayerBaseVectorGeoJson extends LayerBaseVector {
      * @param {mapMoveMakeGetParams} [options.mapMoveMakeGetParams=function(lyr, extent, zoomLevel){}] function to create additional map move params
      * @param {MapMoveCls} [options.mapMoveObj=mapMove] alternate map move object for use with multi map pages
      */
-    constructor(url, options: LayerBaseVectorGeoJsonOptions = {}) {
+    constructor(url?: string, options: LayerBaseVectorGeoJsonOptions = {}) {
         url = typeof url == 'string' ? url : '';
         super(url, options);
 
diff --git a/test/data/geoJsonFeatures.ts b/test/data/geoJsonFeatures.ts
new file mode 100644
index 0000000..09c15a6
--- /dev/null
+++ b/test/data/geoJsonFeatures.ts
@@ -0,0 +1,968 @@
+/**
+ * Created by glenn on 3/10/2017.
+ */
+/**
+ * Created by glenn on 3/8/2017.
+ */
+
+
+export const sample_segs = {
+    "crs": { "type": "name", "properties": { "name": "urn:ogc:def:crs:EPSG::3857" } },
+    // "crs": {"type": "name", "properties": {"name": "urn:ogc:def:crs:OGC:1.3:CRS84"}},
+
+    "type": "FeatureCollection",
+    "features": [{
+        "type": "Feature",
+        "properties": {
+            "startRp": "013N005M011",
+            "rdwyRteId": 11,
+            "rateFlag": 0.0,
+            "endMile": 4.53,
+            "mmStnVersion": 2014,
+            "stdName": "WIS 13 NB",
+            "mmVersion": "2016-09",
+            "kabCrshFlag": 0.0,
+            "divUnd": "U",
+            "startMile": 3.71,
+            "endRp": "013N005M093",
+            "pdpId": 2074,
+            "rpDesc": null,
+            "pdpLength": 0.82
+        },
+        "geometry": {
+            "type": "LineString",
+            "coordinates": [[-9992497.81540399, 5410145.34171217], [-9992856.20056598, 5411588.19634882], [-9992959.88010738, 5411905.88929907], [-9992961.24970403, 5411910.09341592]]
+        }
+    }, {
+        "type": "Feature",
+        "properties": {
+            "startRp": "013N005M093",
+            "rdwyRteId": 11,
+            "rateFlag": 0.0,
+            "endMile": 5.18,
+            "mmStnVersion": 2014,
+            "stdName": "WIS 13 NB",
+            "mmVersion": "2016-09",
+            "kabCrshFlag": 0.0,
+            "divUnd": "D",
+            "startMile": 4.53,
+            "endRp": "013N006M000",
+            "pdpId": 2075,
+            "rpDesc": null,
+            "pdpLength": 0.65
+        },
+        "geometry": {
+            "type": "LineString",
+            "coordinates": [[-9992961.24970403, 5411910.09341592], [-9992966.9804255, 5411927.68442817], [-9993101.26835489, 5412255.64652059], [-9993210.0086723, 5412480.3353547], [-9993328.78576386, 5412696.78672328], [-9993438.48035086, 5412876.11253749], [-9993642.09731562, 5413184.80642233]]
+        }
+    }, {
+        "type": "Feature",
+        "properties": {
+            "startRp": "013N006M000",
+            "rdwyRteId": 11,
+            "rateFlag": 0.0,
+            "endMile": 5.87,
+            "mmStnVersion": 2014,
+            "stdName": "WIS 13 NB",
+            "mmVersion": "2016-09",
+            "kabCrshFlag": 0.0,
+            "divUnd": "D",
+            "startMile": 5.18,
+            "endRp": "013N008M000",
+            "pdpId": 2076,
+            "rpDesc": "9TH LANE",
+            "pdpLength": 0.69
+        },
+        "geometry": {
+            "type": "LineString",
+            "coordinates": [[-9993642.09731562, 5413184.80642233], [-9993773.58263128, 5413383.59418723], [-9994492.85540891, 5414470.91785164]]
+        }
+    }
+    ]
+};
+
+export const trench = {
+    "type": "FeatureCollection",
+    "crs": {"type": "name", "properties": {"name": "urn:ogc:def:crs:OGC:1.3:CRS84"}},
+    "features": [{
+        "type": "Feature",
+        "geometry": {
+            "type": "LineString",
+            "coordinates": [[-89.353898883995, 43.044169874006], [-89.353895676627, 43.044158106199]]
+        },
+        "properties": {
+            "city": "",
+            "comments": "",
+            "county": "Dane",
+            "dateCreated": "2015-07-17 18:32:20",
+            "dateModified": "2015-07-17 18:32:20",
+            "description": "",
+            "endDepth": null,
+            "featureGuid": "daafb1c8-10c4-4d69-935d-6266268ea9f5",
+            "fiberCount": "",
+            "highway": "",
+            "installType": "UTC",
+            "itsId": "",
+            "location": "",
+            "material": "",
+            "owner": "WisDOT",
+            "region": "Southwest",
+            "segLength": 16.456,
+            "srvcStatus": "I",
+            "startDepth": null,
+            "trenchSize": null,
+            "yearAdded": 2015
+        }
+    }, {
+        "type": "Feature",
+        "geometry": {
+            "type": "LineString",
+            "coordinates": [[-89.391309602361, 43.036389485491], [-89.391129453816, 43.036496761869], [-89.390910083702, 43.036613655479], [-89.390729167637, 43.03668719712]]
+        },
+        "properties": {
+            "city": "",
+            "comments": "",
+            "county": "Dane",
+            "dateCreated": "2015-07-17 18:22:55",
+            "dateModified": "2015-07-17 18:22:55",
+            "description": "",
+            "endDepth": null,
+            "featureGuid": "7bcbe96a-f685-45dd-a7b0-bef747b7741a",
+            "fiberCount": "",
+            "highway": "",
+            "installType": "UTC",
+            "itsId": "",
+            "location": "",
+            "material": "",
+            "owner": "WisDOT",
+            "region": "Southwest",
+            "segLength": 198.985,
+            "srvcStatus": "I",
+            "startDepth": null,
+            "trenchSize": null,
+            "yearAdded": 2013
+        }
+    }, {
+        "type": "Feature",
+        "geometry": {
+            "type": "LineString",
+            "coordinates": [[-89.361873526012, 43.046938009447], [-89.36233732512, 43.046828870794]]
+        },
+        "properties": {
+            "city": "",
+            "comments": "",
+            "county": "Dane",
+            "dateCreated": "2015-07-17 18:05:05",
+            "dateModified": "2015-07-17 18:05:05",
+            "description": "",
+            "endDepth": null,
+            "featureGuid": "cb434d1f-dffb-4c70-a323-c92474ee70d7",
+            "fiberCount": "",
+            "highway": "",
+            "installType": "ASC",
+            "itsId": "",
+            "location": "",
+            "material": "",
+            "owner": "USXchange",
+            "region": "Southwest",
+            "segLength": 138,
+            "srvcStatus": "I",
+            "startDepth": null,
+            "trenchSize": null,
+            "yearAdded": 2009
+        }
+    }, {
+        "type": "Feature",
+        "geometry": {
+            "type": "LineString",
+            "coordinates": [[-89.345891118977, 43.047127162062], [-89.345891154801, 43.047127141555], [-89.345891147205, 43.047127163123], [-89.345891165372, 43.04712718664]]
+        },
+        "properties": {
+            "city": "",
+            "comments": "",
+            "county": "Dane",
+            "dateCreated": "2016-01-19 13:07:59",
+            "dateModified": "2016-01-19 13:07:59",
+            "description": "",
+            "endDepth": null,
+            "featureGuid": "d0a9e0b2-46c0-4f1e-8650-90c35a8150e9",
+            "fiberCount": "",
+            "highway": "",
+            "installType": "",
+            "itsId": "",
+            "location": "",
+            "material": "",
+            "owner": "City of Madison",
+            "region": "Southwest",
+            "segLength": null,
+            "srvcStatus": "",
+            "startDepth": null,
+            "trenchSize": null,
+            "yearAdded": null
+        }
+    }, {
+        "type": "Feature",
+        "geometry": {
+            "type": "LineString",
+            "coordinates": [[-89.345890404258, 43.047127175086], [-89.345890449894, 43.047127155536], [-89.345890466776, 43.047127184448]]
+        },
+        "properties": {
+            "city": "",
+            "comments": "",
+            "county": "Dane",
+            "dateCreated": "2016-01-19 13:08:07",
+            "dateModified": "2016-01-19 13:08:07",
+            "description": "",
+            "endDepth": null,
+            "featureGuid": "065f7b5d-ec71-47fd-938f-ae85e8032cef",
+            "fiberCount": "",
+            "highway": "",
+            "installType": "",
+            "itsId": "",
+            "location": "",
+            "material": "",
+            "owner": "City of Madison",
+            "region": "Southwest",
+            "segLength": null,
+            "srvcStatus": "",
+            "startDepth": null,
+            "trenchSize": null,
+            "yearAdded": null
+        }
+    }, {
+        "type": "Feature",
+        "geometry": {
+            "type": "LineString",
+            "coordinates": [[-89.39227499277, 43.03841579452], [-89.39265838884, 43.038421358853]]
+        },
+        "properties": {
+            "city": "",
+            "comments": "",
+            "county": "Dane",
+            "dateCreated": "2015-07-17 18:02:28",
+            "dateModified": "2015-07-17 18:02:28",
+            "description": "",
+            "endDepth": null,
+            "featureGuid": "54b1f691-b946-41c3-924d-2481f63a5c8d",
+            "fiberCount": "",
+            "highway": "",
+            "installType": "ASC",
+            "itsId": "",
+            "location": "",
+            "material": "",
+            "owner": "USXchange",
+            "region": "Southwest",
+            "segLength": 115,
+            "srvcStatus": "I",
+            "startDepth": null,
+            "trenchSize": null,
+            "yearAdded": 2009
+        }
+    }, {
+        "type": "Feature",
+        "geometry": {
+            "type": "LineString",
+            "coordinates": [[-89.35475623516, 43.044670295696], [-89.354731594679, 43.044664272913], [-89.353582742753, 43.044628712402], [-89.353293285746, 43.04436700513], [-89.351319799114, 43.044236240006], [-89.348727261631, 43.044235605738], [-89.348461002083, 43.044072608381], [-89.346571403115, 43.044078588738], [-89.343905538954, 43.044082849338], [-89.341759383041, 43.044078403803]]
+        },
+        "properties": {
+            "city": "",
+            "comments": "",
+            "county": "Dane",
+            "dateCreated": "2015-07-17 18:13:26",
+            "dateModified": "2015-07-17 18:13:26",
+            "description": "",
+            "endDepth": null,
+            "featureGuid": "fc659bfe-fed4-4db1-8c21-e0e151cb5fd8",
+            "fiberCount": "",
+            "highway": "",
+            "installType": "UTC",
+            "itsId": "",
+            "location": "",
+            "material": "",
+            "owner": "WisDOT",
+            "region": "Southwest",
+            "segLength": 3559.732,
+            "srvcStatus": "I",
+            "startDepth": null,
+            "trenchSize": null,
+            "yearAdded": 2009
+        }
+    }, {
+        "type": "Feature",
+        "geometry": {
+            "type": "LineString",
+            "coordinates": [[-89.395177806047, 43.036410455632], [-89.395149966798, 43.036409330561]]
+        },
+        "properties": {
+            "city": "",
+            "comments": "",
+            "county": "Dane",
+            "dateCreated": "2015-07-17 18:24:54",
+            "dateModified": "2015-07-17 18:24:54",
+            "description": "",
+            "endDepth": null,
+            "featureGuid": "e2e5fbd4-7dfd-4897-9df0-a01eba747d65",
+            "fiberCount": "",
+            "highway": "",
+            "installType": "UTC",
+            "itsId": "",
+            "location": "",
+            "material": "",
+            "owner": "WisDOT",
+            "region": "Southwest",
+            "segLength": 22.738,
+            "srvcStatus": "I",
+            "startDepth": null,
+            "trenchSize": null,
+            "yearAdded": 2013
+        }
+    }, {
+        "type": "Feature",
+        "geometry": {
+            "type": "LineString",
+            "coordinates": [[-89.35459157357, 43.033109401576], [-89.354455841387, 43.033383229942]]
+        },
+        "properties": {
+            "city": "",
+            "comments": "",
+            "county": "Dane",
+            "dateCreated": "2015-07-17 18:08:37",
+            "dateModified": "2015-07-17 18:08:37",
+            "description": "",
+            "endDepth": null,
+            "featureGuid": "9be131ab-9e4e-43a5-93e7-6d98b16dcfa0",
+            "fiberCount": "",
+            "highway": "",
+            "installType": "ASC",
+            "itsId": "",
+            "location": "",
+            "material": "",
+            "owner": "USXchange",
+            "region": "Southwest",
+            "segLength": 134,
+            "srvcStatus": "I",
+            "startDepth": null,
+            "trenchSize": null,
+            "yearAdded": 2009
+        }
+    }, {
+        "type": "Feature",
+        "geometry": {
+            "type": "LineString",
+            "coordinates": [[-89.356909321568, 43.043583769371], [-89.356911453361, 43.043576438688]]
+        },
+        "properties": {
+            "city": "",
+            "comments": "",
+            "county": "Dane",
+            "dateCreated": "2015-07-17 18:02:09",
+            "dateModified": "2015-07-17 18:02:09",
+            "description": "",
+            "endDepth": null,
+            "featureGuid": "b231ee40-5773-4f5c-822b-0355cc2059a4",
+            "fiberCount": "",
+            "highway": "",
+            "installType": "UTC",
+            "itsId": "",
+            "location": "",
+            "material": "",
+            "owner": "WisDOT",
+            "region": "Southwest",
+            "segLength": 9.285,
+            "srvcStatus": "I",
+            "startDepth": null,
+            "trenchSize": null,
+            "yearAdded": 2009
+        }
+    }, {
+        "type": "Feature",
+        "geometry": {
+            "type": "LineString",
+            "coordinates": [[-89.392996975679, 43.03842539113], [-89.393594623357, 43.038425886759]]
+        },
+        "properties": {
+            "city": "",
+            "comments": "",
+            "county": "Dane",
+            "dateCreated": "2015-07-17 18:13:44",
+            "dateModified": "2015-07-17 18:13:44",
+            "description": "",
+            "endDepth": null,
+            "featureGuid": "50c57080-3e49-4a27-8040-c79c174952d8",
+            "fiberCount": "",
+            "highway": "",
+            "installType": "ASC",
+            "itsId": "",
+            "location": "",
+            "material": "",
+            "owner": "USXchange",
+            "region": "Southwest",
+            "segLength": 128,
+            "srvcStatus": "I",
+            "startDepth": null,
+            "trenchSize": null,
+            "yearAdded": 2009
+        }
+    }, {
+        "type": "Feature",
+        "geometry": {
+            "type": "LineString",
+            "coordinates": [[-89.391868870338, 43.036014954752], [-89.391856041302, 43.036025977136]]
+        },
+        "properties": {
+            "city": "",
+            "comments": "",
+            "county": "Dane",
+            "dateCreated": "2015-07-17 18:25:55",
+            "dateModified": "2015-07-17 18:25:55",
+            "description": "",
+            "endDepth": null,
+            "featureGuid": "9ed7c662-9944-49ab-8bf5-94704cd6d110",
+            "fiberCount": "",
+            "highway": "",
+            "installType": "UTC",
+            "itsId": "",
+            "location": "",
+            "material": "",
+            "owner": "WisDOT",
+            "region": "Southwest",
+            "segLength": 14.564,
+            "srvcStatus": "I",
+            "startDepth": null,
+            "trenchSize": null,
+            "yearAdded": 2013
+        }
+    }, {
+        "type": "Feature",
+        "geometry": {
+            "type": "LineString",
+            "coordinates": [[-89.345889904516, 43.047127177633], [-89.345889935209, 43.047127177808]]
+        },
+        "properties": {
+            "city": "",
+            "comments": "",
+            "county": "Dane",
+            "dateCreated": "2016-01-19 13:08:07",
+            "dateModified": "2016-01-19 13:08:07",
+            "description": "",
+            "endDepth": null,
+            "featureGuid": "4a0ba496-2d2f-4876-b8bb-24fed9aa58a0",
+            "fiberCount": "",
+            "highway": "",
+            "installType": "",
+            "itsId": "",
+            "location": "",
+            "material": "",
+            "owner": "City of Madison",
+            "region": "Southwest",
+            "segLength": null,
+            "srvcStatus": "",
+            "startDepth": null,
+            "trenchSize": null,
+            "yearAdded": null
+        }
+    }, {
+        "type": "Feature",
+        "geometry": {
+            "type": "LineString",
+            "coordinates": [[-89.379075782908, 43.038111547553], [-89.379349799008, 43.0372501871]]
+        },
+        "properties": {
+            "city": "",
+            "comments": "",
+            "county": "Dane",
+            "dateCreated": "2016-01-19 13:07:45",
+            "dateModified": "2016-01-19 13:07:45",
+            "description": "",
+            "endDepth": null,
+            "featureGuid": "8425a5e0-fa4b-4f89-8422-dc76ba78a0ab",
+            "fiberCount": "",
+            "highway": "",
+            "installType": "",
+            "itsId": "",
+            "location": "",
+            "material": "",
+            "owner": "City of Madison",
+            "region": "Southwest",
+            "segLength": null,
+            "srvcStatus": "",
+            "startDepth": null,
+            "trenchSize": null,
+            "yearAdded": null
+        }
+    }, {
+        "type": "Feature",
+        "geometry": {
+            "type": "LineString",
+            "coordinates": [[-89.392217325934, 43.036157797979], [-89.392038686732, 43.036086800162]]
+        },
+        "properties": {
+            "city": "",
+            "comments": "",
+            "county": "Dane",
+            "dateCreated": "2015-07-17 18:25:55",
+            "dateModified": "2015-07-17 18:25:55",
+            "description": "",
+            "endDepth": null,
+            "featureGuid": "47b579f5-a79a-4f04-8546-c7340408b0df",
+            "fiberCount": "",
+            "highway": "",
+            "installType": "UTC",
+            "itsId": "",
+            "location": "",
+            "material": "",
+            "owner": "WisDOT",
+            "region": "Southwest",
+            "segLength": 69.147,
+            "srvcStatus": "I",
+            "startDepth": null,
+            "trenchSize": null,
+            "yearAdded": 2013
+        }
+    }, {
+        "type": "Feature",
+        "geometry": {
+            "type": "LineString",
+            "coordinates": [[-89.345889970765, 43.047127182514], [-89.345889935209, 43.047127177808]]
+        },
+        "properties": {
+            "city": "",
+            "comments": "",
+            "county": "Dane",
+            "dateCreated": "2016-01-19 13:08:09",
+            "dateModified": "2016-01-19 13:08:09",
+            "description": "",
+            "endDepth": null,
+            "featureGuid": "80b32091-588a-438a-bf24-eeed578a1485",
+            "fiberCount": "",
+            "highway": "",
+            "installType": "",
+            "itsId": "",
+            "location": "",
+            "material": "",
+            "owner": "City of Madison",
+            "region": "Southwest",
+            "segLength": null,
+            "srvcStatus": "",
+            "startDepth": null,
+            "trenchSize": null,
+            "yearAdded": null
+        }
+    }, {
+        "type": "Feature",
+        "geometry": {
+            "type": "LineString",
+            "coordinates": [[-89.365717365691, 43.044790184814], [-89.366055621384, 43.04465706628]]
+        },
+        "properties": {
+            "city": "",
+            "comments": "",
+            "county": "Dane",
+            "dateCreated": "2015-07-17 18:04:16",
+            "dateModified": "2015-07-17 18:04:16",
+            "description": "",
+            "endDepth": null,
+            "featureGuid": "2c39e8e6-b6f7-48fc-b8e6-eec23a4e5065",
+            "fiberCount": "",
+            "highway": "",
+            "installType": "ASC",
+            "itsId": "",
+            "location": "",
+            "material": "",
+            "owner": "USXchange",
+            "region": "Southwest",
+            "segLength": 113,
+            "srvcStatus": "I",
+            "startDepth": null,
+            "trenchSize": null,
+            "yearAdded": 2009
+        }
+    }, {
+        "type": "Feature",
+        "geometry": {
+            "type": "LineString",
+            "coordinates": [[-89.354730567381, 43.036400294633], [-89.354867778807, 43.036911177605]]
+        },
+        "properties": {
+            "city": "",
+            "comments": "",
+            "county": "Dane",
+            "dateCreated": "2015-07-17 18:08:50",
+            "dateModified": "2015-07-17 18:08:50",
+            "description": "",
+            "endDepth": null,
+            "featureGuid": "64983325-54c2-4f00-94d0-65ddd1a73616",
+            "fiberCount": "",
+            "highway": "",
+            "installType": "ASC",
+            "itsId": "",
+            "location": "",
+            "material": "",
+            "owner": "USXchange",
+            "region": "Southwest",
+            "segLength": 167,
+            "srvcStatus": "I",
+            "startDepth": null,
+            "trenchSize": null,
+            "yearAdded": 2009
+        }
+    }, {
+        "type": "Feature",
+        "geometry": {
+            "type": "LineString",
+            "coordinates": [[-89.377677004437, 43.04118643741], [-89.377125147726, 43.041238817659]]
+        },
+        "properties": {
+            "city": "",
+            "comments": "",
+            "county": "Dane",
+            "dateCreated": "2015-07-17 18:07:53",
+            "dateModified": "2015-07-17 18:07:53",
+            "description": "",
+            "endDepth": null,
+            "featureGuid": "8ba02a21-ae22-4af7-b913-a266d88759c2",
+            "fiberCount": "",
+            "highway": "",
+            "installType": "UTC",
+            "itsId": "",
+            "location": "",
+            "material": "",
+            "owner": "WisDOT",
+            "region": "Southwest",
+            "segLength": 163.901,
+            "srvcStatus": "I",
+            "startDepth": null,
+            "trenchSize": null,
+            "yearAdded": 2009
+        }
+    }, {
+        "type": "Feature",
+        "geometry": {
+            "type": "LineString",
+            "coordinates": [[-89.354886880432, 43.039603041611], [-89.354873360775, 43.040026585234]]
+        },
+        "properties": {
+            "city": "",
+            "comments": "",
+            "county": "Dane",
+            "dateCreated": "2015-07-17 18:09:39",
+            "dateModified": "2015-07-17 18:09:39",
+            "description": "",
+            "endDepth": null,
+            "featureGuid": "89930faa-b256-4afe-9e46-ccd9d0c70ecf",
+            "fiberCount": "",
+            "highway": "",
+            "installType": "ASC",
+            "itsId": "",
+            "location": "",
+            "material": "",
+            "owner": "USXchange",
+            "region": "Southwest",
+            "segLength": 165,
+            "srvcStatus": "I",
+            "startDepth": null,
+            "trenchSize": null,
+            "yearAdded": 2009
+        }
+    }, {
+        "type": "Feature",
+        "geometry": {
+            "type": "LineString",
+            "coordinates": [[-89.378268605015, 43.039635680758], [-89.378484733316, 43.03966826861], [-89.378653989381, 43.039653959331]]
+        },
+        "properties": {
+            "city": "",
+            "comments": "",
+            "county": "Dane",
+            "dateCreated": "2016-01-19 13:07:49",
+            "dateModified": "2016-01-19 13:07:49",
+            "description": "",
+            "endDepth": null,
+            "featureGuid": "c8377ee1-e980-4a11-b9ea-d43221927639",
+            "fiberCount": "",
+            "highway": "",
+            "installType": "",
+            "itsId": "",
+            "location": "",
+            "material": "",
+            "owner": "City of Madison",
+            "region": "Southwest",
+            "segLength": null,
+            "srvcStatus": "",
+            "startDepth": null,
+            "trenchSize": null,
+            "yearAdded": null
+        }
+    }, {
+        "type": "Feature",
+        "geometry": {
+            "type": "LineString",
+            "coordinates": [[-89.345890152631, 43.047127168245], [-89.345890131578, 43.047127185234]]
+        },
+        "properties": {
+            "city": "",
+            "comments": "",
+            "county": "Dane",
+            "dateCreated": "2016-01-19 13:08:04",
+            "dateModified": "2016-01-19 13:08:04",
+            "description": "",
+            "endDepth": null,
+            "featureGuid": "6123b51a-15e7-477e-a623-8f29b64829e8",
+            "fiberCount": "",
+            "highway": "",
+            "installType": "",
+            "itsId": "",
+            "location": "",
+            "material": "",
+            "owner": "City of Madison",
+            "region": "Southwest",
+            "segLength": null,
+            "srvcStatus": "",
+            "startDepth": null,
+            "trenchSize": null,
+            "yearAdded": null
+        }
+    }]
+};
+
+
+export const cams = {
+    "type": "FeatureCollection",
+    "crs": {"type": "name", "properties": {"name": "urn:ogc:def:crs:OGC:1.3:CRS84"}},
+    "features": [{
+        "type": "Feature",
+        "geometry": {"type": "Point", "coordinates": [-89.32369295359959, 43.17893291595122]},
+        "properties": {
+            "camNumber": 221,
+            "centerId": "Madison",
+            "centerName": "Madison",
+            "city": "",
+            "comments": "",
+            "county": "Dane",
+            "dateCreated": "2015-07-17 14:27:47",
+            "dateModified": "2015-07-17 14:27:47",
+            "description": "",
+            "encoderIp": "",
+            "equipment": "",
+            "featureGuid": "b3254371-b0d6-4fe8-9640-e43a4a3de41e",
+            "height": null,
+            "highway": "I-39/90/94",
+            "instlAdrss": "",
+            "itsId": "CCTV-13-0010",
+            "location": "I-39/90/94 @ US 51",
+            "mac": "",
+            "morisId": "420",
+            "mount": "",
+            "multicast": "",
+            "owner": "",
+            "poleId": "",
+            "region": "Southwest",
+            "svcAcct": "",
+            "svcMeter": "",
+            "url": "content.dot.wi.gov/travel/madison/cameras/cam221.jpg",
+            "yearAdded": null,
+            "Comments": "",
+            "County": "Dane",
+            "Cam_No": 221,
+            "Center-ID": "Madison",
+            "Center-Name": "Madison",
+            "Encoder_IP": "",
+            "Equipment": "",
+            "Install_Address": "",
+            "MAC": "",
+            "Moris_ID": "420",
+            "Multicast": "",
+            "Svc_Prov_Acct": "",
+            "Svc_Prov_Meter": "",
+            "URL": "content.dot.wi.gov/travel/madison/cameras/cam221.jpg"
+        }
+    }, {
+        "type": "Feature",
+        "geometry": {"type": "Point", "coordinates": [-88.5424253013911, 44.014741825246325]},
+        "properties": {
+            "camNumber": null,
+            "centerId": "Green Bay",
+            "centerName": "Milwaukee",
+            "city": "",
+            "comments": "Not in 511 website; Not STOC Operated",
+            "county": "Winnebago",
+            "dateCreated": "2015-07-17 14:28:31",
+            "dateModified": "2015-07-17 14:28:31",
+            "description": "",
+            "encoderIp": "",
+            "equipment": "",
+            "featureGuid": "25e37162-3bd0-4480-9fe4-bdf81071be2f",
+            "height": null,
+            "highway": "Oregon/Jackson St",
+            "instlAdrss": "",
+            "itsId": "CCTV-70-0008",
+            "location": "Oregon/Jackson St @ Wolf River North Pier",
+            "mac": "",
+            "morisId": "",
+            "mount": "",
+            "multicast": "",
+            "owner": "",
+            "poleId": "",
+            "region": "Northeast",
+            "svcAcct": "",
+            "svcMeter": "",
+            "url": "",
+            "yearAdded": null,
+            "Comments": "Not in 511 website; Not STOC Operated",
+            "County": "Winnebago",
+            "Cam_No": null,
+            "Center-ID": "Green Bay",
+            "Center-Name": "Milwaukee",
+            "Encoder_IP": "",
+            "Equipment": "",
+            "Install_Address": "",
+            "MAC": "",
+            "Moris_ID": "",
+            "Multicast": "",
+            "Svc_Prov_Acct": "",
+            "Svc_Prov_Meter": "",
+            "URL": ""
+        }
+    }, {
+        "type": "Feature",
+        "geometry": {"type": "Point", "coordinates": [-89.39186771089234, 43.07556455822463]},
+        "properties": {
+            "camNumber": null,
+            "centerId": "",
+            "centerName": "",
+            "city": "City of Madison",
+            "comments": "360 camera",
+            "county": "Dane",
+            "dateCreated": "2016-01-19 12:57:03",
+            "dateModified": "2016-01-19 12:57:03",
+            "description": "Buckeye Gorham",
+            "encoderIp": "",
+            "equipment": "",
+            "featureGuid": "19a5e1d4-ac35-41c5-8061-fe2d3725b89e",
+            "height": 25,
+            "highway": "",
+            "instlAdrss": "",
+            "itsId": "Buckeye Gorham",
+            "location": "buckeye lot looking toward Gorham",
+            "mac": "",
+            "morisId": "",
+            "mount": "Light Pole",
+            "multicast": "",
+            "owner": "City of Madison",
+            "poleId": "",
+            "region": "Southwest",
+            "svcAcct": "",
+            "svcMeter": "",
+            "url": "",
+            "yearAdded": 2012,
+            "Comments": "360 camera",
+            "County": "Dane",
+            "Cam_No": null,
+            "Center-ID": "",
+            "Center-Name": "",
+            "Encoder_IP": "",
+            "Equipment": "",
+            "Install_Address": "",
+            "MAC": "",
+            "Moris_ID": "",
+            "Multicast": "",
+            "Svc_Prov_Acct": "",
+            "Svc_Prov_Meter": "",
+            "URL": ""
+        }
+    }, {
+        "type": "Feature",
+        "geometry": {"type": "Point", "coordinates": [-87.97019174922053, 43.03718072438942]},
+        "properties": {
+            "camNumber": 82,
+            "centerId": "Milwaukee",
+            "centerName": "Milwaukee",
+            "city": "",
+            "comments": "",
+            "county": "Milwaukee",
+            "dateCreated": "2015-07-17 14:28:14",
+            "dateModified": "2015-07-17 14:28:14",
+            "description": "",
+            "encoderIp": "",
+            "equipment": "",
+            "featureGuid": "4a862936-4395-4824-a9ec-2291855efbed",
+            "height": null,
+            "highway": "WIS 175",
+            "instlAdrss": "",
+            "itsId": "CCTV-40-0082",
+            "location": "WIS 175 @ Bluemound Rd",
+            "mac": "",
+            "morisId": "325",
+            "mount": "",
+            "multicast": "",
+            "owner": "",
+            "poleId": "",
+            "region": "Southeast",
+            "svcAcct": "0041-809-830",
+            "svcMeter": "VZ498758",
+            "url": "content.dot.wi.gov/travel/milwaukee/cameras/cam082.jpg",
+            "yearAdded": null,
+            "Comments": "",
+            "County": "Milwaukee",
+            "Cam_No": 82,
+            "Center-ID": "Milwaukee",
+            "Center-Name": "Milwaukee",
+            "Encoder_IP": "",
+            "Equipment": "",
+            "Install_Address": "",
+            "MAC": "",
+            "Moris_ID": "325",
+            "Multicast": "",
+            "Svc_Prov_Acct": "0041-809-830",
+            "Svc_Prov_Meter": "VZ498758",
+            "URL": "content.dot.wi.gov/travel/milwaukee/cameras/cam082.jpg"
+        }
+    }, {
+        "type": "Feature",
+        "geometry": {"type": "Point", "coordinates": [-89.43360610547992, 43.07329856071294]},
+        "properties": {
+            "camNumber": null,
+            "centerId": "",
+            "centerName": "",
+            "city": "City of Madison",
+            "comments": " ",
+            "county": "Dane",
+            "dateCreated": "2016-01-19 12:57:05",
+            "dateModified": "2016-01-19 12:57:05",
+            "description": "Farley University",
+            "encoderIp": "",
+            "equipment": "",
+            "featureGuid": "c9dd8265-326a-492d-afaf-374fdee875e7",
+            "height": 30,
+            "highway": "",
+            "instlAdrss": "",
+            "itsId": "Farley University",
+            "location": "On corner of Farley Ave and Campus Dr (EB)",
+            "mac": "",
+            "morisId": "",
+            "mount": "Light Pole",
+            "multicast": "",
+            "owner": "City of Madison",
+            "poleId": "",
+            "region": "Southwest",
+            "svcAcct": "",
+            "svcMeter": "",
+            "url": "https://cameras.cityofmadison.com/pull.web?camera=462336&s=0",
+            "yearAdded": 2012,
+            "Comments": " ",
+            "County": "Dane",
+            "Cam_No": null,
+            "Center-ID": "",
+            "Center-Name": "",
+            "Encoder_IP": "",
+            "Equipment": "",
+            "Install_Address": "",
+            "MAC": "",
+            "Moris_ID": "",
+            "Multicast": "",
+            "Svc_Prov_Acct": "",
+            "Svc_Prov_Meter": "",
+            "URL": "https://cameras.cityofmadison.com/pull.web?camera=462336&s=0"
+        }
+    }]
+};
\ No newline at end of file
diff --git a/test/specs/layers/LayerBaseVectorGeoJsonSpec.ts b/test/specs/layers/LayerBaseVectorGeoJsonSpec.ts
new file mode 100644
index 0000000..f43b6c0
--- /dev/null
+++ b/test/specs/layers/LayerBaseVectorGeoJsonSpec.ts
@@ -0,0 +1,44 @@
+/**
+ * Created by glenn on 3/10/2017.
+ */
+
+
+import {LayerBaseVectorGeoJson, LayerBaseVectorGeoJsonOptions} from '../../../src/layers/LayerBaseVectorGeoJson';
+
+import {cams, trench, sample_segs} from '../../data/geoJsonFeatures';
+
+describe('LayerBaseVectorGeoJSON', function () {
+    let geoj: LayerBaseVectorGeoJson;
+
+
+    beforeEach(function () {
+        geoj = new LayerBaseVectorGeoJson();
+    });
+
+    it('should instantiate with no options provided', function () {
+        geoj = new LayerBaseVectorGeoJson("");
+        expect(geoj).toBeDefined();
+    });
+
+    it('should instantiate with nothing', function () {
+        geoj = new LayerBaseVectorGeoJson();
+        expect(geoj).toBeDefined();
+    });
+
+    it('should add the cams', function () {
+        geoj.addFeatures(cams);
+        expect(geoj.features.length).toBeGreaterThan(0);
+    });
+
+    it('should add the trenches', function () {
+        geoj.addFeatures(trench);
+        expect(geoj.features.length).toBeGreaterThan(0);
+    });
+    
+    it('should add the mm segments', function () {
+        geoj.addFeatures(sample_segs);
+        expect(geoj.features.length).toBeGreaterThan(0);
+    });
+
+});
+
diff --git a/test/specs/spec.ts b/test/specs/spec.ts
index 4530c20..c9ccdbe 100644
--- a/test/specs/spec.ts
+++ b/test/specs/spec.ts
@@ -2,21 +2,4 @@
  * Created by glenn on 3/10/2017.
  */
 
-
-describe("a simple test", function () {
-   it("should work", function () {
-
-       expect(0).toBe(0);
-
-   });
-
-      it("should not work", function () {
-
-       expect(0).toBe(0);
-
-
-
-
-   });
-
-});
\ No newline at end of file
+import './layers/LayerBaseVectorGeoJsonSpec';
-- 
GitLab