overleaf/services/web/public/coffee/base.coffee

63 lines
2.8 KiB
CoffeeScript
Raw Normal View History

2014-06-17 11:43:42 +00:00
define [
"libraries"
2014-06-21 21:20:37 +00:00
"modules/recursionHelper"
"modules/errorCatcher"
"modules/localStorage"
"utils/underscore"
2014-06-17 11:43:42 +00:00
], () ->
App = angular.module("SharelatexApp", [
"ui.bootstrap"
"autocomplete"
2014-06-21 21:20:37 +00:00
"RecursionHelper"
2014-06-23 16:25:45 +00:00
"ng-context-menu"
"underscore"
"ngSanitize"
2014-08-13 15:04:23 +00:00
"ipCookie"
2015-10-27 10:58:27 +00:00
"mvdSixpack"
"ErrorCatcher"
"localStorage"
"ngTagsInput"
"ui.select"
]).config ($qProvider, sixpackProvider, $httpProvider, uiSelectConfig) ->
2017-07-03 10:19:13 +00:00
$qProvider.errorOnUnhandledRejections(false)
uiSelectConfig.spinnerClass = 'fa fa-refresh ui-select-spin'
2015-10-27 10:58:27 +00:00
sixpackProvider.setOptions({
2015-10-27 11:20:54 +00:00
debug: false
2015-10-27 10:58:27 +00:00
baseUrl: window.sharelatex.sixpackDomain
client_id: window.user_id
2015-10-27 10:58:27 +00:00
})
MathJax?.Hub?.Config(
extensions: ["Safe.js"]
messageStyle: "none"
imageFont:null
"HTML-CSS":
availableFonts: ["TeX"]
# MathJax's automatic font scaling does not work well when we render math
# that isn't yet on the page, so we disable it and set a global font
# scale factor
scale: 110
matchFontHeight: false
TeX:
equationNumbers: { autoNumber: "AMS" }
useLabelIDs: false
skipStartupTypeset: true
tex2jax:
processEscapes: true
# Dollar delimiters are added by the mathjax directive
inlineMath: [ ["\\(","\\)"] ]
displayMath: [ ['$$','$$'], ["\\[","\\]"] ]
)
App.run ($templateCache) ->
# UI Select templates are hard-coded and use Glyphicon icons (which we don't import).
# The line below simply overrides the hard-coded template with our own, which is
# basically the same but using Font Awesome icons.
$templateCache.put "bootstrap/match.tpl.html", "<div class=\"ui-select-match\" ng-hide=\"$select.open && $select.searchEnabled\" ng-disabled=\"$select.disabled\" ng-class=\"{\'btn-default-focus\':$select.focus}\"><span tabindex=\"-1\" class=\"btn btn-default form-control ui-select-toggle\" aria-label=\"{{ $select.baseTitle }} activate\" ng-disabled=\"$select.disabled\" ng-click=\"$select.activate()\" style=\"outline: 0;\"><span ng-show=\"$select.isEmpty()\" class=\"ui-select-placeholder text-muted\">{{$select.placeholder}}</span> <span ng-hide=\"$select.isEmpty()\" class=\"ui-select-match-text pull-left\" ng-class=\"{\'ui-select-allow-clear\': $select.allowClear && !$select.isEmpty()}\" ng-transclude=\"\"></span> <i class=\"caret pull-right\" ng-click=\"$select.toggle($event)\"></i> <a ng-show=\"$select.allowClear && !$select.isEmpty() && ($select.disabled !== true)\" aria-label=\"{{ $select.baseTitle }} clear\" style=\"margin-right: 10px\" ng-click=\"$select.clear($event)\" class=\"btn btn-xs btn-link pull-right\"><i class=\"fa fa-times\" aria-hidden=\"true\"></i></a></span></div>"
sl_debugging = window.location?.search?.match(/debug=true/)?
window.sl_console =
log: (args...) -> console.log(args...) if sl_debugging
2014-06-17 11:43:42 +00:00
2014-11-25 16:00:21 +00:00
return App