mirror of
https://github.com/scm-manager/scm-manager.git
synced 2025-11-15 17:56:17 +01:00
460 lines
12 KiB
JavaScript
460 lines
12 KiB
JavaScript
/**
|
|
* Copyright (c) 2010, Sebastian Sdorra
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions are met:
|
|
*
|
|
* 1. Redistributions of source code must retain the above copyright notice,
|
|
* this list of conditions and the following disclaimer.
|
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
|
* this list of conditions and the following disclaimer in the documentation
|
|
* and/or other materials provided with the distribution.
|
|
* 3. Neither the name of SCM-Manager; nor the names of its
|
|
* contributors may be used to endorse or promote products derived from this
|
|
* software without specific prior written permission.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
* DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY
|
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
*
|
|
* http://bitbucket.org/sdorra/scm-manager
|
|
*
|
|
*/
|
|
|
|
Ext.ns("Sonia.scm");
|
|
|
|
Sonia.scm.Main = Ext.extend(Ext.util.Observable, {
|
|
|
|
tabRepositoriesText: 'Repositories',
|
|
navChangePasswordText: 'Change Password',
|
|
sectionMainText: 'Main',
|
|
sectionSecurityText: 'Security',
|
|
navRepositoriesText: 'Repositories',
|
|
sectionConfigText: 'Config',
|
|
navGeneralConfigText: 'General',
|
|
tabGeneralConfigText: 'SCM Config',
|
|
|
|
navRepositoryTypesText: 'Repository Types',
|
|
tabRepositoryTypesText: 'Repository Config',
|
|
navPluginsText: 'Plugins',
|
|
tabPluginsText: 'Plugins',
|
|
navUsersText: 'Users',
|
|
tabUsersText: 'Users',
|
|
navGroupsText: 'Groups',
|
|
tabGroupsText: 'Groups',
|
|
|
|
sectionLoginText: 'Login',
|
|
navLoginText: 'Login',
|
|
|
|
sectionLogoutText: 'Log out',
|
|
navLogoutText: 'Log out',
|
|
|
|
logoutFailedText: 'Logout Failed!',
|
|
|
|
errorTitle: 'Error',
|
|
errorMessage: 'Unknown error occurred.',
|
|
|
|
errorSessionExpiredTitle: 'Session expired',
|
|
errorSessionExpiredMessage: 'Your session is expired. Please relogin.',
|
|
|
|
mainTabPanel: null,
|
|
|
|
infoPanels: [],
|
|
scripts: [],
|
|
stylesheets: [],
|
|
|
|
constructor : function(config) {
|
|
this.addEvents('login', 'logout', 'init');
|
|
this.mainTabPanel = Ext.getCmp('mainTabPanel');
|
|
this.addListener('login', this.postLogin, this);
|
|
Sonia.scm.Main.superclass.constructor.call(this, config);
|
|
},
|
|
|
|
init: function(){
|
|
this.fireEvent('init', this);
|
|
},
|
|
|
|
registerInfoPanel: function(type, panel){
|
|
this.infoPanels[type] = panel;
|
|
},
|
|
|
|
getInfoPanel: function(type){
|
|
var rp = null;
|
|
var panel = this.infoPanels[type];
|
|
if ( panel == null ){
|
|
rp = {
|
|
xtype: 'repositoryInfoPanel'
|
|
};
|
|
} else {
|
|
rp = Sonia.util.clone( panel );
|
|
}
|
|
return rp;
|
|
},
|
|
|
|
postLogin: function(){
|
|
this.createMainMenu();
|
|
this.createRepositoryPanel();
|
|
},
|
|
|
|
createRepositoryPanel: function(){
|
|
if ( debug ){
|
|
console.debug('create repository panel');
|
|
}
|
|
this.mainTabPanel.add({
|
|
id: 'repositories',
|
|
xtype: 'repositoryPanel',
|
|
title: this.tabRepositoriesText,
|
|
closeable: false,
|
|
autoScroll: true
|
|
});
|
|
this.mainTabPanel.setActiveTab('repositories');
|
|
},
|
|
|
|
createMainMenu: function(){
|
|
if ( debug ){
|
|
console.debug('create main menu');
|
|
}
|
|
var panel = Ext.getCmp('navigationPanel');
|
|
panel.addSection({
|
|
id: 'navMain',
|
|
title: this.sectionMainText,
|
|
links: [{
|
|
label: this.navRepositoriesText,
|
|
fn: function(){
|
|
this.mainTabPanel.setActiveTab('repositories');
|
|
},
|
|
scope: this
|
|
}]
|
|
});
|
|
|
|
var securitySection = null;
|
|
|
|
if ( state.user.type == 'xml' && state.user.name != 'anonymous' ){
|
|
securitySection = {
|
|
title: this.sectionSecurityText,
|
|
links: [{
|
|
label: this.navChangePasswordText,
|
|
fn: function(){
|
|
new Sonia.action.ChangePasswordWindow().show();
|
|
}
|
|
}]
|
|
}
|
|
}
|
|
|
|
if ( admin ){
|
|
|
|
panel.addSections([{
|
|
id: 'navConfig',
|
|
title: this.sectionConfigText,
|
|
links: [{
|
|
label: this.navGeneralConfigText,
|
|
fn: function(){
|
|
this.addTabPanel("scmConfig", "scmConfig", this.navGeneralConfigText);
|
|
},
|
|
scope: this
|
|
},{
|
|
label: this.navRepositoryTypesText,
|
|
fn: function(){
|
|
this.addTabPanel('repositoryConfig', 'repositoryConfig', this.tabRepositoryTypesText);
|
|
},
|
|
scope: this
|
|
},{
|
|
label: this.navPluginsText,
|
|
fn: function(){
|
|
this.addTabPanel('plugins', 'pluginGrid', this.navPluginsText);
|
|
},
|
|
scope: this
|
|
}]
|
|
}]);
|
|
|
|
if ( securitySection == null ){
|
|
securitySection = {
|
|
title: this.sectionSecurityText,
|
|
links: []
|
|
}
|
|
}
|
|
|
|
securitySection.links.push({
|
|
label: this.navUsersText,
|
|
fn: function(){
|
|
this.addTabPanel('users', 'userPanel', this.navUsersText);
|
|
},
|
|
scope: this
|
|
});
|
|
securitySection.links.push({
|
|
label: this.navGroupsText,
|
|
fn: function(){
|
|
this.addTabPanel('groups', 'groupPanel', this.tabGroupsText);
|
|
},
|
|
scope: this
|
|
});
|
|
}
|
|
|
|
if ( securitySection != null ){
|
|
panel.addSection( securitySection );
|
|
}
|
|
|
|
if ( state.user.name == 'anonymous' ){
|
|
panel.addSection({
|
|
id: 'navLogin',
|
|
title: this.sectionLoginText,
|
|
links: [{
|
|
label: this.sectionLoginText,
|
|
fn: this.login,
|
|
scope: this
|
|
}]
|
|
});
|
|
} else {
|
|
panel.addSection({
|
|
id: 'navLogout',
|
|
title: this.sectionLogoutText,
|
|
links: [{
|
|
label: this.navLogoutText,
|
|
fn: this.logout,
|
|
scope: this
|
|
}]
|
|
});
|
|
}
|
|
|
|
//fix hidden logout button
|
|
panel.doLayout();
|
|
},
|
|
|
|
addTabPanel: function(id, xtype, title){
|
|
var panel = {
|
|
id: id,
|
|
xtype: xtype,
|
|
title: title,
|
|
closable: true,
|
|
autoScroll: true
|
|
};
|
|
this.addTab(panel);
|
|
},
|
|
|
|
addTab: function(panel){
|
|
var tab = this.mainTabPanel.findById(panel.id);
|
|
if ( tab == null ){
|
|
this.mainTabPanel.add(panel);
|
|
}
|
|
this.mainTabPanel.setActiveTab(panel.id);
|
|
},
|
|
|
|
loadState: function(s){
|
|
if ( debug ){
|
|
console.debug( s );
|
|
}
|
|
state = s;
|
|
admin = s.user.admin;
|
|
|
|
// call login callback functions
|
|
this.fireEvent("login", state);
|
|
},
|
|
|
|
clearState: function(){
|
|
// clear state
|
|
state = null;
|
|
// clear repository store
|
|
repositoryTypeStore.removeAll();
|
|
// remove all tabs
|
|
this.mainTabPanel.removeAll();
|
|
// remove navigation items
|
|
Ext.getCmp('navigationPanel').removeAll();
|
|
},
|
|
|
|
checkLogin: function(){
|
|
Ext.Ajax.request({
|
|
url: restUrl + 'authentication.json',
|
|
method: 'GET',
|
|
scope: this,
|
|
success: function(response){
|
|
if ( debug ){
|
|
console.debug('login success');
|
|
}
|
|
var s = Ext.decode(response.responseText);
|
|
this.loadState(s);
|
|
},
|
|
failure: function(){
|
|
if ( debug ){
|
|
console.debug('login failed');
|
|
}
|
|
var loginWin = new Sonia.login.Window();
|
|
loginWin.show();
|
|
}
|
|
});
|
|
},
|
|
|
|
login: function(){
|
|
this.clearState();
|
|
var loginWin = new Sonia.login.Window();
|
|
loginWin.show();
|
|
},
|
|
|
|
logout: function(){
|
|
Ext.Ajax.request({
|
|
url: restUrl + 'authentication/logout.json',
|
|
method: 'GET',
|
|
scope: this,
|
|
success: function(response){
|
|
if ( debug ){
|
|
console.debug('logout success');
|
|
}
|
|
this.clearState();
|
|
// call logout callback functions
|
|
this.fireEvent( "logout", state );
|
|
|
|
var s = null;
|
|
var text = response.responseText;
|
|
if ( text != null && text.length > 0 ){
|
|
s = Ext.decode( text );
|
|
}
|
|
if ( s != null && s.success ){
|
|
this.loadState(s);
|
|
} else {
|
|
// show login window
|
|
var loginWin = new Sonia.login.Window();
|
|
loginWin.show();
|
|
}
|
|
},
|
|
failure: function(){
|
|
if ( debug ){
|
|
console.debug('logout failed');
|
|
}
|
|
Ext.Msg.alert(this.logoutFailedText);
|
|
}
|
|
});
|
|
},
|
|
|
|
addListeners: function(event, callbacks){
|
|
Ext.each(callbacks, function(callback){
|
|
if ( Ext.isFunction(callback) ){
|
|
this.addListener(event, callback);
|
|
} else if (Ext.isObject(callback)) {
|
|
this.addListener(event, callback.fn, callback.scope);
|
|
} else if (debug){
|
|
console.debug( "callback is not a function or object. " + callback );
|
|
}
|
|
}, this);
|
|
},
|
|
|
|
handleFailure: function(status, title, message){
|
|
if (debug){
|
|
console.debug( 'handle failure for status code: ' + status );
|
|
}
|
|
if ( status == 401 ){
|
|
Ext.Msg.show({
|
|
title: this.errorSessionExpiredTitle,
|
|
msg: this.errorSessionExpiredMessage,
|
|
buttons: Ext.Msg.OKCANCEL,
|
|
fn: function(btn){
|
|
if ( btn == 'ok' ){
|
|
this.login();
|
|
}
|
|
},
|
|
scope: this
|
|
});
|
|
} else {
|
|
if ( title == null ){
|
|
title = this.errorTitle;
|
|
}
|
|
if ( message == null ){
|
|
message = this.errorMessage;
|
|
}
|
|
Ext.MessageBox.show({
|
|
title: title,
|
|
msg: String.format(message, status),
|
|
buttons: Ext.MessageBox.OK,
|
|
icon:Ext.MessageBox.ERROR
|
|
});
|
|
}
|
|
},
|
|
|
|
loadScript: function(url){
|
|
if ( this.scripts.indexOf(url) < 0 ){
|
|
var js = document.createElement('script');
|
|
js.type = "text/javascript";
|
|
js.src = url;
|
|
document.head.appendChild(js);
|
|
this.scripts.push(url);
|
|
}
|
|
},
|
|
|
|
loadStylesheet: function(url){
|
|
if ( this.stylesheets.indexOf(url) < 0 ){
|
|
var css = document.createElement('link');
|
|
css.rel = 'stylesheet';
|
|
css.type = 'text/css';
|
|
css.href = url;
|
|
document.head.appendChild(css);
|
|
this.stylesheets.push(url);
|
|
}
|
|
}
|
|
|
|
});
|
|
|
|
Ext.onReady(function(){
|
|
|
|
Ext.state.Manager.setProvider(new Ext.state.CookieProvider());
|
|
|
|
var mainTabPanel = new Ext.TabPanel({
|
|
id: 'mainTabPanel',
|
|
region: 'center',
|
|
deferredRender: false
|
|
});
|
|
|
|
new Ext.Viewport({
|
|
layout: 'border',
|
|
items: [
|
|
new Ext.BoxComponent({
|
|
region: 'north',
|
|
id: 'north-panel',
|
|
contentEl: 'north',
|
|
height: 75
|
|
}), {
|
|
region: 'west',
|
|
id: 'navigationPanel',
|
|
title: 'Navigation',
|
|
xtype: 'navPanel',
|
|
split: true,
|
|
width: 200,
|
|
minSize: 175,
|
|
maxSize: 400,
|
|
collapsible: true,
|
|
margins: '0 0 0 5'
|
|
},
|
|
new Ext.BoxComponent({
|
|
region: 'south',
|
|
id: 'south-panel',
|
|
contentEl: 'south',
|
|
height: 16,
|
|
margins: '2 2 2 5'
|
|
}),
|
|
mainTabPanel
|
|
]
|
|
});
|
|
|
|
main = new Sonia.scm.Main();
|
|
|
|
/**
|
|
* Adds a tab to main TabPanel
|
|
*
|
|
* @deprecated use main.addTabPanel
|
|
*/
|
|
function addTabPanel(id, xtype, title){
|
|
main.addTabPanel(id, xtype, title);
|
|
}
|
|
|
|
main.addListeners('init', initCallbacks);
|
|
main.addListeners('login', loginCallbacks);
|
|
main.addListeners('logout', logoutCallbacks);
|
|
|
|
main.init();
|
|
main.checkLogin();
|
|
}); |