
RSS © www.atoutfox.org - Forum
Re: Rencontre 2026bonjour à tous,
si vous pouviez éviter la période 20 - 27 mai : je serai sur les trains à vapeur
du Pays de Galles !
A bientôt
Jean
--
Cet e-mail a été vérifié par le logiciel antivirus d'AVG.
www.avg.com
Wed, 01 Apr 2026 06:58:36 GMTRe: Rencontre 2026Bonjour Kikoun,
les discussions sont toujours en cours et recherche d'hôtel + intervenants
mais normalement oui ...fin mai
publication bientôt
Cordialement
Tue, 31 Mar 2026 06:58:36 GMTRencontre 2026Bonjour.
Je souhaiterais savoir s'il est prévu une rencontre en 2026.
Tue, 31 Mar 2026 06:58:36 GMTImprimer un formulaireMerci à Jcriv et Jean de Grenoble ....J'utilise aussi impression écran et modification de l'image.. mais je pensais qu'il pouvait exister une solution dans Foxprox
comme l'imression d'un rapport...
A plus
Zep
Wed, 18 Mar 2026 06:58:36 GMTRe: Imprimer un formulaireBonjour.
Pour une astuce, j'utilisais ça pour imprimer via word (code d'origine donné par Mike Gagnon) : faire une copie de l'écran contenant les graphiques/images, coller dans un doc, imprimer le doc.
Si ça peut t'aider...
=Form2Clipboard(ThisForm.HWnd)
FUNCTION Form2Clipboard
PARAMETERS hWnd
*!* Parts of this code was borrowed http://www.news2news.com/vfp/
*!* Mike Gagnon
WAIT WINDOW "Calculs en cours..." NOWAIT
*!* * Removed 29/09/2015
*!* LOCAL oWord as Word.application
#DEFINE CF_BITMAP 2
#DEFINE SRCCOPY 13369376
DO copyActiveWindow
PRIVATE lnLeft,lnTop,lnRight,lnBottom,lnWidth,lnHeight
IF IsVide(hwnd)
hwnd = GetFocus()
ENDIF
STORE 0 TO lnLeft, lnTop, lnRight, lnBottom, lnWidth, lnHeight
= getRect (@lnLeft, @lnTop, @lnRight, @lnBottom, @lnWidth,@lnHeight)
hdc = GetWindowDC(m.hwnd)
hVdc = CreateCompatibleDC(m.hdc)
hBitmap = CreateCompatibleBitmap(m.hdc, m.lnWidth, m.lnHeight)
= SelectObject (m.hVdc, m.hBitmap)
= BitBlt (hVdc, 0,0, m.lnWidth, m.lnHeight, m.hdc, 0,0, SRCCOPY)
= OpenClipboard (m.hwnd)
= EmptyClipboard()
= SetClipboardData (CF_BITMAP, hBitmap)
= CloseClipboard()
= DeleteObject (hBitmap)
= DeleteDC (hVdc)
= ReleaseDC (hwnd, hdc)
*!* oWord=CREATEOBJECT("word.application")
*!* oWord.Documents.Add()
*!* loSelection=oWord.Selection
*!* IF m.loSelection.PageSetup.Orientation = 0 Then
*!* m.loSelection.PageSetup.Orientation = 1
*!* ELSE
*!* m.loSelection.PageSetup.Orientation = 0
*!* ENDIF
*!* m.loselection.PasteAndFormat(2)
*!* oWord.Visible =.t.
*!* WAIT CLEAR
Inform("L'image écran est dans le presse-papier")
RETURN
PROCEDURE copyActiveWindow
DECLARE INTEGER GetWindowRect IN user32 INTEGER hwnd, STRING @ lpRect
DECLARE INTEGER SelectObject IN gdi32 INTEGER hdc,INTEGER hObject
DECLARE INTEGER ReleaseDC IN user32 INTEGER hwnd,INTEGER hdc
DECLARE INTEGER CreateCompatibleDC IN gdi32 INTEGER hdc
DECLARE INTEGER DeleteObject IN gdi32 INTEGER hObject
DECLARE INTEGER DeleteDC IN gdi32 INTEGER hdc
DECLARE INTEGER CloseClipboard IN user32
DECLARE INTEGER GetFocus IN user32
DECLARE INTEGER EmptyClipboard IN user32
DECLARE INTEGER GetWindowDC IN user32 INTEGER hwnd
DECLARE INTEGER OpenClipboard IN user32 INTEGER hwnd
DECLARE INTEGER SetClipboardData IN user32 INTEGER wFormat, INTEGER hMem
DECLARE INTEGER CreateCompatibleBitmap IN gdi32;
INTEGER hdc, INTEGER nWidth, INTEGER nHeight
DECLARE INTEGER BitBlt IN gdi32;
INTEGER hDestDC, INTEGER x, INTEGER y,;
INTEGER nWidth, INTEGER nHeight, INTEGER hSrcDC,;
INTEGER xSrc, INTEGER ySrc, INTEGER dwRop
RETURN
PROCEDURE getRect(lnLeft, lnTop, lnRight, lnBottom,lnWidth, lnHeight)
LOCAL lpRect
lpRect = Repli(Chr(0), 16)
= GetWindowRect (hwnd, @lpRect)
lnLeft = buf2dword(SUBSTR(lpRect, 1,4))
lnTop = buf2dword(SUBSTR(lpRect, 5,4))
lnRight = buf2dword(SUBSTR(lpRect, 9,4))
lnBottom = buf2dword(SUBSTR(lpRect, 13,4))
lnWidth = lnRight - lnLeft
lnHeight = lnBottom - lnTop
RETURN
FUNCTION buf2dword (lcBuffer)
RETURN Asc(SUBSTR(lcBuffer, 1,1)) + ;
Asc(SUBSTR(lcBuffer, 2,1)) * 256 +;
Asc(SUBSTR(lcBuffer, 3,1)) * 65536 +;
Asc(SUBSTR(lcBuffer, 4,1)) * 16777216
Wed, 18 Mar 2026 06:58:36 GMTRe: Imprimer un formulaireBonjour ZEP,
dans le temps, j'ai beaucoup utilisé Foxypreviewer de Cesar CHALOM qui non
seulement permet d'imprimer mais aussi de créer des PDFs, d'envoyer le document
par mail, etc ...
www.foxypreviewer.com
Bonne journée
Jean à Grenoble
--
Cet e-mail a été vérifié par le logiciel antivirus d'AVG.
www.avg.com
Tue, 17 Mar 2026 06:58:36 GMTImprimer un formulaireBonjour,
j'ai développé dernièrement la création de graphiques à partir de données... je voudrais les imprimer .. Avez vous une astuce ?
Merci..
Tue, 17 Mar 2026 06:58:36 GMTRe: Documentation VFP en francaisBonjour et Merci pour tous
Wed, 04 Mar 2026 06:58:36 GMTRe: Documentation VFP en francaiset il y a ce groupe très efficace !
Bonne journée à tous
Jean à Grenoble
--
Cet e-mail a été vérifié par le logiciel antivirus d'AVG.
www.avg.com
Wed, 04 Mar 2026 06:58:36 GMTRe: Documentation VFP en francaisBonjour
Non pas de documentation VFP9 en Français
la dernière version du fichier d'aide et livre en Français = VFP6
Ceci dit avec google traduction ce n'est pas un problème pour un développeur
Cordialement
Francis
Tue, 03 Mar 2026 06:58:36 GMTDocumentation VFP en francaisBonjour,
De mémoire, il m'a semblé vue une traduction de la documentation de VFP9.
Merci pour la réponse et bonne journée.
Tue, 03 Mar 2026 06:58:36 GMTRe: Impression en Noir et BlancEnvironement de l'imprimante coché => donc les dans les option du cadrage l'imprimante devait être en noir et blanc. Si pas de bac spécial pour imprimer décocher cette option tout en retournant voir les options d'impression dans le cadrage, quitte a faire un "load data environement" dans le menu report.
Wed, 18 Feb 2026 06:58:36 GMTRe: Factures électroniquesBonsoir Francis,
Ooops "syntax error" ;-) ..... Odoo l'ERP open source
Après tout n'est pas gratuit la compta est payante notre choix à été Odoo On Premise
C'est payant mais tout le code source est chez nous
C'est un serveur Python qui fonctionne en reverse proxy sur notre IIS qui hoste notre site Ecommerce en VFP 9
Pour ce qui est de la facturation électronique le premier module ( hosté chez Odoo ) est gratuit,
Et il faudrait vérifier si elle fait bien partie de la version Odoo Community qui est gratuite
Cordialement
Marcel
Mon, 19 Jan 2026 06:58:36 GMTRe: Factures électroniquesMerci pour ta réponse Gilles
Même si je parlais des DPD / FA
pour xfrx : tu peux faire un exemple "basique" et envoyer au support eqeus les matin sont réactifs
ton sujet m'intéresse bien si tu veux nous tenir informé. Merci
Cordialement
Francis
Le mer. 14 janvier 2026, 07h57 GLS a écrit :
> Bonjour Francis,
> je suis dessus en ce moment au moins pour les factures PDF facturX.
> J'arrive à réaliser des factures au format factur-X - EXTENDED (format le plus complexe et qui devrait être retenu par le fisc Français d'après le groupement FacturX).
> Le seul soucis c'est que le PDF/A3a généré par la version 1.7 d'XFRX possède des erreurs de structures de PDF qui sont relevées par les outils de vérification de la conformité Factur-X..
> Cdlt
> Gilles
>
>
>
> .
>
Mon, 19 Jan 2026 06:58:36 GMTRe: Factures électroniquesBonsoir Marcel
pour "ODDO" : parles-tu de la banque ou de l'ERP open source ?
Cordialement
Francis
Le sam. 17 janvier 2026, 19h00 Marcel a écrit :
> Bonjour,
>
> Comme on est passé sur Oddo suite à cette obligation de facture éléctronique.
> Je compte automatiser l'intégration de l'existant en VFP et j'ai bossée sur VFP <-> Python
> Le résultat public sur Github est ici :
> https://github.com/marceldesmet/py-fox
>
> J'arrive à passer des Object VFP via Json à des fonctions Python et il existe des tonnes de librairies en open source.
> Pour les factures électroniques il y a
> Peppol BIS (Business Interoperability Specifications) -> pip install peppol-bis
> Python-ubl ( Universal Business Language) format -> pip install python-ubl
>
> Cordialement
> Marcel
>
>
> .
>
Mon, 19 Jan 2026 06:58:36 GMTRe: Exécuter un script python depuis VFPBonjour,
C'est probalement un peu tard mais bon ....
J'intègre pour le moment notre site ( VFP + WestWind ) avec l'ERP d'Odoo
https://github.com/marceldesmet/py-fox
Cela fonctionne assez bien y compris pour les erreurs du code python qui reviennent dans VFP
[VPF]
? '--- Test: Update single product image by internal reference'
LOCAL loSingleRes
TRY
loSingleRes = loPy.UpdateProductImageByRef(lcInternalRef, lcImagePath, 'odoo_client.test_connection')
CATCH TO oerr
? 'VFP wrapper call error:', oerr.MESSAGE
loSingleRes = .NULL.
ENDTRY
IF VARTYPE(loSingleRes) == 'O'
* loSingleRes is a Collection (ok, product_id, template_id, error)
? 'ok:', loSingleRes.item[1,2]
? 'product_id:', loSingleRes.item[2,2]
? 'template_id:', loSingleRes.item[3,2]
* Error field only exists when there's an error
IF loSingleRes.Count >= 4
? 'error:', loSingleRes.item[4,2]
ELSE
? 'error: (none)'
ENDIF
ELSE
? 'UpdateProductImageByRef returned non-collection result:', loSingleRes
ENDIF
[/VFP]
Cordialement
Marcel
Mon, 19 Jan 2026 06:58:36 GMTRe: Factures électroniquesBonjour,
Comme on est passé sur Oddo suite à cette obligation de facture éléctronique.
Je compte automatiser l'intégration de l'existant en VFP et j'ai bossée sur VFP <-> Python
Le résultat public sur Github est ici :
https://github.com/marceldesmet/py-fox
J'arrive à passer des Object VFP via Json à des fonctions Python et il existe des tonnes de librairies en open source.
Pour les factures électroniques il y a
Peppol BIS (Business Interoperability Specifications) -> pip install peppol-bis
Python-ubl ( Universal Business Language) format -> pip install python-ubl
Cordialement
Marcel
Sat, 17 Jan 2026 06:58:36 GMTRe: Impression en Noir et BlancJ'ai trouvé la solution. J'ai tout simplement mis un champ d'une table sur mon état.
Thu, 15 Jan 2026 06:58:36 GMTImpression en Noir et BlancBonjour.
Je rencontre un soucis. J'ai un état en couleur à imprimer (une image en grand format). Lorsque je fais l'aperçu avant impression il s'affiche en couleur. Mais lorsque je lance l'impression il sort en blanc et noir. Dans mes autres programmes, les impressions où se trouvent un logo par exemple, les impressions sortent en couleurs.
Si quelqu'un a une solution.
Thu, 15 Jan 2026 06:58:36 GMTRe: Factures électroniquesBonjour Francis,
je suis dessus en ce moment au moins pour les factures PDF facturX.
J'arrive à réaliser des factures au format factur-X - EXTENDED (format le plus complexe et qui devrait être retenu par le fisc Français d'après le groupement FacturX).
Le seul soucis c'est que le PDF/A3a généré par la version 1.7 d'XFRX possède des erreurs de structures de PDF qui sont relevées par les outils de vérification de la conformité Factur-X..
Cdlt
Gilles
Wed, 14 Jan 2026 06:58:36 GMTFactures électroniquesBonjour
Est-ce que quelqu'un a déjà pu commencer des travaux sur la facturation électronique et e-reporting
(obligatoire 1/9/2026)
Merci de faire part ce vos expériences
Cordialement
Francis
Tue, 13 Jan 2026 06:58:36 GMTRe: renomer un repertoire ?Comme D et D, e dirais même plus : run rename 2025 2026. Comme ça il n'y aura pas de mauvaises surprises.
Thu, 01 Jan 2026 06:58:36 GMTRe: renomer un repertoire ?run rename source destination
Il y a une autre méthode plus compliquée si cela t'interesse ...
Bonne journée
Jean
--
Cet e-mail a été vérifié par le logiciel antivirus d'AVG.
www.avg.com
Tue, 30 Dec 2025 06:58:36 GMTrenomer un repertoire ?renomer un repertoire
Mon, 29 Dec 2025 06:58:36 GMTRe: Run curl.exe APIBonjour, c'est bon j'ai trouvé . Fautes d'étourderies .... Merci et belle journée, SAndra LAINE
Tue, 09 Dec 2025 06:58:36 GMTRun curl.exe APIBonjour, J'ai encore besoin d'aide. J'ai besoin d'envoyer un fichier pdf qui est en local sur une API. Je ne peux pas le faire en JSON par contre c'est possible en curl . Quand je lance mon code dans la fenetre de commande cmd, cela marche mais je n'arrive pas depuis vfp9
Voici mon code curl :que j'ai mis dans un fichier texte F:\test\test2\curltxt.txt :
curl -X POST "https://apisandbox.hubintent.com/api/documents/v1/documents" \ -H "Authorization: Bearer 11111111111111111" \ -H "accept: application/json" \ -H 'Content-Type: multipart/form-data' \ -F "file=@F:/test/test2/journee_i.pdf;type=application/pdf" \ -F "title=quitus_chauffa" \ -F "elementType=intervention" \ -F "elementReference=730042" \ -F "description=Quitus" \ -F "intent_contractReference=TOTO" \ -F "intent_documentType=quitus_preventive" \ -F "intent_documentFamily=rapports_intervention" \ -F "intent_creationDate =20251001"
J'ai essayé plusieurs façon :
[vfp]
lc = filetostr("F:\test\test2\curltxt.txt")
RUN &lc
[/vfp]
Pour moi ça ne devrait marcher. Qu'est ce que je fais de mal ?
Merci pour votre aide . Sandra LAINE
Mon, 08 Dec 2025 06:58:36 GMTRe: API envoi de PDF MSXML2.ServerXMLHTTPBonjour, ok Merci. J'ai vu qu'il y avait une autre méthode avec curl. Je vais essayer dans ce sens. Merci pour ton aide.
Cordialement Sandra
Mon, 01 Dec 2025 06:58:36 GMTRe: API envoi de PDF MSXML2.ServerXMLHTTPBonjour Sandra,
Ce message est-il en retour de votre requête à l'API ?
Si oui c'est que le fichier doit être envoyé autrement que contenu dans le JSON.
A vérifier dans la documentation d'utilisation de l'API.
Cdlt
Gls
Sat, 29 Nov 2025 06:58:36 GMTRe: API envoi de PDF MSXML2.ServerXMLHTTPAlors j'ai réussi à résoudre mon problème de taille de variable . Voilà mon Json :
J'ai un message "no file attached to the request" comme au debut
{
"file": "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ZyAxOCAwIFIvU3VidHlwZS9UeXBlMT4+CmVuZG9iagoxOCAwIG9iago8PC9UeXBlL0VuY29kaW5nL0Jhc2VFbmNvZGluZy9XaW5BbnNpRW5jb2RpbmcvRGlmZmVyZW5jZXNbCjEvZzQxL2c0MC9nNTYvZzQ0L2c0Ny9nMy9nMzkvZzQ1L2c1MC9nNTMvZzQ5L2c3MS9nODgvZzIxL2cyNi9nMTgvZzIwL2cxOS9nMjQvZzU1L2c3Mi9nNzAvZzc1L2c4MS9nNzYvZzEzMS9nNzkvZzM3L2c0Ml0+PgplbmRvYmoKMTIgMCBvYmoKPDwvQmFzZUZvbnQvVGltZXMtUm9tYW4vVHlwZS9Gb250Ci9FbmNvZGluZyAxOSAwIFIvU3VidHlwZS9UeXBlMT4+CmVuZG9iagoxOSAwIG9iago8PC9UeXBlL0VuY29kaW5nL0RpZmZlcmVuY2VzWwoxNzYvZGVncmVlCjIzMi9lZ3JhdmUvZWFjdXRlXT4+CmVuZG9iagoxMCAwIG9iago8PC9UeXBlL0ZvbnREZXNjcmlwdG9yL0ZvbnROYW1lL0pEQUhGTCtUVDIwMjJvMDAvRm9udEJCb3hbMCAtMTIzIDE1NTcgMTY4MF0vRmxhZ3MgNAovQXNjZW50IDE2ODAKL0NhcEhlaWdodCAxNjgwCi9EZXNjZW50IC0xMjMKL0l0YWxpY0FuZ2xlIDAKL1N0ZW1WIDIzMwovQ2hhclNldCgvZzM3L2cyMC9nMy9nNDIvZzE5L2czOS9nMjQvZzQ1L2c1NS9nNTAvZzcyL2c1My9nNzAvZzQ5L2c3NS9nNzEvZzQxL2c4MS9nODgvZzQwL2c3Ni9nMjEvZzU2L2cxMzEvZzI2L2c0NC9nNzkvZzE4L2c0NykvRm9udEZpbGUzIDE2IDAgUj4+CmVuZG9iagoyIDAgb2JqCjw8L1Byb2R1Y2VyKEFGUEwgR2hvc3RzY3JpcHQgOC4xMSkKL0NyZWF0aW9uRGF0ZShEOjIwMjUxMTI3MjIyNzU1KQovTW9kRGF0ZShEOjIwMjUxMTI3MjIyNzU1KQovVGl0bGUoZjpcXGRldmVsb3BwZW1lbnRcXHRhYmxldHBjXFxkZXZ0YWJsZXRfdGFjdGlsZVxcam91cm5lZS5mcngpCi9DcmVhdG9yKFBTY3JpcHQ1LmRsbCBWZXJzaW9uIDUuMi4yKQovQXV0aG9yKG1pbmlwKT4+ZW5kb2JqCnhyZWYKMCAyMAowMDAwMDAwMDAwIDY1NTM1IGYgCjAwMDAwMDIwNDUgMDAwMDAgbiAKMDAwMDAwODgwNCAwMDAwMCBuIAowMDAwMDAxOTc2IDAwMDAwIG4gCjAwMDAwMDE4MTUgMDAwMDAgbiAKMDAwMDAwMDAxNSAwMDAwMCBuIAowMDAwMDAxNzk1IDAwMDAwIG4gCjAwMDAwMDI0MDUgMDAwMDAgbiAKMDAwMDAwMjI1NyAwMDAwMCBuIAowMDAwMDAyMDkzIDAwMDAwIG4gCjAwMDAwMDg0ODkgMDAwMDAgbiAKMDAwMDAwNzg3MCAwMDAwMCBuIAowMDAwMDA4MzI4IDAwMDAwIG4gCjAwMDAwMDc4MDcgMDAwMDAgbiAKMDAwMDAwMjE3MyAwMDAwMCBuIAowMDAwMDAyMjAzIDAwMDAwIG4gCjAwMDAwMDI1NTIgMDAwMDAgbiAKMDAwMDAwNzc4NiAwMDAwMCBuIAowMDAwMDA4MTMyIDAwMDAwIG4gCjAwMDAwMDg0MTEgMDAwMDAgbiAKdHJhaWxlcgo8PCAvU2l6ZSAyMCAvUm9vdCAxIDAgUiAvSW5mbyAyIDAgUgo+PgpzdGFydHhyZWYKOTAzNAolJUVPRgo=",
"title": "quitus intervention chauffage",
"elementType":"intervention",
"intent_contractReference":"TEST",
"intent_documentFamily":"rapports_intervention",
"elementReference":"730042",
"grant_type":"client_credentials"
}
Cordialement,
sandra
Fri, 28 Nov 2025 06:58:36 GMTRe: API envoi de PDF MSXML2.ServerXMLHTTPMerci pour votre réponse mais mon fichier fait 10ko .
Avez-vous une piset ?
Cordialement,
Sandra
Fri, 28 Nov 2025 06:58:36 GMTRe: API envoi de PDF MSXML2.ServerXMLHTTPBonjour,
Je pense me souvenir que la taille maximum d'une chaîne de caractère sous VFP est de 16 M octets.
Si le fichier PDF flirte ou dépasse ces 16MO alors il reste à fournir le lien du fichier dans le JSON en mettant à disposition le fichier sur un serveur WEB à travers ce lien pour que l'utilisateur le télécharge dans son navigateur internet ou le récupère par internet.
Cdlt
Gilles
Fri, 28 Nov 2025 06:58:36 GMTRe: API envoi de PDF MSXML2.ServerXMLHTTPBonjour, merci beaucoup pour votre aide. . J'ai fait STRCONV( filetostr("d:\hes\hes\journee_i.pdf") , 13), mais le problème c'est que ma variable est trop longue et quand je fais mon send, j'ai un message line is too long
lcfile = STRCONV( filetostr("f:\test\compta.pdf") , 13)
lcmessage = '{ ' + CHR(13) + CHR(10) + ;
'"title":"Test",' + CHR(13) + CHR(10) + ;
'"file":"'+ &lcfile +'", ' + CHR(13) + CHR(10) + ;
'"elementType":"intervention", ' + CHR(13) + CHR(10) + ;
'"elementReference":"730042", ' + CHR(13) + CHR(10) + ;
'"grant_type":"client_credentials", ' + CHR(13) + CHR(10) + ;
'}'
Cordialement,
sandra
Fri, 28 Nov 2025 06:58:36 GMTRe: API envoi de PDF MSXML2.ServerXMLHTTPBonjour
Soit "file" contient une URL pointant sur le fichier PDF et le destinataire va le retrouver et le charger dans son navigateur
Soit "file" doit contenir une variable contenant le fichier (FILETOSTR) convertie en BASE64
Exemple:
{"reparation":[{
"reference_externe1":"REF5",
"divers":"premier test",
"articlereparation":[{
"article":"BLOUSON PACK",
"photo1":"iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAABGdBTUEAALGPC/xhBQAAACBjSFJNAAB6JgAAgIQAAPoAAACA6AAAdTAAAOpgAAA6mAAAF3CculE8AAAACXBIWXMAAA3WAAAN1gGQb3mcAAAAB3RJTUUH4gwDDAomYeXG1QAAABh0RVh0U29mdHdhcmUAcGFpbnQubmV0IDQuMS40E0BoxAAAANJJREFUWEftlzEOwjAMRS0RS70EF+GQ7ASE2JA4V4duvQAS+AcHmdIxwQz+kpcm9fuxM8RklQ5pl3K6cuZR4s5HfjQJ5JKcyA2G4oxutOET71d/7hHCAlPpRKvwzLPE1Cjmr/wwAaEkdkHKdBnOw7YsNhRyIvcHC+0oPTdw3d9N1gTYJOUZ64ceJ18KjMoDGwZet136pHu6630nhE3GzaTr3QVW5YaBMBAGwkAYCANhIAz8gQH3J5n3o9T9We4+mECuo1mR93BahZKgL+L4R+M50RPOLxhzmDqZyQAAAABJRU5ErkJggg==",
}]
}]}
Cdlt
GLS
Thu, 27 Nov 2025 06:58:36 GMTRe: API envoi de PDF MSXML2.ServerXMLHTTPBonjour,
Le fichier PDF doit d'abord être intégrée dans une variable Foxpro convertie en base64 et intégrée dans le json.
Exemple: Le PDF est dans l'attribut Photo1
{"reparation":[{
"destinataire_livraison":"LUI",
"adresse1_livraison":"Rue du test",
"cp_livraison":"56000",
"ville_livraison":"MA VILLE",
"articlereparation":[{
"article":"MON BLOUSON",
"defaut1":"Déperlance",
"situation_defaut1":"Sur la face avant de l'article",
"photo1":"iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAABGdBTUEAALGPC/xhBQAAACBjSFJNAAB6JgAAgIQAAPoAAACA6AAAdTAAAOpgAAA6mAAAF3CculE8AAAACXBIWXMAAA3WAAAN1gGQb3mcAAAAB3RJTUUH4gwDDAomYeXG1QAAABh0RVh0U29mdHdhcmUAcGFpbnQubmV0IDQuMS40E0BoxAAAANJJREFUWEftlzEOwjAMRS0RS70EF+GQ7ASE2JA4V4duvQAS+AcHmdIxwQz+kpcm9fuxM8RklQ5pl3K6cuZR4s5HfjQJ5JKcyA2G4oxutOET71d/7hHCAlPpRKvwzLPE1Cjmr/wwAaEkdkHKdBnOw7YsNhRyIvcHC+0oPTdw3d9N1gTYJOUZ64ceJ18KjMoDGwZet136pHu6630nhE3GzaTr3QVW5YaBMBAGwkAYCANhIAz8gQH3J5n3o9T9We4+mECuo1mR93BahZKgL+L4R+M50RPOLxhzmDqZyQAAAABJRU5ErkJggg==",
}]
}]}
Cordilament
GLS
Thu, 27 Nov 2025 06:58:36 GMTAPI envoi de PDF MSXML2.ServerXMLHTTPBonjour, Je suis embêtée, j'ai un programme VFP 9 qui envoie nos interventions de dépannage par le biais d'une API qui marche très bien. on me demande maintenant en plus d'envoyer les comptes-rendus en pdf et J'y arrives par jotform mais pas dans mon code JSON. Je dois mal faire quelque chose. J'ai un message d'erreur {"message":"No file attached to the request","code":"BODY-INVALID"} . je Pense que c'est cette ligne là qui ne va pas mais je ne sais pas comment faire : "file":"D:/zz/journee_i.pdf",
Voilà mon code.
[vfp]
LOCAL oHTTP as MSXML2.ServerXMLHTTP
oHTTP=Createobject("MSXML2.ServerXMLHTTP")
oHTTP.Open("POST", m.cURL, .F.)
oHTTP.setRequestHeader('Accept', 'application/json')
oHTTP.setRequestHeader('Content-Type', 'application/json')
oHTTP.setRequestHeader('Authorization', 'Bearer '+lcToken)
lcmessage = FILETOSTR('D:\donnees\730042.txt')
oHTTP.Send(lcMessage )
[/vfp]
voilà a quoi ressemble mon fichier 730042.txt
{
"title":"Test",
"file":"D:/zz/journee_i.pdf",
"elementType":"intervention",
"elementReference":"730042",
"grant_type":"client_credentials",
"intent_documentType":"quitus_maintenance_preventive",
"description":"Quitus",
"intent_documentFamily":"rapports_intervention",
"intent_contractReference":"CONTRAT_TEST",
"intent_documentFamily":"rapports_intervention"
}
Merci par avance pour votre aide.
Sandra
Thu, 27 Nov 2025 06:58:36 GMTRe: Attaquer une base SQL Server avec VFPBonjour,
Toutes les versions et éditions de SQL server sont disponibles sur le Web.
Si les clients pour qui tu penses développer en SQL ont déjà un serveur SQL, il te faudra vérifier quelle édition ils utilisent : Standard, Entreprise, Web, ou Express.
Si tu as des clients qui utilisent du Standard ou de l'Entreprise, alors tu peux de ton côté développer sur une édition "Developer" qui a les mêmes capacités et perfs que Entreprise, mais elle est gratuite, MAIS elle est interdite en production, réservée au développement.
Si tes clients ont de l'Express, alors tu peux installer un Express sur ta machine de dev, pas la peine de t'encombrer avec des fonctionnalités que tu n'utiliseras jamais (SQL Broker, SQL Agent, etc...)
Pour ce qui est de la version, autant commencer par la 2022 (la 2025 est encore en preview)
Tue, 21 Oct 2025 06:58:36 GMTRe: Attaquer une base SQL Server avec VFPBonsoir Jean,
>>contributions 07-SQL SQL par l'exemple (id = 105)<<
Je crois l'avoir survolé, je vais m'y mettre désormais.
>>un excellent livre écrit par Tamar GRANOR<<
Est-ce que ce livre est encore disponible ? Ou est-ce que l'on peut l'avoir ?
Bonne soirée.
Mon, 20 Oct 2025 06:58:36 GMTRe: Attaquer une base SQL Server avec VFPBonjour Jean,
C'est vrai je ne le maitrise pas, mais j'ai l'habitude d'utiliser d'autres comme Informix 4GL, et un peu ORACLE. Cela fait très longtemps, mais je pense qu'il doit y avoir quelques similitudes. De toutes façons, je crois que je peux faire appel à votre expertise si besoin est. J'ai bien l'habitude d'utiliser de temps en temps RLOCK() et FLOCK(). Merci d'avance pour cela.
Cordialement.
Mon, 20 Oct 2025 06:58:36 GMTRe: Attaquer une base SQL Server avec VFPBonjour Michel,
Merci de m'édifier, je faisais allusion effectivement à un serveur SQL Server. Honnêtement je n'avais pas connaissance de SQL Express, sinon j'ai bien compris la contribution de GLS. Je suppose que SQL Express est disponible sur le Web. Je vous reviendrai certainement.
Merci de nouveau.
Cordialement.
Mon, 20 Oct 2025 06:58:36 GMTRe: Attaquer une base SQL Server avec VFPpour le SQL, il ya une excellente contribution dans atoutfox :
contributions 07-SQL SQL par l'exemple (id = 105)
et un excellent livre écrit par Tamar GRANOR et traduit en français par Atoufox.
Bonne journée
Jean
--
Cet e-mail a été vérifié par le logiciel antivirus d'AVG.
www.avg.com
Mon, 20 Oct 2025 06:58:36 GMTRe: Attaquer une base SQL Server avec VFPBonjour Damonzon,
tu nous a pas dit si tu maitrises SQL ! Si oui, cela va beaucoup simplifier ton
travail puisque c'est le seul moyen de travailler avec SQL Server.
Sinon on va pouvoir te donner des exemples et comme le dit Michel ce n'est pas
insurmontable.
Le seul 'problème' que je vois est la philosophie de "l'exclusion mutuelle". Si
tu utilises encore RLOCK() et Flock(), il va y avoir du changement.
Bon après-midi
Jean
--
Cet e-mail a été vérifié par le logiciel antivirus d'AVG.
www.avg.com
Sun, 19 Oct 2025 06:58:36 GMTRe: Attaquer une base SQL Server avec VFPBonjour,
De quelle licence parles-tu? Quand tu utilises SQL Server, il te faut toujours voir les choses des deux côtés : coté client (ton appli VFP) et côté serveur (là où se trouvent tes données sur un serveur SQL Server).
* côté client, Gilles t'a donné les pistes de départ, tu vois qu'il n'est pas besoin de licence en plus, c'est dans VFP
* côté serveur, il te faut évidemment un serveur SQL Server. Selon le volume des données que tu va y stocker, tu va choisir une version différente. Il est plus que probable que tu aies besoin uniquement de la version gratuite de SQL Server, qui s'appelle SQL Express. Cette version fonctionne parfaitement sur un Windows pro partagée avec des applications clientes (il y a aussi une version Linux), et tu peux donc installer un SQL Express sur ta machine de développement.
Tu devras aussi, sur ta machine de dev, installer SSMS : Sql Server Management Studio. C'est ce qui qui va te permettre de créer, modifier et maintenir tes bases de données sur ton serveur SQL Server. C'est gratuit.
Tu verras, rien d'insurmontable!
Sun, 19 Oct 2025 06:58:36 GMTRe: Attaquer une base SQL Server avec VFPBonjour GLS,
Il faudrait déjà que je me procure une licence SQL Server. J'imagine qu'il y'aura du grain à moudre.
Merci beaucoup et à bientôt.
Cordialement.
Sun, 19 Oct 2025 06:58:36 GMTRe: Aperçu avant impression tronquéBonjour GLS,
Encore merci. Je vous reviendrai dès j'aurais fait cette opération.
Bonne journée de dimanche.
Sun, 19 Oct 2025 06:58:36 GMTRe: Attaquer une base SQL Server avec VFPEvidemment la base de données Foxpro devra être migrée sous SQL.
Une fois cela effectué, il y a 3 manières d'accéder et manipuler les données SQL.
- des vues distantes VFP sur SQL
- des requêtes envoyées par la commande VFP SQLEXE() et le retour dans des curseurs VFP
- l'utilisation de Foxpro CursorAdaptor
Bonne journée
Cdlt
Sun, 19 Oct 2025 06:58:36 GMTRe: Aperçu avant impression tronquéSur toutes les machines qui utilisent l'application.
Sun, 19 Oct 2025 06:58:36 GMTRe: Attaquer une base SQL Server avec VFPBonjour,
La base de données restera celle de VFP ou faut-il créer une base SQL Server et l'intégrer dans le projet VFP ?
Merci.
Sat, 18 Oct 2025 06:58:36 GMTRe: Aperçu avant impression tronquéMerci GLS,
Dois-je faire cette modification sur ma machine de développement ou sur celle du client concerné ?
Sat, 18 Oct 2025 06:58:36 GMTRe: Attaquer une base SQL Server avec VFPBonjour,
Le plus long et le plus fastidieux est qu'il faut revoir les accès aux datas de nos applications en remplaçant toutes les commandes de gestions des données Foxpro (replace, seek, (locate, found, etc..) par des équivalences en SQL (update, select sql, etc..) pour préparer nos applications à gérer les accès en commande SQL
Cdlt
Gilles
Sat, 18 Oct 2025 06:58:36 GMTRe: Aperçu avant impression tronquéBonjour,
C'est certainement lié à la haute résolution de la carte graphique et son exploitation par Foxpro.
Pour régler le problème il faut depuis les propriété de l'exécutable de l'application onglet compatibilité bouton "Modifier les paramètres PPP élevés puis clic sur la case "Remplacement de la mise à l'échelle PPP"
Cdlt
Gilles
Sat, 18 Oct 2025 06:58:36 GMTAttaquer une base SQL Server avec VFPBonjour chers Collègues
J'ai l'obligation d'utiliser VFP pour travailler sur SQL Server Database suite aux nombreuses opportunités que j'ai ratées. Quels sont les prérequis et autres conditions à remplir ?
Merci d'avance pour toutes contributions.
Cordialement.
Damonzon.
Sat, 18 Oct 2025 06:58:36 GMTAperçu avant impression tronquéBonjour chers Collègues,
Parmi la dizaine de clients qui utilisent mon logiciel GRH, il y'a seulement un chez qui l'aperçu avant impression est tronqué vers la droite. Ce qui se répercute sur les documents imprimés. J'ai réglé autant que je peux l'affichage, mais le problème demeure toujours. J'ai même donné à son affichage les paramètres que j'ais sur ma machine de développement, mais le problème est resté irrésolu. Et ça concerne tous les document imprimés. J'espère qu'un d'entre vous m'aidera à trouver la solution.
Merci d'avance.
Cordialement.
Damonzon.
Sat, 18 Oct 2025 06:58:36 GMTRe: FormulaireMerci beaucoup, bonne journée à toi aussi.
Thu, 21 Aug 2025 06:58:36 GMTRe: Formulairela fenêtre principale de VFP s'appelle _screen mais elle n'a pas de propriété
closable. Pour faire ce que tu veux, il faut créer une fenêtre 'principale' qui
elle aura une propriété closable et qui devra contenir le menu principal de ton
application ...
Bonne journée
Jean à Grenoble
--
Cet e-mail a été vérifié par le logiciel antivirus d'AVG.
www.avg.com
Thu, 21 Aug 2025 06:58:36 GMTRe: FormulaireLe jeu. 21 août 2025, 10h45 Jean à Grenoble a écrit :
> Bonjour,
>
> si je comprend bien, tu veux interdire la fermeture de l'écran principal de VFP
> ? A mon humble avis, c'est impossible car cela voudrait dire que l'on ne peut
> pas quitter VFP.
>
> Si tu as un formulaire de ton application qui contient un menu, tu peux mettre
> la propriété closable à .F. (form.closable = .F.), cela va griser la croix en
> haut à droite. Mais dans ce cas tu dois avoir un moyen de fermer la fenêtre par
> programmation.
>
> Et si ce n'est pas cela que tu veux, il faut que tu précises ta question !
>
> Bonne journée
>
> Jean à Grenoble
>
> --
> Cet e-mail a été vérifié par le logiciel antivirus d'AVG.
> www.avg.com
> .
>
Bonjour et merci beaucoup,
en fait je voudrais interdire aux utilistaeurs de fermer leur session en cliquant sur la croix du formulaire qui contient la barre de menu, et les obliger à passer par l'item "Quitter" qui outre la fermeture de l'application nettoie un certain nombre de fichiers tampon. je n'ai pas pu trouver le nom de ce formulaire qui doit doit appartenir au système et être créé avec le gestionnaire de projet.. Avec le nom du formulaire il suffit de modifier la propriété "closable" mais je n'ai pas le nom. Merci de ton aide..
Thu, 21 Aug 2025 06:58:36 GMTRe: FormulaireBonjour,
si je comprend bien, tu veux interdire la fermeture de l'écran principal de VFP
? A mon humble avis, c'est impossible car cela voudrait dire que l'on ne peut
pas quitter VFP.
Si tu as un formulaire de ton application qui contient un menu, tu peux mettre
la propriété closable à .F. (form.closable = .F.), cela va griser la croix en
haut à droite. Mais dans ce cas tu dois avoir un moyen de fermer la fenêtre par
programmation.
Et si ce n'est pas cela que tu veux, il faut que tu précises ta question !
Bonne journée
Jean à Grenoble
--
Cet e-mail a été vérifié par le logiciel antivirus d'AVG.
www.avg.com
Thu, 21 Aug 2025 06:58:36 GMTFormulairebonjour,
je souhaite neutraliser la fermeture du formulaire qui supporte la barre de menu. pouvez vous me donner la methode ou m'indiquer le nom du formulaire qui doit être crée par le système et n'apparait pas dans docs. merci.
Thu, 21 Aug 2025 06:58:36 GMTRe: Afficheur Client VFD avec COM7L'afficheur a été livré avec un câble USB. Il est reconnu sur le port COM7 dans le gestionnaire de périphérique. D'habitude je configure les afficheurs comme imprimante GENERIC avec TEXT ONLY puis je lance la commande SET PRINTER TO NAME AFFICHEUR et ça passe. Mais cette fois ci, cette méthode ne matche pas. Je pense que je dois avoir des problèmes avec l'utilisation du PORT avec VFP.
Tue, 22 Jul 2025 06:58:36 GMTRe: Afficheur Client VFD avec COM7Bonjour,
on pourrait avoir une peu plus de précisions ?
Est-ce que le problème est la gestion du port com7 ?
Est-ce que vous avez la documentation de l'afficheur avec le protocole de liaison ?
etc ...
Jean à Grenoble
--
Cet e-mail a été vérifié par le logiciel antivirus d'AVG.
www.avg.com
Tue, 22 Jul 2025 06:58:36 GMTAfficheur Client VFD avec COM7Bonjour!
Comment gérer un afficheur client avec port com7?
Mon, 21 Jul 2025 06:58:36 GMT