summaryrefslogtreecommitdiff
path: root/web-ui/test/spec/mail_view/ui/draft_box.spec.js
blob: 921767ba5b1568228ff5fb8da7cd3fea4b3f6279 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
describeComponent('mail_view/ui/draft_box', function () {
  'use strict';

  var mail;

  beforeEach(function () {
    Pixelated.mockBloodhound();
    mail = Pixelated.testData().parsedMail.simpleTextPlain;
    spyOn($, 'getJSON').and.returnValue($.Deferred());
  });

  describe('when initializing', function () {
    it('fetches the email to draft', function () {
      var mailWantEvent = spyOnEvent(document, Pixelated.events.mail.want);

      this.setupComponent({mailIdent: '1'});

      expect(mailWantEvent).toHaveBeenTriggeredOnAndWith(document, {
        mail: '1', caller: this.component
      });
    });
  });

  describe('after initialize', function () {
    it('renders the compose box when mail is received', function () {
      this.setupComponent({mailIdent: '1'});
      var templates = require('views/templates');

      spyOn(this.component, 'render');

      this.component.trigger(this.component, Pixelated.events.mail.here, { mail: mail});

      expect(this.component.render).toHaveBeenCalledWith(templates.compose.box, {
        recipients: { to: mail.header.to, cc: mail.header.cc, bcc: mail.header.bcc },
        subject: mail.header.subject, attachments: [],
        body: mail.textPlainBody
      });
    });

  });

  it('shows no message selected pane when draft is sent', function() {
    var openNoMessageSelectedEvent = spyOnEvent(document, Pixelated.events.dispatchers.rightPane.openNoMessageSelected);

    this.setupComponent({mailIdent: mail.ident});
    this.component.trigger(this.component, Pixelated.events.mail.here, { mail: mail});

    this.component.trigger(document, Pixelated.events.mail.sent);

    expect(openNoMessageSelectedEvent).toHaveBeenTriggeredOn(document);
  });

  it('should call the enableFloatlabel method when events.mail.here is trigged', function() {
    this.setupComponent({mailIdent: mail.ident});
    spyOn(this.component, 'enableFloatlabel');

    this.component.trigger(this.component, Pixelated.events.mail.here, { mail: mail });

    expect(this.component.enableFloatlabel).toHaveBeenCalledWith('input.floatlabel');
    expect(this.component.enableFloatlabel).toHaveBeenCalledWith('textarea.floatlabel');
  });

});