mirror of
https://github.com/directus/directus.git
synced 2026-02-01 22:35:08 -05:00
Fix panel editing
This commit is contained in:
@@ -244,10 +244,9 @@ export default defineComponent({
|
||||
}
|
||||
|
||||
function onPointerUp() {
|
||||
dragging.value = false;
|
||||
if (props.editMode === false) return;
|
||||
emit('update', editedPosition);
|
||||
|
||||
dragging.value = false;
|
||||
window.removeEventListener('pointerup', onPointerUp);
|
||||
window.removeEventListener('pointermove', onPointerMove);
|
||||
|
||||
|
||||
@@ -5,9 +5,9 @@
|
||||
:key="panel.id"
|
||||
:panel="panel"
|
||||
:edit-mode="editMode"
|
||||
@update="stagePanelEdits($event, panel.id)"
|
||||
@delete="confirmDeletePanel = panel.id"
|
||||
@duplicate="duplicatePanel(panel)"
|
||||
@update="$emit('update', { edits: $event, id: panel.id })"
|
||||
@delete="$emit('delete', panel.id)"
|
||||
@duplicate="$emit('duplicate', panel)"
|
||||
/>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
@@ -52,7 +52,14 @@
|
||||
<insights-navigation />
|
||||
</template>
|
||||
|
||||
<insights-workspace :edit-mode="editMode" :panels="panels" :zoom-to-fit="zoomToFit" />
|
||||
<insights-workspace
|
||||
:edit-mode="editMode"
|
||||
:panels="panels"
|
||||
:zoom-to-fit="zoomToFit"
|
||||
@update="stagePanelEdits"
|
||||
@delete="confirmDeletePanel = $event"
|
||||
@duplicate="duplicatePanel"
|
||||
/>
|
||||
|
||||
<router-view
|
||||
name="detail"
|
||||
@@ -210,33 +217,35 @@ export default defineComponent({
|
||||
toggleZoomToFit,
|
||||
};
|
||||
|
||||
function stagePanelEdits(edits: Partial<Panel>, key: string = props.panelKey) {
|
||||
function stagePanelEdits(event: { edits: Partial<Panel>; id?: string }) {
|
||||
const key = event.id ?? props.panelKey;
|
||||
|
||||
if (key === '+') {
|
||||
stagedPanels.value = [
|
||||
...stagedPanels.value,
|
||||
{
|
||||
id: `_${nanoid()}`,
|
||||
dashboard: props.primaryKey,
|
||||
...edits,
|
||||
...event.edits,
|
||||
},
|
||||
];
|
||||
} else {
|
||||
if (stagedPanels.value.some((panel) => panel.id === key)) {
|
||||
stagedPanels.value = stagedPanels.value.map((panel) => {
|
||||
if (panel.id === key) {
|
||||
return merge({ id: key, dashboard: props.primaryKey }, panel, edits);
|
||||
return merge({ id: key, dashboard: props.primaryKey }, panel, event.edits);
|
||||
}
|
||||
|
||||
return panel;
|
||||
});
|
||||
} else {
|
||||
stagedPanels.value = [...stagedPanels.value, { id: key, dashboard: props.primaryKey, ...edits }];
|
||||
stagedPanels.value = [...stagedPanels.value, { id: key, dashboard: props.primaryKey, ...event.edits }];
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function stageConfiguration(edits: Partial<Panel>) {
|
||||
stagePanelEdits(edits);
|
||||
stagePanelEdits({ edits });
|
||||
router.push(`/insights/${props.primaryKey}`);
|
||||
}
|
||||
|
||||
@@ -303,7 +312,7 @@ export default defineComponent({
|
||||
const newPanel = omit(merge({}, panel), 'id');
|
||||
newPanel.position_x = newPanel.position_x + 2;
|
||||
newPanel.position_y = newPanel.position_y + 2;
|
||||
stagePanelEdits(newPanel, '+');
|
||||
stagePanelEdits({ edits: newPanel, id: '+' });
|
||||
}
|
||||
|
||||
function toggleFullScreen() {
|
||||
|
||||
Reference in New Issue
Block a user