2015-06-12 09:00:40 +08:00
|
|
|
MultiselectListInteractionHandler = require '../../src/components/multiselect-list-interaction-handler'
|
|
|
|
WorkspaceStore = require '../../src/flux/stores/workspace-store'
|
|
|
|
FocusedContentStore = require '../../src/flux/stores/focused-content-store'
|
2016-05-04 07:42:28 +08:00
|
|
|
Thread = require('../../src/flux/models/thread').default
|
2015-06-12 09:00:40 +08:00
|
|
|
Actions = require '../../src/flux/actions'
|
|
|
|
_ = require 'underscore'
|
|
|
|
|
|
|
|
describe "MultiselectListInteractionHandler", ->
|
|
|
|
beforeEach ->
|
|
|
|
@item = new Thread(id:'123')
|
|
|
|
@itemFocus = new Thread({id: 'focus'})
|
|
|
|
@itemKeyboardFocus = new Thread({id: 'keyboard-focus'})
|
|
|
|
@itemAfterFocus = new Thread(id:'after-focus')
|
|
|
|
@itemAfterKeyboardFocus = new Thread(id:'after-keyboard-focus')
|
|
|
|
|
|
|
|
data = [@item, @itemFocus, @itemAfterFocus, @itemKeyboardFocus, @itemAfterKeyboardFocus]
|
|
|
|
|
2016-01-22 09:07:32 +08:00
|
|
|
@onFocusItem = jasmine.createSpy('onFocusItem')
|
|
|
|
@onSetCursorPosition = jasmine.createSpy('onSetCursorPosition')
|
2016-01-15 04:26:54 +08:00
|
|
|
@dataSource =
|
2015-06-12 09:00:40 +08:00
|
|
|
selection:
|
|
|
|
toggle: jasmine.createSpy('toggle')
|
|
|
|
expandTo: jasmine.createSpy('expandTo')
|
|
|
|
walk: jasmine.createSpy('walk')
|
|
|
|
get: (idx) ->
|
|
|
|
data[idx]
|
|
|
|
getById: (id) ->
|
|
|
|
_.find data, (item) -> item.id is id
|
|
|
|
indexOfId: (id) ->
|
|
|
|
_.findIndex data, (item) -> item.id is id
|
|
|
|
count: -> data.length
|
|
|
|
|
2016-01-22 09:07:32 +08:00
|
|
|
@props =
|
|
|
|
dataSource: @dataSource
|
|
|
|
keyboardCursorId: 'keyboard-focus'
|
|
|
|
focusedId: 'focus'
|
|
|
|
onFocusItem: @onFocusItem
|
|
|
|
onSetCursorPosition: @onSetCursorPosition
|
|
|
|
|
2015-06-12 09:00:40 +08:00
|
|
|
@collection = 'threads'
|
|
|
|
@isRootSheet = true
|
2016-01-22 09:07:32 +08:00
|
|
|
@handler = new MultiselectListInteractionHandler(@props)
|
2015-06-12 09:00:40 +08:00
|
|
|
|
|
|
|
spyOn(WorkspaceStore, 'topSheet').andCallFake => {root: @isRootSheet}
|
|
|
|
|
|
|
|
it "should never show focus", ->
|
|
|
|
expect(@handler.shouldShowFocus()).toEqual(false)
|
|
|
|
|
|
|
|
it "should always show the keyboard cursor", ->
|
|
|
|
expect(@handler.shouldShowKeyboardCursor()).toEqual(true)
|
|
|
|
|
2016-01-22 09:07:32 +08:00
|
|
|
it "should always show checkmarks", ->
|
|
|
|
expect(@handler.shouldShowCheckmarks()).toEqual(true)
|
|
|
|
|
2015-06-12 09:00:40 +08:00
|
|
|
describe "onClick", ->
|
|
|
|
it "should focus list items", ->
|
|
|
|
@handler.onClick(@item)
|
2016-01-22 09:07:32 +08:00
|
|
|
expect(@onFocusItem).toHaveBeenCalledWith(@item)
|
2015-06-12 09:00:40 +08:00
|
|
|
|
|
|
|
describe "onMetaClick", ->
|
|
|
|
it "shoud toggle selection", ->
|
|
|
|
@handler.onMetaClick(@item)
|
2016-01-15 04:26:54 +08:00
|
|
|
expect(@dataSource.selection.toggle).toHaveBeenCalledWith(@item)
|
2015-06-12 09:00:40 +08:00
|
|
|
|
|
|
|
it "should focus the keyboard on the clicked item", ->
|
|
|
|
@handler.onMetaClick(@item)
|
2016-01-22 09:07:32 +08:00
|
|
|
expect(@onSetCursorPosition).toHaveBeenCalledWith(@item)
|
2015-06-12 09:00:40 +08:00
|
|
|
|
|
|
|
describe "onShiftClick", ->
|
|
|
|
it "should expand selection", ->
|
|
|
|
@handler.onShiftClick(@item)
|
2016-01-15 04:26:54 +08:00
|
|
|
expect(@dataSource.selection.expandTo).toHaveBeenCalledWith(@item)
|
2015-06-12 09:00:40 +08:00
|
|
|
|
|
|
|
it "should focus the keyboard on the clicked item", ->
|
|
|
|
@handler.onShiftClick(@item)
|
2016-01-22 09:07:32 +08:00
|
|
|
expect(@onSetCursorPosition).toHaveBeenCalledWith(@item)
|
2015-06-12 09:00:40 +08:00
|
|
|
|
|
|
|
describe "onEnter", ->
|
|
|
|
it "should focus the item with the current keyboard selection", ->
|
|
|
|
@handler.onEnter()
|
2016-01-22 09:07:32 +08:00
|
|
|
expect(@onFocusItem).toHaveBeenCalledWith(@itemKeyboardFocus)
|
2015-06-12 09:00:40 +08:00
|
|
|
|
|
|
|
describe "onSelect (x key on keyboard)", ->
|
|
|
|
describe "on the root view", ->
|
|
|
|
it "should toggle the selection of the keyboard item", ->
|
|
|
|
@isRootSheet = true
|
|
|
|
@handler.onSelect()
|
2016-01-15 04:26:54 +08:00
|
|
|
expect(@dataSource.selection.toggle).toHaveBeenCalledWith(@itemKeyboardFocus)
|
2015-06-12 09:00:40 +08:00
|
|
|
|
|
|
|
describe "on the thread view", ->
|
|
|
|
it "should toggle the selection of the focused item", ->
|
|
|
|
@isRootSheet = false
|
|
|
|
@handler.onSelect()
|
2016-01-15 04:26:54 +08:00
|
|
|
expect(@dataSource.selection.toggle).toHaveBeenCalledWith(@itemFocus)
|
2015-06-12 09:00:40 +08:00
|
|
|
|
|
|
|
describe "onShift", ->
|
|
|
|
describe "on the root view", ->
|
|
|
|
beforeEach ->
|
|
|
|
@isRootSheet = true
|
|
|
|
|
|
|
|
it "should shift the keyboard item", ->
|
|
|
|
@handler.onShift(1, {})
|
2016-01-22 09:07:32 +08:00
|
|
|
expect(@onSetCursorPosition).toHaveBeenCalledWith(@itemAfterKeyboardFocus)
|
2015-06-12 09:00:40 +08:00
|
|
|
|
|
|
|
it "should walk selection if the select option is passed", ->
|
|
|
|
@handler.onShift(1, select: true)
|
2016-01-15 04:26:54 +08:00
|
|
|
expect(@dataSource.selection.walk).toHaveBeenCalledWith({current: @itemKeyboardFocus, next: @itemAfterKeyboardFocus})
|
2015-06-12 09:00:40 +08:00
|
|
|
|
|
|
|
describe "on the thread view", ->
|
|
|
|
beforeEach ->
|
|
|
|
@isRootSheet = false
|
|
|
|
|
|
|
|
it "should shift the focused item", ->
|
|
|
|
@handler.onShift(1, {})
|
2016-01-22 09:07:32 +08:00
|
|
|
expect(@onFocusItem).toHaveBeenCalledWith(@itemAfterFocus)
|