mirror of
https://github.com/Fabio286/antares.git
synced 2025-02-21 14:10:42 +01:00
feat: data table autorefresh, closes #36
This commit is contained in:
parent
07d1e82325
commit
9ecd88870d
@ -3,15 +3,35 @@
|
|||||||
<div class="workspace-query-runner column col-12">
|
<div class="workspace-query-runner column col-12">
|
||||||
<div class="workspace-query-runner-footer">
|
<div class="workspace-query-runner-footer">
|
||||||
<div class="workspace-query-buttons">
|
<div class="workspace-query-buttons">
|
||||||
<button
|
<div class="dropdown">
|
||||||
class="btn btn-link btn-sm mr-0 pr-0"
|
<div class="btn-group">
|
||||||
:class="{'loading':isQuering}"
|
<button
|
||||||
title="F5"
|
class="btn btn-link btn-sm mr-0 pr-1"
|
||||||
@click="reloadTable"
|
:class="{'loading':isQuering}"
|
||||||
>
|
title="F5"
|
||||||
<span>{{ $t('word.refresh') }}</span>
|
@click="reloadTable"
|
||||||
<i class="mdi mdi-24px mdi-refresh ml-1" />
|
>
|
||||||
</button>
|
<span>{{ $t('word.refresh') }}</span>
|
||||||
|
<i v-if="!+autorefreshTimer" class="mdi mdi-24px mdi-refresh ml-1" />
|
||||||
|
<i v-else class="mdi mdi-24px mdi-history mdi-flip-h ml-1" />
|
||||||
|
</button>
|
||||||
|
<div class="btn btn-link btn-sm dropdown-toggle pl-0 pr-0" tabindex="0">
|
||||||
|
<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>
|
||||||
|
<input
|
||||||
|
v-model="autorefreshTimer"
|
||||||
|
class="slider no-border"
|
||||||
|
type="range"
|
||||||
|
min="0"
|
||||||
|
max="30"
|
||||||
|
step="1"
|
||||||
|
@change="setRefreshInterval"
|
||||||
|
>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
<button
|
<button
|
||||||
class="btn btn-link btn-sm"
|
class="btn btn-link btn-sm"
|
||||||
@click="showAddModal"
|
@click="showAddModal"
|
||||||
@ -77,7 +97,9 @@ export default {
|
|||||||
fields: [],
|
fields: [],
|
||||||
keyUsage: [],
|
keyUsage: [],
|
||||||
lastTable: null,
|
lastTable: null,
|
||||||
isAddModal: false
|
isAddModal: false,
|
||||||
|
autorefreshTimer: 0,
|
||||||
|
refreshInterval: null
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
@ -111,6 +133,7 @@ export default {
|
|||||||
},
|
},
|
||||||
beforeDestroy () {
|
beforeDestroy () {
|
||||||
window.removeEventListener('keydown', this.onKey);
|
window.removeEventListener('keydown', this.onKey);
|
||||||
|
clearInterval(this.refreshInterval);
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
...mapActions({
|
...mapActions({
|
||||||
@ -196,6 +219,17 @@ export default {
|
|||||||
e.stopPropagation();
|
e.stopPropagation();
|
||||||
if (e.key === 'F5')
|
if (e.key === 'F5')
|
||||||
this.reloadTable();
|
this.reloadTable();
|
||||||
|
},
|
||||||
|
setRefreshInterval () {
|
||||||
|
if (this.refreshInterval)
|
||||||
|
clearInterval(this.refreshInterval);
|
||||||
|
|
||||||
|
if (+this.autorefreshTimer) {
|
||||||
|
this.refreshInterval = setInterval(() => {
|
||||||
|
if (!this.isQuering)
|
||||||
|
this.reloadTable();
|
||||||
|
}, this.autorefreshTimer * 1000);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -41,7 +41,8 @@ module.exports = {
|
|||||||
insert: 'Insert',
|
insert: 'Insert',
|
||||||
connecting: 'Connecting',
|
connecting: 'Connecting',
|
||||||
name: 'Name',
|
name: 'Name',
|
||||||
collation: 'Collation'
|
collation: 'Collation',
|
||||||
|
autoRefresh: 'Auto-refresh'
|
||||||
},
|
},
|
||||||
message: {
|
message: {
|
||||||
appWelcome: 'Welcome to Antares SQL Client!',
|
appWelcome: 'Welcome to Antares SQL Client!',
|
||||||
|
@ -37,6 +37,12 @@ body {
|
|||||||
cursor: help;
|
cursor: help;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.no-border {
|
||||||
|
outline: none !important;
|
||||||
|
border: none !important;
|
||||||
|
box-shadow: none !important;
|
||||||
|
}
|
||||||
|
|
||||||
.bg-checkered {
|
.bg-checkered {
|
||||||
background-image:
|
background-image:
|
||||||
linear-gradient(to right, rgba(192, 192, 192, 0.75), rgba(192, 192, 192, 0.75)),
|
linear-gradient(to right, rgba(192, 192, 192, 0.75), rgba(192, 192, 192, 0.75)),
|
||||||
|
Loading…
x
Reference in New Issue
Block a user