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

WinDev Discussion :

Comment savoir ce qui a été modifié par l'utilisateur ? [WD17]


Sujet :

WinDev

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Février 2004
    Messages
    67
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2004
    Messages : 67
    Points : 47
    Points
    47
    Par défaut Comment savoir ce qui a été modifié par l'utilisateur ?
    Bonjour à tous.

    La propriété ..modifié nous indique si quelque chose a été modifié.
    Mais comment faire pour savoir ce qui a été modifié sans tester tous les champs un à un ?

    Merci de votre aide !

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Responsable Données
    Inscrit en
    Janvier 2009
    Messages
    5 262
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable Données

    Informations forums :
    Inscription : Janvier 2009
    Messages : 5 262
    Points : 12 936
    Points
    12 936
    Par défaut
    Bonjour,
    Tu peux faire une boucle avec EnumereChamp(), puis utiliser les indirections pour tester tous les champs d'une fenêtre.

    Tatayo.

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Février 2004
    Messages
    67
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2004
    Messages : 67
    Points : 47
    Points
    47
    Par défaut
    Merci Tatayo !

    Voici ce que j'ai fait:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    i est entier = 1
    sChampmodifié est une chaîne
    sNomChamp est une chaîne
    sNomChamp = EnumèreChamp(FEN_Fiche_Immo, i)
     
    TANTQUE sNomChamp<>""
    	TestChampModif(sNomChamp, sChampmodifié)
    	i++
    	sNomChamp = EnumèreChamp(FEN_Fiche_Immo, i)
    FIN
    Et la procédure:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    PROCEDURE TestChampModif(Nom_Champ, sChampsModifiés)
     
    SI {Nom_Champ}..Modifié=Vrai ALORS
    	sChampsModifiés+=[" / "]	+{Nom_Champ}..Libellé
    FIN
    RENVOYER sChampsModifiés
    Je ne connaissais pas les indirections !
    C'était bien comme cela que tu voyais les choses ?

  4. #4
    Expert éminent sénior
    Homme Profil pro
    Responsable Données
    Inscrit en
    Janvier 2009
    Messages
    5 262
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable Données

    Informations forums :
    Inscription : Janvier 2009
    Messages : 5 262
    Points : 12 936
    Points
    12 936
    Par défaut
    Tout à fait.
    Par contre je n'aime pas trop les procédures qui changent la valeur des paramètres.
    J'aurai plutôt fait ainsi:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    i est entier = 1
    sChampmodifié est une chaîne
    sNomChamp est une chaîne
    sNomChamp = EnumèreChamp(FEN_Fiche_Immo, i)
     
    TANTQUE sNomChamp<>""
    	sChampmodifié += ["/"] + TestChampModif(sNomChamp)
    	i++
    	sNomChamp = EnumèreChamp(FEN_Fiche_Immo, i)
    FIN
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    PROCEDURE TestChampModif(Nom_Champ)
    sChampsModifiés est une chaine
     
    SI {Nom_Champ}..Modifié=Vrai ALORS
    	sChampsModifiés = {Nom_Champ}..Libellé
    FIN
    RENVOYER sChampsModifiés
    Tatayo.

  5. #5
    Membre chevronné
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2009
    Messages
    1 278
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Mars 2009
    Messages : 1 278
    Points : 2 151
    Points
    2 151
    Par défaut
    Citation Envoyé par meganulos Voir le message
    Merci Tatayo !

    Voici ce que j'ai fait:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    i est entier = 1
    sChampmodifié est une chaîne
    sNomChamp est une chaîne
    sNomChamp = EnumèreChamp(FEN_Fiche_Immo, i)
     
    TANTQUE sNomChamp<>""
    	TestChampModif(sNomChamp, sChampmodifié)
    	i++
    	sNomChamp = EnumèreChamp(FEN_Fiche_Immo, i)
    FIN
    Et la procédure:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    PROCEDURE TestChampModif(Nom_Champ, sChampsModifiés)
     
    SI {Nom_Champ}..Modifié=Vrai ALORS
    	sChampsModifiés+=[" / "]	+{Nom_Champ}..Libellé
    FIN
    RENVOYER sChampsModifiés
    Je ne connaissais pas les indirections !
    C'était bien comme cela que tu voyais les choses ?
    Je pense que oui.. par contre tu devrais rajouter un indchamp dans ton indirection : {Nom_Champ, indchamp}..Modifié

  6. #6
    Membre du Club
    Profil pro
    Inscrit en
    Février 2004
    Messages
    67
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2004
    Messages : 67
    Points : 47
    Points
    47
    Par défaut
    Merci Tatayo, j'ai fait la modification que tu as préconisée.
    Par contre Michel, le indchamp c'est quoi et ça sert à quoi ?

  7. #7
    Membre chevronné
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2009
    Messages
    1 278
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Mars 2009
    Messages : 1 278
    Points : 2 151
    Points
    2 151
    Par défaut
    C'est une indication pour l'indirection qui permet d'optimiser la recherche de l'objet (en fonction de son type)

  8. #8
    Membre du Club
    Profil pro
    Inscrit en
    Février 2004
    Messages
    67
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2004
    Messages : 67
    Points : 47
    Points
    47
    Par défaut
    OK !

    Merci beaucoup à tous les deux.

  9. #9
    Membre habitué
    Avatar de jdsetls
    Homme Profil pro
    Rédacteur technique
    Inscrit en
    Décembre 2012
    Messages
    209
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Rédacteur technique
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Décembre 2012
    Messages : 209
    Points : 167
    Points
    167
    Billets dans le blog
    1
    Par défaut Faire un fichier texte ?
    Je te suggère d'ajouter à ton bouton de modification une routine créant un fichier texte, ou y ajoutant :
    date, heure, utilisateur, rubriques modifiées.

    Tu peux ajouter Valeur d'origine d'après Mon_fichier.Ma_rubrique
    valeur modifiée d'après Mon_champ_lié

    à condition bien sûr que tu récupères le contenu de la rubrique avant d'écrire ton EcranVersFichier.

    Pour les principes de mise en œuvre, comme Tatayo te l'a décrit.

    As ever in a coding world,

    Jacques De Schryver

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 1
    Dernier message: 16/01/2014, 16h58
  2. comment savoir si une table est lockée par un user
    Par zinabd dans le forum Oracle
    Réponses: 4
    Dernier message: 16/01/2009, 10h18
  3. Comment savoir si un champ est compteur par req
    Par nanou9999 dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 14/09/2006, 12h18
  4. [CSS] Comment savoir ce qui est faisable?
    Par cladsam dans le forum Mise en page CSS
    Réponses: 13
    Dernier message: 07/02/2006, 13h06
  5. Comment savoir qu'un fichier est modifie
    Par moniphal dans le forum Langage
    Réponses: 2
    Dernier message: 02/10/2005, 10h26

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