-
Notifications
You must be signed in to change notification settings - Fork 113
/
Copy pathheader.php
208 lines (178 loc) · 6.9 KB
/
header.php
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
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
<?php
/* Copyright 2018 Atos SE and Worldline
* Licensed under MIT (https://github.com/atosorigin/DevOpsMaturityAssessment/blob/master/LICENSE) */
require 'survey.php';
$survey = new Survey;
// Create an array to represent the navbar buttons
$navBar = array (
'Questionaire' => array ('Url' => 'section-' . SectionNameToURLName($survey->sections[0]['SectionName']), 'Type' => 'Standard'),
'Sections' => array ('Type' => 'Dropdown' ),
// Sub-menus for each page are added here (see below)
'Results' => array ('Url' => 'results', 'Type' => 'Standard' ),
'Detailed Reports' => array ('Type' => 'Dropdown', 'Items' => array (
'Download CSV' => array('Url' => 'devops-maturity-csv.php', 'Type' => 'Standard'),
'Divider1' => array('Type' =>'Divider') ) ),
// Sub-menus for detailed reports are added here, see below
'Resources' => array ('Url' => 'resources', 'Type' => 'Standard' ),
'About' => array ('Url' => 'about', 'Type' => 'Standard' ) );
// Add the sub-menus for each page of the survey, and also for the detailed reports
foreach ($survey->sections as $section)
{
$navBar['Sections']['Items'][$section['SectionName']]['Url'] = 'section-' . SectionNameToURLName($section['SectionName']);
$navBar['Sections']['Items'][$section['SectionName']]['Type'] = 'Standard';
if ( $section['HasSubCategories'] )
{
$navBar['Detailed Reports']['Items'][$section['SectionName']]['Url'] = 'results-' . SectionNameToURLName($section['SectionName']);
$navBar['Detailed Reports']['Items'][$section['SectionName']]['Type'] = 'Standard';
}
}
function GetBaseURL()
{
// Routine based on https://wp-mix.com/php-absolute-path-document-root-base-url/
$doc_root = str_replace($_SERVER['SCRIPT_NAME'], '', $_SERVER['SCRIPT_FILENAME']);
//$doc_root = str_replace($doc_root, "\\", "\\");
// base directory
$base_dir = __DIR__;
$base_dir = str_replace("\\", "/", $base_dir);
// server protocol
$protocol = empty($_SERVER['HTTPS']) ? 'http' : 'https';
// domain name
$domain = $_SERVER['SERVER_NAME'];
// base url
$base_url = str_replace($doc_root, '', $base_dir);
// server port
$port = $_SERVER['SERVER_PORT'];
$disp_port = ($protocol == 'http' && $port == 80 || $protocol == 'https' && $port == 443) ? '' : ":$port";
// put em all together to get the complete base URL
return $protocol . "://" . $domain . $disp_port . $base_url;
}
function SectionNameToURLName($sectionName) {
return strtolower(str_replace(',', '', str_replace(' ', '-', $sectionName)));
}
function RenderNavBarButtons($navBar)
{
foreach ($navBar as $index=>$navBarButton)
{
switch ( $navBarButton['Type'] ) {
case 'Standard':
RenderStandardNavBarButton($index, $navBarButton['Url']);
break;
case 'Dropdown':
RenderDropdownNavBarButton($index, $navBarButton);
break;
}
}
}
function OnClickHandler($url)
{
global $isForm;
if ( $isForm )
{
// If the page contains a form then we need to set the form action and submit
return "$('form').attr('action', '$url'); $('form').submit();";
}
else
{
// If the page is not a form then just navigate to the right URL
return "window.location = '$url';";
}
}
function RenderStandardNavBarButton($buttonText, $url)
{
// Check if this is the button for the current page, and if so style it accordingly
global $activePage;
$active = '';
if ($activePage == $buttonText)
{
$active = ' active';
}
?>
<li>
<a href="#" class="nav-link<?=$active?>" onclick="<?=OnClickHandler($url)?>"><?=$buttonText?></a>
</li>
<?php
}
function RenderDropdownNavBarButton($buttonText, $navBarButton)
{
// Check if this is the button for the current page, and if so style it accordingly
global $activePage;
$active = '';
if ($activePage == $buttonText)
{
$active = ' active';
}
?>
<li class="navbar-item dropdown">
<a href="#" class="nav-link dropdown-toggle<?=$active?>" id="navbarDropdownMenuLink" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
<?=$buttonText?>
</a>
<div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
<?php foreach ($navBarButton['Items'] as $index=>$dropdownItem) {
switch ( $dropdownItem['Type'] ) {
case 'Standard': ?>
<a class="dropdown-item" href="#" onclick="<?=OnClickHandler($dropdownItem['Url'])?>"><?=$index?></a>
<?php break;
case 'Divider': ?>
<div class="dropdown-divider"></div>
<?php break;
}
}?>
</div>
</li>
<?php
}
?>
<!doctype html>
<html lang="en">
<head>
<!-- Required meta tags -->
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
<!-- Open Graph info -->
<meta property="og:title" content="DevOps Maturity Assessment" />
<meta property="og:description" content="This online DevOps Maturity Assessment questionnaire will help you understand your current strengths and weaknesses and then recommend resources that can support you in taking the next steps on your DevOps journey." />
<meta property="og:site_name" content="DevOps Maturity Assessment" />
<meta property="og:image" content="<?=GetBaseURL()?>/og-image.jpg" />
<meta property="og:image:width" content="1680" />
<meta property="og:image:height" content="870" />
<!-- Favicon stuff - check out https://realfavicongenerator.net/ -->
<link rel="apple-touch-icon" sizes="180x180" href="apple-touch-icon.png">
<link rel="icon" type="image/png" sizes="32x32" href="favicon-32x32.png">
<link rel="icon" type="image/png" sizes="16x16" href="favicon-16x16.png">
<link rel="manifest" href="site.webmanifest">
<link rel="mask-icon" href="safari-pinned-tab.svg" color="#5bbad5">
<meta name="msapplication-TileColor" content="#2d89ef">
<meta name="theme-color" content="#ffffff">
<!-- Bootstrap CSS -->
<link rel="stylesheet" href="css/bootstrap.min.css">
<link rel="stylesheet" href="fontawesome/css/all.css" rel="stylesheet">
<title>DevOps Maturity Assessment</title>
<script src="./js/chart.bundle.min.js"></script>
<script src="js/jquery-3.3.1.min.js"></script>
<style>
#bigwrapper {
background-image: Url('backdrop.jpg');
background-repeat: no-repeat;
background-position: top center;
background-attachment: fixed;
backgroun-size: cover;
background-color: RGB(2, 2, 1);
padding-top: 70px;
}
@media (max-width: 355px) {
#bigwrapper { padding-top: 100px; }
}
</style>
</head>
<body id="bigwrapper">
<nav class="navbar navbar-dark bg-primary fixed-top navbar-expand-md form-group" ">
<a href="about" class="navbar-brand">DevOps Maturity Assessment</a>
<button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarNav">
<span class="navbar-toggler-icon"></span>
</button>
<div class="collapse navbar-collapse" id="navbarNav">
<ul class="navbar-nav ml-auto">
<?php RenderNavBarButtons($navBar); ?>
</ul>
</div>
</nav>