function App() { this.markdown = new Markdown(); this.sidebar = new Sidebar(); this.search = new Search(); this.swimlane = new Swimlane(); this.dropdown = new Dropdown(); this.tooltip = new Tooltip(this); this.popover = new Popover(this); this.keyboardShortcuts(); this.chosen(); this.poll(); // Alert box fadeout $(".alert-fade-out").delay(4000).fadeOut(800, function() { $(this).remove(); }); // Reload page when a destination project is changed var reloading_project = false; $("select.task-reload-project-destination").change(function() { if (! reloading_project) { $(".loading-icon").show(); reloading_project = true; window.location = $(this).data("redirect").replace(/PROJECT_ID/g, $(this).val()); } }); } App.prototype.listen = function() { this.popover.listen(); this.markdown.listen(); this.sidebar.listen(); this.tooltip.listen(); this.dropdown.listen(); this.search.listen(); this.search.focus(); this.taskAutoComplete(); this.datePicker(); this.focus(); }; App.prototype.refresh = function() { $(document).off(); this.listen(); }; App.prototype.focus = function() { // Autofocus fields (html5 autofocus works only with page onload) $("[autofocus]").each(function(index, element) { $(this).focus(); }) // Auto-select input fields $(document).on('focus', '.auto-select', function() { $(this).select(); }); // Workaround for chrome $(document).on('mouseup', '.auto-select', function(e) { e.preventDefault(); }); }; App.prototype.poll = function() { window.setInterval(this.checkSession, 60000); }; App.prototype.keyboardShortcuts = function() { var self = this; // Submit form Mousetrap.bindGlobal("mod+enter", function() { $("form").submit(); }); // Open board selector Mousetrap.bind("b", function(e) { e.preventDefault(); $('#board-selector').trigger('chosen:open'); }); // Close popover and dropdown Mousetrap.bindGlobal("esc", function() { self.popover.close(); self.dropdown.close(); }); }; App.prototype.checkSession = function() { if (! $(".form-login").length) { $.ajax({ cache: false, url: $("body").data("status-url"), statusCode: { 401: function() { window.location = $("body").data("login-url"); } } }); } }; App.prototype.datePicker = function() { // Datepicker translation $.datepicker.setDefaults($.datepicker.regional[$("body").data("js-lang")]); // Datepicker $(".form-date").datepicker({ showOtherMonths: true, selectOtherMonths: true, dateFormat: 'yy-mm-dd', constrainInput: false }); // Datetime picker $(".form-datetime").datetimepicker({ controlType: 'select', oneLine: true, dateFormat: 'yy-mm-dd', // timeFormat: 'h:mm tt', constrainInput: false }); }; App.prototype.taskAutoComplete = function() { // Task auto-completion if ($(".task-autocomplete").length) { if ($('.opposite_task_id').val() == '') { $(".task-autocomplete").parent().find("input[type=submit]").attr('disabled','disabled'); } $(".task-autocomplete").autocomplete({ source: $(".task-autocomplete").data("search-url"), minLength: 1, select: function(event, ui) { var field = $(".task-autocomplete").data("dst-field"); $("input[name=" + field + "]").val(ui.item.id); $(".task-autocomplete").parent().find("input[type=submit]").removeAttr('disabled'); } }); } }; App.prototype.chosen = function() { $(".chosen-select").chosen({ width: "180px", no_results_text: $(".chosen-select").data("notfound"), disable_search_threshold: 10 }); $(".select-auto-redirect").change(function() { var regex = new RegExp($(this).data('redirect-regex'), 'g'); window.location = $(this).data('redirect-url').replace(regex, $(this).val()); }); }; App.prototype.showLoadingIcon = function() { $("body").append(' '); }; App.prototype.hideLoadingIcon = function() { $("#app-loading-icon").remove(); }; App.prototype.isVisible = function() { var property = ""; if (typeof document.hidden !== "undefined") { property = "visibilityState"; } else if (typeof document.mozHidden !== "undefined") { property = "mozVisibilityState"; } else if (typeof document.msHidden !== "undefined") { property = "msVisibilityState"; } else if (typeof document.webkitHidden !== "undefined") { property = "webkitVisibilityState"; } if (property != "") { return document[property] == "visible"; } return true; }; App.prototype.formatDuration = function(d) { if (d >= 86400) { return Math.round(d/86400) + "d"; } else if (d >= 3600) { return Math.round(d/3600) + "h"; } else if (d >= 60) { return Math.round(d/60) + "m"; } return d + "s"; };