Skip to content

Commit

Permalink
FIX Adding some page updates after sorting:
Browse files Browse the repository at this point in the history
- The status of the block (switching to unpublished/draft) now correctly changes
- An update of the preview is triggered
- Fixes an issue where required props were not being provided to ElementActions in a test

Fixes silverstripe#547
  • Loading branch information
ScopeyNZ committed Dec 18, 2018
1 parent 7c9554d commit 905fa80
Show file tree
Hide file tree
Showing 4 changed files with 26 additions and 5 deletions.
2 changes: 1 addition & 1 deletion client/dist/js/bundle.js

Large diffs are not rendered by default.

7 changes: 6 additions & 1 deletion client/src/components/ElementEditor/ElementEditor.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
/* global window */

import React, { PureComponent } from 'react';
import PropTypes from 'prop-types';
import { inject } from 'lib/Injector';
Expand Down Expand Up @@ -57,7 +59,10 @@ class ElementEditor extends PureComponent {
handleDragEnd(sourceId, afterId) {
const { actions: { handleSortBlock }, areaId } = this.props;

handleSortBlock(sourceId, afterId, areaId);
handleSortBlock(sourceId, afterId, areaId).then(() => {
const preview = window.jQuery('.cms-preview');
preview.entwine('ss.preview')._loadUrl(preview.find('iframe').attr('src'));
});

this.setState({
dragTargetElementId: null,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ describe('ElementActions', () => {
{ title: 'Settings', name: 'Settings' },
{ title: 'History', name: 'History' }
];
const editTabsClick = () => {};

describe('renderEditTabs()', () => {
it('should map input tabs into an array of buttons', () => {
Expand All @@ -24,6 +25,7 @@ describe('ElementActions', () => {
areaId={1}
editTabs={testTabs}
ActionMenuComponent={ActionMenuComponent}
handleEditTabsClick={editTabsClick}
/>
);

Expand All @@ -42,6 +44,7 @@ describe('ElementActions', () => {
areaId={1}
editTabs={testTabs}
ActionMenuComponent={ActionMenuComponent}
handleEditTabsClick={editTabsClick}
/>
);

Expand All @@ -60,6 +63,7 @@ describe('ElementActions', () => {
areaId={1}
editTabs={testTabs}
ActionMenuComponent={ActionMenuComponent}
handleEditTabsClick={editTabsClick}
>
<AbstractAction title="some button" />
</ElementActions>
Expand Down
18 changes: 15 additions & 3 deletions client/src/state/editor/sortBlockMutation.js
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,8 @@ mutation SortBlockMutation($blockId:ID!, $afterBlockId:ID!) {
AfterBlockID: $afterBlockId
) {
ID
IsLiveVersion
IsPublished
}
}
`;
Expand All @@ -24,22 +26,32 @@ const config = {
optimisticResponse: {
sortBlock: {
ID: blockId,
IsLiveVersion: false,
__typename: 'Block',
},
},
update: store => {
update: (store, { data: { sortBlock: updatedElementData } }) => {
const variables = readBlocksConfig.options({ areaId }).variables;
const data = store.readQuery({ query: readBlocksQuery, variables });
const cachedData = store.readQuery({ query: readBlocksQuery, variables });

// Query returns a deeply nested object. Explicit reconstruction via spreads is too verbose.
// This is an alternative, relatively efficient way to deep clone
const newData = JSON.parse(JSON.stringify(data));
const newData = JSON.parse(JSON.stringify(cachedData));
let { edges } = newData.readOneElementalArea.Elements;

// Find the block we reordered
const movedBlockIndex = edges.findIndex(edge => edge.node.ID === blockId);
// Keep it
const movedBlock = edges[movedBlockIndex];
// Update the moved block with the new details returned in the GraphQL response
Object.entries(updatedElementData).forEach(([key, value]) => {
// Skip the type name as this is always returned but should never change
if (key === '__typename') {
return;
}

movedBlock[key] = value;
});
// Remove the moved block
edges.splice(movedBlockIndex, 1);
// If the target is 0, it's added to the start
Expand Down

0 comments on commit 905fa80

Please sign in to comment.