2016-03-22 02:32:48 +08:00
|
|
|
React = require 'react'
|
2016-03-29 16:41:24 +08:00
|
|
|
ReactDOM = require 'react-dom'
|
2016-03-22 02:32:48 +08:00
|
|
|
ComposerHeaderActions = require '../lib/composer-header-actions'
|
|
|
|
Fields = require '../lib/fields'
|
2016-03-29 16:41:24 +08:00
|
|
|
ReactTestUtils = require('react-addons-test-utils')
|
2016-03-22 02:32:48 +08:00
|
|
|
{Actions} = require 'nylas-exports'
|
|
|
|
|
|
|
|
describe "ComposerHeaderActions", ->
|
|
|
|
makeField = (props = {}) ->
|
|
|
|
@onChangeParticipants = jasmine.createSpy("onChangeParticipants")
|
|
|
|
@onAdjustEnabledFields = jasmine.createSpy("onAdjustEnabledFields")
|
|
|
|
props.onChangeParticipants = @onChangeParticipants
|
|
|
|
props.onAdjustEnabledFields = @onAdjustEnabledFields
|
|
|
|
props.enabledFields ?= []
|
|
|
|
props.draftClientId = 'a'
|
|
|
|
@component = ReactTestUtils.renderIntoDocument(
|
|
|
|
<ComposerHeaderActions {...props} />
|
|
|
|
)
|
|
|
|
|
|
|
|
it "renders all 'show' fields when the focused field is one of the participant fields", ->
|
|
|
|
makeField.call(@, {focusedField: Fields.To})
|
|
|
|
showCc = ReactTestUtils.findRenderedDOMComponentWithClass(@component, "show-cc")
|
|
|
|
showBcc = ReactTestUtils.findRenderedDOMComponentWithClass(@component, "show-bcc")
|
|
|
|
showSubject = ReactTestUtils.findRenderedDOMComponentWithClass(@component, "show-subject")
|
|
|
|
expect(showCc).toBeDefined()
|
|
|
|
expect(showBcc).toBeDefined()
|
|
|
|
expect(showSubject).toBeDefined()
|
|
|
|
|
|
|
|
it "does not render the 'show' fields when the focused field is outside the participant fields", ->
|
|
|
|
makeField.call(@, {focusedField: Fields.Subject})
|
|
|
|
showCc = ReactTestUtils.scryRenderedDOMComponentsWithClass(@component, "show-cc")
|
|
|
|
showBcc = ReactTestUtils.scryRenderedDOMComponentsWithClass(@component, "show-bcc")
|
|
|
|
showSubject = ReactTestUtils.scryRenderedDOMComponentsWithClass(@component, "show-subject")
|
|
|
|
expect(showCc.length).toBe 0
|
|
|
|
expect(showBcc.length).toBe 0
|
|
|
|
expect(showSubject.length).toBe 0
|
|
|
|
|
|
|
|
it "hides show cc if it's enabled", ->
|
|
|
|
makeField.call(@, {focusedField: Fields.To, enabledFields: [Fields.Cc]})
|
|
|
|
els = ReactTestUtils.scryRenderedDOMComponentsWithClass(@component, "show-cc")
|
|
|
|
expect(els.length).toBe 0
|
|
|
|
|
|
|
|
it "hides show bcc if it's enabled", ->
|
|
|
|
makeField.call(@, {focusedField: Fields.To, enabledFields: [Fields.Bcc]})
|
|
|
|
els = ReactTestUtils.scryRenderedDOMComponentsWithClass(@component, "show-bcc")
|
|
|
|
expect(els.length).toBe 0
|
|
|
|
|
|
|
|
it "hides show subject if it's enabled", ->
|
|
|
|
makeField.call(@, {focusedField: Fields.To, enabledFields: [Fields.Subject]})
|
|
|
|
els = ReactTestUtils.scryRenderedDOMComponentsWithClass(@component, "show-subject")
|
|
|
|
expect(els.length).toBe 0
|
|
|
|
|
|
|
|
it "renders 'popout composer' in the inline mode", ->
|
|
|
|
makeField.call(@, {focusedField: Fields.To})
|
|
|
|
els = ReactTestUtils.scryRenderedDOMComponentsWithClass(@component, "show-popout")
|
|
|
|
expect(els.length).toBe 1
|
|
|
|
|
|
|
|
it "doesn't render 'popout composer' if in a composer window", ->
|
|
|
|
spyOn(NylasEnv, 'isComposerWindow').andReturn(true)
|
|
|
|
makeField.call(@, {focusedField: Fields.To})
|
|
|
|
els = ReactTestUtils.scryRenderedDOMComponentsWithClass(@component, "show-popout")
|
|
|
|
expect(els.length).toBe 0
|
|
|
|
|
|
|
|
it "pops out the composer when clicked", ->
|
|
|
|
spyOn(Actions, "composePopoutDraft")
|
|
|
|
makeField.call(@, {focusedField: Fields.To})
|
|
|
|
el = ReactTestUtils.findRenderedDOMComponentWithClass(@component, "show-popout")
|
2016-03-29 16:41:24 +08:00
|
|
|
ReactTestUtils.Simulate.click(ReactDOM.findDOMNode(el))
|
2016-03-22 02:32:48 +08:00
|
|
|
expect(Actions.composePopoutDraft).toHaveBeenCalled()
|
|
|
|
|
|
|
|
it "shows and focuses cc when clicked", ->
|
|
|
|
makeField.call(@, {focusedField: Fields.To})
|
|
|
|
el = ReactTestUtils.findRenderedDOMComponentWithClass(@component, "show-cc")
|
2016-03-29 16:41:24 +08:00
|
|
|
ReactTestUtils.Simulate.click(ReactDOM.findDOMNode(el))
|
2016-03-22 02:32:48 +08:00
|
|
|
expect(@onAdjustEnabledFields).toHaveBeenCalledWith show: [Fields.Cc]
|
|
|
|
|
|
|
|
it "shows and focuses bcc when clicked", ->
|
|
|
|
makeField.call(@, {focusedField: Fields.To})
|
|
|
|
el = ReactTestUtils.findRenderedDOMComponentWithClass(@component, "show-bcc")
|
2016-03-29 16:41:24 +08:00
|
|
|
ReactTestUtils.Simulate.click(ReactDOM.findDOMNode(el))
|
2016-03-22 02:32:48 +08:00
|
|
|
expect(@onAdjustEnabledFields).toHaveBeenCalledWith show: [Fields.Bcc]
|
|
|
|
|
|
|
|
it "shows subject when clicked", ->
|
|
|
|
makeField.call(@, {focusedField: Fields.To})
|
|
|
|
el = ReactTestUtils.findRenderedDOMComponentWithClass(@component, "show-subject")
|
2016-03-29 16:41:24 +08:00
|
|
|
ReactTestUtils.Simulate.click(ReactDOM.findDOMNode(el))
|
2016-03-22 02:32:48 +08:00
|
|
|
expect(@onAdjustEnabledFields).toHaveBeenCalledWith show: [Fields.Subject]
|