Inhaltsabhängiges Symbol

Seit SKOOR Dashboard 7.1.2 ist es möglich, die state für datenquellen- und datenabfragebasierte Tabellen zu verwenden. Werte können Zuständen zugeordnet werden und die entsprechenden Glühbirnen werden angezeigt. Weitere Details finden Sie unter https://skoorag.atlassian.net/wiki/spaces/DOC/pages/494485/Edit+ Tabelle #State .

Problem

Der Zelleninhalt Tabelle (z. B. OK ) sollte durch ein Symbol (z. B. eine Glühbirne) ersetzt werden.

Lösung

  1. Legen Sie Tabelle in den Spalteneinstellungen fest


    Im obigen Beispiel wird der Klassenwert aus der dritten Spalte jeder Zeile entnommen. Im Beispiel führt dies dazu, dass eine Klasse auf den Status statusOK gesetzt wird.

  2. Fügen Sie im Dashboard-Einstellungsdialog etwas CSS hinzu


    /* 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');
    }

Dies führt zu einem schönen Symbol, das beim Schweben den Originaltext anzeigt.

Anstatt eine Datei-URL für die Bilder zu verwenden, ist es auch möglich, die Bilder mithilfe von Daten-URLs direkt in das CSS einzubetten:

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