mirror of
https://github.com/Unleash/unleash.git
synced 2025-06-04 01:18:20 +02:00
fix: should not register duplicate HTML5 backends
This commit is contained in:
parent
c499a6cb9e
commit
107cc0636f
18
frontend/src/component/common/drag-and-drop.jsx
Normal file
18
frontend/src/component/common/drag-and-drop.jsx
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
import { DndProvider, createDndContext } from 'react-dnd';
|
||||||
|
import { HTML5Backend } from 'react-dnd-html5-backend';
|
||||||
|
import React, { useRef } from 'react';
|
||||||
|
|
||||||
|
const RNDContext = createDndContext(HTML5Backend);
|
||||||
|
|
||||||
|
function useDNDProviderElement(props) {
|
||||||
|
const manager = useRef(RNDContext);
|
||||||
|
|
||||||
|
if (!props.children) return null;
|
||||||
|
|
||||||
|
return <DndProvider manager={manager.current.dragDropManager}>{props.children}</DndProvider>;
|
||||||
|
}
|
||||||
|
|
||||||
|
export default function DragAndDrop(props) {
|
||||||
|
const DNDElement = useDNDProviderElement(props);
|
||||||
|
return <React.Fragment>{DNDElement}</React.Fragment>;
|
||||||
|
}
|
@ -29,6 +29,7 @@ class WrapperComponent extends Component {
|
|||||||
name,
|
name,
|
||||||
description: '',
|
description: '',
|
||||||
type: 'release',
|
type: 'release',
|
||||||
|
stale: false,
|
||||||
strategies: [],
|
strategies: [],
|
||||||
variants: [],
|
variants: [],
|
||||||
enabled: true,
|
enabled: true,
|
||||||
|
@ -1,13 +1,11 @@
|
|||||||
import React from 'react';
|
import React from 'react';
|
||||||
import PropTypes from 'prop-types';
|
import PropTypes from 'prop-types';
|
||||||
|
|
||||||
import { DndProvider } from 'react-dnd';
|
|
||||||
import { HTML5Backend } from 'react-dnd-html5-backend';
|
|
||||||
import arrayMove from 'array-move';
|
import arrayMove from 'array-move';
|
||||||
|
|
||||||
import ConfigureStrategy from './strategy-configure-container';
|
import ConfigureStrategy from './strategy-configure-container';
|
||||||
import AddStrategy from './strategies-add';
|
import AddStrategy from './strategies-add';
|
||||||
import { HeaderTitle } from '../../common';
|
import { HeaderTitle } from '../../common';
|
||||||
|
import DragAndDrop from '../../common/drag-and-drop';
|
||||||
import { updateIndexInArray } from '../../common/util';
|
import { updateIndexInArray } from '../../common/util';
|
||||||
import styles from './strategy.module.scss';
|
import styles from './strategy.module.scss';
|
||||||
|
|
||||||
@ -57,7 +55,7 @@ const StrategiesList = props => {
|
|||||||
/>
|
/>
|
||||||
));
|
));
|
||||||
return (
|
return (
|
||||||
<DndProvider backend={HTML5Backend}>
|
<DragAndDrop>
|
||||||
<div className={styles.strategyListAdd}>
|
<div className={styles.strategyListAdd}>
|
||||||
<HeaderTitle
|
<HeaderTitle
|
||||||
title="Activation strategies"
|
title="Activation strategies"
|
||||||
@ -82,7 +80,7 @@ const StrategiesList = props => {
|
|||||||
)}
|
)}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</DndProvider>
|
</DragAndDrop>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -1,12 +1,11 @@
|
|||||||
import React, { useState, useEffect } from 'react';
|
import React, { useState, useEffect } from 'react';
|
||||||
import PropTypes from 'prop-types';
|
import PropTypes from 'prop-types';
|
||||||
|
|
||||||
import { DndProvider } from 'react-dnd';
|
|
||||||
import { HTML5Backend } from 'react-dnd-html5-backend';
|
|
||||||
import { cloneDeep } from 'lodash';
|
import { cloneDeep } from 'lodash';
|
||||||
import arrayMove from 'array-move';
|
import arrayMove from 'array-move';
|
||||||
import { Button, Icon } from 'react-mdl';
|
import { Button, Icon } from 'react-mdl';
|
||||||
|
|
||||||
|
import DragAndDrop from '../../common/drag-and-drop';
|
||||||
import ConfigureStrategy from './strategy-configure-container';
|
import ConfigureStrategy from './strategy-configure-container';
|
||||||
import AddStrategy from './strategies-add';
|
import AddStrategy from './strategies-add';
|
||||||
import { HeaderTitle } from '../../common';
|
import { HeaderTitle } from '../../common';
|
||||||
@ -123,7 +122,7 @@ const StrategiesList = props => {
|
|||||||
/>
|
/>
|
||||||
));
|
));
|
||||||
return (
|
return (
|
||||||
<DndProvider backend={HTML5Backend}>
|
<DragAndDrop>
|
||||||
{editable && (
|
{editable && (
|
||||||
<HeaderTitle
|
<HeaderTitle
|
||||||
title="Activation strategies"
|
title="Activation strategies"
|
||||||
@ -147,7 +146,7 @@ const StrategiesList = props => {
|
|||||||
Clear all
|
Clear all
|
||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
</DndProvider>
|
</DragAndDrop>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user