-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathAHR Vornoten Abitur.svelte
89 lines (86 loc) · 2.53 KB
/
AHR Vornoten Abitur.svelte
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
{#each chunk(schueler, anzahl) as slice, i}
<div class="page grid" orientation="landscape" size="A3">
<div class="header">
<pre>
Konferenzliste APA BK Abitur <b>{klasse.Klasse || schueler[0].Klasse}</b> 	 {aktAbschnitt().klassenlehrer_in}: <b>{`${aktAbschnitt().lehrer?.Vorname} ${aktAbschnitt().lehrer?.Nachname} (${aktAbschnitt().lehrer?.Kuerzel})`}</b> 	 Stand: {heute()}
</pre>
</div>
<div class="main">
{#each slice as s, ii}
<b>{(i*anzahl)+ii+1}. {s.Name}, {s.Vorname}</b>
<div class="flex-grid">
<div class="tabelle">
<table>
{#each zeilen(faecher(s)) as row}
<tr>
{#each row as cell}
<td class:red={parseInt(cell) < 5 && parseInt(cell) >= 0}>{cell}</td>
{/each}
</tr>
{/each}
<tr><td>✎ → </td>
{#each s.abi_abschluss_faecher as i}
<td></td>
{/each}
</tr>
</table>
</div>
<div class="bemerkungen">
Bermerkungen:
{#each '12345' as i}
<hr>
<Voffset v='1.5' />
{/each}
Zugelassen: {s.abi_abschluss.Zugelassen === '+' ? "Ja":"Nein"}
</div>
</div>
<Voffset v=1 />
{/each}
</div>
<div class="footer">Seite {i+1}/{Math.ceil(schueler.length/anzahl)}</div>
</div>
{/each}
<script>
import { chunk } from './helfer'
import Voffset from './partials/Voffset.svelte'
export let schueler, klasse
const anzahl = 5
const heute = () => new Date().toLocaleDateString('de', {day: '2-digit', month: '2-digit', year: 'numeric'})
const aktAbschnitt = () => schueler[0].abschnitte.slice(-1)[0]
function faecher (s) {
return s.abi_abschluss_faecher.sort((a,b) => a.FSortierung - b.FSortierung)
}
function zeilen (faecher) {
const arr = [[''], ['12.1'], ['12.2'], ['13.1'], ['13.2']]
faecher.forEach(f => {
arr[0].push(f.FachKrz)
arr[1].push(f.P12_1 || '')
arr[2].push(f.P12_2 || '')
arr[3].push(f.P13_1 || '')
arr[4].push(f.P13_2 || '')
})
return arr
}
</script>
<style>
@import 'css/main.css';
table {
width: 98%;
border-collapse: collapse;
}
table td {
border: thin solid #ddd;
white-space:nowrap;
text-align: center;
}
.flex-grid {
display: flex;
}
.tabelle {
flex: 65%;
}
.bemerkungen {
flex: 35%;
}
.red { background-color: tomato; }
</style>