HomeGuidesRecipesAPI
HomeGuidesAPILog In
Guides
These docs are for v11.0. Click to read the latest docs for v31.

Intelledox Visual Insights

Infiniti has many features around Analytics, capturing how users interact with forms and making this data available easily from Infiniti Data Source Type.

As a complement, a new Question type was developed allowing solution designers to add Interactive graphs within Intelledox Infiniti forms and Dashboards. This Question Type is named as Visuals, and is based on Vega (visualization grammar), which provides a declarative language for creating an interactive visualization in a JSON format.

👍

Analytics Module

Please contact your account manager if you are interested in the Analytics Module. Please mention you want to deploy the Question Type Visuals as a separate .dll file has to be provided.

Installation

Before installing this Question Type, you must consider the following requirements:

You must have administrator/elevated permissions to the Infiniti web server, including the ability to copy and replace files in the Infiniti installation folder. This is usually c:\inetpub\wwwroot\infiniti however may vary from system to system.

You must have the following installation file:

  • IXVisuals.dll

🚧

Important

Changes to the configuration may cause interruptions to users in forms. Before installing this Extension in a production Infiniti environment, ensure the environment is backed up. It is recommended that this installation is tested in a non-production environment first, and installed during scheduled downtime.

Note that [Infiniti Produce Path] refers to the installation path on the web server running Infiniti, where the Produce site has been installed. By default, this is c:\inetpub\wwwroot\infiniti\produce however may vary from environment to environment. Equally, [Infiniti Manage Path] refers to where the Manage site has been installed.

  1. Copy IXVisuals.dll into the following folder on the Infiniti web server: [Infiniti Produce Path]\bin
  2. Using a text editor such as Notepad, open the file [Infiniti Produce Path]\appsettings.json and add the following line within Extensions.
{
  "Extensions": [
  ...
  "IXVisuals.AdvancedVisuals, IXVisuals",
  "IXVisuals.AdvancedVisualsDataSource, IXVisuals"
  ],
  ...
}
  1. Similarly, for Manage, copy IXVisuals.dll into the following folder on the Infiniti web server: [Infiniti Manage Path]\bin
  2. Using a text editor such as Notepad, open the file[Infiniti Manage Path]\appsettings.json and add the following line within Extensions.
{
  "Extensions": [
  ...
  "IXVisuals.AdvancedVisualsDataSource, IXVisuals"
  ],
  ...
}

🚧

Note

Ensure you have elevated privileges when opening the appsettings.json file, otherwise, you may not be able to save in the current folder.

  1. Save changes applied to appsettings.json.
  2. Modify .skin file of current Custom Theme. Normally located" [Infiniti Produce Path]\App_Themes\customTheme adding following lines within WizardHeaderLogoSkin tag.
<asp:label runat="server" SkinId="WizardHeaderLogoSkin">
<!--  VEGA VISUALIZATION  -->
<script src="https://vega.github.io/vega/assets/promise.min.js"></script>
    <script src="https://vega.github.io/vega/assets/symbol.min.js"></script>
    <script src="https://vega.github.io/vega/assets/fetch.min.js"></script>
    <script src="https://d3js.org/d3.v3.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/vega/3.3.1/vega.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/vega-lite/2.6.0/vega-lite.js"></script>
    <script>
        if (!String.prototype.startsWith) {
            String.prototype.startsWith = function (search, pos) {
                return this.substr(!pos || pos < 0 ? 0 : +pos, search.length) === search;
            };
        }
    </script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/vega-embed/3.13.1/vega-embed.js"></script>
</asp:label>
  1. Register Custom Theme in Produce appsettings.json. (More information in Custom Themes)
"AppSettings": {
    "Theme": "customTheme"
  }
  1. Using a text editor such as Notepad, open the file[Infiniti Produce Path]\web.config and modify the 'customHeaders' section. You need to update the "Content-Security-Policy' to include 'unsafe-eval' and add the urls: https://d3js.org, https://cdnjs.cloudflare.com and https://vega.github.io to the data section. Your custom headers should look similar to below:
<httpProtocol>
      <customHeaders>
        <remove name="X-Powered-By" />
        <add name="X-Frame-Options" value="SAMEORIGIN" />
        <add name="X-XSS-Protection" value="1; mode=block" />
        <add name="X-Content-Type-Options" value="nosniff" />
        <add name="Referrer-Policy" value="strict-origin-when-cross-origin" />
        <add name="Content-Security-Policy" value="default-src 'self' 'unsafe-inline' 'unsafe-eval' data: https://maxcdn.bootstrapcdn.com https://*.googleapis.com https://fonts.gstatic.com https://d3js.org https://cdnjs.cloudflare.com https://vega.github.io" />
        <add name="Access-Control-Allow-Origin" value="null" />
        <add name="Access-Control-Allow-Headers" value="accept, cache-control, content-type, authorization" />
        <add name="Access-Control-Allow-Methods" value="GET, POST, PUT, PATCH, DELETE, OPTIONS" />
        <add name="Access-Control-Allow-Credentials" value="true" />
        <add name="Access-Control-Max-Age" value="600" />
      </customHeaders>
</httpProtocol>

📘

Note

App Pool might need to be restarted to include changes.

  1. Navigate to Produce and Manage in your browser, an absence of error messages suggests the Question Type has installed correctly.
  2. Create a new Project in Design. The following icon should be available in the top toolbox.
512

Visuals

Adding a Bar Chart Graph

This is probably the most basic but also powerful graph available, let's get started.

Stage I Content Library

  1. Create a new JSON file in your local and name it barChart.json using following code:
{
  "$schema": "https://vega.github.io/schema/vega-lite/v2.json",
  "data": {
    "values": ##data##
  },
  "mark": "bar",
  "encoding": {
    "x": {"field": "category", "type": "ordinal"},
    "y": {"field": "amount", "type": "quantitative"}
  }  
}

📘

Note

##data## is not a valid JSON syntax; this is a keyword used by Visuals Question Type that will be replaced with a JSON formatted structure mapping category and amount values.

  1. Create a new folder named Visuals within Intelledox Infiniti Content Library.
  2. Select Visuals folder.
  3. Click "New Content Item".
  4. Click "Attachment".
  5. Upload the newly created barChart.json file and name it barChart.
  6. Click "Save"
936

Stage II Creating Infiniti Data Source

  1. Create a new Data Source in Manage.
Data Source NameInfiniti
Connection TypeInfiniti
  1. Create a new Data Object Type: "Analytics Device Log". Choose a relevant Display Name like "v10 Analytics Device Log", add all available Filter and Display Fields and click "Save".
1221

Stage III Create Project

  1. Create a new Intelledox Infiniti Project (Dashboard Type).
  2. Add the newly created Intelledox Infiniti Data Source "v10 Analytics Device Log".
PropertyValue
Question TextInfiniti - v10 Analytics Device Log
Data SourceInfiniti
Table/Viewv10 Analytics Device Log
VisibleUnchecked
SelectionMultiple Rows
Unique Field(None)
Default Type(None)
  1. Add the following answers to the Data Source:
Answer NameData FieldFormula
LoginTimeUtcLoginTimeUtc
LoginTimeUtcFormula[Formula]=format([q1.LoginTimeUtc], "MM/dd/yyyy hh:mm")

Reference to the LoginTimeUtc Data Source Answer. In this case eg: [q1.LoginTimeUtc]
BrowserBrowser
  1. Simply drag and drop Visuals Question Type and provide following inputs:
Input NameDescriptionValue
Visual DefinitionReferences Content Library Item that contains JSON definitionbarChart
DataAllows adding variables and values (pipe separated values, making it easier for data coming from a repeating section or a data source) that then will be mapped accordingly into the visualization definition, replacing the keyword ##data##.category=A|B|C|D|E|F|G|H

amount=28|55|43|91|81|53|19|87
1905
880

Intelledox Infiniti Produce

Usage in a Map

In the previous example, we learned how to create a simple Bar Chart manually passing in the data. For this example, we will reference an Intelledox Infiniti Data Source.

👍

Good Practice

It is recommended to create these visualisations as Project Fragments so they can be easily included in different projects across different Intelledox Infiniti Instances.

  1. To begin with, add following JSON definition into Content Library as an attachment and name it "worldMap", (same process described in previous tutorial "Adding a Bar Chart Graph")
{
  "$schema": "https://vega.github.io/schema/vega/v3.0.json",
  "width": 900,
  "height": 500,
  "autosize": "none",
  "signals": [
    {
      "name": "tx",
      "update": "width / 2"
    },
    {
      "name": "ty",
      "update": "300"
    },
    {
      "name": "scale",
      "value": 140
    },
    {
      "name": "angles",
      "value": [ 0, 0 ]
    },
    {
      "name": "cloned",
      "value": null
    },
    {
      "name": "start",
      "value": null
    },
    {
      "name": "drag",
      "value": null
    },
    {
      "name": "delta",
      "value": null
    },
    {
      "name": "rotateX",
      "value": 0
    },
    {
      "name": "centerY",
      "value": 0
    }
  ],

  "projections": [
    {
      "name": "projection",
      "type": "mercator",
      "scale": { "signal": "scale" },
      "rotate": [
        { "signal": "rotateX" },
        0,
        0
      ],
      "center": [
        0,
        { "signal": "centerY" }
      ],
      "translate": [
        { "signal": "tx" },
        { "signal": "ty" }
      ]
    }
  ],

  "data": [
    {
      "name": "world",
      "url": "https://vega.github.io/vega/data/world-110m.json",
      "format": {
        "type": "topojson",
        "feature": "countries"
      }
    },
    {
      "name": "graticule",
      "transform": [
        {
          "type": "graticule",
          "step": [ 15, 15 ]
        }
      ]
    },
    {
      "name": "infiniti",
      "values": ##data##,
      "format": {
        "type": "json",
        "parse": "auto"
      },
      "transform": [
        {
          "type": "geopoint",
          "projection": "projection",
          "fields": [ "longitude", "latitude" ]
        },
        {
          "type": "filter",
          "expr": "datum.x != null && datum.y != null"
        }
      ]
    }
  ],

  "marks": [
    {
      "type": "shape",
      "from": { "data": "graticule" },
      "encode": {
        "enter": {
          "strokeWidth": { "value": 1 },
          "stroke": { "value": "#ddd" },
          "fill": { "value": null }
        }
      },
      "transform": [
        {
          "type": "geoshape",
          "projection": "projection"
        }
      ]
    },
    {
      "type": "shape",
      "from": { "data": "world" },
      "encode": {
        "enter": {
          "strokeWidth": { "value": 0.5 },
          "stroke": { "value": "#000000" },
          "fill": { "value": "#f3fff2" }
        }
      },
      "transform": [
        {
          "type": "geoshape",
          "projection": "projection"
        }
      ]
    },
    {
      "type": "symbol",
      "from": { "data": "infiniti" },
      "encode": {
        "enter": {
          "size": { "value": 30 },
          "fill": { "value": "red" },
          "fillOpacity": { "value": 1 },
          "stroke": { "value": "orange" },
          "strokeWidth": { "value": 0.5 }
        },
        "update": {
          "x": { "field": "x" },
          "y": { "field": "y" }
        }
      }
    }
  ]
}
  1. Create a new Intelledox Infiniti Data Source in Manage (no need to perform this step if you already have one).

  2. Create a new Data Object Type: "Analytics Device Log". Choose a relevant Display Name like "v10 Analytics Device Log", add all available Filter and Display Fields and click "Save".

1221
  1. Open Design and create a "New Project".

  2. Add the newly created Intelledox Infiniti Data Source "v10 Analytics Device Log".

PropertyValue
Question TextInfiniti - v10 Analytics Device Log
Data SourceInfiniti
Table/Viewv10 Analytics Device Log
VisibleUnchecked
SelectionMultiple Rows
Unique Field(None)
Default Type(None)
  1. Add the following answers to the datasource:
Answer NameData field
latitudeLatitude
longitudeLongitude
  1. Add a new Visuals Question below the Data Source with following parameters:
PropertyValue
Question TextMap
Text PositionTop
MandatoryUnchecked
Input (Data)Name=longitude
Fixed Value=Reference to longitude Data Source Answer.
In this case [q1.Longitude]
Input (Data)Name=latitude
Value=Reference to latitude Data Source Answer.
In this case [q1.Latitude]
Input (Visual Definition)Type=Fixed Value
Fixed value= Type the Content libary file name.
In this case WorldMap.vg.json
  1. Save Project and view in Produce.
1155

Include Visual Insights Image in Infiniti Template

  1. Add another new Answer to the Visuals Question and call it "Image". From the Output drop-down list, choose Image.
692
  1. You can also control the Image dimensions in the output document by specifying the maximum height/width of the Image.

  2. Drag and drop your placeholder to link it to the Image answer.

More examples

Here a set of examples utilising Intelledox Visual Insights for data visualization.

Stacked Bar Chart (Browser Usage)

In this example, we will be pulling data from Intelledox Infiniti Analytics Data Sources to visualize Browser Usage.

  1. Create a new Intelledox Infiniti Data Source in Manage (no need to perform this step if you already have one).

  2. Add following JSON definition into Content Library and name it "stackedBarChart", (the same process described in the previous tutorial "Adding a Bar Chart Graph").

{
  "$schema": "https://vega.github.io/schema/vega-lite/v2.json",
  "title":"Browser Usage",
  "data": {
    "values": ##data##
  },
  "mark": "bar",
  "encoding": {
    "x": {
      "timeUnit": "month",
      "field": "timeUTC",
      "type": "ordinal",
      "axis": {"title": "Month of the year"}
    },
    "y": {
      "aggregate": "count",
      "type": "quantitative"
    },
    "color": {
      "field": "browser",
      "type": "nominal",
      "legend": {"title": "Browser"}
    }
  }
}
  1. (Skip this step if you already have a Data Object for Analytics Device Log) Create a new Data Object Type: "Analytics Device Log". Choose a relevant Display Name like "v10 Analytics Device Log", add all available Filter and Display Fields and click "Save".
  2. Open Design and "Crete a New Project". Name it: "pf_Visual_Browser" with Project Type: "Fragment Portion".
  3. Add the Intelledox Infiniti Data Source "v10 Analytics Device Log", and add Browser and LoginTimeUTC answers.

🚧

Date Format

Vega expects dates to come in Month/Day/Year format; it is required to transform original data source answer. To do this, create an extra Data Source Answer with Data Field [Formula] and add this into Fomula: =format([q1.LoginTimeUtc], "MM/dd/yyyy hh:mm").

PropertyValue
Question TextInfiniti - v10 Analytics Device Log
Data SourceInfiniti
VisibleUnchecked
SelectionMultiple Rows
Unique Field(None)
Default Type(None)
  1. Add a new Visuals Question below the Data Source with following parameters:
PropertyValue
Question TextStacked Bar Chart
Text PositionTop
MandatoryUnchecked
Input (Data)Name=browser
Value=Reference to browser Data Source Answer ([q1.Browser]).

Name=timeUTC
Value=Reference to browser Data Source Answer ([q1.timeUTC]).
Visual DefinitionstackedBarChart
  1. Save Project and add it to a current Intelledox Infiniti Form or Dashboard.
374

Example output

Sunburst Chart (Page Journey)

In this example, we will be pulling data from Intelledox Intelledox Visual Insights Data Sources to visualize Page Journey.

  1. Create a new Intelledox Visual Insights Data Source in Manage (no need to perform this step if you already have one). The connection string in this case could be any text.
395
  1. Add these following JSON definitions into Content Library and name it "Sunburst" and "Radial" respectively, (the same process described in the previous tutorial "Adding a Bar Chart Graph").
{
  "$schema": "https://vega.github.io/schema/vega/v3.0.json",
  "width": 600,
  "height": 600,
  "padding": 5,
  "autosize": "none",
  "data": [
    {
      "name": "tree",
      "values" : ##data##,
      "transform": [
        {
          "type": "stratify",
          "key": "id",
          "parentKey": "parent"
        },
        {
          "type": "partition",
          "field": "occurances",
          "size": [{"signal": "2 * PI"}, {"signal": "width / 2"}],
          "as": ["a0", "r0", "a1", "r1", "depth", "children"]
        }
      ]
    }
  ],
  "scales": [
    {
      "name": "color",
      "type": "ordinal",
      "range": {"scheme": "tableau20"}
    }
  ],
  "marks": [
    {
      "type": "arc",
      "from": {"data": "tree"},
      "encode": {
        "enter": {
          "x": {"signal": "width / 2"},
          "y": {"signal": "height / 2"},
          "fill": {"scale": "color", "field": "depth"},
          "tooltip": {"signal": "datum.pageTitle + (datum.occurances ? ' (' + datum.occurances + ' users)' : '')"}
        },
        "update": {
          "startAngle": {"field": "a0"},
          "endAngle": {"field": "a1"},
          "innerRadius": {"field": "r0"},
          "outerRadius": {"field": "r1"},
          "stroke": {"value": "white"},
          "strokeWidth": {"value": 0.5},
          "zindex": {"value": 0}
        },
        "hover": {
          "stroke": {"value": "red"},
          "strokeWidth": {"value": 2},
          "zindex": {"value": 1}
        }
      }
    }
  ]
}
{
  "$schema": "https://vega.github.io/schema/vega/v3.0.json",
  "width": 720,
  "height": 720,
  "padding": 5,
  "autosize": "none",

  "signals": [
    {
      "name": "labels", "value": true,
      "bind": {"input": "checkbox"}
    },
    {
      "name": "radius", "value": 280,
      "bind": {"input": "range", "min": 20, "max": 600}
    },
    {
      "name": "extent", "value": 360,
      "bind": {"input": "range", "min": 0, "max": 360, "step": 1}
    },
    {
      "name": "rotate", "value": 0,
      "bind": {"input": "range", "min": 0, "max": 360, "step": 1}
    },
    {
      "name": "layout", "value": "tidy",
      "bind": {"input": "radio", "options": ["tidy", "cluster"]}
    },
    {
      "name": "links", "value": "line",
      "bind": {
        "input": "select",
        "options": ["line", "curve", "diagonal", "orthogonal"]
      }
    },
    { "name": "originX", "update": "width / 2" },
    { "name": "originY", "update": "height / 2" }
  ],
  "data": [
    {
      "name": "tree",
       "values": ##data##,
      "transform": [
        {
          "type": "stratify",
          "key": "id",
          "parentKey": "parent"
        },
        {
          "type": "tree",
          "method": {"signal": "layout"},
          "size": [1, {"signal": "radius"}],
          "as": ["alpha", "radius", "depth", "children"]
        },
        {
          "type": "formula",
          "expr": "(rotate + extent * datum.alpha + 270) % 360",
          "as":   "angle"
        },
        {
          "type": "formula",
          "expr": "PI * datum.angle / 180",
          "as":   "radians"
        },
        {
          "type": "formula",
          "expr": "inrange(datum.angle, [90, 270])",
          "as":   "leftside"
        },
        {
          "type": "formula",
          "expr": "originX + datum.radius * cos(datum.radians)",
          "as":   "x"
        },
        {
          "type": "formula",
          "expr": "originY + datum.radius * sin(datum.radians)",
          "as":   "y"
        }
      ]
    },
    {
      "name": "links",
      "source": "tree",
      "transform": [
        { "type": "treelinks", "key": "id" },
        {
          "type": "linkpath",
          "shape": {"signal": "links"}, "orient": "radial",
          "sourceX": "source.radians", "sourceY": "source.radius",
          "targetX": "target.radians", "targetY": "target.radius"
        }
      ]
    }
  ],

  "scales": [
    {
      "name": "color",
      "type": "sequential",
      "range": {"scheme": "magma"},
      "domain": {"data": "tree", "field": "depth"},
      "zero": true
    }
  ],

  "marks": [
    {
      "type": "path",
      "from": {"data": "links"},
      "encode": {
        "update": {
          "x": {"signal": "originX"},
          "y": {"signal": "originY"},
          "path": {"field": "path"},
          "stroke": {"value": "#ccc"}
        }
      }
    },
    {
      "type": "symbol",
      "from": {"data": "tree"},
      "encode": {
        "enter": {
          "size": {"value": 100},
          "stroke": {"value": "#fff"}
        },
        "update": {
          "x": {"field": "x"},
          "y": {"field": "y"},
          "fill": {"scale": "color", "field": "depth"}
        }
      }
    },
    {
      "type": "text",
      "from": {"data": "tree"},
      "encode": {
        "enter": {
          "text": {"field": "pageTitle"},
          "fontSize": {"value": 9},
          "baseline": {"value": "middle"}
        },
        "update": {
          "x": {"field": "x"},
          "y": {"field": "y"},
          "dx": {"signal": "(datum.leftside ? -1 : 1) * 6"},
          "angle": {"signal": "datum.leftside ? datum.angle - 180 : datum.angle"},
          "align": {"signal": "datum.leftside ? 'right' : 'left'"},
          "opacity": {"signal": "labels ? 1 : 0"}
        }
      }
    }
  ]
}
  1. Create a new Data Object Type: "Page Journey". Choose a relevant Display Name like "Page Journey", add all available Filter and Display Fields and click "Save".
841
  1. Open Design and "Crete a New Project". Name it: "AnalyticsVisuals_Fragment_PageJourney" with Project Type: "Fragment Portion".
  2. Add the Intelledox Visual Insights Data Source, and add dateFromUtc, dateToUtc and projectTitle answers.

📘

Note

All Infiniti published forms can be retrieved from Infiniti Data Source - Data Object Type "System Projects"

🚧

Date Format

Vega expects dates to come in Year/Month/Day/ format; it is required to transform original data source answer. To do this, create an extra Data Source Answer with Data Field [Formula] and add this into Formula: =format([q1.LoginTimeUtc], \"yyyy-MM-ddTHH:mm:ss\").

PropertyValue
Question TextIXVisuals
Data SourceIntelledox Visual Insights
VisibleUnchecked
SelectionMultiple Rows
Unique Field(None)
Default Type(None)
  1. Add a new Visuals Question below the Data Source with these following parameters:
Input NameValue
Question TextSunburst
Text Position(None)
MandatoryUnchecked
Input (Data)Name=id
Value=Reference to Intelledox Visual Insights Data Source Answer ([q1.id]).

Name=parent
Value=Reference to Intelledox Visual Insights Data Source Answer ([q1.parent]).

Name=pageTitle
Value=Reference to Intelledox Visual Insights Data Source Answer ([q1.pageTitle]).

Name=occurances
Value=Reference to Intelledox Visual Insights Data Source Answer ([q1.occurances]).
Visual Definitionsunburst.vg.json
  1. Add another new Visuals Question below the Data Source with these following parameters:
Input NameValue
Question TextSunburst
Text Position(None)
MandatoryUnchecked
Input (Data)Name=id
Value=Reference to Intelledox Visual Insights Data Source Answer ([q1.id]).

Name=parent
Value=Reference to Intelledox Visual Insights Data Source Answer ([q1.parent]).

Name=pageTitle
Value=Reference to Intelledox Visual Insights Data Source Answer ([q1.pageTitle]).

Name=occurances
Value=Reference to Intelledox Visual Insights Data Source Answer ([q1.occurances]).
Visual Definitionradial.vg.json
  1. Save Project and add it to a current Intelledox Infiniti Form or Dashboard.
1692