Compare commits

...

2 Commits

Author SHA1 Message Date
felixerdy
d20d8b9e97 add xml code changes 2021-09-16 16:51:10 +02:00
felixerdy
53b4f5dfeb keep workspace code and prepare dialog 2021-09-16 16:00:27 +02:00
5 changed files with 9275 additions and 9585 deletions

View File

@ -19,6 +19,7 @@
"@testing-library/user-event": "^7.2.1", "@testing-library/user-event": "^7.2.1",
"axios": "^0.21.0", "axios": "^0.21.0",
"blockly": "^6.20210701.0", "blockly": "^6.20210701.0",
"diff-js-xml": "^1.0.6",
"file-saver": "^2.0.2", "file-saver": "^2.0.2",
"mnemonic-id": "^3.2.7", "mnemonic-id": "^3.2.7",
"moment": "^2.28.0", "moment": "^2.28.0",

View File

@ -20,16 +20,18 @@ class BlocklyWindow extends Component {
componentDidMount() { componentDidMount() {
const workspace = Blockly.getMainWorkspace(); const workspace = Blockly.getMainWorkspace();
this.props.onChangeWorkspace({}); if (!this.props.readOnly) {
this.props.clearStats(); this.props.onChangeWorkspace({});
workspace.addChangeListener((event) => { this.props.clearStats();
this.props.onChangeWorkspace(event); workspace.addChangeListener((event) => {
// switch on that a block is displayed disabled or not depending on whether it is correctly connected this.props.onChangeWorkspace(event);
// for SVG display, a deactivated block in the display is undesirable // switch on that a block is displayed disabled or not depending on whether it is correctly connected
if (this.props.blockDisabled) { // for SVG display, a deactivated block in the display is undesirable
Blockly.Events.disableOrphans(event); if (this.props.blockDisabled) {
} Blockly.Events.disableOrphans(event);
}); }
});
}
Blockly.svgResize(workspace); Blockly.svgResize(workspace);
const zoomToFit = new ZoomToFitControl(workspace); const zoomToFit = new ZoomToFitControl(workspace);
zoomToFit.init(); zoomToFit.init();
@ -37,21 +39,23 @@ class BlocklyWindow extends Component {
componentDidUpdate(props) { componentDidUpdate(props) {
const workspace = Blockly.getMainWorkspace(); const workspace = Blockly.getMainWorkspace();
var xml = this.props.initialXml; if (!this.props.readOnly) {
// if svg is true, then the update process is done in the BlocklySvg component var xml = this.props.initialXml;
if (props.initialXml !== xml && !this.props.svg) { // if svg is true, then the update process is done in the BlocklySvg component
// guarantees that the current xml-code (this.props.initialXml) is rendered if (props.initialXml !== xml && !this.props.svg) {
workspace.clear(); // guarantees that the current xml-code (this.props.initialXml) is rendered
if (!xml) xml = initialXml; workspace.clear();
Blockly.Xml.domToWorkspace(Blockly.Xml.textToDom(xml), workspace); if (!xml) xml = initialXml;
} Blockly.Xml.domToWorkspace(Blockly.Xml.textToDom(xml), workspace);
if (props.language !== this.props.language) { }
// change language if (props.language !== this.props.language) {
if (!xml) xml = initialXml; // change language
var xmlDom = Blockly.Xml.textToDom(xml); if (!xml) xml = initialXml;
Blockly.Xml.clearWorkspaceAndLoadFromXml(xmlDom, workspace); var xmlDom = Blockly.Xml.textToDom(xml);
// var toolbox = workspace.getToolbox(); Blockly.Xml.clearWorkspaceAndLoadFromXml(xmlDom, workspace);
// workspace.updateToolbox(toolbox.toolboxDef_); // var toolbox = workspace.getToolbox();
// workspace.updateToolbox(toolbox.toolboxDef_);
}
} }
Blockly.svgResize(workspace); Blockly.svgResize(workspace);
} }

View File

@ -77,7 +77,7 @@ class Home extends Component {
componentWillUnmount() { componentWillUnmount() {
this.props.clearStats(); this.props.clearStats();
this.props.workspaceName(null); // this.props.workspaceName(null);
} }
onChange = () => { onChange = () => {
@ -112,10 +112,17 @@ class Home extends Component {
</Tooltip> </Tooltip>
<TrashcanButtons /> <TrashcanButtons />
<div className='blocklyWindow'> <div className='blocklyWindow'>
{this.props.project ? {this.props.project ? (
< BlocklyWindow blocklyCSS={{ height: '80vH' }} initialXml={this.props.project.xml} /> <BlocklyWindow
: < BlocklyWindow blocklyCSS={{ height: '80vH' }} /> blocklyCSS={{ height: "80vH" }}
} initialXml={this.props.project.xml}
/>
) : (
<BlocklyWindow
blocklyCSS={{ height: "80vH" }}
initialXml={this.props.workspaceCode?.xml}
/>
)}
</div> </div>
</Grid> </Grid>
{this.state.codeOn ? {this.state.codeOn ?
@ -146,7 +153,8 @@ Home.propTypes = {
const mapStateToProps = state => ({ const mapStateToProps = state => ({
message: state.message, message: state.message,
statistics: state.general.statistics statistics: state.general.statistics,
workspaceCode: state.workspace.code
}); });

View File

@ -18,6 +18,11 @@ import Divider from "@material-ui/core/Divider";
import Typography from "@material-ui/core/Typography"; import Typography from "@material-ui/core/Typography";
import Backdrop from "@material-ui/core/Backdrop"; import Backdrop from "@material-ui/core/Backdrop";
import CircularProgress from "@material-ui/core/CircularProgress"; import CircularProgress from "@material-ui/core/CircularProgress";
import Dialog from "../Dialog";
import Button from "@material-ui/core/Button";
import { initialXml } from "../Blockly/initialXml";
import {diffAsXml} from 'diff-js-xml';
const styles = (theme) => ({ const styles = (theme) => ({
link: { link: {
@ -36,6 +41,7 @@ class ProjectHome extends Component {
type: "", type: "",
key: "", key: "",
message: "", message: "",
dialog: false,
}; };
componentDidMount() { componentDidMount() {
@ -126,10 +132,43 @@ class ProjectHome extends Component {
overflow: "hidden", overflow: "hidden",
}} }}
> >
<Link <div
to={`/${ onClick={async () => {
data === "Projekte" ? "project" : "gallery" const isCodeDifferent = new Promise((resolve) => {
}/${project._id}`} // resolve successfully when there is no existing workspace XML code
if(!this.props.workspaceCode.xml) {
resolve(false)
return
}
// get difference of XML
// TODO: check if code of project is different to workspace code
diffAsXml(
this.props.workspaceCode.xml,
initialXml,
undefined,
undefined,
(result) => {
resolve(result.length !== 0);
}
)
}
);
const showDialog = await isCodeDifferent;
if (showDialog)
this.setState({
dialog: true,
});
else {
this.props.history.push(
`/${
data === "Projekte" ? "project" : "gallery"
}/${project._id}`
);
}
}}
style={{ textDecoration: "none", color: "inherit" }} style={{ textDecoration: "none", color: "inherit" }}
> >
<h3 style={{ marginTop: 0 }}>{project.title}</h3> <h3 style={{ marginTop: 0 }}>{project.title}</h3>
@ -139,6 +178,7 @@ class ProjectHome extends Component {
<BlocklyWindow <BlocklyWindow
svg svg
blockDisabled blockDisabled
readOnly
initialXml={project.xml} initialXml={project.xml}
/> />
<Typography <Typography
@ -151,7 +191,7 @@ class ProjectHome extends Component {
> >
{project.description} {project.description}
</Typography> </Typography>
</Link> </div>
{this.props.user && {this.props.user &&
this.props.user.email === project.creator ? ( this.props.user.email === project.creator ? (
<div> <div>
@ -206,6 +246,27 @@ class ProjectHome extends Component {
type={this.state.type} type={this.state.type}
key={this.state.key} key={this.state.key}
/> />
<Dialog
open={this.state.dialog}
title="Achtung"
actions={
<React.Fragment>
<Button
onClick={() => {
this.setState({ dialog: false });
// TODO: navigate to project
}}
>
Verwerfen
</Button>
<Button onClick={() => {}} color="primary">
Speichern
</Button>
</React.Fragment>
}
>
Möchtest du deinen bisherigen Code als Projekt speichern?
</Dialog>
</div> </div>
); );
} }
@ -226,6 +287,7 @@ const mapStateToProps = (state) => ({
progress: state.project.progress, progress: state.project.progress,
user: state.auth.user, user: state.auth.user,
message: state.message, message: state.message,
workspaceCode: state.workspace.code,
}); });
export default connect(mapStateToProps, { export default connect(mapStateToProps, {

18713
yarn.lock

File diff suppressed because it is too large Load Diff