mirror of
				https://github.com/Fabio286/antares.git
				synced 2025-06-05 21:59:22 +02:00 
			
		
		
		
	refactor: improved vue-i18n implementation
This commit is contained in:
		| @@ -64,7 +64,7 @@ | ||||
|       "target": [ | ||||
|         { | ||||
|           "target": "deb", | ||||
|           "arch":[ | ||||
|           "arch": [ | ||||
|             "x64", | ||||
|             "armv7l", | ||||
|             "arm64" | ||||
|   | ||||
| @@ -31,13 +31,13 @@ | ||||
|                      class="btn btn-primary mr-2" | ||||
|                      @click.stop="confirmModal" | ||||
|                   > | ||||
|                      {{ confirmText || $t('word.confirm') }} | ||||
|                      {{ confirmText || t('word.confirm') }} | ||||
|                   </button> | ||||
|                   <button | ||||
|                      class="btn btn-link" | ||||
|                      @click="hideModal" | ||||
|                   > | ||||
|                      {{ cancelText || $t('word.cancel') }} | ||||
|                      {{ cancelText || t('word.cancel') }} | ||||
|                   </button> | ||||
|                </div> | ||||
|             </div> | ||||
| @@ -49,6 +49,9 @@ | ||||
| <script setup lang="ts"> | ||||
| import { useFocusTrap } from '@/composables/useFocusTrap'; | ||||
| import { computed, onBeforeUnmount, PropType, useSlots } from 'vue'; | ||||
| import { useI18n } from 'vue-i18n'; | ||||
|  | ||||
| const { t } = useI18n(); | ||||
|  | ||||
| const props = defineProps({ | ||||
|    size: { | ||||
|   | ||||
| @@ -431,6 +431,12 @@ export default defineComponent({ | ||||
|     width: 100%; | ||||
|   } | ||||
|  | ||||
|   &__item-text { | ||||
|     overflow: hidden; | ||||
|     white-space: nowrap; | ||||
|     text-overflow: ellipsis; | ||||
|   } | ||||
|  | ||||
|   &__list-wrapper { | ||||
|     cursor: pointer; | ||||
|     position: fixed; | ||||
|   | ||||
| @@ -4,7 +4,7 @@ | ||||
|          v-model="selectedGroup" | ||||
|          class="form-select" | ||||
|          :options="[{name: 'manual'}, ...fakerGroups]" | ||||
|          :option-label="(opt: any) => opt.name === 'manual' ? $t('message.manualValue') : $t(`faker.${opt.name}`)" | ||||
|          :option-label="(opt: any) => opt.name === 'manual' ? t('message.manualValue') : t(`faker.${opt.name}`)" | ||||
|          option-track-by="name" | ||||
|          :disabled="!isChecked" | ||||
|          style="flex-grow: 0;" | ||||
| @@ -15,7 +15,7 @@ | ||||
|          v-if="selectedGroup !== 'manual'" | ||||
|          v-model="selectedMethod" | ||||
|          :options="fakerMethods" | ||||
|          :option-label="(opt: any) => $t(`faker.${opt.name}`)" | ||||
|          :option-label="(opt: any) => t(`faker.${opt.name}`)" | ||||
|          option-track-by="name" | ||||
|          class="form-select" | ||||
|          :disabled="!isChecked" | ||||
| @@ -41,7 +41,7 @@ | ||||
|       <BaseUploadInput | ||||
|          v-else-if="inputProps().type === 'file'" | ||||
|          :model-value="selectedValue" | ||||
|          :message="$t('word.browse')" | ||||
|          :message="t('word.browse')" | ||||
|          @clear="clearValue" | ||||
|          @change="filesChange($event)" | ||||
|       /> | ||||
| @@ -92,6 +92,9 @@ import BaseUploadInput from '@/components/BaseUploadInput.vue'; | ||||
| import ForeignKeySelect from '@/components/ForeignKeySelect.vue'; | ||||
| import FakerMethods from 'common/FakerMethods'; | ||||
| import BaseSelect from '@/components/BaseSelect.vue'; | ||||
| import { useI18n } from 'vue-i18n'; | ||||
|  | ||||
| const { t } = useI18n(); | ||||
|  | ||||
| const props = defineProps({ | ||||
|    type: String, | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|                <div class="modal-title h6"> | ||||
|                   <div class="d-flex"> | ||||
|                      <i class="mdi mdi-24px mdi-apps mr-1" /> | ||||
|                      <span class="cut-text">{{ $t('message.allConnections') }}</span> | ||||
|                      <span class="cut-text">{{ t('message.allConnections') }}</span> | ||||
|                   </div> | ||||
|                </div> | ||||
|                <a class="btn btn-clear c-hand" @click.stop="closeModal" /> | ||||
|   | ||||
| @@ -6,7 +6,7 @@ | ||||
|             <div class="modal-header pl-2"> | ||||
|                <div class="modal-title h6"> | ||||
|                   <div class="d-flex"> | ||||
|                      <i class="mdi mdi-24px mdi-key-variant mr-1" /> {{ $t('word.credentials') }} | ||||
|                      <i class="mdi mdi-24px mdi-key-variant mr-1" /> {{ t('word.credentials') }} | ||||
|                   </div> | ||||
|                </div> | ||||
|                <a class="btn btn-clear c-hand" @click.stop="closeModal" /> | ||||
| @@ -16,7 +16,7 @@ | ||||
|                   <form class="form-horizontal"> | ||||
|                      <div class="form-group"> | ||||
|                         <div class="col-3"> | ||||
|                            <label class="form-label">{{ $t('word.user') }}</label> | ||||
|                            <label class="form-label">{{ t('word.user') }}</label> | ||||
|                         </div> | ||||
|                         <div class="col-9"> | ||||
|                            <input | ||||
| @@ -29,7 +29,7 @@ | ||||
|                      </div> | ||||
|                      <div class="form-group"> | ||||
|                         <div class="col-3"> | ||||
|                            <label class="form-label">{{ $t('word.password') }}</label> | ||||
|                            <label class="form-label">{{ t('word.password') }}</label> | ||||
|                         </div> | ||||
|                         <div class="col-9"> | ||||
|                            <input | ||||
| @@ -44,10 +44,10 @@ | ||||
|             </div> | ||||
|             <div class="modal-footer"> | ||||
|                <button class="btn btn-primary mr-2" @click.stop="sendCredentials"> | ||||
|                   {{ $t('word.send') }} | ||||
|                   {{ t('word.send') }} | ||||
|                </button> | ||||
|                <button class="btn btn-link" @click.stop="closeModal"> | ||||
|                   {{ $t('word.close') }} | ||||
|                   {{ t('word.close') }} | ||||
|                </button> | ||||
|             </div> | ||||
|          </div> | ||||
| @@ -58,6 +58,9 @@ | ||||
| <script setup lang="ts"> | ||||
| import { Ref, ref } from 'vue'; | ||||
| import { useFocusTrap } from '@/composables/useFocusTrap'; | ||||
| import { useI18n } from 'vue-i18n'; | ||||
|  | ||||
| const { t } = useI18n(); | ||||
|  | ||||
| const { trapRef } = useFocusTrap(); | ||||
|  | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| <template> | ||||
|    <ConfirmModal | ||||
|       :confirm-text="$t('word.run')" | ||||
|       :cancel-text="$t('word.cancel')" | ||||
|       :confirm-text="t('word.run')" | ||||
|       :cancel-text="t('word.cancel')" | ||||
|       size="400" | ||||
|       @confirm="runRoutine" | ||||
|       @hide="closeModal" | ||||
| @@ -9,7 +9,7 @@ | ||||
|       <template #header> | ||||
|          <div class="d-flex"> | ||||
|             <i class="mdi mdi-24px mdi-play mr-1" /> | ||||
|             <span class="cut-text">{{ $t('word.parameters') }}: {{ localRoutine.name }}</span> | ||||
|             <span class="cut-text">{{ t('word.parameters') }}: {{ localRoutine.name }}</span> | ||||
|          </div> | ||||
|       </template> | ||||
|       <template #body> | ||||
| @@ -53,6 +53,9 @@ import { NUMBER, FLOAT } from 'common/fieldTypes'; | ||||
| import { FunctionInfos, RoutineInfos } from 'common/interfaces/antares'; | ||||
| import ConfirmModal from '@/components/BaseConfirmModal.vue'; | ||||
| import { useFilters } from '@/composables/useFilters'; | ||||
| import { useI18n } from 'vue-i18n'; | ||||
|  | ||||
| const { t } = useI18n(); | ||||
|  | ||||
| const { wrapNumber } = useFilters(); | ||||
|  | ||||
|   | ||||
| @@ -1,18 +1,18 @@ | ||||
| <template> | ||||
|    <ConfirmModal | ||||
|       :confirm-text="$t('word.discard')" | ||||
|       :cancel-text="$t('word.stay')" | ||||
|       :confirm-text="t('word.discard')" | ||||
|       :cancel-text="t('word.stay')" | ||||
|       @confirm="emit('confirm')" | ||||
|       @hide="emit('close')" | ||||
|    > | ||||
|       <template #header> | ||||
|          <div class="d-flex"> | ||||
|             <i class="mdi mdi-24px mdi-content-save-alert mr-1" /> {{ $t('message.unsavedChanges') }} | ||||
|             <i class="mdi mdi-24px mdi-content-save-alert mr-1" /> {{ t('message.unsavedChanges') }} | ||||
|          </div> | ||||
|       </template> | ||||
|       <template #body> | ||||
|          <div> | ||||
|             {{ $t('message.discardUnsavedChanges') }} | ||||
|             {{ t('message.discardUnsavedChanges') }} | ||||
|          </div> | ||||
|       </template> | ||||
|    </ConfirmModal> | ||||
| @@ -21,6 +21,9 @@ | ||||
| <script setup lang="ts"> | ||||
| import ConfirmModal from '@/components/BaseConfirmModal.vue'; | ||||
| import { onBeforeUnmount } from 'vue'; | ||||
| import { useI18n } from 'vue-i18n'; | ||||
|  | ||||
| const { t } = useI18n(); | ||||
|  | ||||
| const emit = defineEmits(['confirm', 'close']); | ||||
|  | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|                <div class="modal-title h6"> | ||||
|                   <div class="d-flex"> | ||||
|                      <i class="mdi mdi-24px mdi-database-edit mr-1" /> | ||||
|                      <span class="cut-text">{{ $t('message.editSchema') }}</span> | ||||
|                      <span class="cut-text">{{ t('message.editSchema') }}</span> | ||||
|                   </div> | ||||
|                </div> | ||||
|                <a class="btn btn-clear c-hand" @click.stop="closeModal" /> | ||||
| @@ -17,7 +17,7 @@ | ||||
|                   <form class="form-horizontal"> | ||||
|                      <div class="form-group"> | ||||
|                         <div class="col-3"> | ||||
|                            <label class="form-label">{{ $t('word.name') }}</label> | ||||
|                            <label class="form-label">{{ t('word.name') }}</label> | ||||
|                         </div> | ||||
|                         <div class="col-9"> | ||||
|                            <input | ||||
| @@ -26,14 +26,14 @@ | ||||
|                               class="form-input" | ||||
|                               type="text" | ||||
|                               required | ||||
|                               :placeholder="$t('message.schemaName')" | ||||
|                               :placeholder="t('message.schemaName')" | ||||
|                               readonly | ||||
|                            > | ||||
|                         </div> | ||||
|                      </div> | ||||
|                      <div class="form-group"> | ||||
|                         <div class="col-3"> | ||||
|                            <label class="form-label">{{ $t('word.collation') }}</label> | ||||
|                            <label class="form-label">{{ t('word.collation') }}</label> | ||||
|                         </div> | ||||
|                         <div class="col-9"> | ||||
|                            <BaseSelect | ||||
| @@ -43,7 +43,7 @@ | ||||
|                               option-label="collation" | ||||
|                               option-track-by="collation" | ||||
|                            /> | ||||
|                            <small>{{ $t('message.serverDefault') }}: {{ defaultCollation }}</small> | ||||
|                            <small>{{ t('message.serverDefault') }}: {{ defaultCollation }}</small> | ||||
|                         </div> | ||||
|                      </div> | ||||
|                   </form> | ||||
| @@ -51,10 +51,10 @@ | ||||
|             </div> | ||||
|             <div class="modal-footer"> | ||||
|                <button class="btn btn-primary mr-2" @click.stop="updateSchema"> | ||||
|                   {{ $t('word.update') }} | ||||
|                   {{ t('word.update') }} | ||||
|                </button> | ||||
|                <button class="btn btn-link" @click.stop="closeModal"> | ||||
|                   {{ $t('word.close') }} | ||||
|                   {{ t('word.close') }} | ||||
|                </button> | ||||
|             </div> | ||||
|          </div> | ||||
| @@ -70,6 +70,9 @@ import { useWorkspacesStore } from '@/stores/workspaces'; | ||||
| import { useFocusTrap } from '@/composables/useFocusTrap'; | ||||
| import Schema from '@/ipc-api/Schema'; | ||||
| import BaseSelect from '@/components/BaseSelect.vue'; | ||||
| import { useI18n } from 'vue-i18n'; | ||||
|  | ||||
| const { t } = useI18n(); | ||||
|  | ||||
| const props = defineProps({ | ||||
|    selectedSchema: String | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|                <div class="modal-title h6"> | ||||
|                   <div class="d-flex"> | ||||
|                      <i class="mdi mdi-24px mdi-database-arrow-down mr-1" /> | ||||
|                      <span class="cut-text">{{ $t('message.exportSchema') }}</span> | ||||
|                      <span class="cut-text">{{ t('message.exportSchema') }}</span> | ||||
|                   </div> | ||||
|                </div> | ||||
|                <a class="btn btn-clear c-hand" @click.stop="closeModal" /> | ||||
| @@ -16,7 +16,7 @@ | ||||
|                <div class="container"> | ||||
|                   <div class="columns"> | ||||
|                      <div class="col-3"> | ||||
|                         <label class="form-label">{{ $t('message.directoryPath') }}</label> | ||||
|                         <label class="form-label">{{ t('message.directoryPath') }}</label> | ||||
|                      </div> | ||||
|                      <div class="col-9"> | ||||
|                         <fieldset class="input-group"> | ||||
| @@ -26,14 +26,14 @@ | ||||
|                               type="text" | ||||
|                               required | ||||
|                               readonly | ||||
|                               :placeholder="$t('message.schemaName')" | ||||
|                               :placeholder="t('message.schemaName')" | ||||
|                            > | ||||
|                            <button | ||||
|                               type="button" | ||||
|                               class="btn btn-primary input-group-btn" | ||||
|                               @click.prevent="openPathDialog" | ||||
|                            > | ||||
|                               {{ $t('word.change') }} | ||||
|                               {{ t('word.change') }} | ||||
|                            </button> | ||||
|                         </fieldset> | ||||
|                      </div> | ||||
| @@ -51,14 +51,14 @@ | ||||
|                         <div class="column col-auto col-ml-auto "> | ||||
|                            <button | ||||
|                               class="btn btn-dark btn-sm" | ||||
|                               :title="$t('word.refresh')" | ||||
|                               :title="t('word.refresh')" | ||||
|                               @click="refresh" | ||||
|                            > | ||||
|                               <i class="mdi mdi-database-refresh" /> | ||||
|                            </button> | ||||
|                            <button | ||||
|                               class="btn btn-dark btn-sm mx-1" | ||||
|                               :title="$t('message.uncheckAllTables')" | ||||
|                               :title="t('message.uncheckAllTables')" | ||||
|                               :disabled="isRefreshing" | ||||
|                               @click="uncheckAllTables" | ||||
|                            > | ||||
| @@ -66,7 +66,7 @@ | ||||
|                            </button> | ||||
|                            <button | ||||
|                               class="btn btn-dark btn-sm" | ||||
|                               :title="$t('message.checkAllTables')" | ||||
|                               :title="t('message.checkAllTables')" | ||||
|                               :disabled="isRefreshing" | ||||
|                               @click="checkAllTables" | ||||
|                            > | ||||
| @@ -122,22 +122,22 @@ | ||||
|                               <div class="tr"> | ||||
|                                  <div class="th" style="width: 50%;"> | ||||
|                                     <div class="table-column-title"> | ||||
|                                        <span>{{ $t('word.table') }}</span> | ||||
|                                        <span>{{ t('word.table') }}</span> | ||||
|                                     </div> | ||||
|                                  </div> | ||||
|                                  <div class="th text-center"> | ||||
|                                     <div class="table-column-title"> | ||||
|                                        <span>{{ $t('word.structure') }}</span> | ||||
|                                        <span>{{ t('word.structure') }}</span> | ||||
|                                     </div> | ||||
|                                  </div> | ||||
|                                  <div class="th text-center"> | ||||
|                                     <div class="table-column-title"> | ||||
|                                        <span>{{ $t('word.content') }}</span> | ||||
|                                        <span>{{ t('word.content') }}</span> | ||||
|                                     </div> | ||||
|                                  </div> | ||||
|                                  <div class="th text-center"> | ||||
|                                     <div class="table-column-title"> | ||||
|                                        <span>{{ $t('word.drop') }}</span> | ||||
|                                        <span>{{ t('word.drop') }}</span> | ||||
|                                     </div> | ||||
|                                  </div> | ||||
|                               </div> | ||||
| @@ -183,19 +183,19 @@ | ||||
|                   </div> | ||||
|                   <div class="column col-4"> | ||||
|                      <h5 class="h5"> | ||||
|                         {{ $t('word.options') }} | ||||
|                         {{ t('word.options') }} | ||||
|                      </h5> | ||||
|                      <span class="h6">{{ $t('word.includes') }}:</span> | ||||
|                      <span class="h6">{{ t('word.includes') }}:</span> | ||||
|                      <label | ||||
|                         v-for="(_, key) in options.includes" | ||||
|                         :key="key" | ||||
|                         class="form-checkbox" | ||||
|                      > | ||||
|                         <input v-model="options.includes[key]" type="checkbox"><i class="form-icon" /> {{ $tc(`word.${key}`, 2) }} | ||||
|                         <input v-model="options.includes[key]" type="checkbox"><i class="form-icon" /> {{ t(`word.${key}`, 2) }} | ||||
|                      </label> | ||||
|                      <div v-if="clientCustoms.exportByChunks"> | ||||
|                         <div class="h6 mt-4 mb-2"> | ||||
|                            {{ $t('message.newInserStmtEvery') }}: | ||||
|                            {{ t('message.newInserStmtEvery') }}: | ||||
|                         </div> | ||||
|                         <div class="columns"> | ||||
|                            <div class="column col-6"> | ||||
| @@ -209,21 +209,21 @@ | ||||
|                               <BaseSelect | ||||
|                                  v-model="options.sqlInsertDivider" | ||||
|                                  class="form-select" | ||||
|                                  :options="[{value: 'bytes', label: 'KiB'}, {value: 'rows', label: $tc('word.row', 2)}]" | ||||
|                                  :options="[{value: 'bytes', label: 'KiB'}, {value: 'rows', label: t('word.row', 2)}]" | ||||
|                               /> | ||||
|                            </div> | ||||
|                         </div> | ||||
|                      </div> | ||||
|  | ||||
|                      <div class="h6 mb-2 mt-4"> | ||||
|                         {{ $t('message.ourputFormat') }}: | ||||
|                         {{ t('message.ourputFormat') }}: | ||||
|                      </div> | ||||
|                      <div class="columns"> | ||||
|                         <div class="column h5 mb-4"> | ||||
|                            <BaseSelect | ||||
|                               v-model="options.outputFormat" | ||||
|                               class="form-select" | ||||
|                               :options="[{value: 'sql', label: $t('message.singleFile', {ext: '.sql'})}, {value: 'sql.zip', label: $t('message.zipCompressedFile', {ext: '.sql'})}]" | ||||
|                               :options="[{value: 'sql', label: t('message.singleFile', {ext: '.sql'})}, {value: 'sql.zip', label: t('message.zipCompressedFile', {ext: '.sql'})}]" | ||||
|                            /> | ||||
|                         </div> | ||||
|                      </div> | ||||
| @@ -245,7 +245,7 @@ | ||||
|                </div> | ||||
|                <div class="column col-auto px-0"> | ||||
|                   <button class="btn btn-link" @click.stop="closeModal"> | ||||
|                      {{ $t('word.close') }} | ||||
|                      {{ t('word.close') }} | ||||
|                   </button> | ||||
|                   <button | ||||
|                      class="btn btn-primary mr-2" | ||||
| @@ -254,7 +254,7 @@ | ||||
|                      autofocus | ||||
|                      @click.prevent="startExport" | ||||
|                   > | ||||
|                      {{ $t('word.export') }} | ||||
|                      {{ t('word.export') }} | ||||
|                   </button> | ||||
|                </div> | ||||
|             </div> | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|                <div class="modal-title h6"> | ||||
|                   <div class="d-flex"> | ||||
|                      <i class="mdi mdi-24px mdi-playlist-plus mr-1" /> | ||||
|                      <span class="cut-text">{{ $tc('message.insertRow', 2) }}</span> | ||||
|                      <span class="cut-text">{{ t('message.insertRow', 2) }}</span> | ||||
|                   </div> | ||||
|                </div> | ||||
|                <a class="btn btn-clear c-hand" @click.stop="closeModal" /> | ||||
| @@ -39,7 +39,7 @@ | ||||
|                                  <span class="input-group-addon field-type" :class="typeClass(field.type)"> | ||||
|                                     {{ field.type }} {{ wrapNumber(fieldLength(field)) }} | ||||
|                                  </span> | ||||
|                                  <label class="form-checkbox ml-3" :title="$t('word.insert')"> | ||||
|                                  <label class="form-checkbox ml-3" :title="t('word.insert')"> | ||||
|                                     <input | ||||
|                                        type="checkbox" | ||||
|                                        :checked="!fieldsToExclude.includes(field.name)" | ||||
| @@ -55,7 +55,7 @@ | ||||
|             </div> | ||||
|             <div class="modal-footer columns"> | ||||
|                <div class="column d-flex" :class="hasFakes ? 'col-4' : 'col-2'"> | ||||
|                   <div class="input-group tooltip tooltip-right" :data-tooltip="$t('message.numberOfInserts')"> | ||||
|                   <div class="input-group tooltip tooltip-right" :data-tooltip="t('message.numberOfInserts')"> | ||||
|                      <input | ||||
|                         v-model="nInserts" | ||||
|                         type="number" | ||||
| @@ -70,7 +70,7 @@ | ||||
|                   <div | ||||
|                      v-if="hasFakes" | ||||
|                      class="tooltip tooltip-right ml-2" | ||||
|                      :data-tooltip="$t('message.fakeDataLanguage')" | ||||
|                      :data-tooltip="t('message.fakeDataLanguage')" | ||||
|                   > | ||||
|                      <BaseSelect | ||||
|                         v-model="fakerLocale" | ||||
| @@ -85,10 +85,10 @@ | ||||
|                      :class="{'loading': isInserting}" | ||||
|                      @click.stop="insertRows" | ||||
|                   > | ||||
|                      {{ $t('word.insert') }} | ||||
|                      {{ t('word.insert') }} | ||||
|                   </button> | ||||
|                   <button class="btn btn-link" @click.stop="closeModal"> | ||||
|                      {{ $t('word.close') }} | ||||
|                      {{ t('word.close') }} | ||||
|                   </button> | ||||
|                </div> | ||||
|             </div> | ||||
| @@ -110,6 +110,9 @@ import Tables from '@/ipc-api/Tables'; | ||||
| import FakerSelect from '@/components/FakerSelect.vue'; | ||||
| import BaseSelect from '@/components/BaseSelect.vue'; | ||||
| import { useFilters } from '@/composables/useFilters'; | ||||
| import { useI18n } from 'vue-i18n'; | ||||
|  | ||||
| const { t } = useI18n(); | ||||
|  | ||||
| const { wrapNumber } = useFilters(); | ||||
|  | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|                <div class="modal-title h6"> | ||||
|                   <div class="d-flex"> | ||||
|                      <i class="mdi mdi-24px mdi-database-arrow-up mr-1" /> | ||||
|                      <span class="cut-text">{{ $t('message.importSchema') }}</span> | ||||
|                      <span class="cut-text">{{ t('message.importSchema') }}</span> | ||||
|                   </div> | ||||
|                </div> | ||||
|                <a class="btn btn-clear c-hand" @click.stop="closeModal" /> | ||||
| @@ -15,7 +15,7 @@ | ||||
|             <div class="modal-body pb-0"> | ||||
|                {{ sqlFile }} | ||||
|                <div v-if="queryErrors.length > 0" class="mt-2"> | ||||
|                   <label>{{ $tc('message.importQueryErrors', queryErrors.length) }}</label> | ||||
|                   <label>{{ t('message.importQueryErrors', queryErrors.length) }}</label> | ||||
|                   <textarea | ||||
|                      v-model="formattedQueryErrors" | ||||
|                      class="form-input" | ||||
| @@ -28,7 +28,7 @@ | ||||
|                <div class="column col modal-progress-wrapper text-left"> | ||||
|                   <div class="import-progress"> | ||||
|                      <span class="progress-status"> | ||||
|                         {{ progressPercentage }}% - {{ progressStatus }} - {{ $tc('message.executedQueries', queryCount) }} | ||||
|                         {{ progressPercentage }}% - {{ progressStatus }} - {{ t('message.executedQueries', queryCount) }} | ||||
|                      </span> | ||||
|                      <progress | ||||
|                         class="progress d-block" | ||||
| @@ -39,7 +39,7 @@ | ||||
|                </div> | ||||
|                <div class="column col-auto px-0"> | ||||
|                   <button class="btn btn-link" @click.stop="closeModal"> | ||||
|                      {{ completed ? $t('word.close') : $t('word.cancel') }} | ||||
|                      {{ completed ? t('word.close') : t('word.cancel') }} | ||||
|                   </button> | ||||
|                </div> | ||||
|             </div> | ||||
| @@ -57,8 +57,8 @@ import { storeToRefs } from 'pinia'; | ||||
| import { useNotificationsStore } from '@/stores/notifications'; | ||||
| import { useWorkspacesStore } from '@/stores/workspaces'; | ||||
| import Schema from '@/ipc-api/Schema'; | ||||
| import { useI18n } from 'vue-i18n'; | ||||
| import { ImportState } from 'common/interfaces/importer'; | ||||
| import { useI18n } from 'vue-i18n'; | ||||
|  | ||||
| const { t } = useI18n(); | ||||
|  | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|                <div class="modal-title h6"> | ||||
|                   <div class="d-flex"> | ||||
|                      <i class="mdi mdi-24px mdi-database-plus mr-1" /> | ||||
|                      <span class="cut-text">{{ $t('message.createNewSchema') }}</span> | ||||
|                      <span class="cut-text">{{ t('message.createNewSchema') }}</span> | ||||
|                   </div> | ||||
|                </div> | ||||
|                <a class="btn btn-clear c-hand" @click.stop="closeModal" /> | ||||
| @@ -17,7 +17,7 @@ | ||||
|                   <form class="form-horizontal" @submit.prevent="createSchema"> | ||||
|                      <div class="form-group"> | ||||
|                         <div class="col-3"> | ||||
|                            <label class="form-label">{{ $t('word.name') }}</label> | ||||
|                            <label class="form-label">{{ t('word.name') }}</label> | ||||
|                         </div> | ||||
|                         <div class="col-9"> | ||||
|                            <input | ||||
| @@ -26,13 +26,13 @@ | ||||
|                               class="form-input" | ||||
|                               type="text" | ||||
|                               required | ||||
|                               :placeholder="$t('message.schemaName')" | ||||
|                               :placeholder="t('message.schemaName')" | ||||
|                            > | ||||
|                         </div> | ||||
|                      </div> | ||||
|                      <div v-if="customizations.collations" class="form-group"> | ||||
|                         <div class="col-3"> | ||||
|                            <label class="form-label">{{ $t('word.collation') }}</label> | ||||
|                            <label class="form-label">{{ t('word.collation') }}</label> | ||||
|                         </div> | ||||
|                         <div class="col-9"> | ||||
|                            <BaseSelect | ||||
| @@ -42,7 +42,7 @@ | ||||
|                               option-label="collation" | ||||
|                               option-track-by="collation" | ||||
|                            /> | ||||
|                            <small>{{ $t('message.serverDefault') }}: {{ defaultCollation }}</small> | ||||
|                            <small>{{ t('message.serverDefault') }}: {{ defaultCollation }}</small> | ||||
|                         </div> | ||||
|                      </div> | ||||
|                   </form> | ||||
| @@ -54,10 +54,10 @@ | ||||
|                   :class="{'loading': isLoading}" | ||||
|                   @click.stop="createSchema" | ||||
|                > | ||||
|                   {{ $t('word.add') }} | ||||
|                   {{ t('word.add') }} | ||||
|                </button> | ||||
|                <button class="btn btn-link" @click.stop="closeModal"> | ||||
|                   {{ $t('word.close') }} | ||||
|                   {{ t('word.close') }} | ||||
|                </button> | ||||
|             </div> | ||||
|          </div> | ||||
| @@ -73,6 +73,9 @@ import { useWorkspacesStore } from '@/stores/workspaces'; | ||||
| import { useFocusTrap } from '@/composables/useFocusTrap'; | ||||
| import Schema from '@/ipc-api/Schema'; | ||||
| import BaseSelect from '@/components/BaseSelect.vue'; | ||||
| import { useI18n } from 'vue-i18n'; | ||||
|  | ||||
| const { t } = useI18n(); | ||||
|  | ||||
| const { addNotification } = useNotificationsStore(); | ||||
| const workspacesStore = useWorkspacesStore(); | ||||
|   | ||||
| @@ -17,7 +17,7 @@ | ||||
|                <div class="modal-title h6"> | ||||
|                   <div class="d-flex"> | ||||
|                      <i class="mdi mdi-24px mdi-memory mr-1" /> | ||||
|                      <span class="cut-text">{{ $t('message.processesList') }}: {{ connectionName }}</span> | ||||
|                      <span class="cut-text">{{ t('message.processesList') }}: {{ connectionName }}</span> | ||||
|                   </div> | ||||
|                </div> | ||||
|                <a class="btn btn-clear c-hand" @click.stop="closeModal" /> | ||||
| @@ -29,7 +29,7 @@ | ||||
|                         <button | ||||
|                            class="btn btn-dark btn-sm mr-0 pr-1 d-flex" | ||||
|                            :class="{'loading':isQuering}" | ||||
|                            :title="`${$t('word.refresh')} (F5)`" | ||||
|                            :title="`${t('word.refresh')} (F5)`" | ||||
|                            @click="getProcessesList" | ||||
|                         > | ||||
|                            <i v-if="!+autorefreshTimer" class="mdi mdi-24px mdi-refresh mr-1" /> | ||||
| @@ -39,7 +39,7 @@ | ||||
|                            <i class="mdi mdi-24px mdi-menu-down" /> | ||||
|                         </div> | ||||
|                         <div class="menu px-3"> | ||||
|                            <span>{{ $t('word.autoRefresh') }}: <b>{{ +autorefreshTimer ? `${autorefreshTimer}s` : 'OFF' }}</b></span> | ||||
|                            <span>{{ t('word.autoRefresh') }}: <b>{{ +autorefreshTimer ? `${autorefreshTimer}s` : 'OFF' }}</b></span> | ||||
|                            <input | ||||
|                               v-model="autorefreshTimer" | ||||
|                               class="slider no-border" | ||||
| @@ -59,7 +59,7 @@ | ||||
|                         tabindex="0" | ||||
|                      > | ||||
|                         <i class="mdi mdi-24px mdi-file-export mr-1" /> | ||||
|                         <span>{{ $t('word.export') }}</span> | ||||
|                         <span>{{ t('word.export') }}</span> | ||||
|                         <i class="mdi mdi-24px mdi-menu-down" /> | ||||
|                      </button> | ||||
|                      <ul class="menu text-left"> | ||||
| @@ -74,7 +74,7 @@ | ||||
|                </div> | ||||
|                <div class="workspace-query-info"> | ||||
|                   <div v-if="sortedResults.length"> | ||||
|                      {{ $t('word.processes') }}: <b>{{ sortedResults.length.toLocaleString() }}</b> | ||||
|                      {{ t('word.processes') }}: <b>{{ sortedResults.length.toLocaleString() }}</b> | ||||
|                   </div> | ||||
|                </div> | ||||
|             </div> | ||||
| @@ -144,6 +144,9 @@ import { useConnectionsStore } from '@/stores/connections'; | ||||
| import BaseVirtualScroll from '@/components/BaseVirtualScroll.vue'; | ||||
| import ModalProcessesListRow from '@/components/ModalProcessesListRow.vue'; | ||||
| import ModalProcessesListContext from '@/components/ModalProcessesListContext.vue'; | ||||
| import { useI18n } from 'vue-i18n'; | ||||
|  | ||||
| const { t } = useI18n(); | ||||
|  | ||||
| const { addNotification } = useNotificationsStore(); | ||||
| const { getConnectionName } = useConnectionsStore(); | ||||
|   | ||||
| @@ -4,7 +4,7 @@ | ||||
|       @close-context="closeContext" | ||||
|    > | ||||
|       <div v-if="props.selectedRow" class="context-element"> | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-content-copy text-light pr-1" /> {{ $t('word.copy') }}</span> | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-content-copy text-light pr-1" /> {{ t('word.copy') }}</span> | ||||
|          <i class="mdi mdi-18px mdi-chevron-right text-light pl-1" /> | ||||
|          <div class="context-submenu"> | ||||
|             <div | ||||
| @@ -13,7 +13,7 @@ | ||||
|                @click="copyCell" | ||||
|             > | ||||
|                <span class="d-flex"> | ||||
|                   <i class="mdi mdi-18px mdi-numeric-0 mdi-rotate-90 text-light pr-1" /> {{ $tc('word.cell', 1) }} | ||||
|                   <i class="mdi mdi-18px mdi-numeric-0 mdi-rotate-90 text-light pr-1" /> {{ t('word.cell', 1) }} | ||||
|                </span> | ||||
|             </div> | ||||
|             <div | ||||
| @@ -22,7 +22,7 @@ | ||||
|                @click="copyRow" | ||||
|             > | ||||
|                <span class="d-flex"> | ||||
|                   <i class="mdi mdi-18px mdi-table-row text-light pr-1" /> {{ $tc('word.row', 1) }} | ||||
|                   <i class="mdi mdi-18px mdi-table-row text-light pr-1" /> {{ t('word.row', 1) }} | ||||
|                </span> | ||||
|             </div> | ||||
|          </div> | ||||
| @@ -33,7 +33,7 @@ | ||||
|          @click="killProcess" | ||||
|       > | ||||
|          <span class="d-flex"> | ||||
|             <i class="mdi mdi-18px mdi-close-circle-outline text-light pr-1" /> {{ $t('message.killProcess') }} | ||||
|             <i class="mdi mdi-18px mdi-close-circle-outline text-light pr-1" /> {{ t('message.killProcess') }} | ||||
|          </span> | ||||
|       </div> | ||||
|    </BaseContextMenu> | ||||
| @@ -41,6 +41,9 @@ | ||||
|  | ||||
| <script setup lang="ts"> | ||||
| import BaseContextMenu from '@/components/BaseContextMenu.vue'; | ||||
| import { useI18n } from 'vue-i18n'; | ||||
|  | ||||
| const { t } = useI18n(); | ||||
|  | ||||
| const props = defineProps({ | ||||
|    contextEvent: MouseEvent, | ||||
|   | ||||
| @@ -16,15 +16,15 @@ | ||||
|       </div> | ||||
|       <ConfirmModal | ||||
|          v-if="isInfoModal" | ||||
|          :confirm-text="$t('word.update')" | ||||
|          :cancel-text="$t('word.close')" | ||||
|          :confirm-text="t('word.update')" | ||||
|          :cancel-text="t('word.close')" | ||||
|          size="medium" | ||||
|          :hide-footer="true" | ||||
|          @hide="hideInfoModal" | ||||
|       > | ||||
|          <template #header> | ||||
|             <div class="d-flex"> | ||||
|                <i class="mdi mdi-24px mdi-information-outline mr-1" /> {{ $t('message.processInfo') }} | ||||
|                <i class="mdi mdi-24px mdi-information-outline mr-1" /> {{ t('message.processInfo') }} | ||||
|             </div> | ||||
|          </template> | ||||
|          <template #body> | ||||
| @@ -49,6 +49,9 @@ import { Ref, ref } from 'vue'; | ||||
| import ConfirmModal from '@/components/BaseConfirmModal.vue'; | ||||
| import TextEditor from '@/components/BaseTextEditor.vue'; | ||||
| import { useFilters } from '@/composables/useFilters'; | ||||
| import { useI18n } from 'vue-i18n'; | ||||
|  | ||||
| const { t } = useI18n(); | ||||
|  | ||||
| const { cutText } = useFilters(); | ||||
|  | ||||
|   | ||||
| @@ -328,8 +328,9 @@ import ModalSettingsUpdate from '@/components/ModalSettingsUpdate.vue'; | ||||
| import ModalSettingsChangelog from '@/components/ModalSettingsChangelog.vue'; | ||||
| import BaseTextEditor from '@/components/BaseTextEditor.vue'; | ||||
| import BaseSelect from '@/components/BaseSelect.vue'; | ||||
| import { AvailableLocale } from '@/i18n'; | ||||
|  | ||||
| const { t, AvailableLocale } = useI18n(); | ||||
| const { t } = useI18n(); | ||||
|  | ||||
| const applicationStore = useApplicationStore(); | ||||
| const settingsStore = useSettingsStore(); | ||||
| @@ -448,7 +449,7 @@ ORDER BY | ||||
|     employee.id ASC; | ||||
| `; | ||||
|  | ||||
| const localLocale: Ref<string> = ref(null); | ||||
| const localLocale: Ref<AvailableLocale> = ref(null); | ||||
| const localPageSize: Ref<number> = ref(null); | ||||
| const localTimeout: Ref<number> = ref(null); | ||||
| const localEditorTheme: Ref<string> = ref(null); | ||||
| @@ -456,7 +457,7 @@ const selectedTab: Ref<string> = ref('general'); | ||||
|  | ||||
| const locales = computed(() => { | ||||
|    const locales = []; | ||||
|    for (const locale of AvailableLocale) | ||||
|    for (const locale of Object.keys(localesNames)) | ||||
|       locales.push({ code: locale, name: localesNames[locale] }); | ||||
|  | ||||
|    return locales; | ||||
| @@ -516,7 +517,7 @@ const toggleLineWrap = () => { | ||||
|    changeLineWrap(!selectedLineWrap.value); | ||||
| }; | ||||
|  | ||||
| localLocale.value = selectedLocale.value as string; | ||||
| localLocale.value = selectedLocale.value; | ||||
| localPageSize.value = pageSize.value as number; | ||||
| localTimeout.value = notificationsTimeout.value as number; | ||||
| localEditorTheme.value = editorTheme.value as string; | ||||
| @@ -537,6 +538,12 @@ onBeforeUnmount(() => { | ||||
|     .modal-body { | ||||
|       overflow: hidden; | ||||
|  | ||||
|       .tab-link{ | ||||
|          overflow: hidden; | ||||
|          white-space: nowrap; | ||||
|          text-overflow: ellipsis; | ||||
|       } | ||||
|  | ||||
|       .panel-body { | ||||
|         min-height: calc(25vh - 70px); | ||||
|         max-height: 65vh; | ||||
|   | ||||
| @@ -26,27 +26,27 @@ | ||||
|             :class="{'loading': updateStatus === 'checking'}" | ||||
|             @click="checkForUpdates" | ||||
|          > | ||||
|             {{ $t('message.checkForUpdates') }} | ||||
|             {{ t('message.checkForUpdates') }} | ||||
|          </button> | ||||
|          <button | ||||
|             v-else-if="updateStatus === 'downloaded'" | ||||
|             class="btn btn-primary" | ||||
|             @click="restartToUpdate" | ||||
|          > | ||||
|             {{ $t('message.restartToInstall') }} | ||||
|             {{ t('message.restartToInstall') }} | ||||
|          </button> | ||||
|          <button | ||||
|             v-else-if="updateStatus === 'link'" | ||||
|             class="btn btn-primary" | ||||
|             @click="openOutside('https://antares-sql.app/download.html')" | ||||
|          > | ||||
|             {{ $t('message.goToDownloadPage') }} | ||||
|             {{ t('message.goToDownloadPage') }} | ||||
|          </button> | ||||
|       </div> | ||||
|       <div class="form-group mt-4"> | ||||
|          <label class="form-switch d-inline-block disabled" @click.prevent="toggleAllowPrerelease"> | ||||
|             <input type="checkbox" :checked="allowPrerelease"> | ||||
|             <i class="form-icon" /> {{ $t('message.includeBetaUpdates') }} | ||||
|             <i class="form-icon" /> {{ t('message.includeBetaUpdates') }} | ||||
|          </label> | ||||
|       </div> | ||||
|    </div> | ||||
|   | ||||
| @@ -8,27 +8,27 @@ | ||||
|          class="context-element" | ||||
|          @click="unpin" | ||||
|       > | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-pin-off text-light pr-1" /> {{ $t('word.unpin') }}</span> | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-pin-off text-light pr-1" /> {{ t('word.unpin') }}</span> | ||||
|       </div> | ||||
|       <div | ||||
|          v-else | ||||
|          class="context-element" | ||||
|          @click="pin" | ||||
|       > | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-pin mdi-rotate-45 text-light pr-1" /> {{ $t('word.pin') }}</span> | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-pin mdi-rotate-45 text-light pr-1" /> {{ t('word.pin') }}</span> | ||||
|       </div> | ||||
|       <div | ||||
|          v-if="isConnected" | ||||
|          class="context-element" | ||||
|          @click="disconnect" | ||||
|       > | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-power text-light pr-1" /> {{ $t('word.disconnect') }}</span> | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-power text-light pr-1" /> {{ t('word.disconnect') }}</span> | ||||
|       </div> | ||||
|       <div class="context-element" @click="duplicateConnection"> | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-content-duplicate text-light pr-1" /> {{ $t('word.duplicate') }}</span> | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-content-duplicate text-light pr-1" /> {{ t('word.duplicate') }}</span> | ||||
|       </div> | ||||
|       <div class="context-element" @click="showConfirmModal"> | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-delete text-light pr-1" /> {{ $t('word.delete') }}</span> | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-delete text-light pr-1" /> {{ t('word.delete') }}</span> | ||||
|       </div> | ||||
|  | ||||
|       <ConfirmModal | ||||
| @@ -38,12 +38,12 @@ | ||||
|       > | ||||
|          <template #header> | ||||
|             <div class="d-flex"> | ||||
|                <i class="mdi mdi-24px mdi-server-remove mr-1" /> {{ $t('message.deleteConnection') }} | ||||
|                <i class="mdi mdi-24px mdi-server-remove mr-1" /> {{ t('message.deleteConnection') }} | ||||
|             </div> | ||||
|          </template> | ||||
|          <template #body> | ||||
|             <div class="mb-2"> | ||||
|                {{ $t('message.deleteCorfirm') }} <b>{{ connectionName }}</b>? | ||||
|                {{ t('message.deleteCorfirm') }} <b>{{ connectionName }}</b>? | ||||
|             </div> | ||||
|          </template> | ||||
|       </ConfirmModal> | ||||
|   | ||||
| @@ -1,14 +1,14 @@ | ||||
| <template> | ||||
|    <ConfirmModal | ||||
|       :confirm-text="$t('word.update')" | ||||
|       :cancel-text="$t('word.close')" | ||||
|       :confirm-text="t('word.update')" | ||||
|       :cancel-text="t('word.close')" | ||||
|       size="large" | ||||
|       :hide-footer="true" | ||||
|       @hide="hideScratchpad" | ||||
|    > | ||||
|       <template #header> | ||||
|          <div class="d-flex"> | ||||
|             <i class="mdi mdi-24px mdi-notebook-edit-outline mr-1" /> {{ $t('word.scratchpad') }} | ||||
|             <i class="mdi mdi-24px mdi-notebook-edit-outline mr-1" /> {{ t('word.scratchpad') }} | ||||
|          </div> | ||||
|       </template> | ||||
|       <template #body> | ||||
| @@ -22,7 +22,7 @@ | ||||
|                   :show-line-numbers="false" | ||||
|                /> | ||||
|             </div> | ||||
|             <small class="text-gray">{{ $t('message.markdownSupported') }}</small> | ||||
|             <small class="text-gray">{{ t('message.markdownSupported') }}</small> | ||||
|          </div> | ||||
|       </template> | ||||
|    </ConfirmModal> | ||||
| @@ -35,6 +35,9 @@ import { useApplicationStore } from '@/stores/application'; | ||||
| import { useScratchpadStore } from '@/stores/scratchpad'; | ||||
| import ConfirmModal from '@/components/BaseConfirmModal.vue'; | ||||
| import TextEditor from '@/components/BaseTextEditor.vue'; | ||||
| import { useI18n } from 'vue-i18n'; | ||||
|  | ||||
| const { t } = useI18n(); | ||||
|  | ||||
| const applicationStore = useApplicationStore(); | ||||
| const scratchpadStore = useScratchpadStore(); | ||||
|   | ||||
| @@ -55,7 +55,7 @@ | ||||
|                @mouseover.self="tooltipPosition" | ||||
|             > | ||||
|                <i class="settingbar-element-icon mdi mdi-24px mdi-dots-horizontal text-light" /> | ||||
|                <span class="ex-tooltip-content">{{ $t('message.allConnections') }} (Shift+CTRL+Space)</span> | ||||
|                <span class="ex-tooltip-content">{{ t('message.allConnections') }} (Shift+CTRL+Space)</span> | ||||
|             </li> | ||||
|             <li | ||||
|                class="settingbar-element btn btn-link ex-tooltip" | ||||
| @@ -64,7 +64,7 @@ | ||||
|                @mouseover.self="tooltipPosition" | ||||
|             > | ||||
|                <i class="settingbar-element-icon mdi mdi-24px mdi-plus text-light" /> | ||||
|                <span class="ex-tooltip-content">{{ $t('message.addConnection') }}</span> | ||||
|                <span class="ex-tooltip-content">{{ t('message.addConnection') }}</span> | ||||
|             </li> | ||||
|          </ul> | ||||
|       </div> | ||||
| @@ -77,11 +77,11 @@ | ||||
|                @click="showScratchpad" | ||||
|             > | ||||
|                <i class="settingbar-element-icon mdi mdi-24px mdi-notebook-edit-outline text-light" /> | ||||
|                <span class="ex-tooltip-content">{{ $t('word.scratchpad') }}</span> | ||||
|                <span class="ex-tooltip-content">{{ t('word.scratchpad') }}</span> | ||||
|             </li> | ||||
|             <li class="settingbar-element btn btn-link ex-tooltip" @click="showSettingModal('general')"> | ||||
|                <i class="settingbar-element-icon mdi mdi-24px mdi-cog text-light" :class="{' badge badge-update': hasUpdates}" /> | ||||
|                <span class="ex-tooltip-content">{{ $t('word.settings') }}</span> | ||||
|                <span class="ex-tooltip-content">{{ t('word.settings') }}</span> | ||||
|             </li> | ||||
|          </ul> | ||||
|       </div> | ||||
| @@ -99,6 +99,9 @@ import * as Draggable from 'vuedraggable'; | ||||
| import SettingBarContext from '@/components/SettingBarContext.vue'; | ||||
| import { ConnectionParams } from 'common/interfaces/antares'; | ||||
| import { useElementBounding, useScroll } from '@vueuse/core'; | ||||
| import { useI18n } from 'vue-i18n'; | ||||
|  | ||||
| const { t } = useI18n(); | ||||
|  | ||||
| const applicationStore = useApplicationStore(); | ||||
| const connectionsStore = useConnectionsStore(); | ||||
|   | ||||
| @@ -34,7 +34,7 @@ | ||||
|                         <span>{{ cutText(element.content || 'Query', 20, true) }} #{{ element.index }}</span> | ||||
|                         <span | ||||
|                            class="btn btn-clear" | ||||
|                            :title="$t('word.close')" | ||||
|                            :title="t('word.close')" | ||||
|                            @mousedown.left.stop | ||||
|                            @click.stop="closeTab(element)" | ||||
|                         /> | ||||
| @@ -47,11 +47,11 @@ | ||||
|                      @dblclick="openAsPermanentTab(element)" | ||||
|                   > | ||||
|                      <i class="mdi mdi-18px mr-1" :class="element.elementType === 'view' ? 'mdi-table-eye' : 'mdi-table'" /> | ||||
|                      <span :title="`${$t('word.data').toUpperCase()}: ${$tc(`word.${element.elementType}`)}`"> | ||||
|                      <span :title="`${t('word.data').toUpperCase()}: ${t(`word.${element.elementType}`)}`"> | ||||
|                         <span class=" text-italic">{{ cutText(element.elementName, 20, true) }}</span> | ||||
|                         <span | ||||
|                            class="btn btn-clear" | ||||
|                            :title="$t('word.close')" | ||||
|                            :title="t('word.close')" | ||||
|                            @mousedown.left.stop | ||||
|                            @click.stop="closeTab(element)" | ||||
|                         /> | ||||
| @@ -60,11 +60,11 @@ | ||||
|  | ||||
|                   <a v-else-if="element.type === 'data'" class="tab-link"> | ||||
|                      <i class="mdi mdi-18px mr-1" :class="element.elementType === 'view' ? 'mdi-table-eye' : 'mdi-table'" /> | ||||
|                      <span :title="`${$t('word.data').toUpperCase()}: ${$tc(`word.${element.elementType}`)}`"> | ||||
|                      <span :title="`${t('word.data').toUpperCase()}: ${t(`word.${element.elementType}`)}`"> | ||||
|                         {{ cutText(element.elementName, 20, true) }} | ||||
|                         <span | ||||
|                            class="btn btn-clear" | ||||
|                            :title="$t('word.close')" | ||||
|                            :title="t('word.close')" | ||||
|                            @mousedown.left.stop | ||||
|                            @click.stop="closeTab(element)" | ||||
|                         /> | ||||
| @@ -77,11 +77,11 @@ | ||||
|                      :class="{'badge': element.isChanged}" | ||||
|                   > | ||||
|                      <i class="mdi mdi-shape-square-plus mdi-18px mr-1" /> | ||||
|                      <span :title="`${$t('word.new').toUpperCase()}: ${$tc(`word.${element.elementType}`)}`"> | ||||
|                         {{ $t('message.newTable') }} | ||||
|                      <span :title="`${t('word.new').toUpperCase()}: ${t(`word.${element.elementType}`)}`"> | ||||
|                         {{ t('message.newTable') }} | ||||
|                         <span | ||||
|                            class="btn btn-clear" | ||||
|                            :title="$t('word.close')" | ||||
|                            :title="t('word.close')" | ||||
|                            @mousedown.left.stop | ||||
|                            @click.stop="closeTab(element)" | ||||
|                         /> | ||||
| @@ -94,11 +94,11 @@ | ||||
|                      :class="{'badge': element.isChanged}" | ||||
|                   > | ||||
|                      <i class="mdi mdi-tune-vertical-variant mdi-18px mr-1" /> | ||||
|                      <span :title="`${$t('word.settings').toUpperCase()}: ${$tc(`word.${element.elementType}`)}`"> | ||||
|                      <span :title="`${t('word.settings').toUpperCase()}: ${t(`word.${element.elementType}`)}`"> | ||||
|                         {{ cutText(element.elementName, 20, true) }} | ||||
|                         <span | ||||
|                            class="btn btn-clear" | ||||
|                            :title="$t('word.close')" | ||||
|                            :title="t('word.close')" | ||||
|                            @mousedown.left.stop | ||||
|                            @click.stop="closeTab(element)" | ||||
|                         /> | ||||
| @@ -111,11 +111,11 @@ | ||||
|                      :class="{'badge': element.isChanged}" | ||||
|                   > | ||||
|                      <i class="mdi mdi-tune-vertical-variant mdi-18px mr-1" /> | ||||
|                      <span :title="`${$t('word.settings').toUpperCase()}: ${$tc(`word.view`)}`"> | ||||
|                      <span :title="`${t('word.settings').toUpperCase()}: ${t(`word.view`)}`"> | ||||
|                         {{ cutText(element.elementName, 20, true) }} | ||||
|                         <span | ||||
|                            class="btn btn-clear" | ||||
|                            :title="$t('word.close')" | ||||
|                            :title="t('word.close')" | ||||
|                            @mousedown.left.stop | ||||
|                            @click.stop="closeTab(element)" | ||||
|                         /> | ||||
| @@ -128,11 +128,11 @@ | ||||
|                      :class="{'badge': element.isChanged}" | ||||
|                   > | ||||
|                      <i class="mdi mdi-shape-square-plus mdi-18px mr-1" /> | ||||
|                      <span :title="`${$t('word.new').toUpperCase()}: ${$tc(`word.${element.elementType}`)}`"> | ||||
|                         {{ $t('message.newView') }} | ||||
|                      <span :title="`${t('word.new').toUpperCase()}: ${t(`word.${element.elementType}`)}`"> | ||||
|                         {{ t('message.newView') }} | ||||
|                         <span | ||||
|                            class="btn btn-clear" | ||||
|                            :title="$t('word.close')" | ||||
|                            :title="t('word.close')" | ||||
|                            @mousedown.left.stop | ||||
|                            @click.stop="closeTab(element)" | ||||
|                         /> | ||||
| @@ -145,11 +145,11 @@ | ||||
|                      :class="{'badge': element.isChanged}" | ||||
|                   > | ||||
|                      <i class="mdi mdi-shape-square-plus mdi-18px mr-1" /> | ||||
|                      <span :title="`${$t('word.new').toUpperCase()}: ${$tc(`word.${element.elementType}`)}`"> | ||||
|                         {{ $t('message.newTrigger') }} | ||||
|                      <span :title="`${t('word.new').toUpperCase()}: ${t(`word.${element.elementType}`)}`"> | ||||
|                         {{ t('message.newTrigger') }} | ||||
|                         <span | ||||
|                            class="btn btn-clear" | ||||
|                            :title="$t('word.close')" | ||||
|                            :title="t('word.close')" | ||||
|                            @mousedown.left.stop | ||||
|                            @click.stop="closeTab(element)" | ||||
|                         /> | ||||
| @@ -162,11 +162,11 @@ | ||||
|                      :class="{'badge': element.isChanged}" | ||||
|                   > | ||||
|                      <i class="mdi mdi-shape-square-plus mdi-18px mr-1" /> | ||||
|                      <span :title="`${$t('word.new').toUpperCase()}: ${$tc(`word.${element.elementType}`)}`"> | ||||
|                         {{ $t('message.newRoutine') }} | ||||
|                      <span :title="`${t('word.new').toUpperCase()}: ${t(`word.${element.elementType}`)}`"> | ||||
|                         {{ t('message.newRoutine') }} | ||||
|                         <span | ||||
|                            class="btn btn-clear" | ||||
|                            :title="$t('word.close')" | ||||
|                            :title="t('word.close')" | ||||
|                            @mousedown.left.stop | ||||
|                            @click.stop="closeTab(element)" | ||||
|                         /> | ||||
| @@ -179,11 +179,11 @@ | ||||
|                      :class="{'badge': element.isChanged}" | ||||
|                   > | ||||
|                      <i class="mdi mdi-shape-square-plus mdi-18px mr-1" /> | ||||
|                      <span :title="`${$t('word.new').toUpperCase()}: ${$tc(`word.${element.elementType}`)}`"> | ||||
|                         {{ $t('message.newFunction') }} | ||||
|                      <span :title="`${t('word.new').toUpperCase()}: ${t(`word.${element.elementType}`)}`"> | ||||
|                         {{ t('message.newFunction') }} | ||||
|                         <span | ||||
|                            class="btn btn-clear" | ||||
|                            :title="$t('word.close')" | ||||
|                            :title="t('word.close')" | ||||
|                            @mousedown.left.stop | ||||
|                            @click.stop="closeTab(element)" | ||||
|                         /> | ||||
| @@ -196,11 +196,11 @@ | ||||
|                      :class="{'badge': element.isChanged}" | ||||
|                   > | ||||
|                      <i class="mdi mdi-shape-square-plus mdi-18px mr-1" /> | ||||
|                      <span :title="`${$t('word.new').toUpperCase()}: ${$tc(`word.${element.elementType}`)}`"> | ||||
|                         {{ $t('message.newTriggerFunction') }} | ||||
|                      <span :title="`${t('word.new').toUpperCase()}: ${t(`word.${element.elementType}`)}`"> | ||||
|                         {{ t('message.newTriggerFunction') }} | ||||
|                         <span | ||||
|                            class="btn btn-clear" | ||||
|                            :title="$t('word.close')" | ||||
|                            :title="t('word.close')" | ||||
|                            @mousedown.left.stop | ||||
|                            @click.stop="closeTab(element)" | ||||
|                         /> | ||||
| @@ -213,11 +213,11 @@ | ||||
|                      :class="{'badge': element.isChanged}" | ||||
|                   > | ||||
|                      <i class="mdi mdi-shape-square-plus mdi-18px mr-1" /> | ||||
|                      <span :title="`${$t('word.new').toUpperCase()}: ${$tc(`word.${element.elementType}`)}`"> | ||||
|                         {{ $t('message.newScheduler') }} | ||||
|                      <span :title="`${t('word.new').toUpperCase()}: ${t(`word.${element.elementType}`)}`"> | ||||
|                         {{ t('message.newScheduler') }} | ||||
|                         <span | ||||
|                            class="btn btn-clear" | ||||
|                            :title="$t('word.close')" | ||||
|                            :title="t('word.close')" | ||||
|                            @mousedown.left.stop | ||||
|                            @click.stop="closeTab(element)" | ||||
|                         /> | ||||
| @@ -231,11 +231,11 @@ | ||||
|                      @dblclick="openAsPermanentTab(element)" | ||||
|                   > | ||||
|                      <i class="mdi mdi-18px mdi-tune-vertical-variant mr-1" /> | ||||
|                      <span :title="`${$t('word.settings').toUpperCase()}: ${$tc(`word.${element.elementType}`)}`"> | ||||
|                      <span :title="`${t('word.settings').toUpperCase()}: ${t(`word.${element.elementType}`)}`"> | ||||
|                         <span class=" text-italic">{{ cutText(element.elementName, 20, true) }}</span> | ||||
|                         <span | ||||
|                            class="btn btn-clear" | ||||
|                            :title="$t('word.close')" | ||||
|                            :title="t('word.close')" | ||||
|                            @mousedown.left.stop | ||||
|                            @click.stop="closeTab(element)" | ||||
|                         /> | ||||
| @@ -248,11 +248,11 @@ | ||||
|                      :class="{'badge': element.isChanged}" | ||||
|                   > | ||||
|                      <i class="mdi mdi-18px mdi-tune-vertical-variant mr-1" /> | ||||
|                      <span :title="`${$t('word.settings').toUpperCase()}: ${$tc(`word.${element.elementType}`)}`"> | ||||
|                      <span :title="`${t('word.settings').toUpperCase()}: ${t(`word.${element.elementType}`)}`"> | ||||
|                         {{ cutText(element.elementName, 20, true) }} | ||||
|                         <span | ||||
|                            class="btn btn-clear" | ||||
|                            :title="$t('word.close')" | ||||
|                            :title="t('word.close')" | ||||
|                            @mousedown.left.stop | ||||
|                            @click.stop="closeTab(element)" | ||||
|                         /> | ||||
| @@ -268,7 +268,7 @@ | ||||
|                   <a | ||||
|                      class="tab-link workspace-tools-link dropdown-toggle" | ||||
|                      tabindex="0" | ||||
|                      :title="$t('word.tools')" | ||||
|                      :title="t('word.tools')" | ||||
|                   > | ||||
|                      <i class="mdi mdi-24px mdi-tools" /> | ||||
|                   </a> | ||||
| @@ -276,13 +276,13 @@ | ||||
|                      <li class="menu-item"> | ||||
|                         <a class="c-hand p-vcentered" @click="showProcessesModal"> | ||||
|                            <i class="mdi mdi-memory mr-1 tool-icon" /> | ||||
|                            <span>{{ $t('message.processesList') }}</span> | ||||
|                            <span>{{ t('message.processesList') }}</span> | ||||
|                         </a> | ||||
|                      </li> | ||||
|                      <li class="menu-item"> | ||||
|                         <a class="c-hand p-vcentered" @click="toggleConsole"> | ||||
|                            <i class="mdi mdi-console-line mr-1 tool-icon" /> | ||||
|                            <span>{{ $t('word.console') }}</span> | ||||
|                            <span>{{ t('word.console') }}</span> | ||||
|                         </a> | ||||
|                      </li> | ||||
|                      <li | ||||
| @@ -292,7 +292,7 @@ | ||||
|                      > | ||||
|                         <a class="c-hand p-vcentered disabled"> | ||||
|                            <i class="mdi mdi-shape mr-1 tool-icon" /> | ||||
|                            <span>{{ $t('word.variables') }}</span> | ||||
|                            <span>{{ t('word.variables') }}</span> | ||||
|                         </a> | ||||
|                      </li> | ||||
|                      <li | ||||
| @@ -302,7 +302,7 @@ | ||||
|                      > | ||||
|                         <a class="c-hand p-vcentered disabled"> | ||||
|                            <i class="mdi mdi-account-group mr-1 tool-icon" /> | ||||
|                            <span>{{ $t('message.manageUsers') }}</span> | ||||
|                            <span>{{ t('message.manageUsers') }}</span> | ||||
|                         </a> | ||||
|                      </li> | ||||
|                   </ul> | ||||
| @@ -312,7 +312,7 @@ | ||||
|                <li class="tab-item"> | ||||
|                   <a | ||||
|                      class="tab-add" | ||||
|                      :title="$t('message.openNewTab')" | ||||
|                      :title="t('message.openNewTab')" | ||||
|                      @click="addQueryTab" | ||||
|                   > | ||||
|                      <i class="mdi mdi-24px mdi-plus" /> | ||||
| @@ -511,6 +511,9 @@ import WorkspaceTabPropsFunction from '@/components/WorkspaceTabPropsFunction.vu | ||||
| import WorkspaceTabPropsScheduler from '@/components/WorkspaceTabPropsScheduler.vue'; | ||||
| import ModalProcessesList from '@/components/ModalProcessesList.vue'; | ||||
| import ModalDiscardChanges from '@/components/ModalDiscardChanges.vue'; | ||||
| import { useI18n } from 'vue-i18n'; | ||||
|  | ||||
| const { t } = useI18n(); | ||||
|  | ||||
| const { cutText } = useFilters(); | ||||
| const workspacesStore = useWorkspacesStore(); | ||||
|   | ||||
| @@ -15,18 +15,18 @@ | ||||
|                <i | ||||
|                   v-if="customizations.schemas" | ||||
|                   class="mdi mdi-18px mdi-database-plus c-hand mr-2" | ||||
|                   :title="$t('message.createNewSchema')" | ||||
|                   :title="t('message.createNewSchema')" | ||||
|                   @click="showNewDBModal" | ||||
|                /> | ||||
|                <i | ||||
|                   class="mdi mdi-18px mdi-refresh c-hand mr-2" | ||||
|                   :class="{'rotate':isRefreshing}" | ||||
|                   :title="$t('word.refresh')" | ||||
|                   :title="t('word.refresh')" | ||||
|                   @click="refresh" | ||||
|                /> | ||||
|                <i | ||||
|                   class="mdi mdi-18px mdi-power c-hand" | ||||
|                   :title="$t('word.disconnect')" | ||||
|                   :title="t('word.disconnect')" | ||||
|                   @click="disconnectWorkspace(connection.uid)" | ||||
|                /> | ||||
|             </span> | ||||
| @@ -38,7 +38,7 @@ | ||||
|                   v-model="searchTerm" | ||||
|                   class="form-input input-sm" | ||||
|                   type="text" | ||||
|                   :placeholder="$t('message.searchForElements')" | ||||
|                   :placeholder="t('message.searchForElements')" | ||||
|                > | ||||
|                <i v-if="!searchTerm" class="form-icon mdi mdi-magnify mdi-18px" /> | ||||
|                <i | ||||
| @@ -133,6 +133,9 @@ import TableContext from '@/components/WorkspaceExploreBarTableContext.vue'; | ||||
| import MiscContext from '@/components/WorkspaceExploreBarMiscContext.vue'; | ||||
| import MiscFolderContext from '@/components/WorkspaceExploreBarMiscFolderContext.vue'; | ||||
| import ModalNewSchema from '@/components/ModalNewSchema.vue'; | ||||
| import { useI18n } from 'vue-i18n'; | ||||
|  | ||||
| const { t } = useI18n(); | ||||
|  | ||||
| const props = defineProps({ | ||||
|    connection: Object, | ||||
|   | ||||
| @@ -8,7 +8,7 @@ | ||||
|          class="context-element" | ||||
|          @click="runElementCheck" | ||||
|       > | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-play text-light pr-1" /> {{ $t('word.run') }}</span> | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-play text-light pr-1" /> {{ t('word.run') }}</span> | ||||
|       </div> | ||||
|       <div | ||||
|          v-if="selectedMisc.type === 'trigger' && customizations.triggerEnableDisable" | ||||
| @@ -16,10 +16,10 @@ | ||||
|          @click="toggleTrigger" | ||||
|       > | ||||
|          <span v-if="!selectedMisc.enabled" class="d-flex"> | ||||
|             <i class="mdi mdi-18px mdi-play text-light pr-1" /> {{ $t('word.enable') }} | ||||
|             <i class="mdi mdi-18px mdi-play text-light pr-1" /> {{ t('word.enable') }} | ||||
|          </span> | ||||
|          <span v-else class="d-flex"> | ||||
|             <i class="mdi mdi-18px mdi-pause text-light pr-1" /> {{ $t('word.disable') }} | ||||
|             <i class="mdi mdi-18px mdi-pause text-light pr-1" /> {{ t('word.disable') }} | ||||
|          </span> | ||||
|       </div> | ||||
|       <div | ||||
| @@ -28,14 +28,14 @@ | ||||
|          @click="toggleScheduler" | ||||
|       > | ||||
|          <span v-if="!selectedMisc.enabled" class="d-flex"> | ||||
|             <i class="mdi mdi-18px mdi-play text-light pr-1" /> {{ $t('word.enable') }} | ||||
|             <i class="mdi mdi-18px mdi-play text-light pr-1" /> {{ t('word.enable') }} | ||||
|          </span> | ||||
|          <span v-else class="d-flex"> | ||||
|             <i class="mdi mdi-18px mdi-pause text-light pr-1" /> {{ $t('word.disable') }} | ||||
|             <i class="mdi mdi-18px mdi-pause text-light pr-1" /> {{ t('word.disable') }} | ||||
|          </span> | ||||
|       </div> | ||||
|       <div class="context-element" @click="showDeleteModal"> | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-table-remove text-light pr-1" /> {{ $t('word.delete') }}</span> | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-table-remove text-light pr-1" /> {{ t('word.delete') }}</span> | ||||
|       </div> | ||||
|       <ConfirmModal | ||||
|          v-if="isDeleteModal" | ||||
| @@ -50,7 +50,7 @@ | ||||
|          </template> | ||||
|          <template #body> | ||||
|             <div class="mb-2"> | ||||
|                {{ $t('message.deleteCorfirm') }} "<b>{{ selectedMisc.name }}</b>"? | ||||
|                {{ t('message.deleteCorfirm') }} "<b>{{ selectedMisc.name }}</b>"? | ||||
|             </div> | ||||
|          </template> | ||||
|       </ConfirmModal> | ||||
|   | ||||
| @@ -4,7 +4,7 @@ | ||||
|       @close-context="closeContext" | ||||
|    > | ||||
|       <div class="context-element"> | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-plus text-light pr-1" /> {{ $t('word.add') }}</span> | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-plus text-light pr-1" /> {{ t('word.add') }}</span> | ||||
|          <i class="mdi mdi-18px mdi-chevron-right text-light pl-1" /> | ||||
|          <div class="context-submenu"> | ||||
|             <div | ||||
| @@ -12,49 +12,49 @@ | ||||
|                class="context-element" | ||||
|                @click="openCreateTableTab" | ||||
|             > | ||||
|                <span class="d-flex"><i class="mdi mdi-18px mdi-table text-light pr-1" /> {{ $t('word.table') }}</span> | ||||
|                <span class="d-flex"><i class="mdi mdi-18px mdi-table text-light pr-1" /> {{ t('word.table') }}</span> | ||||
|             </div> | ||||
|             <div | ||||
|                v-if="workspace.customizations.viewAdd" | ||||
|                class="context-element" | ||||
|                @click="openCreateViewTab" | ||||
|             > | ||||
|                <span class="d-flex"><i class="mdi mdi-18px mdi-table-eye text-light pr-1" /> {{ $t('word.view') }}</span> | ||||
|                <span class="d-flex"><i class="mdi mdi-18px mdi-table-eye text-light pr-1" /> {{ t('word.view') }}</span> | ||||
|             </div> | ||||
|             <div | ||||
|                v-if="workspace.customizations.triggerAdd" | ||||
|                class="context-element" | ||||
|                @click="openCreateTriggerTab" | ||||
|             > | ||||
|                <span class="d-flex"><i class="mdi mdi-18px mdi-table-cog text-light pr-1" /> {{ $tc('word.trigger', 1) }}</span> | ||||
|                <span class="d-flex"><i class="mdi mdi-18px mdi-table-cog text-light pr-1" /> {{ t('word.trigger', 1) }}</span> | ||||
|             </div> | ||||
|             <div | ||||
|                v-if="workspace.customizations.routineAdd" | ||||
|                class="context-element" | ||||
|                @click="openCreateRoutineTab" | ||||
|             > | ||||
|                <span class="d-flex"><i class="mdi mdi-18px mdi-sync-circle pr-1" /> {{ $tc('word.storedRoutine', 1) }}</span> | ||||
|                <span class="d-flex"><i class="mdi mdi-18px mdi-sync-circle pr-1" /> {{ t('word.storedRoutine', 1) }}</span> | ||||
|             </div> | ||||
|             <div | ||||
|                v-if="workspace.customizations.functionAdd" | ||||
|                class="context-element" | ||||
|                @click="openCreateFunctionTab" | ||||
|             > | ||||
|                <span class="d-flex"><i class="mdi mdi-18px mdi-arrow-right-bold-box pr-1" /> {{ $tc('word.function', 1) }}</span> | ||||
|                <span class="d-flex"><i class="mdi mdi-18px mdi-arrow-right-bold-box pr-1" /> {{ t('word.function', 1) }}</span> | ||||
|             </div> | ||||
|             <div | ||||
|                v-if="workspace.customizations.triggerFunctionAdd" | ||||
|                class="context-element" | ||||
|                @click="openCreateTriggerFunctionTab" | ||||
|             > | ||||
|                <span class="d-flex"><i class="mdi mdi-18px mdi-cog-clockwise pr-1" /> {{ $tc('word.triggerFunction', 1) }}</span> | ||||
|                <span class="d-flex"><i class="mdi mdi-18px mdi-cog-clockwise pr-1" /> {{ t('word.triggerFunction', 1) }}</span> | ||||
|             </div> | ||||
|             <div | ||||
|                v-if="workspace.customizations.schedulerAdd" | ||||
|                class="context-element" | ||||
|                @click="openCreateSchedulerTab" | ||||
|             > | ||||
|                <span class="d-flex"><i class="mdi mdi-18px mdi-calendar-clock text-light pr-1" /> {{ $tc('word.scheduler', 1) }}</span> | ||||
|                <span class="d-flex"><i class="mdi mdi-18px mdi-calendar-clock text-light pr-1" /> {{ t('word.scheduler', 1) }}</span> | ||||
|             </div> | ||||
|          </div> | ||||
|       </div> | ||||
| @@ -63,28 +63,28 @@ | ||||
|          class="context-element" | ||||
|          @click="showExportSchemaModal" | ||||
|       > | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-database-arrow-down text-light pr-1" /> {{ $t('word.export') }}</span> | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-database-arrow-down text-light pr-1" /> {{ t('word.export') }}</span> | ||||
|       </div> | ||||
|       <div | ||||
|          v-if="workspace.customizations.schemaImport" | ||||
|          class="context-element" | ||||
|          @click="initImport" | ||||
|       > | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-database-arrow-up text-light pr-1" /> {{ $t('word.import') }}</span> | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-database-arrow-up text-light pr-1" /> {{ t('word.import') }}</span> | ||||
|       </div> | ||||
|       <div | ||||
|          v-if="workspace.customizations.schemaEdit" | ||||
|          class="context-element" | ||||
|          @click="showEditModal" | ||||
|       > | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-database-edit text-light pr-1" /> {{ $t('word.edit') }}</span> | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-database-edit text-light pr-1" /> {{ t('word.edit') }}</span> | ||||
|       </div> | ||||
|       <div | ||||
|          v-if="workspace.customizations.schemaDrop" | ||||
|          class="context-element" | ||||
|          @click="showDeleteModal" | ||||
|       > | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-database-remove text-light pr-1" /> {{ $t('word.delete') }}</span> | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-database-remove text-light pr-1" /> {{ t('word.delete') }}</span> | ||||
|       </div> | ||||
|  | ||||
|       <ConfirmModal | ||||
| @@ -95,12 +95,12 @@ | ||||
|          <template #header> | ||||
|             <div class="d-flex"> | ||||
|                <i class="mdi mdi-24px mdi-database-remove mr-1" /> | ||||
|                <span class="cut-text">{{ $t('message.deleteSchema') }}</span> | ||||
|                <span class="cut-text">{{ t('message.deleteSchema') }}</span> | ||||
|             </div> | ||||
|          </template> | ||||
|          <template #body> | ||||
|             <div class="mb-2"> | ||||
|                {{ $t('message.deleteCorfirm') }} "<b>{{ selectedSchema }}</b>"? | ||||
|                {{ t('message.deleteCorfirm') }} "<b>{{ selectedSchema }}</b>"? | ||||
|             </div> | ||||
|          </template> | ||||
|       </ConfirmModal> | ||||
| @@ -135,6 +135,9 @@ import ModalExportSchema from '@/components/ModalExportSchema.vue'; | ||||
| import ModalImportSchema from '@/components/ModalImportSchema.vue'; | ||||
| import Schema from '@/ipc-api/Schema'; | ||||
| import Application from '@/ipc-api/Application'; | ||||
| import { useI18n } from 'vue-i18n'; | ||||
|  | ||||
| const { t } = useI18n(); | ||||
|  | ||||
| const props = defineProps({ | ||||
|    contextEvent: MouseEvent, | ||||
|   | ||||
| @@ -35,7 +35,7 @@ | ||||
|       @close-context="isContext = false" | ||||
|    > | ||||
|       <div class="context-element" @click="copyQuery"> | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-content-copy text-light pr-1" /> {{ $t('word.copy') }}</span> | ||||
|          <span class="d-flex"><i class="mdi mdi-18px mdi-content-copy text-light pr-1" /> {{ t('word.copy') }}</span> | ||||
|       </div> | ||||
|    </BaseContextMenu> | ||||
| </template> | ||||
|   | ||||
| @@ -11,27 +11,27 @@ | ||||
|                   @click="saveChanges" | ||||
|                > | ||||
|                   <i class="mdi mdi-24px mdi-content-save mr-1" /> | ||||
|                   <span>{{ $t('word.save') }}</span> | ||||
|                   <span>{{ t('word.save') }}</span> | ||||
|                </button> | ||||
|                <button | ||||
|                   :disabled="!isChanged" | ||||
|                   class="btn btn-link btn-sm mr-0" | ||||
|                   :title="$t('message.clearChanges')" | ||||
|                   :title="t('message.clearChanges')" | ||||
|                   @click="clearChanges" | ||||
|                > | ||||
|                   <i class="mdi mdi-24px mdi-delete-sweep mr-1" /> | ||||
|                   <span>{{ $t('word.clear') }}</span> | ||||
|                   <span>{{ t('word.clear') }}</span> | ||||
|                </button> | ||||
|  | ||||
|                <div class="divider-vert py-3" /> | ||||
|  | ||||
|                <button class="btn btn-dark btn-sm" @click="showParamsModal"> | ||||
|                   <i class="mdi mdi-24px mdi-dots-horizontal mr-1" /> | ||||
|                   <span>{{ $t('word.parameters') }}</span> | ||||
|                   <span>{{ t('word.parameters') }}</span> | ||||
|                </button> | ||||
|             </div> | ||||
|             <div class="workspace-query-info"> | ||||
|                <div class="d-flex" :title="$t('word.schema')"> | ||||
|                <div class="d-flex" :title="t('word.schema')"> | ||||
|                   <i class="mdi mdi-18px mdi-database mr-1" /><b>{{ schema }}</b> | ||||
|                </div> | ||||
|             </div> | ||||
| @@ -42,7 +42,7 @@ | ||||
|             <div class="column col-auto"> | ||||
|                <div class="form-group"> | ||||
|                   <label class="form-label"> | ||||
|                      {{ $t('word.name') }} | ||||
|                      {{ t('word.name') }} | ||||
|                   </label> | ||||
|                   <input | ||||
|                      ref="firstInput" | ||||
| @@ -55,7 +55,7 @@ | ||||
|             <div v-if="customizations.languages" class="column col-auto"> | ||||
|                <div class="form-group"> | ||||
|                   <label class="form-label"> | ||||
|                      {{ $t('word.language') }} | ||||
|                      {{ t('word.language') }} | ||||
|                   </label> | ||||
|                   <BaseSelect | ||||
|                      v-model="localRoutine.language" | ||||
| @@ -67,11 +67,11 @@ | ||||
|             <div v-if="customizations.definer" class="column col-auto"> | ||||
|                <div class="form-group"> | ||||
|                   <label class="form-label"> | ||||
|                      {{ $t('word.definer') }} | ||||
|                      {{ t('word.definer') }} | ||||
|                   </label> | ||||
|                   <BaseSelect | ||||
|                      v-model="localRoutine.definer" | ||||
|                      :options="[{value: '', name:$t('message.currentUser')}, ...workspace.users]" | ||||
|                      :options="[{value: '', name:t('message.currentUser')}, ...workspace.users]" | ||||
|                      :option-label="(user: any) => user.value === '' ? user.name : `${user.name}@${user.host}`" | ||||
|                      :option-track-by="(user: any) => user.value === '' ? '' : `\`${user.name}\`@\`${user.host}\``" | ||||
|                      class="form-select" | ||||
| @@ -81,7 +81,7 @@ | ||||
|             <div v-if="customizations.comment" class="column"> | ||||
|                <div class="form-group"> | ||||
|                   <label class="form-label"> | ||||
|                      {{ $t('word.comment') }} | ||||
|                      {{ t('word.comment') }} | ||||
|                   </label> | ||||
|                   <input | ||||
|                      v-model="localRoutine.comment" | ||||
| @@ -93,7 +93,7 @@ | ||||
|             <div class="column col-auto"> | ||||
|                <div class="form-group"> | ||||
|                   <label class="form-label"> | ||||
|                      {{ $t('message.sqlSecurity') }} | ||||
|                      {{ t('message.sqlSecurity') }} | ||||
|                   </label> | ||||
|                   <BaseSelect | ||||
|                      v-model="localRoutine.security" | ||||
| @@ -105,7 +105,7 @@ | ||||
|             <div v-if="customizations.procedureDataAccess" class="column col-auto"> | ||||
|                <div class="form-group"> | ||||
|                   <label class="form-label"> | ||||
|                      {{ $t('message.dataAccess') }} | ||||
|                      {{ t('message.dataAccess') }} | ||||
|                   </label> | ||||
|                   <BaseSelect | ||||
|                      v-model="localRoutine.dataAccess" | ||||
| @@ -118,7 +118,7 @@ | ||||
|                <div class="form-group"> | ||||
|                   <label class="form-label d-invisible">.</label> | ||||
|                   <label class="form-checkbox form-inline"> | ||||
|                      <input v-model="localRoutine.deterministic" type="checkbox"><i class="form-icon" /> {{ $t('word.deterministic') }} | ||||
|                      <input v-model="localRoutine.deterministic" type="checkbox"><i class="form-icon" /> {{ t('word.deterministic') }} | ||||
|                   </label> | ||||
|                </div> | ||||
|             </div> | ||||
| @@ -126,7 +126,7 @@ | ||||
|       </div> | ||||
|       <div class="workspace-query-results column col-12 mt-2 p-relative"> | ||||
|          <BaseLoader v-if="isLoading" /> | ||||
|          <label class="form-label ml-2">{{ $t('message.routineBody') }}</label> | ||||
|          <label class="form-label ml-2">{{ t('message.routineBody') }}</label> | ||||
|          <QueryEditor | ||||
|             v-show="isSelected" | ||||
|             ref="queryEditor" | ||||
| @@ -160,6 +160,9 @@ import BaseLoader from '@/components/BaseLoader.vue'; | ||||
| import WorkspaceTabPropsRoutineParamsModal from '@/components/WorkspaceTabPropsRoutineParamsModal.vue'; | ||||
| import BaseSelect from '@/components/BaseSelect.vue'; | ||||
| import { FunctionParam } from 'common/interfaces/antares'; | ||||
| import { useI18n } from 'vue-i18n'; | ||||
|  | ||||
| const { t } = useI18n(); | ||||
|  | ||||
| const props = defineProps({ | ||||
|    tabUid: String, | ||||
|   | ||||
| @@ -85,7 +85,7 @@ | ||||
|                   @click="showFakerModal()" | ||||
|                > | ||||
|                   <i class="mdi mdi-24px mdi-playlist-plus mr-1" /> | ||||
|                   <span>{{ $tc('message.insertRow', 2) }}</span> | ||||
|                   <span>{{ t('message.insertRow', 2) }}</span> | ||||
|                </button> | ||||
|  | ||||
|                <div class="dropdown table-dropdown pr-2"> | ||||
|   | ||||
| @@ -51,7 +51,7 @@ | ||||
|             class="btn btn-sm btn-primary mr-0 ml-2" | ||||
|             type="submit" | ||||
|          > | ||||
|             {{ $t('word.filter') }} | ||||
|             {{ t('word.filter') }} | ||||
|          </button> | ||||
|          <button | ||||
|             class="btn btn-sm btn-dark mr-0 ml-2" | ||||
| @@ -71,6 +71,9 @@ import customizations from 'common/customizations'; | ||||
| import { NUMBER, FLOAT } from 'common/fieldTypes'; | ||||
| import BaseSelect from '@/components/BaseSelect.vue'; | ||||
| import { TableFilterClausole } from 'common/interfaces/tableApis'; | ||||
| import { useI18n } from 'vue-i18n'; | ||||
|  | ||||
| const { t } = useI18n(); | ||||
|  | ||||
| const props = defineProps({ | ||||
|    fields: Array as Prop<TableField[]>, | ||||
|   | ||||
| @@ -34,7 +34,8 @@ export type AvailableLocale = keyof typeof messages | ||||
|  | ||||
| const i18n = createI18n<[NestedPartial<MessageSchema>], AvailableLocale>({ | ||||
|    fallbackLocale: 'en-US', | ||||
|    legacy: false, | ||||
|    allowComposition: true, | ||||
|    messages | ||||
| }); | ||||
| export default i18n; | ||||
|  | ||||
| export { i18n }; | ||||
|   | ||||
| @@ -2,10 +2,10 @@ | ||||
| import { ipcRenderer } from 'electron'; | ||||
| import { createApp } from 'vue'; | ||||
| import { createPinia } from 'pinia'; | ||||
| import { VueMaskDirective } from 'v-mask'; | ||||
| import '@mdi/font/css/materialdesignicons.css'; | ||||
| import 'leaflet/dist/leaflet.css'; | ||||
| import '@/scss/main.scss'; | ||||
| import { VueMaskDirective } from 'v-mask'; | ||||
|  | ||||
| import { useApplicationStore } from '@/stores/application'; | ||||
| import { useSettingsStore } from '@/stores/settings'; | ||||
| @@ -13,7 +13,7 @@ import { useNotificationsStore } from '@/stores/notifications'; | ||||
| import { useConsoleStore } from '@/stores/console'; | ||||
|  | ||||
| import App from '@/App.vue'; | ||||
| import i18n from '@/i18n'; | ||||
| import { i18n } from '@/i18n'; | ||||
|  | ||||
| // https://github.com/probil/v-mask/issues/498#issuecomment-827027834 | ||||
| const vMaskV2 = VueMaskDirective; | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| import { defineStore } from 'pinia'; | ||||
| import { ipcRenderer } from 'electron'; | ||||
| import i18n, { AvailableLocale } from '@/i18n'; | ||||
| import { i18n, AvailableLocale } from '@/i18n'; | ||||
| import * as Store from 'electron-store'; | ||||
| const persistentStore = new Store({ name: 'settings' }); | ||||
| const isDarkTheme = window.matchMedia('(prefers-color-scheme: dark)'); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user