mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-26 18:10:45 +08:00
4f34c8403f
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
88 lines
3.9 KiB
CoffeeScript
88 lines
3.9 KiB
CoffeeScript
# Account = require '../../src/flux/models/account'
|
|
# CategoryStore = require '../../src/flux/stores/category-store'
|
|
# RemoveThreadHelper = require '../../src/services/remove-thread-helper'
|
|
#
|
|
# ChangeFolderTask = require '../../src/flux/tasks/change-folder-task'
|
|
# ChangeLabelsTask = require '../../src/flux/tasks/change-labels-task'
|
|
#
|
|
# describe "RemoveThreadHelper", ->
|
|
# describe "removeType", ->
|
|
# it "returns null if there's no current account", ->
|
|
# spyOn(RemoveThreadHelper, "_currentAccount").andReturn null
|
|
# expect(RemoveThreadHelper.removeType()).toBe null
|
|
#
|
|
# it "returns the type if it's saved", ->
|
|
# spyOn(atom.config, "get").andReturn "trash"
|
|
# expect(RemoveThreadHelper.removeType()).toBe "trash"
|
|
#
|
|
# it "returns the archive category if it exists", ->
|
|
# spyOn(CategoryStore, "getStandardCategory").andReturn {name: "archive"}
|
|
# expect(RemoveThreadHelper.removeType()).toBe "archive"
|
|
#
|
|
# it "defaults to archive for Gmail", ->
|
|
# spyOn(RemoveThreadHelper, "_currentAccount").andReturn provider: "gmail"
|
|
# expect(RemoveThreadHelper.removeType()).toBe "archive"
|
|
#
|
|
# it "defaults to trash for everything else", ->
|
|
# spyOn(RemoveThreadHelper, "_currentAccount").andReturn provider: "eas"
|
|
# expect(RemoveThreadHelper.removeType()).toBe "trash"
|
|
#
|
|
# describe "getRemovalTask", ->
|
|
# beforeEach ->
|
|
# spyOn(CategoryStore, "byId").andReturn({id: "inbox-id", name: "inbox"})
|
|
# @mailViewFilterStub = categoryId: -> "inbox-id"
|
|
# @categories = []
|
|
#
|
|
# spyOn(CategoryStore, "getStandardCategory").andCallFake (cat) =>
|
|
# if cat in @categories
|
|
# return {id: "cat-id", name: cat}
|
|
# else return null
|
|
#
|
|
# afterEach ->
|
|
# atom.testOrganizationUnit = null
|
|
#
|
|
# it "returns null if there's no current account", ->
|
|
# spyOn(RemoveThreadHelper, "_currentAccount").andReturn null
|
|
# expect(RemoveThreadHelper.getRemovalTask()).toBe null
|
|
#
|
|
# it "creates the task when using labels and trashing", ->
|
|
# atom.testOrganizationUnit = "label"
|
|
# spyOn(RemoveThreadHelper, "_currentAccount").andReturn new Account
|
|
# provider: "eas"
|
|
# organizationUnit: "label"
|
|
# @categories = ["all", "trash"]
|
|
# t = RemoveThreadHelper.getRemovalTask([], @mailViewFilterStub)
|
|
# expect(t instanceof ChangeLabelsTask).toBe true
|
|
# expect(t.labelsToRemove[0].name).toBe "inbox"
|
|
# expect(t.labelsToAdd[0].name).toBe "trash"
|
|
#
|
|
# it "creates the task when using labels and archiving", ->
|
|
# @categories = ["all", "archive", "trash"]
|
|
# atom.testOrganizationUnit = "label"
|
|
# spyOn(RemoveThreadHelper, "_currentAccount").andReturn new Account
|
|
# provider: "gmail"
|
|
# organizationUnit: "label"
|
|
# t = RemoveThreadHelper.getRemovalTask([], @mailViewFilterStub)
|
|
# expect(t instanceof ChangeLabelsTask).toBe true
|
|
# expect(t.labelsToRemove[0].name).toBe "inbox"
|
|
# expect(t.labelsToAdd[0].name).toBe "all"
|
|
#
|
|
# it "creates the task when using folders and trashing", ->
|
|
# @categories = ["all", "trash"]
|
|
# atom.testOrganizationUnit = "folder"
|
|
# spyOn(RemoveThreadHelper, "_currentAccount").andReturn new Account
|
|
# provider: "eas"
|
|
# organizationUnit: "folder"
|
|
# t = RemoveThreadHelper.getRemovalTask([], @mailViewFilterStub)
|
|
# expect(t instanceof ChangeFolderTask).toBe true
|
|
# expect(t.folder.name).toBe "trash"
|
|
#
|
|
# it "creates the task when using folders and archiving", ->
|
|
# @categories = ["all", "archive", "trash"]
|
|
# atom.testOrganizationUnit = "folder"
|
|
# spyOn(RemoveThreadHelper, "_currentAccount").andReturn new Account
|
|
# provider: "gmail"
|
|
# organizationUnit: "folder"
|
|
# t = RemoveThreadHelper.getRemovalTask([], @mailViewFilterStub)
|
|
# expect(t instanceof ChangeFolderTask).toBe true
|
|
# expect(t.folder.name).toBe "archive"
|