aboutsummaryrefslogtreecommitdiff
path: root/assets
diff options
context:
space:
mode:
Diffstat (limited to 'assets')
-rw-r--r--[-rwxr-xr-x]assets/css/main.css80
-rw-r--r--assets/css/main.css.map9
-rw-r--r--assets/css/main.sass81
-rwxr-xr-xassets/js/main.js571
-rwxr-xr-xassets/php/getNetflixJson.php16
5 files changed, 415 insertions, 342 deletions
diff --git a/assets/css/main.css b/assets/css/main.css
index aa51cdd..e5d025a 100755..100644
--- a/assets/css/main.css
+++ b/assets/css/main.css
@@ -1,78 +1,2 @@
-/**
- * Design of the Netflix Stats Generator
- * @author Marvin Borner
- * @copyright Marvin Borner 2018
- */
-
-/**
- * General
- */
-
-:root {
- --BlueColor: #1e3264;
-}
-
-body {
- font-family: 'Varela Round', sans-serif !important;
- text-rendering: optimizeLegibility !important;
- box-sizing: border-box !important;
-}
-
-.Main {
- display: none;
- min-height: 100vh;
-}
-
-/**
- * General headers
- */
-.SectionHeader {
- display: flex;
- justify-content: center;
- align-items: center;
- align-content: space-between;
- width: 100%;
-}
-
-.SectionHeader h1 {
- text-transform: capitalize;
-}
-
-/**
- * Gradients
- */
-
-.GradientBackground>* {
- position: fixed;
- top: 0;
- left: 0;
- z-index: -1;
- transition: opacity 1.5s cubic-bezier(.445, .05, .55, .95) 0s;
- width: 100%;
- height: 100vh;
-}
-
-.GradientBackground .Color:not(.Active) {
- display: none;
-}
-
-.GradientBackground .GreenBlue {
- background: linear-gradient(145deg, #c3f0c8, #509bf5);
-}
-
-.GradientBackground .OrangePink {
- background: linear-gradient(145deg, #ffc867, #f037a6);
-}
-
-.GradientBackground .GreenBlue {
- background: linear-gradient(145deg, #c3f0c8, #509bf5);
-}
-
-/**
- * Favorites
- */
-
-.FavoritesSection .SectionHeader {
- height: 40vh;
- color: var(--BlueColor);
-} \ No newline at end of file
+body{font-family:"Varela Round", sans-serif !important;text-rendering:optimizeLegibility !important;box-sizing:border-box !important}.Main{min-height:100vh}.SectionHeader{display:flex;justify-content:center;align-items:center;align-content:space-between;width:100%}.SectionHeader h1{text-transform:capitalize}.GradientBackground .GreenBlue,.GradientBackground .OrangePink{position:fixed;top:0;left:0;z-index:-1;transition:opacity 1.5s cubic-bezier(0.445, 0.05, 0.55, 0.95) 0s;width:100%;height:100vh}.GradientBackground .Color:not(.Active){display:none}.GradientBackground .GreenBlue{background:linear-gradient(145deg, #c3f0c8, #509bf5)}.GradientBackground .OrangePink{background:linear-gradient(145deg, #ffc867, #f037a6)}.GradientBackground .GreenBlue{background:linear-gradient(145deg, #c3f0c8, #509bf5)}.FavoritesSection .SectionHeader{height:40vh;color:#1e3264}
+/*# sourceMappingURL=main.css.map */ \ No newline at end of file
diff --git a/assets/css/main.css.map b/assets/css/main.css.map
new file mode 100644
index 0000000..e8bd39d
--- /dev/null
+++ b/assets/css/main.css.map
@@ -0,0 +1,9 @@
+{
+ "version": 3,
+ "mappings": "AAYA,AAAA,IAAI,AAAC,CACD,WAAW,CAAE,qCAAqC,CAClD,cAAc,CAAE,6BAA6B,CAC7C,UAAU,CAAE,qBAAqB,CAAI,AAGzC,AAAA,KAAK,AAAC,CAEF,UAAU,CAAE,KAAK,CAAI,AAOzB,AAAA,cAAc,AAAC,CACX,OAAO,CAAE,IAAI,CACb,eAAe,CAAE,MAAM,CACvB,WAAW,CAAE,MAAM,CACnB,aAAa,CAAE,aAAa,CAC5B,KAAK,CAAE,IAAI,CAAI,AAGnB,AAAe,cAAD,CAAC,EAAE,AAAC,CACd,cAAc,CAAE,UAAU,CAAI,AAOlC,AACI,mBADe,CAef,UAAU,CAfd,AACI,mBADe,CAoBf,WAAW,AAnBD,CACN,QAAQ,CAAE,KAAK,CACf,GAAG,CAAE,CAAC,CACN,IAAI,CAAE,CAAC,CACP,OAAO,CAAE,EAAE,CACX,UAAU,CAAE,OAAO,CAAC,IAAI,CAAC,qCAAqC,CAAC,EAAE,CACjE,KAAK,CAAE,IAAI,CACX,MAAM,CAAE,KAAK,CAAI,AARzB,AAWI,mBAXe,CAWf,MAAM,AAAA,IAAK,CAAA,AAAA,OAAO,CAAE,CAChB,OAAO,CAAE,IAAI,CAAI,AAZzB,AAeI,mBAfe,CAef,UAAU,AAAC,CACP,UAAU,CAAE,yCAAyC,CACjC,AAjB5B,AAoBI,mBApBe,CAoBf,WAAW,AAAC,CACR,UAAU,CAAE,yCAAyC,CACjC,AAtB5B,AAeI,mBAfe,CAef,UAAU,AAUC,CACP,UAAU,CAAE,yCAAyC,CACjC,AAQ5B,AAAkB,iBAAD,CAAC,cAAc,AAAC,CAC7B,MAAM,CAAE,IAAI,CACZ,KAAK,CAtEG,OAAO,CAsEK",
+ "sources": [
+ "main.sass"
+ ],
+ "names": [],
+ "file": "main.css"
+} \ No newline at end of file
diff --git a/assets/css/main.sass b/assets/css/main.sass
new file mode 100644
index 0000000..39cd30c
--- /dev/null
+++ b/assets/css/main.sass
@@ -0,0 +1,81 @@
+/**
+ * Design of the Netflix Stats Generator
+ * @author Marvin Borner
+ * @copyright Marvin Borner 2018
+ */
+
+/**
+ * General
+ */
+
+$BlueColor: #1e3264
+
+body
+ font-family: "Varela Round", sans-serif !important
+ text-rendering: optimizeLegibility !important
+ box-sizing: border-box !important
+
+
+.Main
+ // display: none
+ min-height: 100vh
+
+
+/**
+ * General headers
+ */
+
+.SectionHeader
+ display: flex
+ justify-content: center
+ align-items: center
+ align-content: space-between
+ width: 100%
+
+
+.SectionHeader h1
+ text-transform: capitalize
+
+
+/**
+ * Gradients
+ */
+
+.GradientBackground
+ %Gradient
+ position: fixed
+ top: 0
+ left: 0
+ z-index: -1
+ transition: opacity 1.5s cubic-bezier(0.445, 0.05, 0.55, 0.95) 0s
+ width: 100%
+ height: 100vh
+
+
+ .Color:not(.Active)
+ display: none
+
+
+ .GreenBlue
+ background: linear-gradient(145deg, #c3f0c8, #509bf5)
+ @extend %Gradient
+
+
+ .OrangePink
+ background: linear-gradient(145deg, #ffc867, #f037a6)
+ @extend %Gradient
+
+
+ .GreenBlue
+ background: linear-gradient(145deg, #c3f0c8, #509bf5)
+ @extend %Gradient
+
+
+
+/**
+ * Favorites
+ */
+
+.FavoritesSection .SectionHeader
+ height: 40vh
+ color: $BlueColor \ No newline at end of file
diff --git a/assets/js/main.js b/assets/js/main.js
index d88cda1..8854884 100755
--- a/assets/js/main.js
+++ b/assets/js/main.js
@@ -4,282 +4,341 @@
* @copyright Marvin Borner 2018
*/
-$(function () {
- const CookieInput = $(".CookieInput");
- let NetflixJson;
+$(function() {
+ const CookieInput = $(".CookieInput");
+ let NetflixJson;
- CookieInput.keyup(function (e) {
- if (e.keyCode === 13) {
- $.ajax({
- url: "assets/php/getNetflixJson.php",
- data: {
- "Cookie": CookieInput.val()
- },
- type: "POST",
- }).done(function (response) {
- CookieInput.val("");
- CookieInput.hide();
- $(".Main").fadeIn();
- AnalyzeData(response);
- });
- }
- });
+ CookieInput.keyup(function(e) {
+ if (e.keyCode === 13) {
+ $.ajax({
+ url: "assets/php/getNetflixJson.php",
+ data: {
+ Cookie: CookieInput.val()
+ },
+ type: "POST"
+ }).done(function(response) {
+ CookieInput.val("");
+ CookieInput.hide();
+ $(".Main").fadeIn();
+ AnalyzeData(response);
+ });
+ }
+ });
+ /**
+ * Analyzes the Netflix data JSON response
+ * @param {JSON} JsonResponse
+ */
+ function AnalyzeData(JsonResponse) {
/**
- * Analyzes the Netflix data JSON response
- * @param {JSON} JsonResponse
+ * @example response of a series:
+ * bookmark: 0
+ * country: "DE"
+ * date: 1529338765489
+ * dateStr: "18.06.18"
+ * deviceType: 1481
+ * duration: 3302
+ * episodeTitle: "Folge 13"
+ * estRating: "50"
+ * index: 0
+ * movieID: 80205354
+ * seasonDescriptor: "Teil 1"
+ * series: 80192098
+ * seriesTitle: "Haus des Geldes"
+ * title: "Teil 1: \"Folge 13\""
+ * topNodeId: "80192098"
+ * videoTitle: "Folge 13"
+ *
+ * @example response of a movie:
+ * bookmark: 7771
+ * country: "DE"
+ * date: 1476477258019
+ * dateStr: "14.10.16"
+ * deviceType: 1193
+ * duration: 8160
+ * estRating: "30"
+ * index: 916
+ * movieID: 20557937
+ * title: "Matrix"
+ * topNodeId: "20557937"
+ * videoTitle: "Matrix"
*/
- function AnalyzeData(JsonResponse) {
- /**
- * @example response of a series:
- * bookmark: 0
- * country: "DE"
- * date: 1529338765489
- * dateStr: "18.06.18"
- * deviceType: 1481
- * duration: 3302
- * episodeTitle: "Folge 13"
- * estRating: "50"
- * index: 0
- * movieID: 80205354
- * seasonDescriptor: "Teil 1"
- * series: 80192098
- * seriesTitle: "Haus des Geldes"
- * title: "Teil 1: \"Folge 13\""
- * topNodeId: "80192098"
- * videoTitle: "Folge 13"
- *
- * @example response of a movie:
- * bookmark: 7771
- * country: "DE"
- * date: 1476477258019
- * dateStr: "14.10.16"
- * deviceType: 1193
- * duration: 8160
- * estRating: "30"
- * index: 916
- * movieID: 20557937
- * title: "Matrix"
- * topNodeId: "20557937"
- * videoTitle: "Matrix"
- */
- NetflixJson = JSON.parse(JsonResponse);
- console.log(NetflixJson);
- let EveryWatched = [];
- let IndividualTitles = [];
- let IndividualSeries = [];
- let IndividualMovies = [];
- let AverageWatchTimes = [];
-
- NetflixJson.forEach(function (item, pageKey) {
- item.forEach(function (eachItem, ItemNumber) {
- if ("seriesTitle" in eachItem) { // is series
- const CurrentTitle = NetflixJson[pageKey][ItemNumber].seriesTitle;
- EveryWatched.push(CurrentTitle);
- if (IndividualSeries.indexOf(CurrentTitle) === -1 && CurrentTitle !== undefined) { // only if not already crawled -> individualism
- IndividualSeries.push(CurrentTitle);
- IndividualTitles.push(CurrentTitle);
- }
- } else { // is movie
- const CurrentTitle = NetflixJson[pageKey][ItemNumber].videoTitle;
- EveryWatched.push(CurrentTitle);
- if (IndividualMovies.indexOf(CurrentTitle) === -1 && CurrentTitle !== undefined) { // only if not already crawled -> individualism
- IndividualMovies.push(CurrentTitle);
- IndividualTitles.push(CurrentTitle);
- }
- }
-
- // get watch time
- const DayTimeInSeconds = new Date(NetflixJson[pageKey][ItemNumber].date * 1000);
- const DayTimeInHours = DayTimeInSeconds.getHours();
- AverageWatchTimes.push(DayTimeInHours);
- });
- });
+ NetflixJson = JSON.parse(JsonResponse);
+ console.log(NetflixJson);
+ let EveryWatched = [];
+ let IndividualTitles = [];
+ let IndividualSeries = [];
+ let IndividualMovies = [];
+ let AverageWatchTimes = [];
- const TotalSeriesWatched = IndividualSeries.length;
-
- // Calculate watch time occurrence (average times in which the user watches sth.)
- let AverageWatchTimeOccurrence = [];
- const WatchTimeOccurrenceCounter = new Map([...new Set(AverageWatchTimes)].map(
- x => [x, AverageWatchTimes.filter(y => y === x).length]
- ));
- for (let i = 0; i < 24; i++) {
- AverageWatchTimeOccurrence.push(WatchTimeOccurrenceCounter.get(i));
+ NetflixJson.forEach(function(item, pageKey) {
+ item.forEach(function(eachItem, ItemNumber) {
+ if ("seriesTitle" in eachItem) {
+ // is series
+ const CurrentTitle = NetflixJson[pageKey][ItemNumber].seriesTitle;
+ EveryWatched.push(CurrentTitle);
+ if (
+ IndividualSeries.indexOf(CurrentTitle) === -1 &&
+ CurrentTitle !== undefined
+ ) {
+ // only if not already crawled -> individualism
+ IndividualSeries.push(CurrentTitle);
+ IndividualTitles.push(CurrentTitle);
+ }
+ } else {
+ // is movie
+ const CurrentTitle = NetflixJson[pageKey][ItemNumber].videoTitle;
+ EveryWatched.push(CurrentTitle);
+ if (
+ IndividualMovies.indexOf(CurrentTitle) === -1 &&
+ CurrentTitle !== undefined
+ ) {
+ // only if not already crawled -> individualism
+ IndividualMovies.push(CurrentTitle);
+ IndividualTitles.push(CurrentTitle);
+ }
}
- // Calculate the most watched series/movies
- let TitleCount = [];
- const UnsortedTitleOccurrenceCounter = EveryWatched.reduce((prev, curr) => (prev[curr] = ++prev[curr] || 1, prev), {});
- const SortedTitleOccurrenceCounter = sortObject(UnsortedTitleOccurrenceCounter);
- const TopSeries = Object.keys(SortedTitleOccurrenceCounter)[Object.keys(SortedTitleOccurrenceCounter).length - 1];
- RenderTopSeries(TopSeries);
+ // get watch time
+ const DayTimeInSeconds = new Date(
+ NetflixJson[pageKey][ItemNumber].date * 1000
+ );
+ const DayTimeInHours = DayTimeInSeconds.getHours();
+ AverageWatchTimes.push(DayTimeInHours);
+ });
+ });
- // log
- console.table(IndividualTitles);
- console.table(IndividualSeries);
- console.table(IndividualMovies);
- console.table(AverageWatchTimeOccurrence);
- console.table(SortedTitleOccurrenceCounter);
+ const TotalSeriesWatched = IndividualSeries.length;
- RenderDayTimeChart(AverageWatchTimeOccurrence);
- RenderMostWatchedChart(SortedTitleOccurrenceCounter);
+ // Calculate watch time occurrence (average times in which the user watches sth.)
+ let AverageWatchTimeOccurrence = [];
+ const WatchTimeOccurrenceCounter = new Map(
+ [...new Set(AverageWatchTimes)].map(x => [
+ x,
+ AverageWatchTimes.filter(y => y === x).length
+ ])
+ );
+ for (let i = 0; i < 24; i++) {
+ AverageWatchTimeOccurrence.push(WatchTimeOccurrenceCounter.get(i));
}
- /**
- * Renders the day time chart
- * @param {Array} AverageWatchTimeOccurrenceArray
- */
- function RenderDayTimeChart(AverageWatchTimeOccurrenceArray) {
- var randomColorGenerator = function () {
- return '#' + (Math.random().toString(16) + '0000000').slice(2, 8);
- };
+ // Calculate the most watched series/movies
+ let TitleCount = [];
+ const UnsortedTitleOccurrenceCounter = EveryWatched.reduce(
+ (prev, curr) => ((prev[curr] = ++prev[curr] || 1), prev),
+ {}
+ );
+ const SortedTitleOccurrenceCounter = sortObject(
+ UnsortedTitleOccurrenceCounter
+ );
+ const TopSeries = Object.keys(SortedTitleOccurrenceCounter)[
+ Object.keys(SortedTitleOccurrenceCounter).length - 1
+ ];
+ RenderTopSeries(TopSeries);
- // Render day time chart
- const WatchTimeChartElement = document.getElementById("WatchTimeChart").getContext("2d");
- const WatchTimeChart = new Chart(WatchTimeChartElement, {
- type: 'line',
- data: {
- labels: ["12am", "1am", "2am", "3am", "4am", "5am", "6am", "7am", "8am", "9am", "10am", "11am", "12pm", "1pm", "2pm", "3pm", "4pm", "5pm", "6pm", "7pm", "8pm", "9pm", "10pm", "11pm"],
- datasets: [{
- label: "Watches at daytime",
- borderColor: "rgb(255, 99, 132)",
- cubicInterpolationMode: "monotone",
- pointRadius: 0,
- pointHitRadius: 15,
- data: AverageWatchTimeOccurrenceArray
- }]
- },
- options: {
- scales: {
- yAxes: [{
- ticks: {
- display: false
- },
- gridLines: {
- zeroLineColor: 'transparent',
- zeroLineWidth: 2,
- drawTicks: false,
- drawBorder: false,
- color: 'transparent'
- }
- }],
- xAxes: [{
- gridLines: {
- zeroLineColor: 'rgba(255, 255, 255, 0.25)',
- display: true,
- drawBorder: false,
- color: 'rgba(255, 255, 255, 0.25)'
- }
- }]
- },
- tension: 1
- }
- });
- }
+ // log
+ console.table(IndividualTitles);
+ console.table(IndividualSeries);
+ console.table(IndividualMovies);
+ console.table(AverageWatchTimeOccurrence);
+ console.table(SortedTitleOccurrenceCounter);
- /**
- * Renders the "most watched series" doughnut chart
- * @param {Object} TitleOccurrenceCounterObject
- */
- function RenderMostWatchedChart(TitleOccurrenceCounterObject) {
- // Render and calculate most watched chart
+ RenderDayTimeChart(AverageWatchTimeOccurrence);
+ RenderMostWatchedChart(SortedTitleOccurrenceCounter);
+ }
- const GenerateRandomColorArray = function () {
- let RandomColorArray = [];
- const Generate = function () {
- var letters = '0123456789ABCDEF'.split('');
- var color = '#';
- for (var i = 0; i < 6; i++) {
- color += letters[Math.floor(Math.random() * 16)];
- }
- return color;
- };
- for (var key in TitleOccurrenceCounterObject) {
- RandomColorArray.push(Generate());
- }
- return RandomColorArray;
- };
+ /**
+ * Renders the day time chart
+ * @param {Array} AverageWatchTimeOccurrenceArray
+ */
+ function RenderDayTimeChart(AverageWatchTimeOccurrenceArray) {
+ var randomColorGenerator = function() {
+ return "#" + (Math.random().toString(16) + "0000000").slice(2, 8);
+ };
- const MostWatchedChartElement = document.getElementById("MostWatchedChart").getContext("2d");
- var MostWatchedChartData = {
- labels: [],
- datasets: [{
- label: "Most watched",
- backgroundColor: GenerateRandomColorArray(),
- data: []
- }]
- };
- Chart.pluginService.register({
- beforeInit: function (chart) {
- var data = chart.config.data;
- for (var key in TitleOccurrenceCounterObject) {
- if (TitleOccurrenceCounterObject.hasOwnProperty(key)) {
- if (TitleOccurrenceCounterObject[key] > 2) {
- data.labels.push(key);
- data.datasets[0].data.push(TitleOccurrenceCounterObject[key]);
- }
- }
- }
+ // Render day time chart
+ const WatchTimeChartElement = document
+ .getElementById("WatchTimeChart")
+ .getContext("2d");
+ const WatchTimeChart = new Chart(WatchTimeChartElement, {
+ type: "line",
+ data: {
+ labels: [
+ "12am",
+ "1am",
+ "2am",
+ "3am",
+ "4am",
+ "5am",
+ "6am",
+ "7am",
+ "8am",
+ "9am",
+ "10am",
+ "11am",
+ "12pm",
+ "1pm",
+ "2pm",
+ "3pm",
+ "4pm",
+ "5pm",
+ "6pm",
+ "7pm",
+ "8pm",
+ "9pm",
+ "10pm",
+ "11pm"
+ ],
+ datasets: [
+ {
+ label: "Watches at daytime",
+ borderColor: "rgb(255, 99, 132)",
+ cubicInterpolationMode: "monotone",
+ pointRadius: 0,
+ pointHitRadius: 15,
+ data: AverageWatchTimeOccurrenceArray
+ }
+ ]
+ },
+ options: {
+ scales: {
+ yAxes: [
+ {
+ ticks: {
+ display: false
+ },
+ gridLines: {
+ zeroLineColor: "transparent",
+ zeroLineWidth: 2,
+ drawTicks: false,
+ drawBorder: false,
+ color: "transparent"
+ }
}
- });
- var MostWatchedChart = new Chart(MostWatchedChartElement, {
- type: 'doughnut',
- data: MostWatchedChartData,
- options: {
- animation: {
- animateScale: true
- },
- legend: {
- display: false
- }
+ ],
+ xAxes: [
+ {
+ gridLines: {
+ zeroLineColor: "rgba(255, 255, 255, 0.25)",
+ display: true,
+ drawBorder: false,
+ color: "rgba(255, 255, 255, 0.25)"
+ }
}
- });
- }
+ ]
+ },
+ tension: 1
+ }
+ });
+ }
- /**
- * Renders the top series in the DOM
- * @param {String} Title
- */
- function RenderTopSeries(Title) {
- const InformationJSON = getTitleInformation(Title, output => {
- return output;
- });
- console.table(InformationJSON);
- // TODO: Write to site/DOM + logging output
- }
+ /**
+ * Renders the "most watched series" doughnut chart
+ * @param {Object} TitleOccurrenceCounterObject
+ */
+ function RenderMostWatchedChart(TitleOccurrenceCounterObject) {
+ // Render and calculate most watched chart
- /**
- * Gets an JSON information object of the requested series/movie
- * @param {String} Title
- */
- function getTitleInformation(Title, handleFunction) {
- $.ajax({
- url: "assets/php/getInformation.php",
- data: {
- "Title": Title
- },
- type: "POST",
- }).done(function (response) {
- handleFunction(JSON.parse(response));
- });
- }
+ const GenerateRandomColorArray = function() {
+ let RandomColorArray = [];
+ const Generate = function() {
+ var letters = "0123456789ABCDEF".split("");
+ var color = "#";
+ for (var i = 0; i < 6; i++) {
+ color += letters[Math.floor(Math.random() * 16)];
+ }
+ return color;
+ };
+ for (var key in TitleOccurrenceCounterObject) {
+ RandomColorArray.push(Generate());
+ }
+ return RandomColorArray;
+ };
- /**
- * Sorts an js object by value {int}
- * @param {Object} list
- */
- function sortObject(list) {
- var sortable = [];
- for (var key in list) {
- sortable.push([key, list[key]]);
+ const MostWatchedChartElement = document
+ .getElementById("MostWatchedChart")
+ .getContext("2d");
+ var MostWatchedChartData = {
+ labels: [],
+ datasets: [
+ {
+ label: "Most watched",
+ backgroundColor: GenerateRandomColorArray(),
+ data: []
+ }
+ ]
+ };
+ Chart.pluginService.register({
+ beforeInit: function(chart) {
+ var data = chart.config.data;
+ for (var key in TitleOccurrenceCounterObject) {
+ if (TitleOccurrenceCounterObject.hasOwnProperty(key)) {
+ if (TitleOccurrenceCounterObject[key] > 2) {
+ data.labels.push(key);
+ data.datasets[0].data.push(TitleOccurrenceCounterObject[key]);
+ }
+ }
}
- sortable.sort(function (a, b) {
- return (a[1] < b[1] ? -1 : (a[1] > b[1] ? 1 : 0));
- });
- var orderedList = {};
- for (var i = 0; i < sortable.length; i++) {
- orderedList[sortable[i][0]] = sortable[i][1];
+ }
+ });
+ var MostWatchedChart = new Chart(MostWatchedChartElement, {
+ type: "doughnut",
+ data: MostWatchedChartData,
+ options: {
+ animation: {
+ animateScale: true
+ },
+ legend: {
+ display: false
}
- return orderedList;
+ }
+ });
+ }
+
+ /**
+ * Renders the top series in the DOM
+ * @param {String} Title
+ */
+ function RenderTopSeries(Title) {
+ const InformationJSON = getTitleInformation(Title, output => {
+ return output;
+ });
+ console.table(InformationJSON);
+ // TODO: Write to site/DOM + logging output
+ }
+
+ /**
+ * Gets an JSON information object of the requested series/movie
+ * @param {String} Title
+ */
+ function getTitleInformation(Title, handleFunction) {
+ $.ajax({
+ url: "assets/php/getInformation.php",
+ data: {
+ Title: Title
+ },
+ type: "POST"
+ }).done(function(response) {
+ handleFunction(JSON.parse(response));
+ });
+ }
+
+ /**
+ * Sorts an js object by value {int}
+ * @param {Object} list
+ */
+ function sortObject(list) {
+ var sortable = [];
+ for (var key in list) {
+ sortable.push([key, list[key]]);
+ }
+ sortable.sort(function(a, b) {
+ return a[1] < b[1] ? -1 : a[1] > b[1] ? 1 : 0;
+ });
+ var orderedList = {};
+ for (var i = 0; i < sortable.length; i++) {
+ orderedList[sortable[i][0]] = sortable[i][1];
}
-}); \ No newline at end of file
+ return orderedList;
+ }
+});
diff --git a/assets/php/getNetflixJson.php b/assets/php/getNetflixJson.php
index dcfc4de..3a2fbe4 100755
--- a/assets/php/getNetflixJson.php
+++ b/assets/php/getNetflixJson.php
@@ -7,23 +7,23 @@
$NetflixCookie = $_POST["Cookie"];
-$LastPage = FALSE;
+$LastPage = false;
$CurPage = 0;
$NetflixJson = "[";
-while ($LastPage === FALSE) {
- $ch = curl_init("https://www.netflix.com/api/shakti/7742b8c7/viewingactivity?pg=" . (string)$CurPage . "&pgSize=100");
+while ($LastPage === false) {
+ $ch = curl_init("https://www.netflix.com/api/shakti/7742b8c7/viewingactivity?pg=" . (string) $CurPage . "&pgSize=100");
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_setopt($ch, CURLOPT_COOKIE, $NetflixCookie);
$Result = curl_exec($ch);
//print_r((json_decode($Result, TRUE)["viewedItems"]));
//echo count(json_decode(curl_exec($ch),true)["viewedItems"]);
- if ($LastPage = count(json_decode($Result, TRUE)["viewedItems"]) > 0) {
- $LastPage = FALSE;
- $NetflixJson .= json_encode(json_decode($Result, TRUE)["viewedItems"]) . ",";
+ if ($LastPage = count(json_decode($Result, true)["viewedItems"]) > 0) {
+ $LastPage = false;
+ $NetflixJson .= json_encode(json_decode($Result, true)["viewedItems"]) . ",";
} else {
- $LastPage = TRUE;
+ $LastPage = true;
$NetflixJson = substr($NetflixJson, 0, -1);
}
@@ -31,4 +31,4 @@ while ($LastPage === FALSE) {
$CurPage++;
}
-print_r($NetflixJson . "]"); \ No newline at end of file
+print_r($NetflixJson . "]");