mirror of
				https://github.com/Fabio286/antares.git
				synced 2025-06-05 21:59:22 +02:00 
			
		
		
		
	feat(MySQL): option, disabled by default, to enable table size indicators on sidebar
This commit is contained in:
		| @@ -1,10 +1,14 @@ | |||||||
| import * as antares from 'common/interfaces/antares'; | import * as antares from 'common/interfaces/antares'; | ||||||
| import * as mysql from 'mysql2/promise'; | import * as mysql from 'mysql2/promise'; | ||||||
|  | import * as Store from 'electron-store'; | ||||||
| import { AntaresCore } from '../AntaresCore'; | import { AntaresCore } from '../AntaresCore'; | ||||||
| import dataTypes from 'common/data-types/mysql'; | import dataTypes from 'common/data-types/mysql'; | ||||||
| import SSH2Promise = require('ssh2-promise'); | import SSH2Promise = require('ssh2-promise'); | ||||||
| import SSHConfig from 'ssh2-promise/lib/sshConfig'; | import SSHConfig from 'ssh2-promise/lib/sshConfig'; | ||||||
|  |  | ||||||
|  | Store.initRenderer(); | ||||||
|  | const settingsStore = new Store({ name: 'settings' }); | ||||||
|  |  | ||||||
| export class MySQLClient extends AntaresCore { | export class MySQLClient extends AntaresCore { | ||||||
|    private _schema?: string; |    private _schema?: string; | ||||||
|    private _runningConnections: Map<string, number>; |    private _runningConnections: Map<string, number>; | ||||||
| @@ -308,6 +312,9 @@ export class MySQLClient extends AntaresCore { | |||||||
|       for (const db of filteredDatabases) { |       for (const db of filteredDatabases) { | ||||||
|          if (!schemas.has(db.Database)) continue; |          if (!schemas.has(db.Database)) continue; | ||||||
|  |  | ||||||
|  |          const showTableSize = settingsStore.get('show_table_size'); | ||||||
|  |  | ||||||
|  |          if (showTableSize) { | ||||||
|             let { rows: tables } = await this.raw<antares.QueryResult<ShowTableResult>>(` |             let { rows: tables } = await this.raw<antares.QueryResult<ShowTableResult>>(` | ||||||
|                SELECT |                SELECT | ||||||
|                   TABLE_NAME, |                   TABLE_NAME, | ||||||
| @@ -331,6 +338,21 @@ export class MySQLClient extends AntaresCore { | |||||||
|                }); |                }); | ||||||
|                tablesArr.push(...tables); |                tablesArr.push(...tables); | ||||||
|             } |             } | ||||||
|  |          } | ||||||
|  |          else { | ||||||
|  |             let { rows: tables } = await this.raw<antares.QueryResult<ShowTableResult>>(`SHOW FULL TABLES FROM \`${db.Database}\``); | ||||||
|  |  | ||||||
|  |             if (tables.length) { | ||||||
|  |                tables = tables.map(table => { | ||||||
|  |                   const [name, type] = Object.values(table); | ||||||
|  |                   table.TABLE_SCHEMA = db.Database; | ||||||
|  |                   table.TABLE_NAME = name; | ||||||
|  |                   table.TABLE_TYPE = type; | ||||||
|  |                   return table; | ||||||
|  |                }); | ||||||
|  |                tablesArr.push(...tables); | ||||||
|  |             } | ||||||
|  |          } | ||||||
|  |  | ||||||
|          let { rows: triggers } = await this.raw<antares.QueryResult<ShowTriggersResult>>(`SHOW TRIGGERS FROM \`${db.Database}\``); |          let { rows: triggers } = await this.raw<antares.QueryResult<ShowTriggersResult>>(`SHOW TRIGGERS FROM \`${db.Database}\``); | ||||||
|          if (triggers.length) { |          if (triggers.length) { | ||||||
|   | |||||||
| @@ -120,6 +120,24 @@ | |||||||
|                                     </label> |                                     </label> | ||||||
|                                  </div> |                                  </div> | ||||||
|                               </div> |                               </div> | ||||||
|  |                               <div class="form-group column col-12 mb-0"> | ||||||
|  |                                  <div class="col-5 col-sm-12"> | ||||||
|  |                                     <label class="form-label"> | ||||||
|  |                                        {{ t('message.showTableSize') }} | ||||||
|  |                                     </label> | ||||||
|  |                                  </div> | ||||||
|  |                                  <div class="col-1 col-sm-12"> | ||||||
|  |                                     <label class="form-switch d-inline-block" @click.prevent="toggleShowTableSize"> | ||||||
|  |                                        <input type="checkbox" :checked="showTableSize"> | ||||||
|  |                                        <i class="form-icon" /> | ||||||
|  |                                     </label> | ||||||
|  |                                  </div> | ||||||
|  |                                  <div class="col-6 col-sm-12 px-2 p-vcentered"> | ||||||
|  |                                     <small class="d-block" :style="'line-height: 1.1; font-size: 70%;'"> | ||||||
|  |                                        {{ t('message.showTableSizeDescription') }} | ||||||
|  |                                     </small> | ||||||
|  |                                  </div> | ||||||
|  |                               </div> | ||||||
|                               <div class="form-group column col-12 mb-0"> |                               <div class="form-group column col-12 mb-0"> | ||||||
|                                  <div class="col-5 col-sm-12"> |                                  <div class="col-5 col-sm-12"> | ||||||
|                                     <label class="form-label"> |                                     <label class="form-label"> | ||||||
| @@ -418,6 +436,7 @@ const { | |||||||
|    defaultCopyType: selectedCopyType, |    defaultCopyType: selectedCopyType, | ||||||
|    notificationsTimeout, |    notificationsTimeout, | ||||||
|    restoreTabs, |    restoreTabs, | ||||||
|  |    showTableSize, | ||||||
|    disableBlur, |    disableBlur, | ||||||
|    disableScratchpad, |    disableScratchpad, | ||||||
|    applicationTheme, |    applicationTheme, | ||||||
| @@ -440,7 +459,8 @@ const { | |||||||
|    changeEditorTheme, |    changeEditorTheme, | ||||||
|    changeEditorFontSize, |    changeEditorFontSize, | ||||||
|    updateNotificationsTimeout, |    updateNotificationsTimeout, | ||||||
|    changeDefaultCopyType |    changeDefaultCopyType, | ||||||
|  |    changeShowTableSize | ||||||
| } = settingsStore; | } = settingsStore; | ||||||
| const { | const { | ||||||
|    hideSettingModal: closeModal, |    hideSettingModal: closeModal, | ||||||
| @@ -582,6 +602,10 @@ const toggleRestoreSession = () => { | |||||||
|    changeRestoreTabs(!restoreTabs.value); |    changeRestoreTabs(!restoreTabs.value); | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | const toggleShowTableSize = () => { | ||||||
|  |    changeShowTableSize(!showTableSize.value); | ||||||
|  | }; | ||||||
|  |  | ||||||
| const toggleDisableBlur = () => { | const toggleDisableBlur = () => { | ||||||
|    changeDisableBlur(!disableBlur.value); |    changeDisableBlur(!disableBlur.value); | ||||||
| }; | }; | ||||||
|   | |||||||
| @@ -335,7 +335,9 @@ export const enUS = { | |||||||
|       deleteFolder: 'Delete folder', |       deleteFolder: 'Delete folder', | ||||||
|       editConnectionAppearence: 'Edit connection appearence', |       editConnectionAppearence: 'Edit connection appearence', | ||||||
|       executeSelectedQuery: 'Execute selected query', |       executeSelectedQuery: 'Execute selected query', | ||||||
|       defaultCopyType: 'Default copy type' |       defaultCopyType: 'Default copy type', | ||||||
|  |       showTableSize: 'Show table size in sidebar', | ||||||
|  |       showTableSizeDescription: 'MySQL/MariaDB only. Enable this option may affects performance on schema with many tables.' | ||||||
|    }, |    }, | ||||||
|    faker: { |    faker: { | ||||||
|       address: 'Address', |       address: 'Address', | ||||||
|   | |||||||
| @@ -19,6 +19,7 @@ export const useSettingsStore = defineStore('settings', { | |||||||
|       allowPrerelease: settingsStore.get('allow_prerelease', true) as boolean, |       allowPrerelease: settingsStore.get('allow_prerelease', true) as boolean, | ||||||
|       explorebarSize: settingsStore.get('explorebar_size', null) as number, |       explorebarSize: settingsStore.get('explorebar_size', null) as number, | ||||||
|       notificationsTimeout: settingsStore.get('notifications_timeout', 5) as number, |       notificationsTimeout: settingsStore.get('notifications_timeout', 5) as number, | ||||||
|  |       showTableSize: settingsStore.get('show_table_size', false) as boolean, | ||||||
|       dataTabLimit: settingsStore.get('data_tab_limit', 1000) as number, |       dataTabLimit: settingsStore.get('data_tab_limit', 1000) as number, | ||||||
|       autoComplete: settingsStore.get('auto_complete', true) as boolean, |       autoComplete: settingsStore.get('auto_complete', true) as boolean, | ||||||
|       lineWrap: settingsStore.get('line_wrap', true) as boolean, |       lineWrap: settingsStore.get('line_wrap', true) as boolean, | ||||||
| @@ -50,6 +51,10 @@ export const useSettingsStore = defineStore('settings', { | |||||||
|          this.notificationsTimeout = timeout; |          this.notificationsTimeout = timeout; | ||||||
|          settingsStore.set('notifications_timeout', this.notificationsTimeout); |          settingsStore.set('notifications_timeout', this.notificationsTimeout); | ||||||
|       }, |       }, | ||||||
|  |       changeShowTableSize (show: boolean) { | ||||||
|  |          this.showTableSize = show; | ||||||
|  |          settingsStore.set('show_table_size', this.showTableSize); | ||||||
|  |       }, | ||||||
|       changeExplorebarSize (size: number) { |       changeExplorebarSize (size: number) { | ||||||
|          this.explorebarSize = size; |          this.explorebarSize = size; | ||||||
|          settingsStore.set('explorebar_size', this.explorebarSize); |          settingsStore.set('explorebar_size', this.explorebarSize); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user