mirror of
https://github.com/FH-Complete/FHC-Core.git
synced 2026-06-01 12:19:28 +00:00
194 lines
5.4 KiB
JavaScript
194 lines
5.4 KiB
JavaScript
import DashboardSection from "../Section.js";
|
|
import DashboardWidgetPicker from "../Widget/Picker.js";
|
|
import ObjectUtils from "../../../helpers/ObjectUtils.js";
|
|
import ApiDashboardPreset from "../../../api/factory/dashboard/preset.js";
|
|
|
|
export default {
|
|
components: {
|
|
DashboardSection,
|
|
DashboardWidgetPicker
|
|
},
|
|
props: {
|
|
dashboard: String,
|
|
widgets: Array
|
|
},
|
|
data: () => ({
|
|
funktionen: {},
|
|
sections: [],
|
|
tmpLoading: ''
|
|
}),
|
|
computed: {
|
|
pickerWidgets() {
|
|
return this.widgets.filter(widget => widget.allowed);
|
|
}
|
|
},
|
|
methods: {
|
|
widgetAdd(section_name, widget) {
|
|
this.$refs.widgetpicker.getWidget().then(widget_id => {
|
|
widget.widget = widget_id;
|
|
widget.id = 'loading_' + String((new Date()).valueOf());
|
|
delete widget.custom;
|
|
widget.preset = 1;
|
|
let loading = {...widget};
|
|
loading.loading = true;
|
|
this.sections.forEach(section => {
|
|
if (section.name == section_name)
|
|
section.widgets.push(loading);
|
|
});
|
|
|
|
const params = {
|
|
dashboard: this.dashboard,
|
|
funktion_kurzbz: section_name,
|
|
widget
|
|
};
|
|
|
|
return this.$api
|
|
.call(ApiDashboardPreset.addWidget(params))
|
|
.then(result => {
|
|
let newId = result.data;
|
|
widget.id = newId;
|
|
widget.custom = 1;
|
|
this.sections.forEach(section => {
|
|
if (section.name == section_name) {
|
|
section.widgets.splice(section.widgets.indexOf(loading),1);
|
|
section.widgets.push(widget);
|
|
}
|
|
});
|
|
this.funktionen.forEach(funktion => {
|
|
if(funktion.funktion_kurzbz === section_name && funktion.has_preset < 1) {
|
|
funktion.has_preset = 1;
|
|
}
|
|
});
|
|
})
|
|
.catch(this.$fhcAlert.handleSystemError);
|
|
})
|
|
.catch(() => {});
|
|
},
|
|
widgetUpdate(section_name, payload) {
|
|
payload = payload[section_name];
|
|
for (var k in payload) {
|
|
const section = this.sections.find(section => section.name == section_name);
|
|
for (var wid in section.widgets) {
|
|
if (section.widgets[wid].id == k) {
|
|
payload[k] = ObjectUtils.mergeDeep(section.widgets[wid], payload[k]);
|
|
// NOTE(chris): remove internal props
|
|
for (var prop of ['_x', '_y', '_w', '_h', 'index', 'id'])
|
|
if (payload[k][prop])
|
|
delete payload[k][prop];
|
|
break;
|
|
}
|
|
}
|
|
payload[k].widgetid = k;
|
|
delete payload[k].custom;
|
|
}
|
|
this.$api
|
|
.call(Object.entries(payload).map(([key, widget]) => [
|
|
key,
|
|
ApiDashboardPreset.addWidget({
|
|
dashboard: this.dashboard,
|
|
funktion_kurzbz: section_name,
|
|
widget
|
|
})
|
|
]))
|
|
.then(result => {
|
|
this.sections.forEach(section => {
|
|
if (section.name == section_name) {
|
|
section.widgets.forEach((widget, i) => {
|
|
if (payload[widget.id]) {
|
|
payload[widget.id].id = widget.id;
|
|
payload[widget.id].index = widget.index;
|
|
section.widgets[i] = payload[widget.id];
|
|
section.widgets[i].custom = 1;
|
|
}
|
|
});
|
|
}
|
|
});
|
|
})
|
|
.catch(this.$fhcAlert.handleSystemError);
|
|
},
|
|
widgetRemove(section_name, id) {
|
|
const params = {
|
|
db: this.dashboard,
|
|
funktion_kurzbz: section_name,
|
|
widgetid: id
|
|
};
|
|
return this.$api
|
|
.call(ApiDashboardPreset.removeWidget(params))
|
|
.then(result => {
|
|
this.sections.forEach(section => {
|
|
if (section.name == section_name)
|
|
section.widgets = section.widgets.filter(widget => widget.id != id);
|
|
});
|
|
})
|
|
.catch(this.$fhcAlert.handleSystemError);
|
|
},
|
|
loadSections(evt) {
|
|
let funktionen = Array.from(evt.target.querySelectorAll("option:checked"),e=>e.value);
|
|
this.sections = [];
|
|
this.tmpLoading = funktionen.join('###');
|
|
|
|
const params = {
|
|
db: this.dashboard,
|
|
funktionen
|
|
};
|
|
|
|
return this.$api
|
|
.call(ApiDashboardPreset.getBatch(params))
|
|
.then(result => {
|
|
if (this.tmpLoading !== funktionen.join('###'))
|
|
return; // NOTE(chris): prevent race condition
|
|
for (var section in result.data) {
|
|
let widgets = [];
|
|
for (var wid in result.data[section]) {
|
|
result.data[section][wid].id = wid;
|
|
result.data[section][wid].custom = 1;
|
|
widgets.push(result.data[section][wid]);
|
|
}
|
|
this.sections.push({
|
|
name: section,
|
|
widgets
|
|
});
|
|
}
|
|
})
|
|
.catch(this.$fhcAlert.handleSystemError);
|
|
|
|
},
|
|
loadFunktionen() {
|
|
this.$api
|
|
.call(ApiDashboardPreset.list(this.dashboard))
|
|
.then(result => {
|
|
this.funktionen = result.data;
|
|
})
|
|
.catch(this.$fhcAlert.handleSystemError);
|
|
}
|
|
},
|
|
created() {
|
|
this.loadFunktionen();
|
|
},
|
|
watch: {
|
|
dashboard() {
|
|
// TODO(chris): this should be done without a watcher
|
|
this.loadSections({target:this.$refs.funktionenList});
|
|
this.loadFunktionen();
|
|
}
|
|
},
|
|
template: `<div class="dashboard-admin-presets">
|
|
<div class="row">
|
|
<div class="col-3">
|
|
<select ref="funktionenList" style="height:30em" class="form-control" multiple @input="loadSections">
|
|
<option
|
|
v-for="funktion in funktionen"
|
|
:key="funktion.funktion_kurzbz"
|
|
:value="funktion.funktion_kurzbz"
|
|
:class="(funktion.has_preset > 0) ? 'fw-bold' : ''"
|
|
>{{ funktion.beschreibung }}</option>
|
|
</select>
|
|
</div>
|
|
<div class="col-9">
|
|
<dashboard-section v-for="section in sections" :key="section.name" :name="section.name" :widgets="section.widgets" @widget-add="widgetAdd" @widget-update="widgetUpdate" @widget-remove="widgetRemove"></dashboard-section>
|
|
</div>
|
|
</div>
|
|
<dashboard-widget-picker ref="widgetpicker" :widgets="pickerWidgets"></dashboard-widget-picker>
|
|
</div>`
|
|
}
|