Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Python mode (aka text-paste) branch #187

Open
wants to merge 72 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 12 commits
Commits
Show all changes
72 commits
Select commit Hold shift + click to select a range
209e696
Add text paste method
dabbler0 Mar 18, 2016
3ac4938
python mode dropdown menu and block color (WIP)
Jun 2, 2016
577f634
function names in modeOptions detected as block name, python mode demo
Jun 6, 2016
43a49af
implement handleButton for extending if/elses
Jun 13, 2016
36b8dca
fix text-paste with the hiddenInput value not updating
Jun 16, 2016
705aa62
C if/elseif/else amalgamation
dabbler0 Jul 6, 2016
0935880
Merge branch 'svg-grouping' into c_if_else
dabbler0 Jul 6, 2016
d4e5fcf
Add pipeline for mutation buttons
dabbler0 Jul 6, 2016
d129f15
Remove extraneous debug
dabbler0 Jul 6, 2016
bfa7674
Add necessary annotation pipeline
dabbler0 Jul 11, 2016
04eecb4
Merge branch 'svg-grouping' into c_if_else
dabbler0 Jul 11, 2016
05d6a78
Merge branch 'svg-grouping' into c_if_else
dabbler0 Jul 11, 2016
1c9afed
Add +/- buttons for functions and plumbing for potentially paren unwr…
dabbler0 Jul 11, 2016
cdc38cc
+/- buttons for declarator lists
dabbler0 Jul 11, 2016
6dbf7a9
Initializers and comma expressions
dabbler0 Jul 11, 2016
3f8d44d
Add button for if even when no else
dabbler0 Jul 11, 2016
fe888f2
Allow flexible button config
dabbler0 Jul 11, 2016
cfad85f
+/- buttons for functions
dabbler0 Jul 11, 2016
dc39662
Subtract button for if/else, and vertical glyphs
dabbler0 Jul 11, 2016
a6f87c8
Usability improvements, and dual buttons for declarations
dabbler0 Jul 12, 2016
809a104
Fix a bug with dragging mutation buttons
dabbler0 Jul 12, 2016
7778591
Undo capture for mutation buttons
dabbler0 Jul 12, 2016
df0617a
Move from parse annotations to droplet tree inspection for +/- buttons
dabbler0 Jul 12, 2016
d5228dd
Move more to structure examination
dabbler0 Jul 12, 2016
e9ba713
Move back to parsing for declarations to fix a bug
dabbler0 Jul 12, 2016
f4a7506
View socket bug fix
dabbler0 Jul 12, 2016
67056a2
Center glyphs in buttons
dabbler0 Jul 12, 2016
f1a097b
python mode adaptation to the updated tree walker (WIP)
Jul 13, 2016
c1b7a16
Merge branch 'master' of https://github.com/droplet-editor/droplet in…
Jul 13, 2016
8689eea
python block drop encourage/discourage at document level (WIP)
Jul 13, 2016
42cd6ec
Merge with upstream
dabbler0 Jul 13, 2016
1ec6e1e
python mode block drop to/from indent issue
Jul 13, 2016
8d699f3
Merge branch 'master' of https://github.com/droplet-editor/droplet in…
Jul 13, 2016
97c37e4
Move to new architecture for droppability rules and shapes
dabbler0 Jul 14, 2016
cc52ddf
Fix bug where you can't drag something if it matches the context exactly
dabbler0 Jul 14, 2016
2d4cc64
Add parenthesis rules
dabbler0 Jul 14, 2016
c997d11
Rewrite parser priorities for sizeof() to avoid weird paren case and …
dabbler0 Jul 14, 2016
6faf556
Flesh out enough more colors that the palette works
dabbler0 Jul 14, 2016
0f4bd2d
Add node contexts for paren-unwrapping purposes
dabbler0 Jul 15, 2016
e6e6d9f
Fix nodeContext annotations for trailingText
dabbler0 Jul 15, 2016
c8f26ee
I actually don't know what changed
dabbler0 Jul 15, 2016
c28dc85
Update build to report errors
dabbler0 Jul 15, 2016
5972ee5
Move JavaScript to the new infrastructure, for the most part
dabbler0 Jul 18, 2016
1281efb
Move CoffeeScript over to new infrastructure as well for the most part
dabbler0 Jul 18, 2016
0fd6abe
Handle buttons and such
dabbler0 Jul 18, 2016
8cb7f3f
Fix all tests but one, which requires new infrastructure
dabbler0 Jul 18, 2016
73a376a
Clean up reparsing
dabbler0 Jul 19, 2016
ef83eab
Clean up error handling
dabbler0 Jul 19, 2016
68e639e
Fix all the tests for the new serialization method
dabbler0 Jul 19, 2016
bc81625
Merge upstream
dabbler0 Jul 19, 2016
395a7e6
Oops, finish merging
dabbler0 Jul 19, 2016
b2a6aff
Add necessary droppability graph file
dabbler0 Jul 19, 2016
a9838c3
Fix coffee precedences
dabbler0 Jul 19, 2016
b08dc64
Fix the rest of the tests
dabbler0 Jul 19, 2016
f4004af
Fix typo
dabbler0 Jul 19, 2016
8fe78ce
Merge
dabbler0 Jul 19, 2016
0e23a77
Fix some merge conflicts and a typo
dabbler0 Jul 19, 2016
883ec5e
Fix tests for phantomjs
dabbler0 Jul 19, 2016
008f00d
Fix for tests
dabbler0 Jul 19, 2016
25cd0ce
Merge branch 'master' of https://github.com/droplet-editor/droplet in…
Jul 20, 2016
7f6bed0
Add some additional tests exercising the new rules
dabbler0 Jul 20, 2016
74acf89
Merge branch 'graph-based-droppability' into container-buttons
dabbler0 Jul 20, 2016
6dee597
Fix visual bug with buttons disappearing sometimes
dabbler0 Jul 20, 2016
6d26d59
Don't put an add button on struct declarations
dabbler0 Jul 20, 2016
4a84d0f
python mode basic tests; demo page minor bug fixed
Jul 20, 2016
7a14256
Allow type changing during block reparsing
dabbler0 Jul 21, 2016
012eeee
typo fixed
Jul 25, 2016
8db958a
tweaks to the treewalker (fixes the C mode unit tests)
Jul 25, 2016
1d6482f
Merge branch 'container-buttons' of https://github.com/droplet-editor…
Aug 8, 2016
f3941bd
adapting python mode to the container-buttons branch
Aug 8, 2016
e0d08ff
python mode: tests fixed, subtract button, pass stmt not working yet
Aug 17, 2016
ce34e2d
dropdown menu arrow icon color fixed
Aug 17, 2016
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions Gruntfile.coffee
Original file line number Diff line number Diff line change
Expand Up @@ -99,6 +99,7 @@ module.exports = (grunt) ->
'test/js/jstest.js': ['test/src/jstest.coffee']
'test/js/cstest.js': ['test/src/cstest.coffee']
'test/js/htmltest.js': ['test/src/htmltest.coffee']
'test/js/pytest.js': ['test/src/pytest.coffee']
options:
transform: ['coffeeify']
browserifyOptions:
Expand Down
207 changes: 207 additions & 0 deletions example/example-python.coffee
Original file line number Diff line number Diff line change
@@ -0,0 +1,207 @@
# Droplet config editor
window.expressionContext = {
prefix: 'a = '
}

window.dropletConfig = ace.edit 'droplet-config'
dropletConfig.setTheme 'ace/theme/chrome'
dropletConfig.getSession().setMode 'ace/mode/python'

# dropletConfig.setValue localStorage.getItem('config') ? '''
dropletConfig.setValue '''
({
"mode": "python",
"modeOptions": {
"functions": {
"myFunction": {
"color": "purple",
"dropdown": [['foo', 'bar'], ['baz', 'qux']]
},
'colorTest': {
'color': 'yellow',
'dropdown': [null, ['1', '2', '3']]
},
'nestedFn': {
'color': 'pink'
}
}
},
"palette": [
{
'name': 'Input/output',
'color': 'blue',
'blocks': [
{
'block': "print 'hello'",
},
{
'block': "input('Enter a number')",
'wrapperContext': expressionContext
},
{
'block': "raw_input('Enter a string')",
'wrapperContext': expressionContext
},
{
'block': 'myFunction(drop, down)'
},
{
'block': 'colorTest(0, 1)'
},
{
'block': 'nestedFn(nestedFn(nestedFn))'
}
]
},
{
'name': 'Control flow',
'color': 'control',
'blocks': [
{
'block': "for i in range(0, 10):\\n print 'hello'",
},
{
'block': "if a == b:\\n print 'hello'",
},
{
'block': "while a < b:\\n print 'hello'",
}
]
},
{
'name': 'Methods',
'color': 'purple',
'blocks': [
{
'block': 'import module'
},
{
'block': 'from module import something'
},
{
'block': "def myMethod(arg):\\n print 'hello'",
},
{
'block': "return 'hello'",
},
{
'block': "myMethod(arg)",
'wrapperContext': expressionContext
},
]
},
{
'name': 'Variables',
'color': 'red',
'blocks': [
{
'block': 'a = 1'
}
]
},
{
'name': 'Math',
'color': 'red',
'blocks': [
{
'block': 'a + b',
'wrapperContext': expressionContext
},
{
'block': 'a - b',
'wrapperContext': expressionContext
},
{
'block': 'a * b',
'wrapperContext': expressionContext
},
{
'block': 'a / b',
'wrapperContext': expressionContext
},
{
'block': 'a % b',
'wrapperContext': expressionContext
},
{
'block': 'a ** b',
'wrapperContext': expressionContext
}
]
},
{
'name': 'Logic',
'color': 'teal',
'blocks': [
{
'block': 'a == b',
'wrapperContext': expressionContext
},
{
'block': 'a < b',
'wrapperContext': expressionContext
},
{
'block': 'a > b',
'wrapperContext': expressionContext
},
{
'block': 'a and b',
'wrapperContext': expressionContext
},
{
'block': 'a or b',
'wrapperContext': expressionContext
}
]
}
]
})
'''

# Droplet itself
createEditor = (options) ->
$('#droplet-editor').html ''
editor = new droplet.Editor $('#droplet-editor')[0], options

editor.setEditorState localStorage.getItem('blocks') is 'yes'
editor.aceEditor.getSession().setUseWrapMode true

# Initialize to starting text
editor.setValue localStorage.getItem('text') ? ''

editor.on 'change', ->
localStorage.setItem 'text', editor.getValue()

window.editor = editor

createEditor eval dropletConfig.getValue()

$('#toggle').on 'click', ->
editor.toggleBlocks()
localStorage.setItem 'blocks', (if editor.currentlyUsingBlocks then 'yes' else 'no')

# Stuff for testing convenience
$('#update').on 'click', ->
localStorage.setItem 'config', dropletConfig.getValue()
createEditor eval dropletConfig.getValue()

configCurrentlyOut = localStorage.getItem('configOut') is 'yes'

updateConfigDrawerState = ->
if configCurrentlyOut
$('#left-panel').css 'left', '0px'
$('#right-panel').css 'left', '525px'
else
$('#left-panel').css 'left', '-500px'
$('#right-panel').css 'left', '25px'

editor.resize()

localStorage.setItem 'configOut', (if configCurrentlyOut then 'yes' else 'no')

$('#close').on 'click', ->
configCurrentlyOut = not configCurrentlyOut
updateConfigDrawerState()

updateConfigDrawerState()
74 changes: 74 additions & 0 deletions example/example-python.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,74 @@
<html>
<head>
<title>Droplet Demo</title>
<meta name="viewport" content="width=device-width, initial-scale=1.0"/>
<link rel="stylesheet" type="text/css" href="../css/droplet.css"/>
<style>
#container {
position: absolute;
top: 45px; bottom: 25px; right: 25px; left: 25px;
}
#left-panel {
position: absolute;
top: 0; bottom: 0; width: 500px; left: 0;
}
#droplet-config {
position: absolute;
top: 25px; bottom: 0; left: 0; right: 0;
}
#droplet-editor-wrapper {
position: absolute;
top: 25px; bottom: 0; right: 0; left: 0;
overflow: hidden;
}
#right-panel {
position: absolute;
top: 0; bottom: 0; left: 525px; right: 0;
}
#toggle, #update {
position: absolute;
top: 0; left: 0; right: 0; height: 25px;
cursor: pointer;
background-color: #DDD;
text-align: center;
}
#close {
position: absolute;
left: -25px;
width: 25px;
top: 0;
bottom: 0;
background-color: #FDD;
cursor: pointer;
}
</style>
</head>
<body>
<div id="left-panel">
<div id="update">
Update
</div>
<div id="droplet-config">
</div>
</div>
<div id="right-panel">
<div id="close">
</div>
<div id="toggle">
Toggle
</div>
<div id="droplet-editor-wrapper">
<div id="droplet-editor">
</div>
</div>
</div>

<script src="lib/jquery.min.js"></script>
<script src="lib/coffee-script.js"></script>
<script src="../vendor/ace/ace.js"></script>
<script src="../dist/droplet-full.js"></script>

<script src="example-python.coffee" type="text/coffeescript"></script>
<script src="//localhost:35729/livereload.js"></script>
</body>
</html>
6 changes: 6 additions & 0 deletions src/controller.coffee
Original file line number Diff line number Diff line change
Expand Up @@ -1041,6 +1041,12 @@ class CapturePoint
constructor: (rememberedSockets) ->
@rememberedSockets = rememberedSockets.map (x) -> x.clone()

Editor::setFocusedText = (value) ->
if @getCursor().type is 'socket'
@populateSocket @getCursor(), value
@hiddenInput.value = value
@redrawMain()

# BASIC BLOCK MOVE SUPPORT
# ================================

Expand Down
Loading