SimonBHB

Permet d'ouvrir un fichier vidéo avec VLC facilement

May 28th, 2020
1,490
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
  1. // ==UserScript==
  2. // @name         VLC
  3. // @namespace    http://tampermonkey.net/
  4. // @version      3.0
  5. // @description  Permet de copier/lire des videos facilement. Pour VLC cela copie dans le press papier une commande et en faisant Windows + R cela ouvre VLC avec le film directement. Tester sous Google Chrome
  6. // @author       Simon
  7. // @match        http://*/*
  8. // @match        https://*/*
  9. // @require http://code.jquery.com/jquery-latest.js
  10. // @require https://cdnjs.cloudflare.com/ajax/libs/jStorage/0.4.12/jstorage.min.js
  11. // @grant    GM_addStyle
  12. // ==/UserScript==
  13.  
  14. // Je n'ai pas trouvé de CDN pour jnotify:
  15. (function(B){B.jnotify=function(L,N,M){return new C(L,N,M)};B.jnotify.version="1.3.01";var K,G=0,D=[],F=0,I=false,J=false,E,A={type:"",delay:2000,sticky:false,clickToDismiss:true,closeLabel:"&#x2716;",showClose:true,fadeSpeed:250,slideSpeed:250,classContainer:"jnotify-container",classNotification:"jnotify-notification",classDismissible:"jnotify-dismissible",classBackground:"jnotify-background",classClose:"jnotify-close",classMessage:"jnotify-message",init:null,create:null,beforeRemove:null,remove:null,transition:null};B.jnotify.setup=function(L){A=B.extend({},A,L)};B.jnotify.play=function(N,O){if(I&&(N!==true)||(D.length==0)){return }I=true;var M=D[0];var L=(arguments.length>=2)?parseInt(O,10):M.options.delay;E=setTimeout(function(){E=0;M.remove(function(){if(D.length==0){I=false}else{if(!J){B.jnotify.play(true)}}})},L)};B.jnotify.pause=function(){clearTimeout(E);J=I=true};B.jnotify.resume=function(){J=false;B.jnotify.play(true,0)};function H(N,M,L,O){if("delegate" in jQuery.fn){N.delegate(L,M,O)}else{N.on(M,L,O)}}function C(S,T){var R=this,L=typeof T;if(L==="number"){T=B.extend({},A,{delay:T})}else{if(L==="boolean"){T=B.extend({},A,{sticky:true})}else{if(L==="string"){var P=T;T=B.extend({},A,{type:P});if((arguments.length>2)&&((typeof arguments[2]!=="undefined")||(arguments[2]!=null))){if(typeof arguments[2]=="number"){T.delay=arguments[2]}else{if(typeof arguments[2]=="boolean"){T.sticky=arguments[2]}}}else{if(P==="error"){T.sticky=true}}}else{T=B.extend({},A,T)}}}this.id=F++;this.options=T;if(!K){K=B('<div class="'+A.classContainer+'" />').appendTo("body");if(B.isFunction(T.init)){T.init.apply(R,[K])}function Q(U){var V=U.data("jnotify");V.remove()}H(K,"click.jnotify","a."+T.classClose,function(U){Q(B(U.currentTarget).closest("."+T.classNotification))});H(K,"click.jnotify","div."+T.classDismissible,function(U){Q(B(U.currentTarget))})}function M(W){var V='<div class="'+T.classNotification+(T.type.length?(" "+T.classNotification+"-"+T.type):"")+(T.clickToDismiss?(" "+T.classDismissible):"")+'"><div class="'+T.classBackground+'"></div>'+(T.sticky&&T.showClose?('<a class="'+T.classClose+'">'+T.closeLabel+"</a>"):"")+'<div class="'+T.classMessage+'"><div>'+W+"</div></div></div>";var U=B(V);U.data("jnotify",R);U.appendTo(K);if(B.isFunction(T.create)){T.create.apply(R,[U,K])}G++;return U}function O(V){for(var U=0;U<D.length;U++){if(V.id===D[U].id){D.splice(U,1);break}}}this.remove=function(X){var U=N.find("."+T.classMessage),V=U.parent();O(R);G--;if(B.isFunction(T.beforeRemove)){T.beforeRemove.apply(R,[U])}function W(){V.remove();if(B.isFunction(X)){setTimeout(function(){X.apply(R,[U])},1)}if(B.isFunction(T.remove)){setTimeout(function(){T.remove.apply(R,[U])},1)}}if(B.isFunction(T.transition)){T.transition.apply(R,[V,U,D.length-1,W,T])}else{U.fadeTo(T.fadeSpeed,0.01,function(){if(G===0){W()}else{V.slideUp(T.slideSpeed,W)}});if(G<=0){V.fadeOut(T.fadeSpeed)}}};var N=M(S);if(!T.sticky){D.push(this);B.jnotify.play()}return this}})(jQuery);
  16.  
  17. // Le CSS de jnotify:
  18. GM_addStyle ( `
  19. div.jnotify-container{position:fixed;top:0;left:0;width:100%;z-index:100000;}div.jnotify-container div.jnotify-notification{position:relative;}div.jnotify-container div.jnotify-notification div.jnotify-background{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#e3f0db;filter:alpha(opacity=90);-moz-opacity:.90;opacity:.90;z-index:1;}div.jnotify-container div.jnotify-notification a.jnotify-close,div.jnotify-container div.jnotify-notification a.jnotify-close:link,div.jnotify-container div.jnotify-notification a.jnotify-close:visited,div.jnotify-container div.jnotify-notification a.jnotify-close:focus,div.jnotify-container div.jnotify-notification a.jnotify-close:hover{position:absolute;top:2px;right:5px;padding:0 5px;font:bold 1.4em Verdana,Arial,Helvetica,sans-serif;line-height:1em;color:#567b1b;text-decoration:none;z-index:3;cursor:pointer;}div.jnotify-container div.jnotify-notification div.jnotify-message{position:relative;z-index:2;padding:20px;text-align:center;color:#567b1b;font:bold 1.4em Verdana,Arial,Helvetica,sans-serif;line-height:1.2em;}div.jnotify-container div.jnotify-notification div.jnotify-message *{font:inherit;font-size:1em;}div.jnotify-container div.jnotify-notification-error div.jnotify-background{background-color:#e4abb9;}
  20. div.jnotify-container div.jnotify-notification-error a.jnotify-close,div.jnotify-container div.jnotify-notification-error div.jnotify-message{color:#a72947!important;}div.jnotify-container div.jnotify-notification-warning div.jnotify-background{background-color:#fff7d1;}div.jnotify-container div.jnotify-notification-warning a.jnotify-close,div.jnotify-container div.jnotify-notification-warning div.jnotify-message{color:#c2a928!important;}
  21. ` );
  22.  
  23. // image en base64
  24. // On va afficher un icône VLC a la place du vrai icone du site:
  25. var imgVLC = "";
  26.  
  27. // Icône pour pour copier le lien:
  28. var imgCopier = "";
  29.  
  30. // Icône pour lancer le film sur la page:
  31. var imgLecture = "";
  32.  
  33. (function() {
  34.     'use strict';
  35.     $(document).ready(function() {
  36.         // URL de base du site:
  37.         var baseUrl = "http://" + document.location.hostname;
  38.  
  39.         // URL de l'image du du site:
  40.         var urlIMGMovie = "/icons/movie.gif";
  41.         var urlIMGSound2 = "/icons/sound2.gif";
  42.  
  43.         var title = $('title').html();
  44.  
  45.         // On sépare tout les mots du titre:
  46.         var splitTitle = $('title').html().split(" ");
  47.  
  48.         var pathFile = "";
  49.         for (let i = 2; i < splitTitle.length; i++) {
  50.             if(i > 2) {
  51.                 pathFile += "%20";
  52.             }
  53.             pathFile += splitTitle[i];
  54.         }
  55.         pathFile += "/";
  56.         //console.log(pathFile);
  57.  
  58.         // Prenait pas en compte les espaces:
  59.         //var pathFile1 = $("h1").text().split(" ")[2] + "/";
  60.         //console.log(pathFile1);
  61.  
  62.         // Si 3 mots ou plus:
  63.         if(splitTitle.length >= 3) {
  64.             // On regarde les deux premier mot de la page. Si ça commence par ces deux mots c'est une page qu'on recherche:
  65.             if(splitTitle[0] == 'Index' && splitTitle[1] == 'of') {
  66.                 // Chemin vers VLC(peut ne pas exister:
  67.                 var vlc = $.jStorage.get("vlc");
  68.  
  69.                 // Formulaire VLC:
  70.                 $("table").append('<tr><td colspan="6"><input id="vlc" placeholder="Path/vers/vlc.exe"><br><br><span id="submit" style="margin:5px;padding:5px;border-radius: 10px;box-shadow: 0px 0px 10px #000000;opacity: 0.9;background-color:#F1F1F1;">Envoyer</span></td></tr>');
  71.  
  72.                 // Pour calculer la durée de la vidéo en seconde:
  73.                 $("table").append('<tr><td colspan="6"><hr><input class="heure_calc" placeholder="heure"><input class="minute_calc" placeholder="minute"><input class="seconde_calc" placeholder="seconde">: Résultat: <input class="result_clc" placeholder="resultat"></td></tr>');
  74.  
  75.                 // Pour le dev j'affiche les bordure du tableau:
  76.                 //$("table").attr("border", "1");
  77.  
  78.                 $("html").css('background-color', "#F1F1F1");
  79.  
  80.                 // On boucle sur les lignes du tableau de la page:
  81.                 $.each($('tr'), function(key, value) {
  82.                     // On rajoute un titre a notre colonne sur la première ligne autrement elle en a pas:
  83.                     if(key == 0) {
  84.                         $(value).append('<th>Start Time</th>');
  85.                     }
  86.  
  87.                     // On agrandit la petite barre hr sur la seconde ligne et la dernière ligne vu qu'on rajoute une colonne:
  88.                     if(key == 1 || key == $("tr").length-3) {
  89.                         value.innerHTML = '<th colspan="6"><hr></th>';
  90.                     }
  91.  
  92.                     // On prend les lignes qui contiennent des fichiers sauf les lignes qui peuvent pas en contenir:
  93.                     if(key > 2 && key < $("tr").length-1) {
  94.                         $.each(value.cells, function(key2, value2 ) {
  95.                             if(key2 == 0) {
  96.                                 // On regarde qu'elle type de fichier on a:
  97.                                 if($(value2.innerHTML).attr("src") == urlIMGMovie || $(value2.innerHTML).attr("src") == urlIMGSound2) {
  98.                                     // Le nom du fichier:
  99.                                     var fileName = $(value.cells[1].innerHTML).attr("href");
  100.  
  101.                                     // On crée un lien absolue:
  102.                                     var url = baseUrl + pathFile + fileName;
  103.  
  104.                                     // On param la durée par défaut ou celle stockée:
  105.                                     var duree = "0";
  106.                                     if($.jStorage.get(url) == null) {
  107.                                         $.jStorage.set(url, 0);
  108.                                     } else {
  109.                                         duree = $.jStorage.get(url);
  110.                                     }
  111.  
  112.                                     // On affiche une colonne avec la durée:
  113.                                     $(value).append('<td><input class="data_duree" value="' + duree + '" data-url="' + url + '" style="width:115px;" placeholder="Durée en seconde"></td>');
  114.  
  115.                                     // On va afficher l'image de VLC seulement si on a un path:
  116.                                     var textVLC = '';
  117.                                     if(vlc != null) {
  118.                                         textVLC = '<img src="' + imgVLC + '" alt="[VID]">';
  119.                                     } else {
  120.                                         //console.log("pas de vlc");
  121.                                     }
  122.  
  123.                                     // On affiche les images:
  124.                                     value2.innerHTML = textVLC + ' <img class="view" style="width:18px;" src="' + imgLecture + '"> <img class="copy" style="width:26px;" src="' + imgCopier + '">';
  125.                                 }
  126.                             }
  127.                         });
  128.                         //console.log("--------------------");
  129.                     }
  130.                 });
  131.  
  132.  
  133.                 $(".copy").click(function(){
  134.                     var urlNew = baseUrl + pathFile + $(this).parent().next().children('a').attr("href");
  135.  
  136.                     // On va copier les infos dans le press papier:
  137.                     var $temp = $("<input>");
  138.                     $.jnotify('Lien copié ', 'notice', {timeout: 2});
  139.                     $(this).parent().append($temp);
  140.                     $temp.val(urlNew).select();
  141.                     document.execCommand("copy");
  142.                     $temp.remove();
  143.                 });
  144.  
  145.                 $("#vlc").attr("value", vlc);
  146.                 $("img").click(function(){
  147.                     if($(this).attr("src") == imgVLC) {
  148.                         var urlNew = baseUrl + pathFile + $(this).parent().next().children('a').attr("href");
  149.  
  150.                         // On va copier les infos dans le press papier:
  151.                         var $temp = $("<input>");
  152.                         $.jnotify('Lien avec VLC copié', 'notice', {timeout: 2});
  153.                         $(this).parent().append($temp);
  154.                         $temp.val(vlc + " " + urlNew + " --start-time " + $.jStorage.get(urlNew)).select();
  155.                         document.execCommand("copy");
  156.                         $temp.remove();
  157.                     }
  158.                 });
  159.  
  160.                 // Affiche le lecteur vidéo:
  161.                 $(".view").click(function(){
  162.                     var urlNew = baseUrl + pathFile + $(this).parent().next().children('a').attr("href");
  163.  
  164.                     var myWindow = window.open("", "MsgWindow", "width=808,height=468");
  165.                     myWindow.document.clear();
  166.                     myWindow.document.write('<div id="video_container"><video id="video" controls autoplay width="800"><source src="' + urlNew + '#t=' + $.jStorage.get(urlNew) + '" type="video/mp4" id="mp4"><p>Votre navigateur ne prend pas en charge les vidéos HTML5.</p></video></div>');
  167.                 });
  168.  
  169.                 //$(".close_lecteur").click(function(){
  170.                 //    $.jnotify('Durée ou a été arrêté la vidéo: ' + $('#video_container').find('video').get(0).currentTime + ' secondes' , 'notice', {timeout: 2});
  171.                 //});
  172.  
  173.                 // Enregistre la durée voulu:
  174.                 $(".data_duree").keyup(function(event){
  175.                     console.log(event.which + " " + $(this).val() + " " + $(this).data('url'));
  176.                     $.jStorage.set($(this).data('url'), $(this).val());
  177.                 });
  178.  
  179.                 $("#submit").click(function(){
  180.                     console.log("submit");
  181.                     $.jStorage.set("vlc", $("#vlc").val());
  182.                     // On recharge la page pour avoir les infos a jour:
  183.                     document.location.reload(true);
  184.                 });
  185.  
  186.  
  187.                 $(".heure_calc").keyup(function(event){
  188.                     var heure = new Number($(this).val());
  189.                     var minute = new Number($(".minute_calc").val());
  190.                     var seconde = new Number($(".seconde_calc").val());
  191.                     var calc = (heure*3600) + (minute*60) + seconde
  192.                     //console.log(event.which + " " + $(this).val());
  193.                     console.log(calc);
  194.                     $(".result_clc").val(calc);
  195.                 });
  196.  
  197.                 $(".minute_calc").keyup(function(event){
  198.                     var heure = new Number($(".heure_calc").val());
  199.                     var minute = new Number($(this).val());
  200.                     var seconde = new Number($(".seconde_calc").val());
  201.                     var calc = (heure*3600) + (minute*60) + seconde
  202.                     //console.log(event.which + " " + $(this).val());
  203.                     console.log(calc);
  204.                     $(".result_clc").val(calc);
  205.                 });
  206.  
  207.                 $(".seconde_calc").keyup(function(event){
  208.                     var heure = new Number($(".heure_calc").val());
  209.                     var minute = new Number($(".minute_calc").val());
  210.                     var seconde = new Number($(this).val());
  211.                     var calc = (heure*3600) + (minute*60) + (seconde);
  212.                     //console.log(event.which + " " + $(this).val());
  213.                     console.log(calc);
  214.                     $(".result_clc").val(calc);
  215.                 });
  216.             }
  217.         }
  218.     });
  219. })();
  220. // E:\VideoLAN\vlc\vlc.exe
Add Comment
Please, Sign In to add comment