Toutes mes réponses sur les forums
-
AuteurRéponses
-
Merlin
Maître des clésJe n’ai pas le temps de tout bien vérifier mais a priori le problème vient du nom des champs (this.getField(“Name.3.1”) et this.getField(“Name.3.2”)) qui sont utilisés dans le script en nom absolu.
Comme ils rentrent dans la boucle leur nom est modifié pendant l’exécution de celle-ci et ça provoque des incohérences.
Ça l’est moins quand on utilise P1 mais c’est flagrant quand on utilise P2, le retour de la Console est sans appel :
TypeError: this.getField(…) is null
12:Document-Level:Renommer_c(dans “Test-4.pdf”, ligne 12 du script sans commentaire, ou ligne 15 du script commenté, voir capture)
Il faut donc soit les exclure de la boucle, soit modifier leurs noms de sorte qu’ils ne rentrent pas dans la boucle.
Attachments:
You must be logged in to view attached files.Merlin
Maître des clésBonjour
J’ai placé cette question dans un nouveau sujet pour plus de clarté.
Pour répondre à la question : je n’ai jamais utilisé FindChangeList.txt avec AppleScript, seulement avec les scripts JavaScript (.jsx).
Tout ce que je peux te dire c’est que le fichier FindChangeList.txt doit être placé dans le dossier FindChangeSupport qui se trouve au même niveau que le fichier FindChangeByList.jsx
A priori ça devrait être pareil pour les scripts AppleScript.
Attachments:
You must be logged in to view attached files.Merlin
Maître des clés“Il y a un truc que je ne comprend pas. Mon script fonctionne mais il y a toujours un champ qui n’est pas renommé…”
Il est toujours très difficile d’examiner des scripts non commentés, même quand on sait ce qu’ils sont supposés faire.
J’y jetterai un deuxième regard demain à tête reposée.
Merlin
Maître des clés“Par contre mon script ne fonctionne pas quand je souhaite “modifier” la partie 2 P2. J’ai une erreur à la ligne 28…”
Vu le dernier exemple je crois que tu as compris l’erreur entre nom du script (qui importe peu) et nom de la fonction.
Attachments:
You must be logged in to view attached files.Merlin
Maître des clésBonjour
Non hélas, ni ses instructions (dont je suis l’auteur) ni ce script (fourni par Adobe) ne permettent de rechercher dans un style de paragraphe en particulier.
Tu pourrais peut-être trouver ton bonheur en utilisant ce script : Record Find Change
Merlin
Maître des clés“un nouveau problème rien ne fonctionne sur les mobiles !!!!!!!!!! une idée pourquoi ? c’est des simples boutons …”
En fait ce n’est pas nouveau, hélas.
Le support de JavaScript sur les mobiles est très très limité. Pour te donner une idée la documentation JavaScript d’Acrobat fait plus de 800 pages, celle d’Acrobat Mobile à peine une soixantaine.
“la personne qui m’a répondu est un des dirigeants d’une banque privée.”
Je travaille beaucoup avec les banques, suffisamment pour savoir que en général les postes sont équipés d’Acrobat Reader mais que le plus souvent l’utilisation de JavaScript est désactivée par le service informatique. Sécurité oblige.
“Le but est de faire du visuel et d’impressionner”
Dans ce cas le plus simple est d’utiliser InDesign, de faire des animations qui déchirent avec ses fonctions intégrées et/ou avec Express, de publier en ligne avec Publish On Line et de mettre un lien sur ton CV.
Le PDF a beaucoup de qualités (ce n’est pas moi qui dirait le contraire) mais en version interactive ce n’est pas un format diffusable de façon fiable.
Exemple que j’ai réalisé : https://indd.adobe.com/view/2a8f6f46-a53c-4fd4-851e-db3a5d906f6b
Exemple réalisé par JCTremblay : https://indd.adobe.com/view/16a62004-694d-442a-9650-000a6dd4d241
Et voir plus généralement : https://indd.adobe.com/view/c2c7aa96-405e-488f-8902-e1d96c1bea4f
Merlin
Maître des clésSinon fais moi passer ton document, avec Acrobat j’en aurai pour 2 minutes.
Merlin
Maître des clés“Je voulais renommer 30 champs : “Q.7.1” à “Q.7.30” qui se seraient appelés : “R.7.1″ à R.7.30”.”
Il y a beaucoup plus simple qu’un script, c’est une astuce bien cachée dans Acrobat (je ne sais pas pour PDF Expert).
Dans le panneau des champs il faut d’abord cliquer sur le bouton AZ pour afficher les champs dans l’ordre alphabétique.
À partir de là il apparaissent sous forme d’une arborescence qu’on déplie en cliquant sur les flèches, ce sont les points dans les noms qui séparent chaque niveau.
Il faut juste savoir qu’il suffit de double-cliquer sur un nom pour pouvoir renommer, on peut renommer la racine ou n’importe quel niveau en deux secondes. 😉
Attachments:
You must be logged in to view attached files.Merlin
Maître des clés“D’après plusieurs pro dans le domaine 3 minutes pour un CV “
Compte plutôt entre 10 et 20 secondes.
Il est généralement plus judicieux de présenter un CV “normal” et d’y mettre des liens vers les documents interactifs que tu veux présenter, ainsi s’il retient l’attention le recruteur prendra le temps d’aller voir.
“je ne sais pas supprimer des calques”
Acrobat est retors : il faut d’abord masquer le calque à supprimer et ensuite soit aplatir tous les calques soit le fusionner avec un autre, ce qui le fait disparaitre.
“la lecture des vidéos n’est pas activé par defaut”
Si Acrobat pouvait déjà juste lire les vidéos se serait bien, depuis la dernière mise à jour ça ne fonctionne plus !
Merlin
Maître des clésBonjour
L’expérience montre que la plupart des gens (et des recruteurs) affichent les PDF dans le logiciel par défaut (Aperçu sur Mac, Edge sur Windows, et “Pourave” sur mobile).
Donc pour qu’un CV soit lu et retenu il faut aller au plus simple pour être efficace.
En clair : zéro interactivité, parce qu’en plus s’ils comprennent que quelque chose ne fonctionne pas dans certains cas ce sera forcément de ta faute et à cause de ton “incompétence”. Ils ne remettront jamais en cause leur logiciel ni leurs pratiques.
Merlin
Maître des clésbebarth doit être en vacances.
J’ai retrouvé le sujet, le script y est en pièce jointe :
Merlin
Maître des clésNos messages se sont croisés (j’étais au téléphone avec un bavard).
Sinon, bebarth a créé un utilitaire de renommage des champs, je pense qu’il va t’en parler.
Merlin
Maître des clésBonjour
Il te faut télécharger la version d’essai de Qoppa PDF Studio qui permet de renommer plusieurs champs de formulaire à la fois, des centaines si besoin.
Comme cette version d’essai ajoute des filigranes l’astuce c’est de faire ça dans une copie du document PDF et ensuite de ramener les champs renommés dans le document original par copier-coller en ouvrant les 2 PDF avec Acrobat, ou avec PDF Expert.
Pour trouver cette fonction il faut sélectionner plusieurs champs à la fois et faire un clic-droit dessus : Sequential renaming (Je ne l’ai pas en français).
Attachments:
You must be logged in to view attached files.Merlin
Maître des clésBonjour
Ça m’en bouche un coin ! Je ne savais qu’il existait un logiciel capable faire ça (bien que dans Acrobat les items se placent à gauche quand on clique sur le menu).
Concernant Acrobat tu n’as rien raté, la réponse est non.
Merlin
Maître des clésSur mon PC ça fonctionne bien, sauf quand je veux jouer la même note deux fois de suite : pour la jouer une deuxième fois il faut cliquer deux fois de suite.
Je ne peux pas tester faute d’avoir les sons mais je me demande si tu ne devrais pas plutôt utiliser l’action souris relâchée.
Merlin
Maître des clés🙂
Merlin
Maître des clésBonjour
Il me semble que c’est un vieux bug de la version Mac, fais moi passer ton fichier que j’essaie sur PC.
Merlin
Maître des clésBonjour
” En fait, tout se passe à la création de ton champ image qui te propose un nom avec le suffixe “_af_image”.”
Ça c’est le comportement d’Acrobat, peut être que PDF Expert gère différemment.
En tout cas oui, il faut qu’il y ait une différence entre les noms car JavaScriptement on ne peut pas distinguer un bouton image d’un bouton en label/texte seul.
Merlin
Maître des clésEssaye ça :
if (nomChamp.indexOf("Aide.")==0) {
if (this.getField(nomChamp).type=="text" || (this.getField(nomChamp).type=="button" && nomChamp.indexOf("_af_image")>0)) this.getField(nomChamp).readonly=true;
else this.getField(nomChamp).readonly=false;
}
Merlin
Maître des clésDans ce cas il faut voir avec le service informatique ou avec l’administrateur de l’ordinateur, qui a volontairement verrouillé cette option.
C’est souvent le cas dans les entreprises qui ne veulent pas prendre le moindre risque de sécurité.
Merlin
Maître des clésCe message prévient que JavaScript n’est pas activé sur le poste utilisé, il est donc normal que rien ne fonctionne.
Tu peux soit cliquer sur le bouton “Options” pour l’activer pour ce document seulement, soit l’activer dans les Préférences pour tous les documents.
Attachments:
You must be logged in to view attached files.Merlin
Maître des clésBonjour
bebarth m’a devancé.
Effectivement le type “image” n’existe pas, et s’il n’y a pas de message d’erreur dans la console c’est tout simplement parce-que la condition ne s’exécute pas, et donc qu’elle ne peut pas provoquer d’erreur.
C’est dans ces cas là qu’on regrette de ne pas avoir utilisé :
try {
// blablabla
}
catch(e) {console.println(e);}
😉
Merlin
Maître des clésthis.dirty = false;
est placé à la fin de chaque fonction pour que l’utilisateur ne soit pas invité à enregistrer le document après utilisation.
Merlin
Maître des clésNe te fatigues pas avec les scripts contenus dans le document ils sont minifiés.
Ci-dessous les deux principaux, le premier s’exécute à l’ouverture du document, le deuxième à chaque changement de sélection du menu déroulant.
/* importation texte */
this.delay = true;
this.resetForm();
this.getField("ratpStation").clearItems(); // champ liste déroulante
// importer l'unique PJ sans la nommer
var p = this.getDataObject(this.dataObjects[0].name)
var fi = this.getDataObjectContents(p.name)
var fit = util.stringFromStream(fi)
// séparation des rangées
var datarr1 = fit.split("\n")
// séparation des colonnes
var datarr = new Array()
for (var i = 0 ; i < datarr1.length ; i++) {datarr = datarr1.split(";")}
var fillarr = new Array() ;
for (var j = 0 ; j < datarr.length ; j++) { fillarr[j] = [datarr[j][1], j] ;}
// remplissage de la liste déroulante avec la 2e rangée
this.getField("ratpStation").setItems(fillarr);
// réglage du corps de la liste déroulante au cas où
this.getField("ratpStation").textSize = 18;
// masquage du champ QRcode
this.getField("ratp.QRcode").display = display.hidden;
// masquage du bouton Gmap
this.getField("ratpBoutonGmap").display = display.hidden;
// mise en couleur des champs
maCouleur = ["RGB", 224/255, 224/255, 224/255]; // gris moyen clair
this.getField("ratpStation").fillColor = maCouleur;
this.getField("ratp.adresse").fillColor = maCouleur;
this.getField("ratp.coordonneesGPS").fillColor = maCouleur;
this.getField("ratp.departement").fillColor = maCouleur;
this.delay = false;
this.dirty = false;
/****************************************************/
function selectData() {
if (!event.willCommit) {
this.delay = true;
this.getField("ratp.adresse").value = datarr[event.changeEx][2];
this.getField("ratp.coordonneesGPS").value = datarr[event.changeEx][3];
this.getField("ratp.departement").value = datarr[event.changeEx][7];
// affichage bouton Gmap
this.getField("ratpBoutonGmap").display = display.visible;
// affichage du champ QRcode sauf si Reader
if (app.viewerVariation == "Reader")
{this.getField("ratp.QRcode").display = display.hidden;}
else
{this.getField("ratp.QRcode").display = display.visible;}
//
if (datarr[event.changeEx][1] == "Sélectionnez une station") {
this.resetForm("ratp");
this.getField("ratpBoutonGmap").display = display.hidden;
this.getField("ratp.QRcode").display = display.hidden;
}
this.delay = false;
this.dirty = false;
}
}
Merlin
Maître des clésPour pouvoir te répondre il faudrait que tu partages le document, un exemple ou au moins le script utilisé.
L’exemple ci-dessus fonctionne avec Reader.
Merlin
Maître des clés“On peut faire ça ?”
Oui, regarde ce document de démo : https://www.abracadabrapdf.net/pdf-de-demo/formulaires/open-data-javascript-et-pdf/
Il y a 26560 entrées dans le fichier CSV incorporé.
Merlin
Maître des clésBonjour
Attention car ça ne fonctionne pas dans Reader, auquel cas l’astuce c’est de transformer le bouton en texte seul (label only) ce qui lui fait perdre son icône, et ensuite de le retransformer en bouton avec icône.
Merlin
Maître des clésL’astuce c’est de coller le texte d’abord dans un éditeur de texte ou dans un traitement de texte en mode “texte seul” (TextEdit, Bloc-Notes…) et ensuite de re copier-coller vers Acrobat, mais c’est un peu laborieux.
Merlin
Maître des clésBonjour.
Hélas non, la commande qui permet de coller du texte brut, sans formatage, (CTRL/CMD + Shift + V) fonctionne dans quasiment tous les logiciels mais pas dans Acrobat !
Merlin
Maître des clésJ’obtiens un NaN quand j’utilise ton code
C’est normal, ce script ne fonctionne que sur une page générée depuis une page modèle, il ne fonctionne pas sur la page modèle elle même ni sur une page normale (statique).
D’ailleurs pour que ça fonctionne vraiment bien il faut lui ajouter :
this.calculateNow();
pour s’assurer de la mise à jour immédiate du calcul du numéro de la page générée.
Je ne me souviens plus de la raison profonde pour laquelle les pages générées requièrent ce script particulier mais je me souviens que j’avais bien galéré pour le mettre au point. Je remercie une fois de plus notre grand gourou Thom Parker qui m’avait expliqué pourquoi et comment.
Merlin
Maître des clésPS : il faut le placer en script de calcul dans les champs concernés.
Merlin
Maître des clésBonjour
Il faut utiliser ce script, sachant qu’il renvoie une erreur quand on le place sur la page modèle et que c’est normal : il ne fonctionne que sur une page générée.
event.value = (event.target.page[1] + 1) + " / " + this.numPages ;
La partie en orange est facultative, ça sert à obtenir une numérotation du type : 2/10 (s’il y a 10 pages).
Merlin
Maître des clés🙂
Merlin
Maître des clésBonjour
Quelle que soit l’interface que tu utilises (nouvelle expérience ou ancien Acrobat) il faut que tu trouves l’outil “Modèles de pages”.
Dans l’exemple ci-joint le script est dans les cases à cocher (c’est le même partout).
Il faudra adapter les cases à cocher et le script si tu veux n’afficher qu’un seul jeu de page à la fois (même nom et valeur d’exportation différente).
Attachments:
You must be logged in to view attached files.Merlin
Maître des clésPar ailleurs on devrait pouvoir le simplifier ainsi (non testé) :
if (nomChamp.indexOf("Menu.")==0) {
this.getField("Menu.3").fillColor=color.green;
this.getField("Menu.4").fillColor=color.green;
if (this.getField(nomChamp).type=="text" || this.getField(nomChamp).type=="combobox") {this.getField(nomChamp).defaultValue=this.getField(nomChamp).value;}
else if ((this.getField(nomChamp).type=="checkbox" || this.getField(nomChamp).type=="radiobutton") && this.getField(nomChamp).name != "Menu.6") {this.getField(nomChamp).value="Off";}
}
Merlin
Maître des clésBonjour
Non testé :
if (nomChamp.indexOf("Menu.")==0) {
this.getField("Menu.3").fillColor=color.green;
this.getField("Menu.4").fillColor=color.green;
if (this.getField(nomChamp).type=="text") {this.getField(nomChamp).defaultValue=this.getField(nomChamp).value;}
else if ((this.getField(nomChamp).type=="checkbox" || this.getField(nomChamp).type=="radiobutton") && this.getField(nomChamp).name != "Menu.6") {this.getField(nomChamp).value="Off";}
else if (this.getField(nomChamp).type=="combobox") {sText = this.getField(nomChamp).value; this.getField(nomChamp).defaultValue = sText;}
}
7 novembre 2024 à 11:01 en réponse à : Identifier la couleur des champs en exportant les données #75132Merlin
Maître des clésOn pourrait aussi baliser automatiquement les données avec la couleur du champ, mais pour ça il faudrait utiliser un script d’exportation spécifique au lieu de la fonction fournie dans Acrobat.
7 novembre 2024 à 10:59 en réponse à : Identifier la couleur des champs en exportant les données #75131Merlin
Maître des clésBonjour
La réponse est non, sauf si on ajoute un champ/rubrique “couleur” en plus de chaque champ.
L’autre solution serait d’ajouter (automatiquement) la couleur dans le contenu des données de chaque champ de manière à avoir cette indication dans les données..
Mais tout dépend de la façon dont sont ensuite utilisées les données au format TXT.
Merlin
Maître des clésPour masquer tous les champs il faut décocher toutes les cases, c’est la principale différence entre cases à cocher et boutons-radio : l’utilisateur peut désélectionner toutes les cases, contrairement aux boutons-radio.
Merlin
Maître des clés*Parce que les traitements de texte ajoutent des caractères “parasites”, et parce-que les éditeurs de texte colorent automatiquement la syntaxe des scripts, ce qui rend leur lecture plus facile et évite des erreurs (image jointe).
Attachments:
You must be logged in to view attached files.Merlin
Maître des clésBonjour et bienvenue
Ça serait plus facile si tu avais posté un exemple en PDF contenant les coches et les champs en question.
Il y a une erreur (que font tous les débutants) à ne pas commettre : il ne faut jamais éditer des scripts avec un traitement de texte (comme Word), il faut toujours utiliser un Éditeur de texte, comme BBEdit (Mac) ou NotePad (Windows).
Il est contre-productif de répéter la condition (if/else) pour chaque champ, une seule condition peut traiter plusieurs instructions afficher/masquer (ou autre). C’est à ça que servent les accolades.
Il est inutile de mettre “this” devant “event.target”.
En fait, pour agir comme des boutons-radio, il faut que les 3 cases à cocher aient toutes exactement le même nom avec chacune une valeur d’exportation différente. Et pour que ça fonctionne correctement il faut mettre le même script dans les trois cases.
Pour faire simple disons que la case 1 a une valeur d’exportation “1”, la case 2 a la valeur d’exportation “2” et la case 3 a la valeur d’exportation “3”.
Ce qui donnerait par exemple ce script à placer dans les 3 cases, en action Souris relevée :
// D'ABORD ON MASQUE TOUS LES CHAMPS
this.getField("Teste_PSA1").display=display.hidden;
this.getField("vict_pro_1_4").display=display.hidden;
this.getField("aucune_vict_pr_1_4").display=display.hidden;
this.getField("Texte_PSA3").display=display.hidden;
this.getField("une_vict_pr_3").display=display.hidden;
this.getField("vic_profil3").display=display.hidden;
this.getField("enfant_victime").display=display.hidden;
this.getField("enfant_victime1").display=display.hidden;
this.getField("autre_vic_case").display=display.hidden;
this.getField("Texte222").display=display.hidden;
this.getField("Texte223").display=display.hidden;
this.getField("Liste222").display=display.hidden;
this.getField("Liste223").display=display.hidden;
this.getField("Texte121").display=display.hidden;
this.getField("Texte122").display=display.hidden;
this.getField("Texte_PSA4").display=display.hidden;
this.getField("Texte_CETM2").display=display.hidden;
this.getField("typeverdict").display=display.hidden;
this.getField("Tx_SAS").display=display.hidden;
// ENSUITE ON AFFICHE CEUX QUI DOIVENT L'ÊTRE
if (event.target.value == 1)
{
this.getField("Teste_PSA1").display=display.visible;
this.getField("vict_pro_1_4").display=display.visible;
this.getField("aucune_vict_pr_1_4").display=display.visible;
}
else if (event.target.value == 2)
{
this.getField("Texte_PSA3").display=display.visible;
this.getField("une_vict_pr_3").display=display.visible;
this.getField("vic_profil3").display=display.visible;
this.getField("enfant_victime").display=display.visible;
this.getField("enfant_victime1").display=display.visible;
this.getField("autre_vic_case").display=display.visible;
this.getField("Texte222").display=display.visible;
this.getField("Texte223").display=display.visible;
this.getField("Liste222").display=display.visible;
this.getField("Liste223").display=display.visible;
this.getField("Texte121").display=display.visible;
this.getField("Texte122").display=display.visible;
}
else if (event.target.value == 3)
{
this.getField("Texte_PSA4").display=display.visible;
this.getField("Texte_CETM2").display=display.visible;
this.getField("typeverdict").display=display.visible;
this.getField("Tx_SAS").display=display.visible;
}
Merlin
Maître des clésAlors pourquoi ça fonctionne en ne recherchant que 4 chiffres ???
Soit parce-que tu as eu la chance de ne pas l’avoir fait fonctionner sur des codes utilisant des lettres, soit parce-que ECMAScript n’est pas très rigoureux dans le respect des métacaractères GREP (comme j’ai déjà pu le constater).
À mon avis c’est la 2e supposition qui est la plus probable.
😉
Merlin
Maître des clésJ’ai également écris un petit utilitaire !
Excellent !
Merlin
Maître des clésJoker !
Merlin
Maître des clés🙂
Merlin
Maître des clésEffectivement j’utilise l’utilitaire cité ci-dessus.
C’est un ancien script que je t’ai donné, maintenant je ne perd plus de temps à ne convertir que les caractères accentués je converti toute la chaîne de caractères, et je laisse l’originale juste au-dessus sous forme de commentaire.
Ainsi l’originale disparaît lors de la minification/optimisation du script avec tous les autres commentaires, comme ça je suis le seul à comprendre ce que fait le script et je complique la tâche de ceux qui veulent piquer ou détourner mes scripts 😉
Exemple :
// var strTitre = "COUCOU";
// var strMessage = "Merci de renseigner les champs Date et Nom avant d'enregistrer ce document.";
var strTitre = "\u0043\u004F\u0055\u0043\u004F\u0055";
var strMessage = "\u004D\u0065\u0072\u0063\u0069\u0020\u0064\u0065\u0020\u0072\u0065\u006E\u0073\u0065\u0069\u0067\u006E\u0065\u0072\u0020\u006C\u0065\u0073\u0020\u0063\u0068\u0061\u006D\u0070\u0073\u0020\u0044\u0061\u0074\u0065\u0020\u0065\u0074\u0020\u004E\u006F\u006D\u0020\u0061\u0076\u0061\u006E\u0074\u0020\u0064\u0027\u0065\u006E\u0072\u0065\u0067\u0069\u0073\u0074\u0072\u0065\u0072\u0020\u0063\u0065\u0020\u0064\u006F\u0063\u0075\u006D\u0065\u006E\u0074\u002E";
// MESSAGE D'ALERTE
app.alert({cMsg:strMessage, nIcon: 1, cTitle: strTitre});}
Et je met toujours les commentaires en capitales pour mieux les détacher du code et les rendre plus visibles
Merlin
Maître des clésvar strAlertRaz = "Voulez vous vraiment supprimer le contenu de tous les champs de donn\u00E9es et revenir \u00E0 l'\u00E9tat initial du document ?\n\nCette action ne pourra pas \u00EAtre annul\u00E9e.\nSi besoin utilisez : menu Fichier : R\u00E9tablir";
var strTitr = "TITRE";
// si réponse = 3 = non
if (app.alert({cMsg: strAlertRaz, cTitle: strTitr, nIcon: 2, nType: 2}) == 3) {
app.alert("Opération annulée.");
}
else {this.resetForm();}
Merlin
Maître des clésConcernant la fonction “defaut”, je n’ai pas bien compris pourquoi mais pour les combobox l’égalité “defaultValue = value” ne fonctionne pas directement, il passer par une variable.
Par-contre ce qui est certain car c’est précisé dans la doc c’est qu’il faut cocher l’option “Autoriser l’utilisateur à saisir un texte personnalisé” pour chaque combobox concerné sinon ça ne peut pas fonctionner.
Fait attention à une chose : quand tu testes des conditions avec trois “if” qui se suivent tu obliges le script à tester tous les champs trois fois, alors qu’avec “else if” la deuxième condition n’est testée que si la première n’est pas remplie, et la troisième n’est testée que si la première et la deuxième ne sont pas remplies.
“else if” est donc un gain de temps qui permet d’accélérer l’exécution des scripts.
function Default() {
var sText;
for (var i=0; i<this.numFields; i++) {
var nomChamp=this.getNthFieldName(i);
//console.println(i+" - nomChamp : "+nomChamp+" - "+(this.getField(nomChamp).page+1)+" - "+this.getField(nomChamp).type);
if (nomChamp.indexOf("R.")==0) {
if (this.getField(nomChamp).type=="text") this.getField(nomChamp).defaultValue=this.getField(nomChamp).value;
else if ((this.getField(nomChamp).type=="checkbox" || this.getField(nomChamp).type=="radiobutton")) this.getField(nomChamp).defaultValue=this.getField(nomChamp).value;
else if (this.getField(nomChamp).type=="combobox") {sText = this.getField(nomChamp).value; this.getField(nomChamp).defaultValue = sText;}
}
if (nomChamp.indexOf("Q.")==0) {
if (this.getField(nomChamp).type=="text") {this.getField(nomChamp).value="";}
else if ((this.getField(nomChamp).type=="checkbox" || this.getField(nomChamp).type=="radiobutton")) this.getField(nomChamp).value="Off";
else if (this.getField(nomChamp).type=="combobox") {this.getField(nomChamp).value=this.getField(nomChamp).getItemAt(0,false);}
}
if (nomChamp.indexOf("Titre.")==0) {this.getField(nomChamp).defaultValue=this.getField(nomChamp).value;}
if (nomChamp.indexOf("TQ.")==0) {this.getField(nomChamp).defaultValue=this.getField(nomChamp).value;}
if (nomChamp.indexOf("Question.")==0) {this.getField(nomChamp).defaultValue=this.getField(nomChamp).value;}
if (nomChamp.indexOf("Aide." && this.getField(nomChamp).type=="text")==0) {this.getField(nomChamp).defaultValue=this.getField(nomChamp).value;}
if (nomChamp.indexOf("TL.")==0 && this.getField(nomChamp).type=="text") {this.getField(nomChamp).defaultValue="";}
if (nomChamp.indexOf("Menu.")==0) {
this.getField("Menu.3").fillColor=color.green;
this.getField("Menu.4").fillColor=color.green;
if (this.getField(nomChamp).type=="text") this.getField(nomChamp).defaultValue=this.getField(nomChamp).value;
else if ((this.getField(nomChamp).type=="checkbox" || this.getField(nomChamp).type=="radiobutton")) this.getField(nomChamp).value="Off";
else if (this.getField(nomChamp).type=="combobox") {sText = this.getField(nomChamp).value; this.getField(nomChamp).defaultValue = sText;}
}
}}
Merlin
Maître des clésJ’ai l’habitude de mettre toutes mes fonctions ensembles dans un seul fichier texte et ensuite de tout copier-coller dans un seul script de document.
Après avoir cherché l’erreur en vain pendant de longues minutes c’est quand j’ai fait ça avec tes deux fonctions, car je trouve ça plus pratique, que l’évidence m’a sauté aux yeux :
dans la fonction “aleatoir” l’indice “i” est déclaré avec “var”, donc il est enfermé dans cette fonction et ne peut pas communiquer avec une autre fonction. Ce qui condamne la fonction “hasard/random” à l’échec systématique.
Quand elle est appelée directement depuis le bouton ça fonctionne car dans ce cas l’indice “var i” n’est pas enfermé dans une fonction.
Donc dans la fonction “aleatoir” il faut juste supprimer “var” en deuxième ligne pour que ça fonctionne :
function aleatoir() {
for (i=1; i<=30; i++) {
// etc
Ci-joint.
Attachments:
You must be logged in to view attached files.Merlin
Maître des clésBonjour
Il existe une fonction nommée “random” dans tes scripts, et il est fort possible que “random” fasse partie des mots réservés. Il faudrait donc commencer par changer ce nom.
Merlin
Maître des clésNormalement il suffit de cocher “Mémoriser cette action…” et de cliquer “Autoriser” pour que le site cible soit ajouté à la liste blanche.
Sinon on peut cocher “Autoriser les PDF à accéder à tous les sites” dans les Préférences*, mais c’est un choix utilisateur qu’on ne peut pas forcer.
Voir captures.
*Ce n’est pas dans les Préférences “Internet”, ce serait trop facile !
😉
Attachments:
You must be logged in to view attached files.Merlin
Maître des clésBonjour
Place ce script en Action “Souris relâchée” dans le champ concerné :
if ( !/^\s*$/.test(event.target.value) ) {app.launchURL(event.target.value);}
Mais il faut remplir le champ avec une vraie URL, c’est à dire qui commence par “www” ou “http” ou https”.
Pour la couleur bleue il faut changer la couleur du texte, pour le soulignement je n’ai pas de solution car il faudrait utiliser le format RTF mais celui-ci se réinitialise à chaque changement du contenu du champ.
Ci-joint.
Attachments:
You must be logged in to view attached files.Merlin
Maître des clésBonjour
Dans ton document il y a 25 scripts de document, donc je n’ai pas cherché la ligne 75… 😉
Sinon, met ton script en fonction dans un script de document :
function aleatoir() {
for (var i=1; i<=30; i++) {
try {
random (i);
} catch(e) {
this.getField("Var."+i+".3").value="";
}
}
}
Et appelle cette fonction via la condition (if else).
Merlin
Maître des clésQuand je te dis que tu es un génie !
Sur Windows ça fonctionne parfaitement avec la touche Ctrl ou avec la touche AltGr (qui correspond à la touche Alt/Option du Mac). Ça fonctionne aussi très bien avec la touche Ctrl et la touche AltGr en même temps.
Et aussi avec la touche majuscule pour la sélection continue.
Merlin
Maître des clésbebarth est un génie !
Merlin
Maître des clésLes parenthèses : erreur à la console et arrêt du script
Le crochet [ : erreur à la console et arrêt du script
Le crochet ] : n’a pas l’air de poser problèmeParenthèses et crochets sont utilisés en JavaScript comme délimiteurs de string et d’array, c’est pour ça qu’il faut les échapper (escape) avec un antislash quand ils sont utilisés dans une chaîne de caractères (string).
Merlin
Maître des clésAu lieu de
droite P'(x)
essaie avec
droite P\'\(x\)
ou avec
droite P\\'\\(x\\)
Par fois deux antislash valent mieux qu’un seul.
Merlin
Maître des clésC’est bebarth qu’il faut remercier, j’ai juste adapté son script.
Merlin
Maître des clésBonjour et bienvenue
Je ne vois pas de popup ni d’action qui affiche de calque dans ton exemple…
Regarde dans les actions des deux champs, j’ai ajouté des scripts. Car ce document étant créé avec InDesign les champs sont attachés aux calques, on ne peut donc pas utiliser l’action “Définir la visibilité du calque”.
Attachments:
You must be logged in to view attached files.Merlin
Maître des clésBonjour
Essaie de remplacer le “?” par son équivalent en Unicode :
\u003F
Merlin
Maître des clésJe l’ai fait comme ça (ci-joint).
Le script est dans le champ “calcul”.
Attachments:
You must be logged in to view attached files.Merlin
Maître des clésBonjour
Il n’y a pas besoin de script, c’est une fonction native dans Acrobat (Reader) et dans la plupart des logiciels.
Capture jointe.
Attachments:
You must be logged in to view attached files.Merlin
Maître des clésEn vrai c’est du “Device Independent Path” dont je voulais parler.
Je viens d’en retrouver le lien : http://acrobatusers.com/tutorials/file-paths-acrobat-javascript
Merlin
Maître des clésBonjour
Ci-joint, le script est dans le champ “zone2”.
Je l’ai placé en action champ désactivé car comme la sélection multiple est autorisée ça ne fonctionne pas correctement en action “changement de sélection”.
this.getField("choix2").value = event.value;
var f = this.getField("zone2");
var a = f.currentValueIndices;
if (typeof a == "number") {// A single selection (type: number)
this.getField("pop2").setItems([f.value]);
}
else { // Multiple selections (type: array)
this.getField("pop2").setItems(f.value);
}
Attachments:
You must be logged in to view attached files.Merlin
Maître des clésVoir le “Safe Path” : https://opensource.adobe.com/dc-acrobat-sdk-docs/library/jsapiref/index.html#safe-path
Merlin
Maître des clésPS : ci-dessus c’est le principe que j’ai décrit, je n’ai pas vérifié mais il est possible que pour des “raisons de sécurité” Adobe ait limité l’échange de variables entre les documents.
Cependant ce qui vaut chez Adobe ne vaut pas pour tous les éditeurs de logiciels.
Merlin
Maître des clésBonjour
Attention, le point est aussi un caractère spécial non toléré dans un nom de variable. Donc pas de noms de champs contenant des points !
Autre question : si je déclare ces variables par var, celles ci ne sont déclarées que dans le script de document ou dans tout le document?
En utilisant “var” dans la déclaration d’une variable :
var toto = "Blablabla";
Si elle est déclarée dans une fonction elle n’est disponible que dans cette fonction.
Si elle est déclarée ailleurs que dans une fonction (script de document ou d’objet) elle est disponible dans tout le document actif, et seulement dans celui là.
En n’utilisant pas “var” dans la déclaration :
toto = "Blablabla";
Elle est disponible pour tous les scripts de tous les documents ouverts et ceux qu’on ouvrira par la suite tant qu’on n’aura pas quitté l’application.
Ce qui est parfois trompeur car on peut avoir un document avec des scripts qui fonctionnent très bien alors que le lendemain, après avoir quitté l’application, ou bien quand on le transmet à quelqu’un d’autre ça ne fonctionne plus. En cause : la variable avait été déclarée ailleurs dans un autre document.
Ce qui peut aussi causer des erreurs si plusieurs documents utilisent un même nom de variable : il en résulte que chaque document écrase la variable déclarée dans un autre.
Merlin
Maître des clésBonjour
A priori la réponse est oui mais il faudrait que tu donne plus détails sur la formule à calculer, voire que tu partages tout ou partie du formulaire si tu veux un exemple.
Merlin
Maître des clésC’est tout le charme des forums, chacun propose son idée et ensuite il faut faire la part des choses.
Ci-joint un exemple fonctionnel, il faut aussi faire attention à l’ordre de calcul.
Attachments:
You must be logged in to view attached files.Merlin
Maître des cléssauf que, à nouveau, l’affichage en lettre n’est pas automatique : il faut cliquer sur le champ “TexteNombre” pour voir apparaître la transcription. Ça fait un moment que je cherche mais je ne vois pas où est l’erreur. Est-ce parce que l’ordre de calcul n’a pas été modifié ?
J’ai déjà répondu à cette question il y a deux jours dans ma première réponse (voir ci-dessus) :
“Et dans le champ “SaisieSomme” le script devrait placé en script de Validation, pas en Action.”
Si tu ne lis pas les réponses et que tu ne regardes pas les copies d’écran qu’on se donne la peine de te fournir tu risques de tourner en rond pendant longtemps !
18 septembre 2024 à 08:42 en réponse à : Formulaire Devis – Afficher un tarif selon choix liste déroulante #74865Merlin
Maître des clésBonjour
Fais une recherche sur “liste”, mère fille” ou sur “listes dépendantes” dans ce forum. Tu auras beaucoup de réponses car ce sujet à déjà été abordé de nombreuses fois.
Merlin
Maître des clésC’est vrai, mais la validation Acrobat implique d’indiquer une fourchette de valeurs et je ne souhaite pas indiquer de valeur maximale.
Non.
Si tu avais regardé la capture d’écran que j’ai posté (ci-dessus) tu aurais vu qu’on peut très bien n’entrer qu’une seule valeur, minimum ou maximum.
Merlin
Maître des clésCeci dit JC à raison, le script de conversion en lettres serait mieux placé en script de document.
Et pour plus de cohérence je mettrais le symbole € dans le champ “SaisieSomme”, qui devrait être en lecture seule tout comme le champ “TexteSomme”.
Attachments:
You must be logged in to view attached files.Merlin
Maître des clésBonjour
C’est le script de validation du champ “nombre” qui n’est pas correct, c’est d’autant plus dommage qu’il n’y a pas besoin de script : il suffit d’utiliser la validation fournie par Acrobat (voir capture).
Et dans le champ “SaisieSomme” le script devrait placé en script de Validation, pas en Action.
Attachments:
You must be logged in to view attached files.Merlin
Maître des clésBonjour
Ci-joint, je ne sais pas s’il y a eu d’autres versions depuis.
Attachments:
You must be logged in to view attached files.Merlin
Maître des clésMoi en général c’est après avoir dormi que je comprend mes erreurs/bugs !
😉
Merlin
Maître des clésIl y a de nombreuses années j’ai publié cet utilitaire qui fonctionne sur ce principe, c’est le plus inutile et le moins utilisé que j’ai jamais fait !
Merlin
Maître des clésJe viens de regarder la documentation : une chose est sure c’est que dans tous les cas ça ne pourrait se faire que depuis la console ou depuis un script d’application.
Donc tu n’es pas plus avancé.
Si c’était possible la seule solution serait d’envoyer le script dans la console, d’afficher la console, de demander à l’utilisateur de tout sélectionner dans la console et d’appuyer sur la touche Entrée (Enter) en lui demandant de bien faire attention à ne pas confondre avec la touche Retour (Return). Sachant que sur les Mac portable il faut faire FN-Return pour obtenir Enter.
D’expérience je peux te dire qu’entre les inexpérimentés qui ne comprendront rien et les méfiants qui ne voudront pas le faire, ça ne fonctionnera que pour un tout petit petit nombre d’utilisateurs.
…
Merlin
Maître des clésBonjour
Remplace la première ligne par :
if (this.getField("meca") === null) {
Par ailleurs, logiquement ton script devrait s’exécuter même si le champ n’est pas déplacé, mais tu ne dois pas le voir car ils se superposent.
3 septembre 2024 à 22:15 en réponse à : Mr ou Mme qui s’inscrit avec bouton radio ou case à cocher #74807Merlin
Maître des clésLa différence c’est qu’après en avoir coché un, l’utilisateur ne peux pas décocher un groupe de boutons-radio. Contrairement aux cases à cocher.
Sinon c’est tout pareil.
3 septembre 2024 à 22:12 en réponse à : Mr ou Mme qui s’inscrit avec bouton radio ou case à cocher #74806Merlin
Maître des clésIls ne sont pas vraiment différents, c’est juste que bebarth a placé le script seulement dans les cases à cocher, tu as juste à le copier-coller dans les boutons-radio (où il y a encore mon script précédent).
Le nom tu peux l’écrire comme tu veux dans le champ texte, avec ou sans majuscules.
3 septembre 2024 à 11:05 en réponse à : Mr ou Mme qui s’inscrit avec bouton radio ou case à cocher #74800Merlin
Maître des clésBonjour
Il y a des scripts inutiles et incohérents dans ton document, deux script d’actions suffisent (voir ci-joint).
Tu devrais utiliser la console JavaScript qui donne des renseignements précieux, voir : https://www.abracadabrapdf.net/ressources-et-tutos/js-et-formulaires-ressources/console-javascript-d-acrobat/
Mr = Mister, c’est de l’anglais. En français l’abréviation de Monsieur c’est M. (voir : https://www.lalanguefrancaise.com/orthographe/m-ou-mr-abreviation-monsieur)
😉
Attachments:
You must be logged in to view attached files.Merlin
Maître des clésCette variable devrait être insérée dans la dernière ligne, où tu as répété l’instruction.
Je l’ai renommée ci-dessous :
var aTousLesModeles=this.templates;
for (j=0; j<aTousLesModeles.length; j++) {
aTousLesModeles[j].hidden=false; // true ou false
var leNom = aTousLesModeles[j].name;
var ind = leNom.substr(leNom.length-1);
var sNom = leNom.substr(0,leNom.length-1);
this.setPageLabels(this.numPages-1, ["D",sNom,ind-1]);
}
En tout cas tu me sauves la mise car je suis justement en train de travailler sur les documents pour lesquels j’ai besoin de ce script qui affiche le nom exact des templates (sans ajouter de numéro), qui ne fonctionnait plus à cause de fichu bug du “i” sur le forum.
😉
Merlin
Maître des clésJe l’ai modifié car le dernier caractère du nom du modèle n’étais pas conservé.
Quand j’utilise ton script ça ne fonctionne pas et la console renvoie ce message d’erreur :
TypeError: leNom is undefined
5:Batch:ExecMerlin
Maître des clésC’est surtout bebarth qu’il faut remercier, je me suis contenté d’essayer de faire un peu d’humour.
🙂
Merlin
Maître des clésBonjour
Je sais la prendre mais je ne sais pas la calculer !
😉
Merlin
Maître des clésPour info la version d’essai de Qoppa PDF Studio permet de renommer plusieurs champs de formulaire à la fois, des centaines si besoin.
Comme cette version d’essai ajoute des filigranes l’astuce c’est de faire ça dans une copie du document PDF et ensuite de ramener les champs renommés dans le document original par copier-coller en ouvrant les 2 PDF avec Acrobat, ou avec PDF Expert.
Je n’ai pas testé avec ce dernier mais il n’y a aucune raison que ça ne fonctionne pas.
Merlin
Maître des clésTu as bien fait, à l’origine c’était fait exprès car ça correspondait à un type de documents particuliers, et ensuite je l’ai conservé tel quel.
-
Cette réponse a été modifiée le il y a 8 mois et 1 semaine par
Merlin.
Merlin
Maître des clésBonjour
Bonne question à laquelle je ne peux pas répondre pour le moment car je suis dans les Alpes loin de chez moi et mon ordi.
…
Merlin
Maître des clésEn tout cas ça dépasse les miennes.
Moi en matière d’essence j’utilise surtout du SP98 😉
Merlin
Maître des clés- Je n’imaginais même pas que de tels logiciels existaient, impressionnant !
- Avec Acrobat c’est facile mais avec PDF XChange je ne sais pas non plus…
Ce qui devrait fonctionner avec n’importe quel logiciel c’est d’aplatir la page et de copier-coller les données dans un tableur.
Merlin
Maître des clésJe ne sais pas ce qu’est un logiciel de calepinage mais j’image qu’en entrée il prend un fichier de type tableur (CSV ou Excel).
Donc cette manip me paraitrait plus simple à effectuer dans un tableur, après avoir exporté les données.
Merlin
Maître des clésLe script qui démasque les modèles en conservant leurs noms, à placer dans une Action :
var aTousLesModeles = this.templates;
for (i = 0; i < aTousLesModeles.length; i++) {
aTousLesModeles.hidden = false; // true ou false
var leNom=aTousLesModeles.name;
var ind=leNom.substr(leNom.length-1);
var nm=leNom.substr(0,leNom.length-1);
this.setPageLabels(this.numPages-1, ["D",leNom.substr(0,leNom.length-1),ind-1]);
}
Merlin
Maître des clésBonjour
Il te faut emballer les calculs dans une condition qui vérifie si les champs à calculer ne sont pas vides. Exemple :
//calculs cotés caisson
if (this.getField(“A.3.”+i).value != “” &&this.getField(“A.2.”+i).value != “” && this.getField(“A.7.”+i).value != “”) {
this.getField(“Caiss.1.”+i).value =
this.getField(“A.3.”+i).value + “×”+
this.getField(“A.2.”+i).value + “×”+
this.getField(“A.7.”+i).value;
}Merlin
Maître des clésTu partiras avec une bonne base car beaucoup de JavaScripteurs sont largués dès qu’on aborde le GREP.
😉
if ((/\d{3}.+$/.test(strName))) {
// blablabla
}
Merlin
Maître des clés“Ce serait utile en effet. Est-ce qu’un script pourrait aussi créer un modèle en utilisant le nom du panneau page? J’imagine que oui.”
Je n’en ai pas mais bebarth est capable de tout… 😉
Je n’ai pas eu ce besoin car s’il y a peu de modèles ce n’est pas très utile, et s’il y en a beaucoup je préfère prendre le temps de le créer manuellement par séquence en vérifiant au fur et à mesure. Quand je dis “beaucoup” c’est parfois plus de 70 pour certains clients.
Par ailleurs Acrobat ne sait que numéroter les pages en 1, 2, 3, etc. sans permettre l’ajout d’un ou plusieurs zéro directeur (01, 02, 03 ou 001, 002, 003, etc) ce qui est pénalisant pour ce que j’en fait.
Merlin
Maître des clésPar ailleurs j’ai appris récemment par Thom Parker que le logiciel PDF XChange, utilisé notamment par Michel, implémente le “JavaScript Dialog object”, ce qui devrait être plus pratique que Acrobat pour créer ce genre de boite de dialogue.
Merlin
Maître des clésWaouh, beau boulot !
Si ça t’intéresse, bebarth m’avait écrit un script qui “démasque” les modèles masqués en conservant leurs noms de modèle dans le panneau des pages, au lieu d’avoir page 1, page 2, etc.
C’est très pratique quand il y en a beaucoup.
Avec son autorisation (dont je doute pas) je pourrais te l’envoyer, ou le poster céans.
Merlin
Maître des clésOn ajoute autour du script existant une condition qui vérifie que tous les Groupes de boutons-radio soit cochés.
Quand un bouton-radio ou une case à cocher n’est pas coché sa valeur est égale à “Off”.
if (this.getField("Groupe 1").value != "Off" && this.getField("Groupe 2").value != "Off" && this.getField("Groupe 3").value != "Off" && this.getField("Groupe 4").value != "Off" && this.getField("Groupe 5").value != "Off" && this.getField("Groupe 6").value != "Off" && this.getField("Groupe 7").value != "Off") {
// script
}
else {event.value="";}
Ci-joint.
Attachments:
You must be logged in to view attached files. -
Cette réponse a été modifiée le il y a 8 mois et 1 semaine par
-
AuteurRéponses