summaryrefslogtreecommitdiff
path: root/app/assets/javascripts/droplab/droplab_ajax_filter.js
blob: 0d6a7892bdc50b3d495abe934634579f1af8a83d (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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
/* eslint-disable */
(function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g=(g.droplab||(g.droplab = {}));g=(g.ajax||(g.ajax = {}));g=(g.datasource||(g.datasource = {}));g.js = f()}})(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){
/* global droplab */

require('../window')(function(w){
  w.droplabAjaxFilter = {
    init: function(hook) {
      this.destroyed = false;
      this.hook = hook;
      this.notLoading();

      this.debounceTriggerWrapper = this.debounceTrigger.bind(this);
      this.hook.trigger.addEventListener('keydown.dl', this.debounceTriggerWrapper);
      this.hook.trigger.addEventListener('focus', this.debounceTriggerWrapper);
      this.trigger();
    },

    notLoading: function notLoading() {
      this.loading = false;
    },

    debounceTrigger: function debounceTrigger(e) {
      var NON_CHARACTER_KEYS = [16, 17, 18, 20, 37, 38, 39, 40, 91, 93];
      var invalidKeyPressed = NON_CHARACTER_KEYS.indexOf(e.detail.which || e.detail.keyCode) > -1;
      if (invalidKeyPressed || this.loading) {
        return;
      }

      if (this.timeout) {
        clearTimeout(this.timeout);
      }

      this.timeout = setTimeout(this.trigger.bind(this), 200);
    },

    trigger: function trigger() {
      var config = this.hook.config.droplabAjaxFilter;
      var searchValue = this.trigger.value;

      if (!config || !config.endpoint || !config.searchKey) {
        return;
      }

      if (config.searchValueFunction) {
        searchValue = config.searchValueFunction();
      }

      if (searchValue === config.searchKey) {
        return this.list.show();
      }

      this.loading = true;

      this.hook.list.setData([]);

      var params = config.params || {};
      params[config.searchKey] = searchValue;
      var self = this;
      this._loadUrlData(config.endpoint + this.buildParams(params)).then(function(data) {
        if (!self.destroyed) {
          self.hook.list.setData.call(self.hook.list, data[0]);
        }
        self.notLoading();
      });
    },

    _loadUrlData: function _loadUrlData(url) {
      return new Promise(function(resolve, reject) {
        var xhr = new XMLHttpRequest;
        xhr.open('GET', url, true);
        xhr.onreadystatechange = function () {
          if(xhr.readyState === XMLHttpRequest.DONE) {
            if (xhr.status === 200) {
              var data = JSON.parse(xhr.responseText);
              return resolve([data, xhr]);
            } else {
              return reject([xhr.responseText, xhr.status]);
            }
          }
        };
        xhr.send();
      });
    },

    buildParams: function(params) {
      if (!params) return '';
      var paramsArray = Object.keys(params).map(function(param) {
        return param + '=' + (params[param] || '');
      });
      return '?' + paramsArray.join('&');
    },

    destroy: function destroy() {
      if (this.timeout) {
        clearTimeout(this.timeout);
      }

      this.destroyed = true;

      this.hook.trigger.removeEventListener('keydown.dl', this.debounceTriggerWrapper);
      this.hook.trigger.removeEventListener('focus', this.debounceTriggerWrapper);
    }
  };
});
},{"../window":2}],2:[function(require,module,exports){
module.exports = function(callback) {
  return (function() {
    callback(this);
  }).call(null);
};

},{}]},{},[1])(1)
});