Content dependent icon

Since SKOOR Dashboard 7.1.2 it is possible to use the state column on data source and data query based tables. Values can be mapped to states and the corresponsding lightbulbs are shown. See https://skoorag.atlassian.net/wiki/spaces/DOC/pages/494485/Edit+Table#State for further details.

Problem

Table cell content (e.g. OK) should be replaced with an icon (e.g. lightbulb).

Solution

  1. Set Table cell class in column settings


    In the above example, the class value is taken from the third column of each row. In the example it will result in a class set to status statusOK.

  2. Add some CSS in the dashboard settings dialog


    /* Set a lightbulb as default background image for tds with class status */
    td.status {
      background-image: url('assets/images/lightbulb-grey.svg');
      background-size: 15px;
      background-repeat: no-repeat;
      background-position: center 6px;
    }
    
    /* 
     * Absolute positioned elements (the tooltip in this case) always take the 
     * next not static positioned element as the anchor point
     */
    td.status > div {
      position: relative;
      overflow: visible; 
    }
    
    /* 
     * Makes the inner td absolute positioned and style the span that it looks like a tooltip.
     * Initially, the tooltip is hidden.
     */
    td.status > div > span {    
        padding: 2px;
        display:none;
        position: absolute;
        top: -3px;
        left: 30px;    
        text-align: left;
        background-color: #eff0f1;
        border: 1px solid #c7cbce;
        -moz-border-radius: 2px;
        -webkit-border-radius: 2px;
        -ms-border-radius: 2px;
        border-radius: 2px;
        white-space: nowrap;
    }
    
    /* Shows the tooltip on hover */
    td.status:hover > div > span {
      display: block;
    }
    
    /* 
     * Defines the background image for the defined value. 
     * You need one of those for each possible content, undefined values
     * will display the default image.
     */
    td.statusOK {
      background-image: url('assets/images/lightbulb-green.svg');
    }

This will result in a nice icon displaying the original text on hover.

Instead of using a file URL for the images it is also possible to embed the images directly into the CSS using data URLs:

td.statusOK {
  background-image: url('');
}