Files
SCM-Manager/scm-webapp/src/main/webapp/resources/js/layout.js

131 lines
3.1 KiB
JavaScript
Raw Normal View History

2010-09-04 16:36:25 +02:00
/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
Ext.onReady(function(){
// NOTE: This is an example showing simple state management. During development,
// it is generally best to disable state management as dynamically-generated ids
// can change across page loads, leading to unpredictable results. The developer
// should ensure that stable state ids are set for stateful components in real apps.
Ext.state.Manager.setProvider(new Ext.state.CookieProvider());
2010-09-05 13:54:49 +02:00
var tabPanel = new Ext.TabPanel({
region: 'center', // a center region is ALWAYS required for border layout
deferredRender: false,
2010-09-06 11:47:37 +02:00
activeTab: 0, // first tab initially active
2010-09-05 13:54:49 +02:00
items: [{
id: 'welcome',
xtype: 'panel',
title: 'Welcome',
// closable: true,
autoScroll: true
}]
});
new Ext.Viewport({
2010-09-04 16:36:25 +02:00
layout: 'border',
items: [
// create instance immediately
new Ext.BoxComponent({
region: 'north',
id: 'north-panel',
contentEl: 'north',
height: 75
}), {
region: 'west',
id: 'west-panel', // see Ext.getCmp() below
title: 'West',
split: true,
width: 200,
minSize: 175,
maxSize: 400,
collapsible: true,
margins: '0 0 0 5',
layout: {
type: 'accordion',
animate: true
},
items: [{
contentEl: 'west',
title: 'Navigation',
border: false,
iconCls: 'nav' // see the HEAD section for style used
}, {
title: 'Settings',
contentEl: 'settings',
border: false,
iconCls: 'settings'
}]
},
2010-09-05 13:54:49 +02:00
new Ext.BoxComponent({
2010-09-04 16:36:25 +02:00
region: 'south',
id: 'south-panel',
contentEl: 'south',
height: 16,
margins: '2 2 2 5'
}),
// in this instance the TabPanel is not wrapped by another panel
// since no title is needed, this Panel is added directly
// as a Container
2010-09-05 13:54:49 +02:00
tabPanel
]});
function addGroupPanel(){
tabPanel.add({
id: 't_group',
xtype: 'groupGrid',
title: 'Groups',
closable: true,
autoScroll: true
});
2010-09-05 13:57:15 +02:00
tabPanel.setActiveTab('t_group');
2010-09-05 13:54:49 +02:00
}
2010-09-06 12:28:13 +02:00
function addRepositoryPanel(){
tabPanel.add({
id: 't_repository',
xtype: 'repositoryGrid',
title: 'Repositories',
closable: true,
autoScroll: true
});
tabPanel.setActiveTab('t_repository');
}
2010-09-05 16:14:46 +02:00
function createMainMenu(){
var menu = Ext.get( 'main-menu' );
2010-09-06 12:28:13 +02:00
2010-09-05 16:14:46 +02:00
var groupsLink = menu.createChild({
tag: 'li',
2010-09-05 16:19:20 +02:00
html: 'Groups',
style: 'cursor: pointer;'
2010-09-05 16:14:46 +02:00
});
groupsLink.on('click', addGroupPanel);
2010-09-06 12:28:13 +02:00
var repositoryLink = menu.createChild({
tag: 'li',
html: 'Repositories',
style: 'cursor: pointer;'
});
repositoryLink.on('click', addRepositoryPanel);
2010-09-05 16:14:46 +02:00
}
2010-09-05 13:54:49 +02:00
Ext.Ajax.request({
url: restUrl + 'authentication.json',
method: 'GET',
success: function(){
2010-09-05 16:14:46 +02:00
createMainMenu();
2010-09-05 13:54:49 +02:00
},
failure: function(){
var loginWin = new Sonia.login.Window();
loginWin.on('success', function(){
2010-09-05 16:14:46 +02:00
createMainMenu();
2010-09-05 13:54:49 +02:00
});
loginWin.show();
}
2010-09-04 16:36:25 +02:00
});
});