-
Notifications
You must be signed in to change notification settings - Fork 1
/
assignment1.html
134 lines (108 loc) · 6.16 KB
/
assignment1.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
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Assignment 1</title>
<meta name="description" content="Assignmnent 1">
<meta name="author" content="Chan Chi-Loong, V/R">
<meta name="apple-mobile-web-app-capable" content="yes" />
<meta name="apple-mobile-web-app-status-bar-style" content="black-translucent" />
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
<link rel="stylesheet" href="css/reveal.min.css">
<link rel="stylesheet" href="css/theme/night.css" id="theme">
<link rel="stylesheet" href="css/style.css">
<style>
</style>
<!-- If the query includes 'print-pdf', use the PDF print sheet -->
<script>
document.write( '<link rel="stylesheet" href="css/print/' + ( window.location.search.match( /print-pdf/gi ) ? 'pdf' : 'paper' ) + '.css" type="text/css" media="print">' );
</script>
<!--[if lt IE 9]>
<script src="lib/js/html5shiv.js"></script>
<![endif]-->
</head>
<body>
<div class="reveal">
<!-- Any section element inside of this container is displayed as a slide -->
<div class="slides">
<section data-state="alert" data-transition="zoom">
<h1 class="shadowfont white">Assignment 1</h1>
</section>
<section>
<h3>Setup</h3>
<p>To be completed by <b>22-2-2021</b>(Thurs) 1200hrs</p>
<ul>
<li>This repo link will be of the format https://<b><username></b>.github.io/HASS-assignment1</li>
<li>In the repo create a basic <b>index.html</b> file, and make it visible on GitHub repo pages (it's under the settings tab, under GitHub pages).</li>
<li>You can put your CSS style tags, HTML and JS script code into one file, or organize them into files/directories.</li>
</ul>
</section>
<section>
<h3>The Problem</h3>
<ul>
<li>Connect to the data.gov.sg PSI API and get the realtime dataset. It is detailed <a href="https://beta.data.gov.sg/collections/1396/view">here</a>.</li>
<li>The URI for the API is: <a href="https://api.data.gov.sg/v1/environment/psi">https://api.data.gov.sg/v1/environment/psi</a></li>
<li>Print out all <b>readings data</b> into a table. There are 12 readings, from o3_sub_index to psi_twenty_four_hourly.</li>
</ul>
</section>
<section>
<h3>Extra Challenge</h3>
<ul>
<li>Theme the layout of the table nicely. Tweak the CSS to your liking, or use some CSS framework!</li>
<li>Print out the timestamp of when the data in the reading was updated.</li>
</ul>
</section>
<section>
<h3>Screenshot</h3>
<img src="img/assignment1_screenshot.jpg"/>
</section>
<section>
<h3>More details</h3>
<ul>
<li>This portion is not a design challenge.</li>
<li>It is to show you can connect to an API, pull out and understand/read the JSON data, and list the table.</li>
<li>Be sure you know what you are manipulating in the JSON schema. <b>Console.log</b> to inspect the JSON structure.</li>
<li>You can use JQuery to append the HTML elements you need. Or just write in plain ES5/ES6 javascript. Or whatever JS framework you prefer.</li>
</ul>
</section>
<section>
<h3>More help please!</h3>
<ul>
<li>If you can, write from scratch. <img src="img/smile.svg" width="20" /></li>
<li>But here's a basic starter <a href="assignments/assignment1-starter.html">template</a> if you need one.</li>
</ul>
</section>
<section>
<h2>Questions?</h2>
<div class="plain">
<div class="rotate-icon"><a href="http://www.vslashr.com"><img width="100" src="img/VslashR_logo_white.svg"></a></div>
</div>
<p><small>Chi-Loong | V/R</small></p>
</section>
</div>
</div>
<script src="lib/js/head.min.js"></script>
<script src="js/reveal.js"></script>
<script>
// Full list of configuration options available here:
// https://github.com/hakimel/reveal.js#configuration
Reveal.initialize({
controls: true,
progress: true,
history: true,
center: true,
theme: Reveal.getQueryHash().theme, // available themes are in /css/theme
transition: Reveal.getQueryHash().transition || 'default', // default/cube/page/concave/zoom/linear/fade/none
// Optional libraries used to extend on reveal.js
dependencies: [
{ src: 'lib/js/classList.js', condition: function() { return !document.body.classList; } },
{ src: 'plugin/markdown/marked.js', condition: function() { return !!document.querySelector( '[data-markdown]' ); } },
{ src: 'plugin/markdown/markdown.js', condition: function() { return !!document.querySelector( '[data-markdown]' ); } },
{ src: 'plugin/highlight/highlight.js', async: true, callback: function() { hljs.initHighlightingOnLoad(); } },
{ src: 'plugin/zoom-js/zoom.js', async: true, condition: function() { return !!document.body.classList; } },
{ src: 'plugin/notes/notes.js', async: true, condition: function() { return !!document.body.classList; } }
]
});
</script>
</body>
</html>