diff options
-rw-r--r--[-rwxr-xr-x] | assets/css/main.css | 80 | ||||
-rw-r--r-- | assets/css/main.css.map | 9 | ||||
-rw-r--r-- | assets/css/main.sass | 81 | ||||
-rwxr-xr-x | assets/js/main.js | 571 | ||||
-rwxr-xr-x | assets/php/getNetflixJson.php | 16 |
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 . "]"); |