多维表格
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

231 lines
5.8 KiB

import axios from 'axios';
import SqlQueryParser from '../helpers/SqlQueryParser'
export const state = () => ({
/**
*
* type : SELECT, INSERT, UPDATE, CREATE, DELETE, DROP
*
* query :
*
*
* response :
* status : 0 / -1
*
*/
list: [{
type: 'SELECT',
query: 'SELECT 1',
response: {status: 0}
}],
clipboardQuery: null,
// editors: ['', '', '']
editors: [
{
type: 'temp',
code: '',
fileName: null,
filePath: null,
edited: false
}, {
type: 'temp',
code: '',
fileName: null,
filePath: null,
edited: false
}, {
type: 'temp',
code: '',
fileName: null,
filePath: null,
edited: false
},
],
sqlFilePaths: [],
projectSqlFilePaths: {},
currentProjectKey: ''
});
export const mutations = {
MutSqlFilePathsAdd(state, args) {
state.projectSqlFilePaths = {
...state.projectSqlFilePaths,
[state.currentProjectKey]: [...state.projectSqlFilePaths[state.currentProjectKey], args]
}
},
MutSqlFilePathsRemove(state, index) {
state.projectSqlFilePaths[state.currentProjectKey].splice(index, 1);
state.projectSqlFilePaths[state.currentProjectKey] = [...state.projectSqlFilePaths[state.currentProjectKey]];
},
MutList(state, list) {
state.projectSqlFilePaths[state.currentProjectKey] = list;
},
MutCurrentProjectKey(state, currentProjectKey) {
state.currentProjectKey = currentProjectKey;
},
MutListAdd(state, args) {
state.list.unshift(args);
if (state.list.length > 500) state.list.pop();
},
MutListRemove(state, index) {
// find index and set status
state.list.splice(index, 1);
state.list = [...state.list]
},
MutListRemoveItem(state, item) {
state.list = state.list.filter(query => item.query !== query.query)
},
MutSetClipboardQuery(state, clipboardQuery) {
state.clipboardQuery = clipboardQuery;
},
MutSetEditorByIndex(state, {editor, index}) {
state.editors[index] = editor;
state.editors = [...state.editors];
},
MutSetEditors(state, editors) {
state.editors = editors.map(editor => ({...editor}));
}
};
export const getters = {
GtrCurrentSqlFilePaths(state) {
return state.projectSqlFilePaths[state.currentProjectKey];
}
};
export const actions = {
async executeQuery({commit, state, rootState}, {envs, query}) {
const sqlMgr = rootState.sqlMgr.sqlMgr;
let result;
// const type = SqlQueryParser.getType(query);
// const typeColor = SqlQueryParser.getColorForQueryType(type)
// let t = process.hrtime();
try {
// const client = await sqlMgr.projectGetSqlClient(envs);
// result = await sqlMgr.sqlOp(envs, 'executeRawQuery', query);
result = await this.dispatch('sqlMgr/ActSqlOp', [envs, 'executeRawQuery', query]);
// var t1 = process.hrtime(t);
// var t2 = (t1[0] + t1[1] / 1000000000).toFixed(2);
// commit('MutListAdd', {
// id: Date.now(),
// name: '',
// query: query,
// type,
// typeColor,
// response: {status: 0},
// createdAt: Date.now(),
// timeTaken: t2,
// })
} catch (e) {
// var t1 = process.hrtime(t);
// var t2 = (t1[0] + t1[1] / 1000000000).toFixed(2);
//
// commit('MutListAdd', {
// id: Date.now(),
// name: '',
// query: query,
// type,
// typeColor,
// response: {status: -1},
// createdAt: Date.now(),
// timeTaken: t2,
//
// });
throw e;
}
return result;
//
//
// let a = {...action};
// try {
// commit('notification/MutToggleProgressBar', true, {root: true});
//
// if(action.body) {
// try {
// a.body = JSON.parse(a.body);
// } catch (e) {
// console.log(e);
// }
// }
// if(action.headers) {
// try {
// a.headers = JSON.parse(a.headers);
// } catch (e) {
// console.log(e);
// }
// }
//
// a.response = {};
// let data = await axios({
// url: a.url,
// method: a.type,
// data: a.body,
// headers: a.headers
// });
//
// a.response.status = data.status;
// a.response.data = data.data;
// console.log(data);
// } catch (e) {
// console.log(Object.keys(e), Object.entries(e));
// a.response = e.response;
// //throw e;
// } finally {
// commit('notification/MutToggleProgressBar', false, {root: true});
// commit('MutListAdd', {...a,body:JSON.stringify(a.body),headers:JSON.stringify(a.headers)});
// return a.response;
// }
},
async loadSqlCollectionForProject({commit, state}, {projectName, projectId}) {
const key = projectName + "__" + projectId;
commit('MutCurrentProjectKey', key)
if (!(key in state.projectSqlFilePaths)) {
commit('MutList', []);
}
}
};
/**
* @copyright Copyright (c) 2021, Xgene Cloud Ltd
*
* @author Naveen MR <oof1lab@gmail.com>
* @author Pranav C Balan <pranavxc@gmail.com>
*
* @license GNU AGPL version 3 or any later version
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/