| 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
 | describeComponent('dispatchers/left_pane_dispatcher', function () {
  'use strict';
  describe('initialize', function () {
    it('asks for tags', function () {
      var tagWantEvent = spyOnEvent(document, Pixelated.events.tags.want);
      this.setupComponent();
      expect(tagWantEvent).toHaveBeenTriggeredOn(document);
      expect(tagWantEvent.mostRecentCall.data.caller[0]).toEqual(this.$node[0]);
    });
  });
  describe('after initialization', function () {
    beforeEach(function () {
      this.setupComponent();
    });
    it('pushes the url state when a tag is selected but not for the first tag', function () {
      var pushStateEvent = spyOnEvent(document, Pixelated.events.router.pushState);
      $(document).trigger(Pixelated.events.ui.tag.selected, { tag: 'Drafts'});
      $(document).trigger(Pixelated.events.ui.tag.selected, { tag: 'inbox'});
      expect(pushStateEvent).toHaveBeenTriggeredOn(document, { tag: 'inbox'});
    });
    it('doesnt fetch mails by tag when skipMailListRefresh is sent on tag.selected', function () {
      var fetchByTagEvent = spyOnEvent(document, Pixelated.events.ui.mails.fetchByTag);
      $(document).trigger(Pixelated.events.ui.tag.selected, { tag: 'Drafts', skipMailListRefresh: true});
      expect(fetchByTagEvent).not.toHaveBeenTriggeredOn(document, { tag: 'Drafts'});
    });
    it('asks for more tags when refreshTagList is fired', function () {
      var tagWantEvent = spyOnEvent(document, Pixelated.events.tags.want);
      $(document).trigger(Pixelated.events.dispatchers.tags.refreshTagList, {});
      expect(tagWantEvent).toHaveBeenTriggeredOn(document);
    });
  });
});
 |