1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003 |
- "use strict";
- /**
- * @fileoverview function used in this file builds history tab and generates query.
- *
- * @requires jQuery
- * @requires move.js
- * @version $Id$
- */
- /* global contr */
- // js/designer/init.js
- /* global fromArray:writable */
- // js/designer/move.js
- /* global themeImagePath */
- // templates/javascript/variables.twig
- var DesignerHistory = {};
- var historyArray = []; // Global array to store history objects
- var selectField = []; // Global array to store information for columns which are used in select clause
- var gIndex;
- var vqbEditor = null;
- /**
- * To display details of objects(where,rename,Having,aggregate,groupby,orderby,having)
- *
- * @param index index of historyArray where change is to be made
- *
- **/
- DesignerHistory.detail = function (index) {
- var type = historyArray[index].getType();
- var str;
- if (type === 'Where') {
- str = 'Where ' + historyArray[index].getColumnName() + historyArray[index].getObj().getRelationOperator() + historyArray[index].getObj().getQuery();
- }
- if (type === 'Rename') {
- str = 'Rename ' + historyArray[index].getColumnName() + ' To ' + historyArray[index].getObj().getRenameTo();
- }
- if (type === 'Aggregate') {
- str = 'Select ' + historyArray[index].getObj().getOperator() + '( ' + historyArray[index].getColumnName() + ' )';
- }
- if (type === 'GroupBy') {
- str = 'GroupBy ' + historyArray[index].getColumnName();
- }
- if (type === 'OrderBy') {
- str = 'OrderBy ' + historyArray[index].getColumnName() + ' ' + historyArray[index].getObj().getOrder();
- }
- if (type === 'Having') {
- str = 'Having ';
- if (historyArray[index].getObj().getOperator() !== 'None') {
- str += historyArray[index].getObj().getOperator() + '( ' + historyArray[index].getColumnName() + ' )';
- str += historyArray[index].getObj().getRelationOperator() + historyArray[index].getObj().getQuery();
- } else {
- str = 'Having ' + historyArray[index].getColumnName() + historyArray[index].getObj().getRelationOperator() + historyArray[index].getObj().getQuery();
- }
- }
- return str;
- };
- /**
- * Sorts historyArray[] 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 historyArray[]
- *
- *
- * @param {int} init starting index of unsorted array
- * @param {int} finit last index of unsorted array
- *
- **/
- DesignerHistory.display = function (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 = historyArray[i];
- temp = historyArray[i].getTab(); // + '.' + historyArray[i].getObjNo(); for Self JOINS
- for (j = 0; j < i; j++) {
- if (temp > historyArray[j].getTab()) {
- // + '.' + historyArray[j].getObjNo())) { //for Self JOINS
- for (k = i; k > j; k--) {
- historyArray[k] = historyArray[k - 1];
- }
- historyArray[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
- var historyArrayLength = historyArray.length;
- for (i = 0; i < historyArrayLength; i++) {
- temp = historyArray[i].getTab(); // + '.' + historyArray[i].getObjNo(); for Self JOIN
- str += '<h3 class="tiger"><a href="#">' + temp + '</a></h3>';
- str += '<div class="toggle_container">\n';
- while (historyArray[i].getTab() === temp) {
- // + '.' + historyArray[i].getObjNo()) === temp) {
- str += '<div class="block"> <table class="pma-table" width ="250">';
- str += '<thead><tr><td>';
- if (historyArray[i].getAndOr()) {
- str += '<img src="' + themeImagePath + 'designer/or_icon.png" onclick="DesignerHistory.andOr(' + i + ')" title="OR"></td>';
- } else {
- str += '<img src="' + themeImagePath + 'designer/and_icon.png" onclick="DesignerHistory.andOr(' + i + ')" title="AND"></td>';
- }
- str += '<td style="padding-left: 5px;" class="right">' + Functions.getImage('b_sbrowse', Messages.strColumnName) + '</td>' + '<td width="175" style="padding-left: 5px">' + $('<div/>').text(historyArray[i].getColumnName()).html() + '<td>';
- if (historyArray[i].getType() === 'GroupBy' || historyArray[i].getType() === 'OrderBy') {
- var detailDescGroupBy = $('<div/>').text(DesignerHistory.detail(i)).html();
- str += '<td class="text-center">' + Functions.getImage('s_info', DesignerHistory.detail(i)) + '</td>' + '<td title="' + detailDescGroupBy + '">' + historyArray[i].getType() + '</td>' + '<td onclick=DesignerHistory.historyDelete(' + i + ')>' + Functions.getImage('b_drop', Messages.strDelete) + '</td>';
- } else {
- var detailDesc = $('<div/>').text(DesignerHistory.detail(i)).html();
- str += '<td class="text-center">' + Functions.getImage('s_info', DesignerHistory.detail(i)) + '</td>' + '<td title="' + detailDesc + '">' + historyArray[i].getType() + '</td>' + '<td onclick=DesignerHistory.historyEdit(' + i + ')>' + Functions.getImage('b_edit', Messages.strEdit) + '</td>' + '<td onclick=DesignerHistory.historyDelete(' + i + ')>' + Functions.getImage('b_drop', Messages.strDelete) + '</td>';
- }
- str += '</tr></thead>';
- i++;
- if (i >= historyArrayLength) {
- break;
- }
- str += '</table></div>';
- }
- i--;
- str += '</div>';
- }
- return str;
- };
- /**
- * To change And/Or relation in history tab
- *
- *
- * @param {int} index of historyArray where change is to be made
- *
- **/
- DesignerHistory.andOr = function (index) {
- if (historyArray[index].getAndOr()) {
- historyArray[index].setAndOr(0);
- } else {
- historyArray[index].setAndOr(1);
- }
- var existingDiv = document.getElementById('ab');
- existingDiv.innerHTML = DesignerHistory.display(0, 0);
- $('#ab').accordion('refresh');
- };
- /**
- * Deletes entry in historyArray
- *
- * @param index index of historyArray[] which is to be deleted
- *
- **/
- DesignerHistory.historyDelete = function (index) {
- var fromArrayLength = fromArray.length;
- for (var k = 0; k < fromArrayLength; k++) {
- if (fromArray[k] === historyArray[index].getTab()) {
- fromArray.splice(k, 1);
- break;
- }
- }
- historyArray.splice(index, 1);
- var existingDiv = document.getElementById('ab');
- existingDiv.innerHTML = DesignerHistory.display(0, 0);
- $('#ab').accordion('refresh');
- };
- /**
- * To show where,rename,aggregate,having forms to edit a object
- *
- * @param{int} index index of historyArray where change is to be made
- *
- **/
- DesignerHistory.historyEdit = function (index) {
- gIndex = index;
- var type = historyArray[index].getType();
- if (type === 'Where') {
- document.getElementById('eQuery').value = historyArray[index].getObj().getQuery();
- document.getElementById('erel_opt').value = historyArray[index].getObj().getRelationOperator();
- 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 = historyArray[index].getObj().getQuery();
- document.getElementById('hrel_opt').value = historyArray[index].getObj().getRelationOperator();
- document.getElementById('hoperator').value = historyArray[index].getObj().getOperator();
- 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 = historyArray[index].getObj().getRenameTo();
- 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 = historyArray[index].getObj().getOperator();
- 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 historyArray when Edit button is clicked
- * checks for the type of object and then sets the new value
- *
- * @param index index of historyArray where change is to be made
- **/
- DesignerHistory.edit = function (type) {
- if (type === 'Rename') {
- if (document.getElementById('e_rename').value !== '') {
- historyArray[gIndex].getObj().setRenameTo(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 !== '---') {
- historyArray[gIndex].getObj().setOperator(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 !== '') {
- historyArray[gIndex].getObj().setQuery(document.getElementById('eQuery').value);
- historyArray[gIndex].getObj().setRelationOperator(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 !== '') {
- historyArray[gIndex].getObj().setQuery(document.getElementById('hQuery').value);
- historyArray[gIndex].getObj().setRelationOperator(document.getElementById('hrel_opt').value);
- historyArray[gIndex].getObj().setOperator(document.getElementById('hoperator').value);
- }
- document.getElementById('query_having').style.visibility = 'hidden';
- }
- var existingDiv = document.getElementById('ab');
- existingDiv.innerHTML = DesignerHistory.display(0, 0);
- $('#ab').accordion('refresh');
- };
- /**
- * history object closure
- *
- * @param nColumnName 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 nObjNo object no used for inner join
- * @param nType type of object
- *
- **/
- DesignerHistory.HistoryObj = function (nColumnName, nObj, nTab, nObjNo, nType) {
- var andOr;
- var obj;
- var tab;
- var columnName;
- var objNo;
- var type;
- this.setColumnName = function (nColumnName) {
- columnName = nColumnName;
- };
- this.getColumnName = function () {
- return columnName;
- };
- this.setAndOr = function (nAndOr) {
- andOr = nAndOr;
- };
- this.getAndOr = function () {
- return andOr;
- };
- this.getRelation = function () {
- return andOr;
- };
- this.setObj = function (nObj) {
- obj = nObj;
- };
- this.getObj = function () {
- return obj;
- };
- this.setTab = function (nTab) {
- tab = nTab;
- };
- this.getTab = function () {
- return tab;
- };
- this.setObjNo = function (nObjNo) {
- objNo = nObjNo;
- };
- this.getObjNo = function () {
- return objNo;
- };
- this.setType = function (nType) {
- type = nType;
- };
- this.getType = function () {
- return type;
- };
- this.setObjNo(nObjNo);
- this.setTab(nTab);
- this.setAndOr(0);
- this.setObj(nObj);
- this.setColumnName(nColumnName);
- this.setType(nType);
- };
- /**
- * where object closure, makes an object with all information of where
- *
- * @param nRelationOperator type of relation operator to be applied
- * @param nQuery stores value of value/sub-query
- *
- **/
- DesignerHistory.Where = function (nRelationOperator, nQuery) {
- var relationOperator;
- var query;
- this.setRelationOperator = function (nRelationOperator) {
- relationOperator = nRelationOperator;
- };
- this.setQuery = function (nQuery) {
- query = nQuery;
- };
- this.getQuery = function () {
- return query;
- };
- this.getRelationOperator = function () {
- return relationOperator;
- };
- this.setQuery(nQuery);
- this.setRelationOperator(nRelationOperator);
- };
- /**
- * Orderby object closure
- *
- * @param nOrder order, ASC or DESC
- */
- DesignerHistory.OrderBy = function (nOrder) {
- var order;
- this.setOrder = function (nOrder) {
- order = nOrder;
- };
- this.getOrder = function () {
- return order;
- };
- this.setOrder(nOrder);
- };
- /**
- * Having object closure, makes an object with all information of where
- *
- * @param nRelationOperator type of relation operator to be applied
- * @param nQuery stores value of value/sub-query
- * @param nOperator operator
- **/
- DesignerHistory.Having = function (nRelationOperator, nQuery, nOperator) {
- var relationOperator;
- var query;
- var operator;
- this.setOperator = function (nOperator) {
- operator = nOperator;
- };
- this.setRelationOperator = function (nRelationOperator) {
- relationOperator = nRelationOperator;
- };
- this.setQuery = function (nQuery) {
- query = nQuery;
- };
- this.getQuery = function () {
- return query;
- };
- this.getRelationOperator = function () {
- return relationOperator;
- };
- this.getOperator = function () {
- return operator;
- };
- this.setQuery(nQuery);
- this.setRelationOperator(nRelationOperator);
- this.setOperator(nOperator);
- };
- /**
- * rename object closure,makes an object with all information of rename
- *
- * @param nRenameTo new name information
- *
- **/
- DesignerHistory.Rename = function (nRenameTo) {
- var renameTo;
- this.setRenameTo = function (nRenameTo) {
- renameTo = nRenameTo;
- };
- this.getRenameTo = function () {
- return renameTo;
- };
- this.setRenameTo(nRenameTo);
- };
- /**
- * aggregate object closure
- *
- * @param nOperator aggregte operator
- *
- **/
- DesignerHistory.Aggregate = function (nOperator) {
- var operator;
- this.setOperator = function (nOperator) {
- operator = nOperator;
- };
- this.getOperator = function () {
- return operator;
- };
- this.setOperator(nOperator);
- };
- /**
- * This function returns unique element from an array
- *
- * @param arrayName array from which duplicate elem are to be removed.
- * @return unique array
- */
- DesignerHistory.unique = function (arrayName) {
- var newArray = [];
- uniquetop: for (var i = 0; i < arrayName.length; i++) {
- var newArrayLength = newArray.length;
- for (var j = 0; j < newArrayLength; j++) {
- if (newArray[j] === arrayName[i]) {
- continue uniquetop;
- }
- }
- newArray[newArrayLength] = 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
- */
- DesignerHistory.found = function (arrayName, value) {
- var arrayNameLength = arrayName.length;
- for (var i = 0; i < arrayNameLength; 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
- */
- DesignerHistory.addArray = function (add, arr) {
- var addLength = add.length;
- for (var i = 0; i < addLength; 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.
- *
- */
- DesignerHistory.removeArray = function (rem, arr) {
- var remLength = rem.length;
- for (var i = 0; i < remLength; i++) {
- var arrLength = arr.length;
- for (var j = 0; j < arrLength; j++) {
- if (rem[i] === arr[j]) {
- arr.splice(j, 1);
- }
- }
- }
- return arr;
- };
- /**
- * This function builds the groupby clause from history object
- *
- */
- DesignerHistory.queryGroupBy = function () {
- var i;
- var str = '';
- var historyArrayLength = historyArray.length;
- for (i = 0; i < historyArrayLength; i++) {
- if (historyArray[i].getType() === 'GroupBy') {
- str += '`' + historyArray[i].getColumnName() + '`, ';
- }
- }
- str = str.substr(0, str.length - 2);
- return str;
- };
- /**
- * This function builds the Having clause from the history object.
- *
- */
- DesignerHistory.queryHaving = function () {
- var i;
- var and = '(';
- var historyArrayLength = historyArray.length;
- for (i = 0; i < historyArrayLength; i++) {
- if (historyArray[i].getType() === 'Having') {
- if (historyArray[i].getObj().getOperator() !== 'None') {
- and += historyArray[i].getObj().getOperator() + '(`' + historyArray[i].getColumnName() + '`) ' + historyArray[i].getObj().getRelationOperator();
- and += ' ' + historyArray[i].getObj().getQuery() + ', ';
- } else {
- and += '`' + historyArray[i].getColumnName() + '` ' + historyArray[i].getObj().getRelationOperator() + ' ' + historyArray[i].getObj().getQuery() + ', ';
- }
- }
- }
- if (and === '(') {
- and = '';
- } else {
- and = and.substr(0, and.length - 2) + ')';
- }
- return and;
- };
- /**
- * This function builds the orderby clause from the history object.
- *
- */
- DesignerHistory.queryOrderBy = function () {
- var i;
- var str = '';
- var historyArrayLength = historyArray.length;
- for (i = 0; i < historyArrayLength; i++) {
- if (historyArray[i].getType() === 'OrderBy') {
- str += '`' + historyArray[i].getColumnName() + '` ' + historyArray[i].getObj().getOrder() + ', ';
- }
- }
- str = str.substr(0, str.length - 2);
- return str;
- };
- /**
- * This function builds the Where clause from the history object.
- *
- */
- DesignerHistory.queryWhere = function () {
- var i;
- var and = '(';
- var or = '(';
- var historyArrayLength = historyArray.length;
- for (i = 0; i < historyArrayLength; i++) {
- if (historyArray[i].getType() === 'Where') {
- if (historyArray[i].getAndOr() === 0) {
- and += '( `' + historyArray[i].getColumnName() + '` ' + historyArray[i].getObj().getRelationOperator() + ' ' + historyArray[i].getObj().getQuery() + ')';
- and += ' AND ';
- } else {
- or += '( `' + historyArray[i].getColumnName() + '` ' + historyArray[i].getObj().getRelationOperator() + ' ' + historyArray[i].getObj().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;
- };
- DesignerHistory.checkAggregate = function (idThis) {
- var i;
- var historyArrayLength = historyArray.length;
- for (i = 0; i < historyArrayLength; i++) {
- var temp = '`' + historyArray[i].getTab() + '`.`' + historyArray[i].getColumnName() + '`';
- if (temp === idThis && historyArray[i].getType() === 'Aggregate') {
- return historyArray[i].getObj().getOperator() + '(' + idThis + ')';
- }
- }
- return '';
- };
- DesignerHistory.checkRename = function (idThis) {
- var i;
- var historyArrayLength = historyArray.length;
- for (i = 0; i < historyArrayLength; i++) {
- var temp = '`' + historyArray[i].getTab() + '`.`' + historyArray[i].getColumnName() + '`';
- if (temp === idThis && historyArray[i].getType() === 'Rename') {
- return ' AS `' + historyArray[i].getObj().getRenameTo() + '`';
- }
- }
- return '';
- };
- /**
- * This function builds from clause of query
- * makes automatic joins.
- *
- *
- */
- DesignerHistory.queryFrom = function () {
- var i;
- var tabLeft = [];
- var tabUsed = [];
- var tTabLeft = [];
- var temp;
- var query = '';
- var quer = '';
- var parts = [];
- var tArray = [];
- tArray = fromArray;
- var K = 0;
- var k;
- var key;
- var key2;
- var key3;
- var parts1; // the constraints that have been used in the LEFT JOIN
- var constraintsAdded = [];
- var historyArrayLength = historyArray.length;
- for (i = 0; i < historyArrayLength; i++) {
- fromArray.push(historyArray[i].getTab());
- }
- fromArray = DesignerHistory.unique(fromArray);
- tabLeft = fromArray;
- temp = tabLeft.shift();
- quer = '`' + temp + '`';
- tabUsed.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 (DesignerHistory.found(tabUsed, parts[1]) > 0) {
- for (key3 in contr[K][key][key2]) {
- parts1 = contr[K][key][key2][key3][0].split('.');
- if (DesignerHistory.found(tabLeft, parts1[1]) > 0) {
- if (DesignerHistory.found(constraintsAdded, 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 + '` ';
- constraintsAdded.push(key);
- }
- tTabLeft.push(parts[1]);
- }
- }
- }
- }
- }
- }
- K = 0;
- tTabLeft = DesignerHistory.unique(tTabLeft);
- tabUsed = DesignerHistory.addArray(tTabLeft, tabUsed);
- tabLeft = DesignerHistory.removeArray(tTabLeft, tabLeft);
- tTabLeft = [];
- for (K in contr) {
- for (key in contr[K]) {
- for (key2 in contr[K][key]) {
- // table name
- parts = key2.split('.');
- if (DesignerHistory.found(tabLeft, parts[1]) > 0) {
- for (key3 in contr[K][key][key2]) {
- parts1 = contr[K][key][key2][key3][0].split('.');
- if (DesignerHistory.found(tabUsed, parts1[1]) > 0) {
- if (DesignerHistory.found(constraintsAdded, 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 + '` ';
- constraintsAdded.push(key);
- }
- tTabLeft.push(parts[1]);
- }
- }
- }
- }
- }
- }
- tTabLeft = DesignerHistory.unique(tTabLeft);
- tabUsed = DesignerHistory.addArray(tTabLeft, tabUsed);
- tabLeft = DesignerHistory.removeArray(tTabLeft, tabLeft);
- tTabLeft = [];
- }
- for (k in tabLeft) {
- quer += ' , `' + tabLeft[k] + '`';
- }
- query = quer + query;
- fromArray = tArray;
- return query;
- };
- /**
- * This function is the main function for query building.
- * uses history object details for this.
- *
- * @uses DesignerHistory.queryWhere()
- * @uses DesignerHistory.queryGroupBy()
- * @uses DesignerHistory.queryHaving()
- * @uses DesignerHistory.queryOrderBy()
- */
- DesignerHistory.buildQuery = function () {
- var qSelect = 'SELECT ';
- var temp;
- var selectFieldLength = selectField.length;
- if (selectFieldLength > 0) {
- for (var i = 0; i < selectFieldLength; i++) {
- temp = DesignerHistory.checkAggregate(selectField[i]);
- if (temp !== '') {
- qSelect += temp;
- temp = DesignerHistory.checkRename(selectField[i]);
- qSelect += temp + ', ';
- } else {
- temp = DesignerHistory.checkRename(selectField[i]);
- qSelect += selectField[i] + temp + ', ';
- }
- }
- qSelect = qSelect.substring(0, qSelect.length - 2);
- } else {
- qSelect += '* ';
- }
- qSelect += '\nFROM ' + DesignerHistory.queryFrom();
- var qWhere = DesignerHistory.queryWhere();
- if (qWhere !== '') {
- qSelect += '\nWHERE ' + qWhere;
- }
- var qGroupBy = DesignerHistory.queryGroupBy();
- if (qGroupBy !== '') {
- qSelect += '\nGROUP BY ' + qGroupBy;
- }
- var qHaving = DesignerHistory.queryHaving();
- if (qHaving !== '') {
- qSelect += '\nHAVING ' + qHaving;
- }
- var qOrderBy = DesignerHistory.queryOrderBy();
- if (qOrderBy !== '') {
- qSelect += '\nORDER BY ' + qOrderBy;
- }
- /**
- * @var button_options Object containing options
- * for jQueryUI dialog buttons
- */
- var buttonOptions = {};
- buttonOptions[Messages.strClose] = function () {
- $(this).dialog('close');
- };
- buttonOptions[Messages.strSubmit] = function () {
- if (vqbEditor) {
- var $elm = $ajaxDialog.find('textarea');
- vqbEditor.save();
- $elm.val(vqbEditor.getValue());
- }
- $('#vqb_form').trigger('submit');
- };
- var $ajaxDialog = $('#box').dialog({
- appendTo: '#page_content',
- width: 500,
- buttons: buttonOptions,
- 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 (!vqbEditor) {
- vqbEditor = Functions.getSqlEditor($elm);
- }
- if (vqbEditor) {
- vqbEditor.setValue(qSelect);
- vqbEditor.focus();
- } else {
- $elm.val(qSelect);
- $elm.trigger('focus');
- }
- };
- AJAX.registerTeardown('designer/history.js', function () {
- vqbEditor = null;
- historyArray = [];
- selectField = [];
- $('#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').on('click', function () {
- DesignerHistory.edit('Rename');
- });
- $('#ok_edit_having').on('click', function () {
- DesignerHistory.edit('Having');
- });
- $('#ok_edit_Aggr').on('click', function () {
- DesignerHistory.edit('Aggregate');
- });
- $('#ok_edit_where').on('click', function () {
- DesignerHistory.edit('Where');
- });
- $('#ab').accordion({
- collapsible: true,
- active: 'none'
- });
- });
|