* animate.css: animations css * links.css: liens avec le fond blanc qui se déroule * links.css: WIP liens thème sombre * GitHub.ico: un petit merci à GitHub * live-concert-fg.png: image de plan rapproché : les fans * live-concert-scene.jpg: Image de fond : la scene * splash-image-2.jpg: image de fond : photo colorée, public de concert, vient de totemproduction.fr * links.css: ficher de définitions globales du style des bouttons (encore inutilisé) * yavsc.user.js: WIP implémente le widget "utilisateur", permettant l'affichage des liens rapides pour tout nom d'ulitisateur, le cas échéant, vers l'ajout à un cercle, vers son blog, vers des methodes choisies d'administateur, vers ses réseaux sociaux, voir plus. * About.aspx: Implémente une page "à propos" * Test.aspx: Page de test: désolé pour le bruit, elle n'est compilée qu'en mode `Debug` (elle n'est pas accessible en production) * NpgsqlBlogProvider.cs: Corrige la méthode pour enlever un tag à un article ... * NpgsqlBlogProvider.csproj: . * NpgsqlCircleProvider.cs: liste les cercles auquels appartient un utilisateur. * BasketController.cs: * NpgsqlContentProvider.cs: Les commandes sont fortement typée. * README.md: mise à jour des priorités * style.css: réécriture du thème clair * style.css: * implémente un classe css `clickme` pour attirer l'oeil sur le boutton de validation après la modification d'un champ de formulaire. * enlève tous les coins arrondis * modifie la chasse de caractères (une seule utilisée pour le moment) * * style.css: * integre la référence à la feuille de style des [animations](https://daneden.github.io/animate.css/) * corrige des marges, alignements * supprime ce qui reste de coin arrondi * néttoye les définitions obsolètes * définit la classe `username` * corrige le survol à la suppression de tag * FrontOfficeController.cs: renomme des methodes, refabriqué pour s'adapter aux changements de l'API du workflow, WIP propose les cercles utilisateurs pour l'ajout des profiles préstataires aux cercles. * HomeController.cs: implémente une page "à propos" * T.cs: re-autorise le titre vide de page, au cas où ... car ce n'est pas un véritable défaut fonctionnel. * YavscHelpers.cs: Implemente un outil de presentation des liens action traduits. Tous les liens action utilisent maintenant cette nouvelle methode, au profile de celle du framework `HtmlHelpers.ActionLink` * App.master: corrige l'usage du contrôle utilisateur des cotes dans le cadre des cotes de billet. * AppAdmin.master: * Index.aspx: * Service.aspx: * ProductCategory.aspx: traduction des liens action * NoLogin.master: * traduction des liens action * suppression des liens de remerciement dans le bas de page, cette information a été déplacée dans la page `/Home/Credits` * to-markdown.js: transforme maintenant les noeuds Html `div` en paragraphes Markdown. * yavsc.hidefieldset.js: Le script règle la forme de la souris au survol du bouton, le cas échéant. * yavsc.js: nouvelle fonction javascript pour logger un objet arbitraire. * yavsc.rate.js: Fixe la possibilité de mettre des cotes très basses ou très hautes (reste encore un mieux à faire), Affiche au survol des descriptions optionnelles de la cote. * Title.aspx: * UserPost.aspx: * Edit.aspx: * Index.aspx: * Brand.aspx: * Index.aspx: * PostActions.ascx: * TitleNotFound.aspx: * Booking.aspx: * Command.aspx: * ChangePasswordSuccess.aspx: Traduction des liens action * Login.aspx: * Traduction des liens actionTraduction des liens action * Profile.aspx: * Traduction des liens actionTraduction des liens action * utilisation de la classe css `mayhide` qui autorise maintenant un champ d'entrées de formulaire à être plié/déplié au click sur sa légende. * Admin.aspx: Traduction des liens actionTraduction des liens actionTraduction des liens actionTraduction des liens actionTraduction des liens actionTraduction des liens action * Backups.aspx: * RoleList.aspx: * UserList.aspx: * Index.aspx: Traduction des liens actionTraduction des liens action * Edit.aspx: * refabrication de la structure Html * Traduction des liens actionTraduction des liens action * Index.aspx: Simlpification des apperçus de blog * TagControl.ascx: refabrication pour simplifier l'implémentation du contrôle utilisateur des tags * UserPosts.aspx: Traduction des liens action, et simplification du listing de blog * Basket.aspx: Affiche les articles du panier de commandes avec leur vue dédiée à leur type (les commande sont maintenant fortement typées) * Catalog.aspx: Traduction des liens action, correctin du lien vers le produit (cassé depuis une vielle refabrication des routes) * DoAnEstimate.aspx: refabrication de la vue de création du devis: renommée depuis `Estimate` * Performer.ascx: * un message supplementaire à l'absence de compétence affichée par un préstataire * des guillemets autour du commentaire du préstataire sur sa compétence * ajout du préstataire au cercles * Performers.aspx: Décrit en détail les informations sur la disponibilité d'un préstataire, à la date demandée. * YourEstimates.aspx: renomage de cette page, pour préciser sa fonction : Vos devis. * Contact.aspx: structure Html de la page de contact * Credits.aspx: Ajoute les remerciements aux communauté du libre * Index.aspx: ne fait rien * Web.config: * import de `System.Transactions` * mise à jour des credits libres * WebDeploy.targets: utilise les séparateurs de chemin vers ficher à la POSIX, ne change rien pour ma config ... (TODO tester sous WoinDose) * Yavsc.csproj: déploie des pages des scripts Javascript et des images et feuilles de style en plus. * CircleManager.cs: implémente les methodes utilisées à la construction du contrôle utilisateur. * CircleProvider.cs: * doc xml * extension de interface * Commande.cs: l'objet `Command` devient abstrait, pour exister (être instanciée), une commande doit maintenant hériter de cet objet abstrait. * LocalizedText.resx: * LocalizedText.fr.resx: * LocalizedText.Designer.cs: * LocalizedText.fr.Designer.cs: traductions * IContentProvider.cs: doc xml * SiteSkills.aspx: renomage de cette page, pour préciser sa fonction : les compétences sur ce site.
127 lines
3.3 KiB
JavaScript
127 lines
3.3 KiB
JavaScript
|
|
var Yavsc = (function(apiBaseUrl){
|
|
var self = {};
|
|
|
|
self.apiBaseUrl = (apiBaseUrl || '/api');
|
|
|
|
self.dumpprops = function (obj) {
|
|
var str = "";
|
|
for(var k in obj)
|
|
if (obj.hasOwnProperty(k))
|
|
str += " "+k + " = " + obj[k] + "\n";
|
|
return (str); };
|
|
|
|
self.logObj = function(obj) {
|
|
console.log('obj:'+obj);
|
|
console.log('-props:'+self.dumpprops(obj));
|
|
};
|
|
|
|
self.showHide = function () {
|
|
var id = $(this).attr('did');
|
|
var target = $('#'+id);
|
|
if (target.hasClass('hidden')) {
|
|
target.removeClass('hidden');
|
|
if (typeof this.oldhtml == "undefined")
|
|
this.oldhtml = $(this).html();
|
|
$(this).html('['+this.oldhtml+']');
|
|
}
|
|
else {
|
|
target.addClass('hidden');
|
|
$(this).html(this.oldhtml);
|
|
}
|
|
};
|
|
|
|
self.dimiss = function () {
|
|
$(this).parent().remove();
|
|
};
|
|
|
|
self.ajax = function (method,data,callback,badInputCallback,errorCallBack) {
|
|
if (!badInputCallback) badInputCallback=Yavsc.onAjaxBadInput;
|
|
if (!errorCallBack) errorCallBack=Yavsc.onAjaxError;
|
|
$.ajax({
|
|
url: self.apiBaseUrl+'/'+method,
|
|
type: "POST",
|
|
data: data,
|
|
success: function (response) {
|
|
if (callback) callback(response);
|
|
},
|
|
statusCode: {
|
|
400: Yavsc.onAjaxBadInput
|
|
},
|
|
error: Yavsc.onAjaxError});
|
|
};
|
|
|
|
self.onScroll = function() {
|
|
var $notifications = $('#notifications');
|
|
if ($notifications.has('*').length>0) {
|
|
if ($(window).scrollTop()>0) {
|
|
$notifications.addClass("dispmodal");
|
|
}
|
|
else {
|
|
$notifications.removeClass("dispmodal");
|
|
}}
|
|
};
|
|
|
|
self.notice = function (msg, callback, msgok) {
|
|
if (!msgok) msgok='Ok';
|
|
var note = $('<div class="notification">'+msg+'<br></div>');
|
|
var btn = $('<a class="actionlink"><i class="fa fa-check">'+msgok+'</i></a>');
|
|
if (callback) btn.click(callback);
|
|
btn.click(self.dimiss).appendTo(note);
|
|
note.appendTo("#notifications");
|
|
self.onScroll();
|
|
};
|
|
|
|
self.onAjaxBadInput = function (data)
|
|
{
|
|
if (!data) { Yavsc.notice('no data'); return; }
|
|
if (!data.responseJSON) { Yavsc.notice('no json data:'+data); return; }
|
|
if (!Array.isArray(data.responseJSON)) { Yavsc.notice('Bad Input: '+data.responseJSON); return; }
|
|
$.each(data.responseJSON, function (key, value) {
|
|
var errspanid = "Err_" + value.key;
|
|
var errspan = document.getElementById(errspanid);
|
|
if (errspan==null)
|
|
Yavsc.notice('ENOTANODE: '+errspanid);
|
|
else
|
|
errspan.innerHTML=value.errors.join("<br/>");
|
|
});
|
|
};
|
|
|
|
self.onAjaxError = function (xhr, ajaxOptions, thrownError) {
|
|
if (xhr.status!=400)
|
|
Yavsc.notice(xhr.status+" : "+xhr.responseText);
|
|
};
|
|
|
|
$(document).ready(function(){
|
|
|
|
$('.maskable').each( function() {
|
|
var $mobj = $(this);
|
|
var $btnshow = $('#'+$mobj.data('btn-show'));
|
|
var $btnhide = $('#'+$mobj.data('btn-hide'));
|
|
var onClickHide = function(){
|
|
$mobj.addClass('hidden');
|
|
$btnshow.removeClass('hidden');
|
|
$btnhide.addClass('hidden');
|
|
};
|
|
$btnhide.click(onClickHide);
|
|
onClickHide();
|
|
$btnshow.click(function(){
|
|
$mobj.removeClass('hidden');
|
|
$btnshow.addClass('hidden');
|
|
$btnhide.removeClass('hidden');
|
|
});
|
|
});
|
|
});
|
|
|
|
$(document).ready(function(){
|
|
$body = $("body");
|
|
$(document).on({
|
|
ajaxStart: function() { $body.addClass("loading"); },
|
|
ajaxStop: function() { $body.removeClass("loading"); }
|
|
});
|
|
$(window).scroll(self.onScroll);
|
|
});
|
|
return self;
|
|
})();
|
|
|