Right Click Widget

2329
29
06-11-2025 09:10 AM
Brian_McLeer
Frequent Contributor
10 29 2,329

Introduction

The Right Click widget adds contextual map tools to ArcGIS Experience Builder. When a user right-clicks on the map, a menu appears offering a set of configurable actions. This provides access to functions like zoom, measurement, coordinate copying, marker plotting, text placement, and reverse geocoding.

End User Interaction

Once deployed, users can right-click anywhere on the map to open a context menu. Depending on the configuration, the following actions may be available:

Navigation Actions:

  • Zoom In / Zoom Out: Adjusts the zoom level at the click location
  • Center Here: Pans the map to center on the clicked point

Coordinate Actions:

  • Copy Coordinates: Copies the location to the clipboard using the configured coordinate system
  • Plot Coordinates: Places numbered coordinate markers with configurable styling and coordinate labels
  • Plot Marker: Places simple markers with customizable appearance

Graphics Actions:

  • Add Text: Places custom text graphics on the map with configurable font properties
  • Clear All Graphics: Removes all placed markers and text (displays count when graphics are present)

External Services:

  • Open in Google Street View: Opens the location in Google Street View using projected coordinates
  • Open in Pictometry: Opens the location in Pictometry aerial imagery viewer using projected coordinates

Measurement Tools:

  • Measure Distance / Measure Area: Opens measurement tools with the following features:
    • Automatic segment and total labeling for distance measurements
    • Filtered unit options
    • Single or dual unit display options
    • Close button for tool termination

Information Services:

  • What's Here?: Performs location identification using:
    • Reverse geocoding via configured locator service for address lookup
    • Feature layer queries against configured ArcGIS Feature Services
    • Popup display showing results from both geocoding and feature layer queries

The context menu adapts based on administrator settings. Tools close automatically after use or on map interaction.

Measurement Tools

The measurement functionality includes the following specifications:

Available Units

  • Distance measurements: Feet, Yards, Miles, Meters, Kilometers
  • Area measurements: Square Feet, Square Yards, Square Miles, Square Meters, Square Kilometers, Acres

Unit Display Options

  • Single Unit Only: Displays measurements in the selected default unit
  • Show Both Units: Displays measurements in both the primary unit and its converted equivalent (e.g., "150.00 feet (45.72 meters)")

Interface Elements

  • Distance measurement tool includes a Close button
  • Area measurement tool includes a Close button
  • Default "New measurement" buttons are removed

Coordinate and Marker Plotting

The widget provides two types of marker placement:

Coordinate Markers:

  • Numbered sequentially starting from 1
  • Display configurable coordinate information in popups
  • Support multiple coordinate systems (map native, WGS84, custom WKID)
  • Optional coordinate labels displayed on map
  • Configurable marker styles, colors, outlines, and positioning
  • Support decimal degrees or degrees/minutes/seconds format for lat/lon

Simple Markers:

  • Basic point markers without numbering
  • Fully customizable appearance including style, size, color, outline, rotation, and offsets
  • Support transparency settings

Text Graphics:

  • Custom text placement at clicked locations
  • Configurable font family, size, weight, and color
  • Optional text outlines (halo) and backgrounds
  • Persistent during browser session

Developer Configuration

Map Widget Selection

  • Connects the Right Click widget to map widgets in the application
  • Enables right-click functionality on selected maps

Enabled Actions

Each action can be individually toggled:

  • Zoom In
  • Zoom Out
  • Center Here
  • Copy Coordinates
  • Plot Coordinates
  • Plot Marker
  • Add Text
  • Open in Google Street View
  • Open in Pictometry
  • Measure Distance
  • Measure Area
  • What's Here?

Coordinate System Settings

The format for copied coordinates can be configured:

  • Use the current map's coordinate system
  • Use WGS84 (latitude/longitude)

Plot Coordinates Settings

Comprehensive marker configuration options:

  • Coordinate System: Map native, WGS84, or custom WKID
  • Format Options: Decimal degrees or degrees/minutes/seconds for lat/lon
  • Marker Style: Circle, Square, Cross, X, Diamond, Triangle, Pin
  • Visual Properties: Size, color, outline color/width, opacity, rotation angle
  • Positioning: X/Y offset controls for precise placement
  • Text Settings: Number text size and color
  • Labels: Optional coordinate labels with customizable offset, size, and color
  • Popup Content: Toggle coordinate display in marker popups

Simple Marker Settings

Independent styling controls for basic markers:

  • Style Options: Circle, Square, Cross, X, Diamond, Triangle, Pin
  • Appearance: Size, color, outline properties, opacity
  • Positioning: Rotation angle and X/Y offsets

Text Settings

Font and display configuration for text graphics:

  • Typography: Font family, size, weight (normal/bold)
  • Colors: Text color and outline (halo) color
  • Effects: Outline size, optional background color
  • Background: Transparent or colored background options

Reverse Geocoding Configuration

  • Reverse geocoding service URL field for "What's Here?" functionality
  • Optional WKID setting for coordinate projection
  • Feature layer configuration for "What's Here?" queries:
    • Add multiple ArcGIS Feature Service layers
    • Select specific fields to display from each layer
    • Configure search radius and maximum results per layer
    • Set spatial relationship parameters for queries

Feature Layer Configuration

Advanced settings for "What's Here?" functionality:

  • Layer Management: Add/remove feature layers with custom names
  • Field Selection: Choose specific fields to display from each service
  • Service Integration: Automatic field loading from Feature Service URLs
  • Display Options: Configure field aliases and grouping

Popup Display Settings

Customization options for information popups:

  • Layout: Popup width and maximum height settings
  • Content Organization: Show/hide layer names, group by layer option
  • Field Display: Use field aliases or raw field names
  • Styling: Responsive design with scrolling for large content

Measurement Settings

  • Default Units: Select from Feet, Yards, Miles, Meters, or Kilometers
  • Unit Display: Choose between single unit display or dual unit display with conversions

External Service URLs

  • Pictometry Integration: Configure Pictometry service URL with coordinate parameters
  • Geocoding Services: Set reverse geocoding service endpoints

Widget Placement

The widget does not display interface components and operates in the background. Recommended configuration:

  • Set widget size to 0×0 pixels
  • Place in unused corner of the layout
  • Use "Send to back" option in layout settings
  • Keep widget visible and active
  • Recommended for desktop only, not for tablet/phone viewers

Technical Notes

  • Unit dropdown options are filtered to show only the specified available units
  • Invalid unit selections are blocked and revert to default units
  • Console logging is limited to warnings and errors
  • Widget includes cleanup procedures for memory management
  • Graphics persist during browser session but are cleared on page refresh
  • Coordinate projections support multiple spatial reference systems
  • Field metadata is automatically loaded from configured Feature Services

Changelog

07/23/2025:

  • Tested widget on Developer Edition 1.18 that was released on 7/23/25 and widget functions as normal. 

06/20/2025:

  • Add enhanced marker styling with 7 different shape options (circle, square, cross, x, diamond, triangle, pin)
  • Add marker rotation, opacity, and X/Y offset positioning controls
  • Add text graphics functionality with custom font controls, outlines, and background options
  • Add support for custom coordinate systems via WKID input
  • Add coordinate format options (decimal degrees vs degrees/minutes/seconds)
  • Add simple marker plotting separate from coordinate markers
  • Add comprehensive field selection for feature layers with automatic field loading
  • Add popup display customization options (width, height, grouping, field aliases)
  • Add real-time graphics counting in clear all option
  • Add marker preview functionality in settings interface
  • Add enhanced coordinate label positioning and formatting
  • Add separate styling controls for coordinate markers vs simple markers

06/13/2025:

  • Resolve a bug where browser default window sometimes appear on right click in addition to custom right click window
  • Add Pictometry as a right-click option
  • Add feature layers to What's Here? function to be queried against

Summary

The Right Click widget enables configurable map-based actions through a context menu. It supports zooming, measurements with filtered unit control, coordinate retrieval, marker and text placement with extensive styling options, and reverse geocoding with feature layer integration. Configuration is available through Developer Edition and applies to connected map widgets.

Feedback on bugs and enhancements can be submitted in the comments section of this blog post.

29 Comments
Brian_McLeer
Frequent Contributor

Update on 6/20/25:

  • Add enhanced marker styling with 7 different shape options (circle, square, cross, x, diamond, triangle, pin)
  • Add marker rotation, opacity, and X/Y offset positioning controls
  • Add text graphics functionality with custom font controls, outlines, and background options
  • Add support for custom coordinate systems via WKID input
  • Add coordinate format options (decimal degrees vs degrees/minutes/seconds)
  • Add simple marker plotting separate from coordinate markers
  • Add comprehensive field selection for feature layers with automatic field loading
  • Add popup display customization options (width, height, grouping, field aliases)
  • Add real-time graphics counting in clear all option
  • Add marker preview functionality in settings interface
  • Add enhanced coordinate label positioning and formatting
  • Add separate styling controls for coordinate markers vs simple markers

ZachBodenner
MVP Regular Contributor

This is so cool! When you've deployed this widget, where do you actually put it? It seems like I can just place it anywhere in the appl, but is there a way to you like to make it not visible so it doesn't take up any space?

 

Brian_McLeer
Frequent Contributor

Thank you @ZachBodenner, if you watch the  second video right above Developer Configuration in the main blog post this will show you where I have it deployed to my applications. 

 

Brian_McLeer_0-1751051016721.png

 

ZachBodenner
MVP Regular Contributor

Serves me right for only watching the first one! Okay yes that's what I had in my mind as well. Thanks again!

ericsamson_tract
Frequent Contributor

Awesome stuff! can't wait to implement this.

JasonBOCQUET
Frequent Contributor

Great widget ! Very simple to use and efficient !

 

Do you think it's possible to add a custom box for the user ? That let him able to set the color, size, etc of the symbols that he add on the map.

 

 

Brian_McLeer
Frequent Contributor

Thank you @JasonBOCQUET. It may be possible, but I think for the intention of this widget it is meant to be kept simple by taking some aspects of the custom draw, measurement, and custom external map coordinate custom widgets and having in a context menu and putting less on the user. The option to modify how the symbology looks for text, coordinate points, and marker points is available in the settings panel of Developer Edition, so the person creating the application can change how points and text appear for the end user. 

Brian_McLeer
Frequent Contributor

07/23/2025:

  • Tested widget on Developer Edition 1.18 that was released on 7/23/25 and widget functions as normal. 
JeffreyThompson2
MVP Frequent Contributor

@Brian_McLeer I tested it out and I like it. I did make one small UI improvement. I turned off a number of menu option and found that the menu often opened far away from my mouse click. I added a sub-function around line 2083 to adjust the menu height based on how many options are disabled.

 const actionArray = Object.entries(props.config.enabledActions)
 let notEnabled = 0
 actionArray.forEach(pair => {
     if (!pair[1]) {
         notEnabled++
     }
 })
 const decreaseBy = notEnabled * 38 //each item in menu is 38px

 const menuWidth = 200;
 const menuHeight = 420 - decreaseBy; // Updated to accommodate new text menu item
Brian_McLeer
Frequent Contributor

Thank you @JeffreyThompson2. I tested in my version and have updated the ZIP file on this post with your improvements. Thank you for providing the feedback. 

JasonBOCQUET
Frequent Contributor

to update the widget if I already use it, i have only to edit the widget.tsx file with the new code ? 

Brian_McLeer
Frequent Contributor

@JasonBOCQUET that is correct, but I did update the ZIP file on this post

James_Kellough
Occasional Contributor

Hi @Brian_McLeer, love the widget and I use it heavily in my apps. Recently one of my users asked a question about it that I can't answer so I'm hoping you can help. They want to know why the distance tool shows a discrepancy between measurement length along a line versus what is shown in the info box?  This doesn't seem to be an issue with the area tool.

Distance Tool Measurement

right-click-distance.png

 

Area Tool Measurement

right-click-area.png

 

 

Thanks for the clarification. 

James

 

Brian_McLeer
Frequent Contributor

Thank you @James_Kellough, I was somewhat able to replicate what you reported. It seems that sometimes it doesn't fully catch up in the upper right dialogue box and sometimes it does for me. I will review over the next few weeks to see if I can resolve the bug.  

shodge_fsu
Occasional Contributor

@Brian_McLeer -- I wonder if the issue is with the projection that you use or assume others use not matching up with what your app is expecting.

Brian_McLeer
Frequent Contributor

@shodge_fsu that may be the culprit. We publish our data in WGS 84 / UTM zone 12N, not Web Mercator. I can try spinning up an app in Web Mercator and test there as I have not been getting the issue in my apps. 

Brian_McLeer
Frequent Contributor

@James_Kellough @shodge_fsu I found the issue in an app I tested. I removed the old ZIP and upload a new ZIP. @James_Kellough would you be able to implement the newest ZIP on this blog post and try again? Thank you @shodge_fsu for the advice!

shodge_fsu
Occasional Contributor

@Brian_McLeer -- Just added the new code into my app and it now measures correctly.  Thanks for the timely fix.

James_Kellough
Occasional Contributor

@Brian_McLeer, apologies for the tardy reply, I've just returned from some time off. Thank you so much for your attention and quick fix. The issue is resolved on my end. Cheers!

Brian_McLeer
Frequent Contributor

Thank you both @James_Kellough and @shodge_fsu, glad to hear it is working.  

JasonBOCQUET
Frequent Contributor

Hi @Brian_McLeer i took your last version of the right click widget and the problem that @JeffreyThompson2 have corrected (the menu often opened far away from my mouse click) is back for me.

EXP Builder 1.18 dev edition

 

Brian_McLeer
Frequent Contributor

@JasonBOCQUET is there anyway you could post a short screen recording of the issue? 

JasonBOCQUET
Frequent Contributor

@Brian_McLeer 

Of course :

JasonBOCQUET_0-1756997417177.png

 

i've right click on "Paris" and the menu open far away

Brian_McLeer
Frequent Contributor

@JasonBOCQUET I was able to replicate your issue when clicking more towards the bottom of the map. I have made some updates, and the updated ZIP has been posted to the main article on this thread. Would you be able to try again and see if you still get the issue? 

Marc_Graham
Frequent Contributor

Hi @Brian_McLeer 

I tried to deploy this to my ArcGIS Enterprise Portal, but it appears that the widget only supports developer edition as there is no dist folder only src.  Are you able to release compiled versions of the widget suitable for ArcGIS Enterprise?

Marc_Graham_0-1757029840452.png

Marc_Graham_1-1757029884880.png

Thanks,

Marc

JasonBOCQUET
Frequent Contributor

 @Brian_McLeer Hi Brian, works perfectly ! big thanks for your work 🙂

JeffreyThompson2
MVP Frequent Contributor

@Marc_Graham It is standard practice in this group to not include the dist files in the uploads. Compatibility issues can arise if the Widget is not compiled in the same version of Developer Edition that is included in Enterprise. It's not practical to expect Widget developers to make a compiled version for every possible version of Enterprise and it would make the package size much larger and more confusing. Here's some instructions on how to make a dist folder and get the Widget in your Enterprise.

https://community.esri.com/t5/experience-builder-tips-and-tricks/registering-a-custom-widget-in-arcg...

Marc_Graham
Frequent Contributor

Absolutely understand.

thanks for replying, I’ll find someone who can help me build it.

cheers for sharing your work!

JeffreyThompson2
MVP Frequent Contributor

@Marc_Graham This Widget is @Brian_McLeer's work. I deserve no credit for this.

Contributors
About the Author
GIS Administrator/Developer at City of Grand Junction, CO.