aboutsummaryrefslogtreecommitdiff
path: root/resources/vue/apps/CoursePlanningTileFilter.vue
blob: 0ac69b178f9f346386e755fc83c3b74528a70b2f (plain)
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
<template>
    <form method="post" :action="storeURL" class="default">
        <input type="hidden" :name="csrf.name" :value="csrf.value">
        <input v-for="(_, key) in items"
               :key="`input-${key}`"
               type="hidden"
               :name="key"
               :value="checkboxes[key] ? 1 : 0"
        >

        <fieldset>
            <legend>{{ $gettext('Angezeigte Veranstaltungsdaten') }}</legend>

            <label v-for="(label, key) in items" :key="key">
                <input :name="key"
                       type="checkbox"
                       v-model="checkboxes[key]"
                       :disabled="isDisabled(key)"
                >
                {{ label }}
            </label>
        </fieldset>

        <footer data-dialog-button>
            <button type="submit" class="accept button">
                {{ $gettext('Speichern') }}
            </button>
        </footer>
    </form>
</template>
<script setup lang="ts">
import { computed, reactive, unref } from "vue";
import { $gettext } from "../../assets/javascripts/lib/gettext";

type ValidField = 'course_number' | 'course_name' | 'lecturers' | 'rooms';

const props = defineProps({
    view: [String, null],
    weekday: [String, null],
    config: Object,
});

const checkboxes = reactive({...unref(props.config)});
if (!checkboxes.course_number && !checkboxes.course_name) {
    checkboxes.course_name = true;
}

const csrf = computed(() => window.STUDIP.CSRF_TOKEN);

const items: Record<ValidField, string> = {
    course_number: $gettext('Veranstaltungsnummer'),
    course_name: $gettext('Veranstaltungstitel'),
    lecturers: $gettext('Lehrende'),
    rooms: $gettext('Raum'),
};

const storeURL = window.STUDIP.URLHelper.getURL(`dispatch.php/admin/courseplanning/store_tilefilter/${props.view}/${props.weekday}`, {}, true);

function isDisabled(f: string): boolean {
    const field = f as ValidField;

    return (field === 'course_number' && !checkboxes.course_name)
        || (field === 'course_name' && !checkboxes.course_number);

}
</script>