2017-12-23 05:43:02 +01:00
|
|
|
/*
|
2017-12-24 07:52:40 +01:00
|
|
|
* Copyright (c) 2017, Tony Opara
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions are met:
|
|
|
|
* - Redistributions of source code must retain the above copyright notice, this
|
|
|
|
* list of conditions and the following disclaimer.
|
|
|
|
* - 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.
|
|
|
|
*
|
|
|
|
* Neither the name of Google 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 COPYRIGHT HOLDER 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.
|
|
|
|
*/
|
2017-12-23 05:43:02 +01:00
|
|
|
|
|
|
|
$(function(){
|
|
|
|
$.contextMenu({
|
|
|
|
selector: '.context-menu-one',
|
|
|
|
trigger: 'left',
|
|
|
|
build: function($trigger, e) {
|
|
|
|
|
|
|
|
return {
|
|
|
|
callback: function(key, options) {
|
|
|
|
var m = "clicked: " + key;
|
|
|
|
DatabaseExtension.handleSavedConnectionClicked(key, $(this).text());
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
items: {
|
|
|
|
"edit": {name: " Edit "},
|
|
|
|
"sep0": "",
|
|
|
|
"delete": {name: " Delete "},
|
|
|
|
"sep1": "---------",
|
|
|
|
"connect": {name: " Connect "},
|
|
|
|
"dummy": {name: "", icon: ""}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
var DatabaseExtension = {};
|
|
|
|
|
|
|
|
DatabaseExtension.currentConnection = {};
|
|
|
|
|
|
|
|
DatabaseExtension.handleSavedConnectionClicked = function(menuKey, connectionName) {
|
2017-12-24 07:52:40 +01:00
|
|
|
var jdbcConnectionInfo = {};
|
|
|
|
jdbcConnectionInfo.connectionName = connectionName;
|
|
|
|
|
|
|
|
if(menuKey === "edit"){
|
|
|
|
DatabaseExtension.handleEditConnectionClicked(connectionName);
|
|
|
|
|
|
|
|
}else if(menuKey === "delete"){
|
|
|
|
DatabaseExtension.handleDeleteConnectionClicked(connectionName);
|
|
|
|
|
|
|
|
}else if(menuKey === "connect"){
|
|
|
|
DatabaseExtension.handleConnectClicked(connectionName);
|
|
|
|
}
|
2017-12-23 05:43:02 +01:00
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
DatabaseExtension.handleConnectClicked = function(connectionName) {
|
2017-12-24 07:52:40 +01:00
|
|
|
|
|
|
|
$.get(
|
|
|
|
"command/database/saved-connection" + '?' + $.param({"connectionName": connectionName}),
|
|
|
|
null,
|
|
|
|
|
|
|
|
function(savedDatabaseConfig) {
|
|
|
|
|
|
|
|
if(savedDatabaseConfig){
|
|
|
|
|
|
|
|
var savedConfig = savedDatabaseConfig.savedConnections[0];
|
|
|
|
var databaseConfig = {};
|
|
|
|
databaseConfig.connectionName = savedConfig.connectionName;
|
|
|
|
databaseConfig.databaseType = savedConfig.databaseType;
|
|
|
|
databaseConfig.databaseServer = savedConfig.databaseHost;
|
|
|
|
databaseConfig.databasePort = savedConfig.databasePort;
|
|
|
|
databaseConfig.databaseUser = savedConfig.databaseUser;
|
|
|
|
databaseConfig.databasePassword = savedConfig.databasePassword;
|
|
|
|
databaseConfig.initialDatabase = savedConfig.databaseName;
|
|
|
|
databaseConfig.initialSchema = savedConfig.databaseSchema;
|
|
|
|
|
|
|
|
$.post(
|
|
|
|
"command/database/connect",
|
|
|
|
databaseConfig,
|
|
|
|
|
|
|
|
function(databaseInfo) {
|
|
|
|
|
|
|
|
if(databaseInfo){
|
|
|
|
DatabaseExtension.currentConnection.databaseInfo;
|
|
|
|
$( "#currentConnectionNameInput" ).val(databaseConfig.connectionName);
|
|
|
|
$( "#currentDatabaseTypeInput" ).val(databaseConfig.databaseType);
|
|
|
|
$( "#currentDatabaseUserInput" ).val(databaseConfig.databaseUser);
|
|
|
|
$( "#currentDatabasePasswordInput" ).val(databaseConfig.databasePassword);
|
|
|
|
$( "#currentDatabaseHostInput" ).val(databaseConfig.databaseServer);
|
|
|
|
$( "#currentDatabasePortInput" ).val(databaseConfig.databasePort);
|
|
|
|
$( "#currentInitialDatabaseInput" ).val(databaseConfig.initialDatabase);
|
|
|
|
|
|
|
|
var connectionParam = "Connection[" + databaseConfig.connectionName + "] :: "
|
|
|
|
+ "jdbc:"
|
|
|
|
+ databaseConfig.databaseType + "://"
|
|
|
|
+ databaseConfig.databaseServer + ":"
|
|
|
|
+ databaseConfig.databasePort + "/"
|
|
|
|
+ databaseConfig.initialDatabase;
|
|
|
|
|
|
|
|
$( "#connectionParameterSpan" ).text(connectionParam);
|
|
|
|
$( "#newConnectionDiv" ).hide();
|
|
|
|
$( "#sqlEditorDiv" ).show();
|
|
|
|
|
|
|
|
}else{
|
|
|
|
window.alert("Unable to establish connection to database");
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
"json"
|
|
|
|
).fail(function( jqXhr, textStatus, errorThrown ){
|
|
|
|
alert( textStatus + ':' + errorThrown );
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
"json"
|
2017-12-23 05:43:02 +01:00
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
DatabaseExtension.handleDeleteConnectionClicked = function(connectionName) {
|
2017-12-24 07:52:40 +01:00
|
|
|
$.ajax({
|
|
|
|
url: 'command/database/saved-connection' + '?' + $.param({"connectionName": connectionName}),
|
|
|
|
type: 'DELETE',
|
|
|
|
contentType:'application/json',
|
|
|
|
data: null,
|
|
|
|
success: function(settings) {
|
|
|
|
if(settings){
|
|
|
|
|
|
|
|
$( "#menuListUl" ).empty();
|
|
|
|
var items = [];
|
|
|
|
$.each(settings.savedConnections,function(index,savedConnection){
|
|
|
|
items.push('<li class="pure-menu-item sc-list"><a href="#" class="pure-menu-link context-menu-one">'
|
|
|
|
+ '<span class="context-menu-text" >' + savedConnection.connectionName + '</span>'
|
|
|
|
+ '<span class="sc-context-more-vert pull-right"> </span></a></li>');
|
|
|
|
})
|
|
|
|
|
|
|
|
$( "#menuListUl" ).append(items.join(''));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}).fail(function( jqXhr, textStatus, errorThrown ){
|
2017-12-23 05:43:02 +01:00
|
|
|
alert( textStatus + ':' + errorThrown );
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
DatabaseExtension.handleEditConnectionClicked = function(connectionName) {
|
2017-12-24 07:52:40 +01:00
|
|
|
|
|
|
|
$.get(
|
|
|
|
"command/database/saved-connection" + '?' + $.param({"connectionName": connectionName}),
|
|
|
|
null,
|
|
|
|
function(savedDatabaseConfig) {
|
|
|
|
|
|
|
|
if(savedDatabaseConfig){
|
|
|
|
|
|
|
|
var savedConfig = savedDatabaseConfig.savedConnections[0];
|
|
|
|
$( "#connectionName" ).val(savedConfig.connectionName);
|
|
|
|
$( "#databaseTypeSelect" ).val(savedConfig.databaseType);
|
|
|
|
$( "#databaseHost" ).val(savedConfig.databaseHost);
|
|
|
|
$( "#databasePort" ).val(savedConfig.databasePort);
|
|
|
|
$( "#databaseUser" ).val(savedConfig.databaseUser);
|
|
|
|
$( "#databasePassword" ).val(savedConfig.databasePassword);
|
|
|
|
$( "#initialDatabase" ).val(savedConfig.databaseName);
|
|
|
|
$( "#initialSchema" ).val(savedConfig.databaseSchema);
|
|
|
|
$( "#newConnectionControlDiv" ).hide();
|
|
|
|
$( "#editConnectionControlDiv" ).show();
|
|
|
|
$( "#newConnectionDiv" ).show();
|
|
|
|
$('#sqlEditorDiv').hide();
|
|
|
|
$("#connectionName").attr('readonly', 'readonly');
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
"json"
|
|
|
|
);
|
2017-12-23 05:43:02 +01:00
|
|
|
|
|
|
|
}
|