init web ems all
This commit is contained in:
136
phpMyAdmin/js/designer/database.js
Executable file
136
phpMyAdmin/js/designer/database.js
Executable file
@@ -0,0 +1,136 @@
|
||||
var designer_tables = [{ name: 'pdf_pages', key: 'pg_nr', auto_inc: true },
|
||||
{ name: 'table_coords', key: 'id', auto_inc: true }];
|
||||
|
||||
var DesignerOfflineDB = (function () {
|
||||
var designerDB = {};
|
||||
var datastore = null;
|
||||
|
||||
designerDB.open = function (callback) {
|
||||
var version = 1;
|
||||
var request = window.indexedDB.open('pma_designer', version);
|
||||
|
||||
request.onupgradeneeded = function (e) {
|
||||
var db = e.target.result;
|
||||
e.target.transaction.onerror = designerDB.onerror;
|
||||
|
||||
for (var t in designer_tables) {
|
||||
if (db.objectStoreNames.contains(designer_tables[t].name)) {
|
||||
db.deleteObjectStore(designer_tables[t].name);
|
||||
}
|
||||
}
|
||||
|
||||
for (var t in designer_tables) {
|
||||
db.createObjectStore(designer_tables[t].name, {
|
||||
keyPath: designer_tables[t].key,
|
||||
autoIncrement: designer_tables[t].auto_inc
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
request.onsuccess = function (e) {
|
||||
datastore = e.target.result;
|
||||
if (typeof callback !== 'undefined' && callback !== null) {
|
||||
callback(true);
|
||||
}
|
||||
};
|
||||
|
||||
request.onerror = designerDB.onerror;
|
||||
};
|
||||
|
||||
designerDB.loadObject = function (table, id, callback) {
|
||||
var db = datastore;
|
||||
var transaction = db.transaction([table], 'readwrite');
|
||||
var objStore = transaction.objectStore(table);
|
||||
var cursorRequest = objStore.get(parseInt(id));
|
||||
|
||||
cursorRequest.onsuccess = function (e) {
|
||||
callback(e.target.result);
|
||||
};
|
||||
|
||||
cursorRequest.onerror = designerDB.onerror;
|
||||
};
|
||||
|
||||
designerDB.loadAllObjects = function (table, callback) {
|
||||
var db = datastore;
|
||||
var transaction = db.transaction([table], 'readwrite');
|
||||
var objStore = transaction.objectStore(table);
|
||||
var keyRange = IDBKeyRange.lowerBound(0);
|
||||
var cursorRequest = objStore.openCursor(keyRange);
|
||||
var results = [];
|
||||
|
||||
transaction.oncomplete = function (e) {
|
||||
callback(results);
|
||||
};
|
||||
|
||||
cursorRequest.onsuccess = function (e) {
|
||||
var result = e.target.result;
|
||||
if (Boolean(result) === false) {
|
||||
return;
|
||||
}
|
||||
results.push(result.value);
|
||||
result.continue();
|
||||
};
|
||||
|
||||
cursorRequest.onerror = designerDB.onerror;
|
||||
};
|
||||
|
||||
designerDB.loadFirstObject = function (table, callback) {
|
||||
var db = datastore;
|
||||
var transaction = db.transaction([table], 'readwrite');
|
||||
var objStore = transaction.objectStore(table);
|
||||
var keyRange = IDBKeyRange.lowerBound(0);
|
||||
var cursorRequest = objStore.openCursor(keyRange);
|
||||
var firstResult = null;
|
||||
|
||||
transaction.oncomplete = function (e) {
|
||||
callback(firstResult);
|
||||
};
|
||||
|
||||
cursorRequest.onsuccess = function (e) {
|
||||
var result = e.target.result;
|
||||
if (Boolean(result) === false) {
|
||||
return;
|
||||
}
|
||||
firstResult = result.value;
|
||||
};
|
||||
|
||||
cursorRequest.onerror = designerDB.onerror;
|
||||
};
|
||||
|
||||
designerDB.addObject = function (table, obj, callback) {
|
||||
var db = datastore;
|
||||
var transaction = db.transaction([table], 'readwrite');
|
||||
var objStore = transaction.objectStore(table);
|
||||
var request = objStore.put(obj);
|
||||
|
||||
request.onsuccess = function (e) {
|
||||
if (typeof callback !== 'undefined' && callback !== null) {
|
||||
callback(e.currentTarget.result);
|
||||
}
|
||||
};
|
||||
|
||||
request.onerror = designerDB.onerror;
|
||||
};
|
||||
|
||||
designerDB.deleteObject = function (table, id, callback) {
|
||||
var db = datastore;
|
||||
var transaction = db.transaction([table], 'readwrite');
|
||||
var objStore = transaction.objectStore(table);
|
||||
var request = objStore.delete(parseInt(id));
|
||||
|
||||
request.onsuccess = function (e) {
|
||||
if (typeof callback !== 'undefined' && callback !== null) {
|
||||
callback(true);
|
||||
}
|
||||
};
|
||||
|
||||
request.onerror = designerDB.onerror;
|
||||
};
|
||||
|
||||
designerDB.onerror = function (e) {
|
||||
console.log(e);
|
||||
};
|
||||
|
||||
// Export the designerDB object.
|
||||
return designerDB;
|
||||
}());
|
||||
857
phpMyAdmin/js/designer/history.js
Executable file
857
phpMyAdmin/js/designer/history.js
Executable file
@@ -0,0 +1,857 @@
|
||||
/* vim: set expandtab sw=4 ts=4 sts=4: */
|
||||
/**
|
||||
* @fileoverview function used in this file builds history tab and generates query.
|
||||
*
|
||||
* @requires jQuery
|
||||
* @requires moves.js
|
||||
* @version $Id$
|
||||
*/
|
||||
|
||||
var history_array = []; // Global array to store history objects
|
||||
var select_field = []; // Global array to store informaation for columns which are used in select clause
|
||||
var g_index;
|
||||
var vqb_editor = null;
|
||||
|
||||
/**
|
||||
* To display details of objects(where,rename,Having,aggregate,groupby,orderby,having)
|
||||
*
|
||||
* @param index index of history_array where change is to be made
|
||||
*
|
||||
**/
|
||||
|
||||
function detail (index) {
|
||||
var type = history_array[index].get_type();
|
||||
var str;
|
||||
if (type === 'Where') {
|
||||
str = 'Where ' + history_array[index].get_column_name() + history_array[index].get_obj().getrelation_operator() + history_array[index].get_obj().getquery();
|
||||
}
|
||||
if (type === 'Rename') {
|
||||
str = 'Rename ' + history_array[index].get_column_name() + ' To ' + history_array[index].get_obj().getrename_to();
|
||||
}
|
||||
if (type === 'Aggregate') {
|
||||
str = 'Select ' + history_array[index].get_obj().get_operator() + '( ' + history_array[index].get_column_name() + ' )';
|
||||
}
|
||||
if (type === 'GroupBy') {
|
||||
str = 'GroupBy ' + history_array[index].get_column_name();
|
||||
}
|
||||
if (type === 'OrderBy') {
|
||||
str = 'OrderBy ' + history_array[index].get_column_name() + ' ' + history_array[index].get_obj().get_order();
|
||||
}
|
||||
if (type === 'Having') {
|
||||
str = 'Having ';
|
||||
if (history_array[index].get_obj().get_operator() !== 'None') {
|
||||
str += history_array[index].get_obj().get_operator() + '( ' + history_array[index].get_column_name() + ' )';
|
||||
str += history_array[index].get_obj().getrelation_operator() + history_array[index].get_obj().getquery();
|
||||
} else {
|
||||
str = 'Having ' + history_array[index].get_column_name() + history_array[index].get_obj().getrelation_operator() + history_array[index].get_obj().getquery();
|
||||
}
|
||||
}
|
||||
return str;
|
||||
}
|
||||
|
||||
/**
|
||||
* Sorts history_array[] first,using table name as the key and then generates the HTML code for history tab,
|
||||
* clubbing all objects of same tables together
|
||||
* This function is called whenever changes are made in history_array[]
|
||||
*
|
||||
*
|
||||
* @param {int} init starting index of unsorted array
|
||||
* @param {int} finit last index of unsorted array
|
||||
*
|
||||
**/
|
||||
|
||||
function display (init, finit) {
|
||||
var str;
|
||||
var i;
|
||||
var j;
|
||||
var k;
|
||||
var sto;
|
||||
var temp;
|
||||
// this part sorts the history array based on table name,this is needed for clubbing all object of same name together.
|
||||
for (i = init; i < finit; i++) {
|
||||
sto = history_array[i];
|
||||
temp = history_array[i].get_tab();// + '.' + history_array[i].get_obj_no(); for Self JOINS
|
||||
for (j = 0; j < i; j++) {
|
||||
if (temp > (history_array[j].get_tab())) {// + '.' + history_array[j].get_obj_no())) { //for Self JOINS
|
||||
for (k = i; k > j; k--) {
|
||||
history_array[k] = history_array[k - 1];
|
||||
}
|
||||
history_array[j] = sto;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
// this part generates HTML code for history tab.adds delete,edit,and/or and detail features with objects.
|
||||
str = ''; // string to store Html code for history tab
|
||||
for (i = 0; i < history_array.length; i++) {
|
||||
temp = history_array[i].get_tab(); // + '.' + history_array[i].get_obj_no(); for Self JOIN
|
||||
str += '<h3 class="tiger"><a href="#">' + temp + '</a></h3>';
|
||||
str += '<div class="toggle_container">\n';
|
||||
while ((history_array[i].get_tab()) === temp) { // + '.' + history_array[i].get_obj_no()) === temp) {
|
||||
str += '<div class="block"> <table width ="250">';
|
||||
str += '<thead><tr><td>';
|
||||
if (history_array[i].get_and_or()) {
|
||||
str += '<img src="' + pmaThemeImage + 'designer/or_icon.png" onclick="and_or(' + i + ')" title="OR"/></td>';
|
||||
} else {
|
||||
str += '<img src="' + pmaThemeImage + 'designer/and_icon.png" onclick="and_or(' + i + ')" title="AND"/></td>';
|
||||
}
|
||||
str += '<td style="padding-left: 5px;" class="right">' + PMA_getImage('b_sbrowse', PMA_messages.strColumnName) + '</td>' +
|
||||
'<td width="175" style="padding-left: 5px">' + $('<div/>').text(history_array[i].get_column_name()).html() + '<td>';
|
||||
if (history_array[i].get_type() === 'GroupBy' || history_array[i].get_type() === 'OrderBy') {
|
||||
var detailDesc = $('<div/>').text(detail(i)).html();
|
||||
str += '<td class="center">' + PMA_getImage('s_info', detail(i)) + '</td>' +
|
||||
'<td title="' + detailDesc + '">' + history_array[i].get_type() + '</td>' +
|
||||
'<td onclick=history_delete(' + i + ')>' + PMA_getImage('b_drop', PMA_messages.strDelete) + '</td>';
|
||||
} else {
|
||||
var detailDesc = $('<div/>').text(detail(i)).html();
|
||||
str += '<td class="center">' + PMA_getImage('s_info', detail(i)) + '</td>' +
|
||||
'<td title="' + detailDesc + '">' + history_array[i].get_type() + '</td>' +
|
||||
'<td onclick=history_edit(' + i + ')>' + PMA_getImage('b_edit', PMA_messages.strEdit) + '</td>' +
|
||||
'<td onclick=history_delete(' + i + ')>' + PMA_getImage('b_drop', PMA_messages.strDelete) + '</td>';
|
||||
}
|
||||
str += '</tr></thead>';
|
||||
i++;
|
||||
if (i >= history_array.length) {
|
||||
break;
|
||||
}
|
||||
str += '</table></div>';
|
||||
}
|
||||
i--;
|
||||
str += '</div>';
|
||||
}
|
||||
return str;
|
||||
}
|
||||
|
||||
/**
|
||||
* To change And/Or relation in history tab
|
||||
*
|
||||
*
|
||||
* @param {int} index of history_array where change is to be made
|
||||
*
|
||||
**/
|
||||
|
||||
function and_or (index) {
|
||||
if (history_array[index].get_and_or()) {
|
||||
history_array[index].set_and_or(0);
|
||||
} else {
|
||||
history_array[index].set_and_or(1);
|
||||
}
|
||||
var existingDiv = document.getElementById('ab');
|
||||
existingDiv.innerHTML = display(0, 0);
|
||||
$('#ab').accordion('refresh');
|
||||
}
|
||||
|
||||
/**
|
||||
* Deletes entry in history_array
|
||||
*
|
||||
* @param index index of history_array[] which is to be deleted
|
||||
*
|
||||
**/
|
||||
|
||||
function history_delete (index) {
|
||||
for (var k = 0; k < from_array.length; k++) {
|
||||
if (from_array[k] === history_array[index].get_tab()) {
|
||||
from_array.splice(k, 1);
|
||||
break;
|
||||
}
|
||||
}
|
||||
history_array.splice(index, 1);
|
||||
var existingDiv = document.getElementById('ab');
|
||||
existingDiv.innerHTML = display(0, 0);
|
||||
$('#ab').accordion('refresh');
|
||||
}
|
||||
|
||||
/**
|
||||
* To show where,rename,aggregate,having forms to edit a object
|
||||
*
|
||||
* @param{int} index index of history_array where change is to be made
|
||||
*
|
||||
**/
|
||||
|
||||
function history_edit (index) {
|
||||
g_index = index;
|
||||
var type = history_array[index].get_type();
|
||||
if (type === 'Where') {
|
||||
document.getElementById('eQuery').value = history_array[index].get_obj().getquery();
|
||||
document.getElementById('erel_opt').value = history_array[index].get_obj().getrelation_operator();
|
||||
document.getElementById('query_where').style.left = '530px';
|
||||
document.getElementById('query_where').style.top = '130px';
|
||||
document.getElementById('query_where').style.position = 'absolute';
|
||||
document.getElementById('query_where').style.zIndex = '103';
|
||||
document.getElementById('query_where').style.visibility = 'visible';
|
||||
document.getElementById('query_where').style.display = 'block';
|
||||
}
|
||||
if (type === 'Having') {
|
||||
document.getElementById('hQuery').value = history_array[index].get_obj().getquery();
|
||||
document.getElementById('hrel_opt').value = history_array[index].get_obj().getrelation_operator();
|
||||
document.getElementById('hoperator').value = history_array[index].get_obj().get_operator();
|
||||
document.getElementById('query_having').style.left = '530px';
|
||||
document.getElementById('query_having').style.top = '130px';
|
||||
document.getElementById('query_having').style.position = 'absolute';
|
||||
document.getElementById('query_having').style.zIndex = '103';
|
||||
document.getElementById('query_having').style.visibility = 'visible';
|
||||
document.getElementById('query_having').style.display = 'block';
|
||||
}
|
||||
if (type === 'Rename') {
|
||||
document.getElementById('e_rename').value = history_array[index].get_obj().getrename_to();
|
||||
document.getElementById('query_rename_to').style.left = '530px';
|
||||
document.getElementById('query_rename_to').style.top = '130px';
|
||||
document.getElementById('query_rename_to').style.position = 'absolute';
|
||||
document.getElementById('query_rename_to').style.zIndex = '103';
|
||||
document.getElementById('query_rename_to').style.visibility = 'visible';
|
||||
document.getElementById('query_rename_to').style.display = 'block';
|
||||
}
|
||||
if (type === 'Aggregate') {
|
||||
document.getElementById('e_operator').value = history_array[index].get_obj().get_operator();
|
||||
document.getElementById('query_Aggregate').style.left = '530px';
|
||||
document.getElementById('query_Aggregate').style.top = '130px';
|
||||
document.getElementById('query_Aggregate').style.position = 'absolute';
|
||||
document.getElementById('query_Aggregate').style.zIndex = '103';
|
||||
document.getElementById('query_Aggregate').style.visibility = 'visible';
|
||||
document.getElementById('query_Aggregate').style.display = 'block';
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Make changes in history_array when Edit button is clicked
|
||||
* checks for the type of object and then sets the new value
|
||||
*
|
||||
* @param index index of history_array where change is to be made
|
||||
**/
|
||||
|
||||
function edit (type) {
|
||||
if (type === 'Rename') {
|
||||
if (document.getElementById('e_rename').value !== '') {
|
||||
history_array[g_index].get_obj().setrename_to(document.getElementById('e_rename').value);
|
||||
document.getElementById('e_rename').value = '';
|
||||
}
|
||||
document.getElementById('query_rename_to').style.visibility = 'hidden';
|
||||
}
|
||||
if (type === 'Aggregate') {
|
||||
if (document.getElementById('e_operator').value !== '---') {
|
||||
history_array[g_index].get_obj().set_operator(document.getElementById('e_operator').value);
|
||||
document.getElementById('e_operator').value = '---';
|
||||
}
|
||||
document.getElementById('query_Aggregate').style.visibility = 'hidden';
|
||||
}
|
||||
if (type === 'Where') {
|
||||
if (document.getElementById('erel_opt').value !== '--' && document.getElementById('eQuery').value !== '') {
|
||||
history_array[g_index].get_obj().setquery(document.getElementById('eQuery').value);
|
||||
history_array[g_index].get_obj().setrelation_operator(document.getElementById('erel_opt').value);
|
||||
}
|
||||
document.getElementById('query_where').style.visibility = 'hidden';
|
||||
}
|
||||
if (type === 'Having') {
|
||||
if (document.getElementById('hrel_opt').value !== '--' && document.getElementById('hQuery').value !== '') {
|
||||
history_array[g_index].get_obj().setquery(document.getElementById('hQuery').value);
|
||||
history_array[g_index].get_obj().setrelation_operator(document.getElementById('hrel_opt').value);
|
||||
history_array[g_index].get_obj().set_operator(document.getElementById('hoperator').value);
|
||||
}
|
||||
document.getElementById('query_having').style.visibility = 'hidden';
|
||||
}
|
||||
var existingDiv = document.getElementById('ab');
|
||||
existingDiv.innerHTML = display(0, 0);
|
||||
$('#ab').accordion('refresh');
|
||||
}
|
||||
|
||||
/**
|
||||
* history object closure
|
||||
*
|
||||
* @param ncolumn_name name of the column on which conditions are put
|
||||
* @param nobj object details(where,rename,orderby,groupby,aggregate)
|
||||
* @param ntab table name of the column on which conditions are applied
|
||||
* @param nobj_no object no used for inner join
|
||||
* @param ntype type of object
|
||||
*
|
||||
**/
|
||||
|
||||
function history_obj (ncolumn_name, nobj, ntab, nobj_no, ntype) {
|
||||
var and_or;
|
||||
var obj;
|
||||
var tab;
|
||||
var column_name;
|
||||
var obj_no;
|
||||
var type;
|
||||
this.set_column_name = function (ncolumn_name) {
|
||||
column_name = ncolumn_name;
|
||||
};
|
||||
this.get_column_name = function () {
|
||||
return column_name;
|
||||
};
|
||||
this.set_and_or = function (nand_or) {
|
||||
and_or = nand_or;
|
||||
};
|
||||
this.get_and_or = function () {
|
||||
return and_or;
|
||||
};
|
||||
this.get_relation = function () {
|
||||
return and_or;
|
||||
};
|
||||
this.set_obj = function (nobj) {
|
||||
obj = nobj;
|
||||
};
|
||||
this.get_obj = function () {
|
||||
return obj;
|
||||
};
|
||||
this.set_tab = function (ntab) {
|
||||
tab = ntab;
|
||||
};
|
||||
this.get_tab = function () {
|
||||
return tab;
|
||||
};
|
||||
this.set_obj_no = function (nobj_no) {
|
||||
obj_no = nobj_no;
|
||||
};
|
||||
this.get_obj_no = function () {
|
||||
return obj_no;
|
||||
};
|
||||
this.set_type = function (ntype) {
|
||||
type = ntype;
|
||||
};
|
||||
this.get_type = function () {
|
||||
return type;
|
||||
};
|
||||
this.set_obj_no(nobj_no);
|
||||
this.set_tab(ntab);
|
||||
this.set_and_or(0);
|
||||
this.set_obj(nobj);
|
||||
this.set_column_name(ncolumn_name);
|
||||
this.set_type(ntype);
|
||||
}
|
||||
|
||||
/**
|
||||
* where object closure, makes an object with all information of where
|
||||
*
|
||||
* @param nrelation_operator type of relation operator to be applied
|
||||
* @param nquery stores value of value/sub-query
|
||||
*
|
||||
**/
|
||||
|
||||
|
||||
var where = function (nrelation_operator, nquery) {
|
||||
var relation_operator;
|
||||
var query;
|
||||
this.setrelation_operator = function (nrelation_operator) {
|
||||
relation_operator = nrelation_operator;
|
||||
};
|
||||
this.setquery = function (nquery) {
|
||||
query = nquery;
|
||||
};
|
||||
this.getquery = function () {
|
||||
return query;
|
||||
};
|
||||
this.getrelation_operator = function () {
|
||||
return relation_operator;
|
||||
};
|
||||
this.setquery(nquery);
|
||||
this.setrelation_operator(nrelation_operator);
|
||||
};
|
||||
|
||||
/**
|
||||
* Orderby object closure
|
||||
*
|
||||
* @param norder order, ASC or DESC
|
||||
*/
|
||||
var orderby = function (norder) {
|
||||
var order;
|
||||
this.set_order = function (norder) {
|
||||
order = norder;
|
||||
};
|
||||
this.get_order = function () {
|
||||
return order;
|
||||
};
|
||||
this.set_order(norder);
|
||||
};
|
||||
|
||||
/**
|
||||
* Having object closure, makes an object with all information of where
|
||||
*
|
||||
* @param nrelation_operator type of relation operator to be applied
|
||||
* @param nquery stores value of value/sub-query
|
||||
* @param noperator operator
|
||||
**/
|
||||
|
||||
var having = function (nrelation_operator, nquery, noperator) {
|
||||
var relation_operator;
|
||||
var query;
|
||||
var operator;
|
||||
this.set_operator = function (noperator) {
|
||||
operator = noperator;
|
||||
};
|
||||
this.setrelation_operator = function (nrelation_operator) {
|
||||
relation_operator = nrelation_operator;
|
||||
};
|
||||
this.setquery = function (nquery) {
|
||||
query = nquery;
|
||||
};
|
||||
this.getquery = function () {
|
||||
return query;
|
||||
};
|
||||
this.getrelation_operator = function () {
|
||||
return relation_operator;
|
||||
};
|
||||
this.get_operator = function () {
|
||||
return operator;
|
||||
};
|
||||
this.setquery(nquery);
|
||||
this.setrelation_operator(nrelation_operator);
|
||||
this.set_operator(noperator);
|
||||
};
|
||||
|
||||
/**
|
||||
* rename object closure,makes an object with all information of rename
|
||||
*
|
||||
* @param nrename_to new name information
|
||||
*
|
||||
**/
|
||||
|
||||
var rename = function (nrename_to) {
|
||||
var rename_to;
|
||||
this.setrename_to = function (nrename_to) {
|
||||
rename_to = nrename_to;
|
||||
};
|
||||
this.getrename_to = function () {
|
||||
return rename_to;
|
||||
};
|
||||
this.setrename_to(nrename_to);
|
||||
};
|
||||
|
||||
/**
|
||||
* aggregate object closure
|
||||
*
|
||||
* @param noperator aggregte operator
|
||||
*
|
||||
**/
|
||||
|
||||
var aggregate = function (noperator) {
|
||||
var operator;
|
||||
this.set_operator = function (noperator) {
|
||||
operator = noperator;
|
||||
};
|
||||
this.get_operator = function () {
|
||||
return operator;
|
||||
};
|
||||
this.set_operator(noperator);
|
||||
};
|
||||
|
||||
/**
|
||||
* This function returns unique element from an array
|
||||
*
|
||||
* @param arrayName array from which duplicate elem are to be removed.
|
||||
* @return unique array
|
||||
*/
|
||||
|
||||
function unique (arrayName) {
|
||||
var newArray = [];
|
||||
uniquetop:
|
||||
for (var i = 0; i < arrayName.length; i++) {
|
||||
for (var j = 0; j < newArray.length; j++) {
|
||||
if (newArray[j] === arrayName[i]) {
|
||||
continue uniquetop;
|
||||
}
|
||||
}
|
||||
newArray[newArray.length] = arrayName[i];
|
||||
}
|
||||
return newArray;
|
||||
}
|
||||
|
||||
/**
|
||||
* This function takes in array and a value as input and returns 1 if values is present in array
|
||||
* else returns -1
|
||||
*
|
||||
* @param arrayName array
|
||||
* @param value value which is to be searched in the array
|
||||
*/
|
||||
|
||||
function found (arrayName, value) {
|
||||
for (var i = 0; i < arrayName.length; i++) {
|
||||
if (arrayName[i] === value) {
|
||||
return 1;
|
||||
}
|
||||
}
|
||||
return -1;
|
||||
}
|
||||
|
||||
/**
|
||||
* This function concatenates two array
|
||||
*
|
||||
* @params add array elements of which are pushed in
|
||||
* @params arr array in which elements are added
|
||||
*/
|
||||
function add_array (add, arr) {
|
||||
for (var i = 0; i < add.length; i++) {
|
||||
arr.push(add[i]);
|
||||
}
|
||||
return arr;
|
||||
}
|
||||
|
||||
/* This function removes all elements present in one array from the other.
|
||||
*
|
||||
* @params rem array from which each element is removed from other array.
|
||||
* @params arr array from which elements are removed.
|
||||
*
|
||||
*/
|
||||
function remove_array (rem, arr) {
|
||||
for (var i = 0; i < rem.length; i++) {
|
||||
for (var j = 0; j < arr.length; j++) {
|
||||
if (rem[i] === arr[j]) {
|
||||
arr.splice(j, 1);
|
||||
}
|
||||
}
|
||||
}
|
||||
return arr;
|
||||
}
|
||||
|
||||
/**
|
||||
* This function builds the groupby clause from history object
|
||||
*
|
||||
*/
|
||||
|
||||
function query_groupby () {
|
||||
var i;
|
||||
var str = '';
|
||||
for (i = 0; i < history_array.length;i++) {
|
||||
if (history_array[i].get_type() === 'GroupBy') {
|
||||
str += '`' + history_array[i].get_column_name() + '`, ';
|
||||
}
|
||||
}
|
||||
str = str.substr(0, str.length - 2);
|
||||
return str;
|
||||
}
|
||||
|
||||
/**
|
||||
* This function builds the Having clause from the history object.
|
||||
*
|
||||
*/
|
||||
|
||||
function query_having () {
|
||||
var i;
|
||||
var and = '(';
|
||||
for (i = 0; i < history_array.length;i++) {
|
||||
if (history_array[i].get_type() === 'Having') {
|
||||
if (history_array[i].get_obj().get_operator() !== 'None') {
|
||||
and += history_array[i].get_obj().get_operator() + '(`' + history_array[i].get_column_name() + '`) ' + history_array[i].get_obj().getrelation_operator();
|
||||
and += ' ' + history_array[i].get_obj().getquery() + ', ';
|
||||
} else {
|
||||
and += '`' + history_array[i].get_column_name() + '` ' + history_array[i].get_obj().getrelation_operator() + ' ' + history_array[i].get_obj().getquery() + ', ';
|
||||
}
|
||||
}
|
||||
}
|
||||
if (and === '(') {
|
||||
and = '';
|
||||
} else {
|
||||
and = and.substr(0, and.length - 2) + ')';
|
||||
}
|
||||
return and;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* This function builds the orderby clause from the history object.
|
||||
*
|
||||
*/
|
||||
|
||||
function query_orderby () {
|
||||
var i;
|
||||
var str = '';
|
||||
for (i = 0; i < history_array.length;i++) {
|
||||
if (history_array[i].get_type() === 'OrderBy') {
|
||||
str += '`' + history_array[i].get_column_name() + '` ' +
|
||||
history_array[i].get_obj().get_order() + ', ';
|
||||
}
|
||||
}
|
||||
str = str.substr(0, str.length - 2);
|
||||
return str;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* This function builds the Where clause from the history object.
|
||||
*
|
||||
*/
|
||||
|
||||
function query_where () {
|
||||
var i;
|
||||
var and = '(';
|
||||
var or = '(';
|
||||
for (i = 0; i < history_array.length;i++) {
|
||||
if (history_array[i].get_type() === 'Where') {
|
||||
if (history_array[i].get_and_or() === 0) {
|
||||
and += '( `' + history_array[i].get_column_name() + '` ' + history_array[i].get_obj().getrelation_operator() + ' ' + history_array[i].get_obj().getquery() + ')';
|
||||
and += ' AND ';
|
||||
} else {
|
||||
or += '( `' + history_array[i].get_column_name() + '` ' + history_array[i].get_obj().getrelation_operator() + ' ' + history_array[i].get_obj().getquery() + ')';
|
||||
or += ' OR ';
|
||||
}
|
||||
}
|
||||
}
|
||||
if (or !== '(') {
|
||||
or = or.substring(0, (or.length - 4)) + ')';
|
||||
} else {
|
||||
or = '';
|
||||
}
|
||||
if (and !== '(') {
|
||||
and = and.substring(0, (and.length - 5)) + ')';
|
||||
} else {
|
||||
and = '';
|
||||
}
|
||||
if (or !== '') {
|
||||
and = and + ' OR ' + or + ' )';
|
||||
}
|
||||
return and;
|
||||
}
|
||||
|
||||
function check_aggregate (id_this) {
|
||||
var i;
|
||||
for (i = 0; i < history_array.length; i++) {
|
||||
var temp = '`' + history_array[i].get_tab() + '`.`' + history_array[i].get_column_name() + '`';
|
||||
if (temp === id_this && history_array[i].get_type() === 'Aggregate') {
|
||||
return history_array[i].get_obj().get_operator() + '(' + id_this + ')';
|
||||
}
|
||||
}
|
||||
return '';
|
||||
}
|
||||
|
||||
function check_rename (id_this) {
|
||||
var i;
|
||||
for (i = 0; i < history_array.length; i++) {
|
||||
var temp = '`' + history_array[i].get_tab() + '`.`' + history_array[i].get_column_name() + '`';
|
||||
if (temp === id_this && history_array[i].get_type() === 'Rename') {
|
||||
return ' AS `' + history_array[i].get_obj().getrename_to() + '`';
|
||||
}
|
||||
}
|
||||
return '';
|
||||
}
|
||||
|
||||
/**
|
||||
* This function builds from clause of query
|
||||
* makes automatic joins.
|
||||
*
|
||||
*
|
||||
*/
|
||||
function query_from () {
|
||||
var i;
|
||||
var tab_left = [];
|
||||
var tab_used = [];
|
||||
var t_tab_used = [];
|
||||
var t_tab_left = [];
|
||||
var temp;
|
||||
var query = '';
|
||||
var quer = '';
|
||||
var parts = [];
|
||||
var t_array = [];
|
||||
t_array = from_array;
|
||||
var K = 0;
|
||||
var k;
|
||||
var key;
|
||||
var key2;
|
||||
var key3;
|
||||
var parts1;
|
||||
|
||||
// the constraints that have been used in the LEFT JOIN
|
||||
var constraints_added = [];
|
||||
|
||||
for (i = 0; i < history_array.length; i++) {
|
||||
from_array.push(history_array[i].get_tab());
|
||||
}
|
||||
from_array = unique(from_array);
|
||||
tab_left = from_array;
|
||||
temp = tab_left.shift();
|
||||
quer = '`' + temp + '`';
|
||||
tab_used.push(temp);
|
||||
|
||||
// if master table (key2) matches with tab used get all keys and check if tab_left matches
|
||||
// after this check if master table (key2) matches with tab left then check if any foreign matches with master .
|
||||
for (i = 0; i < 2; i++) {
|
||||
for (K in contr) {
|
||||
for (key in contr[K]) {// contr name
|
||||
for (key2 in contr[K][key]) {// table name
|
||||
parts = key2.split('.');
|
||||
if (found(tab_used, parts[1]) > 0) {
|
||||
for (key3 in contr[K][key][key2]) {
|
||||
parts1 = contr[K][key][key2][key3][0].split('.');
|
||||
if (found(tab_left, parts1[1]) > 0) {
|
||||
if (found(constraints_added, key) > 0) {
|
||||
query += ' AND ' + '`' + parts[1] + '`.`' + key3 + '` = ';
|
||||
query += '`' + parts1[1] + '`.`' + contr[K][key][key2][key3][1] + '` ';
|
||||
} else {
|
||||
query += '\n' + 'LEFT JOIN ';
|
||||
query += '`' + parts[1] + '` ON ';
|
||||
query += '`' + parts1[1] + '`.`' + contr[K][key][key2][key3][1] + '` = ';
|
||||
query += '`' + parts[1] + '`.`' + key3 + '` ';
|
||||
|
||||
constraints_added.push(key);
|
||||
}
|
||||
t_tab_left.push(parts[1]);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
K = 0;
|
||||
t_tab_left = unique(t_tab_left);
|
||||
tab_used = add_array(t_tab_left, tab_used);
|
||||
tab_left = remove_array(t_tab_left, tab_left);
|
||||
t_tab_left = [];
|
||||
for (K in contr) {
|
||||
for (key in contr[K]) {
|
||||
for (key2 in contr[K][key]) {// table name
|
||||
parts = key2.split('.');
|
||||
if (found(tab_left, parts[1]) > 0) {
|
||||
for (key3 in contr[K][key][key2]) {
|
||||
parts1 = contr[K][key][key2][key3][0].split('.');
|
||||
if (found(tab_used, parts1[1]) > 0) {
|
||||
if (found(constraints_added, key) > 0) {
|
||||
query += ' AND ' + '`' + parts[1] + '`.`' + key3 + '` = ';
|
||||
query += '`' + parts1[1] + '`.`' + contr[K][key][key2][key3][1] + '` ';
|
||||
} else {
|
||||
query += '\n' + 'LEFT JOIN ';
|
||||
query += '`' + parts[1] + '` ON ';
|
||||
query += '`' + parts1[1] + '`.`' + contr[K][key][key2][key3][1] + '` = ';
|
||||
query += '`' + parts[1] + '`.`' + key3 + '` ';
|
||||
|
||||
constraints_added.push(key);
|
||||
}
|
||||
t_tab_left.push(parts[1]);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
t_tab_left = unique(t_tab_left);
|
||||
tab_used = add_array(t_tab_left, tab_used);
|
||||
tab_left = remove_array(t_tab_left, tab_left);
|
||||
t_tab_left = [];
|
||||
}
|
||||
for (k in tab_left) {
|
||||
quer += ' , `' + tab_left[k] + '`';
|
||||
}
|
||||
query = quer + query;
|
||||
from_array = t_array;
|
||||
return query;
|
||||
}
|
||||
|
||||
/**
|
||||
* This function is the main function for query building.
|
||||
* uses history object details for this.
|
||||
*
|
||||
* @ uses query_where()
|
||||
* @ uses query_groupby()
|
||||
* @ uses query_having()
|
||||
* @ uses query_orderby()
|
||||
*
|
||||
* @param formtitle title for the form
|
||||
* @param fadin
|
||||
*/
|
||||
|
||||
function build_query (formtitle, fadin) {
|
||||
var q_select = 'SELECT ';
|
||||
var temp;
|
||||
if (select_field.length > 0) {
|
||||
for (var i = 0; i < select_field.length; i++) {
|
||||
temp = check_aggregate(select_field[i]);
|
||||
if (temp !== '') {
|
||||
q_select += temp;
|
||||
temp = check_rename(select_field[i]);
|
||||
q_select += temp + ', ';
|
||||
} else {
|
||||
temp = check_rename(select_field[i]);
|
||||
q_select += select_field[i] + temp + ', ';
|
||||
}
|
||||
}
|
||||
q_select = q_select.substring(0, q_select.length - 2);
|
||||
} else {
|
||||
q_select += '* ';
|
||||
}
|
||||
|
||||
q_select += '\nFROM ' + query_from();
|
||||
|
||||
var q_where = query_where();
|
||||
if (q_where !== '') {
|
||||
q_select += '\nWHERE ' + q_where;
|
||||
}
|
||||
|
||||
var q_groupby = query_groupby();
|
||||
if (q_groupby !== '') {
|
||||
q_select += '\nGROUP BY ' + q_groupby;
|
||||
}
|
||||
|
||||
var q_having = query_having();
|
||||
if (q_having !== '') {
|
||||
q_select += '\nHAVING ' + q_having;
|
||||
}
|
||||
|
||||
var q_orderby = query_orderby();
|
||||
if (q_orderby !== '') {
|
||||
q_select += '\nORDER BY ' + q_orderby;
|
||||
}
|
||||
|
||||
/**
|
||||
* @var button_options Object containing options
|
||||
* for jQueryUI dialog buttons
|
||||
*/
|
||||
var button_options = {};
|
||||
button_options[PMA_messages.strClose] = function () {
|
||||
$(this).dialog('close');
|
||||
};
|
||||
button_options[PMA_messages.strSubmit] = function () {
|
||||
if (vqb_editor) {
|
||||
var $elm = $ajaxDialog.find('textarea');
|
||||
vqb_editor.save();
|
||||
$elm.val(vqb_editor.getValue());
|
||||
}
|
||||
$('#vqb_form').submit();
|
||||
};
|
||||
|
||||
var $ajaxDialog = $('#box').dialog({
|
||||
appendTo: '#page_content',
|
||||
width: 500,
|
||||
buttons: button_options,
|
||||
modal: true,
|
||||
title: 'SELECT'
|
||||
});
|
||||
// Attach syntax highlighted editor to query dialog
|
||||
/**
|
||||
* @var $elm jQuery object containing the reference
|
||||
* to the query textarea.
|
||||
*/
|
||||
var $elm = $ajaxDialog.find('textarea');
|
||||
if (! vqb_editor) {
|
||||
vqb_editor = PMA_getSQLEditor($elm);
|
||||
}
|
||||
if (vqb_editor) {
|
||||
vqb_editor.setValue(q_select);
|
||||
vqb_editor.focus();
|
||||
} else {
|
||||
$elm.val(q_select);
|
||||
$elm.focus();
|
||||
}
|
||||
}
|
||||
|
||||
AJAX.registerTeardown('designer/history.js', function () {
|
||||
vqb_editor = null;
|
||||
history_array = [];
|
||||
select_field = [];
|
||||
$('#ok_edit_rename').off('click');
|
||||
$('#ok_edit_having').off('click');
|
||||
$('#ok_edit_Aggr').off('click');
|
||||
$('#ok_edit_where').off('click');
|
||||
});
|
||||
|
||||
AJAX.registerOnload('designer/history.js', function () {
|
||||
$('#ok_edit_rename').click(function () {
|
||||
edit('Rename');
|
||||
});
|
||||
$('#ok_edit_having').click(function () {
|
||||
edit('Having');
|
||||
});
|
||||
$('#ok_edit_Aggr').click(function () {
|
||||
edit('Aggregate');
|
||||
});
|
||||
$('#ok_edit_where').click(function () {
|
||||
edit('Where');
|
||||
});
|
||||
$('#ab').accordion({ collapsible : true, active : 'none' });
|
||||
});
|
||||
66
phpMyAdmin/js/designer/init.js
Executable file
66
phpMyAdmin/js/designer/init.js
Executable file
@@ -0,0 +1,66 @@
|
||||
/* vim: set expandtab sw=4 ts=4 sts=4: */
|
||||
/**
|
||||
* Initialises the data required to run Designer, then fires it up.
|
||||
*/
|
||||
|
||||
var j_tabs;
|
||||
var h_tabs;
|
||||
var contr;
|
||||
var display_field;
|
||||
var server;
|
||||
var db;
|
||||
var selected_page;
|
||||
var designer_tables_enabled;
|
||||
|
||||
AJAX.registerTeardown('designer/init.js', function () {
|
||||
$('.trigger').off('click');
|
||||
});
|
||||
|
||||
AJAX.registerOnload('designer/init.js', function () {
|
||||
$('.trigger').click(function () {
|
||||
$('.panel').toggle('fast');
|
||||
$(this).toggleClass('active');
|
||||
$('#ab').accordion('refresh');
|
||||
return false;
|
||||
});
|
||||
|
||||
j_tabs = designer_config.scriptTables.j_tabs;
|
||||
h_tabs = designer_config.scriptTables.h_tabs;
|
||||
contr = designer_config.scriptContr;
|
||||
display_field = designer_config.scriptDisplayField;
|
||||
|
||||
server = designer_config.server;
|
||||
db = designer_config.db;
|
||||
selected_page = designer_config.displayPage;
|
||||
designer_tables_enabled = designer_config.tablesEnabled;
|
||||
|
||||
Main();
|
||||
|
||||
if (! designer_tables_enabled) {
|
||||
DesignerOfflineDB.open(function (success) {
|
||||
if (success) {
|
||||
Show_tables_in_landing_page(db);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
$('#query_Aggregate_Button').click(function () {
|
||||
document.getElementById('query_Aggregate').style.display = 'none';
|
||||
});
|
||||
|
||||
$('#query_having_button').click(function () {
|
||||
document.getElementById('query_having').style.display = 'none';
|
||||
});
|
||||
|
||||
$('#query_rename_to_button').click(function () {
|
||||
document.getElementById('query_rename_to').style.display = 'none';
|
||||
});
|
||||
|
||||
$('#build_query_button').click(function () {
|
||||
build_query('SQL Query on Database', 0);
|
||||
});
|
||||
|
||||
$('#query_where_button').click(function () {
|
||||
document.getElementById('query_where').style.display = 'none';
|
||||
});
|
||||
});
|
||||
2232
phpMyAdmin/js/designer/move.js
Executable file
2232
phpMyAdmin/js/designer/move.js
Executable file
File diff suppressed because it is too large
Load Diff
19
phpMyAdmin/js/designer/objects.js
Executable file
19
phpMyAdmin/js/designer/objects.js
Executable file
@@ -0,0 +1,19 @@
|
||||
function PDFPage (db_name, page_descr, tbl_cords) {
|
||||
// no dot set the auto increment before put() in the database
|
||||
// issue #12900
|
||||
// this.pg_nr = null;
|
||||
this.db_name = db_name;
|
||||
this.page_descr = page_descr;
|
||||
this.tbl_cords = tbl_cords;
|
||||
}
|
||||
|
||||
function TableCoordinate (db_name, table_name, pdf_pg_nr, x, y) {
|
||||
// no dot set the auto increment before put() in the database
|
||||
// issue #12900
|
||||
// this.id = null;
|
||||
this.db_name = db_name;
|
||||
this.table_name = table_name;
|
||||
this.pdf_pg_nr = pdf_pg_nr;
|
||||
this.x = x;
|
||||
this.y = y;
|
||||
}
|
||||
160
phpMyAdmin/js/designer/page.js
Executable file
160
phpMyAdmin/js/designer/page.js
Executable file
@@ -0,0 +1,160 @@
|
||||
function Show_tables_in_landing_page (db) {
|
||||
Load_first_page(db, function (page) {
|
||||
if (page) {
|
||||
Load_HTML_for_page(page.pg_nr);
|
||||
selected_page = page.pg_nr;
|
||||
} else {
|
||||
Show_new_page_tables(true);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
function Save_to_new_page (db, page_name, table_positions, callback) {
|
||||
Create_new_page(db, page_name, function (page) {
|
||||
if (page) {
|
||||
var tbl_cords = [];
|
||||
for (var pos = 0; pos < table_positions.length; pos++) {
|
||||
table_positions[pos].pdf_pg_nr = page.pg_nr;
|
||||
Save_table_positions(table_positions[pos], function (id) {
|
||||
tbl_cords.push(id);
|
||||
if (table_positions.length === tbl_cords.length) {
|
||||
page.tbl_cords = tbl_cords;
|
||||
DesignerOfflineDB.addObject('pdf_pages', page);
|
||||
}
|
||||
});
|
||||
}
|
||||
if (typeof callback !== 'undefined') {
|
||||
callback(page);
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
function Save_to_selected_page (db, page_id, page_name, table_positions, callback) {
|
||||
Delete_page(page_id);
|
||||
Save_to_new_page(db, page_name, table_positions, function (page) {
|
||||
if (typeof callback !== 'undefined') {
|
||||
callback(page);
|
||||
}
|
||||
selected_page = page.pg_nr;
|
||||
});
|
||||
}
|
||||
|
||||
function Create_new_page (db, page_name, callback) {
|
||||
var newPage = new PDFPage(db, page_name);
|
||||
DesignerOfflineDB.addObject('pdf_pages', newPage, function (pg_nr) {
|
||||
newPage.pg_nr = pg_nr;
|
||||
if (typeof callback !== 'undefined') {
|
||||
callback(newPage);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
function Save_table_positions (positions, callback) {
|
||||
DesignerOfflineDB.addObject('table_coords', positions, callback);
|
||||
}
|
||||
|
||||
function Create_page_list (db, callback) {
|
||||
DesignerOfflineDB.loadAllObjects('pdf_pages', function (pages) {
|
||||
var html = '';
|
||||
for (var p = 0; p < pages.length; p++) {
|
||||
var page = pages[p];
|
||||
if (page.db_name === db) {
|
||||
html += '<option value="' + page.pg_nr + '">';
|
||||
html += escapeHtml(page.page_descr) + '</option>';
|
||||
}
|
||||
}
|
||||
if (typeof callback !== 'undefined') {
|
||||
callback(html);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
function Delete_page (page_id, callback) {
|
||||
DesignerOfflineDB.loadObject('pdf_pages', page_id, function (page) {
|
||||
if (page) {
|
||||
for (var i = 0; i < page.tbl_cords.length; i++) {
|
||||
DesignerOfflineDB.deleteObject('table_coords', page.tbl_cords[i]);
|
||||
}
|
||||
DesignerOfflineDB.deleteObject('pdf_pages', page_id, callback);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
function Load_first_page (db, callback) {
|
||||
DesignerOfflineDB.loadAllObjects('pdf_pages', function (pages) {
|
||||
var firstPage = null;
|
||||
for (var i = 0; i < pages.length; i++) {
|
||||
var page = pages[i];
|
||||
if (page.db_name === db) {
|
||||
// give preference to a page having same name as the db
|
||||
if (page.page_descr === db) {
|
||||
callback(page);
|
||||
return;
|
||||
}
|
||||
if (firstPage === null) {
|
||||
firstPage = page;
|
||||
}
|
||||
}
|
||||
}
|
||||
callback(firstPage);
|
||||
});
|
||||
}
|
||||
|
||||
function Show_new_page_tables (check) {
|
||||
var all_tables = $('#id_scroll_tab').find('td input:checkbox');
|
||||
all_tables.prop('checked', check);
|
||||
for (var tab = 0; tab < all_tables.length; tab++) {
|
||||
var input = all_tables[tab];
|
||||
if (input.value) {
|
||||
var element = document.getElementById(input.value);
|
||||
element.style.top = Get_random(550, 20) + 'px';
|
||||
element.style.left = Get_random(700, 20) + 'px';
|
||||
VisibleTab(input, input.value);
|
||||
}
|
||||
}
|
||||
selected_page = -1;
|
||||
$('#page_name').text(PMA_messages.strUntitled);
|
||||
MarkUnsaved();
|
||||
}
|
||||
|
||||
function Load_HTML_for_page (page_id) {
|
||||
Show_new_page_tables(false);
|
||||
Load_page_objects(page_id, function (page, tbl_cords) {
|
||||
$('#name-panel').find('#page_name').text(page.page_descr);
|
||||
MarkSaved();
|
||||
for (var t = 0; t < tbl_cords.length; t++) {
|
||||
var tb_id = db + '.' + tbl_cords[t].table_name;
|
||||
var table = document.getElementById(tb_id);
|
||||
table.style.top = tbl_cords[t].y + 'px';
|
||||
table.style.left = tbl_cords[t].x + 'px';
|
||||
|
||||
var checkbox = document.getElementById('check_vis_' + tb_id);
|
||||
checkbox.checked = true;
|
||||
VisibleTab(checkbox, checkbox.value);
|
||||
}
|
||||
selected_page = page.pg_nr;
|
||||
});
|
||||
}
|
||||
|
||||
function Load_page_objects (page_id, callback) {
|
||||
DesignerOfflineDB.loadObject('pdf_pages', page_id, function (page) {
|
||||
var tbl_cords = [];
|
||||
var count = page.tbl_cords.length;
|
||||
for (var i = 0; i < count; i++) {
|
||||
DesignerOfflineDB.loadObject('table_coords', page.tbl_cords[i], function (tbl_cord) {
|
||||
tbl_cords.push(tbl_cord);
|
||||
if (tbl_cords.length === count) {
|
||||
if (typeof callback !== 'undefined') {
|
||||
callback(page, tbl_cords);
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
function Get_random (max, min) {
|
||||
var val = Math.random() * (max - min) + min;
|
||||
return Math.floor(val);
|
||||
}
|
||||
Reference in New Issue
Block a user