| <!DOCTYPE html> |
| <!-- |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you under the Apache License, Version 2.0 (the |
| * "License"); you may not use this file except in compliance |
| * with the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, |
| * software distributed under the License is distributed on an |
| * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| * KIND, either express or implied. See the License for the |
| * specific language governing permissions and limitations |
| * under the License. |
| --> |
| <div id="bodydiv" class="bodydiv"> |
| |
| <table style="width: 100%;"> |
| <tr> |
| <td><h2><span id="h1"></span><span id="appNameHeader"></span></h2></td> |
| </tr> |
| </table> |
| |
| <table style="width: 100%;"> |
| <tr> |
| <th id="th" class="thl thr" style="padding-top: 4px; padding-bottom:4px;">Clone this App</th> |
| </tr> |
| </table> |
| |
| <form id="cloneAppForm"> |
| <table style="width: 100%;"> |
| <tr><td><b>New App Name:</b></td></tr> |
| <tr><td><input type="text" id="appName" size="15" autocapitalize="off" placeholder="Your app name"/> <span id="appDomain"></span></td></tr> |
| <tr><tr><td style="padding-top: 6px;"><b>App Icon:</b></td></tr> |
| <tr><td><img id="appimg" style="width: 50px; height: 50px; vertical-align: top;"></td></tr> |
| <tr><tr><td style="padding-top: 6px;"><b>Sharing:</b></td></tr> |
| <tr><td><input type="checkbox" value="shared"/><span>Shared</span></td></tr> |
| <tr><tr><td style="padding-top: 6px;"><b>App Title:</b></td></tr> |
| <tr><td><input type="text" id="appTitle" size="30" placeholder="Enter the title of your app" style="width: 300px;"/></td></tr> |
| <tr><tr><td style="padding-top: 6px;"><b>Description:</b></td></tr> |
| <tr><td><textarea id="appDescription" cols="40" rows="3" placeholder="Enter a short description of your app" style="width: 300px;"></textarea></td></tr> |
| <tr><td> |
| <input id="cloneAppOKButton" type="submit" class="graybutton" style="font-weight: bold;" value="Clone" title="Clone the app"/> |
| <input id="cloneAppCancelButton" type="button" class="graybutton" value="Cancel"/> |
| </td></tr> |
| </table> |
| </form> |
| |
| <script type="text/javascript"> |
| |
| // Get the app name |
| var appname = ui.fragmentParams(location)['app']; |
| |
| /** |
| * Return the link to an app. |
| */ |
| function applink(appname) { |
| var protocol = location.protocol; |
| var host = location.hostname; |
| var port = ':' + location.port; |
| if (port == ':80' || port == ':443' || port == ':') |
| port = ''; |
| var link = protocol + '//' + appname + '.' + host + port + '/'; |
| return link; |
| } |
| |
| // Set page titles |
| var tclone = isNil(config.clone)? 'Clone' : config.clone; |
| document.title = ui.windowtitle(location.hostname) + ' - ' + tclone + ' - ' + appname; |
| $('appNameHeader').innerHTML = '<a href=\"' + applink(appname) + '\" target=\"' + '_blank' + '\">' + appname + '</a>'; |
| $('th').innerHTML = tclone + ' this App'; |
| $('cloneAppOKButton').value = tclone; |
| $('cloneAppOKButton').title = tclone + ' this app'; |
| |
| // Set images |
| $('appimg').src = ui.b64img(appcache.get('/public/app.b64')); |
| |
| // Init form |
| $('appDomain').innerHTML = '.' + location.hostname; |
| |
| // Init service references |
| var editWidget = sca.component("EditWidget"); |
| var dashboards = sca.reference(editWidget, "dashboards"); |
| var apps = sca.reference(editWidget, "apps"); |
| |
| /** |
| * The current app entry and corresponding saved XML content. |
| */ |
| var appentry; |
| var savedappentryxml = ''; |
| |
| /** |
| * Get and display an app. |
| */ |
| function getapp(name) { |
| if (isNil(name)) |
| return false; |
| return apps.get(name, function(doc) { |
| |
| // Stop now if we didn't get the app |
| if (doc == null) |
| return false; |
| |
| appentry = doc != null? car(elementsToValues(atom.readATOMEntry(mklist(doc)))) : mklist("'entry", mklist("'title", ''), mklist("'id", name)); |
| var title = cadr(assoc("'title", cdr(appentry))); |
| $('appTitle').value = title; |
| $('appDescription').innerHTML = ''; |
| savedappentryxml = car(atom.writeATOMEntry(valuesToElements(mklist(appentry)))); |
| return true; |
| }); |
| } |
| |
| /** |
| * Clone an app. |
| */ |
| $('cloneAppForm').onsubmit = function() { |
| var name = $('appName').value; |
| if (name == '') |
| return false; |
| |
| // Clone the app |
| var title = $('appTitle').value; |
| var app = mklist(mklist("'entry", mklist("'title", title != ''? title : name), mklist("'id", appname))); |
| var entry = atom.writeATOMEntry(valuesToElements(app)); |
| dashboards.put(name, car(entry), function(e) { |
| if (e) |
| return false; |
| |
| // Open it in the page editor |
| ui.navigate('/#view=page&app=' + name, '_view'); |
| return false; |
| }); |
| return false; |
| }; |
| |
| /** |
| * Cancel cloning an app. |
| */ |
| $('cloneAppCancelButton').onclick = function() { |
| history.back(); |
| }; |
| |
| // Get the current app |
| getapp(appname); |
| |
| </script> |
| |
| </div> |