e09d3e3e75
Summary: This diff centralizes logic for creating common tasks for things like moving to trash, archive, etc. TaskFactory exposes a set of convenience methods and hides the whole "and also remove the current label" business from the user. This diff also formally separates the concept of "moving to trash" and "archiving" so that "remove" isn't used in an unclear way. I also refactored where selection is managed. Previously you'd fire some action like archiveSelection and it'd clear the selection, but if you selected some items and used another method to archive a few, they were still selected. The selection is now bound to the ModelView as intended, so if items are removed from the modelView, they are removed from it's attached selection. This means that it shouldn't /technically/ be possible to have selected items which are not in view. I haven't refactored the tests yet. They are likely broken... Fix next/prev logic Test Plan: Run tests Reviewers: evan Reviewed By: evan Differential Revision: https://phab.nylas.com/D2157 |
||
---|---|---|
.. | ||
docs | ||
lib | ||
stylesheets | ||
filters-screencap.png | ||
package.json | ||
README.md |
Filters package for N1
Install this plugin:
-
Download and run N1
-
From the menu, select
Developer > Install a Package Manually...
The dialog will default to this examples directory. Just choose the package to install it!When you install packages, they're moved to
~/.nylas/packages
, and N1 runsapm install
on the command line to fetch dependencies listed in the package'spackage.json
Who?
The source is annotated for people who are familiar with React, but not familiar with APIs from either Atom or N1.
As such, we will not annotate any code that is specific for React, but we'll annotate code for everything else.
Why?
There's no native way to automate mail filtering in N1. This package provides a lightweight interface and implementation of mail filters and mail rules to handle repetitive mail tasks for you.
How?
This package works in two steps: managing the filters and applying the filters.
Managing the filters boils down to simple CRUD operations.
Applying the filters boils down to checking each incoming message, checking to see if the message matches any of the requirements for the filters, and, if there's a match, applying the actions on the thread.
Currently, this package supports only simple filter operations. The only criteria it supports are:
- exact match sender email
- exact match recipient email
- substring match with subject & body
- substring absense with subject & body
The only actions this package supports currently are:
- Marking as read
- Applying labels or folders
- Starring
- Deleting
- Archiving (skipping the inbox)
Roadmap
Right now, both managing the filters and applying the filters is done client-side.
The immediate objective is to implement an amazing user experience for managing mail filters.
The long-term objective is to remove the client-side implementation of applying filters and move this work to the backend.