extends ../layout block vars - var suppressNavbar = true - var suppressFooter = true - var suppressSystemMessages = true block content .editor(ng-controller="IdeController").full-size .loading-screen(ng-if="state.loading") .loading-screen-brand-container .loading-screen-brand( style="height: 20%;" ng-style="{ 'height': state.load_progress + '%' }" ) h3.loading-screen-label(ng-if="!state.error") #{translate("loading")} span.loading-screen-ellip . span.loading-screen-ellip . span.loading-screen-ellip . p.loading-screen-error(ng-if="state.error").ng-cloak span(ng-bind-html="state.error") .global-alerts(ng-cloak) .alert.alert-danger.small(ng-if="connection.forced_disconnect") strong #{translate("disconnected")} | #{translate("please_refresh")} .alert.alert-warning.small(ng-if="connection.reconnection_countdown") strong #{translate("lost_connection")}. | #{translate("reconnecting_in_x_secs", {seconds:"{{ connection.reconnection_countdown }}"})}. a#try-reconnect-now-button.alert-link-as-btn.pull-right(href, ng-click="tryReconnectNow()") #{translate("try_now")} .alert.alert-warning.small(ng-if="connection.reconnecting") strong #{translate("reconnecting")}... .alert.alert-warning.small(ng-if="connection.inactive_disconnect") strong #{translate("editor_disconected_click_to_reconnect")} .div(ng-controller="SavingNotificationController") .alert.alert-warning.small(ng-repeat="(doc_id, state) in docSavingStatus" ng-if="state.unsavedSeconds > 8") #{translate("saving_notification_with_seconds", {docname:"{{ state.doc.name }}", seconds:"{{ state.unsavedSeconds }}"})} include ./editor/left-menu #chat-wrapper.full-size( layout="chat", spacing-open="{{ui.chatResizerSizeOpen}}", spacing-closed="{{ui.chatResizerSizeClosed}}", initial-size-east="250", init-closed-east="true", open-east="ui.chatOpen", ng-hide="state.loading", ng-cloak ) .ui-layout-center include ./editor/header include ./editor/share != moduleIncludes("publish:body", locals) #ide-body( ng-cloak, layout="main", ng-hide="state.loading", resize-on="layout:chat:resize", minimum-restore-size-west="130" custom-toggler-pane=hasFeature('custom-togglers') ? "'west'" : "false" custom-toggler-msg-when-open=hasFeature('custom-togglers') ? "'" + translate("tooltip_hide_filetree") + "'" : "false" custom-toggler-msg-when-closed=hasFeature('custom-togglers') ? "'" + translate("tooltip_show_filetree") + "'" : "false" ) .ui-layout-west include ./editor/file-tree include ./editor/history-file-tree .ui-layout-center include ./editor/editor include ./editor/binary-file include ./editor/history include ./editor/publish-template .ui-layout-east include ./editor/chat include ./editor/hotkeys script(type="text/ng-template", id="genericMessageModalTemplate") .modal-header button.close( type="button" data-dismiss="modal" ng-click="done()" ) × h3 {{ title }} .modal-body(ng-bind-html="message") .modal-footer button.btn.btn-info(ng-click="done()") #{translate("ok")} script(type="text/ng-template", id="lockEditorModalTemplate") .modal-header h3 {{ title }} .modal-body(ng-bind-html="message") block requirejs script(type="text/javascript" src='/socket.io/socket.io.js') //- don't use cdn for workers - var aceWorkerPath = buildJsPath(lib('ace'), {cdn:false}) - var pdfWorkerPath = buildJsPath('/libs/' + lib('pdfjs') + '/pdf.worker', {cdn:false}) - var pdfCMapsPath = buildJsPath('/libs/' + lib('pdfjs') + '/bcmaps/', {cdn:false}) //- We need to do .replace(/\//g, '\\/') do that '' -> '<\/script>' //- and doesn't prematurely end the script tag. script#data(type="application/json"). !{JSON.stringify({userSettings: userSettings, user: user, trackChangesState: trackChangesState, useV2History: useV2History, enabledLinkedFileTypes: settings.enabledLinkedFileTypes}).replace(/\//g, '\\/')} script(type="text/javascript"). window.data = JSON.parse($("#data").text()); script(type='text/javascript'). window.project_id = "!{project_id}"; var data = JSON.parse($("#data").text()); window.userSettings = data.userSettings; window.user = data.user; window.enabledLinkedFiles = data.enabledLinkedFiles; window.csrfToken = "!{csrfToken}"; window.anonymous = #{anonymous}; window.anonymousAccessToken = "#{anonymousAccessToken}"; window.isTokenMember = #{!!isTokenMember}; window.maxDocLength = #{maxDocLength}; window.trackChangesState = data.trackChangesState; window.wikiEnabled = #{!!(settings.apis.wiki && settings.apis.wiki.url)}; window.requirejs = { "paths" : { "mathjax": "#{buildJsPath('/libs/mathjax/MathJax.js', {cdn:false, qs:{config:'TeX-AMS_HTML'}})}", "moment": "libs/#{lib('moment')}", "pdfjs-dist/build/pdf": "libs/#{lib('pdfjs')}/pdf", "pdfjs-dist/build/pdf.worker": "#{pdfWorkerPath}", "ace": "#{lib('ace')}", "fineuploader": "libs/#{lib('fineuploader')}", "ide": "#{buildJsPath('ide.js', {hashedPath:settings.useMinifiedJs, removeExtension:true})}", "libraries": "#{buildJsPath('libraries.js', {hashedPath:settings.useMinifiedJs, removeExtension:true})}", !{moduleIncludes("editor:script", locals)} !{moduleIncludes("publish:script", locals)} }, "waitSeconds": 0, "shim": { "pdfjs-dist/build/pdf": { "deps": ["libs/#{lib('pdfjs')}/compatibility"] }, "ace/ext-searchbox": { "deps": ["ace/ace"] }, "ace/ext-modelist": { "deps": ["ace/ace"] }, "ace/ext-language_tools": { "deps": ["ace/ace"] } }, "config":{ "moment":{ "noGlobal": true } } }; window.aceWorkerPath = "#{aceWorkerPath}"; window.pdfCMapsPath = "#{pdfCMapsPath}" window.uiConfig = JSON.parse('!{JSON.stringify(uiConfig).replace(/\//g, "\\/")}'); script( data-main=buildJsPath("ide.js", {hashedPath:false}), baseurl=fullJsPath, data-ace-base=buildJsPath(lib('ace')), src=buildJsPath('libs/require.js', {hashedPath:true}) )