From 6bf3e99167dcdf1984687683bc0db529746976f9 Mon Sep 17 00:00:00 2001 From: Andrew Fiedler Date: Tue, 11 Oct 2016 16:57:02 -0700 Subject: [PATCH] DDF-2644 Refactor layer preferences to remove map, checkboxes, and apply - Removed apply and updated saving to be automatic. As such, the map is no longer necessary (you can watch the main map update in real time). - Removed checkboxes in favor of clicking on the layer name. - Added opacity indication of whether or not a layer is shown. - Upgraded to latest cesium in order to pull in https://github.com/AnalyticalGraphicsInc/cesium/pull/4258, which had been causing issues with hiding and showing of layers too quickly (cesium would crash). --- catalog/ui/catalog-ui-search/package.json | 2 +- .../visualization/maps/cesium/map.cesium.js | 5 +- .../maps/openlayers/map.openlayers.js | 2 - .../src/main/webapp/css/searchPage.css | 11 -- .../view/preferences/PreferencesModal.view.js | 134 +++--------------- .../src/main/webapp/less/components/init.less | 1 + .../main/webapp/less/components/layers.less | 21 +++ .../preferences/layer.list.handlebars | 1 - .../layer.preferences.tab.handlebars | 1 - .../preferences/layerPicker.handlebars | 8 +- .../preferences/preference.buttons.handlebars | 1 - 11 files changed, 51 insertions(+), 136 deletions(-) create mode 100644 catalog/ui/catalog-ui-search/src/main/webapp/less/components/layers.less diff --git a/catalog/ui/catalog-ui-search/package.json b/catalog/ui/catalog-ui-search/package.json index c805859926b4..a19816e95367 100644 --- a/catalog/ui/catalog-ui-search/package.json +++ b/catalog/ui/catalog-ui-search/package.json @@ -77,7 +77,7 @@ "backbone.modelbinder": "1.1.0", "backbone.paginator": "2.0.5", "bootstrap": "3.2.0", - "cesium": "1.24.0", + "cesium": "1.26.0", "density-clustering": "1.3.0", "dropzone": "^4.3.0", "geo-convex-hull": "1.2.0", diff --git a/catalog/ui/catalog-ui-search/src/main/webapp/component/visualization/maps/cesium/map.cesium.js b/catalog/ui/catalog-ui-search/src/main/webapp/component/visualization/maps/cesium/map.cesium.js index bb0dd251e2fb..075fa53047d2 100644 --- a/catalog/ui/catalog-ui-search/src/main/webapp/component/visualization/maps/cesium/map.cesium.js +++ b/catalog/ui/catalog-ui-search/src/main/webapp/component/visualization/maps/cesium/map.cesium.js @@ -39,8 +39,6 @@ Cesium.BingMapsApi.defaultKey = properties.bingKey || 0; var imageryProviderTypes = LayerCollectionController.imageryProviderTypes; var CesiumLayerCollectionController = LayerCollectionController.extend({ initialize: function() { - this.listenTo(wreqr.vent, 'preferencesModal:reorder:bigMap', this.reIndexLayers); - // there is no automatic chaining of initialize. LayerCollectionController.prototype.initialize.apply(this, arguments); } @@ -67,7 +65,8 @@ function createMap(insertionElement) { infoBox: false, //skyBox: false, //skyAtmosphere: false, - baseLayerPicker: false // Hide the base layer picker + baseLayerPicker: false, // Hide the base layer picker, + mapMode2D: 0 } }); diff --git a/catalog/ui/catalog-ui-search/src/main/webapp/component/visualization/maps/openlayers/map.openlayers.js b/catalog/ui/catalog-ui-search/src/main/webapp/component/visualization/maps/openlayers/map.openlayers.js index ad37908014b0..3af34cfe6371 100644 --- a/catalog/ui/catalog-ui-search/src/main/webapp/component/visualization/maps/openlayers/map.openlayers.js +++ b/catalog/ui/catalog-ui-search/src/main/webapp/component/visualization/maps/openlayers/map.openlayers.js @@ -36,8 +36,6 @@ var defaultColor = '#3c6dd5'; var OpenLayerCollectionController = LayerCollectionController.extend({ initialize: function() { - this.listenTo(wreqr.vent, 'preferencesModal:reorder:bigMap', this.reIndexLayers); - // there is no automatic chaining of initialize. LayerCollectionController.prototype.initialize.apply(this, arguments); } diff --git a/catalog/ui/catalog-ui-search/src/main/webapp/css/searchPage.css b/catalog/ui/catalog-ui-search/src/main/webapp/css/searchPage.css index bb2c9f91900a..9a2749ff4d56 100644 --- a/catalog/ui/catalog-ui-search/src/main/webapp/css/searchPage.css +++ b/catalog/ui/catalog-ui-search/src/main/webapp/css/searchPage.css @@ -1407,17 +1407,6 @@ a.pause:hover, a.pause:focus { transform: scale(2, 1.3); } -.layerPickers .table > thead > tr > td, -.layerPickers .table > tbody > tr > td, -.layerPickers .table > tfoot > tr > td { - padding: 2px; - vertical-align: middle; - max-width: 6.25rem; - white-space: normal; - overflow: hidden; - text-overflow: ellipsis; -} - .layerPickers tbody { /* overflow:auto and white-space:nowrap make the tbody "scrollable", diff --git a/catalog/ui/catalog-ui-search/src/main/webapp/js/view/preferences/PreferencesModal.view.js b/catalog/ui/catalog-ui-search/src/main/webapp/js/view/preferences/PreferencesModal.view.js index 101075f665d4..589dc8817a57 100644 --- a/catalog/ui/catalog-ui-search/src/main/webapp/js/view/preferences/PreferencesModal.view.js +++ b/catalog/ui/catalog-ui-search/src/main/webapp/js/view/preferences/PreferencesModal.view.js @@ -12,7 +12,7 @@ * . * **/ -/* global define,require*/ +/* global define*/ define([ 'application', 'underscore', @@ -27,14 +27,10 @@ define([ 'templates/preferences/layer.list.handlebars', 'templates/preferences/layerPicker.handlebars', 'templates/preferences/preference.buttons.handlebars', - 'component/singletons/user-instance', - 'wreqr', - // load dependencies - 'spectrum', - 'jquerySortable' + 'component/singletons/user-instance' ], function (Application, _, Marionette, Backbone, $, properties, maptype, Modal, preferencesModalTemplate, layerPrefsTabTemplate, layerListTemplate, - layerPickerTemplate, preferenceButtonsTemplate, user, wreqr) { + layerPickerTemplate, preferenceButtonsTemplate, user) { var PrefsModalView = Marionette.LayoutView.extend({ setDefaultModel: function(){ this.model = user.get('user>preferences'); @@ -83,114 +79,27 @@ define([ initialize: function () { }, onRender: function () { - var viewLayerModels = []; - this.model.each(function (layerModel) { - var clonedLayerModel = layerModel.clone(); - clonedLayerModel.set('modelCid', layerModel.cid); - viewLayerModels.push(clonedLayerModel); - }); - var MapLayerConstructor = user.get('user>preferences>mapLayers').constructor; - this.viewMapLayers = new MapLayerConstructor(viewLayerModels); // listen to any change on all models in collection. - this.listenTo(this.viewMapLayers, 'change', this.onEdit); - if (maptype.is3d()) { - require(['cesium', 'js/controllers/cesium.layerCollection.controller'], function(Cesium, CesiumLayersController){ - PrefsModalView.CesiumLayersController = CesiumLayersController.extend({ - showMap: function () { - this.makeMap({ - element: this.options.element.el.querySelector('#layerPickerMap'), - cesiumOptions: { - sceneMode: Cesium.SceneMode.SCENE3D, - animation: false, - geocoder: false, - navigationHelpButton: false, - fullscreenButton: false, - timeline: false, - homeButton: false, - sceneModePicker: false, - baseLayerPicker: false - } - }); - } - }); - this.widgetController = new PrefsModalView.CesiumLayersController({ - collection: this.viewMapLayers, - element: this - }); - - // HACK fix it - this.layerPickers = new PrefsModalView.LayerPickerTable({ - childView: PrefsModalView.LayerPicker, - collection: this.viewMapLayers, - childViewOptions: { widgetController: this.widgetController } - }); - this.layerButtons = new PrefsModalView.Buttons({ tabView: this }); - this.showLayerPickersAndLayerButtons(); - }.bind(this)); - } else if (maptype.is2d()) { - require(['js/controllers/ol.layerCollection.controller'], function(OpenLayersController){ - PrefsModalView.OpenLayersController = OpenLayersController.extend({ - showMap: function () { - this.makeMap({ - element: this.options.element.el.querySelector('#layerPickerMap'), - zoom: 2, - controls: [] - }); - } - }); - this.widgetController = new PrefsModalView.OpenLayersController({ - collection: this.viewMapLayers, - element: this - }); - - // HACK fix it - this.layerPickers = new PrefsModalView.LayerPickerTable({ - childView: PrefsModalView.LayerPicker, - collection: this.viewMapLayers, - childViewOptions: { widgetController: this.widgetController } - }); - this.layerButtons = new PrefsModalView.Buttons({ tabView: this }); - this.showLayerPickersAndLayerButtons(); - }.bind(this)); - } + this.listenTo(this.model, 'change', this.save); + // HACK fix it + this.layerPickers = new PrefsModalView.LayerPickerTable({ + childView: PrefsModalView.LayerPicker, + collection: this.model + }); + this.layerButtons = new PrefsModalView.Buttons({ tabView: this }); + this.showLayerPickersAndLayerButtons(); }, showLayerPickersAndLayerButtons: function(){ this.layerPickersRegion.show(this.layerPickers); this.layerButtonsRegion.show(this.layerButtons); - this.widgetController.showMap('layerPickerMap'); - }, - onDestroy: function () { - this.viewMapLayers = null; - this.widgetController.destroy(); - }, - onEdit: function () { - if (!this.isEdited) { - this.layerButtons.ui.save.toggleClass('btn-default').toggleClass('btn-primary'); - this.isEdited = true; - } }, save: function () { - if (this.isEdited) { - var mapLayers = this.model; - this.viewMapLayers.each(function (viewLayer) { - var layer = mapLayers.get(viewLayer.get('modelCid')); - if (viewLayer.get('alpha') !== layer.get('alpha')) { - layer.set('alpha', viewLayer.get('alpha')); - } - if (viewLayer.get('show') !== layer.get('show')) { - layer.set('show', viewLayer.get('show')); - } - }); - this.model.sort(); - this.model.savePreferences(); - this.isEdited = false; - this.layerButtons.ui.save.toggleClass('btn-default').toggleClass('btn-primary'); - wreqr.vent.trigger('preferencesModal:reorder:bigMap'); - } + this.model.sort(); + this.model.savePreferences(); + this.layerButtons.ui.save.toggleClass('btn-default').toggleClass('btn-primary'); }, resetDefaults: function () { - this.onEdit(); - this.viewMapLayers.each(function (viewLayer) { + this.model.each(function (viewLayer) { var url = viewLayer.get('url'); var defaultConfig = _.find(properties.imageryProviders, function (layerObj) { return url === layerObj.url; @@ -198,7 +107,8 @@ define([ viewLayer.set('show', true); viewLayer.set('alpha', defaultConfig.alpha); }); - this.viewMapLayers.sort(); + this.model.sort(); + this.save(); } }); /* @@ -240,19 +150,19 @@ define([ className: 'layerPicker-row', ui: { range: 'input[type="range"]' }, events: { 'sort': 'render' }, - initialize: function (options) { + initialize: function () { this.modelBinder = new Backbone.ModelBinder(); - this.widgetController = options.widgetController; this.$el.data('layerPicker', this); // make model available to sortable.update() this.listenTo(this.model, 'change:show', this.changeShow); }, onRender: function () { var layerBindings = Backbone.ModelBinder.createDefaultBindings(this.el, 'name'); this.modelBinder.bind(this.model, this.$el, layerBindings); - this.ui.range.prop('disabled', !this.model.get('show')); + this.changeShow(); }, - changeShow: function (model) { - this.ui.range.prop('disabled', !model.get('show')); + changeShow: function () { + this.$el.toggleClass('is-disabled', !this.model.get('show')); + this.ui.range.prop('disabled', !this.model.get('show')); }, onDestroy: function () { this.modelBinder.unbind(); diff --git a/catalog/ui/catalog-ui-search/src/main/webapp/less/components/init.less b/catalog/ui/catalog-ui-search/src/main/webapp/less/components/init.less index 1984fa9280eb..d3d563e287b4 100644 --- a/catalog/ui/catalog-ui-search/src/main/webapp/less/components/init.less +++ b/catalog/ui/catalog-ui-search/src/main/webapp/less/components/init.less @@ -7,6 +7,7 @@ @import "gradient"; @import "headers"; @import "labels"; +@import "layers"; @import "focus"; @import "list"; @import "loading"; diff --git a/catalog/ui/catalog-ui-search/src/main/webapp/less/components/layers.less b/catalog/ui/catalog-ui-search/src/main/webapp/less/components/layers.less new file mode 100644 index 000000000000..631ce12e2b21 --- /dev/null +++ b/catalog/ui/catalog-ui-search/src/main/webapp/less/components/layers.less @@ -0,0 +1,21 @@ +.layerPickers .table > thead > tr > td, +.layerPickers .table > tbody > tr > td, +.layerPickers .table > tfoot > tr > td { + padding: 2px; + vertical-align: middle; + max-width: 6.25rem; + white-space: normal; + overflow: hidden; + text-overflow: ellipsis; + + label { + cursor: pointer; + } + input[type="checkbox"] { + display: none; + } +} + +.layerPickers .table > tbody > tr.is-disabled { + opacity: .6; +} \ No newline at end of file diff --git a/catalog/ui/catalog-ui-search/src/main/webapp/templates/preferences/layer.list.handlebars b/catalog/ui/catalog-ui-search/src/main/webapp/templates/preferences/layer.list.handlebars index 0b905912e599..8e05e81d2a8d 100644 --- a/catalog/ui/catalog-ui-search/src/main/webapp/templates/preferences/layer.list.handlebars +++ b/catalog/ui/catalog-ui-search/src/main/webapp/templates/preferences/layer.list.handlebars @@ -14,7 +14,6 @@ - diff --git a/catalog/ui/catalog-ui-search/src/main/webapp/templates/preferences/layer.preferences.tab.handlebars b/catalog/ui/catalog-ui-search/src/main/webapp/templates/preferences/layer.preferences.tab.handlebars index 0ecae8a5bc56..ff2cf2331195 100644 --- a/catalog/ui/catalog-ui-search/src/main/webapp/templates/preferences/layer.preferences.tab.handlebars +++ b/catalog/ui/catalog-ui-search/src/main/webapp/templates/preferences/layer.preferences.tab.handlebars @@ -11,6 +11,5 @@ * **/ --}} -
diff --git a/catalog/ui/catalog-ui-search/src/main/webapp/templates/preferences/layerPicker.handlebars b/catalog/ui/catalog-ui-search/src/main/webapp/templates/preferences/layerPicker.handlebars index 26422a3a75ed..779f84d12c8d 100644 --- a/catalog/ui/catalog-ui-search/src/main/webapp/templates/preferences/layerPicker.handlebars +++ b/catalog/ui/catalog-ui-search/src/main/webapp/templates/preferences/layerPicker.handlebars @@ -12,10 +12,10 @@ **/ --}} -
- - - + diff --git a/catalog/ui/catalog-ui-search/src/main/webapp/templates/preferences/preference.buttons.handlebars b/catalog/ui/catalog-ui-search/src/main/webapp/templates/preferences/preference.buttons.handlebars index 254dec943335..0dccdf050b2e 100644 --- a/catalog/ui/catalog-ui-search/src/main/webapp/templates/preferences/preference.buttons.handlebars +++ b/catalog/ui/catalog-ui-search/src/main/webapp/templates/preferences/preference.buttons.handlebars @@ -11,6 +11,5 @@ * **/ --}} -