-
-
Notifications
You must be signed in to change notification settings - Fork 278
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Calling setVisibleLayers()
on a dynamic layer does not correctly update layer control widget
#700
Comments
Correctly update layer control widget when calling `setVisibleLayers()` on a dynamic layer, fixes cmv#700
I think the issue here is you can't pass an empty array to layer.setVisibleLayers([-1]); Docs mention this here: https://developers.arcgis.com/javascript/3/jsapi/arcgisdynamicmapservicelayer-amd.html#setvisiblelayers
I agree, it would be ideal if this behavior were possible. But the way that the esri api's dynamic layer works makes this a little bit complicated. Initially, the rest services default visibility is used to display the checkboxes on the layer. This initial array allows group layers in the array. If a group layer is in the array, and a child sublayer is in the array, that sublayer will be visible: visibleLayers: [0, 1]
Calling visibleLayers: [0, 1, 4]
|
No, it's still broken, try 1,2,3 in the array instead.
On Wed, 22 Mar 2017 at 2:22 AM, Gregg Roemhildt <notifications@github.com> wrote:
I think the issue here is you can't pass an empty array to setVisibleLayers
it needs to be a -1 instead:
layer.setVisibleLayers([-1]);
Docs mention this here:
https://developers.arcgis.com/javascript/3/jsapi/arcgisdynamicmapservicelayer-amd.html#setvisiblelayers
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub
<#700 (comment)>, or mute
the thread
<https://github.com/notifications/unsubscribe-auth/AAibY2XO17brpJgW_-8fqRfJ-9zkN1Wqks5rn88LgaJpZM4MjGgx>
.
|
Note that "Emergency Operations" and "Event Information" are ticked. Also,
there is no way to have "Event Grids" and "Road Blocks" without that
"Emergency Operations" and "Event Information" so it doesn't behave the
same as the setting in viewer.js
…On Wed, 22 Mar 2017 at 6:53 AM, Gregg Roemhildt ***@***.***> wrote:
1,2,3 appears to work for me.
[image: image]
<https://cloud.githubusercontent.com/assets/5471079/24162414/6f7caccc-0e35-11e7-8b89-55fd0ef6c949.png>
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub
<#700 (comment)>, or mute
the thread
<https://github.com/notifications/unsubscribe-auth/AAibYxCGmmVT4cRppdXUe818rxMRj5nfks5roA61gaJpZM4MjGgx>
.
|
Yes, I think that's the behavior that was chosen because the alternative was to uncheck the group layers when setVisibleLayers is called, which might be an unexpected behavior. Especially if you have several levels of group layer nesting. Is that the issue your pull request is targeting? |
Yes, as far as I can tell from my testing
…On Wed, 22 Mar 2017 at 7:12 AM, Gregg Roemhildt ***@***.***> wrote:
Note that "Emergency Operations" and "Event Information" are ticked.
Yes, I think that's the behavior that was chosen because the alternative
was to uncheck the group layers when setVisibleLayers is called, which
might be an unexpected behavior. Especially if you have several levels of
group layer nesting.
Is that the issue your pull request is targeting?
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub
<#700 (comment)>, or mute
the thread
<https://github.com/notifications/unsubscribe-auth/AAibYzVMX9ScWjDf5LRpcgrkLfg4LeQ8ks5roBMigaJpZM4MjGgx>
.
|
Okay, I think I understand what's going on now in your pull request, but correct me if I"m wrong:
I like the fact that it allows more flexibility in the layer control. I think there's a problem though. Essentially, its changing the behavior of the api. It is (imo) for the better but regardless changing the api will have unintended consequences. For instance, any other widget that calls |
Yes, It would probably be better somewhere else, but I don't know where.
…On Wed, 22 Mar 2017 at 8:14 AM, Gregg Roemhildt ***@***.***> wrote:
Okay, I think I understand what's going on now in your pull request, but
correct me if I"m wrong:
1. layer.setVisibleLaysers([1,2,3]) is called
2. layer control is overriding the default setVisibleLayers with its
own which does the following:
a. Removes sub layers from the array if the parent group id is not in
the array. Layer array becomes []
b. Sets the array to [-1] if no layers are in the array after removal.
Layer array becomes [-1]
c. calls the original setVisibleLayers with the modified array
I like the fact that it allows more flexibility in the layer control. I
think there's a problem with step b though. Essentially, its changing the
behavior of the api. It is (imo) for the better but regardless changing the
api will have unintended consequences.
For instance, any other widget that calls setVisibleLayers will have to
pass the group layers in order for the visibility to work, where previously
only the child id's were needed. And if the layer control isn't included,
then these widgets would not work the same.
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub
<#700 (comment)>, or mute
the thread
<https://github.com/notifications/unsubscribe-auth/AAibYxR4xnXTs2Kf8j9HpCiQWCqdxozrks5roCGqgaJpZM4MjGgx>
.
|
Instead, I think the layer control needs to maintain its own |
Perhaps use the layerControl/setVisibleLayers topic or something?
…On Wed, 22 Mar 2017 at 8:18 AM, Gregg Roemhildt ***@***.***> wrote:
Instead, I think the layer control needs to maintain its own visibleLayer
array and not modify the original one. We can't change the api even if its
written in a way that doesn't work well.
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub
<#700 (comment)>, or mute
the thread
<https://github.com/notifications/unsubscribe-auth/AAibYx4S7UzdwLlG0NtTV62RkV_UAcMQks5roCKegaJpZM4MjGgx>
.
|
we definitely do not want to modify/override the Esri API. I want to get a handle on exactly what the issue is before commenting further. Might be related to other issues regarding layer visibility noted in the past. |
thinking out loud: using We have to keep in mind that other widgets like identify use the Bottom line: more discussion and testing required... |
Yep. Whatever we do needs to also correctly handle other scenarios such as:
imageParameters: buildImageParameters({
layerIds: [0, 2, 4, 5, 8, 10, 12, 21],
layerOption: 'show'
})
layerControlLayerInfos: {
layerIds: [0, 2, 4, 5, 8, 9, 10, 12, 21]
}
layerControlLayerInfos: {
subLayerInfos: [
{
id: 0
}, {
id: 2
}, {
id: 4
}, {
id: 5
}, {
id: 8
}, {
id: 9
}, {
id: 10
}, {
id: 12
}, {
id: 21
}
]
} Each of these examples are supported configurations to set the initial layer visibility yet the layerControl does not handle any of them correctly with respect to group laer. I have not looked at whether the pull request fixes these. Supporting what is in the configuration is just as important if not more important than supporting programmatic control of layer visibility through I think we also need to consider a tri-state checkbox for the group layer in the layerControl to more accurately reflect the state of the map. That is a topic for another day... |
Continued thought. # 2 above: layerControlLayerInfos: {
layerIds: [0, 2, 4, 5, 8, 9, 10, 12, 21]
} may provide the correct results. More investigation is needed to be sure... I prefer # 3 as it provides the most control - you can determine which sub layers and groups are included in the layerControl AND you can set the layerControlLayerInfos: {
subLayerInfos: [
{
id: 0,
defaultVisibility: false
}, {
id: 2
}, {
id: 4
}, {
id: 5
}, {
id: 8
}, {
id: 9
}, {
id: 10
}, {
id: 12
}, {
id: 21
}
]
} |
Related: #605 |
I am completing a redesign of how group layers within a Dynamic layer are handled within the layerControl. The behavior will be similar to the newly introduced "Group Layer". More intuitive and consistent - at least from my perspectice. The changes will address the issue from this PR in a different way. I won't close this PR yet. |
Love the new folder icons! Will this change the way the default visibility is set up @tmcgee? Meaning if I set "Louisville Public Safety" Group to be off by default, and I turn it on using the checkbox, will that set all child layers to a |
No, currently toggling the layer visibility would not change the visibility of the sub layers. This is intentional as I think that would be undesirable for many (most?) implementations. There is an existing menu option to set all sub layers visible/invisible that handles this. Definitely open to adjustments of my current view. |
Perfect. That was my only concern 👍 Edit: what if I set "Public Safety" off by default, and then check the box for public safety to visible? Does that set all the sublayers to visible or just the ones that are |
Regarding your edit: The behavior is consistent with what is implemented for the Grouped layer currently and how most 3-state check boxes work on the web (so hopefully familiar to users). If any child sub layers in the layerControl are not visible, clicking the checkbox would make all sub layers (AND child folders) in the layerControl visible. If all of the sublayers are visible, they would all be toggled to not visible. I think I have handled all the various scenarios using |
That makes sense. I think the new behavior will implement some changes that layer publishers will need to address but I do believe it is for the better and will hopefully be a welcome addition by the community. |
I am hoping to avoid that as much as possible but perhaps may not succeed in all cases. What cannot or should not be changed by republishing can hopefully be managed within configuration. |
How often can you reproduce it?
Description:
Calling
setVisibleLayers()
on a dynamic layer does not correctly update the layer control widget.Steps to reproduce:
app.layers[1].setVisibleLayers([]);
(that assumes that app.layers[1] is Louisvile Public Safety, the first layer didn't load - CORS blocked it I think)Expected results:
All sublayers and folder under Louisvile Public Safety should be unticked and not visible.
Actual results:
All sublayers under Louisvile Public Safety are unticked and hidden, all folders are ticked.
It should also be possible to set some sublayers to be ticked in the layer control widget, but have their parent folder unticked (like how Schools under Public Safety is default unticked)
Environment:
The text was updated successfully, but these errors were encountered: