Save watched episodes
Opened this issue ยท 8 comments
At first; thanks for building this website!
It would be awesome if you could save the episodes you've watched. Just with an selectbox before each episode. It would already be good if it's stored in LocalStorage. This should be easy to build. Also storing applied filters would be very useful.
Hey @AndreasFurster, thank you for the feedback. The LocalStorage
solution is definitely easy enough to implement. This is something I'll prioritize and get to in the near future ๐
Really, For those that thumbed it down, you know it would help more if you actually said why! Otherwise you are just being nonconstructive!
I would like to start by saying, love the site. It has been very helpful and is the best list I have found out there by far.
So I know this has been a long time since this has been posted,
so I took some time to put a script together.,
I have attached the file of the jquery script I wrote that will be at the bottom of this post to help with this problem, if only temporary.
Either you @AceFire6 can add this where you want it for everyone,
OR @AndreasFurster you can use this script in the command console of your web browser or have some sort of script running extension like tampermonkey to run it automatically when you visit the page.
There is a limitation to the saving since it uses cookies and there is a max on the size it can only store about 160 for you, I note this in the code in detail, but best to just check the ones you are currently working on, since the other part is not going to be showing on your screen anyway. The only workaround for this would be to have some sort of server side storage database, like MySQL. Even then, this code would still be viable using a AJAX request method added to the code.
Note, make sure if you use tampermonkey you have all the matches possible, like this:
// ==UserScript==
// @name Arrowverse Episode Order
// @namespace http://tampermonkey.net/
// @Version 0.1
// @description Adds Watched Checkmarks to the page
// @author ajsmith21 (github.com/ajsmith21)
// @match https://flash-arrow-order.herokuapp.com/*
// @match https://flash-arrow-order.herokuapp.com/?*
// @match https://flash-arrow-order.herokuapp.com*
// @match http://flash-arrow-order.herokuapp.com/*
// @match http://flash-arrow-order.herokuapp.com/?*
// @match http://flash-arrow-order.herokuapp.com*
// @match https://arrowverse.info*
// @match https://arrowverse.info/*
// @match https://arrowverse.info/?*
// @match http://arrowverse.info*
// @match http://arrowverse.info/*
// @match http://arrowverse.info/?*
// @grant none
// ==/UserScript==
Hi @ajsmith21
I did not downvote you're script, but I also did not start using it.
First I would like to say that it is great you are trying to contribute! I could have done it myself then, but I did not took the time to do it. You did. You definitely deserve feedback. I think there are a couple of reasons why your contribution is down-voted.
For starters, it is an external script to run in things like Tampermonkey. This adds a whole other requirement for using the arrowverse website.
Even if the script is added to the website directly, it is still an external script. The script does stuff like disabling and re-enabling event handlers (line 53 and 230). This is completely unnecessary if the code was directly integrated into the website.
Then the script... The code is ok. You know how jQuery works, and you've added comments. It's the logic that is extremely over-complicated. Think about it... Wat are actually the requirements of this feature? If I had to create a summary, I would say something like this: "Add an checkbox to each table row, and sync it's state in localStorage/cookies". Do we really need 260 lines of code for that? If we do, we are probably doing things wrong.
One other example; at line 219 you say "Now this part is just stolen from you code and...". You cannot do that. Because if the code is changed in the arrowverse project, your code isn't changed with it.
If you want, and @AceFire6 is ok with it, you can fork the project, and we could implement this feature into the project the right way.
Oh, I know you did not downvote it. Some people just did without feedback, which is what would have been helpful.
And on the note of the feedback you just gave, thank you very much for it. This helps a lot. This is the constructive criticism that I was looking for. I like to know what I did wrong, and how people think I could fix it.
The use of tampermonkey was just a suggestion, if someone wanted to implement it themselves before a feature like this was added to the site.
I will agree, there is probably a much shorter way to implement this. The code is far from refined.
I am trying to understand your comment on line 219, I don't really understand what you are trying to say about that, can you please elaborate?
As for the fork, I have to be honest, I am still trying to get used to how github works (actually all online code repositories for that matter).
So I don't even know where to start, I just haven't taken the time to learn it yet.
And again, thank you very much for the feedback!
I will take a look at my code here again soon and see about doing something about some of the stuff you mentioned when I have a moment.
This is actually the first time I have written any code that has made use of cookies, I have never had reason to use them. I have also always had a back end database running on all my projects I have ever worked on.
I'm glad you received it well ๐!
I will agree, there is probably a much shorter way to implement this. The code is far from refined.
It's not really about how long or how short, just about how complicated it is. And a lot of it (if not all) will be solved by integrating it into the project.
I am trying to understand your comment on line 219...
You should try to prevent code duplication. Especially in an external script. If for example we want to save each wiki open to Google Analytics in the feature, the current script will override that action. This because it removes the event handler and creates a complete new one. This is not a great example and I don't see more cases in the script, but I wanted to mention it as feedback.
As for the fork, I have to be honest, I am still trying to get used to how github works (actually all online code repositories for that matter).
So I don't even know where to start, I just haven't taken the time to learn it yet.
I highly recommend this series from The Coding Train.
The first 4 episodes give a great introduction into source control and Github.
@AndreasFurster, I see why I removed and re-added that event handler, It was due to the fact that the event handler that did exists applied to the entire row when clicked on would open a new tab that went to the wiki. So I needed to replace it to only do that when clicking on the other columns of the row not the check mark portion. I agree this is not the best practice but in having no access to the base code I needed a way to control this. You are right tho, this is part of my code that would definitely need to be changed if it was to be used, along with the original event handler.
Also, thank you so much for the Training Series, I will watch this as soon as I can!
:D
Just wanted to bump and see if this is still in your roadmap? I'm trying to avoid making my own version of this, in a different language I'd contribute to add it but I'm not savvy enough with Python to meaningfully add in the feature.
Any update on this one?
Seems a pull request was made for it but never made it in?