<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">2014/1/3 Andreas Neumann <span dir="ltr"><<a href="mailto:a.neumann@carto.net" target="_blank">a.neumann@carto.net</a>></span><br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
Hi,<br>
<br>
Thank you for your initiative, Alessandro. My comments are inline.<br></blockquote><div><br></div><div><br></div><div>Hello Andreas, thanks for your clarifications, my comments follow. </div><div><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<br>
<br>
Am <a href="tel:03.01.2014%2013" value="+390301201413">03.01.2014 13</a>:06, schrieb Alessandro Pasotti:<br>
<div class="im">> 2014/1/3 Bernhard Ströbl <<a href="mailto:bernhard.stroebl@jena.de">bernhard.stroebl@jena.de</a>><br>
><br>
>> Hi Alessandro,<br>
>><br>
><br>
> Hello Bernard, thanks for your comments!<br><br></div></blockquote><div>[...] </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<div class="im">
><br>
> This is all the configuration you need:<br>
> <a href="https://github.com/elpaso/QGIS-Web-Client/blob/master/php/config.php" target="_blank">https://github.com/elpaso/QGIS-Web-Client/blob/master/php/config.php</a><br>
><br>
> I removed:<br>
> * the DB connection parameters (they are already in the project file)<br>
> * the search table name (it's now the layer name)<br>
> * the displaytext, and search_category fields<br>
><br>
> The idea is that you should not have to modify your table and create any<br>
> particular column to make it work (it might be usefult to do that in any<br>
> case for performance reasons).<br>
<br>
</div>In my case I deliberately decoupled the search completely from the<br>
project - as a I want a lot of search options always available,<br>
regardless of the project, also if the search layer is not available in<br>
the project.<br>
<br>
Imagine a project only containing raster maps. You still want to be able<br>
to search for addresses, parcel numbers, streets, buildings, etc.<br>
without having to load all of these layers into the project.<br>
<br></blockquote><div><br></div><div>I see you point, I believe that both should be possible but I suspect that the zero-configuration approach should come first. </div><div>This because this way you have a working installation with less configuration, you can always override the default behaviour to have more complex search options.</div>
<div><br></div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
BTW: there is an alternative search method that uses the builtin layers<br>
already. See section 4.2 in<br>
<a href="https://raw.github.com/qgis/QGIS-Web-Client/master/README" target="_blank">https://raw.github.com/qgis/QGIS-Web-Client/master/README</a><br>
<br>
It uses QGIS server without any additional scripts necessary. It has a<br>
"drill-down"-like interface which feels different from the other search<br>
method.<br></blockquote><div><br></div><div>I saw this search feature, and I'm using both (the Python-wsgi/PHP one and GetFeatureInfo) as they are both useful, I see them as a "generic search" and an "advanced search", we need both.</div>
<div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<br>
So please just make sure that both versions will work - the decoupled<br>
search as it is now possible and your new idea of deriving search from<br>
the project.<br></blockquote><div><br></div><div><br></div><div>Yes, absolutely agreed, my intention is to add features without breaking the already existing (and yet amazing) features.</div><div><br></div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<div class="im"><br>
>> Be aware of SQL injection!<br>
><br>
><br>
> Since most parameters are now taken directly from the project file, the<br>
> only parameters that need to be passed on the URL are the search text, the<br>
> layer name (which doesn't go directly in the query).<br>
> I'm using PDO prepare statements whenever possible to avoid injections and<br>
> a preg_replace to strip away everything potentially harmful.<br>
><br>
><br>
>><br>
>><br></div></blockquote><div>[...] </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<div class="im"><br>
> Then I would like to get layer from the ProjectSettings and automatically<br>
> select layers for the reference map.<br>
<br>
</div>Again, there is a good reason to do it and there are reasons for not<br>
doing it. In my case I again wanted to decouple the reference map from<br>
the content of the QGIS project. The best reference map in my case was<br>
to use a topographic map series with different scales. I also wanted to<br>
use this reference map in a project where the reference maps layers<br>
aren't present in the project - e.g. in a project about different<br>
orthoimages.<br>
<br>
If you implement this in a configurable way, then I am fine with your<br>
change - but make sure that the current behaviour of decoupled reference<br>
map can be kept, if specified.<br>
<div class="im"><br></div></blockquote><div><br></div><div>Again, I see you point :)</div><div>But again, I'm asking myself which is the easier/simple option to satisfy the vast majority of use cases, I would by default start with the option that works out of the box without the need to configure anything.</div>
<div>Then, show how to completely customize the reference map.</div><div><br></div><div>The overall feeling I've got starting with QGIS Web Client is that the search feature and reference map in QGIS Web Client start with the more complex scenario and require too much user configuration to make it work (even worse: the search requires a particular table structure and column names!), on the contrary, we should start with the simplest scenario and try to make it work with minimal configuration, then show a way to do the most complicated things.</div>
<div><br></div><div> </div><div>[...]</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div class="im">
</div><div class="im">
><br>
>> 6. this might be difficult or not possible: it would be nice to have an<br>
>>> interactive legend so that the user can directly click on a legend item<br>
>>> to filter->zoom to the features that match the selected legend item. I<br>
>>> feel this would require changes to the server side too....<br>
>>><br>
>><br>
>> the legend as created with GetLegendGraphic is - well - a graphic. I<br>
>> cannot see how you could implement this<br>
<br>
</div>If the legend graphic would be an intelligent SVG graphic (with some<br>
metadata in the SVG elements) rather than a stupid PNG I could see this<br>
as a possibility. It would need an extension in the GetLegendGraphic<br>
request. Each legend object in an SVG legend could know its relation<br>
with the rule or category and the user could interact with it.<br>
<br>
There is already a filter parameter available that allow the filtering<br>
of a layer. See<br>
<a href="http://hub.qgis.org/projects/quantum-gis/wiki/QGIS_Server_Tutorial#FILTER-parameter" target="_blank">http://hub.qgis.org/projects/quantum-gis/wiki/QGIS_Server_Tutorial#FILTER-parameter</a><br>
<br>
If an SVG graphics (with a bit of Javascript) could be coupled with the<br>
already implemented FILTER parameter it would be rather easy to implement.<br>
<br>
I would be interested in this improvement myself. So maybe we could team<br>
up with this. Would be useful to further discuss what we want to<br>
accomplish with the interactive legend.<br></blockquote><div><br></div><div><br></div><div>Great that you're in!</div><div><br></div><div>The simplest approach I see is to use the RULE parameter to GetLegendGraphic to download the individual image for each class, then build the legend on the client with a small Python/PHP helper. </div>
<div><br></div><div>An SVG image would also fit and would not require an additional Python/PHP helper as long as the SVG has hooks to add js functionality to the legend items.</div><div><br></div><div>Another option is to do some mapserver-like templating. </div>
<div><br></div><div>What about filing a ticket for this feature and moving the discussion there?</div><div><br></div></div><div><br></div>-- <br>Alessandro Pasotti<br>w3: <a href="http://www.itopen.it">www.itopen.it</a>
</div></div>