mirror of
https://github.com/salesagility/SuiteCRM.git
synced 2024-11-22 16:02:36 +00:00
277 lines
12 KiB
Smarty
277 lines
12 KiB
Smarty
{*
|
|
/**
|
|
*
|
|
* SugarCRM Community Edition is a customer relationship management program developed by
|
|
* SugarCRM, Inc. Copyright (C) 2004-2013 SugarCRM Inc.
|
|
*
|
|
* SuiteCRM is an extension to SugarCRM Community Edition developed by SalesAgility Ltd.
|
|
* Copyright (C) 2011 - 2018 SalesAgility Ltd.
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it under
|
|
* the terms of the GNU Affero General Public License version 3 as published by the
|
|
* Free Software Foundation with the addition of the following permission added
|
|
* to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
|
|
* IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY
|
|
* OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
|
|
*
|
|
* This program 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 Affero General Public License for more
|
|
* details.
|
|
*
|
|
* You should have received a copy of the GNU Affero General Public License along with
|
|
* this program; if not, see http://www.gnu.org/licenses or write to the Free
|
|
* Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
|
|
* 02110-1301 USA.
|
|
*
|
|
* You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road,
|
|
* SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com.
|
|
*
|
|
* The interactive user interfaces in modified source and object code versions
|
|
* of this program must display Appropriate Legal Notices, as required under
|
|
* Section 5 of the GNU Affero General Public License version 3.
|
|
*
|
|
* In accordance with Section 7(b) of the GNU Affero General Public License version 3,
|
|
* these Appropriate Legal Notices must retain the display of the "Powered by
|
|
* SugarCRM" logo and "Supercharged by SuiteCRM" logo. If the display of the logos is not
|
|
* reasonably feasible for technical reasons, the Appropriate Legal Notices must
|
|
* display the words "Powered by SugarCRM" and "Supercharged by SuiteCRM".
|
|
*/
|
|
|
|
|
|
*}
|
|
{{sugar_include type="smarty" file=$headerTpl}}
|
|
{sugar_include include=$includes}
|
|
<div id="EditView_tabs">
|
|
{*display tabs*}
|
|
{{counter name="tabCount" start=-1 print=false assign="tabCount"}}
|
|
<ul class="nav nav-tabs">
|
|
{{if $useTabs}}
|
|
{{foreach name=section from=$sectionPanels key=label item=panel}}
|
|
{{capture name=label_upper assign=label_upper}}{{$label|upper}}{{/capture}}
|
|
{* if tab *}
|
|
{{if (isset($tabDefs[$label_upper].newTab) && $tabDefs[$label_upper].newTab == true)}}
|
|
{*if tab display*}
|
|
{{counter name="tabCount" print=false}}
|
|
{{if $tabCount == '0'}}
|
|
<li role="presentation" class="active">
|
|
<a id="tab{{$tabCount}}" data-toggle="tab" class="hidden-xs">
|
|
{sugar_translate label='{{$label}}' module='{{$module}}'}
|
|
</a>
|
|
{* Count Tabs *}
|
|
{{counter name="tabCountOnlyXS" start=-1 print=false assign="tabCountOnlyXS"}}
|
|
{{foreach name=sectionOnlyXS from=$sectionPanels key=labelOnly item=panelOnlyXS}}
|
|
{{capture name=label_upper_count_only assign=label_upper_count_only}}{{$labelOnly|upper}}{{/capture}}
|
|
{{if (isset($tabDefs[$label_upper_count_only].newTab) && $tabDefs[$label_upper_count_only].newTab == true)}}
|
|
{{counter name="tabCountOnlyXS" print=false}}
|
|
{{/if}}
|
|
{{/foreach}}
|
|
|
|
{*
|
|
For the mobile view, only show the first tab has a drop down when:
|
|
* There is more than one tab set
|
|
* When Acton Menu's are enabled
|
|
*}
|
|
<!-- Counting Tabs {{$tabCountOnlyXS}}-->
|
|
<a id="xstab{{$tabCount}}" href="#" class="visible-xs first-tab{{if $tabCountOnlyXS > 0}}-xs{{/if}} dropdown-toggle" data-toggle="dropdown">
|
|
{sugar_translate label='{{$label}}' module='{{$module}}'}
|
|
</a>
|
|
{{if $tabCountOnlyXS > 0}}
|
|
<ul id="first-tab-menu-xs" class="dropdown-menu">
|
|
{{counter name="tabCountXS" start=0 print=false assign="tabCountXS"}}
|
|
{{foreach name=sectionXS from=$sectionPanels key=label item=panelXS}}
|
|
{{capture name=label_upper_xs assign=label_upper_xs}}{{$label|upper}}{{/capture}}
|
|
{{if (isset($tabDefs[$label_upper_xs].newTab) && $tabDefs[$label_upper_xs].newTab == true)}}
|
|
<li role="presentation">
|
|
<a id="tab{{$tabCountXS}}" data-toggle="tab" onclick="changeFirstTab(this, 'tab-content-{{$tabCountXS}}');">
|
|
{sugar_translate label='{{$label}}' module='{{$module}}'}
|
|
</a>
|
|
</li>
|
|
{{counter name="tabCountXS" print=false}}
|
|
{{/if}}
|
|
{{/foreach}}
|
|
</ul>
|
|
{{/if}}
|
|
</li>
|
|
{{else}}
|
|
<li role="presentation" class="hidden-xs">
|
|
<a id="tab{{$tabCount}}" data-toggle="tab">
|
|
{sugar_translate label='{{$label}}' module='{{$module}}'}
|
|
</a>
|
|
</li>
|
|
{{/if}}
|
|
{{else}}
|
|
{* if panel skip*}
|
|
{{/if}}
|
|
{{/foreach}}
|
|
{{/if}}
|
|
|
|
</ul>
|
|
|
|
<div class="clearfix"></div>
|
|
{{if $useTabs}}
|
|
<div class="tab-content">
|
|
{{else}}
|
|
<div class="tab-content" style="padding: 0; border: 0;">
|
|
{{/if}}
|
|
{{counter name="tabCount" start=0 print=false assign="tabCount"}}
|
|
{* Loop through all top level panels first *}
|
|
{{if $useTabs}}
|
|
{{foreach name=section from=$sectionPanels key=label item=panel}}
|
|
{{capture name=label_upper assign=label_upper}}{{$label|upper}}{{/capture}}
|
|
{{if isset($tabDefs[$label_upper].newTab) && $tabDefs[$label_upper].newTab == true}}
|
|
{{if $tabCount == '0'}}
|
|
<div class="tab-pane-NOBOOTSTRAPTOGGLER active fade in" id='tab-content-{{$tabCount}}'>
|
|
{{include file='themes/SuiteP/include/EditView/tab_panel_content.tpl'}}
|
|
</div>
|
|
{{else}}
|
|
<div class="tab-pane-NOBOOTSTRAPTOGGLER fade" id='tab-content-{{$tabCount}}'>
|
|
{{include file='themes/SuiteP/include/EditView/tab_panel_content.tpl'}}
|
|
</div>
|
|
{{/if}}
|
|
{{counter name="tabCount" print=false}}
|
|
{{/if}}
|
|
{{/foreach}}
|
|
{{else}}
|
|
<div class="tab-pane panel-collapse"> </div>
|
|
{{/if}}
|
|
</div>
|
|
{*display panels*}
|
|
<div class="panel-content">
|
|
<div> </div>
|
|
{{counter name="tabCount" start=-1 print=false assign="tabCount"}}
|
|
{{counter name="panelCount" start=-1 print=false assign="panelCount"}}
|
|
{{foreach name=section from=$sectionPanels key=label item=panel}}
|
|
{{capture name=label_upper assign=label_upper}}{{$label|upper}}{{/capture}}
|
|
{* if tab *}
|
|
{{if (isset($tabDefs[$label_upper].newTab) && $tabDefs[$label_upper].newTab == true && $useTabs)}}
|
|
{{counter name="tabCount" print=false}}
|
|
{*if tab skip*}
|
|
{{else}}
|
|
{* if panel display*}
|
|
{*if panel collasped*}
|
|
{{if (isset($tabDefs[$label_upper].panelDefault) && $tabDefs[$label_upper].panelDefault == "collapsed") }}
|
|
{*collapse panel*}
|
|
{{assign var='collapse' value="panel-collapse collapse"}}
|
|
{{assign var='collapsed' value="collapsed"}}
|
|
{{assign var='collapseIcon' value="glyphicon glyphicon-plus"}}
|
|
{{assign var='panelHeadingCollapse' value="panel-heading-collapse"}}
|
|
{{else}}
|
|
{*expand panel*}
|
|
{{assign var='collapse' value="panel-collapse collapse in"}}
|
|
{{assign var='collapseIcon' value="glyphicon glyphicon-minus"}}
|
|
{{assign var='panelHeadingCollapse' value=""}}
|
|
{{/if}}
|
|
|
|
{{if $useTabs}}
|
|
{{if $tabCount == 0}}
|
|
<div class="panel panel-default tab-panel-{{$tabCount}}" style="display: block;">
|
|
{{else}}
|
|
<div class="panel panel-default tab-panel-{{$tabCount}}" style="display: none;">
|
|
{{/if}}
|
|
{{else}}
|
|
<div class="panel panel-default">
|
|
{{/if}}
|
|
<div class="panel-heading {{$panelHeadingCollapse}}">
|
|
<a class="{{$collapsed}}" role="button" data-toggle="collapse-edit" aria-expanded="false">
|
|
<div class="col-xs-10 col-sm-11 col-md-11">
|
|
{sugar_translate label='{{$label}}' module='{{$module}}'}
|
|
</div>
|
|
</a>
|
|
|
|
</div>
|
|
<div class="panel-body {{$collapse}} panelContainer" id="detailpanel_{{$panelCount}}" data-id="{{$label_upper}}">
|
|
<div class="tab-content">
|
|
{{include file='themes/SuiteP/include/EditView/tab_panel_content.tpl'}}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
{{/if}}
|
|
{{counter name="panelCount" print=false}}
|
|
{{/foreach}}
|
|
</div>
|
|
</div>
|
|
{{sugar_include type='smarty' file=$footerTpl}}
|
|
|
|
|
|
{{if $useTabs}}
|
|
{sugar_getscript file="cache/include/javascript/sugar_grp_yui_widgets.js"}
|
|
<script type="text/javascript">
|
|
var {{$form_name}}_tabs = new YAHOO.widget.TabView("{{$form_name}}_tabs");
|
|
{{$form_name}}_tabs.selectTab(0);
|
|
</script>
|
|
{{/if}}
|
|
<script type="text/javascript">
|
|
YAHOO.util.Event.onContentReady("{{$form_name}}",
|
|
function () {ldelim} initEditView(document.forms.{{$form_name}}) {rdelim});
|
|
//window.setTimeout(, 100);
|
|
{{if $module == "Users"}}
|
|
window.onbeforeunload = function () {ldelim} return disableOnUnloadEditView(); {rdelim};
|
|
{{else}}
|
|
window.onbeforeunload = function () {ldelim} return onUnloadEditView(); {rdelim};
|
|
{{/if}}
|
|
// bug 55468 -- IE is too aggressive with onUnload event
|
|
if ($.browser.msie) {ldelim}
|
|
$(document).ready(function() {ldelim}
|
|
$(".collapseLink,.expandLink").click(function (e) {ldelim} e.preventDefault(); {rdelim});
|
|
{rdelim});
|
|
{rdelim}
|
|
</script>
|
|
|
|
{literal}
|
|
|
|
<script type="text/javascript">
|
|
|
|
var selectTab = function(tab) {
|
|
$('#EditView_tabs div.tab-content div.tab-pane-NOBOOTSTRAPTOGGLER').hide();
|
|
$('#EditView_tabs div.tab-content div.tab-pane-NOBOOTSTRAPTOGGLER').eq(tab).show().addClass('active').addClass('in');
|
|
$('#EditView_tabs div.panel-content div.panel').hide();
|
|
$('#EditView_tabs div.panel-content div.panel.tab-panel-' + tab).show()
|
|
};
|
|
|
|
var selectTabOnError = function(tab) {
|
|
selectTab(tab);
|
|
$('#EditView_tabs ul.nav.nav-tabs li').removeClass('active');
|
|
$('#EditView_tabs ul.nav.nav-tabs li a').css('color', '');
|
|
|
|
$('#EditView_tabs ul.nav.nav-tabs li').eq(tab).find('a').first().css('color', 'red');
|
|
$('#EditView_tabs ul.nav.nav-tabs li').eq(tab).addClass('active');
|
|
|
|
};
|
|
|
|
var selectTabOnErrorInputHandle = function(inputHandle) {
|
|
var tab = $(inputHandle).closest('.tab-pane-NOBOOTSTRAPTOGGLER').attr('id').match(/^tab-content-(.*)$/)[1];
|
|
selectTabOnError(tab);
|
|
};
|
|
|
|
|
|
$(function(){
|
|
$('#EditView_tabs ul.nav.nav-tabs li > a[data-toggle="tab"]').click(function(e){
|
|
if(typeof $(this).parent().find('a').first().attr('id') != 'undefined') {
|
|
var tab = parseInt($(this).parent().find('a').first().attr('id').match(/^tab(?<number>(.)*)$/)[1]);
|
|
selectTab(tab);
|
|
}
|
|
});
|
|
|
|
$('a[data-toggle="collapse-edit"]').click(function(e){
|
|
if($(this).hasClass('collapsed')) {
|
|
// Expand panel
|
|
// Change style of .panel-header
|
|
$(this).removeClass('collapsed');
|
|
// Expand .panel-body
|
|
$(this).parents('.panel').find('.panel-body').removeClass('in').addClass('in');
|
|
} else {
|
|
// Collapse panel
|
|
// Change style of .panel-header
|
|
$(this).addClass('collapsed');
|
|
// Collapse .panel-body
|
|
$(this).parents('.panel').find('.panel-body').removeClass('in').removeClass('in');
|
|
}
|
|
});
|
|
});
|
|
|
|
</script>
|
|
|
|
{/literal}
|