This commit is contained in:
Tim Stallard 2017-04-03 14:52:27 +01:00
parent 3ad2cd24e7
commit b07d6003ed
3 changed files with 60 additions and 5 deletions

View File

@ -7,17 +7,47 @@
<li><a href="#" id="projectName">New Diagram</a></li>
<li><a href="#" id="import">Open File</a></li>
<li><a href="#" id="export">Save</a></li>
<li>
<li id="snapshots-parent">
<a href="#" id="snapshotsLink">Snapshots</a>
<ul id="snapshots">
<li><a href="#" id="addSnapshot">Add Snapshot</a></li>
</ul>
</li>
<li><a href="#" id="help-button">Help</a></li>
</ul>
<input type="file" id="importUpload"></input>
<div id="blocks">
</div>
<div id="workspace">
</div>
<div id="help">
<div>
Welcome to CryptoAssist! This is an online tool for manipulating data using various common ciphers.
<p>
You can operate the system by dragging blocks down from the top scrolling bar to place them on the diagram. You should probably start with an input and output block, and then add extra cipher blocks between them.
<p>
To join multiple blocks together, just drag from the bottom output section, and draw a line to the top of another block.
<p>
If you're interested, you can view the code on <a href="https://github.com/TimStallard/CryptoAssist">GitHub</a>. The entire project is written in Javascript, and uses the webpack build system to combine many CommonJS modules. The following libraries, all licensed under the <a href="https://opensource.org/licenses/MIT">MIT license</a>, are used in this project:
<ul>
<li><a href="https://www.npmjs.com/package/babel-core">babel-core</a></li>
<li><a href="https://www.npmjs.com/package/babel-loader">babel-loader</a></li>
<li><a href="https://www.npmjs.com/package/babel-preset-es2015">babel-preset-es2015</a></li>
<li><a href="https://www.npmjs.com/package/chart.js">chart.js</a></li>
<li><a href="https://www.npmjs.com/package/css-loader">css-loader</a></li>
<li><a href="https://www.npmjs.com/package/file-saver">file-saver</a></li>
<li><a href="https://www.npmjs.com/package/handlebars">handlebars</a></li>
<li><a href="https://www.npmjs.com/package/handlebars-loader">handlebars-loader</a></li>
<li><a href="https://www.npmjs.com/package/html-webpack-plugin">html-webpack-plugin</a></li>
<li><a href="https://www.npmjs.com/package/jquery">jquery</a></li>
<li><a href="https://www.npmjs.com/package/node-sass">node-sass</a></li>
<li><a href="https://www.npmjs.com/package/node-uuid">node-uuid</a></li>
<li><a href="https://www.npmjs.com/package/sass-loader">sass-loader</a></li>
<li><a href="https://www.npmjs.com/package/style-loader">style-loader</a></li>
<li><a href="https://www.npmjs.com/package/webpack">webpack</a></li>
<li><a href="https://www.npmjs.com/package/webpack-dev-server">webpack-dev-server</a></li>
</ul>
</div>
</div>
</body>
</html>

View File

@ -51,11 +51,19 @@ events.subscribe(["snapshotsChanged", "diagramImport"], function(){
});
$("#header #snapshots").on("click", ".snapshot>a", function(){
var snapshot = diagram.snapshots[parseInt($(this).data("i"))]
var snapshot = diagram.snapshots[parseInt($(this).data("i"))] //get the snapshot with the ID from this element
var newSnapshotName = prompt("Reverting to this snapshot will cause you to lose your current work. If you would like to make a snapshot of your current workspace, please enter a name for it:");
if(newSnapshotName){
if(newSnapshotName){ //if user wants another snapshot, make one
require("./diagram/addSnapshot.js")(newSnapshotName);
}
diagram.state = JSON.parse(JSON.stringify(snapshot.state));
diagram.state = JSON.parse(JSON.stringify(snapshot.state)); //load in snapshot
require("./diagram/updateState.js")();
});
$("#header #help-button").click(function(){
$("#help").fadeIn().css("display", "flex");
});
$("#help").click(function(){
$("#help").fadeOut();
});

View File

@ -114,7 +114,7 @@ body{
}
}
>li:last-child{
>li#snapshots-parent{
position: relative;
min-width: 150px;
ul#snapshots{
@ -147,3 +147,20 @@ body{
display: none;
}
}
#help{
position: fixed;
top: 0;
left: 0;
background-color: rgba(0, 0, 0, 0.7);
width: 100vw;
height: 100vh;
display: none;
>div{
background-color: white;
width: 80%;
margin: auto;
padding: 20px;
border-radius: 20px;
}
}