104 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			104 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| // Selected = is clicked sport selected or not, BOOL
 | |
| // Sports = all selected sports, ARRAY
 | |
| $(".sport").on("selected", function(e, selected, sports) {
 | |
|     console.log(selected, sports);
 | |
|     filters.sports = sports;
 | |
|     $(window).trigger("filter");
 | |
| })
 | |
| 
 | |
| window.addEventListener('DOMContentLoaded', (event) => {
 | |
|     window.sessionStorage.setItem('tweets', JSON.stringify([]));
 | |
|     // run code every 5 seconds
 | |
|     setInterval(function() {
 | |
|         $(window).trigger("filter");
 | |
|     }, 1000);
 | |
| });
 | |
| 
 | |
| $(".sport").on("click", function() {
 | |
|     $(this).toggleClass("selected")
 | |
| 
 | |
|     let sportName = $(this).children()[1].innerHTML // 2nd element, which is the sport name
 | |
| 
 | |
|     
 | |
|     let index = selectedSports.indexOf(sportName)
 | |
|     if (index > -1 ) {  // If element is found in array
 | |
|         selectedSports.splice(index, 1) // Remove sport at index
 | |
|     } else {
 | |
|         selectedSports.push(sportName)  // Add sport to array
 | |
|     }
 | |
| 
 | |
|     $(this).trigger("selected", [selectedSports.includes(sportName), selectedSports]) // Trigger event
 | |
|     showFeeds()
 | |
| })
 | |
| 
 | |
| $(window).on("resize", function(){
 | |
|     showFeeds()
 | |
| });
 | |
| 
 | |
| $(window).on("load", function() {
 | |
|     showFeeds()
 | |
| })
 | |
| 
 | |
| $(".sortby").on("click", function() {
 | |
|     $(".sort-dropdown").toggle()
 | |
|     // $(".sort-btn").toggleClass("radius-bottom")
 | |
| }) 
 | |
| 
 | |
| $(".sort-dropdown-list li").on("click", function() {
 | |
|     $(".sort-dropdown").toggle()
 | |
| })
 | |
| 
 | |
| let root = document.querySelector(":root")
 | |
| 
 | |
| $(".logo").on("click", function() {
 | |
|     if (root.style.getPropertyValue("--main-bg") === 'snow') {
 | |
|         console.log("IM here")
 | |
|         root.style.setProperty('--main-medium-dark', '#1E1E1E');
 | |
|         root.style.setProperty('--main-bg', '#292929');
 | |
|         root.style.setProperty('--main-light', ' #ffffff' );
 | |
|         root.style.setProperty('--main-dark', '#ffffff');
 | |
|         root.style.setProperty('--tweet-color', '#000000')
 | |
|         root.style.setProperty('--column-color', '#1E1E1E')
 | |
|     } else {
 | |
|         root.style.setProperty('--main-medium-dark', '#1D9BF0');
 | |
|         root.style.setProperty('--main-bg', 'snow');
 | |
|         root.style.setProperty('--main-light', '#000000');
 | |
|         root.style.setProperty('--main-dark', ' #000000');
 | |
|         root.style.setProperty('--tweet-color', 'whitesmoke');
 | |
|         root.style.setProperty('--column-color', 'rgba(112, 128, 144, 0.388');
 | |
|     }
 | |
| })
 | |
| 
 | |
| $(window).on("filter", function() {
 | |
|     console.log("called")
 | |
|     var parent = document.querySelector("#filtered")
 | |
|     parent.replaceChildren();
 | |
| 
 | |
|     console.log(filters);
 | |
| 
 | |
|     tweets = window.sessionStorage.getItem('tweets');
 | |
|     tweets = JSON.parse(tweets);
 | |
|     console.log(tweets.length)
 | |
|     tweets = filterTweets(tweets, filters.blockedWords, filters.searchedWords.concat(filters.sports), filters.sorted, filters.order);
 | |
|     tweets = sortTweets(tweets);
 | |
|     var displayTweets = tweets.reverse().slice(0, 20).reverse();
 | |
|     for (i = 0; i < 19; i++){
 | |
|         console.log("FDS")
 | |
|         parent.prepend(tweetCell(displayTweets[i]));
 | |
|         console.log("FDS 2")
 | |
|     }
 | |
| })
 | |
| 
 | |
| 
 | |
| $(".order-btn").on("click", function() {
 | |
|     if($(this).html() == "arrow_downward") {    // Descending to ascending
 | |
|         $(this).html("arrow_upward")
 | |
|         // trigger an event called ascending
 | |
|         $(window).trigger("ascending")
 | |
|     } else {    // Ascending to descending
 | |
|         $(this).html("arrow_downward")
 | |
|         // trigger an event called descending
 | |
|         $(window).trigger("descending")
 | |
|     }
 | |
| })
 |