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