diff options
author | silverwind <me@silverwind.io> | 2020-02-23 22:34:28 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-02-23 21:34:28 +0000 |
commit | 062f35109df236a06a00d403d006b90760f9cfac (patch) | |
tree | 908b1dc1fe14a55a7c72bcf6a49ac586fc677602 /web_src/js/features | |
parent | 09dbd85a3a9043de9f8ea06a0a7ee7fd45711344 (diff) | |
download | gitea-062f35109df236a06a00d403d006b90760f9cfac.tar.gz gitea-062f35109df236a06a00d403d006b90760f9cfac.zip |
move vue and vue-calendar-heatmap to webpack (#10188)
- unvendor vue and vue-calendar-heatmap
- remove unused moment.js leftover from previous heatmap version
- ensure webpack loads the full version of vue
- fix vue devmode warning related to 'searchLimit' type
I wanted to name the chunk heatmap.js but adblockers don't like that
filename [1].
[1] https://github.com/easylist/easylist/blob/3899d5dff33216c0bc64f09ff15d376f346d3e33/easyprivacy/easyprivacy_general.txt#L2095
Diffstat (limited to 'web_src/js/features')
-rw-r--r-- | web_src/js/features/userHeatmap.js | 98 |
1 files changed, 98 insertions, 0 deletions
diff --git a/web_src/js/features/userHeatmap.js b/web_src/js/features/userHeatmap.js new file mode 100644 index 0000000000..4862bc436c --- /dev/null +++ b/web_src/js/features/userHeatmap.js @@ -0,0 +1,98 @@ +import Vue from 'vue'; + +const { AppSubUrl, heatmapUser } = window.config; + +export default async function initHeatmap() { + const el = document.getElementById('user-heatmap'); + if (!el) return; + + const { CalendarHeatmap } = await import(/* webpackChunkName: "userheatmap" */'vue-calendar-heatmap'); + Vue.component('calendarHeatmap', CalendarHeatmap); + + const vueDelimeters = ['${', '}']; + + Vue.component('activity-heatmap', { + delimiters: vueDelimeters, + + props: { + user: { + type: String, + required: true + }, + suburl: { + type: String, + required: true + }, + locale: { + type: Object, + required: true + } + }, + + data() { + return { + isLoading: true, + colorRange: [], + endDate: null, + values: [], + totalContributions: 0, + }; + }, + + mounted() { + this.colorRange = [ + this.getColor(0), + this.getColor(1), + this.getColor(2), + this.getColor(3), + this.getColor(4), + this.getColor(5) + ]; + this.endDate = new Date(); + this.loadHeatmap(this.user); + }, + + methods: { + loadHeatmap(userName) { + const self = this; + $.get(`${this.suburl}/api/v1/users/${userName}/heatmap`, (chartRawData) => { + const chartData = []; + for (let i = 0; i < chartRawData.length; i++) { + self.totalContributions += chartRawData[i].contributions; + chartData[i] = { date: new Date(chartRawData[i].timestamp * 1000), count: chartRawData[i].contributions }; + } + self.values = chartData; + self.isLoading = false; + }); + }, + + getColor(idx) { + const el = document.createElement('div'); + el.className = `heatmap-color-${idx}`; + document.body.appendChild(el); + + const color = getComputedStyle(el).backgroundColor; + + document.body.removeChild(el); + + return color; + } + }, + + template: '<div><div v-show="isLoading"><slot name="loading"></slot></div><h4 class="total-contributions" v-if="!isLoading"><span v-html="totalContributions"></span> total contributions in the last 12 months</h4><calendar-heatmap v-show="!isLoading" :locale="locale" :no-data-text="locale.no_contributions" :tooltip-unit="locale.contributions" :end-date="endDate" :values="values" :range-color="colorRange"/></div>' + }); + + new Vue({ + delimiters: vueDelimeters, + el, + + data: { + suburl: AppSubUrl, + heatmapUser, + locale: { + contributions: 'contributions', + no_contributions: 'No contributions', + }, + }, + }); +} |