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:
parent
6aad1633e1
commit
f0ac0f6153
@ -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')
|
||||||
|
@ -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">
|
||||||
|
@ -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>
|
||||||
|
Loading…
Reference in New Issue
Block a user