summaryrefslogtreecommitdiff
path: root/app/assets/javascripts/pages/search/show/refresh_counts.js
diff options
context:
space:
mode:
authorMichael Kozono <mkozono@gmail.com>2019-08-12 22:02:28 +0000
committerMichael Kozono <mkozono@gmail.com>2019-08-12 22:02:28 +0000
commit4254f5dc0ea4c226690d0d9abd20d1c9822fefcb (patch)
tree3cd94454d455b99ae3dd192633fc0942441c46d6 /app/assets/javascripts/pages/search/show/refresh_counts.js
parent4ce6d2b9db680b7c8563ee65fe25ee4d38a329e9 (diff)
parent2f8709fb53137c2f53409f2400cd85083b06d6f6 (diff)
downloadgitlab-ce-4254f5dc0ea4c226690d0d9abd20d1c9822fefcb.tar.gz
Merge branch 'ce-12547-load-search-counts-async' into 'master'
Load search result counts asynchronously (CE) See merge request gitlab-org/gitlab-ce!31663
Diffstat (limited to 'app/assets/javascripts/pages/search/show/refresh_counts.js')
-rw-r--r--app/assets/javascripts/pages/search/show/refresh_counts.js24
1 files changed, 24 insertions, 0 deletions
diff --git a/app/assets/javascripts/pages/search/show/refresh_counts.js b/app/assets/javascripts/pages/search/show/refresh_counts.js
new file mode 100644
index 00000000000..fa75ee6075d
--- /dev/null
+++ b/app/assets/javascripts/pages/search/show/refresh_counts.js
@@ -0,0 +1,24 @@
+import axios from '~/lib/utils/axios_utils';
+
+function showCount(el, count) {
+ el.textContent = count;
+ el.classList.remove('hidden');
+}
+
+function refreshCount(el) {
+ const { url } = el.dataset;
+
+ return axios
+ .get(url)
+ .then(({ data }) => showCount(el, data.count))
+ .catch(e => {
+ // eslint-disable-next-line no-console
+ console.error(`Failed to fetch search count from '${url}'.`, e);
+ });
+}
+
+export default function refreshCounts() {
+ const elements = Array.from(document.querySelectorAll('.js-search-count'));
+
+ return Promise.all(elements.map(refreshCount));
+}