summaryrefslogtreecommitdiffstats
path: root/sca-cpp/trunk/hosting/server/htdocs/create/index.html
blob: 6097053cd6e7519055357b16eebebdb442ff703e (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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
<!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></h2></td>
<td style="vertical-align: middle; text-align: right;"><span id="status" style="font-weight: bold; color: #808080;"></span></td>
</tr>
</table>

<table style="width: 100%;">
<tr>
<th class="thl thr" style="padding-top: 4px; padding-bottom:4px;">Create an App</th>
</tr>
</table>

<form id="createAppForm">
<table style="width: 100%;">
<tr><td><b>App Name:</b></td></tr>
<tr><td><input type="text" id="appName" size="15" autocapitalize="off" placeholder="Your app name"/></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="createAppOKButton" type="submit" class="graybutton" style="font-weight: bold;" value="Create" title="Create the app"/>
<input id="createAppCancelButton" type="button" class="graybutton" value="Cancel"/>
</td></tr>
</table>
</form>

<script type="text/javascript">

// Set page titles
document.title = ui.windowtitle(location.hostname) + ' - Create App';
$('h1').innerHTML = ui.hometitle(location.hostname);

// Set images
$('appimg').src = ui.b64img(appcache.get('/public/app.b64'));

// Init service references
var editWidget = sca.component("EditWidget");
var dashboards = sca.reference(editWidget, "dashboards");
var apps = sca.reference(editWidget, "apps");

/**
 * Create an app.
 */
$('createAppForm').onsubmit = function() {
    var name = $('appName').value;
    if (name == '')
        return false;
    showStatus('Saving');

    // Clone the '.new' app template
    var title = $('appTitle').value;
    var app = mklist(mklist("'entry", mklist("'title", title != ''? title : name), mklist("'id", 'new')));
    var entry = atom.writeATOMEntry(valuesToElements(app));
    dashboards.put(name, car(entry), function(e) {
        if (e) {
            showStatus('Local copy');
            return false;
        }
        showStatus('Saved');

        // Open it in the page editor
        ui.navigate('/#view=page&app=' + name, '_view');
        return false;
    });
    return false;
};

/**
 * Cancel creating an app.
 */
$('createAppCancelButton').onclick = function() {
    history.back();
};

showStatus(defaultStatus());

</script>

</div>