source: trunk/zoo-project/zoo-services/utils/open-api/templates/index.html @ 962

Last change on this file since 962 was 962, checked in by djay, 19 months ago

Update OGC API - Processes documentation and implementation, providing a browsable User Interface to Processes.

File size: 26.5 KB
Line 
1<!doctype html>
2#import zoo
3#import html,os
4#set removeCacheFile=False
5#set strUrl=$inputs["tmpl"]["xlink:href"]
6#set currentUrl=$strUrl.replace($openapi["openapi"]["rootUrl"],"")
7#if $currentUrl=="/"
8#set currentKey="root"
9#set $currentUrl="/index"
10#else
11#set currentKey=$currentUrl
12#end if
13#set urlCompnents=$currentUrl.split('/')
14#*
15* Load the JSON content from the API
16*#
17#try
18#import json
19#if "cache_file" in $inputs["tmpl"]
20#set values=json.load(open($inputs["tmpl"]["cache_file"]))
21#else
22#set values=$inputs["tmpl"]["value"]
23#end if
24#except Exception as e
25$e
26#end try
27<html lang="en">
28  <head>
29    <!-- Required meta tags -->
30    <meta charset="utf-8">
31    <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
32
33    <!-- Bootstrap CSS -->
34    <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css" integrity="sha384-JcKb8q3iqJ61gNV9KGb8thSsNjpSL0n8PARn9HuZOnIxN0hoP+VmmDGMN5t9UJ0Z" crossorigin="anonymous">
35
36    <!-- Custom styles for this template -->
37    <link href="$openapi["openapi"]["rootUrl"]/../static/openapi.css" rel="stylesheet">
38
39    <title>#if "id" in $values#$values["id"]#else##if $currentKey in $openapi and "title" in $openapi[$currentKey]#$openapi[$currentKey]["title"]#else#Landing Page#end if##end if#</title>
40  </head>
41  <body itemscope itemtype="https://schema.org/DataCatalog">
42    <header>
43     <!-- Fixed navbar -->
44      <nav
45        class="navbar navbar-expand-md navbar-dark fixed-top bg-dark"
46        itemprop="creator"
47        itemscope itemtype="https://schema.org/Organization" >
48        <a class="navbar-brand" href="#">
49          <img itemprop="logo" src="http://zoo-project.org/img/zoo-sun-logo.png" width="55" height="30" class="d-inline-block align-top" alt="">
50           <span itemprop="name">$conf["provider"]["providerName"]</span>
51        </a>
52        <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarCollapse" aria-controls="navbarCollapse" aria-expanded="false" aria-label="Toggle navigation">
53          <span class="navbar-toggler-icon"></span>
54        </button>
55        <div class="collapse navbar-collapse" id="navbarCollapse">
56          <ul class="navbar-nav mr-auto"
57            itemscope itemtype="https://schema.org/BreadcrumbList">
58            <li class="nav-item #if $currentKey=="root"# active#end if#"
59              itemprop="itemListElement" itemscope
60              itemtype="https://schema.org/ListItem">
61              <a itemprop="item" class="nav-link"
62                href="$openapi["openapi"]["rootUrl"]/index.html">
63                <span itemprop="name">Home #if $currentKey=="root"# <span class="sr-only">(current)</span>#end if#</span>
64                <meta itemprop="position" content="1" />
65              </a>
66            </li>
67            #if $currentKey!="root"
68            #for i in range(1,len($urlCompnents))
69            <li
70              itemprop="itemListElement" itemscope
71              itemtype="https://schema.org/ListItem"
72              class="nav-item #if $i+1==len($urlCompnents)#active#end if#">
73            #set prefix=""
74            #for j in range(1,$i)
75            #set $prefix+="/"+$urlCompnents[$j]
76            #end for
77              <a itemprop="item" class="nav-link" href="$openapi["openapi"]["rootUrl"]$(prefix)/$(urlCompnents[$i]).html">
78                <span itemprop="name">
79            #if $i==2
80            $(urlCompnents[$i])
81            #else
82            $(urlCompnents[$i].title())
83            #end if
84            #if $i+1==len($urlCompnents)
85            <span class="sr-only">(current)</span>
86            #end if
87                <meta itemprop="position" content="$(i+1)" />
88                </span>
89              </a>
90            </li>
91            #end for
92            #end if
93          </ul>
94        </div>
95       </nav>
96    </header>
97        <script>
98        var System={};
99        </script>
100
101#def printRel($o,$v)
102#if $v in $o
103$o[$v]
104#else
105View default (no title found for $v).
106#end if
107#end def
108#*
109       
110*#
111#def printControl(obj)
112#if "type" not in $obj
113#set oType="format"
114#else
115#set oType=$obj["type"]
116#end if
117        <div class="input-group">
118          <div class="input-group-prepend">
119            <div class="input-group-text">$obj["title"]</div>
120          </div>
121          #if "ph" in $obj 
122          <input type="text"
123            #if "value" in $obj#value="$obj["value"]""#end if#
124            #if "id" in $obj#data-id="$obj["id"]"#end if#
125            class="form-control" data-name="$obj["title"]" name="$(oType)_$obj["name"]" placeholder="$obj["ph"]" #if "required" in $obj#required#end if#/>
126          #else
127          <select name="$(oType)_$obj["name"]" class="form-control" #if "required" in $obj#required#end if#>
128          #for i in range(len($obj["options"]))
129            <option>$obj["options"][$i]</option>
130          #end for
131          </select>
132          #end if
133          #if "required" in $obj
134          <div class="invalid-feedback">
135            Please set a value for $obj["id"].
136          </div>
137          #end if
138        </div>
139#end def
140#def printCard(obj)
141      <div class="card" #if "attrs" in $obj#$obj["attrs"]#end if#>
142        <div class="card-header" id="heading$(obj["id"])">
143          <h4 class="mb-0">
144            <button class="btn btn-link btn-block text-left" type="button" data-toggle="collapse" data-target="#collapse$(obj["id"])" aria-expanded="true" aria-controls="collapse$(obj["id"])">
145              $obj["title"]
146            </button>
147          </h4>
148        </div>
149        <div id="collapse$(obj["id"])" class="collapse #if "class" in $obj#$obj["class"]#end if#" aria-labelledby="heading$(obj["id"])">
150          <div class="card-body">
151            $obj["content"]
152          </div>
153        </div>
154      </div>
155#end def
156#def printInputContent($obj)
157#set cName=$obj["id"].replace(".","_")
158#if "formats" in $obj["input"]
159 #set cFormats=[]
160  #for j in range(len($obj["input"]["formats"]))
161  #set $cFormats+=[$obj["input"]["formats"][$j]["mimeType"]]
162  #end for
163  $printControl({"title": "format","type": "input_format","name": $cName,"options":$cFormats})
164  #set largs={"id": $obj["id"],"title": "href","type": "input_value","name": $cName,"ph":"URL"}
165  #if $obj["minOccurs"]>0
166  #set $largs["required"]=True
167  #end if
168  $printControl($largs)
169#else
170 #if "literalDataDomains" in $obj["input"]
171  #set cDataDomain=$obj["input"]["literalDataDomains"][0]
172  #set largs={"id": $obj["id"],"title": $cDataDomain["dataType"]["name"],"type": "input_value", "name": $cName,}
173  #if $obj["minOccurs"]>0
174  #set $largs["required"]=True
175  #end if
176  #if "anyValue" in $cDataDomain["valueDefinition"]
177   #set $largs["ph"]="Value"
178      $printControl($largs)
179  #else
180   #if "allowedValues" in $cDataDomain["valueDefinition"]
181    #set $largs["options"]=$cDataDomain["valueDefinition"]["allowedValues"]
182    $printControl($largs)
183   #else
184    ELSE
185    $obj
186   #end if
187  #end if
188  #if "defaultValue" in $cDataDomain
189      <script>
190        System["function_$cName"]=function(){
191          try{
192            jQuery("input[name='input_value_$cName'],select[name='input_value_$cName]']").val($cDataDomain["defaultValue"]);
193          }catch(e){
194            jQuery("input[name='input_value_$cName'],select[name='input_value_$cName']").val("$cDataDomain["defaultValue"]");
195          }
196        }
197      </script>
198  #end if
199 #else
200  $obj
201  ELSE
202 #end if
203#end if
204#end def
205#def printProvider(conf)
206#set provider=$conf["provider"]
207      <b itemprop="name">$provider["providerName"]</b>
208      <p><a itemprop="url" href="$provider["providerSite"]">$provider["providerSite"]</a></p>
209#end def
210#def printContact(conf)
211#set provider=$conf["provider"]
212#set alt=$openapi["provider_alt"]
213#set elements=list($alt.keys())
214      <b>Address</b>
215      #for i in ["addressDeliveryPoint","addressCity","addressAdministrativeArea","addressPostalCode","addressCountry","addressElectronicMailAddress","phoneVoice","phoneFacsimile"]
216      #if i!="addressElectronicMailAddress" and $provider[$i]!="False"
217      <p itemprop="$(alt[$i.lower()])">
218      #if i=="phoneVoice"
219      Phone
220      <svg width="1em" height="1em" viewBox="0 0 16 16" class="bi bi-telephone" fill="currentColor" xmlns="http://www.w3.org/2000/svg">
221        <path fill-rule="evenodd" d="M3.654 1.328a.678.678 0 0 0-1.015-.063L1.605 2.3c-.483.484-.661 1.169-.45 1.77a17.568 17.568 0 0 0 4.168 6.608 17.569 17.569 0 0 0 6.608 4.168c.601.211 1.286.033 1.77-.45l1.034-1.034a.678.678 0 0 0-.063-1.015l-2.307-1.794a.678.678 0 0 0-.58-.122l-2.19.547a1.745 1.745 0 0 1-1.657-.459L5.482 8.062a1.745 1.745 0 0 1-.46-1.657l.548-2.19a.678.678 0 0 0-.122-.58L3.654 1.328zM1.884.511a1.745 1.745 0 0 1 2.612.163L6.29 2.98c.329.423.445.974.315 1.494l-.547 2.19a.678.678 0 0 0 .178.643l2.457 2.457a.678.678 0 0 0 .644.178l2.189-.547a1.745 1.745 0 0 1 1.494.315l2.306 1.794c.829.645.905 1.87.163 2.611l-1.034 1.034c-.74.74-1.846 1.065-2.877.702a18.634 18.634 0 0 1-7.01-4.42 18.634 18.634 0 0 1-4.42-7.009c-.362-1.03-.037-2.137.703-2.877L1.885.511z"/>
222      </svg>
223      #end if
224      $provider[$i]
225      </p>
226      #else
227      #if i=="addressElectronicMailAddress"
228      <b>Email</b>
229      <p itemprop="$(alt[$i.lower()])">
230      $provider[$i]
231      </p>
232      #end if
233      #end if
234      #end for
235#end def     
236#def printIndentification(conf)
237#set provider=$conf["provider"]
238$printCard({"id": "provider","title": "Provider","content": $printProvider($conf),"class": "show"})
239$printCard({"id": "contact","title": "Contact","content": $printContact($conf),"class": "show","attrs":'itemprop="address" itemscope itemtype="https://schema.org/PostalAddress"'})
240#end def
241     
242#if $currentKey=="root"
243  <div class="container-fluid">
244  <div class="row">
245      <div class="col-sm-8">
246#end if
247        <!-- $currentUrl -->
248      <!-- Begin page content -->     
249      <main #if $currentKey!="root"#class="container-fluid"#end if#>
250        <h1 itemprop="name">#if "id" in $values#$values["id"]: #end if##if "title" in $values#$html.escape($values["title"])#else##if len($urlCompnents)==2#$currentUrl[1:].title()#else#$currentUrl[1:]#end if##end if#</h1>
251        #if "description" in $values#<p itemprop="description">$html.escape($values["description"])</p>#end if#
252        #if $currentKey=="root"
253        <div class="keywords">
254          #for i in $conf["identification"]["keywords"].split(',')
255          <button type="button"
256            class="btn btn-outline-info">$i</button>
257          #end for
258        </div>
259        License:
260        <a itemprop="license" href="$openapi["openapi"]["license_url"]">$openapi["openapi"]["license_name"]</a>
261        #end if
262    #if "inputs" in $values
263#set $cid="JOBSOCKET-"+$conf["lenv"]["usid"]
264        <form class="needs-validation" data-id="$cid" novalidate>
265    <h3>Inputs</h3>
266    <div class="accordion" id="accordionInputExample">
267      #for i in range(len(values["inputs"]))
268      #set cInput=$values["inputs"][$i]
269      #set cName=$cInput["id"].replace(".","_")
270      $printCard({"id": $cName, "title": $cInput["id"],"content":'<p>'+$cInput["description"]+'</p>'+$printInputContent($cInput)})
271      #end for   
272    </div>
273     
274    <h3>Outputs</h3>
275    <div class="accordion" id="accordionOutputExample">
276      #for i in range(len(values["outputs"]))
277      #set cOutput=$values["outputs"][$i]
278      #set cName=$cOutput["id"].replace(".","_")
279      #set cFormats=[]
280      #if "formats" in $cOutput["output"]
281      #for j in range(len($cOutput["output"]["formats"]))
282      #set cFormats+=[$cOutput["output"]["formats"][$j]["mimeType"]]
283      #end for
284      #end if
285      #set cTransmissions=[]
286      #for j in range(len($values["outputTransmission"]))
287      #set cTransmissions+=[$values["outputTransmission"][$j]]
288      #end for
289      #set cContent="<p>"+$cOutput["description"]+"</p>"
290      #if len(cFormats)>0
291      #set $cContent+=$printControl({"id": $cOutput["id"], "title": "format","type": "format","name": $cName,"options":$cFormats})
292      #end if
293      #if len(cTransmissions)>0
294      #set $cContent+=$printControl({"id": $cOutput["id"], "title": "transmission","type": "transmission","name": $cName,"options":$cTransmissions})
295      #end if
296      $printCard({"id": $cName+"_"+str($i),"title": $cOutput["id"],"content": $cContent})
297      #end for
298    </div>
299   
300    <h3>Execution options</h3>
301    <div class="accordion" id="accordionExampleExecutionMode">
302      #set cContent=""
303      #set cUrl=$openapi["openapi"]["publisherurl"]+cid+"&type="
304      #for a in ["successUri","inProgressUri","failedUri"]
305      #set $cContent+=$printControl({"title": $a,"type": "main_value","name": $a,"ph":"URL","value":$cUrl+$a.replace("Uri","")})
306      #end for
307      $printCard({"id":"ModeOne","title":"Subscribers","content": $cContent})
308      $printCard({"id":"ModeTwo","title":"Response","content": $printControl({"title":"format","type": "main_value","name": "format","options":["document","raw"]})})
309      $printCard({"id":"ModeThree","title":"Mode","content": $printControl({"title":"mode","type": "main_value","name": "mode","options":["async","sync"]})})
310    </div>
311    <button type="submit" class="btn btn-primary" >Submit</button>
312    </form>
313    <div class="modal" tabindex="-1" id="exampleModal">
314      <div class="modal-dialog modal-xl">
315        <div class="modal-content">
316          <div class="modal-header">
317            <h5 class="modal-title">Your request</h5>
318            <button type="button" class="close" data-dismiss="modal" aria-label="Close">
319              <span aria-hidden="true">&times;</span>
320            </button>
321          </div>
322          <div class="modal-body">
323            <textarea name="modalText" class="form-control" style="min-height:300px"></textarea>
324            <pre id="result"></pre>
325            <div id="progress_details" style="display:none">
326              <p id="prgress_description"></p>
327              <div class="progress">
328                <div class="progress-bar progress-bar-striped progress-bar-animated" role="progressbar" aria-valuenow="0" aria-valuemin="0" aria-valuemax="100" style="width: 0%"></div>
329              </div>
330            </div>
331          </div>
332          <div class="modal-footer">
333            <button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>
334            <button type="button" class="btn btn-primary">Submit Job</button>
335          </div>
336        </div>
337      </div>
338    </div>
339    <script>
340      var socket;
341      function loadRequest(){
342        var requestObject={
343          "inputs":[],
344          "outputs":[],
345          "subscriber":{},
346          "mode": \$("select[name='main_value_mode']").val(),
347          "response": \$("select[name='main_value_format']").val()
348        }
349        for(var i=0;i < System["JSON_STR"]["inputs"].length;i++){
350          var cInput={"id": System["JSON_STR"]["inputs"][i]["id"]};
351          var cName=System["JSON_STR"]["inputs"][i]["id"].replace(".","_");
352          var selector="input[name='input_value_"+cName+"'],"+
353                       "select[name='input_value_"+cName+"']";
354          if(\$(selector).val()!=""){
355            cInput["input"]={};
356          if(System["JSON_STR"]["inputs"][i]["input"]["formats"]){
357            var selector1="input[name='input_format_"+cName+"'],"+
358              "select[name='input_format_"+cName+"']";
359            cInput["input"]["format"]={
360              "mimeType": \$(selector1).val()
361            };
362            cInput["input"]["value"]={
363              "href": \$(selector).val()
364            };
365          }
366          else{
367            if(System["JSON_STR"]["inputs"][i]["input"]["literalDataDomains"]){
368              console.log(System["JSON_STR"]["inputs"][i]["input"]["literalDataDomains"]);
369              cInput["input"]["dataType"]={
370                "name": System["JSON_STR"]["inputs"][i]["input"]["literalDataDomains"][0]["dataType"]["name"]
371              };
372              cInput["input"]["value"]=\$(selector).val();
373            }
374            }
375            requestObject["inputs"].push(cInput);
376          }
377        }
378        console.log(System["JSON_STR"]["outputs"]);
379        for(var i=0;i < System["JSON_STR"]["outputs"].length;i++){
380          var cOutput={"id": System["JSON_STR"]["outputs"][i]["id"]};
381          var cName=System["JSON_STR"]["outputs"][i]["id"].replace(/\./g,"_");
382          if(System["JSON_STR"]["outputs"][i]["output"]["formats"]){
383            var selector="select[name='format_"+cName+"']";
384            cOutput["format"]={
385              "mimeType": \$(selector).val()
386            };
387          }
388          else{
389            if(System["JSON_STR"]["outputs"][i]["output"]["literalDataDomains"]){
390              cOutput["dataType"]={
391                "name": System["JSON_STR"]["outputs"][i]["output"]["literalDataDomains"][0]["dataType"]["name"]
392              };
393            }
394          }
395          var selector1="select[name='transmission_"+cName+"']";
396          cOutput["transmissionMode"]=\$(selector1).val();
397          requestObject["outputs"].push(cOutput);
398        }
399        if(\$("input[name='main_value_successUri']").val()!="")
400          requestObject["subscriber"]["successUri"]=\$("input[name='main_value_successUri']").val();
401        if(\$("input[name='main_value_inProgressUri']").val()!="")
402          requestObject["subscriber"]["inProgressUri"]=\$("input[name='main_value_inProgressUri']").val();
403        if(\$("input[name='main_value_failedUri']").val()!="")
404          requestObject["subscriber"]["failedUri"]=\$("input[name='main_value_failedUri']").val();
405        \$(".modal").find("textarea").first().val(js_beautify(JSON.stringify(requestObject)));
406        \$("#exampleModal").modal('toggle');
407        \$('#result').html("");
408        \$("#exampleModal").find(".btn-primary").off('click');
409        \$("#exampleModal").find(".btn-primary").click(function(){
410          \$('#result').html("");
411          if(!socket && requestObject["mode"]!="sync")
412            socket = new WebSocket("$openapi["openapi"]["wsurl"]");
413          else
414              \$.ajax({
415                contentType: "application/json",
416                data: \$("textarea").val(),
417                type: "POST",
418                url: "$openapi["openapi"]["rootUrl"]$(currentUrl)/jobs",
419                success: function (msg) {
420                  console.log(msg);
421                  var cObj=msg;
422                  \$('#result').html(js_beautify(JSON.stringify(msg["outputs"])));
423                },
424                error: function(){
425                  console.log(arguments);
426                },
427              });
428          if(requestObject["mode"]=="sync"){
429           return;
430          }
431          socket.onopen = function () {
432            console.log('Connected!');
433            socket.send("SUB $cid");
434          };
435          socket.onmessage = function(event) {
436            console.log('MESSAGE: ' + event.data);
437            if(event.data=="1")
438              \$.ajax({
439                contentType: "application/json",
440                data: \$("textarea").val(),
441                type: "POST",
442                url: "$openapi["openapi"]["rootUrl"]$(currentUrl)/jobs",
443                success: function (msg) {
444                  console.log(msg);
445                },
446                error: function(){
447                  console.log(arguments);
448                },
449              });
450            else{
451              //progressBar
452              \$("#progress_details").show();
453              var cObj=JSON.parse(event.data);
454              if(cObj["jobID"]){
455                \$("#prgress_description").html(cObj["jobID"]+": "+cObj["message"]);
456                \$(".progress-bar").attr("aria-valuenow",cObj["progress"]);
457                \$(".progress-bar").css("width",cObj["progress"]+"%");
458              }else{
459                \$("#progress_details").hide();
460                if(cObj["outputs"])
461                  \$('#result').html(js_beautify(JSON.stringify(cObj["outputs"])));
462                else
463                  \$('#result').html(cObj["message"]);
464              }
465            }
466          };
467        });
468      }
469    </script>
470    #end if
471   
472    #try
473    #if "links" in $values
474    #for i in range(len($values["links"]))
475    #if $i%2==0   
476    <h2>$values["links"][$i]["title"]</h2>
477    <p>
478      <a href="$values["links"][$i]["href"]">$printRel($openapi["links_title"],$values["links"][$i]["rel"])</a>
479    </p>
480    #if $i+1<=len($values["links"]) and len($values["links"])>1 and not($values["links"][$i+1]["rel"]=="alternate" and $openapi["openapi"]["full_html_support"]=="true")
481    <p><a href="$values["links"][$i+1]["href"]">$printRel($openapi["links_title"],$values["links"][$i+1]["rel"])</a></p>
482    #end if
483    #end if
484    #end for
485    #end if
486    #except Exception as e
487    $e
488    #end try
489    #if "conformsTo" in $values
490    <ul>
491      #for i in range(len($values["conformsTo"]))
492      <li>
493      <a href="$values["conformsTo"][$i]">$values["conformsTo"][$i]</a>
494      </li>
495      #end for
496    </ul>
497    #end if
498    #if "jobs" in $urlCompnents
499    #set $removeCacheFile=True
500    #end if
501    #if hasattr($values, "__len__") and isinstance($values,list) and len($values)>0
502    <table class="table table-striped">
503      <thead>
504        <tr>
505          #if "jobs" not in $urlCompnents
506          #*
507          * Processes list
508          *#
509          <th scope="col">#</th>
510          <th scope="col">Title</th>
511          <th scope="col">Version</th>
512          #else
513          #*
514          * Jobs list
515          *#
516          <th scope="col">#</th>
517          <th scope="col">Message</th>
518          <th scope="col">Links</th>
519          #end if
520        </tr>
521      </thead>
522      <tbody>   
523        #for i in range(len($values))
524        <tr>
525          #if "jobs" not in $urlCompnents
526          #*
527          * Processes list
528          *#
529          <th scope="row">
530            <a href="$(values[$i]["links"][0]["href"][:-1]).html">
531              <svg width="1em" height="1em" viewBox="0 0 16 16" class="bi bi-link-45deg" fill="currentColor" xmlns="http://www.w3.org/2000/svg">
532                <path d="M4.715 6.542L3.343 7.914a3 3 0 1 0 4.243 4.243l1.828-1.829A3 3 0 0 0 8.586 5.5L8 6.086a1.001 1.001 0 0 0-.154.199 2 2 0 0 1 .861 3.337L6.88 11.45a2 2 0 1 1-2.83-2.83l.793-.792a4.018 4.018 0 0 1-.128-1.287z"/>
533                <path d="M6.586 4.672A3 3 0 0 0 7.414 9.5l.775-.776a2 2 0 0 1-.896-3.346L9.12 3.55a2 2 0 0 1 2.83 2.83l-.793.792c.112.42.155.855.128 1.287l1.372-1.372a3 3 0 0 0-4.243-4.243L6.586 4.672z"/>
534              </svg>
535            $values[$i]["id"]
536            </a>
537          </th>
538          <td>$values[$i]["title"]</td>
539          <td>#if "version" in $values[$i]#$values[$i]["version"]#else#1.0.0#end if#</td>
540          #else
541          #*
542          * Jobs list
543          *#
544          #set cValue=$values[$i]["infos"]
545          <th scope="row">
546            #if "status" in $cValue and $cValue["status"]=="successful"
547            <svg width="1em" height="1em" viewBox="0 0 16 16" class="bi bi-check-circle-fill text-success" fill="currentColor" xmlns="http://www.w3.org/2000/svg">
548              <path fill-rule="evenodd" d="M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zm-3.97-3.03a.75.75 0 0 0-1.08.022L7.477 9.417 5.384 7.323a.75.75 0 0 0-1.06 1.06L6.97 11.03a.75.75 0 0 0 1.079-.02l3.992-4.99a.75.75 0 0 0-.01-1.05z"/>
549            </svg>
550            #else
551            #if "status" in $cValue and $cValue["status"]=="failed"
552            <svg width="1.0625em" height="1em" viewBox="0 0 17 16" class="bi bi-exclamation-triangle-fill text-error" fill="currentColor" xmlns="http://www.w3.org/2000/svg">
553              <path fill-rule="evenodd" d="M8.982 1.566a1.13 1.13 0 0 0-1.96 0L.165 13.233c-.457.778.091 1.767.98 1.767h13.713c.889 0 1.438-.99.98-1.767L8.982 1.566zM8 5a.905.905 0 0 0-.9.995l.35 3.507a.552.552 0 0 0 1.1 0l.35-3.507A.905.905 0 0 0 8 5zm.002 6a1 1 0 1 0 0 2 1 1 0 0 0 0-2z"/>
554            </svg>
555            #end if
556            #end if
557            $cValue["jobID"]
558          </th>
559          <td>$cValue["message"]</td>
560          <td>
561          <div class="dropdown">
562            <button class="btn btn-secondary dropdown-toggle" type="button" id="dropdownMenuButton" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
563            Action
564            </button>
565            <div class="dropdown-menu" aria-labelledby="dropdownMenuButton">
566              #for j in range(len($cValue["links"]))
567              #set $cValueLink=$cValue["links"][$j]
568              #if $cValueLink["href"].count("result")==0
569              <a class="dropdown-item delete"
570                href="#"
571                data-value="$(cValueLink["href"])">Delete</a>
572              #end if
573              <a class="dropdown-item" href="$(cValueLink["href"]).html">$cValueLink["title"]</a>
574              #end for       
575            </div>
576          </div>
577          </td>
578          #end if
579        </tr>   
580        #end for
581      </tbody>
582    </table>
583    <script>
584    System["jobListDelete"]=function(){
585      \$(".delete").each(function(){
586        \$(this).off("click");
587        \$(this).click(function(){
588          console.log("OK");
589          \$.ajax({
590            url: \$(this).data("value"),
591            type: "DELETE",
592            success: function(){
593              console.log(arguments);
594            }
595          });
596        });
597      });
598    }
599    </script>
600    #end if
601
602      <div class="microlight">$json.dumps(values)</div>
603      <textarea class="form-control" style="height: 300px;"></textarea>
604      <script>
605      window.onload = function(){
606        var jsContent=\$(".microlight").html();
607        var tmpStr=js_beautify(jsContent);
608        \$("textarea").last().val(tmpStr);
609        \$(".microlight").remove();
610        for(var i in System){
611          System[i]();
612        }
613         System["JSON_STR"]=JSON.parse(tmpStr);
614         var forms = document.getElementsByClassName('needs-validation');
615         // Loop over them and prevent submission
616         var validation = Array.prototype.filter.call(forms, function(form) {
617      form.addEventListener('submit', function(event) {
618             event.preventDefault();
619             event.stopPropagation();
620             if (form.checkValidity() === false) {
621               event.preventDefault();
622      event.stopPropagation();
623      alert('ok');
624             }else{
625               loadRequest();
626             }
627             form.classList.add('was-validated');
628           }, false);
629         });
630     
631      }
632      </script>
633      <hr>
634      <address>$openapi["openapi"]["rootUrl"]$(currentUrl).html</address>
635      <!-- hhmts start -->Last modified: Wed Oct 21 17:23:48 CEST 2020 <!-- hhmts end -->
636    </main>
637#if $currentKey=="root"
638    </div> 
639    <div class="col-sm-4"
640      itemprop="provider"
641      itemscope itemtype="https://schema.org/Organization">
642      $printIndentification($conf)
643    </div>
644   </div>
645  </div>
646#end if
647     
648
649    <footer class="footer" itemscope itemtype="https://schema.org/SoftwareApplication">
650      <div class="container-fluid">
651        <span class="text-muted">
652          Powered by
653          <a target="_blank" itemprop="url"
654            href="http://www.zoo-project.org/"><span itemprop="name">ZOO-Project</span></a>
655          <span itemprop="version">$zoo.VERSION</span>.
656          <meta itemprop="applicationCategory" content="WebService" />
657        #try
658        #set sysname=$os.uname()
659        #except Exception as e
660        #set sysname=["Unknown"]
661        #end try
662          <meta itemprop="operatingSystem" content="$sysname[0]" />
663        </span>
664      </div>
665    </footer>
666
667    <!-- JS, Popper.js, and jQuery -->
668    <script src="https://code.jquery.com/jquery-3.5.1.min.js" integrity="sha256-9/aliU8dGd2tb6OSsuzixeV4y/faTqgFtohetphbbj0=" crossorigin="anonymous"></script>
669    <script src="https://cdn.jsdelivr.net/npm/popper.js@1.16.1/dist/umd/popper.min.js" integrity="sha384-9/reFTGAW83EW2RDu2S0VKaIzap3H66lZH81PoYlFhbGU+6BZp6G7niu735Sk7lN" crossorigin="anonymous"></script>
670    <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.5.2/js/bootstrap.min.js" integrity="sha384-B4gt1jrGC7Jh4AgTPSdUtOBvfO8shuf57BaghqFfPlYxofvL8/KUEfYiJOMMV+rV" crossorigin="anonymous"></script>
671    <script src="https://cdnjs.cloudflare.com/ajax/libs/js-beautify/1.13.0/beautify.min.js" integrity="sha512-84xqGKD+OW9ElGeIq5RkXhsKveQx+kAjahn9r7f/Vm9J0bDrwEabW3MQNgYdTzLBnwfrTGs0nuPx3pZxh6itNg==" crossorigin="anonymous"></script>
672  </body>
673</html>
674#if "cache_file" in $inputs["tmpl"] and $removeCacheFile
675<!-- REMOVED ! -->     
676#import os
677$(os.remove($inputs["tmpl"]["cache_file"]))
678#end if
Note: See TracBrowser for help on using the repository browser.

Search

Context Navigation

ZOO Sponsors

http://www.zoo-project.org/trac/chrome/site/img/geolabs-logo.pnghttp://www.zoo-project.org/trac/chrome/site/img/neogeo-logo.png http://www.zoo-project.org/trac/chrome/site/img/apptech-logo.png http://www.zoo-project.org/trac/chrome/site/img/3liz-logo.png http://www.zoo-project.org/trac/chrome/site/img/gateway-logo.png

Become a sponsor !

Knowledge partners

http://www.zoo-project.org/trac/chrome/site/img/ocu-logo.png http://www.zoo-project.org/trac/chrome/site/img/gucas-logo.png http://www.zoo-project.org/trac/chrome/site/img/polimi-logo.png http://www.zoo-project.org/trac/chrome/site/img/fem-logo.png http://www.zoo-project.org/trac/chrome/site/img/supsi-logo.png http://www.zoo-project.org/trac/chrome/site/img/cumtb-logo.png

Become a knowledge partner

Related links

http://zoo-project.org/img/ogclogo.png http://zoo-project.org/img/osgeologo.png