cycle-analytics.js.es6 2.2 KB
Newer Older
F
Fatih Acet 已提交
1 2
((global) => {

F
Fatih Acet 已提交
3 4
  const COOKIE_NAME = 'cycle_analytics_help_dismissed';

F
Fatih Acet 已提交
5 6
  gl.CycleAnalytics = class CycleAnalytics {
    constructor() {
F
Fatih Acet 已提交
7 8 9
      const that = this;

      this.isHelpDismissed = $.cookie(COOKIE_NAME);
F
Fatih Acet 已提交
10 11 12 13
      this.vue = new Vue({
        el: '#cycle-analytics',
        name: 'CycleAnalytics',
        created: this.fetchData(),
F
Fatih Acet 已提交
14 15 16 17 18 19
        data: this.decorateData({ isLoading: true }),
        methods: {
          dismissLanding() {
            that.dismissLanding();
          }
        }
F
Fatih Acet 已提交
20 21 22
      });
    }

F
Fatih Acet 已提交
23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41
    fetchData(options) {
      options = options || { startDate: 30 };

      $.ajax({
        url: $('#cycle-analytics').data('request-path'),
        method: 'GET',
        dataType: 'json',
        contentType: 'application/json',
        data: { start_date: options.startDate }
      }).done((data) => {
        this.vue.$data = this.decorateData(data);
        this.initDropdown();
      })
      .error((data) => {
        this.handleError(data);
      })
      .always(() => {
        this.vue.isLoading = false;
      })
F
Fatih Acet 已提交
42 43
    }

F
Fatih Acet 已提交
44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
    decorateData(data) {
      data.summary = data.summary || [];
      data.stats = data.stats || [];
      data.isHelpDismissed = this.isHelpDismissed;
      data.isLoading = data.isLoading || false;

      data.summary.forEach((item) => {
        item.value = item.value || '-';
      });

      data.stats.forEach((item) => {
        item.value = item.value || '-';
      })

      return data;
F
Fatih Acet 已提交
59 60 61
    }

    handleError(data) {
F
Fatih Acet 已提交
62 63 64 65 66 67 68 69 70 71 72
      this.vue.$data = {
        hasError: true,
        isHelpDismissed: this.isHelpDismissed
      };

      new Flash('There was an error while fetching cycle analytics data.', 'alert');
    }

    dismissLanding() {
      this.vue.isHelpDismissed = true;
      $.cookie(COOKIE_NAME, true);
F
Fatih Acet 已提交
73 74 75 76 77 78
    }

    initDropdown() {
      const $dropdown = $('.js-ca-dropdown');
      const $label = $dropdown.find('.dropdown-label');

F
Fatih Acet 已提交
79
      $dropdown.find('li a').off('click').on('click', (e) => {
F
Fatih Acet 已提交
80 81
        e.preventDefault();
        const $target = $(e.currentTarget);
F
Fatih Acet 已提交
82
        const value = $target.data('value');
F
Fatih Acet 已提交
83

F
Fatih Acet 已提交
84
        $label.text($target.text().trim());
F
Fatih Acet 已提交
85
        this.vue.isLoading = true;
F
Fatih Acet 已提交
86
        this.fetchData({ startDate: value });
F
Fatih Acet 已提交
87 88
      })
    }
F
Fatih Acet 已提交
89

F
Fatih Acet 已提交
90 91 92
  }

})(window.gl || (window.gl = {}));