mirror of
				https://github.com/Fabio286/antares.git
				synced 2025-06-05 21:59:22 +02:00 
			
		
		
		
	Additions
This commit is contained in:
		
							
								
								
									
										85
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										85
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							| @@ -1146,6 +1146,12 @@ | |||||||
|       "integrity": "sha512-q95SP4FdkmF0CwO0F2q0H6ZgudsApaY/yCtAQNRn1gduef5fGpyEphzy0YCq/N0UFvDSnLg5V8jFK/YGXlDiCw==", |       "integrity": "sha512-q95SP4FdkmF0CwO0F2q0H6ZgudsApaY/yCtAQNRn1gduef5fGpyEphzy0YCq/N0UFvDSnLg5V8jFK/YGXlDiCw==", | ||||||
|       "dev": true |       "dev": true | ||||||
|     }, |     }, | ||||||
|  |     "@types/json5": { | ||||||
|  |       "version": "0.0.29", | ||||||
|  |       "resolved": "https://registry.npmjs.org/@types/json5/-/json5-0.0.29.tgz", | ||||||
|  |       "integrity": "sha1-7ihweulOEdK4J7y+UnC86n8+ce4=", | ||||||
|  |       "dev": true | ||||||
|  |     }, | ||||||
|     "@types/minimatch": { |     "@types/minimatch": { | ||||||
|       "version": "3.0.3", |       "version": "3.0.3", | ||||||
|       "resolved": "https://registry.npmjs.org/@types/minimatch/-/minimatch-3.0.3.tgz", |       "resolved": "https://registry.npmjs.org/@types/minimatch/-/minimatch-3.0.3.tgz", | ||||||
| @@ -4151,9 +4157,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "electron-log": { |     "electron-log": { | ||||||
|       "version": "4.2.0", |       "version": "4.2.1", | ||||||
|       "resolved": "https://registry.npmjs.org/electron-log/-/electron-log-4.2.0.tgz", |       "resolved": "https://registry.npmjs.org/electron-log/-/electron-log-4.2.1.tgz", | ||||||
|       "integrity": "sha512-Yy1X8iZEzoBA8pu5b7YU07dRHi1GPM9C5jLEOn87Uqtdc9rbe6KbvvQ/AAAtGvn4/GC3azRW/eeiSI4ZF+Hm2A==" |       "integrity": "sha512-tUI9w3kUP3qhwXJ92RDUPFVZfwtBwKCy/1TsSHndXYLlNCB/7+vkiQG0uxv9D2Leuxc/DJKfYyrdEBpzi/vyZg==" | ||||||
|     }, |     }, | ||||||
|     "electron-publish": { |     "electron-publish": { | ||||||
|       "version": "22.7.0", |       "version": "22.7.0", | ||||||
| @@ -4858,23 +4864,24 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "eslint-plugin-import": { |     "eslint-plugin-import": { | ||||||
|       "version": "2.20.2", |       "version": "2.21.1", | ||||||
|       "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.20.2.tgz", |       "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.21.1.tgz", | ||||||
|       "integrity": "sha512-FObidqpXrR8OnCh4iNsxy+WACztJLXAHBO5hK79T1Hc77PgQZkyDGA5Ag9xAvRpglvLNxhH/zSmZ70/pZ31dHg==", |       "integrity": "sha512-qYOOsgUv63vHof7BqbzuD+Ud34bXHxFJxntuAC1ZappFZXYbRIek3aJ7jc9i2dHDGDyZ/0zlO0cpioES265Lsw==", | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "requires": { |       "requires": { | ||||||
|         "array-includes": "^3.0.3", |         "array-includes": "^3.1.1", | ||||||
|         "array.prototype.flat": "^1.2.1", |         "array.prototype.flat": "^1.2.3", | ||||||
|         "contains-path": "^0.1.0", |         "contains-path": "^0.1.0", | ||||||
|         "debug": "^2.6.9", |         "debug": "^2.6.9", | ||||||
|         "doctrine": "1.5.0", |         "doctrine": "1.5.0", | ||||||
|         "eslint-import-resolver-node": "^0.3.2", |         "eslint-import-resolver-node": "^0.3.3", | ||||||
|         "eslint-module-utils": "^2.4.1", |         "eslint-module-utils": "^2.6.0", | ||||||
|         "has": "^1.0.3", |         "has": "^1.0.3", | ||||||
|         "minimatch": "^3.0.4", |         "minimatch": "^3.0.4", | ||||||
|         "object.values": "^1.1.0", |         "object.values": "^1.1.1", | ||||||
|         "read-pkg-up": "^2.0.0", |         "read-pkg-up": "^2.0.0", | ||||||
|         "resolve": "^1.12.0" |         "resolve": "^1.17.0", | ||||||
|  |         "tsconfig-paths": "^3.9.0" | ||||||
|       }, |       }, | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "debug": { |         "debug": { | ||||||
| @@ -10924,6 +10931,11 @@ | |||||||
|         "ajv-keywords": "^3.4.1" |         "ajv-keywords": "^3.4.1" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|  |     "scrollparent": { | ||||||
|  |       "version": "2.0.1", | ||||||
|  |       "resolved": "https://registry.npmjs.org/scrollparent/-/scrollparent-2.0.1.tgz", | ||||||
|  |       "integrity": "sha1-cV1bnMV3YPsivczDvvtb/gaxoxc=" | ||||||
|  |     }, | ||||||
|     "scss-tokenizer": { |     "scss-tokenizer": { | ||||||
|       "version": "0.2.3", |       "version": "0.2.3", | ||||||
|       "resolved": "https://registry.npmjs.org/scss-tokenizer/-/scss-tokenizer-0.2.3.tgz", |       "resolved": "https://registry.npmjs.org/scss-tokenizer/-/scss-tokenizer-0.2.3.tgz", | ||||||
| @@ -12246,6 +12258,29 @@ | |||||||
|         "utf8-byte-length": "^1.0.1" |         "utf8-byte-length": "^1.0.1" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|  |     "tsconfig-paths": { | ||||||
|  |       "version": "3.9.0", | ||||||
|  |       "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-3.9.0.tgz", | ||||||
|  |       "integrity": "sha512-dRcuzokWhajtZWkQsDVKbWyY+jgcLC5sqJhg2PSgf4ZkH2aHPvaOY8YWGhmjb68b5qqTfasSsDO9k7RUiEmZAw==", | ||||||
|  |       "dev": true, | ||||||
|  |       "requires": { | ||||||
|  |         "@types/json5": "^0.0.29", | ||||||
|  |         "json5": "^1.0.1", | ||||||
|  |         "minimist": "^1.2.0", | ||||||
|  |         "strip-bom": "^3.0.0" | ||||||
|  |       }, | ||||||
|  |       "dependencies": { | ||||||
|  |         "json5": { | ||||||
|  |           "version": "1.0.1", | ||||||
|  |           "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.1.tgz", | ||||||
|  |           "integrity": "sha512-aKS4WQjPenRxiQsC93MNfjx+nbF4PAdYzmd/1JIj8HYzqfbu86beTuNgXDzPknWk0n0uARlyewZo4s++ES36Ow==", | ||||||
|  |           "dev": true, | ||||||
|  |           "requires": { | ||||||
|  |             "minimist": "^1.2.0" | ||||||
|  |           } | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|     "tslib": { |     "tslib": { | ||||||
|       "version": "1.11.1", |       "version": "1.11.1", | ||||||
|       "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.11.1.tgz", |       "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.11.1.tgz", | ||||||
| @@ -12796,9 +12831,9 @@ | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "vue-i18n": { |     "vue-i18n": { | ||||||
|       "version": "8.18.1", |       "version": "8.18.2", | ||||||
|       "resolved": "https://registry.npmjs.org/vue-i18n/-/vue-i18n-8.18.1.tgz", |       "resolved": "https://registry.npmjs.org/vue-i18n/-/vue-i18n-8.18.2.tgz", | ||||||
|       "integrity": "sha512-K+hFQJksF8Ph23pnhbwSyoQx+4Y1q/rh2o7GiXI/3rLCCrwanUbzudC8+trp0Mb8rn9y83DYF6RXNrMd+VsuCw==" |       "integrity": "sha512-0X5nBTCZAVjlwcrPaYJwNs3iipBBTv0AUHwQUOa8yP3XbQGWKbRHqBb3OhCYtum/IHDD21d/df5Xd2VgyxbxfA==" | ||||||
|     }, |     }, | ||||||
|     "vue-loader": { |     "vue-loader": { | ||||||
|       "version": "15.9.1", |       "version": "15.9.1", | ||||||
| @@ -12813,6 +12848,16 @@ | |||||||
|         "vue-style-loader": "^4.1.0" |         "vue-style-loader": "^4.1.0" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|  |     "vue-observe-visibility": { | ||||||
|  |       "version": "0.4.6", | ||||||
|  |       "resolved": "https://registry.npmjs.org/vue-observe-visibility/-/vue-observe-visibility-0.4.6.tgz", | ||||||
|  |       "integrity": "sha512-xo0CEVdkjSjhJoDdLSvoZoQrw/H2BlzB5jrCBKGZNXN2zdZgMuZ9BKrxXDjNP2AxlcCoKc8OahI3F3r3JGLv2Q==" | ||||||
|  |     }, | ||||||
|  |     "vue-resize": { | ||||||
|  |       "version": "0.4.5", | ||||||
|  |       "resolved": "https://registry.npmjs.org/vue-resize/-/vue-resize-0.4.5.tgz", | ||||||
|  |       "integrity": "sha512-bhP7MlgJQ8TIkZJXAfDf78uJO+mEI3CaLABLjv0WNzr4CcGRGPIAItyWYnP6LsPA4Oq0WE+suidNs6dgpO4RHg==" | ||||||
|  |     }, | ||||||
|     "vue-style-loader": { |     "vue-style-loader": { | ||||||
|       "version": "4.1.2", |       "version": "4.1.2", | ||||||
|       "resolved": "https://registry.npmjs.org/vue-style-loader/-/vue-style-loader-4.1.2.tgz", |       "resolved": "https://registry.npmjs.org/vue-style-loader/-/vue-style-loader-4.1.2.tgz", | ||||||
| @@ -12839,6 +12884,16 @@ | |||||||
|       "integrity": "sha512-4gDntzrifFnCEvyoO8PqyJDmguXgVPxKiIxrBKjIowvL9l+N66196+72XVYR8BBf1Uv1Fgt3bGevJ+sEmxfZzw==", |       "integrity": "sha512-4gDntzrifFnCEvyoO8PqyJDmguXgVPxKiIxrBKjIowvL9l+N66196+72XVYR8BBf1Uv1Fgt3bGevJ+sEmxfZzw==", | ||||||
|       "dev": true |       "dev": true | ||||||
|     }, |     }, | ||||||
|  |     "vue-virtual-scroller": { | ||||||
|  |       "version": "1.0.10", | ||||||
|  |       "resolved": "https://registry.npmjs.org/vue-virtual-scroller/-/vue-virtual-scroller-1.0.10.tgz", | ||||||
|  |       "integrity": "sha512-Hn4qSBDhRY4XdngPioYy/ykDjrLX/NMm1fQXm/4UQQ/Xv1x8JbHGFZNftQowTcfICgN7yc31AKnUk1UGLJ2ndA==", | ||||||
|  |       "requires": { | ||||||
|  |         "scrollparent": "^2.0.1", | ||||||
|  |         "vue-observe-visibility": "^0.4.4", | ||||||
|  |         "vue-resize": "^0.4.5" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|     "vuedraggable": { |     "vuedraggable": { | ||||||
|       "version": "2.23.2", |       "version": "2.23.2", | ||||||
|       "resolved": "https://registry.npmjs.org/vuedraggable/-/vuedraggable-2.23.2.tgz", |       "resolved": "https://registry.npmjs.org/vuedraggable/-/vuedraggable-2.23.2.tgz", | ||||||
|   | |||||||
| @@ -2,7 +2,7 @@ | |||||||
|   "name": "antares", |   "name": "antares", | ||||||
|   "productName": "Antares", |   "productName": "Antares", | ||||||
|   "version": "0.0.0", |   "version": "0.0.0", | ||||||
|   "description": "A cross-platform easy to use SQL client. ", |   "description": "A cross-platform easy to use SQL client.", | ||||||
|   "license": "MIT", |   "license": "MIT", | ||||||
|   "repository": "https://github.com/Fabio286/antares.git", |   "repository": "https://github.com/Fabio286/antares.git", | ||||||
|   "scripts": { |   "scripts": { | ||||||
| @@ -29,7 +29,7 @@ | |||||||
|   }, |   }, | ||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "codemirror": "^5.54.0", |     "codemirror": "^5.54.0", | ||||||
|     "electron-log": "^4.2.0", |     "electron-log": "^4.2.1", | ||||||
|     "electron-updater": "^4.3.1", |     "electron-updater": "^4.3.1", | ||||||
|     "lodash": "^4.17.15", |     "lodash": "^4.17.15", | ||||||
|     "material-design-icons": "^3.0.1", |     "material-design-icons": "^3.0.1", | ||||||
| @@ -40,7 +40,8 @@ | |||||||
|     "source-map-support": "^0.5.16", |     "source-map-support": "^0.5.16", | ||||||
|     "spectre.css": "^0.5.8", |     "spectre.css": "^0.5.8", | ||||||
|     "vue-click-outside": "^1.1.0", |     "vue-click-outside": "^1.1.0", | ||||||
|     "vue-i18n": "^8.18.1", |     "vue-i18n": "^8.18.2", | ||||||
|  |     "vue-virtual-scroller": "^1.0.10", | ||||||
|     "vuedraggable": "^2.23.2", |     "vuedraggable": "^2.23.2", | ||||||
|     "vuex": "^3.4.0", |     "vuex": "^3.4.0", | ||||||
|     "vuex-persist": "^2.2.0" |     "vuex-persist": "^2.2.0" | ||||||
| @@ -55,7 +56,7 @@ | |||||||
|     "electron-webpack-vue": "^2.4.0", |     "electron-webpack-vue": "^2.4.0", | ||||||
|     "eslint": "^6.8.0", |     "eslint": "^6.8.0", | ||||||
|     "eslint-config-standard": "^14.1.1", |     "eslint-config-standard": "^14.1.1", | ||||||
|     "eslint-plugin-import": "^2.20.1", |     "eslint-plugin-import": "^2.21.1", | ||||||
|     "eslint-plugin-node": "^11.1.0", |     "eslint-plugin-node": "^11.1.0", | ||||||
|     "eslint-plugin-promise": "^4.2.1", |     "eslint-plugin-promise": "^4.2.1", | ||||||
|     "eslint-plugin-standard": "^4.0.1", |     "eslint-plugin-standard": "^4.0.1", | ||||||
|   | |||||||
| @@ -24,28 +24,19 @@ | |||||||
|  |  | ||||||
| <script> | <script> | ||||||
| import { mapActions, mapGetters } from 'vuex'; | import { mapActions, mapGetters } from 'vuex'; | ||||||
| import TheTitleBar from '@/components/TheTitleBar'; |  | ||||||
| import TheSettingBar from '@/components/TheSettingBar'; |  | ||||||
| import TheFooter from '@/components/TheFooter'; |  | ||||||
| import TheNotificationsBoard from '@/components/TheNotificationsBoard'; |  | ||||||
| import TheAppWelcome from '@/components/TheAppWelcome'; |  | ||||||
| import Workspace from '@/components/Workspace'; |  | ||||||
| import ModalNewConnection from '@/components/ModalNewConnection'; |  | ||||||
| import ModalEditConnection from '@/components/ModalEditConnection'; |  | ||||||
| import ModalSettings from '@/components/ModalSettings'; |  | ||||||
|  |  | ||||||
| export default { | export default { | ||||||
|    name: 'App', |    name: 'App', | ||||||
|    components: { |    components: { | ||||||
|       TheTitleBar, |       TheTitleBar: () => import(/* webpackChunkName: "TheTitleBar" */'@/components/TheTitleBar'), | ||||||
|       TheSettingBar, |       TheSettingBar: () => import(/* webpackChunkName: "TheSettingBar" */'@/components/TheSettingBar'), | ||||||
|       TheFooter, |       TheFooter: () => import(/* webpackChunkName: "TheFooter" */'@/components/TheFooter'), | ||||||
|       TheNotificationsBoard, |       TheNotificationsBoard: () => import(/* webpackChunkName: "TheNotificationsBoard" */'@/components/TheNotificationsBoard'), | ||||||
|       TheAppWelcome, |       TheAppWelcome: () => import(/* webpackChunkName: "TheAppWelcome" */'@/components/TheAppWelcome'), | ||||||
|       Workspace, |       Workspace: () => import(/* webpackChunkName: "Workspace" */'@/components/Workspace'), | ||||||
|       ModalNewConnection, |       ModalNewConnection: () => import(/* webpackChunkName: "ModalNewConnection" */'@/components/ModalNewConnection'), | ||||||
|       ModalEditConnection, |       ModalEditConnection: () => import(/* webpackChunkName: "ModalEditConnection" */'@/components/ModalEditConnection'), | ||||||
|       ModalSettings |       ModalSettings: () => import(/* webpackChunkName: "ModalSettings" */'@/components/ModalSettings') | ||||||
|    }, |    }, | ||||||
|    data () { |    data () { | ||||||
|       return { |       return { | ||||||
|   | |||||||
| @@ -31,7 +31,10 @@ | |||||||
|                         <div class="col-8 col-sm-12"> |                         <div class="col-8 col-sm-12"> | ||||||
|                            <select v-model="localConnection.client" class="form-select"> |                            <select v-model="localConnection.client" class="form-select"> | ||||||
|                               <option value="mysql"> |                               <option value="mysql"> | ||||||
|                                  MySQL/MariaDB |                                  MySQL | ||||||
|  |                               </option> | ||||||
|  |                               <option value="maria"> | ||||||
|  |                                  MariaDB | ||||||
|                               </option> |                               </option> | ||||||
|                               <option value="mssql"> |                               <option value="mssql"> | ||||||
|                                  Microsoft SQL |                                  Microsoft SQL | ||||||
|   | |||||||
| @@ -35,7 +35,10 @@ | |||||||
|                               @change="setDefaults" |                               @change="setDefaults" | ||||||
|                            > |                            > | ||||||
|                               <option value="mysql"> |                               <option value="mysql"> | ||||||
|                                  MySQL/MariaDB |                                  MySQL | ||||||
|  |                               </option> | ||||||
|  |                               <option value="maria"> | ||||||
|  |                                  MariaDB | ||||||
|                               </option> |                               </option> | ||||||
|                               <option value="mssql"> |                               <option value="mssql"> | ||||||
|                                  Microsoft SQL |                                  Microsoft SQL | ||||||
|   | |||||||
| @@ -102,9 +102,11 @@ export default { | |||||||
|          changeExplorebarSize: 'settings/changeExplorebarSize' |          changeExplorebarSize: 'settings/changeExplorebarSize' | ||||||
|       }), |       }), | ||||||
|       async refresh () { |       async refresh () { | ||||||
|  |          if (!this.isRefreshing) { | ||||||
|             this.isRefreshing = true; |             this.isRefreshing = true; | ||||||
|             await this.refreshStructure(this.connection.uid); |             await this.refreshStructure(this.connection.uid); | ||||||
|             this.isRefreshing = false; |             this.isRefreshing = false; | ||||||
|  |          } | ||||||
|       }, |       }, | ||||||
|       resize (e) { |       resize (e) { | ||||||
|          const el = this.$refs.explorebar; |          const el = this.$refs.explorebar; | ||||||
|   | |||||||
| @@ -10,7 +10,7 @@ | |||||||
|          <span>{{ database.name }}</span> |          <span>{{ database.name }}</span> | ||||||
|       </summary> |       </summary> | ||||||
|       <div class="accordion-body"> |       <div class="accordion-body"> | ||||||
|          <div class="database-bables"> |          <div class="database-tables"> | ||||||
|             <ul class="menu menu-nav pt-0"> |             <ul class="menu menu-nav pt-0"> | ||||||
|                <li |                <li | ||||||
|                   v-for="table of database.tables" |                   v-for="table of database.tables" | ||||||
| @@ -63,6 +63,7 @@ export default { | |||||||
|          align-items: center; |          align-items: center; | ||||||
|          padding: .1rem; |          padding: .1rem; | ||||||
|          cursor: pointer; |          cursor: pointer; | ||||||
|  |          font-size: .7rem; | ||||||
|  |  | ||||||
|          > span{ |          > span{ | ||||||
|             overflow: hidden; |             overflow: hidden; | ||||||
| @@ -78,7 +79,11 @@ export default { | |||||||
|          } |          } | ||||||
|       } |       } | ||||||
|  |  | ||||||
|       .database-bables{ |       .menu-item{ | ||||||
|  |          line-height: 1.2; | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |       .database-tables{ | ||||||
|          margin-left: 1.2rem; |          margin-left: 1.2rem; | ||||||
|       } |       } | ||||||
|    } |    } | ||||||
|   | |||||||
| @@ -4,34 +4,26 @@ | |||||||
|          <QueryEditor v-model="query" /> |          <QueryEditor v-model="query" /> | ||||||
|          <div class="workspace-query-runner-footer"> |          <div class="workspace-query-runner-footer"> | ||||||
|             <div class="workspace-query-buttons"> |             <div class="workspace-query-buttons"> | ||||||
|                <i class="material-icons text-success" @click="runQuery">play_arrow</i> |                <button | ||||||
|  |                   class="btn btn-link btn-sm" | ||||||
|  |                   :class="{'loading':isQuering}" | ||||||
|  |                   @click="runQuery" | ||||||
|  |                > | ||||||
|  |                   <span>{{ $t('word.run') }}</span> | ||||||
|  |                   <i class="material-icons text-success">play_arrow</i> | ||||||
|  |                </button> | ||||||
|  |                <button class="btn btn-link btn-sm"> | ||||||
|  |                   <span>{{ $t('word.save') }}</span> | ||||||
|  |                   <i class="material-icons ml-1">save</i> | ||||||
|  |                </button> | ||||||
|             </div> |             </div> | ||||||
|             <div> |             <div v-if="workspace.breadcrumbs.database"> | ||||||
|                Schema: <b>{{ workspace.breadcrumbs.database }}</b> |                {{ $t('word.schema') }}: <b>{{ workspace.breadcrumbs.database }}</b> | ||||||
|             </div> |             </div> | ||||||
|          </div> |          </div> | ||||||
|       </div> |       </div> | ||||||
|       <div ref="resultTable" class="workspace-query-results column col-12"> |       <div ref="resultTable" class="workspace-query-results column col-12"> | ||||||
|          <table v-if="results" class="table table-hover"> |          <WorkspaceQueryTable v-if="results" :results="results" /> | ||||||
|             <thead> |  | ||||||
|                <tr> |  | ||||||
|                   <th v-for="field in results.fields" :key="field.name"> |  | ||||||
|                      {{ field.name }} |  | ||||||
|                   </th> |  | ||||||
|                </tr> |  | ||||||
|             </thead> |  | ||||||
|             <tbody> |  | ||||||
|                <tr v-for="(row, rKey) in results.rows" :key="rKey"> |  | ||||||
|                   <td |  | ||||||
|                      v-for="(col, cKey) in row" |  | ||||||
|                      :key="cKey" |  | ||||||
|                      :class="fieldType(col)" |  | ||||||
|                   > |  | ||||||
|                      {{ col }} |  | ||||||
|                   </td> |  | ||||||
|                </tr> |  | ||||||
|             </tbody> |  | ||||||
|          </table> |  | ||||||
|       </div> |       </div> | ||||||
|    </div> |    </div> | ||||||
| </template> | </template> | ||||||
| @@ -39,12 +31,14 @@ | |||||||
| <script> | <script> | ||||||
| import Connection from '@/ipc-api/Connection'; | import Connection from '@/ipc-api/Connection'; | ||||||
| import QueryEditor from '@/components/QueryEditor'; | import QueryEditor from '@/components/QueryEditor'; | ||||||
|  | import WorkspaceQueryTable from '@/components/WorkspaceQueryTable'; | ||||||
| import { mapGetters, mapActions } from 'vuex'; | import { mapGetters, mapActions } from 'vuex'; | ||||||
|  |  | ||||||
| export default { | export default { | ||||||
|    name: 'WorkspaceQueryTab', |    name: 'WorkspaceQueryTab', | ||||||
|    components: { |    components: { | ||||||
|       QueryEditor |       QueryEditor, | ||||||
|  |       WorkspaceQueryTable | ||||||
|    }, |    }, | ||||||
|    props: { |    props: { | ||||||
|       connection: Object |       connection: Object | ||||||
| @@ -52,6 +46,7 @@ export default { | |||||||
|    data () { |    data () { | ||||||
|       return { |       return { | ||||||
|          query: '', |          query: '', | ||||||
|  |          isQuering: false, | ||||||
|          results: {} |          results: {} | ||||||
|       }; |       }; | ||||||
|    }, |    }, | ||||||
| @@ -75,6 +70,7 @@ export default { | |||||||
|       }), |       }), | ||||||
|       async runQuery () { |       async runQuery () { | ||||||
|          if (!this.query) return; |          if (!this.query) return; | ||||||
|  |          this.isQuering = true; | ||||||
|          this.results = {}; |          this.results = {}; | ||||||
|          this.resizeResults(); |          this.resizeResults(); | ||||||
|  |  | ||||||
| @@ -94,6 +90,8 @@ export default { | |||||||
|          catch (err) { |          catch (err) { | ||||||
|             this.addNotification({ status: 'error', message: err.stack }); |             this.addNotification({ status: 'error', message: err.stack }); | ||||||
|          } |          } | ||||||
|  |  | ||||||
|  |          this.isQuering = false; | ||||||
|       }, |       }, | ||||||
|       resizeResults (e) { |       resizeResults (e) { | ||||||
|          const el = this.$refs.resultTable; |          const el = this.$refs.resultTable; | ||||||
| @@ -126,11 +124,18 @@ export default { | |||||||
|       .workspace-query-runner-footer{ |       .workspace-query-runner-footer{ | ||||||
|          display: flex; |          display: flex; | ||||||
|          justify-content: space-between; |          justify-content: space-between; | ||||||
|          padding: .2rem .6rem; |          padding: .3rem .6rem .4rem; | ||||||
|          align-items: center; |          align-items: center; | ||||||
|  |  | ||||||
|          .workspace-query-buttons{ |          .workspace-query-buttons{ | ||||||
|             display: flex; |             display: flex; | ||||||
|  |  | ||||||
|  |             .btn{ | ||||||
|  |                display: flex; | ||||||
|  |                align-self: center; | ||||||
|  |                color: $body-font-color; | ||||||
|  |                margin-right: .4rem; | ||||||
|  |             } | ||||||
|          } |          } | ||||||
|       } |       } | ||||||
|    } |    } | ||||||
| @@ -139,14 +144,24 @@ export default { | |||||||
|       overflow: auto; |       overflow: auto; | ||||||
|       white-space: nowrap; |       white-space: nowrap; | ||||||
|  |  | ||||||
|       th{ |       .table{ | ||||||
|  |          width: auto; | ||||||
|  |  | ||||||
|  |          .tr:focus{ | ||||||
|  |             background: rgba($color: #000000, $alpha: .3); | ||||||
|  |          } | ||||||
|  |  | ||||||
|  |          .th{ | ||||||
|             position: sticky; |             position: sticky; | ||||||
|             top: 0; |             top: 0; | ||||||
|             background: $bg-color; |             background: $bg-color; | ||||||
|             border-color: $bg-color-light; |             border-color: $bg-color-light; | ||||||
|  |             padding: .1rem .4rem; | ||||||
|  |             font-weight: 400; | ||||||
|          } |          } | ||||||
|  |  | ||||||
|       td{ |          .td{ | ||||||
|  |             border-left: 1px solid; | ||||||
|             border-color: $bg-color-light; |             border-color: $bg-color-light; | ||||||
|             padding: 0 .4rem; |             padding: 0 .4rem; | ||||||
|             text-overflow: ellipsis; |             text-overflow: ellipsis; | ||||||
| @@ -154,23 +169,8 @@ export default { | |||||||
|             white-space: nowrap; |             white-space: nowrap; | ||||||
|             overflow: hidden; |             overflow: hidden; | ||||||
|  |  | ||||||
|          &.type-string{ |             &:first-child{ | ||||||
|             color: seagreen; |                border-left: none; | ||||||
|          } |  | ||||||
|          &.type-number{ |  | ||||||
|             color: cornflowerblue; |  | ||||||
|             text-align: right; |  | ||||||
|          } |  | ||||||
|          &.type-date{ |  | ||||||
|             color: coral; |  | ||||||
|          } |  | ||||||
|          &.type-blob{ |  | ||||||
|             color: darkorchid; |  | ||||||
|          } |  | ||||||
|          &.type-null{ |  | ||||||
|             color: gray; |  | ||||||
|             &::after{ |  | ||||||
|                content: 'NULL'; |  | ||||||
|             } |             } | ||||||
|          } |          } | ||||||
|       } |       } | ||||||
|   | |||||||
							
								
								
									
										56
									
								
								src/renderer/components/WorkspaceQueryTable.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								src/renderer/components/WorkspaceQueryTable.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,56 @@ | |||||||
|  | <template> | ||||||
|  |    <div v-if="results" class="table table-hover"> | ||||||
|  |       <div class="thead"> | ||||||
|  |          <div class="tr"> | ||||||
|  |             <div | ||||||
|  |                v-for="field in results.fields" | ||||||
|  |                :key="field.name" | ||||||
|  |                class="th" | ||||||
|  |             > | ||||||
|  |                {{ field.name }} | ||||||
|  |             </div> | ||||||
|  |          </div> | ||||||
|  |       </div> | ||||||
|  |       <div class="tbody"> | ||||||
|  |          <div | ||||||
|  |             v-for="(row, rKey) in results.rows" | ||||||
|  |             :key="rKey" | ||||||
|  |             class="tr" | ||||||
|  |             tabindex="0" | ||||||
|  |          > | ||||||
|  |             <div | ||||||
|  |                v-for="(col, cKey) in row" | ||||||
|  |                :key="cKey" | ||||||
|  |                class="td" | ||||||
|  |                :class="fieldType(col)" | ||||||
|  |             > | ||||||
|  |                {{ col }} | ||||||
|  |             </div> | ||||||
|  |          </div> | ||||||
|  |       </div> | ||||||
|  |    </div> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script> | ||||||
|  | export default { | ||||||
|  |    name: 'WorkspaceQueryTable', | ||||||
|  |    props: { | ||||||
|  |       results: Object | ||||||
|  |    }, | ||||||
|  |    methods: { | ||||||
|  |       fieldType (col) { | ||||||
|  |          let type = typeof col; | ||||||
|  |          if (type === 'object') | ||||||
|  |             if (col instanceof Date) type = 'date'; | ||||||
|  |          if (col instanceof Uint8Array) type = 'blob'; | ||||||
|  |          if (col === null) type = 'null'; | ||||||
|  |  | ||||||
|  |          return `type-${type}`; | ||||||
|  |       } | ||||||
|  |    } | ||||||
|  | }; | ||||||
|  | </script> | ||||||
|  |  | ||||||
|  | <style> | ||||||
|  |  | ||||||
|  | </style> | ||||||
| @@ -26,7 +26,9 @@ module.exports = { | |||||||
|       about: 'About', |       about: 'About', | ||||||
|       language: 'Language', |       language: 'Language', | ||||||
|       version: 'Version', |       version: 'Version', | ||||||
|       donate: 'Donate' |       donate: 'Donate', | ||||||
|  |       run: 'Run', | ||||||
|  |       schema: 'Schema' | ||||||
|    }, |    }, | ||||||
|    message: { |    message: { | ||||||
|       appWelcome: 'Welcome to Antares SQL Client!', |       appWelcome: 'Welcome to Antares SQL Client!', | ||||||
|   | |||||||
| @@ -26,7 +26,8 @@ module.exports = { | |||||||
|       about: 'Informazioni', |       about: 'Informazioni', | ||||||
|       language: 'Lingua', |       language: 'Lingua', | ||||||
|       version: 'Versione', |       version: 'Versione', | ||||||
|       donate: 'Dona' |       donate: 'Dona', | ||||||
|  |       run: 'Esegui' | ||||||
|    }, |    }, | ||||||
|    message: { |    message: { | ||||||
|       appWelcome: 'Benvenuto in Antares SQL Client!', |       appWelcome: 'Benvenuto in Antares SQL Client!', | ||||||
|   | |||||||
							
								
								
									
										25
									
								
								src/renderer/scss/_data-types.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								src/renderer/scss/_data-types.scss
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,25 @@ | |||||||
|  | @mixin type-colors($types) { | ||||||
|  |    @each $type, $color in $types { | ||||||
|  |       .type-#{$type} { | ||||||
|  |          color: $color; | ||||||
|  |  | ||||||
|  |          @if $type == 'null'{ | ||||||
|  |             &::after{ | ||||||
|  |                content: 'NULL'; | ||||||
|  |             } | ||||||
|  |          } | ||||||
|  |  | ||||||
|  |          @if $type == 'number'{ | ||||||
|  |             text-align: right; | ||||||
|  |          } | ||||||
|  |       } | ||||||
|  |    } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @include type-colors(( | ||||||
|  |    "string": seagreen, | ||||||
|  |    "number": cornflowerblue, | ||||||
|  |    "date": coral, | ||||||
|  |    "blob": darkorchid, | ||||||
|  |    "null": gray, | ||||||
|  | )) | ||||||
							
								
								
									
										65
									
								
								src/renderer/scss/_fake-tables.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								src/renderer/scss/_fake-tables.scss
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,65 @@ | |||||||
|  | .table { | ||||||
|  |    border-collapse: collapse; | ||||||
|  |    border-spacing: 0; | ||||||
|  |    width: 100%; | ||||||
|  |    display: table; | ||||||
|  |   | ||||||
|  |    &.table-striped { | ||||||
|  |      .tbody { | ||||||
|  |        .tr:nth-of-type(odd) { | ||||||
|  |          background: $bg-color; | ||||||
|  |        } | ||||||
|  |      } | ||||||
|  |    } | ||||||
|  |   | ||||||
|  |    &, | ||||||
|  |    &.table-striped { | ||||||
|  |      .tbody { | ||||||
|  |        .tr { | ||||||
|  |          &.active { | ||||||
|  |            background: $bg-color-dark; | ||||||
|  |          } | ||||||
|  |        } | ||||||
|  |      } | ||||||
|  |    } | ||||||
|  |   | ||||||
|  |    &.table-hover { | ||||||
|  |      .tbody { | ||||||
|  |        .tr { | ||||||
|  |          &:hover { | ||||||
|  |            background: $bg-color-dark; | ||||||
|  |          } | ||||||
|  |        } | ||||||
|  |      } | ||||||
|  |    } | ||||||
|  |   | ||||||
|  |    // Scollable tables | ||||||
|  |    &.table-scroll { | ||||||
|  |      display: block; | ||||||
|  |      overflow-x: auto; | ||||||
|  |      padding-bottom: .75rem; | ||||||
|  |      white-space: nowrap; | ||||||
|  |    } | ||||||
|  |  | ||||||
|  |    .thead{ | ||||||
|  |     display: table-header-group; | ||||||
|  |    } | ||||||
|  |   | ||||||
|  |    .tbody{ | ||||||
|  |     display: table-row-group; | ||||||
|  |    } | ||||||
|  |  | ||||||
|  |    .tr{ | ||||||
|  |     display: table-row; | ||||||
|  |    } | ||||||
|  |  | ||||||
|  |    .td, | ||||||
|  |    .th { | ||||||
|  |      border-bottom: $border-width solid $border-color; | ||||||
|  |      padding: $unit-3 $unit-2; | ||||||
|  |      display: table-cell; | ||||||
|  |    } | ||||||
|  |    .th { | ||||||
|  |      border-bottom-width: $border-width-lg; | ||||||
|  |    } | ||||||
|  |  } | ||||||
| @@ -1,5 +1,9 @@ | |||||||
|  |  | ||||||
|  | @import "~spectre.css/src/variables"; | ||||||
| @import "variables"; | @import "variables"; | ||||||
| @import "transitions"; | @import "transitions"; | ||||||
|  | @import "data-types"; | ||||||
|  | @import "fake-tables"; | ||||||
| @import "mdi-additions"; | @import "mdi-additions"; | ||||||
| @import "db-icons"; | @import "db-icons"; | ||||||
| @import "~spectre.css/src/spectre"; | @import "~spectre.css/src/spectre"; | ||||||
| @@ -132,3 +136,10 @@ body{ | |||||||
| .accordion-body { | .accordion-body { | ||||||
|    max-height: 500rem!important; |    max-height: 500rem!important; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .btn.loading { | ||||||
|  |    > .material-icons, | ||||||
|  |    > span{ | ||||||
|  |       visibility: hidden; | ||||||
|  |    } | ||||||
|  | } | ||||||
		Reference in New Issue
	
	Block a user