• Getting Started

  • Data

  • Chart Types

  • Chart Elements

  • Integrations

  • API

  • Tools

  • FAQ

  • Change Log

  • Context Menu

    Overview

    The context menu is what appears when you right-click on an area of the chart. It allows for further chart interactions such as reloading the chart, viewing it as an image, printing the chart, and more. You can enable or disable various context menu items, as well as create your own custom items. You also have the option to display a context menu button so that mobile users can access the menu by tapping the icon.

    Note: If you are building JavaScript charts that will be primarily viewed on mobile devices, you should use our mobile charts plugin. Built using ZingTouch, the plugin supports touch gestures and displays charts with mobile-specific features, including a custom context menu. Refer to the Mobile Charts Tutorial for more information.

    Setup

    The gui object should be placed before the graphset array because it is a loader object. In the object, you can enable or disable existing context menu items with the behaviors array or create custom menu items and/or display a context menu button with the contextMenu object.

    {
      gui: {
        //Context Menu Customization Here
      },
      graphset: [
        {
          //Chart JSON Here
        }
      ]
    }
    

    Refer to the GUI JSON page for a full list of objects and attributes.

    Context Menu Items

    You can style the appearance of the context menu, as well as choose what menu items to display by using our behavior IDs or by creating your own custom menu items.

    Styling Menu Items

    To style the context menu, add a contextMenu object to the gui object. You can change the background color of the context menu object with a backgroundColor attribute. You can fix the menu to a specific position with the docked (true or false) and position (left or right) attributes. To style the context menu items, create an item object. You can style the background and font colors, as well as how the items appear when hovered over. Refer to the Context Menu Item JSON page for a full attribute list.

    {
      gui: {
        contextMenu: {
          backgroundColor: 'red',
          item: {
            backgroundColor: 'pink',
            fontColor: 'black',
            hoverState: {
              backgroundColor: 'black',
              fontColor: 'white'
            }
          }
        }
      },
      graphset: [
        {
          //Chart JSON omitted for brevity.
        }
      ]
    }
    

    Enabling/Disabling Menu Items

    In the gui object, use the behaviors array to enable or disable various context menu behaviors.

    Refer to the list of context menu behavior IDs below. In the following chart, the Download PDF behavior was disabled and the Crosshair Hiding/Showing behavior was enabled. Right-click on the chart to interact with the context menu.

    https://app.zingsoft.com/demos/embed/SUPEL253
    https://app.zingsoft.com/demos/embed/SUPEL253
    {
      gui: {
        behaviors: [
          {
            id: 'DownloadPDF',
            enabled: 'none'
          },
          {
            id: 'CrosshairHide',
            enabled: 'all'
          }
        ]
      },
      graphset: [
        {
          //Chart JSON omitted for brevity.
        }
      ]
    }
    

    Behavior IDs

    Below is a list of behavior IDs that can be used in the behaviors array.

    Built-In IDs
    About BugReport
    BuyLicense CrosshairShow
    CrosshairHide 2D
    3D DownloadPDF
    DownloadCSV DownloadXLS
    DownloadSVG EnterEdit
    ExitEdit ExportData
    FeedClear FeedFaster
    FeedPause FeedSlower
    FeedStart FullScreen
    ShowGuide HideGuide
    HistoryBack HistoryForward
    LinScale LogScale
    LoupeHide LoupeShow
    MaximizeLegend MinimizeLegend
    NormalScreen Print
    Reload SaveAsImage
    ShowAll ViewSource
    ZoomIn ZoomOut
    SaveAsImagePNG (toggles "View as PNG")

    Refer to the Behaviors JSON page for more information.

    Creating Custom Items

    To create your own custom context menu item, you'll need to first create the JavaScript function you want executed when clicked on. Next, add a customItems array to the contextMenu object to define the custom context menu item. Each object must contain:

    Finally, in the behaviors array, enable your custom context menu item by specifying the id and enabled attributes in their own object.

    In the following chart, a Show Alert custom context menu item was created. Right-click on the chart to interact with the context menu.

    https://app.zingsoft.com/demos/embed/VYMRK496
    https://app.zingsoft.com/demos/embed/VYMRK496
    window.zingAlert= function(){
      window.alert("ZingChart is great for making interactive and stylish charts!")
    }
    
    let myConfig = {
      gui: {
        contextMenu: {
          customItems: [
            {
              text: 'Show Alert',
              function: 'zingAlert()',
              id: 'showAlert'
            }
          ]
        },
        behaviors: [
          {
            id: 'showAlert',
            enabled: 'all'
          }
        ]
      },
      graphset: [
        {
          //Chart JSON omitted for brevity.
        }
      ]
    }
    

    Context Menu Button

    You can add a context menu button to your chart. This allows mobile users to tap on the icon to access the context menu. In the contextMenu object, create a button object. Add a visible attribute, and set the value to true. The context menu button will appear in the upper-left corner of the chart.

    Note: Alternatively, you can use the mobile charts plugin, which is recommended for use on web pages that will be primarily viewed on mobile devices. Built using ZingTouch, the plugin supports touch gestures and includes a mobile context menu and other mobile-specific features. Refer to the Mobile Charts Tutorial for more information.

    https://app.zingsoft.com/demos/embed/G49RLFVL
    https://app.zingsoft.com/demos/embed/G49RLFVL
    {
      gui: {
        contextMenu: {
          button: {
            visible: true
          }
        }
      },
      graphset: [
        {
          //Chart JSON omitted for brevity.
        }
      ]
    }
    

    Styling the Menu Button

    To style the context menu button, add a gear object to the contextMenu object. You can change the color and transparency level of the icon using the backgroundColor and alpha attributes. Refer to the Gear JSON page for a full attribute list.

    https://app.zingsoft.com/demos/embed/URC1G3A7
    https://app.zingsoft.com/demos/embed/URC1G3A7
    {
      gui: {
        contextMenu: {
          button: {
            visible: true
          },
          gear: {
            backgroundColor: 'red',
            alpha: 1
          }
        }
      },
      graphset: [
        {
          //Chart JSON omitted for brevity.
        }
      ]
    }
    

    Creating a Custom Button

    You can create your own custom context menu button using ZingChart shapes and the shape_click API event. See the following chart.

    https://app.zingsoft.com/demos/embed/HIRHHM4G
    https://app.zingsoft.com/demos/embed/HIRHHM4G
    let myConfig = {
      graphset: [
        {
          type: 'mixed',
          shapes: [
            {
              id: 'custom-cm-button',
              type: 'circle',
              backgroundImage: 'https://www.zingchart.com/resources/heart.png',
              backgroundRepeat: 'no-repeat',
              size: 20,
              backgroundColor: 'pink',
              borderWidth: '1px',
              borderColor: 'red',
              x: '30px',
              y: '30px',
              cursor: 'hand'
            }
          ],
          //Remaining chart JSON omitted for brevity.
        }
      ]
    };
    
    zingchart.bind('myChart', 'shape_click', function(e){
      if(e.shapeid === 'custom-cm-button') {
        zingchart.exec('myChart', 'showmenu', {
          x: '55px',
          y: '35px'
        });
      }
    
    })
    

    Disabling the Context Menu

    To disable the whole context menu, you'll need to the bind the contextmenu event to the chart after it has rendered and return false.

    zingchart.bind('myChart', 'contextmenu', function(p) {
      return false;
    });
    
    https://app.zingsoft.com/demos/embed/U2IH6QYW
    https://app.zingsoft.com/demos/embed/U2IH6QYW

    The above method only disables the right-click to open the context menu. On mobile views, a hamburger menu will appear in the upper left corner to display the context menu. In order to disable the mobile context menu, add the following code to your chart configuration object:

    gui: {
        contextMenu: { button: { visible: false } },
    },
    

    Once this is added, the hamburger menu will no longer be visible on mobile views.

    Summary

    The ZingChart context menu, accessed on a right click, allows you to use built in ZingChart functions to export your chart, view the JSON source, and more. With features automatically added, such as zoom in/out capability from the context menu when zooming is enabled on your chart, the context menu is an easy way to allow users to interact with your chart by pressing a clearly labeled button. Context Menu items can be customized, hidden, and more!

    For a full list of context menu attributes, see the JSON configuration page.