Skip to content

Commit

Permalink
Merge pull request #1006 from simon-leech/main
Browse files Browse the repository at this point in the history
Layer Restrictions
  • Loading branch information
RobAndrewHurst authored Nov 17, 2023
2 parents d41bfe1 + 7fdcab6 commit 3c04e78
Show file tree
Hide file tree
Showing 3 changed files with 56 additions and 22 deletions.
70 changes: 48 additions & 22 deletions lib/ui/layers/view.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -32,22 +32,22 @@ mapp.utils.merge(mapp.dictionaries, {
export default (layer) => {

if (layer.view === null) {

// Do not create a layer view.
return layer;
return layer;
}

layer.view = mapp.utils.html.node`<div class="layer-view">`

// Create content from layer view panels and plugins
const content = Object.keys(layer)
.map(key => mapp.ui.layers.panels[key] && mapp.ui.layers.panels[key](layer))
.filter(panel => typeof panel !== 'undefined')

// Set default order for panel if not explicit in layer config.
layer.panelOrder = layer.panelOrder || ['draw-drawer','dataviews-drawer','filter-drawer','style-drawer','meta']
layer.panelOrder = layer.panelOrder || ['draw-drawer', 'dataviews-drawer', 'filter-drawer', 'style-drawer', 'meta']

content.sort((a,b)=>{
content.sort((a, b) => {

// Sort according to data-id in panelOrder array.
return layer.panelOrder.findIndex(chk => chk === a.dataset?.id)
Expand All @@ -62,16 +62,16 @@ export default (layer) => {
data-id=zoomToExtent
title=${mapp.dictionary.layer_zoom_to_extent}
class="mask-icon fullscreen"
onclick=${async e=>{
// response indicates whether locations were found.
let response = await layer.zoomToExtent()
// disable button if no locations were found.
e.target.disabled = !response
}}>` || ``
// Create toogleDisplay button for header.
onclick=${async e => {
// response indicates whether locations were found.
let response = await layer.zoomToExtent()
// disable button if no locations were found.
e.target.disabled = !response
}}>` || ``

// Create toggleDisplay button for header.
const toggleDisplay = mapp.utils.html.node`
<button
data-id=display-toggle
Expand All @@ -98,7 +98,7 @@ export default (layer) => {
// Create layer drawer node.
layer.drawer = mapp.ui.elements.drawer({
data_id: `layer-drawer`,
class: `layer-view raised ${layer.classList || ''} ${content.length? '' : 'empty'}`,
class: `layer-view raised ${layer.classList || ''} ${content.length ? '' : 'empty'}`,
header: header,
content: content
})
Expand All @@ -112,23 +112,49 @@ export default (layer) => {
content.forEach(el => layer.view.append(el))
}

// Create a div for the magnifying glass icon
const zoomButton = mapp.utils.html.node`<button class="mask-icon search" title="Zoom To" data-id="zoom-to">`

// Add an event listener to the magnifying glass icon to show the zoom level button when clicked
zoomButton.addEventListener('click', () => {
// Zoom to the extent of the layer if table provided.
if (layer.tableCurrent() !== null) {
layer.zoomToExtent();
layer.show();
};

// Zoom to the zoom level if tables object.
for (const key in layer.tables) {
if (layer.tables[key] !== null) {
layer.mapview.Map.getView().setZoom(key);
layer.show();
}
}
});

// Add the zoom Button before the layer toggle.
layer.view.querySelector('[data-id=display-toggle]').before(zoomButton)

// The layer view drawer should be disabled if layer.tables are not available for the current zoom level.
layer.mapview.Map.getTargetElement().addEventListener('changeEnd', ()=>{
layer.mapview.Map.getTargetElement().addEventListener('changeEnd', () => {

if (!layer.tables) return;

if (layer.tableCurrent() === null) {

// Collapse drawer and disable layer.view.
layer.view.querySelector('[data-id=layer-drawer]').classList.remove('expanded')
layer.view.classList.add('disabled')

} else {
// Remove the active state from the layer view toggle button.
layer.view.querySelector('[data-id=display-toggle]').classList.remove('on')
// Set the layer toggle button to disabled.
layer.view.querySelector('[data-id=display-toggle]').classList.add('disabled')

// Enable the layer.view.
layer.view.classList.remove('disabled')
} else {
// Set the layer toggle button to enabled.
layer.view.querySelector('[data-id=display-toggle]').classList.remove('disabled')
}

})

return layer
Expand Down
4 changes: 4 additions & 0 deletions public/css/_icons.css
Original file line number Diff line number Diff line change
Expand Up @@ -620,6 +620,10 @@
mask-image: url("../icons/icon-toggle-on.svg");
}
}
&.disabled {
background-color: var(--color-primary-light);
pointer-events: none;
}
}

.touch-app {
Expand Down
4 changes: 4 additions & 0 deletions public/css/ui.css
Original file line number Diff line number Diff line change
Expand Up @@ -816,6 +816,10 @@ h3 {
mask-image: url();
}
}
&.disabled {
background-color: var(--color-primary-light);
pointer-events: none;
}
}
.touch-app {
&.bg-icon {
Expand Down

0 comments on commit 3c04e78

Please sign in to comment.