feat(monitors): added auto-refresh feature to ticket monitors
gitea/salix/pipeline/head This commit looks good Details

This commit is contained in:
Carlos Jimenez Ruiz 2021-10-20 14:40:08 +02:00
parent 944915cd31
commit 1c51d34f7d
6 changed files with 69 additions and 4 deletions

View File

@ -1,4 +1,4 @@
<vn-horizontal> <vn-horizontal ng-class="{'hidden': $ctrl.isTopPanelHidden}">
<vn-monitor-sales-clients class="vn-mb-sm"></vn-monitor-sales-clients> <vn-monitor-sales-clients class="vn-mb-sm"></vn-monitor-sales-clients>
<vn-monitor-sales-orders></vn-monitor-sales-orders> <vn-monitor-sales-orders></vn-monitor-sales-orders>
</vn-horizontal> </vn-horizontal>

View File

@ -3,14 +3,25 @@ import Section from 'salix/components/section';
import './style.scss'; import './style.scss';
export default class Controller extends Section { export default class Controller extends Section {
constructor($element, $) {
super($element, $);
const isTopPanelHidden = localStorage.getItem('ticketTopPanelHidden');
if (isTopPanelHidden === 'true')
this.isTopPanelHidden = true;
}
toggle() { toggle() {
const monitor = this.element.querySelector('vn-horizontal'); const monitor = this.element.querySelector('vn-horizontal');
const isHidden = monitor.classList.contains('hidden'); const isHidden = monitor.classList.contains('hidden');
if (!isHidden) if (!isHidden) {
monitor.classList.add('hidden'); monitor.classList.add('hidden');
else localStorage.setItem('ticketTopPanelHidden', true);
} else {
monitor.classList.remove('hidden'); monitor.classList.remove('hidden');
localStorage.setItem('ticketTopPanelHidden', false);
}
} }
} }

View File

@ -0,0 +1,38 @@
import './index.js';
describe('Component vnMonitorIndex', () => {
let controller;
let $element;
beforeEach(ngModule('monitor'));
beforeEach(inject(($compile, $rootScope) => {
$element = $compile('<vn-monitor-index></vn-monitor-index>')($rootScope);
controller = $element.controller('vnMonitorIndex');
}));
describe('toggle()', () => {
it('should add the hidden class to the horizontal contaning the panel to hide', () => {
controller.toggle();
const targetElement = $element[0].querySelector('vn-horizontal');
const firstClass = targetElement.classList[0];
const isTopPanelHidden = localStorage.getItem('ticketTopPanelHidden');
expect(firstClass).toEqual('hidden');
expect(isTopPanelHidden).toEqual('true');
});
it('should remove the hidden class to the horizontal contaning the panel to hide', () => {
const targetElement = $element[0].querySelector('vn-horizontal');
targetElement.classList.add('hidden');
controller.toggle();
const firstClass = targetElement.classList[0];
const isTopPanelHidden = localStorage.getItem('ticketTopPanelHidden');
expect(firstClass).toBeUndefined();
expect(isTopPanelHidden).toEqual('false');
});
});
});

View File

@ -8,4 +8,6 @@ Component lack: Faltan componentes
Minimize/Maximize: Minimizar/Maximizar Minimize/Maximize: Minimizar/Maximizar
Problems: Problemas Problems: Problemas
Theoretical: Teórica Theoretical: Teórica
Practical: Práctica Practical: Práctica
Auto-refresh: Auto-refresco
Toggle auto-refresh every 2 minutes: Conmuta el refresco automático cada 2 minutos

View File

@ -21,6 +21,11 @@
Tickets monitor Tickets monitor
</vn-one> </vn-one>
<vn-none> <vn-none>
<vn-check
label="Auto-refresh"
vn-tooltip="Toggle auto-refresh every 2 minutes"
on-change="$ctrl.autoRefresh(value)">
</vn-check>
<vn-icon <vn-icon
icon="refresh" icon="refresh"
vn-tooltip="Refresh" vn-tooltip="Refresh"

View File

@ -112,6 +112,15 @@ export default class Controller extends Section {
this.selectedTicket = ticket; this.selectedTicket = ticket;
this.$.summary.show(); this.$.summary.show();
} }
autoRefresh(value) {
if (value)
this.refreshTimer = setInterval(() => this.$.model.refresh(), 120000);
else {
clearInterval(this.refreshTimer);
this.refreshTimer = null;
}
}
} }
ngModule.vnComponent('vnMonitorSalesTickets', { ngModule.vnComponent('vnMonitorSalesTickets', {