Geometry Picker Form Element

The Geometry Picker form element allows the user to draw one or more geometries on the map.

To use a geometry picker, the user clicks Add Location () and draws the location on the map. The location is listed on the form (). If you configured the geometry picker to allow multiple locations, the user can click Add Location again and draw another location, up to the maximum number of locations. Hovering over a location in the list highlights the location on the map (). To remove a location, the user clicks the Delete button next to the location in the list. This removes the location from the list and from the map.

Example of the Geometry Picker form element, shown in a Geocortex viewer

Geometry Picker Properties

The following table describes the properties of the Geometry Picker form element. Some properties can be configured in the Properties panel in Workflow Designer. These properties have configuration information in the table. Similarly, some properties can be accessed in expressions. These properties have information about how to access the property in an expression.

If a property can be configured in the Properties panel and accessed in expressions, the property has two names: the name that appears in the Properties panel and the name that is used in expressions. Both names are given in the table. Sometimes the names only differ in capitalization, for example, Visible (in the Properties panel) or visible (in expressions).

Properties of the Geometry Picker Form Element

Auto-Activate

Type: Boolean

Name in Properties Panel: Auto-Activate

Name to Use in Expressions: autoActivate

Indicates whether the element will activate automatically when the form appears. By default, geometry pickers do not automatically activate.

To access the autoActivate property in an expression:

${Display Form ID}.state.{Element ID}.autoActivate

For example:

$form1.state.geometryPicker1.autoActivate

Button Label

Type: String

The text that appears on the button that the user clicks to select a geometry. The default text is Add Location.

You can format the button's label using Markdown.

Description

Type: String

A description of the element. The description appears below the element's title.

You can use the Description property to describe what the element represents or to provide instructions to the user about how to use the element.

You can format the description using Markdown.

Element ID

Type: String

The element's ID, which is used in other form elements and activities to access the element's properties, including the user's input. The ID must be unique across all elements in the form.

You cannot get or set the value of the Element ID property in an expression—you can only use the value that you configured for it. To use the Element ID property in an expression:

${Display Form ID}.state.{Element ID}.{property name}

For example:

$form1.state.geometryPicker1.visible

Enabled

Type: Boolean

Name in Properties Panel: Enabled

Name to Use in Expressions: enabled

Indicates whether the geometry picker is enabled in the running workflow. When a geometry picker is enabled, the user can select geometries. When a geometry picker is disabled, the user can see the geometry picker but cannot interact with it. Disabled elements appear dimmed or shaded in the running workflow.

By default, geometry pickers are enabled. To disable a geometry picker initially, clear the Enabled checkbox. You may want to change the property's value at run time depending on the user's input in a previous form element.

To access the enabled property in an expression:

${Display Form ID}.state.{Element ID}.enabled

For example:

$form1.state.geometryPicker1.enabled

error

Type: String | MarkdownRef

Indicates whether an error occurred in the element.

MarkdownRef objects have a markdown property of type String that represents the Markdown text.

We recommend using the Set Form Element Error and Clear Form Element Error activities to work with errors in form elements.

Geometry Label

Type: String

The text that appears on each geometry in the list of selected geometries. The default text is Location.

You can format the Geometry Label property using Markdown.

Geometry Type

Type: String

The type of geometry that the user will draw on the map to select a geometry—point, polygon, polyline, freehand polygon, freehand polyline, or extent. The default is Polygon.

Maximum Geometries

Type: Number

The maximum number of geometries that the user can select. When the maximum number of geometries have been selected, the Add Location button becomes unavailable. By default, the user can select 1 geometry.

Required

Type: Boolean

Name in Properties Panel: Required

Name to Use in Expressions: require

Indicates whether the user must select a geometry. When the geometry picker is required, the user cannot submit the form until at least one geometry is selected.

By default, geometry pickers are not required. To require a geometry picker, select the Required checkbox.

The Required checkbox is intended as a quick way to do simple validation without having to add a validate event. If you add a validate event to a form element, selecting the Required checkbox will not have any effect. In this case, you must make the validate event check whether the user entered a value.

To access the require property in an expression:

${Display Form ID}.state.{Element ID}.require

For example:

$form1.state.geometryPicker1.require

Title

Type: String

The element's title, which appears at the top of the element.

You may want to change the title to describe what the element represents in your workflow. Descriptive titles make forms easier to understand.

You can format the title using Markdown.

Tooltip

Type: String

A message that displays when the user hovers the mouse pointer over the geometry picker. You may want to use the tooltip to provide help to the user.

type

Type: String

The variety of form element. Geometry pickers are type "GeometryPicker".

Use the type property to find out the variety of a form element in a form with many elements: loop through ${Display Form ID}.state, comparing each element to the known form types and performing some action on the elements that meet your type criteria.

To access the type property in an expression:

${Display Form ID}.state.{Element ID}.type

For example:

$form1.state.geometryPicker1.type

value

Type: GeometryRef

An object of type GeometryRef. GeometryRef objects have a geometry property that is an array of Esri 3.x or 4.x geometries.

Visible

Type: Boolean

Name in Properties Panel: Visible

Name to Use in Expressions: visible

Indicates whether the element is visible to the user. By default, geometry pickers are visible. If you want to hide the element initially, clear the Visible checkbox. You may want to change the visibility at run time depending on the user's input in a previous form element.

To access the visible property in an expression:

${Display Form ID}.state.{Element ID}.visible

For example:

$form1.state.geometryPicker1.visible

Geometry Picker Events

The following table describes the events associated with the Geometry Picker form element. As in Workflow Designer, the events are listed in the order that they fire.

Events for the Geometry Picker Form Element

load

The load event fires when the element finishes loading.

You can use the load event to set one or more of the element's properties at run time.

change

The change event fires when the user adds or removes a geometry.

You can use the change event to display information about the geometry that was just captured, for example, the coordinates or address from a Reverse Geocode activity.

You can use the change event to create dependencies between form elements. For example, you could configure a change subworkflow that enables or disables other form elements depending on the user's selection.

The change event fires every time the user adds or removes a geometry. This means that the geometry picker's change subworkflow can run multiple times. Because of this, you should make sure that the change subworkflow is not computationally intensive or long running.

validate

The validate event fires when the user clicks a button that causes validation.

You can use the validate event to verify that the user's input is valid before allowing the form to submit. If the input is not valid, use the Set Form Element Error activity to display an error to the user and prevent the form from submitting. If the input is valid, use the Clear Form Element Error activity to clear an existing error and allow the form to submit.

If you use a Set Form Element Error activity, make sure you also use a Clear Form Element Error activity to clear the error. Otherwise the form may get stuck in an invalid state.

By default, the Required property does not work when the geometry picker has a validate event. If you want the workflow to perform the Required check, add a Propagate Form Event activity to the validate subworkflow. The Propagate Form Event activity instructs the workflow to perform the Required check after the validate subworkflow completes.

For an example, see Example - Subworkflow for a Validate Event.

© 2018 Latitude Geographics Group Ltd. All Rights Reserved.

Documentation Version 5.9