-
Notifications
You must be signed in to change notification settings - Fork 0
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Updated home page, connected it with the API #18
base: master
Are you sure you want to change the base?
Changes from 12 commits
37f78f4
d456f7d
4c12d66
87e9cf2
1fd19d4
2b75617
9ab302a
4d42c7b
54c9f4e
56c606a
4d115bc
53323ab
eb394e2
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -129,3 +129,4 @@ modules.xml | |
# Project-level: | ||
config/** | ||
!config/**example** | ||
node_modules/ |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,67 @@ | ||
var dayButtons = new Vue({ | ||
el: "#dayButtons", | ||
|
||
data: { | ||
days: [] | ||
}, | ||
|
||
methods: { | ||
toHexFromRGB(color) { | ||
function convertToHex(c) { | ||
let hex = c.toString(16); | ||
return hex.length === 1 ? "0" + hex : hex; | ||
} | ||
return "#" + convertToHex(color[0]) + convertToHex(color[1]) + convertToHex(color[2]); | ||
}, | ||
|
||
isDayFilled(day) { | ||
for(let filledDay of this.days) { | ||
if(Date.parse(filledDay.date) === Date.parse(day.toISOString())) { | ||
return true; | ||
} | ||
} | ||
return false; | ||
}, | ||
|
||
getFilledDayColor(day) { | ||
for(let filledDay of this.days) { | ||
if(Date.parse(filledDay.date) === Date.parse(day.toISOString())) { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Same as above There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Because you have to similar pieces of code, I would move them to a separate function - something like |
||
return this.toHexFromRGB(filledDay.average_color); | ||
} | ||
} | ||
return "#a9a9a9"; | ||
}, | ||
|
||
getDisplayedWeeks() { | ||
let closestSunday = new Date(); | ||
closestSunday = new Date(Date.UTC(closestSunday.getFullYear(), closestSunday.getMonth(), | ||
closestSunday.getDate() + 7 - closestSunday.getDay())); | ||
Comment on lines
+37
to
+39
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I don't think if it is worth renaming the variable, but I would at least add a comment that this is not the closest Sunday, but the closest Sunday in future. It is not obvious at all unless you delve into the expression used to calculate it |
||
let threeWeeks = Array.from(Array(3), () => new Array(7)); | ||
for(let i = 0; i < 3; ++i) { | ||
for(let j = 0; j < 7; ++j) { | ||
threeWeeks[i][j] = new Date(closestSunday); | ||
threeWeeks[i][j].setUTCDate(closestSunday.getUTCDate() - 20 + i * 7 + j); | ||
} | ||
} | ||
return threeWeeks; | ||
} | ||
}, | ||
|
||
mounted() { | ||
axios.get("/api/days/brief").then((response) => { | ||
if (response.data.ok) { | ||
this.days = response.data.days; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. |
||
this.days.map((day) => { | ||
day.data = new Date(day.data); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. The field datA of There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Field There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. @tanya-kta, I don't understand what you're talking about. I can't find the word "data" in the Note: such key is mentioned in the docs of There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Yeah, sorry, I wasn't right. That's a bug |
||
}); | ||
} | ||
else { | ||
alert("The request to API was not successful. Please try again or contact the authors."); | ||
} | ||
}) | ||
.catch(function(error) { | ||
console.error(error); | ||
}); | ||
} | ||
|
||
}); |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,22 +1,95 @@ | ||
{{define "/"}} | ||
<html lang="en"> | ||
<head> | ||
<meta charset="UTF-8"> | ||
<title>Welcome!</title> | ||
</head> | ||
|
||
<body> | ||
<h1>Welcome to the Life Calendar</h1> | ||
<p> | ||
Unfortunately, this page is empty at the moment. Try the following pages: <a href="/login">/login</a>, | ||
<a href="/logout">/logout</a>, <a href="/api">/api</a>/... | ||
<br> | ||
Currently you are | ||
{{if not .}} | ||
not | ||
{{end}} | ||
logged in | ||
</p> | ||
</body> | ||
</html> | ||
<html lang="en"> | ||
<head> | ||
<title>Welcome to Life Calender!</title> | ||
<meta charset="UTF-8"> | ||
<meta name="viewport" content="width=device-width, initial-scale=1"> | ||
<link rel="stylesheet" href="https://www.w3schools.com/w3css/4/w3.css"> | ||
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Roboto"> | ||
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Montserrat"> | ||
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css"> | ||
<style> | ||
.w3-sidebar a {font-family: "Roboto", sans-serif} | ||
body,h1,h2,h3,h4,h5,h6,.w3-wide {font-family: "Montserrat", sans-serif;} | ||
.square { | ||
width: 10%; | ||
background-color: #0b6; | ||
} | ||
Comment on lines
+12
to
+17
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Something is wrong with indentation/spaces |
||
.square:after { | ||
content: ""; | ||
display: block; | ||
padding-bottom: 100%; | ||
} | ||
</style> | ||
</head> | ||
<body class="w3-content" style="max-width:98%"> | ||
{{if .}} | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. A comment must be here! |
||
<!-- Sidebar/menu --> | ||
<nav class="w3-sidebar w3-bar-block w3-white w3-collapse w3-top" style="width:265px" id="UserSidebar"> | ||
<div class="w3-container w3-display-container w3-padding-16"> | ||
<i onclick="w3_close()" class="fa fa-remove w3-hide-large w3-button w3-display-topright"></i> | ||
<h3 class="w3-wide">Life Calendar</h3> | ||
</div> | ||
<div class="w3-padding-64 w3-large w3-text-grey" style="font-weight:bold;"> | ||
<a class="w3-bar-item w3-button w3-border-bottom w3-large" href="#"> | ||
<img src="https://telegram.org/file/464001801/4/pPObBDJVv-M.32191.png/9963667389a3218249" style="width:26%;"> | ||
Egor Filatov | ||
</a> | ||
<a href="/friends" class="w3-bar-item w3-button">Friends</a> | ||
<a href="/analyze" class="w3-bar-item w3-button">Analyze</a> | ||
<a href="/settings" class="w3-bar-item w3-button">Settings</a> | ||
</div> | ||
<a href="/logout" class="w3-bar-item w3-button w3-padding">Logout</a> | ||
</nav> | ||
|
||
<!-- Top menu on small screens --> | ||
<header class="w3-bar w3-top w3-hide-large w3-black w3-large"> | ||
<div class="w3-bar-item w3-padding-24 w3-wide">Life Calendar</div> | ||
<a href="javascript:void(0);" class="w3-bar-item w3-button w3-padding-24 w3-right" onclick="w3_open()"><i class="fa fa-bars"></i></a> | ||
</header> | ||
|
||
<!-- Overlay effect when opening sidebar on small screens --> | ||
<div class="w3-overlay w3-hide-large" onclick="w3_close()" style="cursor:pointer" title="close side menu" id="Overlay"></div> | ||
|
||
<!-- !PAGE CONTENT! --> | ||
<div class="w3-main w3-row-padding w3-margin-top" style="margin-left:265px"> | ||
|
||
<!-- Push down content on small screens --> | ||
<div class="w3-hide-large" style="margin-top:83px"></div> | ||
|
||
<!-- Day grid --> | ||
<div id="dayButtons"> | ||
<table cols=7 class="w3-table"> | ||
<tr v-for="week in getDisplayedWeeks()"> | ||
<td v-for="day in week"> | ||
<div class="w3-col square" v-if="isDayFilled(day)" | ||
v-bind:style="{backgroundColor: getFilledDayColor(day)}"></div> | ||
<div class="w3-col square" v-else style="background-color: #a9a9a9"></div> | ||
</td> | ||
</tr> | ||
</table> | ||
</div> | ||
</div> | ||
|
||
|
||
<script src="https://unpkg.com/vue"></script> | ||
<script src="https://unpkg.com/axios/dist/axios.min.js"></script> | ||
<script src="/scripts/index.js"></script> | ||
Comment on lines
+73
to
+75
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Shouldn't these scripts be included with There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I'm not sure, because I don't which value of There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
|
||
<script> | ||
function w3_open() { | ||
document.getElementById("UserSidebar").style.display = "block"; | ||
document.getElementById("Overlay").style.display = "block"; | ||
} | ||
|
||
function w3_close() { | ||
document.getElementById("UserSidebar").style.display = "none"; | ||
document.getElementById("Overlay").style.display = "none"; | ||
} | ||
Comment on lines
+77
to
+85
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I don't like these functions' names. As far as I understand |
||
</script> | ||
{{else}} | ||
Unfortunately, you are not logged in now :(<br> | ||
<a href="/login">Log in!</a> | ||
{{end}} | ||
</body> | ||
</html> | ||
{{end}} |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -167,13 +167,12 @@ func main() { | |
ui.HandleFunc("/login", HandleLogin).Methods("GET", "POST") | ||
ui.HandleFunc("/logout", HandleLogout).Methods("GET") | ||
|
||
ui.PathPrefix("/scripts/").Handler(http.StripPrefix("/scripts/", http.FileServer(http.Dir("src/scripts")))). | ||
Methods("GET") | ||
Comment on lines
+170
to
+171
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. @DarkSquirrelComes, how do you like the formatting? Is it ok? |
||
|
||
api := mux.NewRouter() | ||
|
||
api.HandleFunc("/api/2", func(w http.ResponseWriter, r *http.Request) { | ||
w.Write([]byte("Hi...")) | ||
}) | ||
api.HandleFunc("/api/days/brief", HandleApiDaysBrief).Methods("GET") | ||
//api.HandleFunc("/api/days/{id:[0-9]+}") | ||
|
||
final := http.NewServeMux() | ||
final.Handle("/", UIPanicHandlerMiddleware(ui)) | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't think
Date.parse
should be called each time. You should (probably) store dates as javascript objects, not as strings. And there definitely should be a better way of convertingday
from aDate
object to a timestamp, so at least the right value should be calculated without a call toDate.parse
and outside of the loopThere was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Still not resolved