/* This file is part of CPEE. CPEE is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. CPEE is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with CPEE (file COPYING in the main directory). If not, see . */ function ui_click_tab(moi) { // {{{ $(moi).trigger('click'); } // }}} function ui_close_tab(moi){ var active = $(moi).parent().attr('data-tab'); var tabbed = $(moi).parent().parent().parent(); var is_inactive = $(moi).parent().hasClass('inactive'); $('*[data-tab=' + active + ']').remove(); $('*[data-belongs-to-tab=' + active + ']').remove(); if (!is_inactive) ui_click_tab($('ui-tabbar ui-tab.default')); } function ui_add_close(moi) { $(moi).append($('')); } function ui_empty_tab_contents(id) { $('ui-content ui-area[data-belongs-to-tab=' + id + ']').empty(); } function ui_add_tab(tabbed,title,id,closeable,additionalclasses) { additionalclasses = typeof additionalclasses !== 'undefined' ? additionalclasses : ''; if ($('ui-tabbar ui-tab[data-tab=' + id + ']').length > 0) { ui_activate_tab($('ui-tabbar ui-tab[data-tab=' + id + ']')); return false; } else { var instab = $("" + title + ""); var insarea = $(""); $(tabbed).find('ui-behind').before(instab); $(tabbed).find('ui-content').append(insarea); ui_add_close($('ui-tabbar ui-tab[data-tab=' + id + ']')); return true; } } function create_new_tab(title, id) { console.log(title,id); var theDiv = document.getElementById(id); var content = document.createTextNode(id); var content = document.createTextNode(id); var newElement = document.createElement('div'); newElement.setAttribute('id', id); newElement.innerHTML = ""; theDiv.appendChild(content); theDiv.appendChild(newElement); return true; } function ui_add_tab_active(tabbed,title,id,closeable,additionalclasses) { var state = ui_add_tab(tabbed,title,id,closeable,additionalclasses); if (state) { create_new_tab(title, id); } if (state) { ui_activate_tab($('ui-tabbar ui-tab[data-tab=' + id + ']')); } return state; } function ui_clone_tab(tabbar,original,title,id,closeable,additionalclasses) { additionalclasses = typeof additionalclasses !== 'undefined' ? additionalclasses : ''; var instab = $("" + title + ""); var insarea = original.clone(); insarea.attr("data-belongs-to-tab",id); insarea.attr("class","inactive"); $(tabbar).find('ui-behind').before(instab); $(tabbar).parent().append(insarea); ui_add_close($('ui-tabbed ui-tab[data-tab=' + id + ']')); } (function($) { //{{{ $.fn.dragcolumn = function() { var drag = $(this); var prev = drag.prev(); var next = drag.next(); this.on("mousedown", function(e) { drag.addClass('draggable'); $(document).one("mouseup", function(e) { drag.removeClass('draggable'); e.preventDefault(); }); e.preventDefault(); }); $(document).on("mousemove", function(e) { if (!drag.hasClass('draggable')) return; // Assume 50/50 split between prev and next then adjust to // the next X for prev var total = prev.outerWidth() + next.outerWidth(); var pos = e.pageX - prev.offset().left; if (pos > total) { pos = total; } var leftPercentage = pos / total; var rightPercentage = 1 - leftPercentage; prev.css('flex', leftPercentage.toString()); next.css('flex', rightPercentage.toString()); e.preventDefault(); }); } $.fn.dragresize = function() { var drag = $(this); var prev = drag.prev(); var initpos = 0; var initheight = $("ui-content",prev).height(); this.on("mousedown", function(e) { drag.addClass('draggable'); initpos = e.pageY; $(document).one("mouseup", function(e) { drag.removeClass('draggable'); e.preventDefault(); }); e.preventDefault(); }); $(document).on("mousemove", function(e) { if (!drag.hasClass('draggable')) return; var pos = initheight - (initpos - e.pageY); if (pos < 0) return; $("ui-content",prev).css('height', pos.toString()); e.preventDefault(); }); } })(jQuery); //}}} function ui_activate_tab(moi) { // {{{ var active = $(moi).attr('data-tab'); var tabbed = $(moi).parent().parent(); var tabs = []; $("ui-tabbar > ui-tab",tabbed).each(function(){ if (!$(this).attr('class').match(/switch/)) { tabs.push($(this).attr('data-tab')); } }); $(".inactive",tabbed).removeClass("inactive"); $.each(tabs,function(a,b){ if (b != active) { $("ui-tabbar ui-tab[data-tab=" + b + "]",tabbed).addClass("inactive"); $("ui-content *[data-belongs-to-tab=" + b + "]",tabbed).addClass("inactive"); } }); } // }}} function ui_toggle_vis_tab(moi) {// {{{ if ($(moi)[0].nodeName == 'UI-TABBED') { var tabbed = $(moi); } if ($(moi)[0].nodeName == 'UI-TAB') { var tabbed = $(moi).parent().parent(); } if (tabbed) { tabbed.toggleClass('off'); } }// }}} $(document).ready(function() { if (!($.browser.name == "Firefox" && $.browser.version >= 20) && !($.browser.name == "Chrome" && $.browser.version >= 30)) { $('body').children().remove(); $('body').append('Sorry, only Firefox >= 20.0 and Chrom(e|ium) >= 17 for now.'); } $('ui-rest ui-content ui-resizehandle').dragcolumn(); $('*[is=x-ui] > ui-resizehandle').dragresize(); $(document).on('click','ui-tabbar ui-tab.switch',function(){ui_toggle_vis_tab(this);}); $(document).on('click','ui-tabbar ui-tab:not(.switch)',function(){ui_activate_tab(this);}); ui_add_close($('ui-tabbar ui-tab.closeable')); $(document).on('click','ui-tabbar ui-tab.closeable ui-close',function(){ui_close_tab(this);}); });