🎨 Handle loading state for widgets
This commit is contained in:
@@ -1,49 +1,41 @@
|
||||
/**
|
||||
* Mixin that all pre-built and custom widgets extend from.
|
||||
* Manages loading state, error handling and data updates.
|
||||
*/
|
||||
import ProgressBar from 'rsup-progress';
|
||||
import ErrorHandler from '@/utils/ErrorHandler';
|
||||
import LoadingAnimation from '@/assets/interface-icons/loader.svg';
|
||||
|
||||
const WidgetMixin = {
|
||||
components: {
|
||||
LoadingAnimation,
|
||||
},
|
||||
props: {
|
||||
/* The options prop is an object of settings for a given widget */
|
||||
options: {
|
||||
type: Object,
|
||||
default: {},
|
||||
},
|
||||
},
|
||||
data: () => ({
|
||||
loading: true, // Indicates current loading status, to display spinner
|
||||
progress: new ProgressBar({ color: 'var(--progress-bar)' }),
|
||||
}),
|
||||
methods: {
|
||||
/* Overridden by widget component. Re-fetches and renders any external data *
|
||||
* Called by parent component, and triggered either by user or time interval */
|
||||
/* Re-fetches external data, called by parent. Usually overridden by widget */
|
||||
update() {
|
||||
// eslint-disable-next-line no-console
|
||||
console.log('No update method configured for this widget');
|
||||
console.log('No update method configured for this widget'); // eslint-disable-line no-console
|
||||
},
|
||||
/* Called when an error occurs */
|
||||
/* Called when an error occurs. Logs to handler, and passes to parent component */
|
||||
error(msg, stackTrace) {
|
||||
ErrorHandler(msg, stackTrace);
|
||||
this.$emit('error', msg);
|
||||
},
|
||||
/* When a data request update starts, show loader */
|
||||
startLoading() {
|
||||
this.loading = true;
|
||||
this.$emit('loading', true);
|
||||
this.progress.start();
|
||||
},
|
||||
/* When a data request finishes, hide loader */
|
||||
finishLoading() {
|
||||
this.loading = false;
|
||||
this.$emit('loading', false);
|
||||
setTimeout(() => { this.progress.end(); }, 500);
|
||||
},
|
||||
},
|
||||
mounted() {
|
||||
// If the mounted function isn't overridden,then hide loader
|
||||
this.loading = false;
|
||||
},
|
||||
};
|
||||
|
||||
export default WidgetMixin;
|
||||
|
||||
Reference in New Issue
Block a user