0.2.13 • Published 4 years ago

@mdo-org/mdo-plugin-sections v0.2.13

Weekly downloads
1
License
SEE LICENSE IN .....
Repository
github
Last release
4 years ago

"Sections" Plugin

Organizes to-dos into "sections":

# Inbox
To-dos that need to be reviewed / categorized.

- [ ] foo
- [ ] bar

# To-Do
To-dos that are actionable / ready to work on.

- [ ] hello
- [ ] world

# Future
To-dos that will become actionable in the future.

- [ ] abc

# Done
To-dos that have been completed
- [X] xyz

Installation

npm install --save @mdo-org/mdo-plugin-sections

Usage

const postpone = require('@mdo-org/mdo-plugin-sections');

const time = "2019-04-01T00:00-05:00";
const timezone = "America/Panama";

mdoStream
  .pipe((postpone.parse({ time, timezone })))
  .pipe((postpone.process({ time, timezone })))
  .pipe((postpone.sort({ time, timezone })))
  .pipe((postpone.stringify({ time, timezone })));

Overview

parse

Assigns a .section property to every Block:

  • If a Block comes after an # Inbox header, it is assigned .section = 'INBOX'.
  • If a Block comes after a # Future header, it is assigned .section = 'FUTURE'.
  • If a Block comes after a # Done header, it is assigned .section = 'DONE'.
  • All other blocks are assigned .section = 'TODO'.

parse also removes the # Inbox and # Future header blocks from the stream (they get re-added on reshuffle).

process

Process runs as two sequential processes.

First process:

  • Any complete block is converted to .section = 'DONE'.
  • Any block with .section = 'DONE' that is NOT complete, is converted to .section = 'TODO'.

Second process:

  • Any block with .section = 'INBOX' or .section = 'TODO' that is NOT actionable, is converted to .section = 'FUTURE'.
  • Any block with .section = 'FUTURE' that is actionable, is converted to .section = 'INBOX'.

To determine whether a block is actionable or not, we look at both the .start and .postpone values. If either of them is in the future, the block is considered NOT actionable.

sort

Move all blocks to their corresponding sections, adding a header on top of each section:

  • Inbox
  • To-Do
  • Future
  • Done

stringify

Removes the .section property from all blocks (to prevent MDo from rendering the section value as a tag).

0.2.13

4 years ago

0.2.12

6 years ago

0.2.11

6 years ago

0.2.10

6 years ago

0.2.9

6 years ago

0.2.8

6 years ago

0.2.7

6 years ago

0.2.6

6 years ago

0.2.5

6 years ago

0.2.3

7 years ago

0.2.1

7 years ago