diff --git a/public/JS/example.app.js b/public/JS/example.app.js index 772e2bc..7ec4ed0 100644 --- a/public/JS/example.app.js +++ b/public/JS/example.app.js @@ -98,13 +98,26 @@ __webpack_require__.r(__webpack_exports__); /* harmony import */ var _vCarousel_ts__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./vCarousel.ts */ "./src/vCarousel.ts"); /// Exemple d'utilisation de vCarousel avec 3 vidéos -// Fournir ici la liste de contenants (div, figure...) des vidéos à faire défiler -// L'ordre est celui de défilement et peut être différent de celui de la page HTML -// La même vidéo peut même être listé plusieurs fois... -// La première entrée correspondant à la vidéo affichée au premier chargement de la page -var videosContainers = ["vFunanbule", "vForgeron", "vCircuit"]; try { - Object(_vCarousel_ts__WEBPACK_IMPORTED_MODULE_0__["vCarousel"])(videosContainers); + // Liste des id des contenants des vidéos à afficher : + var videosContainers_1 = ["vFunanbule", "vForgeron", "vCircuit"]; + // Si un id est fourni par l'url, on affiche cette vidéo en premier : + var wantedVideo_1 = ""; + if (window.location.hash !== undefined) + wantedVideo_1 = window.location.hash.replace("#", ""); + Object(_vCarousel_ts__WEBPACK_IMPORTED_MODULE_0__["vCarousel"])(videosContainers_1, wantedVideo_1); + // Dans le cas où l'utilisateur clique pour sélectionner une vidéo à afficher, on actualise l'affichage : + var selectLinks = document.querySelectorAll(".selectVideo"); + var _loop_1 = function (i) { + var link = selectLinks[i]; + link.addEventListener("click", function (e) { + wantedVideo_1 = link.hash.replace("#", ""); + Object(_vCarousel_ts__WEBPACK_IMPORTED_MODULE_0__["vCarousel"])(videosContainers_1, wantedVideo_1); + }); + }; + for (var i = 0; i < selectLinks.length; i++) { + _loop_1(i); + } } catch (e) { console.error(e); @@ -123,44 +136,64 @@ catch (e) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "vCarousel", function() { return vCarousel; }); -/// La fonction reçoit un tableau d'ids de conteneurs contenant les vidéos à afficher successivement -/// Attention : les vidéos à afficher ne sont pas dédoublonnées, car on peut souhaiter afficher plusieurs fois la même vidéo durant un tour du carrousel -var vCarousel = function (vContainers) { - // On commence par vérifier que les ids de conteneurs fournis sont correctes +/// La fonction vCarousel reçoit un tableau d'ids des conteneurs HTML des vidéos à afficher successivement. +/// Le tableau n'est pas dédoublonné, pour reste libre d'afficher plusieurs fois la même vidéo durant un tour du carrousel +/// On peut éventuellement fournir l'id de la première vidéo à afficher. +var vCarousel = function (vContainers, firstVideoId) { + if (firstVideoId === void 0) { firstVideoId = ""; } + // On commence par vérifier que les ids de conteneurs fournis sont correctes. + // C'est-à-dire qu'il s'agit bien d'éléments HTML contenant au moins une vidéo. var realVContainers = []; for (var _i = 0, vContainers_1 = vContainers; _i < vContainers_1.length; _i++) { - var container = vContainers_1[_i]; - var checkContainerExist = document.getElementById(container); - if (checkContainerExist === null) // utiliser fonctionner empty() de wikilerni ? - console.error("Aucun élément HTML trouvé dans la page pour l'id " + container); + var containerId = vContainers_1[_i]; + var checkContainerExist = document.getElementById(containerId); + if (checkContainerExist === null) + console.error("Aucun élément HTML trouvé dans la page pour l'id fourni " + containerId); else { - var checkVideoExist = document.querySelector("#" + container + " video"); // tester avec + plusieurs vidéos dans le conteneur + var checkVideoExist = document.querySelector("#" + containerId + " video"); if (checkVideoExist === null) - console.error("Aucune balise vidéo trouvée dans l'élément HTML ayant comme id " + container); + console.error("Aucune balise vidéo trouvée dans l'élément HTML ayant comme id " + containerId); else - realVContainers.push({ idContainer: container, containerElt: checkContainerExist, videoElt: checkVideoExist }); + realVContainers.push({ id: containerId, containerElt: checkContainerExist, videoElt: checkVideoExist }); } } - var nbContainers = realVContainers.length; - if (nbContainers < 2) + // Si firstVideoId a été fourni, on vérifie aussi qu'il est valide. + if (firstVideoId !== "" && (realVContainers.findIndex(function (video) { return video.id === firstVideoId; }) === -1)) { + console.error("Vous avez fourni l'id de la vidéo à afficher en premier (" + firstVideoId + "), mais il n'est pas valide."); + firstVideoId = ""; + } + // Il doit rester au moins deux vidéos + var nbVContainers = realVContainers.length; + if (nbVContainers < 2) console.error("Il faut fournir au moins deux conteneurs valides pour faire tourner le carrousel."); else { var _loop_1 = function (i) { - var container = realVContainers[i].containerElt; + var vContainer = realVContainers[i].containerElt; var video = realVContainers[i].videoElt; - if (i !== 0) - container.style.display = "none"; + if ((firstVideoId !== "" && realVContainers[i].id !== firstVideoId) || (firstVideoId == "" && i !== 0)) + vContainer.style.display = "none"; + else + vContainer.style.display = "block"; // nécessaire dans le cas d'un réaffichage video.addEventListener("ended", function () { - container.style.display = "none"; - var nextContainer; - if (i < (nbContainers - 1)) - nextContainer = realVContainers[i + 1].containerElt; - else - nextContainer = realVContainers[0].containerElt; - nextContainer.style.display = "block"; + vContainer.style.display = "none"; + var nextVContainer, nextHash; + if (i < (nbVContainers - 1)) { + nextVContainer = realVContainers[i + 1].containerElt; + nextHash = realVContainers[i + 1].id; + } + else { + nextVContainer = realVContainers[0].containerElt; + nextHash = realVContainers[0].id; + } + nextVContainer.style.display = "block"; + // On adapte l'ancre de l'url de manière à ce qu'elle soit cohérente avec la vidéo affichée + // Attention car cela peut provoquer un déplacement dans la page la première fois pour atteindre l'ancre (à revoir) + window.location.assign("#" + nextHash); }); }; - for (var i = 0; i < nbContainers; i++) { + // Tous les conteneurs sont cachés, sauf celui demandé + // La fin de lecture d'une vidéo provoque l'affichage du suivant + for (var i = 0; i < nbVContainers; i++) { _loop_1(i); } } @@ -170,4 +203,4 @@ var vCarousel = function (vContainers) { /***/ }) /******/ }); -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///webpack/bootstrap","webpack:///./src/example.ts","webpack:///./src/vCarousel.ts"],"names":[],"mappings":";QAAA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;;QAEA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;;;QAGA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA,0CAA0C,gCAAgC;QAC1E;QACA;;QAEA;QACA;QACA;QACA,wDAAwD,kBAAkB;QAC1E;QACA,iDAAiD,cAAc;QAC/D;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA,yCAAyC,iCAAiC;QAC1E,gHAAgH,mBAAmB,EAAE;QACrI;QACA;;QAEA;QACA;QACA;QACA,2BAA2B,0BAA0B,EAAE;QACvD,iCAAiC,eAAe;QAChD;QACA;QACA;;QAEA;QACA,sDAAsD,+DAA+D;;QAErH;QACA;;;QAGA;QACA;;;;;;;;;;;;;AClFA;AAAA;AAAA;AAC2C;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA,IAAI,+DAAS;AACb;AACA;AACA;AACA;;;;;;;;;;;;;ACZA;AAAA;AAAA;AACA;AACO;AACP;AACA;AACA,iDAAiD,2BAA2B;AAC5E;AACA;AACA;AACA;AACA;AACA,qFAAqF;AACrF;AACA;AACA;AACA,sCAAsC,uFAAuF;AAC7H;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,uBAAuB,kBAAkB;AACzC;AACA;AACA;AACA","file":"./JS/example.app.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = \"./src/example.ts\");\n","/// Exemple d'utilisation de vCarousel avec 3 vidéos\nimport { vCarousel } from \"./vCarousel.ts\";\n// Fournir ici la liste de contenants (div, figure...) des vidéos à faire défiler\n// L'ordre est celui de défilement et peut être différent de celui de la page HTML\n// La même vidéo peut même être listé plusieurs fois...\n// La première entrée correspondant à la vidéo affichée au premier chargement de la page\nvar videosContainers = [\"vFunanbule\", \"vForgeron\", \"vCircuit\"];\ntry {\n    vCarousel(videosContainers);\n}\ncatch (e) {\n    console.error(e);\n}\n","/// La fonction reçoit un tableau d'ids de conteneurs contenant les vidéos à afficher successivement\n/// Attention : les vidéos à afficher ne sont pas dédoublonnées, car on peut souhaiter afficher plusieurs fois la même vidéo durant un tour du carrousel\nexport var vCarousel = function (vContainers) {\n    // On commence par vérifier que les ids de conteneurs fournis sont correctes\n    var realVContainers = [];\n    for (var _i = 0, vContainers_1 = vContainers; _i < vContainers_1.length; _i++) {\n        var container = vContainers_1[_i];\n        var checkContainerExist = document.getElementById(container);\n        if (checkContainerExist === null) // utiliser fonctionner empty() de wikilerni ?\n            console.error(\"Aucun élément HTML trouvé dans la page pour l'id \" + container);\n        else {\n            var checkVideoExist = document.querySelector(\"#\" + container + \" video\"); // tester avec + plusieurs vidéos dans le conteneur\n            if (checkVideoExist === null)\n                console.error(\"Aucune balise vidéo trouvée dans l'élément HTML ayant comme id \" + container);\n            else\n                realVContainers.push({ idContainer: container, containerElt: checkContainerExist, videoElt: checkVideoExist });\n        }\n    }\n    var nbContainers = realVContainers.length;\n    if (nbContainers < 2)\n        console.error(\"Il faut fournir au moins deux conteneurs valides pour faire tourner le carrousel.\");\n    else {\n        var _loop_1 = function (i) {\n            var container = realVContainers[i].containerElt;\n            var video = realVContainers[i].videoElt;\n            if (i !== 0)\n                container.style.display = \"none\";\n            video.addEventListener(\"ended\", function () {\n                container.style.display = \"none\";\n                var nextContainer;\n                if (i < (nbContainers - 1))\n                    nextContainer = realVContainers[i + 1].containerElt;\n                else\n                    nextContainer = realVContainers[0].containerElt;\n                nextContainer.style.display = \"block\";\n            });\n        };\n        for (var i = 0; i < nbContainers; i++) {\n            _loop_1(i);\n        }\n    }\n};\n"],"sourceRoot":""} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///webpack/bootstrap","webpack:///./src/example.ts","webpack:///./src/vCarousel.ts"],"names":[],"mappings":";QAAA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;;QAEA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;;;QAGA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA,0CAA0C,gCAAgC;QAC1E;QACA;;QAEA;QACA;QACA;QACA,wDAAwD,kBAAkB;QAC1E;QACA,iDAAiD,cAAc;QAC/D;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA,yCAAyC,iCAAiC;QAC1E,gHAAgH,mBAAmB,EAAE;QACrI;QACA;;QAEA;QACA;QACA;QACA,2BAA2B,0BAA0B,EAAE;QACvD,iCAAiC,eAAe;QAChD;QACA;QACA;;QAEA;QACA,sDAAsD,+DAA+D;;QAErH;QACA;;;QAGA;QACA;;;;;;;;;;;;;AClFA;AAAA;AAAA;AAC2C;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI,+DAAS;AACb;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,+DAAS;AACrB,SAAS;AACT;AACA,mBAAmB,wBAAwB;AAC3C;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;ACzBA;AAAA;AAAA;AACA;AACA;AACO;AACP,kCAAkC,mBAAmB;AACrD;AACA;AACA;AACA,iDAAiD,2BAA2B;AAC5E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sCAAsC,gFAAgF;AACtH;AACA;AACA;AACA,4EAA4E,kCAAkC,EAAE;AAChH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mDAAmD;AACnD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA,uBAAuB,mBAAmB;AAC1C;AACA;AACA;AACA","file":"./JS/example.app.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = \"./src/example.ts\");\n","/// Exemple d'utilisation de vCarousel avec 3 vidéos\nimport { vCarousel } from \"./vCarousel.ts\";\ntry {\n    // Liste des id des contenants des vidéos à afficher : \n    var videosContainers_1 = [\"vFunanbule\", \"vForgeron\", \"vCircuit\"];\n    // Si un id est fourni par l'url, on affiche cette vidéo en premier :\n    var wantedVideo_1 = \"\";\n    if (window.location.hash !== undefined)\n        wantedVideo_1 = window.location.hash.replace(\"#\", \"\");\n    vCarousel(videosContainers_1, wantedVideo_1);\n    // Dans le cas où l'utilisateur clique pour sélectionner une vidéo à afficher, on actualise l'affichage :\n    var selectLinks = document.querySelectorAll(\".selectVideo\");\n    var _loop_1 = function (i) {\n        var link = selectLinks[i];\n        link.addEventListener(\"click\", function (e) {\n            wantedVideo_1 = link.hash.replace(\"#\", \"\");\n            vCarousel(videosContainers_1, wantedVideo_1);\n        });\n    };\n    for (var i = 0; i < selectLinks.length; i++) {\n        _loop_1(i);\n    }\n}\ncatch (e) {\n    console.error(e);\n}\n","/// La fonction vCarousel reçoit un tableau d'ids des conteneurs HTML des vidéos à afficher successivement.\n/// Le tableau n'est pas dédoublonné, pour reste libre d'afficher plusieurs fois la même vidéo durant un tour du carrousel\n/// On peut éventuellement fournir l'id de la première vidéo à afficher.\nexport var vCarousel = function (vContainers, firstVideoId) {\n    if (firstVideoId === void 0) { firstVideoId = \"\"; }\n    // On commence par vérifier que les ids de conteneurs fournis sont correctes.\n    // C'est-à-dire qu'il s'agit bien d'éléments HTML contenant au moins une vidéo.\n    var realVContainers = [];\n    for (var _i = 0, vContainers_1 = vContainers; _i < vContainers_1.length; _i++) {\n        var containerId = vContainers_1[_i];\n        var checkContainerExist = document.getElementById(containerId);\n        if (checkContainerExist === null)\n            console.error(\"Aucun élément HTML trouvé dans la page pour l'id fourni \" + containerId);\n        else {\n            var checkVideoExist = document.querySelector(\"#\" + containerId + \" video\");\n            if (checkVideoExist === null)\n                console.error(\"Aucune balise vidéo trouvée dans l'élément HTML ayant comme id \" + containerId);\n            else\n                realVContainers.push({ id: containerId, containerElt: checkContainerExist, videoElt: checkVideoExist });\n        }\n    }\n    // Si firstVideoId a été fourni, on vérifie aussi qu'il est valide.\n    if (firstVideoId !== \"\" && (realVContainers.findIndex(function (video) { return video.id === firstVideoId; }) === -1)) {\n        console.error(\"Vous avez fourni l'id de la vidéo à afficher en premier (\" + firstVideoId + \"), mais il n'est pas valide.\");\n        firstVideoId = \"\";\n    }\n    // Il doit rester au moins deux vidéos\n    var nbVContainers = realVContainers.length;\n    if (nbVContainers < 2)\n        console.error(\"Il faut fournir au moins deux conteneurs valides pour faire tourner le carrousel.\");\n    else {\n        var _loop_1 = function (i) {\n            var vContainer = realVContainers[i].containerElt;\n            var video = realVContainers[i].videoElt;\n            if ((firstVideoId !== \"\" && realVContainers[i].id !== firstVideoId) || (firstVideoId == \"\" && i !== 0))\n                vContainer.style.display = \"none\";\n            else\n                vContainer.style.display = \"block\"; // nécessaire dans le cas d'un réaffichage\n            video.addEventListener(\"ended\", function () {\n                vContainer.style.display = \"none\";\n                var nextVContainer, nextHash;\n                if (i < (nbVContainers - 1)) {\n                    nextVContainer = realVContainers[i + 1].containerElt;\n                    nextHash = realVContainers[i + 1].id;\n                }\n                else {\n                    nextVContainer = realVContainers[0].containerElt;\n                    nextHash = realVContainers[0].id;\n                }\n                nextVContainer.style.display = \"block\";\n                // On adapte l'ancre de l'url de manière à ce qu'elle soit cohérente avec la vidéo affichée\n                // Attention car cela peut provoquer un déplacement dans la page la première fois pour atteindre l'ancre (à revoir)\n                window.location.assign(\"#\" + nextHash);\n            });\n        };\n        // Tous les conteneurs sont cachés, sauf celui demandé\n        // La fin de lecture d'une vidéo provoque l'affichage du suivant\n        for (var i = 0; i < nbVContainers; i++) {\n            _loop_1(i);\n        }\n    }\n};\n"],"sourceRoot":""} \ No newline at end of file diff --git a/public/index.html b/public/index.html index 9342ffb..e40a9b5 100644 --- a/public/index.html +++ b/public/index.html @@ -2,7 +2,9 @@ - vCarrousel (démo) + vCarrousel (démo) + + @@ -26,5 +28,14 @@
Drôle de circuit !
+ + \ No newline at end of file diff --git a/src/example.ts b/src/example.ts index 3cc670d..e51f8db 100644 --- a/src/example.ts +++ b/src/example.ts @@ -1,14 +1,27 @@ /// Exemple d'utilisation de vCarousel avec 3 vidéos import { vCarousel } from "./vCarousel.ts"; -// Fournir ici la liste de contenants (div, figure...) des vidéos à faire défiler -// L'ordre est celui de défilement et peut être différent de celui de la page HTML -// La même vidéo peut même être listé plusieurs fois... -// La première entrée correspondant à la vidéo affichée au premier chargement de la page -const videosContainers=["vFunanbule", "vForgeron", "vCircuit"]; try { - vCarousel(videosContainers); + // Liste des id des contenants des vidéos à afficher : + const videosContainers=["vFunanbule", "vForgeron", "vCircuit"]; + // Si un id est fourni par l'url, on affiche cette vidéo en premier : + let wantedVideo=""; + if(window.location.hash!==undefined) + wantedVideo=window.location.hash.replace("#",""); + vCarousel(videosContainers, wantedVideo); + + // Dans le cas où l'utilisateur clique pour sélectionner une vidéo à afficher, on actualise l'affichage : + let selectLinks=document.querySelectorAll(".selectVideo"); + for (let i = 0; i < selectLinks.length; i++) + { + let link=selectLinks[i]; + link.addEventListener("click", function(e) + { + wantedVideo=link.hash.replace("#",""); + vCarousel(videosContainers, wantedVideo); + }); + } } catch(e) { diff --git a/src/vCarousel.js b/src/vCarousel.js index 07e7404..037f18d 100644 --- a/src/vCarousel.js +++ b/src/vCarousel.js @@ -1,44 +1,64 @@ "use strict"; -/// La fonction reçoit un tableau d'ids de conteneurs contenant les vidéos à afficher successivement -/// Attention : les vidéos à afficher ne sont pas dédoublonnées, car on peut souhaiter afficher plusieurs fois la même vidéo durant un tour du carrousel +/// La fonction vCarousel reçoit un tableau d'ids des conteneurs HTML des vidéos à afficher successivement. +/// Le tableau n'est pas dédoublonné, pour reste libre d'afficher plusieurs fois la même vidéo durant un tour du carrousel +/// On peut éventuellement fournir l'id de la première vidéo à afficher. exports.__esModule = true; exports.vCarousel = void 0; -exports.vCarousel = function (vContainers) { - // On commence par vérifier que les ids de conteneurs fournis sont correctes +exports.vCarousel = function (vContainers, firstVideoId) { + if (firstVideoId === void 0) { firstVideoId = ""; } + // On commence par vérifier que les ids de conteneurs fournis sont correctes. + // C'est-à-dire qu'il s'agit bien d'éléments HTML contenant au moins une vidéo. var realVContainers = []; for (var _i = 0, vContainers_1 = vContainers; _i < vContainers_1.length; _i++) { - var container = vContainers_1[_i]; - var checkContainerExist = document.getElementById(container); - if (checkContainerExist === null) // utiliser fonctionner empty() de wikilerni ? - console.error("Aucun élément HTML trouvé dans la page pour l'id " + container); + var containerId = vContainers_1[_i]; + var checkContainerExist = document.getElementById(containerId); + if (checkContainerExist === null) + console.error("Aucun élément HTML trouvé dans la page pour l'id fourni " + containerId); else { - var checkVideoExist = document.querySelector("#" + container + " video"); // tester avec + plusieurs vidéos dans le conteneur + var checkVideoExist = document.querySelector("#" + containerId + " video"); if (checkVideoExist === null) - console.error("Aucune balise vidéo trouvée dans l'élément HTML ayant comme id " + container); + console.error("Aucune balise vidéo trouvée dans l'élément HTML ayant comme id " + containerId); else - realVContainers.push({ idContainer: container, containerElt: checkContainerExist, videoElt: checkVideoExist }); + realVContainers.push({ id: containerId, containerElt: checkContainerExist, videoElt: checkVideoExist }); } } - var nbContainers = realVContainers.length; - if (nbContainers < 2) + // Si firstVideoId a été fourni, on vérifie aussi qu'il est valide. + if (firstVideoId !== "" && (realVContainers.findIndex(function (video) { return video.id === firstVideoId; }) === -1)) { + console.error("Vous avez fourni l'id de la vidéo à afficher en premier (" + firstVideoId + "), mais il n'est pas valide."); + firstVideoId = ""; + } + // Il doit rester au moins deux vidéos + var nbVContainers = realVContainers.length; + if (nbVContainers < 2) console.error("Il faut fournir au moins deux conteneurs valides pour faire tourner le carrousel."); else { var _loop_1 = function (i) { - var container = realVContainers[i].containerElt; + var vContainer = realVContainers[i].containerElt; var video = realVContainers[i].videoElt; - if (i !== 0) - container.style.display = "none"; + if ((firstVideoId !== "" && realVContainers[i].id !== firstVideoId) || (firstVideoId == "" && i !== 0)) + vContainer.style.display = "none"; + else + vContainer.style.display = "block"; // nécessaire dans le cas d'un réaffichage video.addEventListener("ended", function () { - container.style.display = "none"; - var nextContainer; - if (i < (nbContainers - 1)) - nextContainer = realVContainers[i + 1].containerElt; - else - nextContainer = realVContainers[0].containerElt; - nextContainer.style.display = "block"; + vContainer.style.display = "none"; + var nextVContainer, nextHash; + if (i < (nbVContainers - 1)) { + nextVContainer = realVContainers[i + 1].containerElt; + nextHash = realVContainers[i + 1].id; + } + else { + nextVContainer = realVContainers[0].containerElt; + nextHash = realVContainers[0].id; + } + nextVContainer.style.display = "block"; + // On adapte l'ancre de l'url de manière à ce qu'elle soit cohérente avec la vidéo affichée + // Attention car cela peut provoquer un déplacement dans la page la première fois pour atteindre l'ancre (à revoir) + window.location.assign("#" + nextHash); }); }; - for (var i = 0; i < nbContainers; i++) { + // Tous les conteneurs sont cachés, sauf celui demandé + // La fin de lecture d'une vidéo provoque l'affichage du suivant + for (var i = 0; i < nbVContainers; i++) { _loop_1(i); } } diff --git a/src/vCarousel.ts b/src/vCarousel.ts index 6a98d99..3a3b8fe 100644 --- a/src/vCarousel.ts +++ b/src/vCarousel.ts @@ -1,50 +1,75 @@ -/// La fonction reçoit un tableau d'ids de conteneurs contenant les vidéos à afficher successivement -/// Attention : les vidéos à afficher ne sont pas dédoublonnées, car on peut souhaiter afficher plusieurs fois la même vidéo durant un tour du carrousel +/// La fonction vCarousel reçoit un tableau d'ids des conteneurs HTML des vidéos à afficher successivement. +/// Le tableau n'est pas dédoublonné, pour reste libre d'afficher plusieurs fois la même vidéo durant un tour du carrousel +/// On peut éventuellement fournir l'id de la première vidéo à afficher. -export const vCarousel = (vContainers:string[]) : void => +export const vCarousel = (vContainers:string[], firstVideoId="") : void => { interface videoDOM { + id: string; containerElt: HTMLElement; videoElt: HTMLMediaElement; } - // On commence par vérifier que les ids de conteneurs fournis sont correctes + // On commence par vérifier que les ids de conteneurs fournis sont correctes. + // C'est-à-dire qu'il s'agit bien d'éléments HTML contenant au moins une vidéo. const realVContainers : videoDOM[] = []; - for(let container of vContainers) + for(let containerId of vContainers) { - let checkContainerExist=document.getElementById(container); - if(checkContainerExist===null)// utiliser fonctionner empty() de wikilerni ? - console.error("Aucun élément HTML trouvé dans la page pour l'id "+container); + let checkContainerExist=document.getElementById(containerId); + if(checkContainerExist===null) + console.error("Aucun élément HTML trouvé dans la page pour l'id fourni "+containerId); else { - let checkVideoExist=document.querySelector("#"+container+" video");// tester avec + plusieurs vidéos dans le conteneur + let checkVideoExist=document.querySelector("#"+containerId+" video"); if(checkVideoExist===null) - console.error("Aucune balise vidéo trouvée dans l'élément HTML ayant comme id "+container); + console.error("Aucune balise vidéo trouvée dans l'élément HTML ayant comme id "+containerId); else - realVContainers.push({containerElt:checkContainerExist, videoElt: checkVideoExist}); + realVContainers.push({id:containerId, containerElt:checkContainerExist, videoElt:checkVideoExist}); } } - let nbContainers=realVContainers.length; - if(nbContainers < 2) + + // Si firstVideoId a été fourni, on vérifie aussi qu'il est valide. + if(firstVideoId!=="" && (realVContainers.findIndex(video => video.id === firstVideoId) === -1)) + { + console.error("Vous avez fourni l'id de la vidéo à afficher en premier ("+firstVideoId+"), mais il n'est pas valide."); + firstVideoId=""; + } + + // Il doit rester au moins deux vidéos + let nbVContainers=realVContainers.length; + if(nbVContainers < 2) console.error("Il faut fournir au moins deux conteneurs valides pour faire tourner le carrousel."); else { - for (let i = 0; i < nbContainers; i++) + // Tous les conteneurs sont cachés, sauf celui demandé + // La fin de lecture d'une vidéo provoque l'affichage du suivant + for (let i = 0; i < nbVContainers; i++) { - let container=realVContainers[i].containerElt; + let vContainer=realVContainers[i].containerElt; let video=realVContainers[i].videoElt; - if(i!==0) - container.style.display = "none"; + if((firstVideoId!=="" && realVContainers[i].id!==firstVideoId) || (firstVideoId=="" && i!==0)) + vContainer.style.display = "none"; + else + vContainer.style.display = "block";// nécessaire dans le cas d'un réaffichage video.addEventListener("ended", function() { - container.style.display = "none"; - let nextContainer: HTMLElement; - if(i < (nbContainers-1)) - nextContainer=realVContainers[i+1].containerElt; + vContainer.style.display = "none"; + let nextVContainer: HTMLElement, nextHash: string; + if(i < (nbVContainers-1)) + { + nextVContainer=realVContainers[i+1].containerElt; + nextHash=realVContainers[i+1].id; + } else - nextContainer=realVContainers[0].containerElt; - nextContainer.style.display = "block"; + { + nextVContainer=realVContainers[0].containerElt; + nextHash=realVContainers[0].id; + } + nextVContainer.style.display = "block"; + // On adapte l'ancre de l'url de manière à ce qu'elle soit cohérente avec la vidéo affichée + // Attention car cela peut provoquer un déplacement dans la page la première fois pour atteindre l'ancre (à revoir) + window.location.assign("#"+nextHash); }); } }