Commit 47bed7eb authored by Bertrand Gauthier's avatar Bertrand Gauthier
Browse files

WIP bootstrap 3 => 4

parent 46325956
Pipeline #10806 passed with stage
in 19 seconds
...@@ -616,23 +616,35 @@ return [ ...@@ -616,23 +616,35 @@ return [
], ],
], ],
/**
* NB: Lors d'un `composer install` fait par une appli requérant le module "unicaen/app", le répertoire
* `public/unicaen` de ce module doit être copié dans le répertoire "public/" de l'appli en question grâce
* à la "post install command" suivante :
*
* "scripts": {
* "post-install-cmd": [
* "cp -r vendor/unicaen/app/public/unicaen public/"
* ]
* }
*
* Les chemins ci-dessous sont donc relatifs au dossier racine de l'appli.
*/
'public_files' => [ 'public_files' => [
'head_scripts' => [ 'head_scripts' => [
'010_jquery' => '/unicaen/app/vendor/jquery-1.11.3.min.js', '015_jquery' => '/unicaen/app/vendor/jquery-3.6.0.min.js',
'020_jqueryui' => '/unicaen/app/vendor/jquery-ui-1.11.4/jquery-ui.min.js', '020_jqueryui' => '/unicaen/app/vendor/jquery-ui-1.12.1/jquery-ui.min.js',
// '030_popper' => '/unicaen/app/vendor/popper.min.js',
'040_bootstrap' => '/unicaen/app/vendor/bootstrap-4.5.2/js/bootstrap.bundle.min.js', '040_bootstrap' => '/unicaen/app/vendor/bootstrap-4.5.2/js/bootstrap.bundle.min.js',
], ],
'inline_scripts' => [ 'inline_scripts' => [
'020_app' => '/js/app.js', '020_app' => '/js/app.js',
'030_util' => '/unicaen/app/js/util.js', '030_util' => '/unicaen/app/js/util.js',
'040_unicaen' => '/unicaen/app/js/unicaen.js', '040_unicaen' => '/unicaen/app/js/unicaen.js',
'050_jquery_form' => '/unicaen/app/vendor/jquery.form-3.51.js' // pour l'uploader Unicaen uniquement!!, '050_jquery_form' => '/unicaen/app/vendor/jquery.form.min.js' // pour l'uploader Unicaen uniquement!!,
], ],
'stylesheets' => [ 'stylesheets' => [
'010_jquery-ui' => '/unicaen/app/vendor/jquery-ui-1.11.4/jquery-ui.min.css', '010_jquery-ui' => '/unicaen/app/vendor/jquery-ui-1.12.1/jquery-ui.min.css',
'020_jquery-ui-structure' => '/unicaen/app/vendor/jquery-ui-1.11.4/jquery-ui.structure.min.css', '020_jquery-ui-structure' => '/unicaen/app/vendor/jquery-ui-1.12.1/jquery-ui.structure.min.css',
'030_jquery-ui-theme' => '/unicaen/app/vendor/jquery-ui-1.11.4/jquery-ui.theme.min.css', '030_jquery-ui-theme' => '/unicaen/app/vendor/jquery-ui-1.12.1/jquery-ui.theme.min.css',
'040_bootstrap' => '/unicaen/app/vendor/bootstrap-4.5.2/css/bootstrap.min.css', '040_bootstrap' => '/unicaen/app/vendor/bootstrap-4.5.2/css/bootstrap.min.css',
'060_unicaen' => '/unicaen/app/css/unicaen.css', '060_unicaen' => '/unicaen/app/css/unicaen.css',
'065_unicaen-icon' => '/unicaen/app/css/unicaen-icon.css', '065_unicaen-icon' => '/unicaen/app/css/unicaen-icon.css',
......
...@@ -101,7 +101,7 @@ ...@@ -101,7 +101,7 @@
.icon.icon-supprimer:before, .icon.icon-supprimer:before,
.icon.icon-delete:before, .icon.icon-delete:before,
.icon.icon-remove:before { .icon.icon-remove:before {
content: "\f00d"; content: "\f12d";
} }
.icon.icon-importer:before, .icon.icon-importer:before,
......
...@@ -13,26 +13,6 @@ body.test { ...@@ -13,26 +13,6 @@ body.test {
background-image: url(); background-image: url();
} }
/*
body.development .navbar-inverse {
background-image: linear-gradient(to bottom, #660000 0px, #870a0a 100%);
border-color: #660000;
}
body.development .navbar-inverse .navbar-nav .active a {
background-image: linear-gradient(to bottom, #d22828 0px, #a41212 100%);
}
body.test .navbar-inverse {
background-image: linear-gradient(to bottom, #002768 0px, #0a3783 100%);
border-color: #002768;
}
body.test .navbar-inverse .navbar-nav .active a {
background-image: linear-gradient(to bottom, #3773d7 0px, #1d57b7 100%);
}
*/
body.test div#contenu-principal { body.test div#contenu-principal {
background-color: white; background-color: white;
} }
...@@ -86,26 +66,25 @@ a.navbar-brand h1 { ...@@ -86,26 +66,25 @@ a.navbar-brand h1 {
margin-bottom: 30px; margin-bottom: 30px;
} }
#footer { #footer {
margin-bottom: 20px; margin-bottom: 20px;
} }
#footer ul { #footer ul {
width: 75%; width: 75%;
margin: auto; margin: auto;
text-align: center; text-align: center;
} }
#footer ul li { #footer ul li {
display: inline; display: inline;
padding: 0 1em; padding: 0 1em;
border-left: 1px gray solid; border-left: 1px gray solid;
} }
#footer ul > li:first-child { #footer ul > li:first-child {
border: none; border: none;
} }
#footer a.ucbn { #footer a.ucbn {
background-image:url(''); background-image:url('');
background-repeat: no-repeat; background-repeat: no-repeat;
...@@ -116,6 +95,9 @@ a.navbar-brand h1 { ...@@ -116,6 +95,9 @@ a.navbar-brand h1 {
text-indent: -9999px; text-indent: -9999px;
} }
thead { thead {
font-weight: bold; font-weight: bold;
} }
......
...@@ -12,11 +12,8 @@ $(function () ...@@ -12,11 +12,8 @@ $(function ()
$(document).ajaxComplete(function (event, xhr, settings) $(document).ajaxComplete(function (event, xhr, settings)
{ {
if (xhr.status === 403) { if (xhr.status === 403) {
if (confirm("Votre session a expiré, vous devez vous reconnecter.\n\nCliquez sur OK pour être redirigé(e) vers la page de connexion...")) { alert("Opération non autorisée ou session expirée.");
var pne = window.location.pathname.split('/'); xhr.abort();
var url = "/" + (pne[0] ? pne[0] : pne[1]) + "/auth/connexion?redirect=" + $(location).attr('href');
$(location).attr('href', url);
}
} }
}); });
...@@ -27,7 +24,7 @@ $(function () ...@@ -27,7 +24,7 @@ $(function ()
if ($(window).scrollTop() > 100) { if ($(window).scrollTop() > 100) {
$('.scrollup').fadeIn(); $('.scrollup').fadeIn();
} }
$(window).scroll(function () $(window).on("scroll", function ()
{ {
if ($(this).scrollTop() > 100) { if ($(this).scrollTop() > 100) {
$('.scrollup').fadeIn(); $('.scrollup').fadeIn();
...@@ -36,7 +33,7 @@ $(function () ...@@ -36,7 +33,7 @@ $(function ()
$('.scrollup').fadeOut(); $('.scrollup').fadeOut();
} }
}); });
$('.scrollup').click(function () $('.scrollup').on("click", function ()
{ {
$("html, body").animate({scrollTop: 0}, 300); $("html, body").animate({scrollTop: 0}, 300);
return false; return false;
...@@ -255,7 +252,7 @@ IntraNavigator = { ...@@ -255,7 +252,7 @@ IntraNavigator = {
//$('body').one("click", ".intranavigator .btn-primary", IntraNavigator.btnPrimaryClickListener); //$('body').one("click", ".intranavigator .btn-primary", IntraNavigator.btnPrimaryClickListener);
// Réglage du focus sur le champ de formulaire ayant l'attribut 'autofocus' // Réglage du focus sur le champ de formulaire ayant l'attribut 'autofocus'
$('.intranavigator [autofocus]').focus(); $('.intranavigator [autofocus]').trigger("focus");
}, },
/** /**
...@@ -350,7 +347,7 @@ $.fn.autocompleteUnicaen = function (options) ...@@ -350,7 +347,7 @@ $.fn.autocompleteUnicaen = function (options)
highlight(element.val(), li, 'sas-highlight'); highlight(element.val(), li, 'sas-highlight');
// si l'item ne possède pas d'id, on fait en sorte qu'il ne soit pas sélectionnable // si l'item ne possède pas d'id, on fait en sorte qu'il ne soit pas sélectionnable
if (!item.id) { if (!item.id) {
li.click(function () { return false; }); li.on("click", function () { return false; });
} }
return li; return li;
}; };
...@@ -591,7 +588,9 @@ AjaxModalListener.prototype.start = function () ...@@ -591,7 +588,9 @@ AjaxModalListener.prototype.start = function ()
this.eventListener.on("click", "#" + this.modalContainerId + " a:not([download])", $.proxy(this.innerAnchorClickListener, this)); this.eventListener.on("click", "#" + this.modalContainerId + " a:not([download])", $.proxy(this.innerAnchorClickListener, this));
// le formulaire éventuel est soumis lorsque le bouton principal de la fenêtre modale est cliqué // le formulaire éventuel est soumis lorsque le bouton principal de la fenêtre modale est cliqué
if (this.getSubmitButton().length) {
this.eventListener.on("click", this.getSubmitButton().selector, $.proxy(this.btnPrimaryClickListener, this)); this.eventListener.on("click", this.getSubmitButton().selector, $.proxy(this.btnPrimaryClickListener, this));
}
// interception la soumission classique du formulaire pour le faire à la sauce AJAX // interception la soumission classique du formulaire pour le faire à la sauce AJAX
this.eventListener.on("submit", "#" + this.modalContainerId + " form", $.proxy(this.formSubmitListener, this)); this.eventListener.on("submit", "#" + this.modalContainerId + " form", $.proxy(this.formSubmitListener, this));
...@@ -933,14 +932,14 @@ $.widget("unicaen.popAjax", { ...@@ -933,14 +932,14 @@ $.widget("unicaen.popAjax", {
var that = this; var that = this;
this.element.click(function () this.element.on("click", function ()
{ {
that.showHide(); that.showHide();
return false; return false;
}); });
$('html').click(function (e) $('html').on("click", function (e)
{ {
that.htmlClick(e); that.htmlClick(e);
}); });
...@@ -1169,7 +1168,7 @@ $.widget("unicaen.popAjax", { ...@@ -1169,7 +1168,7 @@ $.widget("unicaen.popAjax", {
this.popDiv.html(contentDiv); this.popDiv.html(contentDiv);
this.popDiv.appendTo("body"); this.popDiv.appendTo("body");
this.popDiv.find('.pop-ajax-hide').click(function () { that.hide();}); this.popDiv.find('.pop-ajax-hide').on("click", function () { that.hide();});
IntraNavigator.run(); // navigateur interne!! IntraNavigator.run(); // navigateur interne!!
if (this.options.content !== undefined) { if (this.options.content !== undefined) {
...@@ -1192,7 +1191,7 @@ $.widget("unicaen.popAjax", { ...@@ -1192,7 +1191,7 @@ $.widget("unicaen.popAjax", {
}); });
} }
this.getContent().bind('DOMNodeInserted DOMNodeRemoved', function () this.getContent().on('DOMNodeInserted DOMNodeRemoved', function ()
{ {
that.posPop(); that.posPop();
}); });
...@@ -1214,7 +1213,7 @@ $.widget("unicaen.popAjax", { ...@@ -1214,7 +1213,7 @@ $.widget("unicaen.popAjax", {
pc.hide(); pc.hide();
pc.html(content); pc.html(content);
pc.find('.pop-ajax-hide').click(function () { that.hide();}); pc.find('.pop-ajax-hide').on("click", function () { that.hide();});
this.extractTitle(); this.extractTitle();
this._trigger('change', null, this); this._trigger('change', null, this);
......
...@@ -26,11 +26,11 @@ function durationInWords(milliseconds) ...@@ -26,11 +26,11 @@ function durationInWords(milliseconds)
function substitute(stringOrFunction, number) function substitute(stringOrFunction, number)
{ {
var string = $.isFunction(stringOrFunction) ? stringOrFunction(number, milliseconds) : stringOrFunction; var string = typeof stringOrFunction === "function" ? stringOrFunction(number, milliseconds) : stringOrFunction;
return number ? (string.replace(/%d/i, number) + (number > 1 ? "s" : "") + " ") : ""; return number ? (string.replace(/%d/i, number) + (number > 1 ? "s" : "") + " ") : "";
} }
return $.trim(substitute(l.years, years) + (substitute(l.months, month)) + (substitute(l.days, days)) + (substitute(l.hours, hours)) + (substitute(l.minutes, minutes)) + (substitute(l.seconds, seconds)) + (substitute(l.milliseconds, ms))); return (substitute(l.years, years) + (substitute(l.months, month)) + (substitute(l.days, days)) + (substitute(l.hours, hours)) + (substitute(l.minutes, minutes)) + (substitute(l.seconds, seconds)) + (substitute(l.milliseconds, ms))).trim();
} }
/** /**
...@@ -218,11 +218,11 @@ function installConfirm() ...@@ -218,11 +218,11 @@ function installConfirm()
message = $(this).attr('title'); message = $(this).attr('title');
message = "Êtes-vous sûr(e) de vouloir " + message.substr(0, 1).toLowerCase() + message.substr(1) + " ?"; message = "Êtes-vous sûr(e) de vouloir " + message.substr(0, 1).toLowerCase() + message.substr(1) + " ?";
} }
$(this).click(function () { askConfirmation($(this), message); }); $(this).on("click", function () { askConfirmation($(this), message); });
}); });
$(".actions .confirm").each(function () $(".actions .confirm").each(function ()
{ {
$(this).click(function () { askConfirmation($(this)); }); $(this).on("click", function () { askConfirmation($(this)); });
}); });
} }
...@@ -316,7 +316,7 @@ function installMenuToggleButton() ...@@ -316,7 +316,7 @@ function installMenuToggleButton()
atoggle = $('<a title="Afficher/masquer le menu"></a>') atoggle = $('<a title="Afficher/masquer le menu"></a>')
.button({icons: {primary: 'ui-icon-carat-2-e-w'}, texte: false}) .button({icons: {primary: 'ui-icon-carat-2-e-w'}, texte: false})
.css('height', '12px').css('width', '30px').css('margin-bottom', '2px') .css('height', '12px').css('width', '30px').css('margin-bottom', '2px')
.click(function () .on("click", function ()
{ {
var visible = $.jStorage.get('menuvisible', '?'); var visible = $.jStorage.get('menuvisible', '?');
if (visible == '?') { if (visible == '?') {
...@@ -356,7 +356,7 @@ function setMenuVisible(visible) ...@@ -356,7 +356,7 @@ function setMenuVisible(visible)
*/ */
function installOpacifier(element, opacity, ajaxLoadingElement) function installOpacifier(element, opacity, ajaxLoadingElement)
{ {
element.click(function () element.on("click", function ()
{ {
$("body").css("opacity", opacity ? opacity : "0.5"); $("body").css("opacity", opacity ? opacity : "0.5");
$(ajaxLoadingElement ? ajaxLoadingElement : "#ajax-loader").show().position({ $(ajaxLoadingElement ? ajaxLoadingElement : "#ajax-loader").show().position({
...@@ -546,8 +546,8 @@ function installCheckboxes(targetElements, checkboxName, initiallyChecked) ...@@ -546,8 +546,8 @@ function installCheckboxes(targetElements, checkboxName, initiallyChecked)
) )
); );
cocherTout.click(function () { $("input.check-" + checkboxName).prop('checked', true).trigger("change"); }); cocherTout.on("click", function () { $("input.check-" + checkboxName).prop('checked', true).trigger("change"); });
decocherTout.click(function () { $("input.check-" + checkboxName).prop('checked', false).trigger("change"); }); decocherTout.on("click", function () { $("input.check-" + checkboxName).prop('checked', false).trigger("change"); });
return $("input.check-" + checkboxName); return $("input.check-" + checkboxName);
} }
......
// This file is autogenerated via the `commonjs` Grunt task. You can require() this file in a CommonJS environment.
require('../../js/transition.js')
require('../../js/alert.js')
require('../../js/button.js')
require('../../js/carousel.js')
require('../../js/collapse.js')
require('../../js/dropdown.js')
require('../../js/modal.js')
require('../../js/tooltip.js')
require('../../js/popover.js')
require('../../js/scrollspy.js')
require('../../js/tab.js')
require('../../js/affix.js')
\ No newline at end of file
Supports Markdown
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment