0
0
mirror of https://github.com/salesagility/SuiteCRM.git synced 2024-11-22 16:02:36 +00:00
salesagility_SuiteCRM/themes/SuiteP/include/EditView/EditView.tpl

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">&nbsp;</div>
{{/if}}
</div>
{*display panels*}
<div class="panel-content">
<div>&nbsp;</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}