1
0
mirror of https://github.com/muety/wakapi.git synced 2023-08-10 21:12:56 +03:00

fix: ui errors from conditional HasData on summary

This commit is contained in:
Steven Tang 2021-08-29 11:10:54 +10:00
parent 6aad1633e1
commit f0ac0f6153
No known key found for this signature in database
GPG Key ID: AA0C5A4496B7ADF5
3 changed files with 23 additions and 22 deletions

View File

@ -80,7 +80,7 @@ function draw(subselection) {
.filter((c, i) => shouldUpdate(i)) .filter((c, i) => shouldUpdate(i))
.forEach(c => c.destroy()) .forEach(c => c.destroy())
let projectChart = !projectsCanvas.classList.contains('hidden') && shouldUpdate(0) let projectChart = projectsCanvas && !projectsCanvas.classList.contains('hidden') && shouldUpdate(0)
? new Chart(projectsCanvas.getContext('2d'), { ? new Chart(projectsCanvas.getContext('2d'), {
type: 'horizontalBar', type: 'horizontalBar',
data: { data: {
@ -125,7 +125,7 @@ function draw(subselection) {
}) })
: null : null
let osChart = !osCanvas.classList.contains('hidden') && shouldUpdate(1) let osChart = osCanvas && !osCanvas.classList.contains('hidden') && shouldUpdate(1)
? new Chart(osCanvas.getContext('2d'), { ? new Chart(osCanvas.getContext('2d'), {
type: 'pie', type: 'pie',
data: { data: {
@ -158,7 +158,7 @@ function draw(subselection) {
}) })
: null : null
let editorChart = !editorsCanvas.classList.contains('hidden') && shouldUpdate(2) let editorChart = editorsCanvas && !editorsCanvas.classList.contains('hidden') && shouldUpdate(2)
? new Chart(editorsCanvas.getContext('2d'), { ? new Chart(editorsCanvas.getContext('2d'), {
type: 'pie', type: 'pie',
data: { data: {
@ -191,7 +191,7 @@ function draw(subselection) {
}) })
: null : null
let languageChart = !languagesCanvas.classList.contains('hidden') && shouldUpdate(3) let languageChart = languagesCanvas && !languagesCanvas.classList.contains('hidden') && shouldUpdate(3)
? new Chart(languagesCanvas.getContext('2d'), { ? new Chart(languagesCanvas.getContext('2d'), {
type: 'pie', type: 'pie',
data: { data: {
@ -224,7 +224,7 @@ function draw(subselection) {
}) })
: null : null
let machineChart = !machinesCanvas.classList.contains('hidden') && shouldUpdate(4) let machineChart = machinesCanvas && !machinesCanvas.classList.contains('hidden') && shouldUpdate(4)
? new Chart(machinesCanvas.getContext('2d'), { ? new Chart(machinesCanvas.getContext('2d'), {
type: 'pie', type: 'pie',
data: { data: {
@ -257,7 +257,7 @@ function draw(subselection) {
}) })
: null : null
let labelChart = !labelsCanvas.classList.contains('hidden') && shouldUpdate(5) let labelChart = labelsCanvas && !labelsCanvas.classList.contains('hidden') && shouldUpdate(5)
? new Chart(labelsCanvas.getContext('2d'), { ? new Chart(labelsCanvas.getContext('2d'), {
type: 'pie', type: 'pie',
data: { data: {
@ -305,9 +305,12 @@ function parseTopN() {
} }
function togglePlaceholders(mask) { function togglePlaceholders(mask) {
const placeholderElements = containers.map(c => c.querySelector('.placeholder-container')) const placeholderElements = containers.map(c => c ? c.querySelector('.placeholder-container'): null)
for (let i = 0; i < mask.length; i++) { for (let i = 0; i < mask.length; i++) {
if (placeholderElements[i] === null) {
continue;
}
if (!mask[i]) { if (!mask[i]) {
canvases[i].classList.add('hidden') canvases[i].classList.add('hidden')
placeholderElements[i].classList.remove('hidden') placeholderElements[i].classList.remove('hidden')

View File

@ -23,13 +23,13 @@
<div class="mb-8"> <div class="mb-8">
<label class="inline-block text-sm mb-1 text-gray-500" for="username">Username</label> <label class="inline-block text-sm mb-1 text-gray-500" for="username">Username</label>
<input class="shadow appearance-none bg-gray-800 focus:bg-gray-700 text-gray-300 border-green-700 focus:border-gray-500 border rounded w-full py-1 px-3" <input class="shadow appearance-none bg-gray-800 focus:bg-gray-700 text-gray-300 border-green-700 focus:border-gray-500 border rounded w-full py-1 px-3"
type="text" id="username" type="text" id="username" autocomplete="username"
name="username" placeholder="Enter your username" minlength="1" required autofocus> name="username" placeholder="Enter your username" minlength="1" required autofocus>
</div> </div>
<div class="mb-8"> <div class="mb-8">
<label class="inline-block text-sm mb-1 text-gray-500" for="password">Password</label> <label class="inline-block text-sm mb-1 text-gray-500" for="password">Password</label>
<input class="shadow appearance-none bg-gray-800 focus:bg-gray-700 text-gray-300 border-green-700 focus:border-gray-500 border rounded w-full py-1 px-3" <input class="shadow appearance-none bg-gray-800 focus:bg-gray-700 text-gray-300 border-green-700 focus:border-gray-500 border rounded w-full py-1 px-3"
type="password" id="password" type="password" id="password" autocomplete="current-password"
name="password" placeholder="******" minlength="6" required> name="password" placeholder="******" minlength="6" required>
</div> </div>
<div class="flex justify-between items-center"> <div class="flex justify-between items-center">

View File

@ -232,12 +232,6 @@
{{ template "foot.tpl.html" . }} {{ template "foot.tpl.html" . }}
<script>
window.addEventListener('load', function() {
document.getElementById('api-key-instruction').innerHTML = document.getElementById('api-key-container').value
})
</script>
<script> <script>
const languageColors = {{ .LanguageColors | json }} const languageColors = {{ .LanguageColors | json }}
const editorColors = {{ .EditorColors | json }} const editorColors = {{ .EditorColors | json }}
@ -251,14 +245,18 @@
wakapiData.machines = {{ .Machines | json }} wakapiData.machines = {{ .Machines | json }}
wakapiData.labels = {{ .Labels | json }} wakapiData.labels = {{ .Labels | json }}
document.getElementById("to-date-picker").onchange = function () { if (document.getElementById('to-date-picker') !== null) {
var input = document.getElementById("from-date-picker"); document.getElementById("to-date-picker").onchange = function () {
input.setAttribute("max", this.value); var input = document.getElementById("from-date-picker");
} input.setAttribute("max", this.value);
}
document.getElementById("from-date-picker").onchange = function () { document.getElementById("from-date-picker").onchange = function () {
var input = document.getElementById("to-date-picker"); var input = document.getElementById("to-date-picker");
input.setAttribute("min", this.value); input.setAttribute("min", this.value);
}
} else {
document.getElementById('api-key-instruction').innerHTML = document.getElementById('api-key-container').value
} }
</script> </script>