diff options
author | silverwind <me@silverwind.io> | 2020-11-18 23:00:16 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-11-18 16:00:16 -0600 |
commit | 12c2efb45c112baf6013c304c35cbd404f7be21a (patch) | |
tree | 2deb1fd0a4c09b048c9e4f262057bfe4cfa774b1 /web_src | |
parent | d02c3508e629d854d0094f4562c4cdebfada5962 (diff) | |
download | gitea-12c2efb45c112baf6013c304c35cbd404f7be21a.tar.gz gitea-12c2efb45c112baf6013c304c35cbd404f7be21a.zip |
Remove fetch request from heatmap (#13623)
* Remove fetch request from heatmap
Render heatmap data directly to HTML, eliminating one HTTP request on
frontpage and user profile. Also added min-height to the container so
the page content will no longer move after loading.
* rename and error display
* also log the js error
* add error handler
* remove useless inline style and hide divider on small screens
* Update routers/user/home.go
* Update routers/user/profile.go
Diffstat (limited to 'web_src')
-rw-r--r-- | web_src/js/components/ActivityHeatmap.vue | 25 | ||||
-rw-r--r-- | web_src/js/features/heatmap.js | 23 | ||||
-rw-r--r-- | web_src/js/features/userheatmap.js | 10 | ||||
-rw-r--r-- | web_src/js/index.js | 4 | ||||
-rw-r--r-- | web_src/less/features/heatmap.less | 55 |
5 files changed, 61 insertions, 56 deletions
diff --git a/web_src/js/components/ActivityHeatmap.vue b/web_src/js/components/ActivityHeatmap.vue index 1970cb609a..943bf704e2 100644 --- a/web_src/js/components/ActivityHeatmap.vue +++ b/web_src/js/components/ActivityHeatmap.vue @@ -1,13 +1,9 @@ <template> - <div class="heatmap-container"> - <div v-show="isLoading"> - <slot name="loading"/> - </div> - <div v-if="!isLoading" class="total-contributions"> + <div id="user-heatmap"> + <div class="total-contributions"> {{ values.length }} contributions in the last 12 months </div> <calendar-heatmap - v-show="!isLoading" :locale="locale" :no-data-text="locale.no_contributions" :tooltip-unit="locale.contributions" @@ -19,13 +15,17 @@ </template> <script> import {CalendarHeatmap} from 'vue-calendar-heatmap'; -const {AppSubUrl, heatmapUser} = window.config; export default { name: 'ActivityHeatmap', components: {CalendarHeatmap}, + props: { + values: { + type: Array, + default: () => [], + }, + }, data: () => ({ - isLoading: true, colorRange: [ 'var(--color-secondary-alpha-70)', 'var(--color-primary-light-4)', @@ -35,20 +35,11 @@ export default { 'var(--color-primary-dark-4)', ], endDate: new Date(), - values: [], locale: { contributions: 'contributions', no_contributions: 'No contributions', }, }), - async mounted() { - const res = await fetch(`${AppSubUrl}/api/v1/users/${heatmapUser}/heatmap`); - const data = await res.json(); - this.values = data.map(({contributions, timestamp}) => { - return {date: new Date(timestamp * 1000), count: contributions}; - }); - this.isLoading = false; - }, }; </script> <style scoped/> diff --git a/web_src/js/features/heatmap.js b/web_src/js/features/heatmap.js new file mode 100644 index 0000000000..d1cb43dde0 --- /dev/null +++ b/web_src/js/features/heatmap.js @@ -0,0 +1,23 @@ +import Vue from 'vue'; + +import ActivityHeatmap from '../components/ActivityHeatmap.vue'; + +export default async function initHeatmap() { + const el = document.getElementById('user-heatmap'); + if (!el) return; + + try { + const values = JSON.parse(el.dataset.heatmapData).map(({contributions, timestamp}) => { + return {date: new Date(timestamp * 1000), count: contributions}; + }); + + const View = Vue.extend({ + render: (createElement) => createElement(ActivityHeatmap, {props: {values}}), + }); + + new View().$mount(el); + } catch (err) { + console.error(err); + el.textContent = 'Heatmap failed to load'; + } +} diff --git a/web_src/js/features/userheatmap.js b/web_src/js/features/userheatmap.js deleted file mode 100644 index f7e0d1a75f..0000000000 --- a/web_src/js/features/userheatmap.js +++ /dev/null @@ -1,10 +0,0 @@ -import Vue from 'vue'; - -import ActivityHeatmap from '../components/ActivityHeatmap.vue'; - -export default async function initUserHeatmap() { - const el = document.getElementById('user-heatmap'); - if (!el) return; - const View = Vue.extend(ActivityHeatmap); - new View().$mount(el); -} diff --git a/web_src/js/index.js b/web_src/js/index.js index 1f4c9a509a..fc49195607 100644 --- a/web_src/js/index.js +++ b/web_src/js/index.js @@ -12,7 +12,7 @@ import initMigration from './features/migration.js'; import initContextPopups from './features/contextpopup.js'; import initGitGraph from './features/gitgraph.js'; import initClipboard from './features/clipboard.js'; -import initUserHeatmap from './features/userheatmap.js'; +import initHeatmap from './features/heatmap.js'; import initProject from './features/projects.js'; import initServiceWorker from './features/serviceworker.js'; import initMarkdownAnchors from './markdown/anchors.js'; @@ -2553,7 +2553,7 @@ $(document).ready(async () => { attachTribute(document.querySelectorAll('#content, .emoji-input')), initGitGraph(), initClipboard(), - initUserHeatmap(), + initHeatmap(), initProject(), initServiceWorker(), initNotificationCount(), diff --git a/web_src/less/features/heatmap.less b/web_src/less/features/heatmap.less index 5383847387..61db5c81b0 100644 --- a/web_src/less/features/heatmap.less +++ b/web_src/less/features/heatmap.less @@ -1,49 +1,50 @@ #user-heatmap { - width: 107%; // Fixes newest contributions not showing + width: 100%; text-align: center; + position: relative; + min-height: 125px; + display: flex; + align-items: center; + justify-content: center; svg:not(:root) { overflow: inherit; padding: 0 !important; } + text { + fill: currentColor !important; + } + @media @mediaLgAndDown { - & { + &, + & + .divider { display: none; } } .total-contributions { - text-align: left; - margin-top: 0; + font-size: 11px; + position: absolute; + bottom: 0; + left: 25px; } -} - -.heatmap-container { - position: relative; -} -.heatmap-container .total-contributions { - font-size: 11px; - position: absolute; - bottom: 0; - left: 25px; -} - -@media @mediaLgAndDown { - .heatmap-container .total-contributions { - left: 21px; + @media @mediaLgAndDown { + .total-contributions { + left: 21px; + } } -} -@media (max-width: 1000px) { - .heatmap-container .total-contributions { - font-size: 10px; - left: 17px; - bottom: -2px; + @media (max-width: 1000px) { + .total-contributions { + font-size: 10px; + left: 17px; + bottom: -2px; + } } } -.heatmap-container text { - fill: currentColor !important; +.user.profile #user-heatmap { + min-height: 135px; } |