boards_store.js.es6 3.7 KB
Newer Older
P
Phil Hughes 已提交
1 2
((w) => {
  w.BoardsStore = {
3 4 5 6
    state: {},
    create: function () {
      this.state.lists = [];
      this.state.filters = {
P
Phil Hughes 已提交
7 8 9 10
        author_id: gl.utils.getParameterValues('author_id')[0],
        assignee_id: gl.utils.getParameterValues('assignee_id')[0],
        milestone_title: gl.utils.getParameterValues('milestone_title')[0],
        label_name: gl.utils.getParameterValues('label_name[]')
11 12
      };
    },
13
    new: function (board, persist = true) {
14 15 16 17
      const doneList = this.getDoneList(),
            list = new List(board);
      this.state.lists.push(list);

18 19
      if (persist) {
        list.save();
20
        this.removeBlankState();
P
Phil Hughes 已提交
21 22
      }

23 24
      return list;
    },
25 26 27 28
    updateNewListDropdown: function () {
      const data = $('.js-new-board-list').data('glDropdown').renderedData;
      $('.js-new-board-list').data('glDropdown').renderData(data);
    },
29
    shouldAddBlankState: function () {
30 31 32 33 34 35 36 37 38
      // Decide whether to add the blank state
      let addBlankState = true;

      this.state.lists.forEach(function (list) {
        if (list.type !== 'backlog' && list.type !== 'done') {
          addBlankState = false;
          return;
        }
      });
39 40 41
      return addBlankState;
    },
    addBlankState: function () {
42
      const addBlankState = this.shouldAddBlankState();
43

44
      if (this.welcomeIsHidden()) return;
45 46 47 48 49 50 51

      if (addBlankState) {
        this.new({
          id: 'blank',
          list_type: 'blank',
          title: 'Welcome to your Issue Board!',
          position: 0
52
        }, false);
53 54 55
      }
    },
    removeBlankState: function () {
56 57
      if (this.welcomeIsHidden()) return;

58
      this.removeList('blank');
59 60 61 62

      $.cookie('issue_board_welcome_hidden', 'true', {
        expires: 365 * 10
      });
P
Phil Hughes 已提交
63
    },
64 65 66
    welcomeIsHidden: function () {
      return $.cookie('issue_board_welcome_hidden') === 'true';
    },
P
Phil Hughes 已提交
67
    getDoneList: function () {
68
      return this.findList('type', 'done');
P
Phil Hughes 已提交
69
    },
P
Phil Hughes 已提交
70
    removeList: function (id) {
71
      const list = this.findList('id', id);
72 73 74

      if (!list) return;

75
      list.destroy();
76

P
Phil Hughes 已提交
77 78
      this.state.lists = _.reject(this.state.lists, (list) => {
        return list.id === id;
P
Phil Hughes 已提交
79
      });
80 81

      this.updateNewListDropdown();
P
Phil Hughes 已提交
82
    },
P
Phil Hughes 已提交
83
    moveList: function (oldIndex, newIndex) {
84
      const listFrom = this.findList('position', oldIndex),
P
Phil Hughes 已提交
85
            listTo = this.findList('position', newIndex);
P
Phil Hughes 已提交
86

87
      listFrom.position = newIndex;
88 89 90
      if (newIndex === listTo.position) {
        listTo.position = oldIndex;
      } else if (newIndex > listTo.position) {
91
        listTo.position--;
P
Phil Hughes 已提交
92
      } else {
93
        listTo.position++;
P
Phil Hughes 已提交
94
      }
95 96

      listFrom.update();
P
Phil Hughes 已提交
97
    },
98 99 100 101
    moveCardToList: function (listFromId, listToId, issueId) {
      const listFrom = this.findList('id', listFromId),
            listTo = this.findList('id', listToId),
            issueTo = listTo.findIssue(issueId);
P
Phil Hughes 已提交
102
      let issue = listFrom.findIssue(issueId);
P
Phil Hughes 已提交
103
      const issueLists = issue.getLists(),
104
            listLabels = issueLists.map(function (issue) {
P
Phil Hughes 已提交
105 106
              return issue.label;
            });
107

P
Phil Hughes 已提交
108
      // Add to new lists issues if it doesn't already exist
109
      if (!issueTo) {
110
        listTo.addIssue(issue, listFrom);
P
Phil Hughes 已提交
111 112
      }

113
      if (listTo.type === 'done' && listFrom.type !== 'backlog') {
P
Phil Hughes 已提交
114 115
        issueLists.forEach((list) => {
          list.removeIssue(issue);
P
Phil Hughes 已提交
116
        });
117
        issue.removeLabels(listLabels);
118 119
      } else {
        listFrom.removeIssue(issue);
P
Phil Hughes 已提交
120 121
      }
    },
122 123 124
    findList: function (key, val) {
      return _.find(this.state.lists, (list) => {
        return list[key] === val;
P
Phil Hughes 已提交
125
      });
P
Phil Hughes 已提交
126 127 128
    },
    updateFiltersUrl: function () {
      history.pushState(null, null, `?${$.param(this.state.filters)}`);
P
Phil Hughes 已提交
129 130 131
    }
  };
}(window));