BackEnd/YTManager/wwwroot/index.js

59 lines
2.0 KiB
JavaScript
Raw Normal View History

2017-09-01 08:55:02 +00:00
$(document).foundation();
// How many chars at most for the description.
var maxcharsdescriptionfield = 100;
// Grid if images.
var vidholder = new Vue({
el: '#vidholder-0',
data: {
2017-09-03 01:05:50 +00:00
Videos: []
2017-09-01 08:55:02 +00:00
},
2017-09-03 01:05:50 +00:00
// Template has wrapping div because v-for can't be in root it seems.
template: `
<div>
<div class="grid-x grid-margin-x large-up-6">
2017-09-03 01:35:07 +00:00
<div v-for="video in Videos" class="cell">
<div class="success card curvedbottom">
<a :href="video.url"><img :src="video.thumbnailURL"></a>
<div class="card-section" style="padding-top: 7px; padding-bottom: 7px;">
<p style="padding-top: 0px; padding-bottom: 0px; font-size: 12px;">{{ video.title }}</p>
</div>
2017-09-03 01:05:50 +00:00
</div>
2017-09-03 01:35:07 +00:00
</div>
2017-09-03 01:05:50 +00:00
</div >
</div>
`,
2017-09-01 08:55:02 +00:00
methods: {
// Get new videos from the web api.
retrieve: function (event) {
// Wipe out all old entries.
2017-09-03 01:05:50 +00:00
this.Videos = [];
2017-09-01 08:55:02 +00:00
axios.get('/api/Videos')
.then(function (response) {
// And fill it with all the retrieved entries.
response.data.forEach(function (x) {
// Trim description if needed.
if (x.description.length > maxcharsdescriptionfield) {
x.description = x.description.substring(0, maxcharsdescriptionfield) + " ...";
}
2017-09-03 01:05:50 +00:00
// Generate a new URL by adding the YT ID.
x.url = "https://www.youtube.com/watch?v=" + x.youtubeID;
2017-09-01 08:55:02 +00:00
// Add it to our array
2017-09-03 01:05:50 +00:00
this.Videos.push(x);
2017-09-01 08:55:02 +00:00
}.bind(this));
}.bind(this))
.catch(function (error) {
console.log(error);
});
}
}
});
window.addEventListener('load', function () {
vidholder.retrieve();
});