projectList.pug 6.92 KB
Newer Older
Rosanny Sihombing's avatar
Rosanny Sihombing committed
1
2
3
doctype html
html(lang="de")
  head
4
    title= "Projektdaten"
Rosanny Sihombing's avatar
Rosanny Sihombing committed
5
6
    meta(charset="UTF-8")
    meta(name="viewport", content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no")
Rosanny Sihombing's avatar
Rosanny Sihombing committed
7
8
    link(rel="stylesheet", type="text/css", href="/css/bootstrap.min.css")
    link(rel="stylesheet", type="text/css", href="/css/m4lab.css")
Athanasios's avatar
Athanasios committed
9
    link(rel="stylesheet", type="text/css", href="/css/m4lab-mobile.css")
Rosanny Sihombing's avatar
Rosanny Sihombing committed
10
    link(rel="stylesheet", href="https://use.fontawesome.com/releases/v5.8.2/css/all.css", integrity="sha384-oS3vJWv+0UjzBfQzYUhtDYW+Pj2yciDJxpsK1OYPAYjqT085Qq/1cq5FLXAZQ7Ay", crossorigin="anonymous")
Rosanny Sihombing's avatar
Rosanny Sihombing committed
11
12
13
14
    style.
        .title-container {
            position: relative;
            color: white;
15
            height: 12rem;
Athanasios's avatar
Athanasios committed
16
            overflow: hidden;
Rosanny Sihombing's avatar
Rosanny Sihombing committed
17
18
19
20
21
22
23
        }
        .card-title-bottom-left {
            position: absolute;
            bottom: 0px;
            width: 100%;
            color: black;
            font-weight: bold;
Athanasios's avatar
Athanasios committed
24
            background: rgb(255, 255, 255, 0.9);
Rosanny Sihombing's avatar
Rosanny Sihombing committed
25
26
27
28
            text-align: left;
            padding: 5px
        }
        .card-img-top {
Athanasios's avatar
Athanasios committed
29
            height: 100%;
Athanasios's avatar
Athanasios committed
30
            object-fit: contain;
Athanasios's avatar
Athanasios committed
31
32
33
34
35
36
37
38
39
40
41
42
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            margin-left: 0;
            margin-right: 0;
        }
        .card-img-bg {
            background-size: cover;
            filter: blur(30px);
            width: 100%;
            height: 100%;
Rosanny Sihombing's avatar
Rosanny Sihombing committed
43
        }
44
45
46
47
48
49
        .clamp-lines {
            display: -webkit-box;
            -webkit-line-clamp: 6;
            -webkit-box-orient: vertical;
            overflow: hidden;
        }
Rosanny Sihombing's avatar
Rosanny Sihombing committed
50
  body
51
    div(class="container")
52
53
        div(class="row")
            div(class="col-md-12 margin_bottom_40")
54
                img(class="mx-auto" src="https://transfer.hft-stuttgart.de/img/ProjektcodeDaten.png" width="100%")
Rosanny Sihombing's avatar
Rosanny Sihombing committed
55
    div(class="container")
Wolfgang Knopki's avatar
Wolfgang Knopki committed
56
57
        p Hier finden Sie den direkten Zugang zu den Inhalten der bei uns gehosteten Projekte.
        p Weitere Informationen zu den bei uns gehosteten Projekten finden Sie <a href="/projektinformationen">hier</a>.
Athanasios's avatar
Athanasios committed
58
        p Wenn Sie zu einem Projekt beitragen möchten, oder eines erstellen möchten, finden Sie weitere Informationen <a href="/help/gitlab.html">hier</a>.
59
60

        div(class="container")
61
            p#projectCounter #{project.length} Projektdaten werden angezeigt
62
            div(class="pt-4 pb-4 form-row")
Rosanny Sihombing's avatar
Rosanny Sihombing committed
63
                div(class="form-group col-md-10")
64
                    input(id="searchInput", class="form-control form-control-lg", type="text", placeholder="Suchen Sie hier nach Themen und Projekten", onkeyup="searchFunction()")
Rosanny Sihombing's avatar
Rosanny Sihombing committed
65
66
67
                div(class="form-group col-md-2")
                    select#sortingSelect(class="form-control form-control-lg")
                        option(value="" disabled) Sort by
Rosanny Sihombing's avatar
Rosanny Sihombing committed
68
69
70
                        option(value="name") &nbsp; Name
                        option(value="created_at") &nbsp; Last created
                        option(value="updated_at") &nbsp; Last updated
Rosanny Sihombing's avatar
Rosanny Sihombing committed
71
72
            | <div class="row">
            for item in project
73
                div(class="card-deck py-4 col-sm")
Athanasios's avatar
Athanasios committed
74
                    div(class="card card-portrait" style="transform: rotate(0);")
Rosanny Sihombing's avatar
Rosanny Sihombing committed
75
                        div(class="title-container")
Athanasios's avatar
Athanasios committed
76
                            div(class="card-img-bg" style=`background-image: url(${item.logo});`)
Rosanny Sihombing's avatar
Rosanny Sihombing committed
77
                            img(class="card-img-top", src=item.logo)
Athanasios's avatar
Athanasios committed
78
                            h5(class="card-title-bottom-left") #{item.name}
79
                        div(class="card-body-fixed-height")
Rosanny Sihombing's avatar
Rosanny Sihombing committed
80
81
82
83
84
                            div(class="row")
                                each key in item.keywords
                                    h6
                                        span(class="badge badge-pill badge-primary px-2") #{key}
                                        | &nbsp;
Rosanny Sihombing's avatar
Rosanny Sihombing committed
85
86
                            div(class="row")
                                div(class="col-9")
87
                                    p(class="card-text clamp-lines") #{item.desc}
88
                                a(href=item.weburl, class="no_text_decoration stretched-link", target="_blank")
Rosanny Sihombing's avatar
Rosanny Sihombing committed
89
            | </div>
Rosanny Sihombing's avatar
Rosanny Sihombing committed
90

Rosanny Sihombing's avatar
Rosanny Sihombing committed
91
92
93
    button(onclick="topFunction()" id="topBtn")
        i(class="fa fa-chevron-up")

Rosanny Sihombing's avatar
Rosanny Sihombing committed
94
95
96
97
98
99
    // jQuery
    script(src="https://code.jquery.com/jquery-3.3.1.min.js")
    script(src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.7/umd/popper.min.js", integrity="sha384-UO2eT0CpHqdSJQ6hJty5KVphtPhzWj9WO1clHTMGa3JDZwrnQq4sF86dIHNDz0W1", crossorigin="anonymous")
    // Bootstrap
    script(src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js" integrity="sha384-JjSmVgyd0p3pXB1rRibZUAYoIIy6OrQ6VrjIEaFf/nJGzIxFDsf4x0xIM+B07jRM" crossorigin="anonymous")
    // Header
100
    script(src="/js/headfoot.js")
Athanasios's avatar
Athanasios committed
101
    script(src="/js/mobile.js")
102
103
    // General functions
    script(src="/js/generalFunction.js")
Rosanny Sihombing's avatar
Rosanny Sihombing committed
104
105
    script.
        function searchFunction() {
Rosanny Sihombing's avatar
Rosanny Sihombing committed
106
107
            var input = document.getElementById("searchInput")
            var filter = input.value.toUpperCase()
Rosanny Sihombing's avatar
Rosanny Sihombing committed
108
            
Rosanny Sihombing's avatar
Rosanny Sihombing committed
109
            var cardsCol = document.getElementsByClassName("col-sm")
Athanasios's avatar
Athanasios committed
110
            var cardTitle, cardBadges, cardText, titleValue, badgesValue, textValue, allValues;
Rosanny Sihombing's avatar
Rosanny Sihombing committed
111
112
            
            var i
Rosanny Sihombing's avatar
Rosanny Sihombing committed
113
114
115
            var counterBlock = 0
            for (i = 0; i < cardsCol.length; i++) {
                cardTitle = cardsCol[i].getElementsByClassName("card-title-bottom-left");
Athanasios's avatar
Athanasios committed
116
117
                //cardBody = cardsCol[i].getElementsByClassName("card-body");
                cardBadges = [...cardsCol[i].getElementsByClassName("badge-pill")];
Rosanny Sihombing's avatar
Rosanny Sihombing committed
118
                cardText = cardsCol[i].getElementsByClassName("card-text");
Rosanny Sihombing's avatar
Rosanny Sihombing committed
119
120
                
                titleValue = cardTitle[0].textContent || cardTitle[0].innerText;
Athanasios's avatar
Athanasios committed
121
122
                badgesValue = cardBadges.map(b => b.textContent).join(" ");
                //bodyValue = cardBody[0].textContent || cardBody[0].innerText;
Rosanny Sihombing's avatar
Rosanny Sihombing committed
123
                textValue = cardText[0].textContent || cardText[0].innerText;
Athanasios's avatar
Athanasios committed
124
125
                allValues = [titleValue, badgesValue, textValue].map(v => v.toUpperCase()).join(" ");
                if (allValues.indexOf(filter)!= -1) {
Rosanny Sihombing's avatar
Rosanny Sihombing committed
126
127
                    cardsCol[i].style.display = "block"
                    counterBlock++
Rosanny Sihombing's avatar
Rosanny Sihombing committed
128
                } else {
Rosanny Sihombing's avatar
Rosanny Sihombing committed
129
                    cardsCol[i].style.display = "none"
Rosanny Sihombing's avatar
Rosanny Sihombing committed
130
131
                }
            }
Rosanny Sihombing's avatar
Rosanny Sihombing committed
132

133
            document.getElementById("projectCounter").innerHTML = counterBlock+" Projektdaten werden angezeigt"
Rosanny Sihombing's avatar
Rosanny Sihombing committed
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
        }

        $("#sortingSelect").change(function() {
            window.location.replace('/projektdaten?sort='+$("#sortingSelect").val())
        });
        function setSortSelect() {
            let sortKeyword = getQueryStringParams('sort', window.location.href)
            if (sortKeyword == "created_at") {
                $("#sortingSelect").val("created_at")
            } else if(sortKeyword == "updated_at") {
                $("#sortingSelect").val("updated_at")
            } else {
                $("#sortingSelect").val("name")
            }
        }
        setSortSelect()