mirror of
				https://github.com/Fabio286/antares.git
				synced 2025-06-05 21:59:22 +02:00 
			
		
		
		
	feat: option to toggle editor auto completion
This commit is contained in:
		| @@ -45,60 +45,83 @@ | ||||
|                      </li> | ||||
|                   </ul> | ||||
|                </div> | ||||
|  | ||||
|                <div v-if="selectedTab === 'general'" class="panel-body py-4"> | ||||
|                   <form class="form-horizontal"> | ||||
|                      <div class="col-8 col-sm-12"> | ||||
|                         <div class="form-group mb-4"> | ||||
|                            <div class="col-6 col-sm-12"> | ||||
|                               <label class="form-label"> | ||||
|                                  <i class="mdi mdi-18px mdi-translate mr-1" /> | ||||
|                                  {{ $t('word.language') }}: | ||||
|                               </label> | ||||
|                            </div> | ||||
|                            <div class="col-6 col-sm-12"> | ||||
|                               <select | ||||
|                                  v-model="localLocale" | ||||
|                                  class="form-select" | ||||
|                                  @change="changeLocale(localLocale)" | ||||
|                               > | ||||
|                                  <option | ||||
|                                     v-for="(locale, key) in locales" | ||||
|                                     :key="key" | ||||
|                                     :value="locale.code" | ||||
|                                  > | ||||
|                                     {{ locale.name }} | ||||
|                                  </option> | ||||
|                               </select> | ||||
|                            </div> | ||||
|                   <div class="container"> | ||||
|                      <form class="form-horizontal columns"> | ||||
|                         <div class="column col-12 h6 text-uppercase mb-1"> | ||||
|                            {{ $t('word.application') }} | ||||
|                         </div> | ||||
|                         <div class="form-group"> | ||||
|                            <div class="col-6 col-sm-12"> | ||||
|                               <label class="form-label"> | ||||
|                                  {{ $t('message.notificationsTimeout') }}: | ||||
|                               </label> | ||||
|                            </div> | ||||
|                            <div class="col-6 col-sm-12"> | ||||
|                               <div class="input-group"> | ||||
|                                  <input | ||||
|                                     v-model="localTimeout" | ||||
|                                     class="form-input" | ||||
|                                     type="number" | ||||
|                                     min="1" | ||||
|                                     @focusout="checkNotificationsTimeout" | ||||
|                         <div class="column col-8 col-sm-12 mb-2"> | ||||
|                            <div class="form-group mb-4"> | ||||
|                               <div class="col-6 col-sm-12"> | ||||
|                                  <label class="form-label"> | ||||
|                                     <i class="mdi mdi-18px mdi-translate mr-1" /> | ||||
|                                     {{ $t('word.language') }}: | ||||
|                                  </label> | ||||
|                               </div> | ||||
|                               <div class="col-6 col-sm-12"> | ||||
|                                  <select | ||||
|                                     v-model="localLocale" | ||||
|                                     class="form-select" | ||||
|                                     @change="changeLocale(localLocale)" | ||||
|                                  > | ||||
|                                  <span class="input-group-addon">{{ $t('word.seconds') }}</span> | ||||
|                                     <option | ||||
|                                        v-for="(locale, key) in locales" | ||||
|                                        :key="key" | ||||
|                                        :value="locale.code" | ||||
|                                     > | ||||
|                                        {{ locale.name }} | ||||
|                                     </option> | ||||
|                                  </select> | ||||
|                               </div> | ||||
|                            </div> | ||||
|                            <div class="form-group"> | ||||
|                               <div class="col-6 col-sm-12"> | ||||
|                                  <label class="form-label"> | ||||
|                                     {{ $t('message.notificationsTimeout') }}: | ||||
|                                  </label> | ||||
|                               </div> | ||||
|                               <div class="col-6 col-sm-12"> | ||||
|                                  <div class="input-group"> | ||||
|                                     <input | ||||
|                                        v-model="localTimeout" | ||||
|                                        class="form-input" | ||||
|                                        type="number" | ||||
|                                        min="1" | ||||
|                                        @focusout="checkNotificationsTimeout" | ||||
|                                     > | ||||
|                                     <span class="input-group-addon">{{ $t('word.seconds') }}</span> | ||||
|                                  </div> | ||||
|                               </div> | ||||
|                            </div> | ||||
|                         </div> | ||||
|                      </div> | ||||
|                   </form> | ||||
|  | ||||
|                         <div class="column col-12 h6 mt-4 text-uppercase mb-1"> | ||||
|                            {{ $t('word.editor') }} | ||||
|                         </div> | ||||
|                         <div class="column col-8 col-sm-12"> | ||||
|                            <div class="form-group"> | ||||
|                               <div class="col-6 col-sm-12"> | ||||
|                                  <label class="form-label"> | ||||
|                                     {{ $t('word.autoCompletion') }}: | ||||
|                                  </label> | ||||
|                               </div> | ||||
|                               <div class="col-6 col-sm-12"> | ||||
|                                  <label class="form-switch d-inline-block" @click.prevent="toggleAutoComplete"> | ||||
|                                     <input type="checkbox" :checked="selectedAutoComplete"> | ||||
|                                     <i class="form-icon" /> | ||||
|                                  </label> | ||||
|                               </div> | ||||
|                            </div> | ||||
|                         </div> | ||||
|                      </form> | ||||
|                   </div> | ||||
|                </div> | ||||
|  | ||||
|                <div v-if="selectedTab === 'themes'" class="panel-body py-4"> | ||||
|                   <div class="container"> | ||||
|                      <div class="columns"> | ||||
|                         <div class="column col-12 h5 mb-2 "> | ||||
|                         <div class="column col-12 h6 text-uppercase mb-2"> | ||||
|                            {{ $t('message.applicationTheme') }} | ||||
|                         </div> | ||||
|                         <div class="column col-6 c-hand theme-block" :class="{'selected': applicationTheme === 'dark'}"> | ||||
| @@ -121,7 +144,7 @@ | ||||
|                      </div> | ||||
|  | ||||
|                      <div class="columns mt-4"> | ||||
|                         <div class="column col-12 h5 mb-2"> | ||||
|                         <div class="column col-12 h6 text-uppercase mb-2 mt-4"> | ||||
|                            {{ $t('message.editorTheme') }} | ||||
|                         </div> | ||||
|                         <div class="column col-6 h5 mb-4"> | ||||
| @@ -256,6 +279,7 @@ export default { | ||||
|          appVersion: 'application/appVersion', | ||||
|          selectedSettingTab: 'application/selectedSettingTab', | ||||
|          selectedLocale: 'settings/getLocale', | ||||
|          selectedAutoComplete: 'settings/getAutoComplete', | ||||
|          notificationsTimeout: 'settings/getNotificationsTimeout', | ||||
|          applicationTheme: 'settings/getApplicationTheme', | ||||
|          editorTheme: 'settings/getEditorTheme', | ||||
| @@ -308,6 +332,7 @@ ORDER BY | ||||
|       ...mapActions({ | ||||
|          closeModal: 'application/hideSettingModal', | ||||
|          changeLocale: 'settings/changeLocale', | ||||
|          changeAutoComplete: 'settings/changeAutoComplete', | ||||
|          changeEditorTheme: 'settings/changeEditorTheme', | ||||
|          updateNotificationsTimeout: 'settings/updateNotificationsTimeout' | ||||
|       }), | ||||
| @@ -327,6 +352,9 @@ ORDER BY | ||||
|          e.stopPropagation(); | ||||
|          if (e.key === 'Escape') | ||||
|             this.closeModal(); | ||||
|       }, | ||||
|       toggleAutoComplete () { | ||||
|          this.changeAutoComplete(!this.selectedAutoComplete); | ||||
|       } | ||||
|    } | ||||
| }; | ||||
|   | ||||
| @@ -34,21 +34,24 @@ export default { | ||||
|    }, | ||||
|    computed: { | ||||
|       ...mapGetters({ | ||||
|          editorTheme: 'settings/getEditorTheme' | ||||
|          editorTheme: 'settings/getEditorTheme', | ||||
|          autoComplete: 'settings/getAutoComplete' | ||||
|       }), | ||||
|       tables () { | ||||
|          return this.workspace.structure.filter(schema => schema.name === this.schema) | ||||
|             .reduce((acc, curr) => { | ||||
|                acc.push(...curr.tables); | ||||
|                return acc; | ||||
|             }, []).map(table => { | ||||
|                return { | ||||
|                   name: table.name, | ||||
|                   comment: table.comment, | ||||
|                   type: table.type, | ||||
|                   fields: [] | ||||
|                }; | ||||
|             }); | ||||
|          return this.workspace | ||||
|             ? this.workspace.structure.filter(schema => schema.name === this.schema) | ||||
|                .reduce((acc, curr) => { | ||||
|                   acc.push(...curr.tables); | ||||
|                   return acc; | ||||
|                }, []).map(table => { | ||||
|                   return { | ||||
|                      name: table.name, | ||||
|                      comment: table.comment, | ||||
|                      type: table.type, | ||||
|                      fields: [] | ||||
|                   }; | ||||
|                }) | ||||
|             : []; | ||||
|       }, | ||||
|       mode () { | ||||
|          switch (this.workspace.client) { | ||||
| @@ -90,6 +93,13 @@ export default { | ||||
|       editorTheme () { | ||||
|          if (this.editor) | ||||
|             this.editor.setTheme(`ace/theme/${this.editorTheme}`); | ||||
|       }, | ||||
|       autoComplete () { | ||||
|          if (this.editor) { | ||||
|             this.editor.setOptions({ | ||||
|                enableLiveAutocompletion: this.autoComplete | ||||
|             }); | ||||
|          } | ||||
|       } | ||||
|    }, | ||||
|    mounted () { | ||||
| @@ -105,7 +115,7 @@ export default { | ||||
|       this.editor.setOptions({ | ||||
|          enableBasicAutocompletion: true, | ||||
|          enableSnippets: true, | ||||
|          enableLiveAutocompletion: true | ||||
|          enableLiveAutocompletion: this.autoComplete | ||||
|       }); | ||||
|  | ||||
|       this.editor.completers.push({ | ||||
|   | ||||
| @@ -64,7 +64,10 @@ module.exports = { | ||||
|       stay: 'Stay', | ||||
|       author: 'Author', | ||||
|       light: 'Light', | ||||
|       dark: 'Dark' | ||||
|       dark: 'Dark', | ||||
|       autoCompletion: 'Auto Completion', | ||||
|       application: 'Application', | ||||
|       editor: 'Editor' | ||||
|    }, | ||||
|    message: { | ||||
|       appWelcome: 'Welcome to Antares SQL Client!', | ||||
|   | ||||
| @@ -10,6 +10,7 @@ export default { | ||||
|       locale: persistentStore.get('locale') || 'en-US', | ||||
|       explorebar_size: persistentStore.get('explorebar_size') || null, | ||||
|       notifications_timeout: persistentStore.get('notifications_timeout') || 5, | ||||
|       auto_complete: persistentStore.get('auto_complete') || true, | ||||
|       application_theme: persistentStore.get('application_theme') || 'dark', | ||||
|       editor_theme: persistentStore.get('editor_theme') || 'twilight' | ||||
|    }, | ||||
| @@ -17,6 +18,7 @@ export default { | ||||
|       getLocale: state => state.locale, | ||||
|       getExplorebarSize: state => state.explorebar_size, | ||||
|       getNotificationsTimeout: state => state.notifications_timeout, | ||||
|       getAutoComplete: state => state.auto_complete, | ||||
|       getApplicationTheme: state => state.application_theme, | ||||
|       getEditorTheme: state => state.editor_theme | ||||
|    }, | ||||
| @@ -30,6 +32,10 @@ export default { | ||||
|          state.notifications_timeout = timeout; | ||||
|          persistentStore.set('notifications_timeout', state.notifications_timeout); | ||||
|       }, | ||||
|       SET_AUTO_COMPLETE (state, val) { | ||||
|          state.auto_complete = val; | ||||
|          persistentStore.set('auto_complete', state.auto_complete); | ||||
|       }, | ||||
|       SET_EXPLOREBAR_SIZE (state, size) { | ||||
|          state.explorebar_size = size; | ||||
|          persistentStore.set('explorebar_size', state.explorebar_size); | ||||
| @@ -48,6 +54,9 @@ export default { | ||||
|       changeExplorebarSize ({ commit }, size) { | ||||
|          commit('SET_EXPLOREBAR_SIZE', size); | ||||
|       }, | ||||
|       changeAutoComplete ({ commit }, val) { | ||||
|          commit('SET_AUTO_COMPLETE', val); | ||||
|       }, | ||||
|       changeEditorTheme ({ commit }, theme) { | ||||
|          commit('SET_EDITOR_THEME', theme); | ||||
|       } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user