Scrigroup - Documente si articole

     

HomeDocumenteUploadResurseAlte limbi doc
AgriculturaAsigurariComertConfectiiContabilitateContracteEconomie
TransporturiTurismZootehnie


DERULAREA CONTRACTELOR DE EXPORT

Contracte



+ Font mai mare | - Font mai mic



Definirea problemei



Tema abordata este "DERULAREA CONTRACTELOR DE EXPORT" pe beneficiari interni, externi si produse, la nivelul unei case de comenzi.

Date de iesire

Datele de iesire din cadrul activitatii de export au fost grupate in trei rapoarte, satisfacand cerintele informationale interne.

a) Nomenclatorul produselor este utilizat de magazioneri si comercianti pt evidenta stocurilor de produse. Continutul informational si forma de prezentare sunt:

Nomenclatorul produselor

Cod produs

Denumire produs

UM

Pret unitar catalog

Stoc

Valoare

(1)

(2)

(3)

(4)

(5)

(6)

b) Lista beneficiarilor este necesara comerciantilor pentru corespondenta comerciala si financiara. Continutul informational si forma de prezentare sunt:

Lista beneficiarilor

Cod beneficiar

Denumire beneficiar

Tara

Adresa

Contul bancar

(1)

(2)

(3)

(4)

(5)

c) Situatia contractelor scadente este folosita de comercianti pentru derularea ritmica a obligatiilor contractuale la cantitatile si termenele si termenele prevazute, pentru fiecare produs contractat. Continutul informational si forma de prezentare sunt:

Situatia contractelor de export

Nr. contract

Data contract

Cod benef

Cod produs

Den produs

Pu pivrare

Cant contr.

Termen livrare

valoare

(1)

(2)

(3)

(4)

(5)

(6)

(7)

(8)

(9)

Date de intrare

Datele de intrare din cadrul activitatii de export, necesare intocmirii celor trei rapoarte prezentate sunt preluate din documente primare distincte: FISA CONTRACTULUI(anexa 1 si 2) si FISA PRODUSULUI

Continutul informational care va face obiectul prelucrarii pe calculator este prezentat in tabelul urmator:

Document primar

Denumirea informatiei preluate

Lista valorilor posibile

Validari si corelatii

Rolol in prelucrare

Fisa contract

* nr contract

1 la 500

Regasire

(anexa 1)

* data contract

1 la 31; 1 al 12

Cronologic

* cod beneficiar

1 la 99999

Selectiv

* cod tara importatoare

Selectiv

* cod valuta

Selectiv

* prex unitar export

>0

Calcule

* curs valutar

* cod produs

1 la 99999

Selectiv

* cantitate contractata

>0

Calcule

* termen de livrare

1 la 31; 1 la 12

Selectiv

Fisa contract

* tara de origine

Selectiv

(anexa 2)

* denumire beneficiar

Descriptiv

* adresa

Descriptiv

* contul bancar

Descriptiv

Fisa produsului

* cod produs

1 la 99999

Acces

* denumire produs

Descriptiv

* pret unitar

>0

Calcule

* unitate de masura

Descriptiv

* cantitate contractata

>0

Calcule

* cantitate produsa

>0

Calcule

* cantitate livrata

>0

Calcule

Actualizarea datelor

Actualizarea datelor din evidentele primare se face selectiv la nivelul pozitiilor din anexa 1 a fiecarui contract si consta din efectuarea urmatoarelor operatii:

Adaugarea noilor contracte sau a noilor pozitii la anumite contracte suplimentare;

Modificarea oricaror informatii din cadrul contractelor existente;

Stergerea anumitor contracte exptrate sau a unor contracte eronate;

Examinarea datelor existente inavidente.

Coduri adoptate

Codurile adoptate in scopul facilitarii operatiilor de regasire si prelucrare sunt:

codul produsului, N, 5 valori 1 la 99999

codul beneficiarului, N, 5 valori 1 la 99999

numar contract, N, 5 valori 1 la 500

cod depozit, N, 2 valori 1 la 3

codul tarii, C, 2 lista cod automobil

contul bancar, C, 10 lista cod ISO

Solutia propusa

Schema generala

Schema generala ofera o imagine de ansamblu asupra configuratiei utilizate asupra componenteloraplicatiei si a tipului de legaturi dintre ele.

Fisiere

Videoformate:

Intrari informationale

Acestea au fost structurate in trei tabele permanente CONTRACTE, PRODUSE, BENEFICIARI, care constituie baza de date (tip DBF).

Tabela CONTRACTE(contr.dbf)

continutul informational este format din date preluate din Fisa Contractului(anexa1)

structura logica a unei inregistrari:

CODB, N, 5 cod beneficiar

CODP, N, 5 cod produs

PLN, N, 5+2 pret livrare

CANTL, N, 7 cantitate livrata

TERMENL, D, 8 termen(data) livrarii

CL, M, 10 conditii de livrare

macheta ecran formatat: nu

cheia primara: CODB

cheia 1 secundara: CODP

cheia 2 secundara: TERMENL

periodicitatea actualizarii: la cerere

operatii de actualizare necesare: adaugare, modificare, stergere, vizualizare, rasfoire

indexari simple dupa: CODB, CODP, TERMENL, compuse dupa: TERMENL+CODP+CODB pentru actualizari si consultari selective

lungime articol: 42 bytes

nr.maxim de articole in fisier: aprox.5000

necesar de memorie: 42x5000 bytes pe HD si FD

salvarea-restaurarea se face periodic pe FD, pastrand numele

legaturi cu alte fisiere: prin CODB cu fisierul Beneficiari si prin CODP prin fisierul Produse.

Tabela PRODUSE(prod.dbf)

continut informational: format din documentul primar Fisa Produsului

structura logica a unei inregistrari:

CODP, N, 5 index, cod produs

DENP, C, 16 index, denumire produs

UMP, C, 3 unitate de masura

macheta ecran formatat: nu

cheia primara: CODP

cheia 1 secundara: DENP

perioada actualizarii: la cerere

operatii de actualizare necesare: adaugare, modificare, stergere, vizualizare, anulare, rasfoire

indexari simple dupa: CODP, DENP pentru consultari selective

lungime articol: 24 bytes

nr.maxim de articole in fisier: aprox.400

necesar de memorie: 24x400 bytes pe HD si FD

salvarea /restaurarea se face periodic pe FD

legaturi cu alte fisiere: nu

Tabela BENEFICIARI(benef.dbf)

continutul informational este format din datele generale si din anexa 2 ale fiecarui contract de livrare sau comanda incheiata

structura logica a unei inregistrari:

CODB, N, 5 index cod beneficiar

DENB, C, 30 denumire beneficiar

STR, C, 20 strada

NR, N, 3 numarul

LOC, C, 20 localitatea

TEL, N, 7 telefon

CTBC, C, 15 cont bancar

macheta ecran formatata: nu

cheia primara: CODB

cheia 1 secundara: DENB

perioada actualizarii: la cerere

operatii de actualizare necesare: adaugare, modificare, stergere, vizualizare, anulare, reactivare

indexari simple dupa: CODB, DENB pentru consultari selective

lungime articol: 100 bytes

nr.maxim de articole in fisier: aprox.1000

necesar de memorie: 100x1000 bytes pe HD si FD

salvarea /restaurarea se face periodic pe FD

legaturi cu alte fisiere: nu

Iesiri informationale

Acestea au fost sistematizate in trei rapoarte prezentand la cerere anumite informatii necesare utilizatorilor, in forma integrala su partiala.

Nomenclatorul produselor

Este afisat pe ecran, in forma tabelara, cu continut informational structurat potrivit urmatoarei machete:

Cod produs

Denumire produs

UM

Pret unitar catalog

Stoc

Valoare

(1)

(2)

(3)

(4)

(5)

(6)

N 5

C 20

C 4

N 9,2

N 7

N 11,2

suport informational utilizat: monitor color

selectia datelor de prelucrat: tabela Produse fara conditii de selectie

ordonarea datelor in report prin indexare compusa dupa CODP, DENP si fisierul temporar DENPROD.idx

calcule efectuate: val*stoc*pu

grade de total: nu

indicatorii(informatiile) de totalizat: nu

recapitulatii rezultate: nu

sumar statistic la sfarsitul raportului: nu

periodicitate: la cerere

dimensiune tabel: nr. Linii/pagina, nr caractere/linie, nr.pagini/tabel

Lista beneficiarilor

Lista este afisabila pe ecran, in forma tabelara, cu un continut informational sistematizat, in concordanta cu o macheta.

Cod beneficiar

Denumire beneficiar

Tara

Adresa

Contul bancar

(1)

(2)

(3)

(4)

(5)

N 5

C 12

C 7

C 35

C 10

suport informational utilizat: monitor color

selectia datelor de prelucrat: tabela Beneficiari, fara conditii de selectie

ordonarea datelor in report prin indexare compusa dupa CODP, DENP si fisierul temporar TARBEN.idx

calcule efectuate: nu sunt

grade de total: nu

recapitulatii rezultate: nu

sumar statistic la sfarsitul raportului: nu

dimensiune tabel: nr. Linii/pagina, nr caractere/linie, nr.pagini/tabel

Situatia contractelor scadente

Situatia este stocata de HD in fisierul SITCONST.TXT, de unde poate fi listata ulterior pe imprimanta sau afisata pe ecran.

Nr. Contract

Data contract

Cod benef

Cod tara

Cod produs

Den produs

Pu pivrare

Cant contr.

Termen livrare

valoare

(1)

(2)

(3)

(4)

(5)

(6)

(7)

(8)

(9)

(10)

suport informational utilizat: hartie, FD, HD, monitor color

selectia datelor de prelucrat: tabela CONTRACT si BENEFICIARI.Conditia de selectie este luna din TERMENL>luna curenta si CODB din fisierele CONTRACTE si BENEFICIARI sa fie egale

ordonarea datelor in report prin indexare dupa TERMENL si CODP si DENB si fisierul temporar LNCNT.idx

calcule efectuate: val=cant*pu

nivele de totalizare: luna, produs, beneficiar scadenta si total general

indicatorii(informatiile) de totalizat: val

recapitulatii rezultate: nu

sumar statistic la sfarsitul raportului: reccount(), max(), min()

periodicitate: lunara

dimensiune tabel: nr. Linii/pagina, nr caractere/linie, nr.pagini/tabel

Dialogul utilizatorului

Dialogul a fost concentrat in patru liste de optuini, prima formand meniul principal, celelalte trei constituind submeniuri asociate fiecarui optiuni din meniul principal. Aceste liste au fost ierarhizate pe trei nivele, fiecare dintre ele sintetizand fie componentele bazei de date, fie functiile realizate de diverse proceduri din program. Cele patru liste de optiuni formeaza nivelul aplicatiei mai precis ele definesc cadrul conservational dintre program si utilizator. O imagine a dialogului dintre utilizatori si program este prezentata in continuare:

MENIUL ORINCIPAL:

F-fisiere

R-rapoarte

T-terminare

MENIU FISIERE MENIU RAPOARTE STOP

C-contracte 1-nomenclatorul produselor

P-produse 2-lista beneficiarilor

B-beneficiari 3-situatia contractelor scadente

R-rapoarte 4-retur

C P B R

MENIU OPERATII

A-adaugare

M-modificare

S-stergere

V-vizualizare

R-retur

A M S V R

Programele aplicatiei

Programele au fost elaborate sub forma de proceduri, monitorizate in concordanta cu listele de optiuni din meniu. Modul de abordare modulara a programului permite realizare, testare si implementare progresiva de sus in jos a fiecarei proceduri tinand seama de componentele realizate pana la momentul respectiv.

Schema procedurala

Aceasta avidentiaza, in primul rand, procedurile elaborate si legaturile lor cu monitorul si in al doilea rand, legaturile directe dintre anumite proceduri. Prezenta succinta a acestei scheme este urmatoarea:

Functiunile realizate de fiecare procedura sunt urmatoarele:

monitor - realizeaza legatura intre operatiunile utilizatorului specifice in cadrul unei sesiuni de lucru si executia procedurilor functionale;

contracte - realizeaza operatii de adaugare, modificare, stergere, si vizualizare de date din tabela CONTRACTE;

produse - idem din tabela PRODUSE;

beneficiari - idem din tabela BENEFICIARI;

listprod - realizeaza afisarea pe ecran a nomenclatorului de produse;

list ben - idem lista beneficiarilor.

sitcontr.

Concluzii

Regimul cocurential in care isi desfasoara activitatea de export firma, reclama o cumoastere permanenta si profunda a relatiilor comerciale cu partenerii externi. Obiectivul principar al acestei activitati il constituie amplificarea si stabilirea pe perioade mai mari a relatiilor economice avantajoase cu partenerii externi solvabili si diminuarea relatiilor economice cu acei parteneri externi nesolvabili. Atunci cand volumul relatii este mare, divers si dinamic, conoasterea profunda a aspectelor pozitive si negative se poate realiza operativ cu ajutorul calculatorului. Acesta poate oferi utilizatorului, prin continutul informational al bazei de date, informatii exacte despre derularea contractelor, livrarilor sau scadentelor.

Examinarea atenta a datelor poate dezvalui perturbatiile generate de diverse verigi organizatorice, din interiorul sau exteriorul firmei. Se pot diminua sau chiar preveni o serie de perturbatii negative prin luarea sau corelarea unor decizii reale, oportune si eficiente in derularea contractelor cu parteneri externi, Fondul de date structurat in cele trei fisiere ale bazei de date poate fi imbunatatit in perioadele urmatoare, dacase vor urmarii, in continuare, legaturile acestei aplicatii cu ale altei aplicatii conexe: marketing, conjunctura economica, prospectare piata, import, etc.

Cerintele informationale ale diversilor utilizatori se armonizeaza cu posibilitatile practice de realizare oferite de programele elaborate in sistemul Fox Pro.

PROCEDURE MONITOR

*==================

set talk off

close databases

clear

wm="D"

do while upper(wm)="D"

clear

@5,2 to 9,21

@4,3 say"MONITORUL APLICATIEI"

@6,3 prompt"1-Fisiere"

@7,3 prompt"2-Rapoarte"

@8,3 prompt"3-Iesire"

menu to wm1

case wm1=1

do fis

case wm1=2

do rap

case wm1=3

wm="N"

endcase

enddo

clear

close all

close procedure

set talk on

return

PROCEDURE FIS

*MODUL DIRECTOR - TABELA APLICATIEI

es="D"

do while es="D"

@5,2 to 10,21

@4,3 say"TABELA APLICATIEI"color/*U

set color to

@6,3 prompt"1-Produse"

@7,3 prompt"2-Beneficiari"

@8,3 prompt"3-Contracte"

@9,3 prompt"4-Iesire"

menu to f

docase

case f=1

do operactp

case f=2

do operactb

case f=3

do operacte

case f=4

es="N"

endcase

enddo

clear

return

PROCEDURE OPERACTP

*===================

*MODUL DIRECTOR-OPERATII ACTUALIZARE TABELA PROD.dbf

use prod

x=file("prod.dbf")

t=.f.

select 1

if used(1)

t=.t.

else

@23,1say"tabela prod.dbf lipseste dindirector.dati<enter>"

read

endif

wdp=space(16)

wum=" "

wcp=0

wcn="D"

op=0

do while wcn $"Dd"

clear

@3,20 to 17,72 double

titlu="actualizarea nomenclatorului de produse"

@4,32say titlu color/*i

set color to

@5,32 to 5,57

@6,22 prompt "1-adaugare selectiva cu index dupa cod"

@7,22 prompt"2-modificare selectiva cu index prin cod "

@8,22 prompt"3-stergere fizica selectiva cu index prin cod"

@9,22prompt"4-stergere logica selectiva cu index prin cod"

@10,22prompt"5-reactivare selectiva cu index prin cod"

@11,22prompt"6-vizualizare selectiva dupa index prin cod"

@12.22prompt"7-rasfoire secventiala cu selectie"

@13,22prompt"8-vizualizare selectiva cu index dupa denumire"

@14,22prompt"9-vizualizare selectiva direct din zona fisier"

@15,22prompt"10-vizualizare secventiala prin pointer"+chr(16)

@16,22prompt"11-retur la nivel superior"

menu to op

do case

case op=1

doadaugp

case op=2

do modifp

case op=3

do stergp

case op=4

do stergp

case op=5

do reactivp

case op=6

do vizcp

case op=7

do resfoirp

case op=8

do vizdenp

case op=9

do vizdirp

case op=10

do acsecvp

case op-11

wcn="N"

endcase

enddo

clear

return

PROCEDURE ICSODP

*================

*INDEXEAZA NOMENCLATORUL PROD.dbf DUPA CODP

close index

delete file iscodp.idx

index on codb to iscodp

set index to iscodp

return

PROCEDURE ADAUGP

*=================

*PROCEDURA DE ADAUGARE NOI PRODUSE IN NOMENCLATOR

CLEAR

@7,22 say"adaugare PRODUSE" color/*i

set color to

cn="D"

di iscodp

do while cn="D"

ww=.F.

st=" "

@19,0 clear to 20,79

@8,9 clear to 16,70

do initp

wcp=0

@9,11 say"cod produs..:"get wcodb picture "@99999"

read

do while ww=.F.

seek wcp

if.not.found()

ww=.T.

else

@19,0 say "inregistrare dubla"

do afecranp

@20,0say"aceasta este inreg. De adaugat?(D/N):"get st picture"!"

read

@8,9 clear to 16,70

@19,0 clear to 20,70

if upper(st) ="N"

exit

else

endif

else

endif

do initp

@19,11 say "cod produs...:"get wcp picture"@99999"color/*i

read

endif

enddo

@19,0 clear to 20,75

if cn ="N"

exit

else

endif

do getecrp

append blank

do repben

do initp

@8,9 clear to 16,70

cn=" "

@20,0 say"continuati adaugarea?(D/N): "get cn picture"@!"

read

enddo

return

PROCEDURE MODIFP

*=================

*MODIFICARE DATE PRODUS IN PROD.dbf

clear

@7,22say"modificare PRODUSE " color/*i

set color to

cn="D"

do iscodp

di while cn="D"

st=" "

@19,0 clear to 20,78

@8,9 clear to 16,70

di initp

wcp=0

@9,11 say"cod produs...: "get wcodb picture"@99999"

read

seek wcp

if .not.found()

@19,0 say"inregistrare lipsa"

else

do movprod

do getecrp

replace codp with wcp

do reprodus

do initp

endif

cn=" "

@20,0 say"continuati modificarea?(D/N): "get cn picture"@!"

read

enddo

return

PROCEDURE STERGP

*================

*STERGERE PRODUSE DIN NOMENCLATORUL PROD.dbf

clear

@7,22 say'stergere produse' color/*i

set color to

cn = 'D'

do iscodp

do while cn = 'd'

st=' '

@19,0 clear to 20,78

@ 8,9 clear to 16,68

wcp=0

@ 9,11 say 'cod produs.:' get wcp picture '@99999'

read

seek wcp

if.not.found()

@19,0 say 'inregistrare lipsa'

else

do afecranp

if delete()

@19,0 say 'produsul era deja marcat pentru stergere.dati<enter>'

read

@19,0 clear to 19,78

else

store' ' to st

@20,0 say'acest produs se va sterge?(D/N):'get st pict '!'

read

@20,0 clear to 20,78

if st='D'

delete

else

endif

endif

endif

cn=' '

@20,0 say'continuati stergerea?(D/N):'get cn picture'@!'

read

enddo

return

PROCEDURE REACTIVP

*==================

*REACTIVAREA PRODUSELOR STERSE LOGIC

clear

@7,22 say'reactivare produse' color/*i

set color to

cn='D'

do iscodp

do while cn='D'

st=' '

@19,0clear to 20,78

@8,9 clear to 16,68

wcp=0

@9,11 say'cod produs:' get wcp picture' @99999'

read

seekwcp

if .not.found()

@19,0say'produsul era deja marcat pentru inregistrare.dati<enter>'

read

store ' ' to st

@20,0 say'acest produs se va reactiva?(D/N):'get pict '!'

read

@19,0clear to 20,78

else

@19,0 say 'produsul nu era marcat pentru stergere.dati<enter>'

read@19,0 clear to 20,78

endif

if st='D'

recall

else

endif

endif

cn=' '

@20,0 say 'continuati reactivarea?(D/N):'get cn picture '@!'

read

enddo

return

PROCEDURE VIZCP

*===============

*VIZUALIZARE PRODUS DUPA COD

clear

@7,22 say'vizualizare produse' color/*i

set color to

cn ='D'

di iscodp

do while cn='D'

st=' '

@20,0 clear to 20,65

@8,9 clear to 16,70

wcp=0

@9,11 say 'cod produs:'get wcp picture'@99999'

read

seek wcp

if.not.found()

@19,0say 'inregistrare lipsa'

else

do afecranp

endif

cn=' '

@20,0say'continuati vizualizarea?(D/N):'get cn picture'@!'

read

enddo

return

PROCEDURE RASFOIRP

*===================

*RASFOIREA PRODUSELOR DIN NOMENCLATORUL PROD.dbf

clear

*scroll 18,11,21,65,4

*@14,2,22,29 box replicate(chr(176).25)

define window windp from 15,4 to 21,28 title 'PRODUSE' double

*activate window windp

@14,4say'dupa pozitionare dati<CTRL END>'

brow window windp normal

do movprod

@14,4 clear to 14,7

do afecranp

@7,23 say'rasfoire secventiala cu selectie'color/*i

set color to

@18,1say' '

wait

*deactivate window windp

return

PROCEDURE MOVPROD

*===================

*MUTA CONTINUTUL VARIABILEI DIN TABELA PROD.dbf

*IN VARIABILE DE MEMORIE

wcp=codp

wcp=denp

wum=ump

PROCEDURE REPRODUS

*===================

*RECTIFICAREA CONTINUTULUI VARIABILELOR DIN TABELA PROD.dbf

* CU CONTINUTUL VARIABILELOR DE MEMORIE

repl codp with wcp

repl denp with wdp

repl ump with wum

return

PROCEDURE AFECRANP

*===================

*AFISEAZA ECRANUL PENTRU VIZUALIZARE DATE PRODUS

@8,9clear to 16,70

@8,9to 12,70

@6,8 to 17,71 double

@7,48 say "poz.crt.in fis"+str(recno(),5)

@9,11 say "cod produs..:"+str(codp,5)

@10,11say"denumire produs..:"+denp

@11,11say"unitate masura...:"+ump

return

PROCEDURE GETECRP

*==================

*AFISAZA ECRANUL PENTRU INCARCARE DATE PRODUS

@8,9 to 12,70

@6,8 to 17,71 double

@7,48 say"poz.crt.in fis."+str(recnu(),5)

@10.11 say "denumire produs..:"get wdp pict"! ! !!"

@11.11 say"unit. de masura..:"get wum pict"!!!"

read

return

PROCEDURE INITP

*==============

*INITIALIZEAZA VARIABILELE DE MEMORIE

wcp=0

wdp=space(16)

wum=" "

return

PROCEDURE VIZDENP

*==================

*VIZUALIZEAZA DUPA PRIMELE 5 CARACTERE DIN

* DENUMIREA PRODUSULUI

clear

close index

delete file isden.idx

x=file("isden.idx")

t=.f.

select 1

if used(1)

t=.t.

else

delete file isden.idx

endif

if t=.t.

index on substr(denp,1,5) to isden

else

index on substr(denp,1,5) to isden

endif

set index ti isden

myn="D"

do while myn$"Dd"

ml=5

k5=" "

go top

@2,2 say "tastati primele 5 litere din denumirea produsului cautat: "get k5 picture"@XXXXX"

read

K5=upper(k5)

@2,2clear to 2,78

seek k5

if.not.found()

myn=" "

@21,2say"produs cu aceasta denumire lipsa!! Dati <enter>"

read

else

ml=5

set color/i

@3,1say"cod denumire produs U.M."

@4,1say"=================="

set color to

do while k5=substr(denp,1,5).and.not.eof()

@ml,1 say str(codp,5)+" "+substr(denp,1,16)+" "+ump

ml=ml+1

skip

if ml>16

ml=5

@20,1say"============================"

wait

@5,0clear to 19.79

else

endif

yn2=" "

enddo

endif

myn=" "

@22,2say"continuati cu alta denumire?(D/N): "get myn

read

@5,1 clear to 19,78

@22,0 clear to 22,78

enddo

K5=" "

Return

PROCEDURE VIZDIRP

*=================

*VIZUALIZARE SELECTIVA DIRECT DIN ZONA TABELEI

clear

@7,22 say "vizualizare din baza" color/*i

set color to

cn="D"

do while upper(cn)="D"

wcp=0

@22,3say"dati codul produsului: "get wcp pict"99999"

read

locate for codp=wcp

do afecranp

continue

@21,3say"continuati?(D/N): "get cn

read

enddo

return

PROCEDURE ACSECVP

*==================

*ACCESE PRIN POINTER(IDENTIFICATOR) IN TABELA PROD.dbf

clear

@7,13 say"acces prin pointer(identificator)"

set color to

do iscodp

yn="D"

do while.not.eof().and.upper(yn)="D"

@1,55 prompt "1-prima inregistrare"

@2,55prompt"2-urmatoarea inregistrare"

@3,55prompt"3-precedenta inregistrare"

@4,55prompt"4-ultima inregistrare"

@5,55prompt"5-a n-a inregistrare"

menu to ii

do case

case ii=1

go top

do afecranp

case ii=2

skip

if eof()

skip-1

else

endif

do afecranp

case ii=3

skip-1

if bof()

skip

else

endif

do afecranp

case ii=4

go bottom

do afecranp

case ii=5

id=1

@22,2say"dati un pointer de inregistrare1-n: "get id picture "@99999"

read

@22,0 clear to 22,78

if id<= reccount()

go id

do afecranp

else

@22,1say"pointer inreg.cautata>pointer ultima inreg: "+str(reccount())

read

@22,0 clear to 22,78

endif

endcase

@22,0 say"continuati?(D/N): "get yn

read

@22,0 clear to 22,,78

enddo

return

PROCEDURE OPERACTB

*===================

*MODUL DIRECTOR-OPERATII ACTUALIZARE TABELA BENEF.dbf

use benef

x=file("benef.dbf")

t=.f.

select 1

if used(1)

t=.t.

else

@23,1say"tabela benef.dbf lipseste dindirector.dati<enter>"

read

endif

wdenb=space(30)

wstr=space(20)

wnr=0

wloc=space(20)

wtel=0

wctbc=space(15)

wcodb=0

wcn="D"

op=0

do while wcn $"Dd"

clear

@3,20 to 17,72 double

titlu="actualizarea nomenclatorului de beneficiari"

@4,32say titlu color/*i

set color to

@5,32 to 5,57

@6,22 prompt "1-adaugare selectiva cu index dupa cod"

@7,22 prompt"2-modificare selectiva cu index prin cod "

@8,22 prompt"3-stergere fizica selectiva cu index prin cod"

@9,22prompt"4-stergere logica selectiva cu index prin cod"

@10,22prompt"5-reactivare selectiva cu index prin cod"

@11,22prompt"6-vizualizare selectiva dupa index prin cod"

@12.22prompt"7-rasfoire secventiala cu selectie"

@13,22prompt"8-vizualizare selectiva cu index dupa denumire"

@14,22prompt"9-vizualizare selectiva direct din zona fisier"

@15,22prompt"10-vizualizare secventiala prin pointer"+chr(16)

@16,22prompt"11-retur la nivel superior"

menu to op

do case

case op=1

doadaugb

case op=2

do modifb

case op=3

do stergb

case op=4

do stergb

case op=5

do reactivb

case op=6

do vizcb

case op=7

do resfoirb

case op=8

do vizdenb

case op=9

do vizdirb

case op=10

do acsecvb

case op-11

wcn="N"

endcase

enddo

clear

return

PROCEDURE ICSODB

*================

*INDEXEAZA NOMENCLATORUL BENEF.dbf DUPA CODB

close index

delete file iscodb.idx

index on codb to iscodb

set index to iscodb

return

PROCEDURE ADAUGB

*=================

*PROCEDURA DE ADAUGARE NOI BENEFICIARI IN NOMENCLATOR

CLEAR

@7,22 say"adaugare beneficiari" color/*i

set color to

cn="D"

di iscodb

do while cn="D"

ww=.F.

st=" "

@19,0 clear to 20,79

@8,9 clear to 16,70

do initb

wcodb=0

@9,11 say"cod beneficiar..:"get wcodb picture "@99999"

read

do while ww=.F.

seek wcodb

if.not.found()

ww=.T.

else

@19,0 say "inregistrare dubla"

do afecranb

@20,0say"aceasta este inreg. De adaugat?(D/N):"get st picture"!"

read

@8,9 clear to 16,70

@19,0 clear to 20,70

if upper(st) ="N"

exit

else

endif

else

endif

enddo

@19,11 say "cod beneficiar...:"get wcodb picture"@99999"

read

endif

enddo

@19,0 clear to 20,75

if cn ="N"

exit

else

endif

do getecrb

append blank

do repben

do initB

@8,9 clear to 16,70

cn=" "

@20,0 say"continuati adaugarea?(D/N): "get cn picture"@!"

read

enddo

return

PROCEDURE MODIFB

*=================

*MODIFICARE DATE BENEFICIARI IN BENEF.dbf

clear

@7,22say"modificare beneficiari " color/*i

set color to

cn="D"

do iscodb

di while cn="D"

st=" "

@19,0 clear to 20,78

@8,9 clear to 16,70

di initb

wcodb=0

@9,11 say"cod beneficiar...: "get wcodb picture"@99999"

read

seek wcodb

if .not.found()

@19,0 say"inregistrare lipsa"

else

do movben

do getecrb

replace codb with wcodb

do repben

do initb

endif

cn=" "

@20,0 say"continuati modificarea?(D/N): "get cn picture"@!"

read

enddo

return

PROCEDURE STERGB

*================

*STERGERE PRODUSE DIN NOMENCLATORU BENEF.dbf

clear

@7,22 say"stergere beneficiari" color/*i

set color to cn="D"

di iscodb

do while cn="D"

st=" "

@19,0 clear to 20,78

@8,9 clear to 16,68

wcodb=0

@9,11say"cod beneficiar..: "get wcodb picture "@99999"

read

seek wcodb

if .not.found()

@19,0 say"inregistrare lipsa"

else

do afecranb

if delete()

@19,0say"beneficiarul era deja marcat pentru stergere.dati<enter>"

read

@19,0 clear to 19,78

else

store" "to st

@20,0say"acest beneficiar se va sterge?(D/N): "get st pict '!'

read

@20,0 clear to 20,78

if st="D"

delete

else

endif

endif

endif

cn=" "

@20,0 say"continuati stergerea?(D/N): "get cn picture"@!"

read

enddo

return

PROCEDURE REACTIVB

*===================

*REACTIVAREA BENEFICIARILOR STERSE LOGIC

clear

@7,22 say"reactivare beneficiari "color/*i

set color to

cn="D"

do iscodb

do while cn="D"

st=" "

@19,0clear to 20,78

@8,9clear to 16,68

wcodb=0

@9,11say"cod beneficiar..: "get wcod picture"@99999"

read

seek wcodb

if .not.found()

@19,0say"inregistrare lipsa"

else

do afecranb

if delete()

@19,0say "beneficiarul era deja marcat pt.stergere.dati<enter>"

read

store" "to st

@20,0say"acest beneficiar se va reactiva?(D/N): "get st pict'!'

read

@19,0clear to 20,78

else

@19,0say"beneficiarul nu era marcat pentru stergere.dati <enter>"

read

@19,0 clear to 20,78

endif

if st='D'

recall

else

endif

endif

cn=" "

@20,0say "continuati stergerea?(D/N):"get cn picture"@!"

read

enddo

return

PROCEDURE VIZCB

*================

*VIZUALIZARE BENEFICIAR DUPA COD

CLEAR

@7,22say"vizualizare beneficiar"color/*i

set color to

cn="D"

do iscodb

do while cn="D"

st=" "

@20,0clear to 20,65

@8,9 clear to 16,70

wcodb=0

@9,11say"cod beneficiar..:"get wcodb picture"@99999"

read

seek wcodb

if.not.found()

@19,0say"inregistrare lipsa"

else

do afecranb

endif

cn=" "

@20,0say"continuati vizualizarea?(D/N): "get cn picture"@!"

read

enddo

return

PROCEDURE RASFOIRB

*===================

*RESFOIREA BENEFICIARILOR DIN NOMENCLATORUL BENEF.dbf

clear

*scroll18,11,21,65,4

*@14,2,22,29 box replicate(chr176),25)

define window windb from 15,4 to 21,37 title 'beneficiar'double

*activate window windb

@7,13 say"rasfoire secventiala cu selectie "

@14,3 clear to 14,7

do movben

do afecranb

@18,1say" "

wait

*deactivate window windb

return

PROCEDURE MOVBEN

*=================

*MUTA CONTINUTUL VARIABILELOR DIN TABELA BENEF.dbf

* IN VARIABILE DE MEMORIE

WCODB=CODB

Wden=denb

Wstr=str

Wnr=nr

Wloc=loc

Wtel=tel

Wctbc=ctbc

Return

PROCEDURE REPBEN

*=================

*RECTIFICA CONTINUTUL VARIABILELOR DIN TABELA BENEF.dbf

* CU CONTINUTUL VARIABILELOR DE MEMORIE

repl codb with wcodb

repl denb with wdenb

repl str with wstr

repl nr with wnr

repl loc with wloc

repl tel with wtel

repl ctbc with wctbc

return

PROCEDURE AFECRANB

*===================

*AFISAZA ECRANUL PT. VIZUALIZARE DATE BENEFICIAR

@8,9clear to 16,70

@8,9to 16,70

@6,8 to 17,71 double

@7,48 say "poz.crt.in fis"+str(recno(),5)

@9,11 say "cod benficiar..:"+str(codp,5)

@10,11say"denumire beneficiar..:"+denb

@11,11say"strada...:"+str

@12,11say"numarul..:"+str(nr,3)

@13,11say"localitatea.."+loc

@14,11say"telefonul...."+str(tel,7)

@15,11say"contul bancar..."+ctbc

return

PROCEDURE GETECRB

*==================

*AFISEAZA ECRANUL PT. INCARCARE DE DATE

@8,9clear to 16,70

@6,8 to 17,71 double

@7,48 say "poz.crt.in fis"+str(recno(),5)

@9,11 say "cod benficiar..:"GET wcodb pict"@99999"

@10,11say"denumire beneficiar..:"get denb

@11,11say"strada...:"get wstr

@12,11say"numarul..:"get wnr

@13,11say"localitatea.."get wloc

@14,11say"telefonul...."get wtel

@15,11say"contul bancar..."get wctbc

read

return

PROCEDURE INITB

*===============

*INITIALIZEAZA VARIABILELE DE MEMORIE

WCODB=0

Wdenb =space(30)

Wstr=space(20)

Wnr=0

Wloc=space(20)

Wtel=0

Wctbc=space(15)

Return

PROCEDURE VIZDENB

*=================

*VIZUALIZEAZA DUPA PRIMELE 5 CARACTERE DIN DENUMIREA

*BENEFICEARI

clear

close index

delete file isdenb.idx

x=file("index.idx")

t=.f.

select

if used (1)

t=.t.

else

delete file isdenb.idx

endif

endif

if t=.t.

index on substr(denb,1,5) to isdenb

*reindex

else

index on substr(denb,1,5) to isdenb

endif

set index to isdenb

myn="D"

do while myn$"Dd"

ml=5

k4=" "

go top

@2,2 say "tastati primele 5 litere din denumirea beneficiarului cautat: " get k5; picture"@XXXXX"

read

K5=upper(k5)

@2,2 clear to 2,78

seek k4

if .not .found()

myn=" "

@21,2 say "beneficiar cu aceasta denumire lipsa!!. Dati<enter>"

read

else

ml=5

set color to /i

@3,1 say"cod denumire beneficear localitate"

@4,1 say"==========================="

set color to

do while k5=substr(den,1,5).and..not.eof()

@ml,1 say str(codb,5)+" "+substr(denb,1,30)+" "+loc

ml=ml+1

skip

if ml>16

ml=5

@20,0 say"================================="wait

@5,0 clearto 19,79

else

endif

yn=" "

enddo

endif

myn=" "

@22,2 say "continuati cu alta denumire?(D/N):"get myn

read

@5,1clear to 19,78

@22,0 clear to 22,78

enddo

k5=" "

return

PROCEDURE VIZDIRB

*=================

*VIZUALIZARE SELECTIVA DIRECT DIN ZONA TABELEI

clear

@7,22 say "vizualizare din baza" color/*i

set color to

cn="D"

do while upper(cn)="D"

wcp=0

@22,3say"dati codul beneficiarului: "get wcp pict"99999"

read

locate for codb=wcodb

do afecranb

continue

@21,3say"continuati?(D/N): "get cn

read

enddo

return

PROCEDURE ACSECVB

*==================

*ACCESE PRIN POINTER(IDENTIFICATOR) IN TABELA BENEF.dbf

clear

@7,13 say"acces prin pointer(identificator)"

set color to

do iscodb

yn="D"

do while.not.eof().and.upper(yn)="D"

@1,55 prompt "1-prima inregistrare"

@2,55prompt"2-urmatoarea inregistrare"

@3,55prompt"3-precedenta inregistrare"

@4,55prompt"4-ultima inregistrare"

@5,55prompt"5-a n-a inregistrare"

menu to ii

do case

case ii=1

go top

do afecranb

case ii=2

skip

if eof()

skip-1

else

endif

do afecranb

case ii=3

skip-1

if bof()

skip

else

endif

do afecranb

case ii=4

go bottom

do afecranb

case ii=5

id=1

@22,2say"dati un pointer de inregistrare1-n: "get id picture "@99999"

read

@22,0 clear to 22,78

if id<= reccount()

go id

do afecranb

else

@22,1say"pointer inreg.cautata.>pointer ultima inreg: "+str(reccount())

read

@22,0 clear to 22,78

endif

endcase

@22,0 say"continuati?(D/N): "get yn

read

@22,0 clear to 22,,78

enddo

return

PROCEDURE OPERACTE

*===================

*MODUL DIRECTOR-OPERATII ACTUALIZARE TABELA CONTR.dbf

use CONTR

x=file("CONTR.dbf")

t=.f.

select 1

if used(1)

t=.t.

else

@23,1say"tabela CONTR.dbf lipseste dindirector.dati<enter>"

read

endif

wdenb=0

wcodp=0

wpln=0.0

wcantl=0

wtlv=ctod('/ /')

wcl=" "

wcn="D"

op=0

do while wcn $"Dd"

clear

@3,20 to 17,72 double

titlu="actualizarea nomenclatorului de beneficiari"

@4,32say titlu color/*i

set color to

@5,32 to 5,57

@6,22 prompt "1-adaugare selectiva cu index dupa cod"

@7,22 prompt"2-modificare selectiva cu index prin cod "

@8,22 prompt"3-stergere fizica selectiva cu index prin cod"

@9,22prompt"4-stergere logica selectiva cu index prin cod"

@10,22prompt"5-reactivare selectiva cu index prin cod"

@11,22prompt"6-vizualizare selectiva dupa index prin cod"

@12.22prompt"7-rasfoire secventiala cu selectie"

@13,22prompt"8-vizualizare selectiva cu index dupa denumire"

@14,22prompt"9-vizualizare selectiva direct din zona fisier"

@15,22prompt"10-vizualizare secventiala prin pointer"+chr(16)

@16,22prompt"11-retur la nivel superior"

menu to op

do case

case op=1

doadauge

case op=2

do modife

case op=3

do sterge

case op=4

do sterge

case op=5

do reactive

case op=6

do vizce

case op=7

do resfoire

case op=8

do vizdire

case op=9

do acsecve

case op=10

wcn="N"

endcase

enddo

clear

return

PROCEDURE ISCODEB

*==================

*INDEXEAZA NOMENCLATORUL CONTR.dbf DUPA CODB

close index

delete file iscode.idx

index on codb to iscodbe

set index to iscodbe

return

PROCEDURE ADAUGE

*=================

*PROCEDURA DE ADAUGARE NOI CONTRACTE IN NOMENCLATOR

CLEAR

@7,22 say"adaugare contracte" color/*i

cn="D"

di iscodeb

do while cn="D"

ww=.F.

st=" "

@19,0 clear to 20,79

@8,9 clear to 16,70

do inite

wcodb=0

@9,11 say"cod beneficiar..:"get wcodb picture "@99999"

read

do while ww=.F.

seek wcodb

if.not.found()

ww=.T.

else

@19,0 say "inregistrare dubla"

do afecrane

@20,0say"aceasta este inreg. De adaugat?(D/N):"get st picture"!"

read

@8,9 clear to 16,70

@19,0 clear to 20,70

if upper(st) ="D"

@20,0 say "continuati operatia de adaugare?(D/N): "get cn pict"!"

read

if upper(CN)="N"

exit

else

endif

else

endif

do inite

@19,11 say "cod beneficiar...:"get wcodb picture"@99999"

read

endif

enddo

@19,0 clear to 20,75

if cn ="N"

exit

else

endif

do getecre

append blank

do repcont

do inite

@8,9 clear to 16,70

cn=" "

@20,0 say"continuati adaugarea?(D/N): "get cn picture"@!"

read

enddo

return

PROCEDURE MODIFE

*=================

*MODIFICARE DATE CONTRACT IN CONTR.dbf

clear

@7,22say"modificare contract " color/*i

set color to

cn="D"

do iscodeb

di while cn="D"

st=" "

@19,0 clear to 20,78

@8,9 clear to 16,70

di inite

wcodb=0

@9,11 say"cod beneficiar...: "get wcodb picture"@99999"

read

seek wcodb

if .not.found()

@19,0 say"inregistrare lipsa"

else

do movcont

do getecre

replace codb with wcodb

do repcont

do inite

endif

cn=" "

@20,0 say"continuati modificarea?(D/N): "get cn picture"@!"

read

enddo

return

PROCEDURE STERGE

*================

*STERGERECONTRACTE DIN NOMENCLATORU CONTR.dbf

clear

@7,22 say"stergere beneficiari" color/*i

set color to

cn="D"

di iscodeb

do while cn="D"

st=" "

@19,0 clear to 20,78

@8,9 clear to 16,68

wcodb=0

@9,11say"cod beneficiar..: "get wcodb picture "@99999"

read

seek wcodb

if .not.found()

@19,0 say"inregistrare lipsa"

else

do afecrane

if delete()

@19,0say"beneficiarul era deja marcat pentru stergere.dati<enter>"

read

@19,0 clear to 19,78

else

store" "to st

@20,0say"acest beneficiar se va sterge?(D/N): "get st pict '!'

read

@20,0 clear to 20,78

if st="D"

delete

else

endif

endif

endif

cn=" "

@20,0 say"continuati stergerea?(D/N): "get cn picture"@!"

read

enddo

return

PROCEDURE REACTIVE

*===================

*REACTIVAREA CONTRACTELOR STERSE LOGIC

clear

@7,22 say"reactivare contracte "color/*i

set color to

cn="D"

do iscodeb

do while cn="D"

st=" "

@19,0clear to 20,78

@8,9clear to 16,68

wcodb=0

@9,11say"cod beneficiar..: "get wcod picture"@99999"

read

seek wcodb

if .not.found()

@19,0say"inregistrare lipsa"

else

do afecrane

if delete()

@19,0say "beneficiarul era deja marcat pt.stergere.dati<enter>"

read

store" "to st

@20,0say"acest beneficiar se va reactiva?(D/N): "get st pict'!'

read

@19,0clear to 20,78

else

@19,0say"beneficiarul nu era marcat pentru stergere.dati <enter>"

read

@19,0 clear to 20,78

endif

if st='D'

recall

else

endif

endif

cn=" "

@20,0say "continuati stergerea?(D/N):"get cn picture"@!"

read

enddo

return

PROCEDURE VIZCE

*================

*VIZUALIZARE CONTRACTE DUPA COD

CLEAR

@7,22say"vizualizare beneficiar"color/*i

set color to

cn="D"

do iscodeb

do while cn="D"

st=" "

@20,0clear to 20,65

@8,9 clear to 16,70

wcodb=0

@9,11say"cod beneficiar..:"get wcodb picture"@99999"

read

seek wcodb

if.not.found()

@19,0say"inregistrare lipsa"

else

do afecrane

endif

cn=" "

@20,0say"continuati vizualizarea?(D/N): "get cn picture"@!"

read

enddo

return

PROCEDURE RASFOIRE

*===================

*RESFOIREA CONTRACTOLOR DIN NOMENCLATORUL BENEF.dbf

clear

define window windb from 15,4 to 21,37 title 'beneficiar'double

@7,13 say"rasfoire secventiala cu selectie "COLOR/*I

set color to

@14,4say "dupa pozitionare dati<CTR END>"

brow window winde normal

@14,3 clear to 14,7

do movcont

do afecrane

@18,1say" "

wait

return

PROCEDURE MOVCONT

*===================

*MUTA CONTINUTUL VARIABILELOR DIN TABELA CONTR.dbf

* IN VARIABILE DE MEMORIE

wcodb=codb

wcodp=codp

wpln=pln

wcantl=cantl

wtlv=termenl

wcl=cl

return

PROCEDURE REP CONT

*===================

*RECTIFICA CONTINUTUL VARIABILELOR DIN TABELA CONTR.dbf

*CU CONTINUTUL VARIABILELOR DE MEMORIE

replcodb with wcodb

repl codp with wcodp

repl pln with wpln

repl cantl with wcantl

repl termenl with wtlv

repl el witl wel

return

PROCEDURE AFECRANE

*====================

*AFISAZA ECRANUL PENTRU VIZUALIZARE DATE CONTRACTE

@8,9 clear to 16,70

@8,9to 16,70

@6,8 to 17,71 double

@7,48 say"poz.crt.in fis"+str(recno(),5)

@9,11 say"cod beneficiar..: "+str(codb,5)

@10,11 say"cod produs....: "+str(codp,5)

@11,11say"pretul de livrare..: "+str(0pln,7,2)

@12,11say"cantitatea contractata:"+str(cantl,7)

@13,11say"termenul de livrare.: "+dtoc(termenl)

return

PROCEDURE GETECRE

*===================

*AFISAZA ECRANUL PENTRU INCARCARE DATE CONTRACT

@8,9 TO 16.70

@6,8 to 17.71 double

@7,48 say"poz.crt.in fis."+str(recno(),5)

@9,11 say"cod beneficiar ...: "get wcodb pict"@99999"

@10.11 say"cod produs...: "get wcodp pict"@99999"

@11,11 say"pretul de livrare.: "get wpln pict"@9999999.99"

@12,11 say"cantitatea livrata.: "get wcantl pict"@9999999"

@13,11 say"termen de livrare..: "get wtlv pict" "

@14,11 say"conditia de livrare..: "get wcl pict" "

return

PROCEDURE INITE

*===============

*INITIALIZEAZA VARIABILELE DE MEMOREI

wcodb=0

wcodp=0

wpln=0

wcantl=0

wtlv=ctod('/ /')

wcl=" "

return

* PROCEDURE VIZDIRE

*=================

*VIZUALIZARE SELECTIVA DIRECT DIN ZONA TABELEI

clear

@7,22 say "vizualizare din baza" color/*i

set color to

cn="D"

do while upper(cn)="D"

wcodb=0

@22,3say"dati codul produsului: "get wcodb pict"99999"

read

locate for codp=wcodb

do afecrane

continue

@21,3say"continuati?(D/N): "get cn

read

enddo

return

PROCEDURE ACSECVE

*==================

*ACCESE PRIN POINTER(IDENTIFICATOR) IN TABELA CONTR.dbf

clear

@7,11 say"acces prin pointer(identificator)"

set color to

do iscodeb

yn="D"

do while.not.eof().and.upper(yn)="D"

@1,55 prompt "1-prima inregistrare"

@2,55prompt"2-urmatoarea inregistrare"

@3,55prompt"3-precedenta inregistrare"

@4,55prompt"4-ultima inregistrare"

@5,55prompt"5-a n-a inregistrare"

menu to ii

do case

case ii=1

go top

do afecrane

case ii=2

skip

if eof()

skip-1

else

endif

do afecrane

case ii=3

skip-1

if bof()

skip

else

endif

do afecrane

case ii=4

go bottom

do afecrane

case ii=5

id=1

@22,2say"dati un pointer de inregistrare1-n: "get id picture "@99999"

read

@22,0 clear to 22,78

if id<= reccount()

go id

do afecrane

else

@22,1say"pointer inreg.cautata>pointer ultima inreg: "+str(reccount())

read

@22,0 clear to 22,78

endif

endcase

@22,0 say"continuati?(D/N): "get yn

read

@22,0 clear to 22,,78

enddo

return

PROCEDURE RAP

*=============

CLEAR

me="D"

do while upper(me)="D"

@5,2 to 9,29

@4,3 say "modulul director pentru editere de repoarte"

@5,3say"=============================="

@6,3prompt"1-lista produselor"

@7,3prompt"2-lista beneficiarilor"

@8,3prompt"3-iesire"

menu to wm1

case wm1=1

do listprod

case wm1=2

do listben

case wm1=3

me="N"

endcase

enddo

return

PROCEDURE LISTPROD

*==================

CLEAR

@4,4 SAY"lista produselor"

select 2

use prod

if .not.file("prod.idx")

index on denp to prod.idx

endif

set index to prod

go top

c4="D"

do while upper(c4)="D"

do while.not.eof()

clear

?' lista produselor'

cod denumire um'

?'========================================='

?

disp next 16 fields codp,denp,umpwhile.not.eof() off

wait

enddo

clear

@20.2 say"continuati?(D/N): "get c4

read

enddo

return

PROCEDURE LISTBEN

*=================

clear

select 3

use benef

if.not.file('benef.idx')

index on denb to benef.idx

endif

set index to benef

go top

c4="D"

do while upper(c4)="D"

while.not.eof()

clear

?' lista beneficiarilor'

?' ----- ----- -------'

?

?'==================================================='

?' cod denumire localitate telefon'

?'==================================================='

?

disp next 15 fields codb,denb,loc,tel while.not.eof() off

wait

enddo

clear

@20,2 say"continuati?(D/N): "get c4

read

enddo

return



Politica de confidentialitate | Termeni si conditii de utilizare



DISTRIBUIE DOCUMENTUL

Comentarii


Vizualizari: 1811
Importanta: rank

Comenteaza documentul:

Te rugam sa te autentifici sau sa iti faci cont pentru a putea comenta

Creaza cont nou

Termeni si conditii de utilizare | Contact
© SCRIGROUP 2025 . All rights reserved