IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

JavaScript Discussion :

interaction entre calendriers


Sujet :

JavaScript

  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    512
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Indre et Loire (Centre)

    Informations forums :
    Inscription : Juin 2007
    Messages : 512
    Par défaut interaction entre calendriers
    Bonjour,
    j'ai deux calendriers qui s'ouvre par la fonction popup, jusque là pas de soucis.
    le premier calendrier représente une date de début et le deuxième une date de fin, la date de fin ne pouvant etre inférieur à la date de début logique.
    Lorsque je sélectionne une date de mon premier calendrier par exemple le 11/12/2009 j'aimerais que lorsque je ferme le premier et que j'ouvre le deuxième celui-ci ne s'ouvre pas selon la date du jour mais la date que j'ai sélectionné dans le premier calendrier.

    Je travaille en php à la base, mais pour faire ce qui est dit au dessus je vais avoir besoin de javascript mais n'y connait pas grandchose

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    <script language="JavaScript">
    var cal1 = new calendar1(document.forms['formUtilr'].elements['_recherche_dateD'],true);
    cal1.year_scroll = true;
    cal1.time_comp = false;
    </script>
    même chose pour le deuxième calendrier.

    Merci.

  2. #2
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Par défaut
    Salut,

    Désolé, mais le code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    document.onDevineAutomatiquementLeCode = envoyerReponse;
    M'affiche le message d'alerte :
    Désolé, votre plugin "Boule de cristal" a mal fonctionné,
    impossible de deviner le code automatiquement.
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  3. #3
    Membre Expert
    Inscrit en
    Septembre 2002
    Messages
    2 307
    Détails du profil
    Informations forums :
    Inscription : Septembre 2002
    Messages : 2 307
    Par défaut
    [Boule_De_Cristal]
    post sc ript
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    if(document.forms['formUtilr'].elements['_recherche_dateF'].value==""){
    document.forms['formUtilr'].elements['_recherche_dateF'].value=document.forms['formUtilr'].elements['_recherche_dateD'].value
    }
    [/Boule_De_Cristal]

  4. #4
    Membre éclairé
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    512
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Indre et Loire (Centre)

    Informations forums :
    Inscription : Juin 2007
    Messages : 512
    Par défaut
    Merci Matthieu2000 ça fonctionne seul petit soucis c'est que la date du premier calendrier s'affiche aussi dans le deuxième...est-ce que je peux contrer ça,puisque j'affiche mes dates sélectionnées dans des zones de texte ensuite.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
     
    <p>
    			<span class="spanDecal"><span class="gras">Période du : </span></span>		
    			<input id="sel1" value="<?php echo $dateD_value; ?>" readonly onclick="javascript:cal1.popup();" name="_recherche_dateD" type="text" class="inputRecherche12px" size="10">
    			<a href="javascript:cal1.popup(); " ><img src="<?php echo $_DOSSIER_FORME; ?>images/cal.gif" width="16" height="16" border="0" alt="Afficher le calendrier"></a>
    			<script language="JavaScript">
    				var cal1 = new calendar1(document.forms['formUtilr'].elements['_recherche_dateD'],true);
    				cal1.year_scroll = true;
    				cal1.time_comp = false;
    			</script>			
     
    			<span class="gras">&nbsp;  au : &nbsp;</span>
    			<input id="sel1" value="<?php echo $dateF_value; ?>" readonly onclick="javascript:cal2.popup();" name="_recherche_dateF" type="text" class="inputRecherche12px" size="10">
    			<a href="javascript:cal2.popup();"><img src="<?php echo $_DOSSIER_FORME; ?>images/cal.gif" width="16" height="16" border="0" alt="Afficher le calendrier"></a>
    			<script language="JavaScript">
    				var cal2 = new calendar1(document.forms['formUtilr'].elements['_recherche_dateF'],true);
    				if(document.forms['formUtilr'].elements['_recherche_dateF'].value==""){
    document.forms['formUtilr'].elements['_recherche_dateF'].value=document.forms['formUtilr'].elements['_recherche_dateD'].value
    }
    				cal2.year_scroll = true;
    				cal2.time_comp = false;
    			</script>
     
    		</p>

  5. #5
    Membre Expert
    Inscrit en
    Septembre 2002
    Messages
    2 307
    Détails du profil
    Informations forums :
    Inscription : Septembre 2002
    Messages : 2 307
    Par défaut
    envoie le code de
    calendar1

  6. #6
    Membre éclairé
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    512
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Indre et Loire (Centre)

    Informations forums :
    Inscription : Juin 2007
    Messages : 512
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
     
    function calendar1(obj_target,avec_form_update) {
     
    	// assigning methods
    	this.gen_date = cal_gen_date1;
    	this.gen_time = cal_gen_time1;
    	this.gen_tsmp = cal_gen_tsmp1;
    	this.prs_date = cal_prs_date1;
    	this.prs_time = cal_prs_time1;
    	this.prs_tsmp = cal_prs_tsmp1;
    	if(avec_form_update)this.popup    = cal_popup2;
    	else this.popup    = cal_popup1;
     
    	// validate input parameters
    	if (!obj_target)
    		return cal_error("Error calling the calendar: no target control specified");
    	if (obj_target.value == null)
    		return cal_error("Error calling the calendar: parameter specified is not valid target control");
    	this.target = obj_target;
    	this.time_comp = BUL_TIMECOMPONENT;
    	this.year_scroll = BUL_YEARSCROLL;
     
    	// register in global collections
    	this.id = calendars.length;
    	calendars[this.id] = this;
    }

  7. #7
    Membre Expert
    Inscrit en
    Septembre 2002
    Messages
    2 307
    Détails du profil
    Informations forums :
    Inscription : Septembre 2002
    Messages : 2 307
    Par défaut
    bizarre ton code!
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    if(avec_form_update)this.popup    = cal_popup2;
    	else this.popup    = cal_popup1;
    tu as 2 calques suivant la valeur du avec_form_update tu en prends une..

    Je penses que tu dois commencer par ajouter une fonction ici
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    onclick="javascript:cal2.popup();"
    par exemple
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    onclick="openCalendarF()"
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    function openCalendarF(){
    cal2.gen_date =cal1.gen_date;
    cal2.prs_date =cal1.prs_date ;
    //...autres parametre a initialiser
     
    cal2.popup();
    }
    PS : refaire l'ensemble de tes codes, c'est un peu bordélique!

  8. #8
    Membre éclairé
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    512
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Indre et Loire (Centre)

    Informations forums :
    Inscription : Juin 2007
    Messages : 512
    Par défaut
    Ben c'est pas mon code en faite, je prends la suite d'un apprentis...et j'avoue que j'ai un peu de mal à m'y retrouvé dans tout ce bazar...

  9. #9
    Membre éclairé
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    512
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Indre et Loire (Centre)

    Informations forums :
    Inscription : Juin 2007
    Messages : 512
    Par défaut
    J'ai deux fonctions de ce genre aussi mais je vois pas trop à quoi elles servent
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
     
    function cal_popup1 (str_datetime) {
    	if (str_datetime) {
    		this.dt_current = this.prs_tsmp(str_datetime);
    	}
    	else {
    		this.dt_current = this.prs_tsmp(this.target.value);
    		this.dt_selected = this.dt_current;
    	}
    	if (!this.dt_current) return;
     
    	var obj_calwindow = window.open(
    		'../../utils/calendrier/calendar.html?datetime=' + this.dt_current.valueOf()+ '&id=' + this.id,
    		'Calendar', 'width=200,height='+(this.time_comp ? 215 : 190)+
    		',status=no,resizable=no,top=200,left=200,dependent=yes,alwaysRaised=yes'
    	);
    	obj_calwindow.opener = window;
    	obj_calwindow.focus();
    }

  10. #10
    Membre éclairé
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    512
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Indre et Loire (Centre)

    Informations forums :
    Inscription : Juin 2007
    Messages : 512
    Par défaut
    lorsque je fais un nouvelle fonction ça ne marche pas...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
     
     
    // if two digit year input dates after this year considered 20 century.
    var NUM_CENTYEAR = 30;
    // is time input control required by default
    var BUL_TIMECOMPONENT = false;
    // are year scrolling buttons required by default
    var BUL_YEARSCROLL = true;
     
    var calendars = [];
    var RE_NUM = /^\-?\d+$/;
     
    function calendar1(obj_target,avec_form_update) {
     
    	// assigning methods
    	this.gen_date = cal_gen_date1;
    	this.gen_time = cal_gen_time1;
    	this.gen_tsmp = cal_gen_tsmp1;
    	this.prs_date = cal_prs_date1;
    	this.prs_time = cal_prs_time1;
    	this.prs_tsmp = cal_prs_tsmp1;
    	if(avec_form_update)this.popup    = cal_popup2;
    	else this.popup    = cal_popup1;
     
    	// validate input parameters
    	if (!obj_target)
    		return cal_error("Error calling the calendar: no target control specified");
    	if (obj_target.value == null)
    		return cal_error("Error calling the calendar: parameter specified is not valid target control");
    	this.target = obj_target;
    	this.time_comp = BUL_TIMECOMPONENT;
    	this.year_scroll = BUL_YEARSCROLL;
     
    	// register in global collections
    	this.id = calendars.length;
    	calendars[this.id] = this;
    }
     
    function cal_popup1 (str_datetime) {
    	if (str_datetime) {
    		this.dt_current = this.prs_tsmp(str_datetime);
    	}
    	else {
    		this.dt_current = this.prs_tsmp(this.target.value);
    		this.dt_selected = this.dt_current;
    	}
    	if (!this.dt_current) return;
     
    	var obj_calwindow = window.open(
    		'../../utils/calendrier/calendar.html?datetime=' + this.dt_current.valueOf()+ '&id=' + this.id,
    		'Calendar', 'width=200,height='+(this.time_comp ? 215 : 190)+
    		',status=no,resizable=no,top=200,left=200,dependent=yes,alwaysRaised=yes'
    	);
    	obj_calwindow.opener = window;
    	obj_calwindow.focus();
    }
     
    function cal_popup2 (str_datetime) {
    	if (str_datetime) {
    		this.dt_current = this.prs_tsmp(str_datetime);
    	}
    	else {
    		this.dt_current = this.prs_tsmp(this.target.value);
    		this.dt_selected = this.dt_current;
    	}
    	if (!this.dt_current) return;
     
    	var obj_calwindow = window.open(
    		'../../utils/calendrier/calendar2.html?datetime=' + this.dt_current.valueOf()+ '&id=' + this.id,
    		'Calendar', 'width=200,height='+(this.time_comp ? 215 : 190)+
    		',status=no,resizable=no,top=200,left=200,dependent=yes,alwaysRaised=yes'
    	);
    	obj_calwindow.opener = window;
    	obj_calwindow.focus();
    }
     
    // timestamp generating function
    function cal_gen_tsmp1 (dt_datetime) {
    	return(this.gen_date(dt_datetime) + ' ' + this.gen_time(dt_datetime));
    }
     
    // date generating function
    function cal_gen_date1 (dt_datetime) {
    	return (
    		(dt_datetime.getDate() < 10 ? '0' : '') + dt_datetime.getDate() + "-"
    		+ (dt_datetime.getMonth() < 9 ? '0' : '') + (dt_datetime.getMonth() + 1) + "-"
    		+ dt_datetime.getFullYear()
    	);
    }
    // time generating function
    function cal_gen_time1 (dt_datetime) {
    	return (
    		(dt_datetime.getHours() < 10 ? '0' : '') + dt_datetime.getHours() + ":"
    		+ (dt_datetime.getMinutes() < 10 ? '0' : '') + (dt_datetime.getMinutes()) + ":"
    		+ (dt_datetime.getSeconds() < 10 ? '0' : '') + (dt_datetime.getSeconds())
    	);
    }
     
    // timestamp parsing function
    function cal_prs_tsmp1 (str_datetime) {
    	// if no parameter specified return current timestamp
    	if (!str_datetime)
    		return (new Date());
     
    	// if positive integer treat as milliseconds from epoch
    	if (RE_NUM.exec(str_datetime))
    		return new Date(str_datetime);
     
    	// else treat as date in string format
    	var arr_datetime = str_datetime.split(' ');
    	return this.prs_time(arr_datetime[1], this.prs_date(arr_datetime[0]));
    }
     
    // date parsing function
    function cal_prs_date1 (str_date) {
     
    	var arr_date = str_date.split('-');
     
    	if (arr_date.length != 3) return cal_error ("Invalid date format: '" + str_date + "'.\nFormat accepted is dd-mm-yyyy.");
    	if (!arr_date[0]) return cal_error ("Invalid date format: '" + str_date + "'.\nNo day of month value can be found.");
    	if (!RE_NUM.exec(arr_date[0])) return cal_error ("Invalid day of month value: '" + arr_date[0] + "'.\nAllowed values are unsigned integers.");
    	if (!arr_date[1]) return cal_error ("Invalid date format: '" + str_date + "'.\nNo month value can be found.");
    	if (!RE_NUM.exec(arr_date[1])) return cal_error ("Invalid month value: '" + arr_date[1] + "'.\nAllowed values are unsigned integers.");
    	if (!arr_date[2]) return cal_error ("Invalid date format: '" + str_date + "'.\nNo year value can be found.");
    	if (!RE_NUM.exec(arr_date[2])) return cal_error ("Invalid year value: '" + arr_date[2] + "'.\nAllowed values are unsigned integers.");
     
    	var dt_date = new Date();
    	dt_date.setDate(1);
     
    	if (arr_date[1] < 1 || arr_date[1] > 12) return cal_error ("Invalid month value: '" + arr_date[1] + "'.\nAllowed range is 01-12.");
    	dt_date.setMonth(arr_date[1]-1);
     
    	if (arr_date[2] < 100) arr_date[2] = Number(arr_date[2]) + (arr_date[2] < NUM_CENTYEAR ? 2000 : 1900);
    	dt_date.setFullYear(arr_date[2]);
     
    	var dt_numdays = new Date(arr_date[2], arr_date[1], 0);
    	dt_date.setDate(arr_date[0]);
    	if (dt_date.getMonth() != (arr_date[1]-1)) return cal_error ("Invalid day of month value: '" + arr_date[0] + "'.\nAllowed range is 01-"+dt_numdays.getDate()+".");
     
    	return (dt_date)
    }
     
    // time parsing function
    function cal_prs_time1 (str_time, dt_date) {
     
    	if (!dt_date) return null;
    	var arr_time = String(str_time ? str_time : '').split(':');
     
    	if (!arr_time[0]) dt_date.setHours(0);
    	else if (RE_NUM.exec(arr_time[0]))
    		if (arr_time[0] < 24) dt_date.setHours(arr_time[0]);
    		else return cal_error ("Invalid hours value: '" + arr_time[0] + "'.\nAllowed range is 00-23.");
    	else return cal_error ("Invalid hours value: '" + arr_time[0] + "'.\nAllowed values are unsigned integers.");
     
    	if (!arr_time[1]) dt_date.setMinutes(0);
    	else if (RE_NUM.exec(arr_time[1]))
    		if (arr_time[1] < 60) dt_date.setMinutes(arr_time[1]);
    		else return cal_error ("Invalid minutes value: '" + arr_time[1] + "'.\nAllowed range is 00-59.");
    	else return cal_error ("Invalid minutes value: '" + arr_time[1] + "'.\nAllowed values are unsigned integers.");
     
    	if (!arr_time[2]) dt_date.setSeconds(0);
    	else if (RE_NUM.exec(arr_time[2]))
    		if (arr_time[2] < 60) dt_date.setSeconds(arr_time[2]);
    		else return cal_error ("Invalid seconds value: '" + arr_time[2] + "'.\nAllowed range is 00-59.");
    	else return cal_error ("Invalid seconds value: '" + arr_time[2] + "'.\nAllowed values are unsigned integers.");
     
    	dt_date.setMilliseconds(0);
    	return dt_date;
    }
     
    function cal_error (str_message) {
    	alert (str_message);
    	return null;
    voila tout le code pour les calendriers

Discussions similaires

  1. [Language]Interaction entre class
    Par LordBob dans le forum Langage
    Réponses: 10
    Dernier message: 14/12/2005, 10h14
  2. interaction entre mon programme & openOffice
    Par artatum dans le forum C
    Réponses: 4
    Dernier message: 10/10/2005, 22h28
  3. [VB .Net][Forms] Interaction entre deux forms
    Par plasticgoat dans le forum Windows Forms
    Réponses: 7
    Dernier message: 24/08/2005, 13h14
  4. [Collaboration/Interaction] Peut-on schématiser une interaction entre un bouton de commande et un autre objet ?
    Par manel007 dans le forum Autres Diagrammes
    Réponses: 5
    Dernier message: 21/09/2004, 01h01

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo