You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

lechatdesnoisettes.js 19KB

8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594
  1. /* French initialisation for the jQuery UI date picker plugin. */
  2. /* Written by Keith Wood (kbwood{at}iinet.com.au),
  3. Stéphane Nahmani (sholby@sholby.net),
  4. Stéphane Raimbault <stephane.raimbault@gmail.com> */
  5. (function( factory ) {
  6. if ( typeof define === "function" && define.amd ) {
  7. // AMD. Register as an anonymous module.
  8. define([ "../jquery.ui.datepicker" ], factory );
  9. } else {
  10. // Browser globals
  11. factory( jQuery.datepicker );
  12. }
  13. }(function( datepicker ) {
  14. datepicker.regional['fr'] = {
  15. closeText: 'Fermer',
  16. prevText: 'Précédent',
  17. nextText: 'Suivant',
  18. currentText: 'Aujourd\'hui',
  19. monthNames: ['janvier', 'février', 'mars', 'avril', 'mai', 'juin',
  20. 'juillet', 'août', 'septembre', 'octobre', 'novembre', 'décembre'],
  21. monthNamesShort: ['janv.', 'févr.', 'mars', 'avril', 'mai', 'juin',
  22. 'juil.', 'août', 'sept.', 'oct.', 'nov.', 'déc.'],
  23. dayNames: ['dimanche', 'lundi', 'mardi', 'mercredi', 'jeudi', 'vendredi', 'samedi'],
  24. dayNamesShort: ['dim.', 'lun.', 'mar.', 'mer.', 'jeu.', 'ven.', 'sam.'],
  25. dayNamesMin: ['D','L','M','M','J','V','S'],
  26. weekHeader: 'Sem.',
  27. dateFormat: 'dd/mm/yy',
  28. firstDay: 1,
  29. isRTL: false,
  30. showMonthAfterYear: false,
  31. yearSuffix: ''};
  32. datepicker.setDefaults(datepicker.regional['fr']);
  33. return datepicker.regional['fr'];
  34. }));
  35. $(document).ready(function() {
  36. //chat_scroll() ;
  37. chat_tabs_gamme_saison() ;
  38. //chat_slideshow() ;
  39. $('[data-toggle="tooltip"]').tooltip() ;
  40. chat_systeme_commande() ;
  41. chat_profil_user() ;
  42. }) ;
  43. function chat_profil_user() {
  44. if($('#profil-user').size()) {
  45. if($('#user-no_mail').is(':checked')) {
  46. $('#mails-jours-prod').hide() ;
  47. }
  48. $('#user-no_mail').change(function() {
  49. if($('#user-no_mail').is(':checked')) {
  50. $('#mails-jours-prod').hide() ;
  51. }
  52. else {
  53. $('#mails-jours-prod').fadeIn() ;
  54. }
  55. }) ;
  56. }
  57. }
  58. function chat_event_click_point_vente(id, force) {
  59. $('#commande-id_point_vente').val(id) ;
  60. $('#points-vente .point-vente').removeClass('selected') ;
  61. $('.point-vente-'+id).addClass('selected') ;
  62. $('.point-vente-'+id).hide().fadeIn('fast') ;
  63. var pain = parseInt($('.point-vente-'+id).data('pain')) ;
  64. var vrac = parseInt($('.point-vente-'+id).data('vrac')) ;
  65. if(pain) {
  66. $('#pain .table').show() ;
  67. $('#pain .indisponible').hide() ;
  68. }
  69. else {
  70. $('#pain .table').hide() ;
  71. $('#pain .indisponible').show() ;
  72. }
  73. if(vrac) {
  74. $('#vrac .table').show() ;
  75. $('#vrac .indisponible').hide() ;
  76. }
  77. else {
  78. $('#vrac .table').hide() ;
  79. $('#vrac .indisponible').show() ;
  80. }
  81. $('#produits, .valider-commande, .btn-commentaire, #bar-fixed').fadeIn() ;
  82. // scroll
  83. if(!force)
  84. boulange_scroll('step-choix-produits') ;
  85. }
  86. function chat_init_horaire_point_vente(date) {
  87. $('#points-vente .horaires .jour').hide() ;
  88. var selector_jour = '#points-vente .horaires .jour-'+date.getDay() ;
  89. $(selector_jour).show() ;
  90. // on cache les points de vente si la livraison n'est pas cochée
  91. $('#points-vente .point-vente').show() ;
  92. if($('#livraison').val() == 0) {
  93. $('#points-vente .point-vente').hide() ;
  94. $('#points-vente .point-vente').each(function() {
  95. if($(this).find('.nom').html() == 'Le Chat des Noisettes') {
  96. $(this).show() ;
  97. }
  98. }) ;
  99. }
  100. // on cache les points de vente qui sont fermés
  101. //$('#points-vente .point-vente').removeClass('disabled') ;
  102. $(selector_jour).each(function() {
  103. if($(this).html() == 'Fermé') {
  104. //$(this).parent().parent().parent().addClass('disabled') ;
  105. $(this).parent().parent().parent().hide() ;
  106. }
  107. }) ;
  108. }
  109. function chat_systeme_commande() {
  110. if($('.commande-form').size()) {
  111. // scroll initial
  112. if($('.boulangerie.selected').size())
  113. {
  114. boulange_scroll('step-choix-date') ;
  115. }
  116. // affichage des différentes parties du formulaire
  117. if(!$('#commande-id_production').val()) {
  118. $('#depots, #points-vente, #produits, .valider-commande, #info-horaire-retrait-commande, .btn-commentaire, #bar-fixed').hide() ;
  119. }
  120. else if(!$('#commande-id_point_vente').val()) {
  121. $('#produits, .valider-commande, .btn-commentaire, #bar-fixed').hide() ;
  122. }
  123. if($('#commande-id_point_vente').val())
  124. chat_event_click_point_vente($('#commande-id_point_vente').val(), true) ;
  125. $('#points-vente .point-vente').click(function() {
  126. var id = parseInt($(this).find('.id').html()) ;
  127. chat_event_click_point_vente(id) ;
  128. }) ;
  129. // datepicker
  130. var dates_production = [] ;
  131. $('#dates div').each(function() {
  132. dates_production.push($(this).find('.date').html()) ;
  133. }) ;
  134. //var var_datepicker = $.datepicker ;
  135. $('#datepicker-production').datepicker({
  136. beforeShowDay: function(date){
  137. var string = $.datepicker.formatDate('dd/mm/yy', date);
  138. for(var i=0; i<dates_production.length; i++) {
  139. //alert(dates_production[i]+' '+string) ;
  140. if(dates_production[i] == string)
  141. return [1] ;
  142. }
  143. return [0] ;
  144. // désactivé car internet explorer plante
  145. //return [ dates_production.indexOf(string) != -1 ] ;
  146. },
  147. onSelect: function(selectedDate) {
  148. // on remet tout les prix à zéro
  149. chat_systeme_commande_reset_table_prix() ;
  150. $('#has-commande-en-cours').hide() ;
  151. var tab_date = selectedDate.split('/') ;
  152. var date = new Date(tab_date[2],tab_date[1]-1,tab_date[0]) ;
  153. // set id production
  154. var id_production = 0 ;
  155. $('#dates div .date').each(function() {
  156. if($(this).html() == selectedDate) {
  157. id_production = $(this).parent().find('.id_production').html() ;
  158. }
  159. });
  160. $('#commande-id_production').val(id_production) ;
  161. // verif si le gars a une commande en cours pour cette production
  162. var has_commande_en_cours = false ;
  163. $('#commandes-en-cours .commande').each(function() {
  164. if($(this).data('idproduction') == id_production) {
  165. //alert('bada') ;
  166. $('#has-commande-en-cours a').attr('href',$(this).data('href')) ;
  167. $('#has-commande-en-cours').show() ;
  168. has_commande_en_cours = true ;
  169. $('#depots, #points-vente, #produits, #info-horaire-retrait-commande').hide() ;
  170. }
  171. }) ;
  172. if(!has_commande_en_cours) {
  173. chat_systeme_commande_produits_dispos(tab_date[2]+'-'+tab_date[1]+'-'+tab_date[0], date) ;
  174. $('#produits, .valider-commande, .btn-commentaire, #bar-fixed').hide() ;
  175. // déselection points de vente
  176. $('#points-vente .point-vente').removeClass('selected') ;
  177. $('#commande-id_point_vente').val('') ;
  178. // affichage points de vente
  179. $('#depots, #points-vente, #info-horaire-retrait-commande').fadeIn() ;
  180. // scroll
  181. boulange_scroll('step-choix-depot') ;
  182. }
  183. }
  184. }) ;
  185. if($('#commande-id_production').val()) {
  186. $("#dates .id_production").each(function() {
  187. if($(this).html() == $('#commande-id_production').val()) {
  188. var tab_date = $(this).parent().find('.date').html().split('/') ;
  189. var date = new Date(tab_date[2],tab_date[1]-1,tab_date[0]);
  190. $('#datepicker-production').datepicker('setDate',date) ;
  191. chat_systeme_commande_produits_dispos(tab_date[2]+'-'+tab_date[1]+'-'+tab_date[0], date) ;
  192. chat_init_horaire_point_vente(date) ;
  193. }
  194. }) ;
  195. }
  196. // tableau produits
  197. $('.commande-form .move-quantity').click(function() {
  198. var vrac = ($(this).parent().parent().parent().parent().parent().parent().parent().attr('id') == 'vrac') ;
  199. if(vrac) {
  200. var quantite = parseInt($(this).parent().parent().find('input.quantity').val()) ;
  201. if($(this).hasClass('moins') && quantite != 0)
  202. quantite -= 500 ;
  203. if($(this).hasClass('plus'))
  204. quantite += 500 ;
  205. $(this).parent().parent().find('input.quantity').val(quantite) ;
  206. chat_systeme_commande_maj_table_prix();
  207. }
  208. else {
  209. var quantite_totale = 0 ;
  210. $('.quantity').each(function() {
  211. quantite_totale += parseInt($(this).val()) ;
  212. }) ;
  213. if($(this).hasClass('plus') && quantite_totale > 2 && $('#confiance').val() == 0) {
  214. $('html, body').animate({
  215. scrollTop: $('#produits').offset().top - 150
  216. }, 'normal', function() {
  217. $('#mess-limit-quantity').fadeOut('fast',function() {
  218. $(this).fadeIn('fast') ;
  219. })
  220. });
  221. }
  222. else {
  223. var quantite = parseInt($(this).parent().parent().find('input.quantity').val()) ;
  224. var quantite_restante = parseInt($(this).parent().parent().parent().find('.quantite-restante .nb').html()) ;
  225. //alert('bada') ;
  226. if($(this).hasClass('moins') && quantite != 0)
  227. quantite -- ;
  228. if($(this).hasClass('plus')){
  229. if(quantite + 1 <= quantite_restante) {
  230. quantite ++ ;
  231. }
  232. else {
  233. if(quantite_restante <= 5) {
  234. $(this).parent().parent().parent().find('.quantite-restante').hide().fadeIn() ;
  235. }
  236. else {
  237. // alert ?
  238. // ...
  239. }
  240. }
  241. }
  242. $(this).parent().parent().find('input.quantity').val(quantite) ;
  243. chat_systeme_commande_maj_table_prix();
  244. }
  245. }
  246. }) ;
  247. chat_systeme_commande_maj_table_prix() ;
  248. chat_systeme_commande_credit_pain();
  249. }
  250. // commentaire commande
  251. $('.commande-form .btn-commentaire').click(function() {
  252. if($('.field-commande-commentaire').css('display') == 'none') {
  253. $('.field-commande-commentaire').slideDown() ;
  254. }
  255. else {
  256. $('.field-commande-commentaire').slideUp() ;
  257. }
  258. return false ;
  259. }) ;
  260. // bar fixed
  261. if($('#bar-fixed').size()) {
  262. $(window).scroll(function (event) {
  263. var scroll = $(window).scrollTop() + $(window).height();
  264. var pos_bottom_produits = $('#table-produits').offset().top + $('#table-produits').height() + 100 ;
  265. if(scroll > pos_bottom_produits) {
  266. if(!$('#bar-fixed').hasClass('not-fixed')) {
  267. $('#bar-fixed').addClass('not-fixed') ;
  268. }
  269. }
  270. else {
  271. $('#bar-fixed').removeClass('not-fixed') ;
  272. }
  273. });
  274. }
  275. }
  276. function chat_systeme_commande_produits_dispos(str_date, date) {
  277. // produits dispos à la vente à cette date
  278. $.get('index.php',{
  279. r: 'commande/infos-production',
  280. date: str_date,
  281. }, function(data) {
  282. if(data.produits_dispos) {
  283. $.each(data.produits_dispos, function( id_produit, produit ) {
  284. if(produit.actif) $('.produit-'+id_produit).show() ;
  285. else $('.produit-'+id_produit).hide() ;
  286. var quantite_restante = produit.quantite_max - produit.quantite_commandee ;
  287. //if(quantite_restante > 0 || !produit.epuise) {
  288. /*if(quantite_restante > 0) {
  289. $('.produit-'+id_produit+' .epuise').hide() ;
  290. $('.produit-'+id_produit+' .input-group').show() ;
  291. $('.produit-'+id_produit+' .quantite-restante .nb').html(quantite_restante) ;
  292. if(parseInt($('.produit-'+id_produit+' .quantite-restante .nb').html()) > 5) {
  293. $('.produit-'+id_produit+' .quantite-restante').hide() ;
  294. }
  295. else {
  296. $('.produit-'+id_produit+' .quantite-restante').show() ;
  297. }
  298. }
  299. else {
  300. $('.produit-'+id_produit+' .epuise').show() ;
  301. $('.produit-'+id_produit+' .quantite-restante').hide() ;
  302. $('.produit-'+id_produit+' .input-group').hide() ;
  303. } */
  304. if((!produit.vrac && (!quantite_restante || quantite_restante < 0 || produit.epuise)) || (produit.vrac && produit.epuise)) {
  305. $('.produit-'+id_produit+' .epuise').show() ;
  306. $('.produit-'+id_produit+' .quantite-restante').hide() ;
  307. $('.produit-'+id_produit+' .input-group').hide() ;
  308. }
  309. else {
  310. $('.produit-'+id_produit+' .epuise').hide() ;
  311. $('.produit-'+id_produit+' .input-group').show() ;
  312. $('.produit-'+id_produit+' .quantite-restante .nb').html(quantite_restante) ;
  313. if(parseInt($('.produit-'+id_produit+' .quantite-restante .nb').html()) > 5) {
  314. $('.produit-'+id_produit+' .quantite-restante').hide() ;
  315. }
  316. else {
  317. $('.produit-'+id_produit+' .quantite-restante').show() ;
  318. }
  319. }
  320. });
  321. }
  322. $('#livraison').val(data.livraison) ;
  323. chat_init_horaire_point_vente(date) ;
  324. }, 'json') ;
  325. }
  326. function chat_systeme_commande_reset_table_prix() {
  327. $('#table-produits tr .colonne-quantite .quantity').each(function() {
  328. $(this).val(0) ;
  329. }) ;
  330. chat_systeme_commande_maj_table_prix() ;
  331. }
  332. function chat_systeme_commande_maj_table_prix() {
  333. // produits pain
  334. var prix = 0 ;
  335. $('.commande-form #table-produits tbody tr').each(function() {
  336. var quantite = parseInt($(this).find('.quantity').val()) ;
  337. var prix_produit = parseFloat($(this).find('.prix').html()) ;
  338. var prix_total_produit = quantite * prix_produit ;
  339. if(prix_total_produit)
  340. $(this).find('.total').html(formate_prix(prix_total_produit)+' €') ;
  341. else
  342. $(this).find('.total').html('--') ;
  343. if(quantite > 0)
  344. prix += prix_total_produit ;
  345. }) ;
  346. $('#total-commande strong').html(formate_prix(prix)+' €') ;
  347. var prix_global = prix ;
  348. // produits vrac
  349. var prix = 0 ;
  350. $('.commande-form #table-produits-vrac tbody tr').each(function() {
  351. var quantite = parseInt($(this).find('.quantity').val()) ;
  352. var prix_produit = parseFloat($(this).find('.prix').html()) ;
  353. var prix_total_produit = quantite/1000 * prix_produit ;
  354. if(prix_total_produit)
  355. $(this).find('.total').html(formate_prix(prix_total_produit)+' €') ;
  356. else
  357. $(this).find('.total').html('--') ;
  358. if(quantite > 0)
  359. prix += prix_total_produit ;
  360. }) ;
  361. $('#total-commande-vrac strong').html(formate_prix(prix)+' €') ;
  362. prix_global += prix ;
  363. $('#total-commande-bottom span').html(formate_prix(prix_global)) ;
  364. if(prix_global)
  365. $('#total-commande-bottom').fadeIn() ;
  366. else
  367. $('#total-commande-bottom').hide() ;
  368. // maj credit pain
  369. chat_systeme_commande_credit_pain_event(prix_global) ;
  370. return prix_global ;
  371. }
  372. function chat_systeme_commande_credit_pain() {
  373. $('input[name=credit_pain]').change(function() {
  374. var prix_global = chat_systeme_commande_maj_table_prix() ;
  375. chat_systeme_commande_credit_pain_event(prix_global) ;
  376. }) ;
  377. }
  378. function chat_systeme_commande_credit_pain_event(prix_global) {
  379. var html = '' ;
  380. var use_credit_pain = $('input[name=credit_pain]').prop('checked') ;
  381. var credit_pain = parseFloat($('#montant-credit-pain').val()) ;
  382. var credit_pain_dispo = credit_pain ;
  383. var montant_paye = 0
  384. if($('#montant-paye').size() && $('#montant-paye').val())
  385. montant_paye = parseFloat($('#montant-paye').val()) ;
  386. if($('#id-commande').size() && $('#id-commande').val()) {
  387. credit_pain_dispo = credit_pain + montant_paye ;
  388. }
  389. if(prix_global > credit_pain_dispo) {
  390. var reste_payer = prix_global - credit_pain_dispo ;
  391. if(use_credit_pain) {
  392. if(montant_paye) {
  393. html += '<span class="montant-paye">'+montant_paye+' € déjà payé</span><br />' ;
  394. }
  395. html += '<strong>'+credit_pain+' €</strong> seront débités<br />' ;
  396. html += 'Restera <strong>'+reste_payer+' €</strong> à payer à la boulangerie' ;
  397. $('#checkbox-credit-pain .info').html(html) ;
  398. }
  399. else {
  400. $('#checkbox-credit-pain .info').html('') ;
  401. }
  402. }
  403. else {
  404. $('#checkbox-credit-pain').removeClass('paiement-impossible') ;
  405. $('input[name=credit_pain]').removeAttr('disabled') ;
  406. if(use_credit_pain) {
  407. var html = '' ;
  408. // à payer
  409. if(prix_global > montant_paye)
  410. {
  411. montant = prix_global - montant_paye ;
  412. if(montant_paye) {
  413. html += '<span class="montant-paye">'+montant_paye+' € déjà payé</span><br />' ;
  414. }
  415. html += '<strong>'+montant+' €</strong> seront débités' ;
  416. $('#checkbox-credit-pain .info').html(html) ;
  417. }
  418. // remboursé
  419. else if(prix_global < montant_paye) {
  420. montant = montant_paye - prix_global ;
  421. if(montant_paye) {
  422. html += '<span class="montant-paye">'+montant_paye+' € déjà payé</span><br />' ;
  423. }
  424. html += '<strong>'+montant+' €</strong> seront remboursés' ;
  425. $('#checkbox-credit-pain .info').html(html) ;
  426. }
  427. else {
  428. if(montant_paye > 0)
  429. $('#checkbox-credit-pain .info').html('<span class="montant-paye">'+montant_paye+' € déjà payé</span>') ;
  430. else
  431. $('#checkbox-credit-pain .info').html('') ;
  432. }
  433. }
  434. else {
  435. $('#checkbox-credit-pain .info').html('')
  436. }
  437. }
  438. }
  439. function formate_prix(prix) {
  440. return prix.toFixed(2).replace( ".", "," ) ;
  441. }
  442. function chat_slideshow() {
  443. if($('body').hasClass('home')) {
  444. var base_url = $('#base_url').val() ;
  445. $.vegas('slideshow', {
  446. backgrounds:[
  447. //{ src:'./img/background/back2.jpg' },
  448. { src:base_url+'/img/background/four.jpg' },
  449. { src:base_url+'/img/background/gueulard.jpg' }
  450. ],
  451. walk: function() {
  452. $('.vegas-loading').css('display','none') ;
  453. $('.vegas-background').css('position','absolute') ;
  454. }
  455. })('overlay');
  456. }
  457. }
  458. function chat_scroll() {
  459. if($('body').hasClass('home')) {
  460. $('#header nav ul a[href^="#"]').click(function(){
  461. var the_id = $(this).attr("href");
  462. $('html, body').animate({
  463. scrollTop: $(the_id).offset().top - 100
  464. }, 'normal');
  465. return false;
  466. });
  467. $(window).scroll(function() {
  468. chat_event_scroll() ;
  469. }) ;
  470. chat_event_scroll() ;
  471. }
  472. }
  473. function chat_event_scroll() {
  474. var scroll_top = $(window).scrollTop() ;
  475. //console.log(scroll_top + ' '+ ($('#horaires').offset().top-100)) ;
  476. $('#header nav ul a').each(function() {
  477. var top = $($(this).attr('href')).offset().top ;
  478. var test = top + $($(this).attr('href')).height() - 150 ;
  479. //console.log($(this).attr('href')+' : '+scroll_top+ ' | '+ test) ;
  480. if(scroll_top <= top + $($(this).attr('href')).height() - 150) {
  481. $('#header a').removeClass('selec') ;
  482. $(this).addClass('selec') ;
  483. }
  484. }) ;
  485. }
  486. function chat_tabs_gamme_saison() {
  487. $('#tab-gamme-saison a').click(function (e) {
  488. e.preventDefault();
  489. $(this).tab('show');
  490. });
  491. }