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

Create a shortcut editor for the notebook. #1347

Merged
merged 3 commits into from
May 5, 2016

Conversation

Carreau
Copy link
Member

@Carreau Carreau commented Apr 13, 2016

Replace #1265

Also introduce es6, and write the new keyboard shortcut editor as pure es6.
Does not use react.


[edit]
Update description after lots of refactor.

Create shortcut editor for the notebook

  1. finish the step allowing the use of es6
  • this include some tweak to web pack configuration to speed up
    recompile in watch mode (in particular cache sourcemaps).
  • enable eslint (error only), on obvious mistakes.
  • setup babel to compile to es5 as a target.
  1. Make the test pass under Casper that does not always have
    Function.prototype.bind defined, which we cannot patch only in the
    tests.

  2. Write an actual shortcut editor that list and allow to modify most of
    the command mode shortcut.

The logic to persist the shortcuts is a bit tricky as there are default
keyboard shortcuts, and so when you "unbind" them you need to re-unbind
them at next startup. This does not work for a few shortcut for
technical reasons: <Esc>, <Shift>, as well as <Ctrl-Shift-P> and <F>
which register asynchronously, so are not detected as "default"
shortcuts.

@sccolbert
Copy link
Contributor

Should preact be a runtime dependency instead of a dev dependency?

@Carreau
Copy link
Member Author

Carreau commented Apr 13, 2016

Should preact be a runtime dependency instead of a dev dependency?

Likely yes, reflect of --save-dev.

@Carreau
Copy link
Member Author

Carreau commented Apr 13, 2016

reflex*,

and it will be bundled in the min.js that will generated by webpack and be shipped, so not actually not sure.

@Carreau Carreau force-pushed the shortcut-editor-2 branch from 702802b to 032b3ff Compare April 13, 2016 15:14
@@ -27,5 +30,7 @@
},
"dependencies": {
"moment": "^2.8.4"
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is a syntax error. You need a comma.

@Carreau
Copy link
Member Author

Carreau commented Apr 14, 2016

ping @jdfreder , you're the one that know the most things about notebook test. Test seem to not run at all with this PR, but I can't seem to figure out the reason why, as the same step works flawlessly locally.

Any ideas ?

@Carreau Carreau force-pushed the shortcut-editor-2 branch 10 times, most recently from 32131cd to 831e7cd Compare April 21, 2016 15:00
Carreau added 2 commits April 21, 2016 18:00
1) finish the step allowing the use of es6

  - this include some tweak to web pack configuration to speed up
    recompile in watch mode (in particular cache sourcemaps).
  - enable eslint (error only), on obvious mistakes.
  - setup babel to compile to es5 as a target.

2) Make the test pass under Casper that does not always have
`Function.prototype.bind` defined, which we cannot patch only in the
tests.

3) Write an actual shortcut editor that list and allow to modify most of
the command mode shortcut.

The logic to persist the shortcuts is a bit tricky as there are default
keyboard shortcuts, and so when you "unbind" them you need to re-unbind
them at next startup. This does not work for a few shortcut for
technical reasons: `<Esc>`, `<Shift>`, as well as `<Ctrl-Shift-P>` and `<F>`
which register asynchronously, so are not detected as "default"
shortcuts.
@Carreau Carreau force-pushed the shortcut-editor-2 branch from a4ea097 to 12b4834 Compare April 21, 2016 16:01
@Carreau
Copy link
Member Author

Carreau commented Apr 29, 2016

BTW, this now works, and can now use es6.

@sccolbert
Copy link
Contributor

What do you mean by "can use es6"?

@Carreau
Copy link
Member Author

Carreau commented Apr 29, 2016

What do you mean by "can use es6"?

Sorry, was unclear, you can use es6 feature in all the js files (typically notebook/static/*/js/*.js), webpack use the a babel loader when minifying, so will understand let, const, import {} from ... etc. There is no extra steps.

@sccolbert
Copy link
Contributor

Ah - I didn't realize we were using babel. Are we still targeting ES5 runtimes?

@Carreau
Copy link
Member Author

Carreau commented Apr 29, 2016

Are we still targeting ES5 runtimes?

Yes. We can use something else than babel, I guess we can use a typescript loader as well, I have no issues with that.

One thing I did not include is the ability to use .jsx, but that should be pretty easy to add too if we decide to do so.

@sccolbert
Copy link
Contributor

sccolbert commented Apr 29, 2016

I don't think we need to use the TS loader at this point. We've been doing okay just shipping the built .js files for our code which is written in TS.

@sccolbert
Copy link
Contributor

Also, I think (but could be wrong) that preact has an h() function, which can reduce the boilerplate needed by createElement.

@Carreau
Copy link
Member Author

Carreau commented Apr 29, 2016

Also, I think (but could be wrong) that preact has an h() function, which can reduce the boilerplate needed by createElement.

Yes it has a h() function, though they don't really explain how/why to use it, expect using /** @jsx h */ in jsx files, and it looks mostly as s/createElement/h/g, but I might be missing something.

@Carreau
Copy link
Member Author

Carreau commented May 5, 2016

Ok, merging to get people to complain.

@Carreau Carreau merged commit d8fc951 into jupyter:master May 5, 2016
@Carreau Carreau deleted the shortcut-editor-2 branch May 5, 2016 21:47
@minrk minrk added this to the 5.0 milestone May 30, 2016
@github-actions github-actions bot locked as resolved and limited conversation to collaborators Apr 14, 2021
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants