aboutsummaryrefslogtreecommitdiff
path: root/app/components/plan-node/plan-node.html
blob: 60cdf50fc5a275de1fbfdb24781489c3cad9db83 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
<div class="plan-node"
   [class.expanded]="showDetails"
   [class.compact]="viewOptions.viewMode === viewModes.COMPACT"
   [class.dot]="viewOptions.viewMode === viewModes.DOT">

   <header (click)="showDetails = !showDetails" tooltip="view node details">
      <h4>{{getNodeName()}}</h4>
      <span *ngIf="viewOptions.viewMode === viewModes.FULL || showDetails">
         <span class="node-duration">{{node[_planService.ACTUAL_DURATION_PROP] | duration}}<span class="text-muted">{{node[_planService.ACTUAL_DURATION_PROP] | durationUnit}}
             | </span><strong>{{executionTimePercent}}</strong>
            <span class="text-muted">%</span>
         </span>
      </span>
   </header>

   <button *ngIf="plan.query && viewOptions.viewMode === viewModes.FULL" tooltip="view corresponding query"
      class="btn btn-sm btn-default btn-slim pull-right" (click)="showQuery = !showQuery">
      <i class="fa fa-database"></i>
   </button>

   <div *ngIf="viewOptions.viewMode === viewModes.FULL">
      <div class="relation-name" *ngIf="node[_planService.RELATION_NAME_PROP]">
         <span class="text-muted">on </span>
         <span *ngIf="node[_planService.SCHEMA_PROP]">{{node[_planService.SCHEMA_PROP]}}.</span>{{node[_planService.RELATION_NAME_PROP]}}
         <span *ngIf="node[_planService.ALIAS_PROP]"> ({{node[_planService.ALIAS_PROP]}})</span>
      </div>

      <div class="relation-name" *ngIf="node[_planService.GROUP_KEY_PROP]">
         <span class="text-muted">by</span> {{node[_planService.GROUP_KEY_PROP]}}</div>
      <div class="relation-name" *ngIf="node[_planService.SORT_KEY_PROP]">
         <span class="text-muted">by</span> {{node[_planService.SORT_KEY_PROP]}}</div>
      <div class="relation-name" *ngIf="node[_planService.JOIN_TYPE_PROP]">{{node[_planService.JOIN_TYPE_PROP]}}
         <span class="text-muted">join</span></div>
      <div class="relation-name" *ngIf="node[_planService.INDEX_NAME_PROP]"><span class="text-muted">
         using</span> {{node[_planService.INDEX_NAME_PROP]}}</div>
      <div class="relation-name" *ngIf="node[_planService.HASH_CONDITION_PROP]"><span class="text-muted">
         on</span> {{node[_planService.HASH_CONDITION_PROP]}}</div>
   </div>

   <div class="tags" *ngIf="viewOptions.showTags && tags.length > 0">
      <span *ngFor="#tag of tags">{{getTagName(tag)}}</span>
   </div>

   <div *ngIf="currentHighlightType !== highlightTypes.NONE">
      <div class="node-bar-container">
         <span class="node-bar" [style.width]="barWidth+'px'" [style.backgroundColor]="backgroundColor"></span>
      </div>
      <span class="node-bar-label" *ngIf="shouldShowNodeBarLabel()">
         <span class="text-muted">{{viewOptions.highlightType}}:</span> {{highlightValue | number:'.0-2'}}
      </span>
   </div>

   <div class="planner-estimate" *ngIf="shouldShowPlannerEstimate()">
      <span *ngIf="plannerRowEstimateDirection === estimateDirections.over"><strong>over</strong> estimated rows</span>
      <span *ngIf="plannerRowEstimateDirection === estimateDirections.under"><strong>under</strong> estimated rows</span>
      <span> by <strong>{{plannerRowEstimateValue | number}}</strong>x</span>
   </div>

   <div *ngIf="showDetails">
      <div *ngIf="getNodeTypeDescription()" class="node-description">
         <span class="node-type">{{node[_planService.NODE_TYPE_PROP]}} Node</span> <span [innerHtml]="getNodeTypeDescription()"></span>
      </div>

      <table class="table prop-list">
         <tr *ngFor="#prop of props">
            <td width="40%">{{prop.key}}</td>
            <td>{{prop.value}}</td>
         <tr>
      </table>
      <div class="text-muted pad-top align-right"><em>*Pev calculated value</em></div>
   </div>

   <div *ngIf="showQuery" class="plan-query-container">
      <button class="btn btn-close pull-right" (click)="showQuery = false">
         <i class="fa fa-close"></i>
      </button>
      <h3>query</h3>
      <pre class="plan-query-text"><code [innerHTML]="getFormattedQuery()"></code></pre>
   </div>
</div>

<ul *ngIf="node.Plans">
  <li *ngFor="#subNode of node.Plans">
    <plan-node [plan]="plan" [node]="subNode" [viewOptions]="viewOptions" [planStats]="planStats"></plan-node>
  </li>
</ul>