-
Notifications
You must be signed in to change notification settings - Fork 1
/
index.html
273 lines (249 loc) · 16.3 KB
/
index.html
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
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
<!DOCTYPE html>
<html lang="en" data-bs-theme="auto">
<head>
<title>Diagnostic Tests</title>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<meta name="description" content="The Diagnostic Tests help you improve your grammar and vocabulary skills." />
<meta name="keywords" content="diagnostic tests, english grammar, grammar, vocabulary" />
<meta name='viewport' content='width=device-width, initial-scale=1' />
<link href="styles/bootstrap.min.css" rel="stylesheet" type="text/css" />
<link href="styles/style.css" rel="stylesheet" type="text/css" />
<link rel="icon" type="image/x-icon" href="images/favicon.ico" />
</head>
<body>
<div class="dropdown position-fixed bottom-0 end-0 mb-3 me-3 z-3">
<button class="btn btn-primary py-2 dropdown-toggle d-flex align-items-center" id="bd-theme" type="button"
aria-expanded="false" data-bs-toggle="dropdown" aria-label="Toggle theme (auto)">
<svg class="bi-nav my-1 me-2 theme-icon-active" width="1em" height="1em">
<use href="#circle-half"></use>
</svg>
<span id="bd-theme-text">Toggle theme</span>
</button>
<ul class="dropdown-menu dropdown-menu-end shadow" aria-labelledby="bd-theme-text">
<li>
<button type="button" class="dropdown-item d-flex align-items-center" data-bs-theme-value="light"
aria-pressed="false">
<svg class="bi-nav me-2 opacity-50 theme-icon" width="1em" height="1em">
<use href="#sun-fill"></use>
</svg>
Light
<svg class="bi-nav ms-auto d-none" width="1em" height="1em">
<use href="#check2"></use>
</svg>
</button>
</li>
<li>
<button type="button" class="dropdown-item d-flex align-items-center" data-bs-theme-value="dark"
aria-pressed="false">
<svg class="bi-nav me-2 opacity-50 theme-icon" width="1em" height="1em">
<use href="#moon-stars-fill"></use>
</svg>
Dark
<svg class="bi-nav ms-auto d-none" width="1em" height="1em">
<use href="#check2"></use>
</svg>
</button>
</li>
<li>
<button type="button" class="dropdown-item d-flex align-items-center active" data-bs-theme-value="auto"
aria-pressed="true">
<svg class="bi-nav me-2 opacity-50 theme-icon" width="1em" height="1em">
<use href="#circle-half"></use>
</svg>
Follow OS theme
<svg class="bi-nav ms-2 d-none" width="1em" height="1em">
<use href="#check2"></use>
</svg>
</button>
</li>
</ul>
</div>
<div id="informational-content">
<div class="p-4 p-md-5 container">
<div class="mshell" id="container">
<div id="iLoader" class="overlay d-flex justify-content-center align-items-center">
<div class="d-flex justify-content-center">
<div class="spinner-border" style="width: 5rem; height: 5rem;" role="status">
<span class="visually-hidden">Loading...</span>
</div>
</div>
</div>
<div class="wrapper">
<div class="myApp" ng-app="myApp" ng-controller="mainCtrl">
<div class="home_page">
<div class="d-flex justify-content-end">
<button type="button" class="btn btn-primary common_page mb-md-5 ng-binding" ng-click="help_btn()">Help</button>
</div>
<div class="mt-4 mb-5">
<h1 class="fw-bold text-center mb-3 d-flex align-items-center justify-content-center">Diagnostic Tests <a href="#" class="ms-2 fs-6 badge rounded-pill text-bg-secondary" data-bs-toggle="tooltip" data-bs-title="The explanations / answers section is currently incomplete as it is being added.">Beta</a></h1>
<h4 class="text-secondary text-center mb-3">Michael Swan | David Baker</h4>
<h5 class="text-center text-body-secondary">to accompany</h5>
</div>
<div class="mt-4 mb-5">
<div class="d-flex justify-content-center mb-5">
<span class="peu text-primary-emphasis fs-5 fw-semibold me-2">Practical English Usage</span>
<span class="pract_eng"></span>
</div>
<div class="d-flex justify-content-center" id="sound_page">
<button type="button" class="btn btn-success fs-3 rounded-4 me-2" ng-click="load_section()">Start</button>
<button type="button" class="btn btn-warning fs-3 rounded-4 d-none" id="resetButtonHome" data-bs-toggle="modal" data-bs-target="#confirmResetModal">Reset all</button>
</div>
</div>
</div>
<div ng-show="activity && !summary" class="header">
<div class="lvlWrapper">
<div class="topicHeader fs-3 text-primary-emphasis fw-semibold" ng-bind-html="d.topic | sanitize"></div>
<span class="text-info-emphasis float-start mb-2"> <span ng-if="d.level == 'b2'">Upper Intermediate</span><span
ng-if="d.level == 'c1'">Advanced</span><span ng-if="d.level == 'c2'">Expert</span>
</span>
</div>
<div class="float-end bg-body-secondary p-1 py-0" ng-hide="summary">
<span>{{d.curr + 1}}</span>
<span>of</span>
<span>{{d.size}}</span>
</div>
</div>
<div class="summaryWrapper" ng-show="summary">
<div class="topicHeader fs-3 text-primary-emphasis fw-semibold ng-binding" ng-bind-html="d.topic | sanitize">verbs</div>
<span ng-if="d.level == 'b2'">Upper Intermediate</span><span
ng-if="d.level == 'c1'">Advanced</span><span ng-if="d.level == 'c2'">Expert</span>
</div>
<div class="learningRec" scroll ng-hide="activity">
<div class="header mb-2">
<div class="topicHeader fs-3 text-primary-emphasis fw-semibold">{{d.topic}}</div>
</div>
<div class="row border-bottom py-2">
<div class="col-lg-6 d-sm-none d-md-block"></div>
<div class="col-lg-2 col-4 text-center d-flex justify-content-center align-items-center">
Upper Intermediate
</div>
<div class="col-lg-2 col-4 text-center d-flex justify-content-center align-items-center">
Advanced
</div>
<div class="col-lg-2 col-4 text-center d-flex justify-content-center align-items-center">
Expert
</div>
</div>
<div class="row border-bottom py-2" ng-repeat="i in main">
<div class="col-lg-6 col-12 mb-2">
<span ng-bind-html="i.text | sanitize"></span>
</div>
<div class="col-lg-2 col-4" ng-repeat="d in i.status track by $index">
<div ng-switch on="d">
<button type="button" ng-switch-when="0" class="btn btn-success w-100" ng-click="go($index, $parent.$parent.$index, i.text)">Try</button>
<button type="button" ng-switch-when="2" class="btn btn-secondary w-100" ng-click="results($index, $parent.$parent.$index, i.text)">Try
again</button>
<button type="button" ng-switch-when="1" class="btn btn-info w-100">–</button>
</div>
</div>
</div>
</div>
<div class="activityArea" ng-show="activity" ng-include src="template"></div>
<div class="topicFooter">
<p class="mb-0"><strong>Diagnostic Tests</strong></p>
<p>Practical English Usage <span class="peuLogo"></p>
</div>
</div>
</div>
</div>
</div>
</div>
<div id="confirmResetModal" class="modal fade" tabindex="-1" aria-labelledby="resetModalLabel" aria-hidden="true">
<div class="modal-dialog modal-dialog-centered">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="resetModalLabel">Confirm reset data?</h5>
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
</div>
<div class="modal-body">
Are you sure you want to reset all of your data? This action cannot be undone.
</div>
<div class="modal-footer d-flex">
<button type="button" class="btn btn-secondary flex-fill" data-bs-dismiss="modal">Cancel</button>
<button type="button" class="btn btn-danger flex-fill" id="confirmResetButton">Confirm</button>
</div>
</div>
</div>
</div>
<svg xmlns="http://www.w3.org/2000/svg" style="display: none;">
<symbol id="check2" viewBox="0 0 16 16">
<path d="M13.854 3.646a.5.5 0 0 1 0 .708l-7 7a.5.5 0 0 1-.708 0l-3.5-3.5a.5.5 0 1 1 .708-.708L6.5 10.293l6.646-6.647a.5.5 0 0 1 .708 0z" />
</symbol>
<symbol id="circle-half" viewBox="0 0 16 16">
<path d="M8 15A7 7 0 1 0 8 1v14zm0 1A8 8 0 1 1 8 0a8 8 0 0 1 0 16z" />
</symbol>
<symbol id="moon-stars-fill" viewBox="0 0 16 16">
<path d="M6 .278a.768.768 0 0 1 .08.858 7.208 7.208 0 0 0-.878 3.46c0 4.021 3.278 7.277 7.318 7.277.527 0 1.04-.055 1.533-.16a.787.787 0 0 1 .81.316.733.733 0 0 1-.031.893A8.349 8.349 0 0 1 8.344 16C3.734 16 0 12.286 0 7.71 0 4.266 2.114 1.312 5.124.06A.752.752 0 0 1 6 .278z" />
<path d="M10.794 3.148a.217.217 0 0 1 .412 0l.387 1.162c.173.518.579.924 1.097 1.097l1.162.387a.217.217 0 0 1 0 .412l-1.162.387a1.734 1.734 0 0 0-1.097 1.097l-.387 1.162a.217.217 0 0 1-.412 0l-.387-1.162A1.734 1.734 0 0 0 9.31 6.593l-1.162-.387a.217.217 0 0 1 0-.412l1.162-.387a1.734 1.734 0 0 0 1.097-1.097l.387-1.162zM13.863.099a.145.145 0 0 1 .274 0l.258.774c.115.346.386.617.732.732l.774.258a.145.145 0 0 1 0 .274l-.774.258a1.156 1.156 0 0 0-.732.732l-.258.774a.145.145 0 0 1-.274 0l-.258-.774a1.156 1.156 0 0 0-.732-.732l-.774-.258a.145.145 0 0 1 0-.274l.774-.258c.346-.115.617-.386.732-.732L13.863.1z" />
</symbol>
<symbol id="sun-fill" viewBox="0 0 16 16">
<path d="M8 12a4 4 0 1 0 0-8 4 4 0 0 0 0 8zM8 0a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-1 0v-2A.5.5 0 0 1 8 0zm0 13a.5.5 0 0 1 .5.5v2a.5.5 0 0 1-1 0v-2A.5.5 0 0 1 8 13zm8-5a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1 0-1h2a.5.5 0 0 1 .5.5zM3 8a.5.5 0 0 1-.5.5h-2a.5.5 0 0 1 0-1h2A.5.5 0 0 1 3 8zm10.657-5.657a.5.5 0 0 1 0 .707l-1.414 1.415a.5.5 0 1 1-.707-.708l1.414-1.414a.5.5 0 0 1 .707 0zm-9.193 9.193a.5.5 0 0 1 0 .707L3.05 13.657a.5.5 0 0 1-.707-.707l1.414-1.414a.5.5 0 0 1 .707 0zm9.193 2.121a.5.5 0 0 1-.707 0l-1.414-1.414a.5.5 0 0 1 .707-.707l1.414 1.414a.5.5 0 0 1 0 .707zM4.464 4.465a.5.5 0 0 1-.707 0L2.343 3.05a.5.5 0 1 1 .707-.707l1.414 1.414a.5.5 0 0 1 0 .708z" />
</symbol>
</svg>
<script src="scripts/bootstrap.bundle.min.js"></script>
<script language="JavaScript" type="text/javascript" src="scripts/jquery.min.js"></script>
<script language="JavaScript" type="text/javascript" src="scripts/jquery-ui.js"></script>
<script language="JavaScript" type="text/javascript" src="scripts/jquery.ui.touch-punch.min.js"></script>
<script language="JavaScript" type="text/javascript" src="scripts/scorm.js"></script>
<script language="JavaScript" type="text/javascript" src="scripts/jquery.ns-autogrow.js"></script>
<script language="JavaScript" type="text/javascript" src="scripts/angular.min.js"></script>
<script language="JavaScript" type="text/javascript" src="scripts/angular-touch.js"></script>
<script language="JavaScript" type="text/javascript" src="scripts/angular-sanitize.min.js"></script>
<script language="JavaScript" type="text/javascript" src="scripts/sortable.js"></script>
<script language="JavaScript" type="text/javascript" src="scripts/app.js"></script>
<script language="JavaScript" type="text/javascript" src="scripts/dir.js"></script>
<script language="JavaScript" type="text/javascript" src="scripts/filters.js"></script>
<script>
/*!
* Color mode toggler for Bootstrap's docs (https://getbootstrap.com/)
* Copyright 2011-2022 The Bootstrap Authors
* Licensed under the Creative Commons Attribution 3.0 Unported License.
*/
(() => {
'use strict'
const storedTheme = localStorage.getItem('theme')
const getPreferredTheme = () => {
if (storedTheme) {
return storedTheme
}
return window.matchMedia('(prefers-color-scheme: dark)').matches ? 'dark' : 'light'
}
const setTheme = function(theme) {
if (theme === 'auto' && window.matchMedia('(prefers-color-scheme: dark)').matches) {
document.documentElement.setAttribute('data-bs-theme', 'dark')
} else {
document.documentElement.setAttribute('data-bs-theme', theme)
}
}
setTheme(getPreferredTheme())
const showActiveTheme = theme => {
const activeThemeIcon = document.querySelector('.theme-icon-active use')
const btnToActive = document.querySelector(`[data-bs-theme-value="${theme}"]`)
const svgOfActiveBtn = btnToActive.querySelector('svg use').getAttribute('href')
document.querySelectorAll('[data-bs-theme-value]').forEach(element => {
element.classList.remove('active')
})
btnToActive.classList.add('active')
activeThemeIcon.setAttribute('href', svgOfActiveBtn)
}
window.matchMedia('(prefers-color-scheme: dark)').addEventListener('change', () => {
if (storedTheme !== 'light' || storedTheme !== 'dark') {
setTheme(getPreferredTheme())
}
})
window.addEventListener('DOMContentLoaded', () => {
showActiveTheme(getPreferredTheme())
document.querySelectorAll('[data-bs-theme-value]')
.forEach(toggle => {
toggle.addEventListener('click', () => {
const theme = toggle.getAttribute('data-bs-theme-value')
localStorage.setItem('theme', theme)
setTheme(theme)
showActiveTheme(theme)
})
})
})
})()
</script>
</body>
</html>