Merge pull request #425 from amiaopensource/rm-jquery

Remove jQuery
This commit is contained in:
Ashley 2020-05-14 08:24:18 -04:00 committed by GitHub
commit 3984c8aae3
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 93 additions and 53 deletions

View File

@ -6,8 +6,6 @@
<meta charset="utf-8"> <meta charset="utf-8">
<link rel="stylesheet" href="css/css.css"> <link rel="stylesheet" href="css/css.css">
<link rel="icon" href="img/vhs.ico"> <link rel="icon" href="img/vhs.ico">
<script src="js/jquery.min.js"></script>
<script src="js/js.js"></script>
</head> </head>
<body> <body>
@ -125,6 +123,7 @@
<li><code>.mxf</code>: Audio Codec: pcm_s16le, Video Codec: mpeg2video</li> <li><code>.mxf</code>: Audio Codec: pcm_s16le, Video Codec: mpeg2video</li>
<li><code>.wav</code>: Audio Codec: pcm_s16le (16 bit PCM)</li> <li><code>.wav</code>: Audio Codec: pcm_s16le (16 bit PCM)</li>
</ul> </ul>
<p class="link"></p>
</div> </div>
<!-- End Codec Defaults --> <!-- End Codec Defaults -->
@ -2863,5 +2862,6 @@ Change the above data-target field, the hover-over description, the button text,
<p>Made with ♥ at <a href="https://wiki.curatecamp.org/index.php/Association_of_Moving_Image_Archivists_%26_Digital_Library_Federation_Hack_Day_2015" target="_blank">AMIA #AVhack15</a>! Contribute to the project via <a href="https://github.com/amiaopensource/ffmprovisr" target="_blank">our GitHub page</a>!</p> <p>Made with ♥ at <a href="https://wiki.curatecamp.org/index.php/Association_of_Moving_Image_Archivists_%26_Digital_Library_Federation_Hack_Day_2015" target="_blank">AMIA #AVhack15</a>! Contribute to the project via <a href="https://github.com/amiaopensource/ffmprovisr" target="_blank">our GitHub page</a>!</p>
</footer> </footer>
</div><!-- ends "grid" --> </div><!-- ends "grid" -->
<script src="js/js.js"></script>
</body> </body>
</html> </html>

4
js/jquery.min.js vendored

File diff suppressed because one or more lines are too long

118
js/js.js
View File

@ -1,52 +1,96 @@
$(document).ready(function() { function scrollTo(element, to, duration) {
var start = element.scrollTop,
change = to - start,
currentTime = 0,
increment = 20;
function appendLink(id) { var animateScroll = function(){
$(id).next('div').find('.link').empty(); currentTime += increment;
$(id).next('div').find('.link').append("<small>Link to this command: <a href='https://amiaopensource.github.io/ffmprovisr/index.html" + id + "'>https://amiaopensource.github.io/ffmprovisr/index.html" + id + "</a></small>"); var val = Math.easeInOutQuad(currentTime, start, change, duration);
element.scrollTop = val;
if(currentTime < duration) {
setTimeout(animateScroll, increment);
} }
}
animateScroll()
}
function moveToRecipe(id) { //t = current time, b = start value, c = change in value, d = duration
document.getElementById(id.substring(1)).checked = true; Math.easeInOutQuad = function (t, b, c, d) {
$('html, body').animate({ scrollTop: $(id).offset().top }, 1000); t /= d/2;
if (t < 1) return c/2*t*t + b;
t--;
return -c/2 * (t*(t-2) - 1) + b;
}
function appendLink(id) {
const link = document.getElementById(id).nextElementSibling.querySelector('.link')
if (link) {
link.innerHTML = ("<small>Link to this command: <a href='https://amiaopensource.github.io/ffmprovisr/index.html#" + id + "'>https://amiaopensource.github.io/ffmprovisr/index.html#" + id + "</a></small>")
}
}
function moveToRecipe(id) {
document.getElementById(id).checked = true;
scrollTo(document.body, 0, 1000);
appendLink(id) appendLink(id)
} }
// open recipe window if a hash is found in URL // open recipe window if a hash is found in URL
if (window.location.hash) { if (window.location.hash) {
id = window.location.hash id = window.location.hash.slice(1)
moveToRecipe(id) moveToRecipe(id)
} }
// add hash URL when recipe is opened // add hash URL when recipe is opened
$('label[class="recipe"]').on("click", function(){ const recipes = document.querySelectorAll('label[class="recipe"]')
id = $(this).attr("for"); recipes.forEach(function(item, i){
window.location.hash = ('#' + id) item.addEventListener("click", function(){
appendLink('#' + id) id = this.getAttribute("for");
window.location.hash = (id)
appendLink(id)
}) })
})
// open recipe when clicked
$('a').on("click", function(){ // open recipe when clicked
intralink = $(this).attr("href") const links = document.querySelectorAll('a')
links.forEach(function(item, i){
item.addEventListener("click", function(){
intralink = this.getAttribute("href")
if (intralink[0] == "#") { if (intralink[0] == "#") {
moveToRecipe(intralink) moveToRecipe(intralink.substring(1))
} }
}) })
})
// Collapse all recipes when button is clicked
$('#toggle-expand-collapse-all').on("click", function(){
var checkboxes = $('input[type=checkbox]');
var anyRecipesOpen = $(checkboxes).is(':checked');
if (anyRecipesOpen) { function getCheckedBoxes(checkboxes) {
var checkboxesChecked = [];
for (var i = 0; i < checkboxes.length; i++) {
if (checkboxes[i].checked) {
checkboxesChecked.push(checkboxes[i]);
}
}
return checkboxesChecked.length > 0 ? checkboxesChecked : null;
}
// Collapse all recipes when button is clicked
document.getElementById('toggle-expand-collapse-all').addEventListener("click", function(){
const checkboxes = document.querySelectorAll('input[type=checkbox]')
var checked = getCheckedBoxes(checkboxes);
if (checked) {
// Collapse all // Collapse all
$('input[type=checkbox]').each(function() { document.querySelectorAll('input[type=checkbox]').forEach(function(item, i){
this.checked = false; item.checked = false;
}); })
} else new Promise(function(resolve, reject) { } else {
// Expand all // Expand all
$('input[type=checkbox]').each(function() { document.querySelectorAll('input[type=checkbox]').forEach(function(item, i){
this.checked = true; item.checked = true;
}); })
}); }
}); })
});