diff --git a/index.js b/index.js index 14f66e4..4f8bd33 100644 --- a/index.js +++ b/index.js @@ -24,7 +24,7 @@ function Compare(a, b, options) { this._setPosition(this._bounds.width / 2); syncMove(a, b); - b.on('resize', function() { + b.on('resize', function () { this._bounds = b.getContainer().getBoundingClientRect(); if (this._x) this._setPosition(this._x); }.bind(this)); @@ -39,12 +39,49 @@ function Compare(a, b, options) { } Compare.prototype = { - _setPointerEvents: function(v) { + /** + * Allows for custom full screen button. + * @param a The map on the left. + * @param b The map on the right. + * @param originId The id of the div where both the maps originated from. + */ + fullscreen: function (a, b, originId) { + + // see if we have a full screen div + var fsc = document.getElementById('mapboxgl-compare-fullscreen'); + + // if full screen div found, put the maps back into the origin div + if (fsc) { + // get origin div + var origin = document.getElementById(originId); + + // add maps back to origin div + origin.appendChild(a.getContainer()); + origin.appendChild(b.getContainer()); + + // remove full screen container + document.body.removeChild(fsc); + } else { + + // create full screen container and append maps to it + fsc = document.createElement('div'); + fsc.className = 'mapboxgl-compare-fullscreen'; + fsc.id = 'mapboxgl-compare-fullscreen'; + fsc.appendChild(a.getContainer()); + fsc.appendChild(b.getContainer()); + document.body.appendChild(fsc); + } + + // resize the maps + a.resize(); + b.resize(); + }, + _setPointerEvents: function (v) { this._container.style.pointerEvents = v; this._swiper.style.pointerEvents = v; }, - _onDown: function(e) { + _onDown: function (e) { if (e.touches) { document.addEventListener('touchmove', this._onMove); document.addEventListener('touchend', this._onTouchEnd); @@ -54,7 +91,7 @@ Compare.prototype = { } }, - _setPosition: function(x) { + _setPosition: function (x) { x = Math.min(x, this._bounds.width); var pos = 'translate(' + x + 'px, 0)'; this._container.style.transform = pos; @@ -63,7 +100,7 @@ Compare.prototype = { this._x = x; }, - _onMove: function(e) { + _onMove: function (e) { if (this.options && this.options.mousemove) { this._setPointerEvents(e.touches ? 'auto' : 'none'); } @@ -71,17 +108,17 @@ Compare.prototype = { this._setPosition(this._getX(e)); }, - _onMouseUp: function() { + _onMouseUp: function () { document.removeEventListener('mousemove', this._onMove); document.removeEventListener('mouseup', this._onMouseUp); }, - _onTouchEnd: function() { + _onTouchEnd: function () { document.removeEventListener('touchmove', this._onMove); document.removeEventListener('touchend', this._onTouchEnd); }, - _getX: function(e) { + _getX: function (e) { e = e.touches ? e.touches[0] : e; var x = e.clientX - this._bounds.left; if (x < 0) x = 0; diff --git a/style.css b/style.css index 53321aa..215e5bc 100644 --- a/style.css +++ b/style.css @@ -1,22 +1,35 @@ .mapboxgl-compare { - background-color:#fff; - position:absolute; - width:2px; - height:100%; - z-index:1; - } -.mapboxgl-compare .compare-swiper { - background-color:#3887be; - box-shadow:inset 0 0 0 2px #fff; - display:inline-block; - border-radius:50%; - position:absolute; - width:60px; - height:60px; - top:50%; - left:-30px; - margin:-30px 1px 0; + background-color: #fff; + position: absolute; + width: 2px; + height: 100%; + z-index: 1; +} + +.compare-swiper { + background-color: #3887be; + box-shadow: inset 0 0 0 2px #fff; + display: inline-block; + border-radius: 50%; + position: absolute; + width: 60px; + height: 60px; + top: 50%; + left: -30px; + margin: -30px 1px 0; color: #fff; - cursor:ew-resize; - background-image:url(); - } + cursor: ew-resize; + background-image: url(); +} + +.mapboxgl-compare-fullscreen { + display: block !important; + z-index: 999 !important; + position: fixed !important; + width: 100% !important; + height: 100% !important; + top: 0 !important; + right: 0 !important; + left: 0 !important; + bottom: 0 !important; +}