Skip to content

Latest commit

 

History

History
188 lines (133 loc) · 7.95 KB

README.md

File metadata and controls

188 lines (133 loc) · 7.95 KB

JumpFlowy

A Chrome/Firefox user script which adds search, navigation, and keyboard shortcut features to WorkFlowy.

Table of Contents generated with DocToc

Target audience

  • WorkFlowy users who need more search and navigation capabilities

Target platforms

Documentation and examples

The documentation and examples consist of:

Getting started

Install the JumpFlowy user script

Configuration of triggers and actions

Configuring JumpFlowy is mostly about binding triggers (e.g. keyboard shortcuts) to actions. You do this by adding an item to your WorkFlowy document, where a tag describes the trigger, and the note describes an (optional) follow action.

There are 2 types of trigger:

  • keyboard shortcuts, e.g. #shortcut(ctrl+shift+KeyF)
  • bookmarks, e.g. #bm(home)

The trigger takes us to the item which defined that trigger, and then JumpFlowy follows that item, i.e. it performs some follow action based on the contents of the item.

There are 3 types of follow action:

  • Perform some named function (where the item's text is the name of that function, e.g. promptToNormalLocalSearch)
  • Go to some other WorkFlowy item (where the item's text is the URL of that WorkFlowy item to go to, e.g. https://workflowy.com)
  • Go to the item itself (where neither a named function nor WorkFlowy URL are found as defined above)

Keyboard shortcut triggers

To add a keyboard trigger, add e.g. #shortcut(ctrl+shift+KeyF) to the item you want to follow.

For the available key codes, see this Mozilla's keyCode reference.

Note: Currently, you'll need to log out and log in again to WorkFlowy (after saving your changes) in order for the keyboard shortcut to take effect. This is a known issue, and a fix is planned.

Bookmark triggers

To add a keyboard trigger, add e.g. #bm(home) to the item you want to follow to define a bookmark called home.

Configuration Examples

See this example configuration.

To use the above configuration as a starting point:

  • Install the JumpFlowy user script.
  • Copy the configuration section below it into your own WorkFlowy document.
  • Edit the configuration according to your needs.
  • Log out and in again (a fix is planned, you won't need to do this in future)

This example binds the keyboard shortcut ctrl+shift+KeyF to a WorkFlowy search:

  • Text: #shortcut(ctrl+shift+KeyF)
  • Note: promptToNormalLocalSearch

This example binds the keyboard shortcut ctrl+KeyJ to a bookmark search:

  • Text: #shortcut(ctrl+KeyJ)
  • Note: promptToFindGlobalBookmarkThenFollow

This example binds the bookmark hm to the root/home of the document.

  • Text: #bm(hm)
  • Note: https://workflowy.com/

With the above configuration enabled, you could press ctrl+KeyJ to trigger the bookmark search, then type hm, ENTER to find and follow the hm bookmark, which would take you to the root/home of the document.

A good convention to follow is to put the trigger in the item's text, and the action as the item's note. However, the trigger (#bm/#shortcut) can be specified anywhere in the item's main text or note. The action must be either the only content in the item's main text, or the only content in the item's note.

Follow actions

When following an item, the follow action will be one of:

  • Go to the item itself, i.e. zoom into it
  • Go to some other item (specify the URL or this other item as this item's note)
  • Perform some named function (specify the name of the function as this item's note)

The normal convention for specifying a named function to execute or a URL to follow is to put it as the only content in the item's text. To be recognised by JumpFlowy, it must be the full text of either the item's main text or the item's note.

For a description of what each of these named functions do, find its comments in jumpflowy.user.js.

The available named functions:

  • addBookmark
  • blurFocusedContent
  • combinationUpdateDateThenMoveToBookmark
  • clearDate
  • createItemAtTopOfCurrent
  • createOrdinaryLink
  • dismissNotification
  • editCurrentItem
  • editParentOfFocusedItem
  • reassembleNameTree
  • logShortReport
  • markFocusedAndDescendantsNotComplete
  • moveToBookmark
  • openFirstLinkInFocusedItem
  • promptToAddBookmarkForCurrentItem (Deprecated: use addBookmark)
  • promptToFindGlobalBookmarkThenFollow
  • promptToFindLocalRegexMatchThenZoom
  • promptToNormalLocalSearch
  • promptToFindByDateRange
  • promptToFindByLastChanged
  • scatterDescendants
  • scheduleDescendants
  • sendToNameTree
  • sendToNameTreeAndClearDateAndComplete
  • updateDate
  • showZoomedAndMostRecentlyEdited
  • validateAllNameTrees

Suggestions for what to configure

As a general guide:

  • Bind promptToFindGlobalBookmarkThenFollow to a convenient key combination, to enable bookmark support.
  • Add lots of named bookmarks (#bm(name)) to frequently visited locations in your document, updating these as needed.
  • Add a handful of keyboard shortcuts (#shortcut(...)) to frequently visited locations which don't change (e.g. top level 'work' or 'personal' sections).
  • Add bookmarks or shortcuts for some subset of the named functions, just those which seem useful to you.

Developing JumpFlowy

Running the tests

To run the tests, see the instructions at the top of add-browser-reload.user.js.

Linting

  • Some static type checking is performed through the use of VS Code, by using JSDoc function annotations and a TypeScript declaration file.
  • Linting is done by by ESLint.
  • prettier is used for formatting.

Contributing

Pull requests and bug reports are very welcome.

Versioning and backwards compatibility

At this early stage while jumpflowy is still under active development, expect some breaking changes to happen even at minor version changes.

Authors

  • Matt Hutton - Initial work

License

This project is licensed under the MIT license. See the LICENSE file for details.

Acknowledgments

  • The WorkFlowy team for creating such a great product
  • rawbytz for proving what's possible on top of WorkFlowy