Editor update: ui and functionality tweaks
[redakcja.git] / apps / wiki / templates / wiki / bootstrap.html
1 {% load staticfiles %}
2 {% load i18n %}
3
4 <!DOCTYPE html>
5 <html>
6     <head>
7         {% if RAVEN_CONFIG %}
8             <script src="http://cdn.ravenjs.com/1.1.7/jquery,native/raven.min.js"></script>
9             <script>
10                 Raven.config('{{RAVEN_CONFIG.SENTRY_URL}}', {{RAVEN_CONFIG.SETTINGS|default:'{}'}}).install();
11                 {% if request.user.is_authenticated %}
12                     Raven.setUser({
13                         name: '{{request.user.username}}',
14                         email: '{{request.user.email}}',
15                         id: {{request.user.id}}
16                     });
17                 {% endif %}
18             </script>
19         {% endif %}
20         <script src="{% url 'django.views.i18n.javascript_catalog' %}"></script>
21         <script src="http://cdnjs.cloudflare.com/ajax/libs/ace/1.1.01/ace.js" type="text/javascript" charset="utf-8"></script>
22         
23         {% if DEBUG %}
24             <link rel="stylesheet/less" type="text/css" href="{% static 'wiki/editor/src/editor/styles/main.less' %}"/>
25             <script type="text/javascript">less = {relativeUrls: true};</script>
26             <script src="{% static 'wiki/editor/libs/less-1.3.3.min.js' %}"></script>
27             <script src="{% static 'wiki/editor/libs/require.js' %}" data-main="{% static 'wiki/editor/src/editor/entrypoint.js' %}" ></script>
28         {% else %}
29             <link href="{% static 'wiki/build/rng.css' %}" rel="stylesheet">
30             <script src="{% static 'wiki/build/rng.js' %}"></script>
31         {% endif %}
32     </head>
33     <body>
34         <script type="text/javascript">
35
36             var config = {
37                 rootSelector: '#editor_root',
38                 jsonifySentPayload: false,
39
40                 {% if request.user.is_authenticated %}
41                 user: {
42                     name: '{{request.user.username}}',
43                     email: '{{request.user.email}}',
44                     id: {{request.user.id}}
45                 },
46                 {% endif %}
47
48                 logging: {
49                     handlers: {
50                         'sentry': {
51                             level: 'info',
52                             handler: 'raven',
53                             formatter: 'noop'
54                         },
55                         'console': {
56                             level: 'debug',
57                             handler: 'console'
58                         }
59                     },
60                     loggers: {
61                         '': {
62                             level: 'debug',
63                             handlers: ['sentry', 'console']
64                         }
65                     }
66                 },
67
68                 metadataKeys: [
69                     'creator.expert',
70                     'creator.scenario',
71                     'creator.textbook',
72                     'title',
73                     'relation.isPartOf',
74                     'publisher',
75                     'subject.competence',
76                     'subject.curriculum',
77                     'subject',
78                     'description',
79                     'description.material',
80                     'identifier.url',
81                     'rights',
82                     'rights.license',
83                     'format',
84                     'type',
85                     'date',
86                     'audience'
87                 ],
88
89                 documentSummaryView: {
90                     title: '{% trans 'Informations about lesson' %}',
91                     properties: [
92                         {name: 'stage', label: '{% trans 'Stage' %}'},
93                         {name: 'assignment', label: '{% trans 'Assignment' %}'}
94                     ]
95                 },
96                 
97                 documentSaveUrl: function(id) { return '/editor/text/' + id + '/'; },
98                 documentHistoryUrl: function(id) { return '/editor/history/' + id + '/'},
99                 documentDiffUrl: function(id) { return '/editor/diff/' + id + '/'; },
100                 documentRestoreUrl: function(id) { return '/editor/revert/' + id + '/'},
101
102                 documentSaveForm: {
103                     fields: [
104                         {label: '{{forms.text_save.comment.label}}', name: '{{forms.text_save.comment.html_name}}', type: 'textarea'},
105                         {label: '{{forms.text_save.stage_completed.label}}', name: '{{forms.text_save.stage_completed.html_name}}', type: 'select', options: [
106                             {% for value,text in tags %}
107                                 {value:'{{value|default:''}}', text:'{{text}}'} {% if not forloop.last %}, {% endif %}
108                             {% endfor %}
109                         ], description: '{{forms.text_save.stage_completed.help_text}}'},
110                     ],
111                     content_field_name: '{{forms.text_save.text.html_name}}',
112                     version_field_name: '{{forms.text_save.parent_revision.html_name}}'
113                 },
114
115                 documentRestoreForm: {
116                     fields: [
117                         {label: '{{forms.text_revert.comment.label}}', name: '{{forms.text_revert.comment.html_name}}', type: 'textarea'}
118                     ],
119                     version_field_name: '{{forms.text_revert.revision.html_name}}'
120                 }
121             };
122
123             {% if can_pubmark %}
124                 config.documentSaveForm.fields.push(
125                     {label: '{{forms.text_save.publishable.label}}', name: '{{forms.text_save.publishable.html_name}}', type: 'checkbox', description: '{{forms.text_save.publishable.help_text}}'}
126                 );
127             {% endif %}
128
129             {% if not request.user.is_authenticated %}
130                 config.documentSaveForm.fields.push(
131                     {label: '{{forms.text_save.author_name.label}}', name: '{{forms.text_save.author_name.html_name}}', type: 'input', description: '{{forms.text_save.author_name.help_text}}'},
132                     {label: '{{forms.text_save.author_email.label}}', name: '{{forms.text_save.author_email.html_name}}', type: 'input', description: '{{forms.text_save.author_email.help_text}}'}
133                 );
134
135                 config.documentRestoreForm.fields.push(
136                     {label: '{{forms.text_revert.author_name.label}}', name: '{{forms.text_revert.author_name.html_name}}', type: 'input', description: '{{forms.text_revert.author_name.help_text}}'},
137                     {label: '{{forms.text_revert.author_email.label}}', name: '{{forms.text_revert.author_email.html_name}}', type: 'input', description: '{{forms.text_revert.author_email.help_text}}'}
138                 );
139             {% endif %}
140
141             {% autoescape off%}
142             var data = {{serialized_document_data}},
143                 templates = {{serialized_templates}}
144             {%endautoescape%}
145
146             var editor_init = function(Editor) {            
147                 Editor.setBootstrappedData('data', data);
148                 Editor.setBootstrappedData('documentToolbar', templates);
149                 Editor.start(config);
150             };
151         </script>
152         <div id="editor_root"></div>
153     </body>
154 </html>