<html><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /></head><body style='font-size: 10pt; font-family: Verdana,Geneva,sans-serif'>
<p>Hi Nyall,</p>
<p>Thank you very much for your detailed reply. Good to hear that there is an interest in making this happen. Is this something that could be added during QGIS 3.x life span or would this have to wait for QGIS 4.x? Would this be something for a 2021 QGIS grant?</p>
<p>About my specific scenario:</p>
<p>I was looking for a to_boolean() conversion function - but it doesn't exist. Would the alternative "eval(@debugging)" be the way here - are there any downsides of using eval() in this context? @debugging would hold a string 'true' or 'false'.</p>
<p>Greetings,</p>
<p>Andreas</p>
<p id="reply-intro">On 2020-06-12 02:15, Nyall Dawson wrote:</p>
<blockquote type="cite" style="padding: 0 0.4em; border-left: #1010ff 2px solid; margin: 0">
<div class="pre" style="margin: 0; padding: 0; font-family: monospace">On Thu, 11 Jun 2020 at 01:26, Andreas Neumann <<a href="mailto:a.neumann@carto.net">a.neumann@carto.net</a>> wrote:
<blockquote type="cite" style="padding: 0 0.4em; border-left: #1010ff 2px solid; margin: 0"><br />Hi,<br /><br />I have a question about the variables that can be defined on different scopes. They are most of the times (or always?) strings, if I manually define them - right?</blockquote>
<br />If you manually define them, then yes -- they are always strings.<br /><br />
<blockquote type="cite" style="padding: 0 0.4em; border-left: #1010ff 2px solid; margin: 0">Some of the automatic variables might be of a different type (like date, layer, etc.)</blockquote>
<br />Correct. The underlying API allows for any variant type value (just<br />like expressions), so potentially a variable could be a int, date,<br />datetime, string, list, map, interval, feature, etc...<br /><br />
<blockquote type="cite" style="padding: 0 0.4em; border-left: #1010ff 2px solid; margin: 0">Can I also manually define a "typed" variable? E.g. a boolean true instead of 'true' as a string?</blockquote>
<br />Only via PyQGIS, not via the UI.<br /><br />It's been requested in the past that we support expose an option for<br />these. And I'd like to see this happen, because then we could improve<br />the UI for entering variable values in the variable list widget. E.g.<br />if a variable has been defined on a project level as a "color" type<br />variable, it would be nice to make it so that when you override this<br />variable for a particular layout item you get a color picker widget.<br />And similarly, if you defined a variable to be of the type "font<br />name", then the tree widget could show a drop down list of available<br />fonts. It would certainly help make them more accessible.<br /><br />It's actually somewhat of a dream of mine to expose variable editing<br />better in the QGIS UI to users. E.g. - via variables its completely<br />possible to make symbols which alter their appearance. So already have<br />this concept of "smart symbols", where you could have a marshland<br />symbol which alters its appearance based on variables like<br />"@height_of_vegetation" and "@density_of_vegetation" and<br />"@health_of_vegetation". That's possible today. But to modify these<br />variables you need to go into the raw variable editor for the layer<br />and tweak their. What would be great is if we did things like expose<br />them at the symbol selector dialog -- so that if a user picks your<br />"marshland" smart symbol from the library, they don't see all the<br />underlying symbol layers and those settings, but instead just see<br />widgets for tweaking these specific @height_of_vegetation/...<br />variables. This is where "typed" variables would be a necessity!<br /><br />Nyall<br /><br /><br />
<blockquote type="cite" style="padding: 0 0.4em; border-left: #1010ff 2px solid; margin: 0"><br />That way I could directly use variables without having to add CASE WHEN END statements ...<br /><br />My use case would be to have a boolean "debugging" variable. If it is set to true, then certain parts of the form with internal IDs would be visible, if set to false, they would be hidden.<br /><br />Thanks,<br /><br />Andreas<br /><br />_______________________________________________<br />QGIS-Developer mailing list<br /><a href="mailto:QGIS-Developer@lists.osgeo.org">QGIS-Developer@lists.osgeo.org</a><br />List info: <a href="https://lists.osgeo.org/mailman/listinfo/qgis-developer" target="_blank" rel="noopener noreferrer">https://lists.osgeo.org/mailman/listinfo/qgis-developer</a><br />Unsubscribe: <a href="https://lists.osgeo.org/mailman/listinfo/qgis-developer" target="_blank" rel="noopener noreferrer">https://lists.osgeo.org/mailman/listinfo/qgis-developer</a></blockquote>
</div>
</blockquote>
<p><br /></p>
</body></html>