mirror of https://github.com/nocodb/nocodb
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.
221 lines
5.7 KiB
221 lines
5.7 KiB
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(); |
|
// eslint-disable-next-line no-useless-catch |
|
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/>. |
|
* |
|
*/
|
|
|