overleaf/services/web/public/coffee/ide.coffee

225 lines
6.8 KiB
CoffeeScript
Raw Normal View History

2014-02-12 10:23:40 +00:00
define [
"base"
"ide/file-tree/FileTreeManager"
"ide/connection/ConnectionManager"
"ide/editor/EditorManager"
"ide/online-users/OnlineUsersManager"
"ide/history/HistoryManager"
"ide/permissions/PermissionsManager"
"ide/pdf/PdfManager"
"ide/binary-files/BinaryFilesManager"
"ide/references/ReferencesManager"
"ide/labels/LabelsManager"
"ide/review-panel/ReviewPanelManager"
2016-07-29 16:24:55 +00:00
"ide/SafariScrollPatcher"
2017-09-27 15:35:28 +00:00
"ide/AutoCompileOnboardingController",
"ide/LinkSharingOnboardingController",
"ide/settings/index"
"ide/share/index"
"ide/chat/index"
2014-07-17 13:04:21 +00:00
"ide/clone/index"
2014-07-22 13:38:32 +00:00
"ide/hotkeys/index"
2015-09-14 14:28:19 +00:00
"ide/wordcount/index"
"ide/directives/layout"
"ide/services/ide"
"__IDE_CLIENTSIDE_INCLUDES__"
2014-09-02 12:19:59 +00:00
"analytics/AbTestingManager"
"directives/focus"
"directives/fineUpload"
2014-07-08 11:32:50 +00:00
"directives/scroll"
"directives/onEnter"
"directives/stopPropagation"
"directives/rightClick"
"directives/expandableTextArea"
"directives/videoPlayState"
"services/queued-http"
"filters/formatDate"
2015-03-17 19:14:55 +00:00
"main/event"
"main/account-upgrade"
2014-02-12 10:23:40 +00:00
], (
App
FileTreeManager
ConnectionManager
EditorManager
OnlineUsersManager
HistoryManager
PermissionsManager
PdfManager
BinaryFilesManager
ReferencesManager
LabelsManager
ReviewPanelManager
2016-07-29 16:24:55 +00:00
SafariScrollPatcher
2014-02-12 10:23:40 +00:00
) ->
2017-06-12 08:44:32 +00:00
App.controller "IdeController", ($scope, $timeout, ide, localStorage, sixpack, event_tracking, labels) ->
# Don't freak out if we're already in an apply callback
$scope.$originalApply = $scope.$apply
$scope.$apply = (fn = () ->) ->
phase = @$root.$$phase
if (phase == '$apply' || phase == '$digest')
fn()
else
this.$originalApply(fn);
$scope.state = {
loading: true
load_progress: 40
error: null
}
$scope.ui = {
leftMenuShown: false
view: "editor"
chatOpen: false
2014-07-22 12:33:01 +00:00
pdfLayout: 'sideBySide'
2017-09-25 14:46:29 +00:00
pdfHidden: false,
2017-09-28 10:31:55 +00:00
pdfWidth: 0,
reviewPanelOpen: localStorage("ui.reviewPanelOpen.#{window.project_id}"),
2017-09-26 13:50:45 +00:00
miniReviewPanelVisible: false,
}
$scope.onboarding = {
autoCompile: if window.showAutoCompileOnboarding then 'unseen' else 'dismissed'
linkSharing: if window.showLinkSharingOnboarding then 'unseen' else 'dismissed'
}
$scope.user = window.user
2017-09-25 14:46:29 +00:00
$scope.shouldABTestPlans = false
2016-10-27 08:41:51 +00:00
if $scope.user.signUpDate >= '2016-10-27'
$scope.shouldABTestPlans = true
$scope.settings = window.userSettings
2014-07-21 10:56:49 +00:00
$scope.anonymous = window.anonymous
2017-10-25 09:34:18 +00:00
$scope.isTokenMember = window.isTokenMember
$scope.chat = {}
2014-09-01 16:48:09 +00:00
ide.toggleReviewPanel = $scope.toggleReviewPanel = () ->
if !$scope.project.features.trackChangesVisible
return
2016-10-11 13:24:01 +00:00
$scope.ui.reviewPanelOpen = !$scope.ui.reviewPanelOpen
2017-01-17 14:39:31 +00:00
event_tracking.sendMB "rp-toggle-panel", { value : $scope.ui.reviewPanelOpen }
$scope.$watch "ui.reviewPanelOpen", (value) ->
if value?
localStorage "ui.reviewPanelOpen.#{window.project_id}", value
2017-09-25 14:46:29 +00:00
$scope.$on "layout:pdf:resize", (_, layoutState) ->
$scope.ui.pdfHidden = layoutState.east.initClosed
2017-09-28 10:31:55 +00:00
$scope.ui.pdfWidth = layoutState.east.size
2017-09-25 14:46:29 +00:00
2016-07-05 14:07:16 +00:00
# Tracking code.
$scope.$watch "ui.view", (newView, oldView) ->
if newView? and newView != "editor" and newView != "pdf"
event_tracking.sendMBOnce "ide-open-view-#{ newView }-once"
2016-07-05 14:07:16 +00:00
$scope.$watch "ui.chatOpen", (isOpen) ->
2016-08-10 16:29:43 +00:00
event_tracking.sendMBOnce "ide-open-chat-once" if isOpen
2016-07-05 14:07:16 +00:00
$scope.$watch "ui.leftMenuShown", (isOpen) ->
2016-08-10 16:29:43 +00:00
event_tracking.sendMBOnce "ide-open-left-menu-once" if isOpen
2016-08-03 11:17:19 +00:00
$scope.trackHover = (feature) ->
2016-08-10 16:29:43 +00:00
event_tracking.sendMBOnce "ide-hover-#{feature}-once"
2016-07-05 14:07:16 +00:00
# End of tracking code.
window._ide = ide
ide.validFileRegex = '^[^\*\/]*$' # Don't allow * and /
ide.project_id = $scope.project_id = window.project_id
ide.$scope = $scope
ide.referencesSearchManager = new ReferencesManager(ide, $scope)
ide.connectionManager = new ConnectionManager(ide, $scope)
ide.fileTreeManager = new FileTreeManager(ide, $scope)
ide.editorManager = new EditorManager(ide, $scope)
ide.onlineUsersManager = new OnlineUsersManager(ide, $scope)
ide.historyManager = new HistoryManager(ide, $scope)
ide.pdfManager = new PdfManager(ide, $scope)
ide.permissionsManager = new PermissionsManager(ide, $scope)
ide.binaryFilesManager = new BinaryFilesManager(ide, $scope)
ide.labelsManager = new LabelsManager(ide, $scope, labels)
2014-07-24 15:39:32 +00:00
inited = false
$scope.$on "project:joined", () ->
return if inited
inited = true
if $scope?.project?.deletedByExternalDataSource
2014-07-24 15:39:32 +00:00
ide.showGenericMessageModal("Project Renamed or Deleted", """
This project has either been renamed or deleted by an external data source such as Dropbox.
We don't want to delete your data on ShareLaTeX, so this project still contains your history and collaborators.
If the project has been renamed please look in your project list for a new project under the new name.
""")
$timeout(
() ->
if $scope.permissions.write
ide.labelsManager.loadProjectLabelsFromServer()
_labelsInitialLoadDone = true
, 200
)
# Count the first 'doc:opened' as a sign that the ide is loaded
# and broadcast a message. This is a good event to listen for
# if you want to wait until the ide is fully loaded and initialized
_loaded = false
$scope.$on 'doc:opened', () ->
if _loaded
return
$scope.$broadcast('ide:loaded')
_loaded = true
DARK_THEMES = [
"ambiance", "chaos", "clouds_midnight", "cobalt", "idle_fingers",
"merbivore", "merbivore_soft", "mono_industrial", "monokai",
"pastel_on_dark", "solarized_dark", "terminal", "tomorrow_night",
"tomorrow_night_blue", "tomorrow_night_bright", "tomorrow_night_eighties",
"twilight", "vibrant_ink"
]
$scope.darkTheme = false
$scope.$watch "settings.theme", (theme) ->
if theme in DARK_THEMES
$scope.darkTheme = true
else
$scope.darkTheme = false
ide.localStorage = localStorage
ide.browserIsSafari = false
try
userAgent = navigator.userAgent
ide.browserIsSafari = (
userAgent &&
userAgent.match(/.*Safari\/.*/) &&
!userAgent.match(/.*Chrome\/.*/) &&
!userAgent.match(/.*Chromium\/.*/)
)
catch err
console.error err
2016-07-29 16:24:55 +00:00
if ide.browserIsSafari
2016-08-01 10:12:50 +00:00
ide.safariScrollPatcher = new SafariScrollPatcher($scope)
2016-07-29 16:24:55 +00:00
# Fix Chrome 61 and 62 text-shadow rendering
browserIsChrome61or62 = false
try
chromeVersion = parseFloat(navigator.userAgent.split(" Chrome/")[1]) || null;
browserIsChrome61or62 = (
chromeVersion? &&
(chromeVersion == 61 || chromeVersion == 62)
)
if browserIsChrome61or62
document.styleSheets[0].insertRule(".ace_editor.ace_autocomplete .ace_completion-highlight { text-shadow: none !important; }", 1)
catch err
console.error err
2016-04-19 10:53:27 +00:00
# User can append ?ft=somefeature to url to activate a feature toggle
ide.featureToggle = location?.search?.match(/^\?ft=(\w+)$/)?[1]
ide.socket.on 'project:publicAccessLevel:changed', (data) =>
if data.newAccessLevel?
ide.$scope.project.publicAccesLevel = data.newAccessLevel
$scope.$digest()
angular.bootstrap(document.body, ["SharelatexApp"])