mirror of
https://github.com/scm-manager/scm-manager.git
synced 2025-11-13 17:05:43 +01:00
165 lines
4.8 KiB
JavaScript
165 lines
4.8 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
|
||
|
|
*
|
||
|
|
*/
|
||
|
|
|
||
|
|
|
||
|
|
Sonia.user.Panel = Ext.extend(Ext.Panel, {
|
||
|
|
|
||
|
|
addText: 'Add',
|
||
|
|
removeText: 'Remove',
|
||
|
|
reloadText: 'Reload',
|
||
|
|
titleText: 'User Form',
|
||
|
|
emptyText: 'Add or select an User',
|
||
|
|
removeTitleText: 'Remove User',
|
||
|
|
removeMsgText: 'Remove User "{0}"?',
|
||
|
|
errorTitleText: 'Error',
|
||
|
|
errorMsgText: 'User deletion failed',
|
||
|
|
|
||
|
|
initComponent: function(){
|
||
|
|
|
||
|
|
var config = {
|
||
|
|
layout: 'border',
|
||
|
|
hideMode: 'offsets',
|
||
|
|
bodyCssClass: 'x-panel-mc',
|
||
|
|
enableTabScroll: true,
|
||
|
|
region:'center',
|
||
|
|
autoScroll: true,
|
||
|
|
tbar: [
|
||
|
|
{xtype: 'tbbutton', text: this.addText, scope: this, handler: this.showAddPanel},
|
||
|
|
{xtype: 'tbbutton', text: this.removeText, scope: this, handler: this.removeUser},
|
||
|
|
'-',
|
||
|
|
{xtype: 'tbbutton', text: this.reloadText, scope: this, handler: this.reload}
|
||
|
|
],
|
||
|
|
items: [{
|
||
|
|
id: 'userGrid',
|
||
|
|
xtype: 'userGrid',
|
||
|
|
region: 'center'
|
||
|
|
},{
|
||
|
|
id: 'userEditPanel',
|
||
|
|
layout: 'fit',
|
||
|
|
items: [{
|
||
|
|
region: 'south',
|
||
|
|
title: 'User Form',
|
||
|
|
xtype: 'panel',
|
||
|
|
padding: 5,
|
||
|
|
html: this.emptyText
|
||
|
|
}],
|
||
|
|
height: 250,
|
||
|
|
split: true,
|
||
|
|
border: false,
|
||
|
|
region: 'south'
|
||
|
|
}]
|
||
|
|
};
|
||
|
|
|
||
|
|
Ext.apply(this, Ext.apply(this.initialConfig, config));
|
||
|
|
Sonia.user.Panel.superclass.initComponent.apply(this, arguments);
|
||
|
|
},
|
||
|
|
|
||
|
|
showAddPanel: function(){
|
||
|
|
var editPanel = Ext.getCmp('userEditPanel');
|
||
|
|
editPanel.removeAll();
|
||
|
|
var panel = new Sonia.user.FormPanel({
|
||
|
|
region: 'south',
|
||
|
|
title: this.titleText,
|
||
|
|
padding: 5,
|
||
|
|
onUpdate: {
|
||
|
|
fn: this.reload,
|
||
|
|
scope: this
|
||
|
|
},
|
||
|
|
onCreate: {
|
||
|
|
fn: this.reload,
|
||
|
|
scope: this
|
||
|
|
}
|
||
|
|
});
|
||
|
|
editPanel.add(panel);
|
||
|
|
editPanel.doLayout();
|
||
|
|
},
|
||
|
|
|
||
|
|
resetPanel: function(){
|
||
|
|
Sonia.user.setEditPanel( Sonia.user.DefaultPanel );
|
||
|
|
},
|
||
|
|
|
||
|
|
removeUser: function(){
|
||
|
|
|
||
|
|
var grid = Ext.getCmp('userGrid');
|
||
|
|
var selected = grid.getSelectionModel().getSelected();
|
||
|
|
if ( selected ){
|
||
|
|
var item = selected.data;
|
||
|
|
var url = restUrl + 'users/' + item.name + '.json';
|
||
|
|
|
||
|
|
Ext.MessageBox.show({
|
||
|
|
title: this.removeTitleText,
|
||
|
|
msg: String.format(this.removeMsgText, item.name),
|
||
|
|
buttons: Ext.MessageBox.OKCANCEL,
|
||
|
|
icon: Ext.MessageBox.QUESTION,
|
||
|
|
fn: function(result){
|
||
|
|
if ( result == 'ok' ){
|
||
|
|
|
||
|
|
if ( debug ){
|
||
|
|
console.debug( 'remove user ' + item.name );
|
||
|
|
}
|
||
|
|
|
||
|
|
Ext.Ajax.request({
|
||
|
|
url: url,
|
||
|
|
method: 'DELETE',
|
||
|
|
scope: this,
|
||
|
|
success: function(){
|
||
|
|
this.reload();
|
||
|
|
this.resetPanel();
|
||
|
|
},
|
||
|
|
failure: function(result){
|
||
|
|
main.handleFailure(
|
||
|
|
result.status,
|
||
|
|
this.errorTitleText,
|
||
|
|
this.errorMsgText
|
||
|
|
);
|
||
|
|
}
|
||
|
|
});
|
||
|
|
}
|
||
|
|
|
||
|
|
},
|
||
|
|
scope: this
|
||
|
|
});
|
||
|
|
|
||
|
|
} else if ( debug ){
|
||
|
|
console.debug( 'no user selected' );
|
||
|
|
}
|
||
|
|
|
||
|
|
},
|
||
|
|
|
||
|
|
reload: function(){
|
||
|
|
Ext.getCmp('userGrid').reload();
|
||
|
|
}
|
||
|
|
|
||
|
|
});
|
||
|
|
|
||
|
|
// register xtype
|
||
|
|
Ext.reg('userPanel', Sonia.user.Panel);
|