mirror of
https://github.com/xibyte/jsketcher
synced 2025-12-10 02:13:58 +01:00
84 lines
2.9 KiB
JavaScript
84 lines
2.9 KiB
JavaScript
import React, {useContext, useEffect} from 'react';
|
||
import connect from 'ui/connect';
|
||
import Widget from 'ui/components/Widget';
|
||
import decoratorChain from 'ui/decoratorChain';
|
||
import {combine, merger} from 'lstream';
|
||
import ls from './SelectedModificationInfo.less';
|
||
import ImgIcon from 'ui/components/ImgIcon';
|
||
import mapContext from 'ui/mapContext';
|
||
import {EMPTY_OBJECT} from 'gems/objects';
|
||
import ButtonGroup from 'ui/components/controls/ButtonGroup';
|
||
import Button from 'ui/components/controls/Button';
|
||
import {removeAndDropDependants} from '../craftHistoryUtils';
|
||
import RenderObject from 'ui/components/RenderObject';
|
||
import {AppContext} from "cad/dom/components/AppContext";
|
||
|
||
function SelectedModificationInfo({ history, index,
|
||
operationRegistry,
|
||
locationHint: lh,
|
||
drop, edit,
|
||
close}) {
|
||
const ctx = useContext(AppContext);
|
||
|
||
useEffect(() => {
|
||
|
||
function clickAwayHandler() {
|
||
ctx.streams.ui.craft.modificationSelection.next(EMPTY_OBJECT);
|
||
}
|
||
|
||
ctx.domService.viewerContainer.addEventListener('click', clickAwayHandler);
|
||
return () => {
|
||
ctx.domService.viewerContainer.removeEventListener('click', clickAwayHandler);
|
||
}
|
||
}, []);
|
||
let m = history[index];
|
||
let visible = !!m;
|
||
if (!visible) {
|
||
return null;
|
||
}
|
||
let op = operationRegistry[m.type];
|
||
if (!op) {
|
||
console.warn('unknown operation ' + m.type);
|
||
return;
|
||
}
|
||
let {appearance} = op;
|
||
let indexNumber = index + 1;
|
||
return <Widget visible={visible}
|
||
left={lh && lh.x}
|
||
bottom={95}
|
||
flatRight={!lh}
|
||
title={m.type + ' operation #' + indexNumber}
|
||
onClose={close}>
|
||
<div className={ls.requestInfo}>
|
||
<ImgIcon className={ls.pic} url={appearance && appearance.icon96} size={48}/>
|
||
<RenderObject object={m.params}/>
|
||
|
||
|
||
</div>
|
||
<div>
|
||
<ButtonGroup>
|
||
<Button onClick={edit}>🖉EDIT</Button>
|
||
<Button type='danger' onClick={drop}>🗑DELETE</Button>
|
||
</ButtonGroup>
|
||
</div>
|
||
</Widget>;
|
||
}
|
||
|
||
export default decoratorChain(
|
||
connect(streams => combine(streams.ui.craft.modificationSelection,
|
||
streams.operation.registry.map(r => ({operationRegistry: r})),
|
||
streams.craft.modifications
|
||
).map(merger)),
|
||
mapContext((ctx, props) => ({
|
||
close: () => ctx.streams.ui.craft.modificationSelection.next(EMPTY_OBJECT),
|
||
drop: () => {
|
||
ctx.streams.craft.modifications.update(modifications => removeAndDropDependants(modifications, props.index))
|
||
ctx.streams.ui.craft.modificationSelection.next(EMPTY_OBJECT);
|
||
},
|
||
edit: () => {
|
||
ctx.streams.craft.modifications.update(({history}) => ({history, pointer: props.index - 1}))
|
||
ctx.streams.ui.craft.modificationSelection.next(EMPTY_OBJECT);
|
||
}
|
||
}))
|
||
)(SelectedModificationInfo);
|
||
|