Chuyên đề Xây dựng hệ thống thông tin quản lý nhân sự tại công ty cổ phần Thiên Minh

* Thực thể khen thưởng: - Tên thực thể : Khen thưởng - Tên viết tắt : KHENTHUONG - Mỗi thể hiện của thực thể KHENTHUONG là một đối tượng dùng để lưu trữ tất cả các lần khen thưởng của Nhân viên trong một tháng, bởi một mã số nhất định là khen thưởng ( MS_KT ). Mỗi lần khen thưởng được biết qua ngày khen thưởng ( NGAYKT ), Lý do khen thưởng ( LYDO ), Hình thức khen thưởng ( HTKT ) và số biên bản xác định số lần khen thưởng đó ( SOBB ).

doc152 trang | Chia sẻ: aloso | Lượt xem: 1667 | Lượt tải: 0download
Bạn đang xem trước 20 trang tài liệu Chuyên đề Xây dựng hệ thống thông tin quản lý nhân sự tại công ty cổ phần Thiên Minh, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
ng ban' RETURN ENDIF IF !FILE(sPath + "Luong" + RIGHT(STR(m.Year), 2) + ".DBF") _Fields = "Manv C(5)" FOR I = 1 TO 12 _Fields = _Fields + ", Hssp" + TRANS(I, "@L ##") + " N(5,2)" _Fields = _Fields + ", L_sp" + TRANS(I, "@L ##") + " N(5,2)" _Fields = _Fields + ", L_phep" + TRANS(I, "@L ##") + " N(5,2)" _Fields = _Fields + ", L_khac" + TRANS(I, "@L ##") + " N(5,2)" ENDFOR CREATE TABLE (sPath + "Luong" + RIGHT(STR(m.Year), 2)) (&_Fields) INDEX ON Manv TAG Manv USE ENDIF SELECT 0 USE (sPath + "Luong" + RIGHT(STR(m.Year), 2)) ORDER Manv ALIAS Luong SELECT 0 USE (sPath + "LLNV") ORDER Manv ALIAS LLNV NOUPDATE SELECT 0 USE (sPath + "Hopdong") ORDER Manv ALIAS Hopdong NOUPDATE SELECT 0 USE (sPath + "Macv") ORDER Macv ALIAS Macv NOUPDATE SELECT Manv ; FROM LLNV ; WHERE Manv NOT IN (SELECT Manv FROM Luong) ; INTO TABLE (sTmp + "tAdd_Manv") USE IN tAdd_Manv SELECT Luong IF _TALLY#0 APPE FROM (sTmp + "tAdd_Manv") ENDIF DELETE ; FROM Luong WHERE Manv NOT IN (SELECT Manv FROM LLNV) SET PROC TO smLib DO Window _Hssp = "Hssp" +TRANS(m.Thang, "@L ##") _L_sp = "L_sp" +TRANS(m.Thang, "@L ##") _L_phep = "L_phep"+TRANS(m.Thang, "@L ##") _L_khac = "L_khac"+TRANS(m.Thang, "@L ##") SELECT ; SPACE(1) AS Tag, ; Manv, ; LLNV.Ten AS Ten, ; LLNV.Ho+LLNV.Ten AS Tennv, ; Hopdong.Macv AS Macv, ; Macv.Diengiai AS Chucvu, ; &_Hssp AS Hssp, ; &_L_sp AS L_sp, ; &_L_phep AS L_phep, ; &_L_khac AS L_khac ; FROM Luong ; WHERE Manv IN (SELECT Manv FROM LLNV WHERE ALLT(Madv)=ALLT(m.Madv)) ; INTO TABLE (sTmp + "tLuongtmp") SET RELATION TO Manv INTO LLNV SET RELATION TO Manv INTO Hopdong ADDI REPLACE ALL ; Ten WITH LLNV.Ten, ; Tennv WITH ALLT(LLNV.Ho)+" " + ALLT(LLNV.Ten), ; Macv WITH Hopdong.Macv SET RELATION TO Macv INTO Macv REPLACE ALL Chucvu WITH Macv->Diengiai SET RELATION TO INDEX ON Manv TAG Manv INDEX ON Macv+UPPER(ALLT(Ten)) TAG Stt GOTO TOP ON KEY LABEL SPACEBAR DO k_Tag ON KEY LABEL CTRL+A DO k_TagAll ON KEY LABEL CTRL+U DO k_TagUn ON KEY LABEL F3 DO Sua WITH VARREAD() ON KEY LABEL F4 DO Copy_hssp sDynamicBackColor="IIF(EMPTY(Tag), 16777215, 16771538)" BROWSE ; FIELDS; Tag, ; Manv :H="Ma nv", ; Tennv :H="Ten nhan vien", ; Chucvu:18:H="Chuc vu", ; Hssp :P="@Z 99.99", ; L_sp :H="Cong sp" :P="@Z 99.99", ; L_phep:H="Cong phep":P="@Z 99.99", ; L_khac:H="Cong nghi":P="@Z 99.99", ; L_tg=L_sp+L_phep+L_khac :H="Cong tgian" :P="@Z 99.99" ; NAME oBrowse ; NOAPPEND NODELETE NOMODIFY ; WHEN Change_Color_Of_Browse(RECNO(), sDynamicBackColor); WINDOW M_WinBrw; TITLE "Cham cong thang " + TRANS(m.Thang) + " – BP: " + Cat_dau(ALLT(m.Tendv)) + ". SPACEBAR/^+A/^+U- Danh dau/Chon tat/Huy chon, F3-Sua, F4-Copy hssp, Esc-Quay ra" *!* *!* NAME oBrowse; *!* NOAPPEND NOMODIFY NODELETE ; *!* WHEN ChangeColor(RECNO()); *!* WINDOW M_WinBrw ; *!* FONT M_Font, M_FntSize -2; *!* TITLE M_Prompt + [. F3-Sua, F4-Them, F8-Xoa, ^F/G-Tim, Esc-Quay ra]; ON KEY LABEL F4 ON KEY LABEL F3 ON KEY LABEL SPACEBAR ON KEY LABEL CTRL+A ON KEY LABEL CTRL+U DO Rel_Window *+Update vao file goc SELECT tLuongTmp SET ORDER TO Manv SELECT Luong SET RELATION TO Manv INTO tLuongTmp sReplace = "Hssp"+TRANS(m.Thang, "@L ##") + " WITH tLuongTmp->Hssp" sReplace = sReplace + ", L_sp" +TRANS(m.Thang, "@L ##")+" WITH tLuongTmp->L_sp" sReplace = sReplace + ", L_phep"+TRANS(m.Thang, "@L ##") +" WITH tLuongTmp->L_phep" sReplace = sReplace + ", L_khac"+TRANS(m.Thang, "@L ##") +" WITH tLuongTmp->L_khac" sReplace = sReplace + " FOR Manv = tLuongTmp->Manv" REPLACE &sReplace USE IN Luong USE IN LLNV USE IN Hopdong USE IN Macv USE IN tLuongtmp DELETE FILE (sTmp + "tAdd_Manv.*") DELETE FILE (sTmp + "tLuongtmp.*") SELECT(curSelect) RETURN ENDPROC *!* Cham cong PROCEDURE Sua PARAMETER _FieldVar PRIVATE curRec, nRec, m.Nhan_huy curRec = RECNO() STORE 0 TO nRec COUNT TO nRec FOR !EMPTY(Tag) IF curRec <= RECCOUNT() GOTO curRec ENDIF IF nRec = 0 =Messagebox("Phai danh dau truoc khi sua!", 61, "Note") RETURN ENDIF STORE .T. TO _Lock1, _Lock2, _Lock3, _Lock4 DO CASE CASE UPPER(ALLT(_FieldVar)) == [L_SP] STORE .F. TO _Lock2, _Lock3, _Lock4 CASE UPPER(ALLT(_FieldVar)) == [L_PHEP] STORE .F. TO _Lock1, _Lock3, _Lock4 CASE UPPER(ALLT(_FieldVar)) == [L_KHAC] STORE .F. TO _Lock1, _Lock2, _Lock4 CASE UPPER(ALLT(_FieldVar)) == [HSSP] STORE .F. TO _Lock1, _Lock2, _Lock3 OTHERWISE ENDCASE m.Nhan_huy = 1 SCAT MEMV PUSH KEY CLEAR DO FORM Luong-f3 POP KEY IF LASTKEY()=27 OR m.Nhan_huy # 1 RETURN ENDIF SELECT tLuongtmp DO CASE CASE UPPER(ALLT(_FieldVar)) == [L_SP] REPLACE ALL ; Tag WITH "", ; L_sp WITH m.L_sp ; FOR !EMPTY(Tag) CASE UPPER(ALLT(_FieldVar)) == [L_PHEP] REPLACE ALL ; Tag WITH "", ; L_phep WITH m.L_phep ; FOR !EMPTY(Tag) CASE UPPER(ALLT(_FieldVar)) == [L_KHAC] REPLACE ALL ; Tag WITH "", ; L_khac WITH m.L_khac ; FOR !EMPTY(Tag) CASE UPPER(ALLT(_FieldVar)) == [HSSP] REPLACE ALL ; Tag WITH "", ; Hssp WITH m.Hssp ; FOR !EMPTY(Tag) OTHERWISE REPLACE ALL ; Tag WITH "", ; Hssp WITH m.Hssp, ; L_sp WITH m.L_sp, ; L_phep WITH m.L_phep, ; L_khac WITH m.L_khac ; FOR !EMPTY(Tag) ENDCASE GOTO curRec RETURN *!*---------------------------------------------------- *!* Thu tuc Copy he so sp tu thang truoc sang thang nay *!*---------------------------------------------------- PROCEDURE Copy_hssp PRIVATE curSelect, curRec _CoKhong = Messagebox("Copy he so san pham tu thang truoc sang?", 289, "Note") IF _CoKhong = 2 RETURN ENDIF curSelect = SELECT() curRec = RECNO() IF m.Thang = 1 IF !FILE(sPath + "Luong" + RIGHT(STR(m.Year-1), 2) + ".DBF") RETURN ENDIF USE (sPath + "Luong" + RIGHT(STR(m.Year-1), 2)) ALIAS Luong0 IN 0 NOUP SELECT Manv, Hssp12 AS Hssp; FROM Luong0 ; WHERE Manv IN (SELECT Manv FROM tLuongtmp) AND Hssp12#0 ; INTO CURS tHssp INDEX ON Manv TAG Manv USE IN Luong0 ELSE _Hssp0 = "Hssp" +TRANS(m.Thang-1, "@L ##") SELECT Manv, &_Hssp0 AS Hssp; FROM Luong ; WHERE Manv IN (SELECT Manv FROM tLuongtmp) AND &_Hssp0#0 ; INTO CURS tHssp INDEX ON Manv TAG Manv ENDIF SELECT tLuongtmp SET RELATION TO Manv INTO tHssp REPLACE ALL Hssp WITH tHssp.Hssp FOR Manv==tHssp.Manv SET RELATION TO USE IN tHssp SELECT(curSelect) IF curRec<=RECCOUNT() GOTO curRec ENDIF RETURN --------------------------- File:Luong-in.PRG *!* ------------------------------------------------------------ *!* Chuong trinh in bang luong *!* Nguoi viet: Hong Tu *!* Ngay viet: 17-06-2003 *!* ------------------------------------------------------------- PRIVATE curSelect, sPath, sTmp, sRpt, m.Nhan_huy, m.Thang, m.Year CLOS DATA curSelect = SELECT() sPath = PATH_HUMAN+"\Data\" sTmp = PATH_HUMAN+"\Text\" sRpt = PATH_HUMAN+"\Repo\" SET PROC TO smLib DO Window SELECT 0 USE (sPath + "Luong-in") ALIAS aLuong SELECT 0 USE (sPath + "Bophan") ORDER Madv ALIAS Bophan STORE MONTH(DATE()) TO m.Thang STORE YEAR(DATE()) TO m.Year m.Madv = "" m.Nhan_huy = 1 ON KEY LABEL F3 DO Khai_bao DO FORM Luong-in ON KEY LABEL F3 m.Tendv = IIF(SEEK(m.Madv, "Bophan"), Bophan.Tenbp, "") _Key = ".T." IF !EMPTY(m.Madv) _Key = "ALLT(Madv)=ALLT(m.Madv)" ENDIF IF LASTKEY() = 27 OR m.Nhan_huy = 0 USE IN Bophan USE IN aLuong SELECT(curSelect) DO Rel_Window RETURN ENDIF IF !FILE(sPath + "Luong" + RIGHT(STR(m.Year), 2) + ".DBF") WAIT WIND NOWA 'Chua cap nhat bang cham cong trong thang!' USE IN Bophan USE IN aLuong DO Rel_Window RETURN ENDIF *+Lay cac bien khai bao san trong file mau SELECT aLuong GO TOP SCAN _Bien = ALLT(Bien) PRIVATE &_Bien STORE aLuong.Gia_tri TO &_Bien ENDS USE IN aLuong SELECT 0 USE (sPath + "Luong" + RIGHT(STR(m.Year), 2)) ORDER Manv ALIAS Luong SELECT 0 USE (sPath + "LLNV") ORDER Manv ALIAS LLNV NOUPDATE SELECT 0 USE (sPath + "Hopdong") ORDER Manv ALIAS Hopdong NOUPDATE SELECT 0 USE (sPath + "Macv") ORDER Macv ALIAS Macv NOUPDATE _Hssp = "Hssp" +TRANS(m.Thang, "@L ##") _L_sp = "L_sp" +TRANS(m.Thang, "@L ##") _L_phep = "L_phep"+TRANS(m.Thang, "@L ##") _L_khac = "L_khac"+TRANS(m.Thang, "@L ##") _p_Tien = "999999999999" SELECT ; SPACE(5) AS Stt, ; Manv, ; LLNV.Ten AS Ten, ; LLNV.Ho+LLNV.Ten AS Tennv, ; LLNV.Madv AS Madv, ; Hopdong.Macv AS Macv, ; Macv.Diengiai AS Chucvu, ; Hopdong.Hs_lc AS Hs_lc, ; Hopdong.Hs_cv AS Hs_cv, ; Hopdong.Luonghd AS Luonghd, ; &_Hssp AS Hssp, ; &_L_sp AS L_sp, ; &_L_phep AS L_phep, ; &_L_khac AS L_khac, ; &_p_Tien AS Luongcd, ; &_p_Tien AS Luongtg, ; &_p_Tien AS Luongtg1, ; &_p_Tien AS Luongsp, ; &_p_Tien AS Luongsp1, ; &_p_Tien AS Tinh_trich ; FROM Luong ; WHERE Manv IN (SELECT Manv FROM LLNV WHERE &_Key) ; INTO TABLE (sTmp + "tLuongtmp") SET RELATION TO Manv INTO LLNV SET RELATION TO Manv INTO Hopdong ADDI REPLACE ALL ; Ten WITH LLNV.Ten, ; Tennv WITH ALLT(LLNV.Ho)+" " + ALLT(LLNV.Ten), ; Madv WITH LLNV.Madv, ; Macv WITH Hopdong.Macv, ; Hs_lc WITH Hopdong.Hs_lc, ; Hs_cv WITH Hopdong.Hs_cv, ; Luonghd WITH Hopdong.Luonghd SET RELATION TO Macv INTO Macv REPLACE ALL Chucvu WITH Macv->Diengiai SET RELATION TO *+Tinh luong: &&Tien luong che do hang thang REPLACE ALL ; Luongcd WITH ROUND(Luonghd*(Hs_lc+Hs_cv), m_Round), ; Tinh_trich WITH ROUND(Luonghd*(Hs_lc+IIF(Hs_cv<=0.1,0,Hs_cv))*m_Tinh_trich/100, m_Round) &&Tien luong lam theo thoi gian IF m_L_tg # 0 REPLACE ALL ; Luongtg WITH ROUND((L_sp+L_phep+L_khac)*Luongcd/m_L_tg, m_Round) ENDIF &&Tien luong lam theo san pham IF m_L_sp # 0 REPLACE ALL ; Luongsp WITH ROUND(L_sp*(Hssp*m_Gia_hssp)/m_L_sp, m_Round) ENDIF &&Lam tron tien luong den hang ngan IF m_Round_Luong # 0 REPLACE ALL ; Luongtg1 WITH m_Round_Luong*ROUND(Luongtg/m_Round_Luong, m_Round), ; Luongsp1 WITH m_Round_Luong*ROUND(Luongsp/m_Round_Luong, m_Round), ; Tinh_trich WITH m_Round_Luong*ROUND(Tinh_trich/m_Round_Luong, m_Round) ELSE REPLACE ALL ; Luongtg1 WITH Luongtg, Luongsp1 WITH Luongsp ENDIF *+ Tinh tong luong theo tung bo phan INDEX ON Madv TAG Madv TOTAL ON Madv TO (sTmp+"tTotal") SELECT 0 USE (sTmp+"tTotal") SET RELATION TO Madv INTO Bophan REPLACE ALL ; Stt WITH "", ; Tennv WITH SPACE(5)+ALLT(Bophan->Tenbp) SET RELATION TO *+ Xap xep bang luong theo tung phong ban+chuc vu SELECT tLuongtmp COPY STRUC TO (sTmp+"tLuongtmp2") SELECT 0 USE (sTmp+"tLuongtmp2") ALIAS tLuong SELECT tTotal SCAN FOR LuongTg1+Luongsp1>0 SCAT MEMV FIELDS ; Madv,Tennv,L_sp,L_phep,L_khac,Luongtg,Luongtg1,Luongsp,Luongsp1,Tinh_trich SELECT tLuong APPE BLANK GATHER MEMV SELECT * ; FROM tLuongtmp ; WHERE Madv = ALLT(m.Madv) AND LuongTg1+Luongsp1>0; ORDE BY Macv, Ten ; INTO TABLE (sTmp+"tL_bp") REPLACE ALL Stt WITH TRANS(RECNO()) USE IN tL_bp SELECT tLuong APPE FROM (sTmp+"tL_bp") APPEN BLANK DELETE FILE (sTmp + "tL_bp.*") SELECT tTotal ENDS USE IN tTotal USE IN Luong USE IN LLNV USE IN Hopdong USE IN Macv USE IN Bophan USE IN tLuongtmp SELECT tLuong GOTO BOTT DELETE GOTO TOP ON KEY LABEL F7 DO Print BROWSE ; FIELDS; Stt, ; Tennv :H="Ten nhan vien", ; Chucvu :H="Chuc vu":18, ; Hs_lc :H="Hslcb":P="@Z 999.99", ; Hs_cv :H="Hstn":P="@Z 999.99", ; Luongcd :H="Luong che do":P="@Z 999 999 999", ; L_tg=L_sp+L_phep+L_khac :H="Cong tg" :P="@Z 999.99", ; Luongtg :P="@Z 999 999 999", ; Luongtg1 :H="Luong tgian":P="@Z 999 999 999", ; Hssp :P="@Z 999.99", ; L_sp :H="Cong sp" :P="@Z 999.99", ; Luongsp :P="@Z 999 999 999", ; Luongsp1 :H="Luong sp":P="@Z 999 999 999", ; Tinh_trich:H="BHXH+YT":P="@Z 999 999 999", ; Cong_luong=Luongtg1+Luongsp1-Tinh_trich:H=[Tong luong]:P="@Z 999 999 999" ; NAME oBrowse NOWA; NOAPPEND NODELETE NOMODIFY ; WHEN Change_Color_Of_Browse(RECNO()); WINDOW M_WinBrw; TITLE "Bang tinh luong thang " + TRANS(m.Thang) + " nam " + STR(m.Year,4) + ". F7-In, Esc-Quay ra" oBrowse.SetAll("DynamicFontBold", "EMPTY(Stt) AND !EMPTY(Tennv)", "Column") oBrowse.SetAll("DynamicForeColor", "IIF(EMPTY(Stt) AND !EMPTY(Tennv),10485760,0)", "Column") BROWSE LAST ON KEY LABEL F7 USE IN tLuong DO Rel_Window DELETE FILE (sTmp + "tLuongtmp.*") DELETE FILE (sTmp + "tLuongtmp2.*") DELETE FILE (sTmp + "tTotal.*") SELECT(curSelect) RETURN ENDPROC *!*---------------------------- *!*Khai bao file Mau tinh luong *!*---------------------------- PROCEDURE Khai_bao PRIVATE curSelect curSelect=SELECT() PUSH KEY CLEAR SELECT aLuong BROWSE ; FIELDS ; Dien_giai: R,; Gia_tri:F:P=[@Z 999 999 999.99]; NAME oBrowse ; NOAP NODE ; WHEN Change_Color_Of_Browse(RECNO()) ; WINDOW m_WinBrw ; TITLE "Khai bao cac chi tieu tinh luong. ESC-Thoat" POP KEY SELECT(curSelect) RETURN *!*----------------------------- *!*In bao cao luong *!*----------------------------- PROCEDURE Print DO CASE CASE m.Nhan_huy = 2 &&In REPORT FORM (sRpt + "Luong-in") TO PRINT PROMPT NOCONSOLE CASE m.Nhan_huy = 1 &&View MODIFY WINDOW m_WinBrw TITLE "Bang tinh luong thang " + TRANS(m.Thang) + " nam " + STR(m.Year,4) + ". Esc - Quay ra" MOVE WINDOW m_WinBrw CENTER KEYB "{CTRL+F10}" REPORT FORM (sRpt + "Luong-in") PREVIEW WINDOW m_WinBrw ENDCASE RETURN ------------------------------ File:main.prg *!* Ngui Viet: Hong Tu. SET TALK OFF CLEAR SET STATUS BAR ON ON KEY CLOSE ALL DO HideToolBar SET SYSMENU TO SET SYSMENU AUTOMATIC *!* SET CENTURY ON *!* SET CLOCK STATUS *!* SET ESCAPE OFF *!* SET EXCLUSIVE OFF *!* SET EXACT OFF *!* SET DATE TO FRENCH *!* SET SAFETY OFF *!* SET STATUS OFF *!* SET HEADING OFF *!* SET REPROCESS TO -1 *!* SET REFRESH TO 1, 1 *!* SET SCOREBOARD OFF *!* SET MULTILOCKS ON *!* SET STATUS BAR OFF *!* SET TALK OFF *!* SET HOURS TO 24 *!* SET DELETED ON *!* Clear WINDOW *!* Clear ALL *!* ON ERROR *!* RELEASE PAD _MTable OF _MSYSMENU *!* RELEASE PAD _MEdit OF _MSYSMENU *!* RELEASE PAD _MFile OF _MSYSMENU *!* RELEASE PAD _MView OF _MSYSMENU *!* RELEASE PAD _MSM_WINDO OF _MSYSMENU *!* RELEASE PAD _MSM_FORMAT OF _MSYSMENU *!* RELEASE PAD _MSM_TOOLS OF _MSYSMENU *!* RELEASE PAD _MSM_PROG OF _MSYSMENU *!* RELEASE PAD _MSM_SYSTM OF _MSYSMENU *!* RELEASE PAD _MSM_TEXT OF _MSYSMENU ****************** Source='\OutSourcing' ****************** _Path = SYS(5)+SYS(2003) _Path = LEFT(_Path,LEN(_Path)-7) PATH_SYS = _Path+'system' PATH_HUMAN = _Path PRE_DIR = PATH_HUMAN USE &PATH_SYS.\maincode STORE CODEPRO TO CODEPROVINCE STORE CODEHOSP TO CODEHOSPITAL STORE benhvien TO Mbenhvien STORE ALLTRIM(LOAIBV) TO MLOAIBV STORE DIENTHOAI TO MDIENTHOAI STORE SOYTE TO MSOYTE USE _TITLE = 'Quan ly nhan su' _ADDRESS = '' _TELE = MDIENTHOAI _HTL_LOOP = .T. ****************************** m_ScrRow = SROW() m_ScrCol = SCOL() m_Font_Name = 'Vn-Sans-Serif' m_Font_Size = 10 _SCREEN.ICON = PATH_HUMAN +'picture\ICON01.ico' _SCREEN.CLOSABLE = .T. _SCREEN.CAPTION = 'Quan ly nhan su' _SCREEN.PICTURE = PATH_HUMAN+'picture\nhansu.jpg' _SCREEN.WINDOWSTATE = 2 SET DEFAULT TO &PATH_HUMAN.\program SET PROC TO smLib Show WINDOW ALL DO LOGIN DO PATH_HUMAN+'PROGRAM\menuns' ON KEY LABEL ALT+Q DO Squit1 *!* DO DONG_BAR *!* DO PHIM *!* DO WHILE (_HTL_LOOP) *!* DO HT_DATE *!* IF LEN(MENU())=0 *!* DO MENUNS *!* ENDIF *!* ENDDO *!* SET SYSMENU TO DEFAULT *!* _SCREEN.BACKCOLOR = RGB(255, 255, 255) *!* _SCREEN.PICTURE = "" *!* Clear *!* CLOSE DATABASES *!* QUIT *!* RETURN *!* *!* ENDPROC PROCEDURE LOGIN RETPASS = .F. DO FORM PATH_HUMAN+'PROGRAM\fuser' IF .NOT. RETPASS QUIT ENDIF Release RETPASS RETURN ENDPROC ********************************************************* FUNCTION HideToolBar *-- Releases all Visual FoxPro toolbars LOCAL i TB_FORMDESIGNER_LOC = "Form Designer" TB_STANDARD_LOC = "Standard" TB_LAYOUT_LOC = "Layout" TB_QUERY_LOC = "Query Designer" TB_VIEWDESIGNER_LOC = "View Designer" TB_COLORPALETTE_LOC = "Color Palette" TB_FORMCONTROLS_LOC = "Form Controls" TB_DATADESIGNER_LOC = "Database Designer" TB_REPODESIGNER_LOC = "Report Designer" TB_REPOCONTROLS_LOC = "Report Controls" TB_PRINTPREVIEW_LOC = "Print Preview" WIN_COMMAND_LOC = "Command" && Command Window WIN_PROJECT_MAN = "Project Manager" DIMENSION aToolBars [13,2] aToolBars[1,1] = TB_FORMDESIGNER_LOC aToolBars[2,1] = TB_STANDARD_LOC aToolBars[3,1] = TB_LAYOUT_LOC aToolBars[4,1] = TB_QUERY_LOC aToolBars[5,1] = TB_VIEWDESIGNER_LOC aToolBars[6,1] = TB_COLORPALETTE_LOC aToolBars[7,1] = TB_FORMCONTROLS_LOC aToolBars[8,1] = TB_DATADESIGNER_LOC aToolBars[9,1] = TB_REPODESIGNER_LOC aToolBars[10,1] = TB_REPOCONTROLS_LOC aToolBars[11,1] = TB_PRINTPREVIEW_LOC aToolBars[12,1] = WIN_COMMAND_LOC aToolBars[13,1] = WIN_PROJECT_MAN FOR i = 1 TO ALEN(aToolBars, 1) aToolBars[i,2] = WVISIBLE(aToolBars[i,1]) IF aToolBars[i,2] HIDE WINDOW (aToolBars[i,1]) ENDIF ENDFOR Return PROC RE_FOX IF FILE("RESET.PRG") DO RESET ENDIF RETURN FUNCTION Squit1 _SCREEN.BACKCOLOR=RGB(255,255,255) CLEAR EVENTS IF FILE("RESET.PRG") DO RESET ENDIF RETURN ----------------------------------- File:menuns.prg *!* Ngoi Viet:Hong Tu. _MEXIT = .F. SET SYSMENU TO SET SYSMENU AUTOMATIC DO WHILE .NOT. _MEXIT DEFINE PAD HUMAN OF _MSYSMENU PROMPT "\<A. Can bo" KEY ALT+A, "" COLOR SCHEME 3 DEFINE PAD PAYROLL OF _MSYSMENU PROMPT "\<B. Lao dong - Tien luong" KEY ALT+C, "" COLOR SCHEME 3 DEFINE PAD TRUYVAN OF _MSYSMENU PROMPT "\<C. Truy van" KEY ALT+B, "" COLOR SCHEME 3 DEFINE PAD HETHONG OF _MSYSMENU PROMPT "\<D. He thong" KEY ALT+D, "" COLOR SCHEME 3 ON PAD HUMAN OF _MSYSMENU ACTIVATE POPUP _HUMAN ON PAD TRUYVAN OF _MSYSMENU ACTIVATE POPUP _TRUYVAN ON PAD PAYROLL OF _MSYSMENU ACTIVATE POPUP _PAYROLL ON PAD HETHONG OF _MSYSMENU ACTIVATE POPUP _HETHONG DEFINE POPUP _HUMAN SHADOW MARGIN RELATIVE COLOR SCHEME 4 ****************** DEFINE BAR 1 OF _HUMAN PROMPT "\<1. Ly lich nhan vien" DEFINE BAR 2 OF _HUMAN PROMPT "\-" DEFINE BAR 3 OF _HUMAN PROMPT "\<2. In ly lich" DEFINE BAR 4 OF _HUMAN PROMPT "\<3. In ly lich trich ngang" * DEFINE BAR 5 OF _HUMAN PROMPT "\<4. In lý lịch, quá trình đào tạo, gia cảnh" DEFINE BAR 6 OF _HUMAN PROMPT "\-" DEFINE BAR 7 OF _HUMAN PROMPT "\<5. Danh sach cong nhan vien" DEFINE BAR 8 OF _HUMAN PROMPT "\<6. Danh sach con cai CB-CNV" DEFINE BAR 9 OF _HUMAN PROMPT "\<7. Qua trinh cong tac" DEFINE BAR 10 OF _HUMAN PROMPT "\<8. Danh sach nhan vien moi nghi viec" *!* DEFINE BAR 11 OF _HUMAN PROMPT "\<9. Thống kê nhân sự" ON SELECTION BAR 1 OF _HUMAN DO FORM FLLNV ON SELECTION BAR 3 OF _HUMAN DO FORM LYLICH ON SELECTION BAR 4 OF _HUMAN DO FORM LLTN * ON SELECTION BAR 5 OF _HUMAN DO FORM B_GROUND ON SELECTION BAR 7 OF _HUMAN DO FORM DSNV ON SELECTION BAR 8 OF _HUMAN DO FORM NS133 ON SELECTION BAR 9 OF _HUMAN DO FORM NS132 ON SELECTION BAR 10 OF _HUMAN DO FORM NVMOI *!* ON SELECTION BAR 11 OF _HUMAN DO FORM NS131 ****************** DEFINE POPUP _PAYROLL SHADOW MARGIN RELATIVE COLOR SCHEME 4 DEFINE BAR 1 OF _PAYROLL PROMPT "\<1. Bang cham cong CB - CNV hang thang" DEFINE BAR 2 OF _PAYROLL PROMPT "\<2. Bang tinh luong CB - CNV hang thang" DEFINE BAR 3 OF _PAYROLL PROMPT "\-" DEFINE BAR 4 OF _PAYROLL PROMPT "\<3. Danh sach lao dong cap so BHXH" DEFINE BAR 5 OF _PAYROLL PROMPT "\<4. Danh sach CB - CNV de nghi nang luong" DEFINE BAR 6 OF _PAYROLL PROMPT "\<5. Thong ke lao dong tien luong" ON SELECTION BAR 1 OF _PAYROLL DO Luong_nv ON SELECTION BAR 2 OF _PAYROLL DO Luong-in ON SELECTION BAR 4 OF _PAYROLL DO FORM LD244 ON SELECTION BAR 5 OF _PAYROLL DO FORM LD2471 ON SELECTION BAR 6 OF _PAYROLL DO FORM LD249 ****************** DEFINE POPUP _TRUYVAN SHADOW MARGIN RELATIVE COLOR SCHEME 4 DEFINE BAR 1 OF _TRUYVAN PROMPT "\<1. Do tuoi trung binh" DEFINE BAR 2 OF _TRUYVAN PROMPT "\<2. Muc luong binh quan" DEFINE BAR 3 OF _TRUYVAN PROMPT "\<3. Thong ke tinh trang gia dinh" DEFINE BAR 4 OF _TRUYVAN PROMPT "\<4. Tinh hinh cong viec" DEFINE BAR 5 OF _TRUYVAN PROMPT "\<5. Nghe nghiep dao tao" DEFINE BAR 6 OF _TRUYVAN PROMPT "\<6. Gia canh" DEFINE BAR 7 OF _TRUYVAN PROMPT "\<7. Di nuoc ngoai" ON SELECTION BAR 1 OF _TRUYVAN DO FORM NS127 ON SELECTION BAR 2 OF _TRUYVAN DO FORM NS128 ON SELECTION BAR 3 OF _TRUYVAN DO FORM NS129 ON SELECTION BAR 4 OF _TRUYVAN DO FORM NS121 ON SELECTION BAR 5 OF _TRUYVAN DO FORM NS122 ON SELECTION BAR 6 OF _TRUYVAN DO FORM NS124 ON SELECTION BAR 7 OF _TRUYVAN DO FORM NS126 ****************** DEFINE POPUP _HETHONG SHADOW MARGIN RELATIVE COLOR SCHEME 4 DEFINE BAR 1 OF _HETHONG PROMPT "\<1. Cai dat font chu" * DEFINE BAR 1 OF _HETHONG PROMPT "\<1. Danh muc" DEFINE BAR 2 OF _HETHONG PROMPT "\<2. Danh muc cac tinh, thanh pho" DEFINE BAR 3 OF _HETHONG PROMPT "\<3. Ma ngach cong chuc" DEFINE BAR 4 OF _HETHONG PROMPT "\-" DEFINE BAR 5 OF _HETHONG PROMPT "\<4. Quan ly mat khau" DEFINE BAR 6 OF _HETHONG PROMPT "\-" DEFINE BAR 7 OF _HETHONG PROMPT "\<5. Bao tri va backup so lieu" DEFINE BAR 8 OF _HETHONG PROMPT "\-" DEFINE BAR 9 OF _HETHONG PROMPT "\<6. Ket thuc" _pIs = PATH_HUMAN + [font\] ON SELECTION BAR 1 OF _HETHONG DO InstFont WITH _pIs IN installfont ON SELECTION BAR 2 OF _HETHONG DO Btd ON SELECTION BAR 3 OF _HETHONG DO FORM FMANGACH ON SELECTION BAR 5 OF _HETHONG DO PRGMS ON SELECTION BAR 7 OF _HETHONG DO Backup ON SELECTION BAR 9 OF _HETHONG DO HT_EXIT ACTIVATE MENU _MSYSMENU ENDDO ENDPROC -------------------------------- File:prgms.prg CLOSE TABLE ALL PASSWORD = PATH_HUMAN+'\data\PWHUMAN.DBF' DBF_TEMP = SYS(2023)+'\'+RIGHT(SYS(2015), 8)+'.DBF' PRIVATE MUSR_NAME, J, PSW1, PSW2, MRECNO STORE '' TO MUSR_NAME, PSW1, PSW2, MPOS STORE 0 TO J, MRECNO IF .NOT. FILE(PASSWORD) CREATE TABLE (PASSWORD) (USER_NAME C (40), PASSWORD C (30), CHUCDANH C (30)) USE ENDIF SELECT 0 USE (PASSWORD) ALIAS PASSWORD COPY TO (DBF_TEMP) STRUCTURE SELECT 0 USE (DBF_TEMP) ALIAS TEMP DO READ_PSW FRMPW = CREATEOBJECT('PSW_IN') FRMPW.SHOW(1) CLOSE TABLE ALL ERASE (DBF_TEMP) RETURN ENDPROC DEFINE CLASS psw_in AS FORM SCALEMODE = 0 HEIGHT = 12 WIDTH = 70 ICON = Path_human + 'Picture\User' BACKCOLOR = RGB(192, 192, 192) BORDERSTYLE = 2 WINDOWTYPE = 1 AUTOCENTER = .T. SHOWTIPS = .T. CONTROLBOX = .F. USER_NAME = '' ADD OBJECT LBLNAME AS LABEL WITH FONTNAME = '.VnAvant', TOP = 2.25, LEFT = 2, HEIGHT = 1.2, WIDTH = 15.0, BACKCOLOR = RGB(192, 192, 192), FORECOLOR = RGB(0, 0, 160) ADD OBJECT CBOUSR_NAME AS COMBOBOX WITH TOP = 2, LEFT = 19.0, HEIGHT = 1.7, WIDTH = 25.0, INPUTMASK = 'XXXXXXXXXXXXXXX', FONTNAME = '.VnAvant', FONTSIZE = 9, COLUMNCOUNT = 1, COLUMNWIDTHS = '12', FIRSTELEMENT = 1, STYLE = 2, ROWSOURCETYPE = 2, ROWSOURCE = 'USER_NAME.USER_NAME', CONTROLSOURCE = 'USER_NAME' ADD OBJECT CMDHIEUCHINH AS COMMANDBUTTON WITH FONTNAME = '.VnAvant', TOP = 1, LEFT = 50, HEIGHT = 1.8, WIDTH = 15, BACKCOLOR = RGB(192, 192, 192), FORECOLOR = RGB(0, 0, 160) * PROCEDURE cmdHIEUCHINH.click LOCAL FRMCHANGE FRMCHANGE = CREATEOBJECT('EDIT_FRM') FRMCHANGE.BORDERSTYLE = 2 FRMCHANGE.SHOW(1) IF PSW1=PSW2 .AND. FREPEAT REPLACE PASSWORD WITH PSW2 THISFORM.REFRESH ELSE WAIT WINDOW TIMEOUT 0.5 'Mat khau khong thay doi !' ENDIF RELEASE EDIT_FRM THISFORM.REFRESH ENDPROC ADD OBJECT CMDTHEM AS COMMANDBUTTON WITH FONTNAME = '.VnAvant', TOP = 3, LEFT = 50, HEIGHT = 1.8, WIDTH = 15, BACKCOLOR = RGB(192, 192, 192), FORECOLOR = RGB(0, 0, 160) *------------------------------------------------------------------------------------- PROCEDURE cmdTHEM.Click LOCAL FRMADD FRMADD = CREATEOBJECT('ADD_FRM') FRMADD.SHOW(1) IF PSW1=PSW2 .AND. .NOT. EMPTY(MUSR_NAME) SELECT USER_NAME APPEND BLANK REPLACE USER_NAME WITH MUSR_NAME, PASSWORD WITH PSW2, CHUCDANH WITH MPOS ELSE WAIT WINDOW TIMEOUT 0.5 'Khong the them' ENDIF RELEASE ADD_FRM THISFORM.REFRESH THISFORM.CBOUSR_NAME.REFRESH ENDPROC ADD OBJECT CMDXOA AS COMMANDBUTTON WITH FONTNAME = '.VnAvant', TOP = 5, LEFT = 50, HEIGHT = 1.8, WIDTH = 15, BACKCOLOR = RGB(192, 192, 192), FORECOLOR = RGB(0, 0, 160) *------------------------------------------------------------------------------------- PROCEDURE cmdXOA.click LOCAL MREC, MRECLUU SELECT USER_NAME MRECLUU = RECNO() COUNT FOR .NOT. DELETED() TO MREC GOTO MRECLUU IF MREC>1 LOCAL FRMDELETE FRMDELETE = CREATEOBJECT('DEL_FRM') FRMDELETE.SHOW(1) RELEASE DEL_FRM THISFORM.REFRESH ELSE WAIT WINDOW TIMEOUT 0.5 'Khong cho phep huy !' ENDIF ENDPROC ADD OBJECT CMDDONGY AS COMMANDBUTTON WITH FONTNAME = '.VnAvant', TOP = 7, LEFT = 50, HEIGHT = 1.8, WIDTH = 15, BACKCOLOR = RGB(192, 192, 192), FORECOLOR = RGB(0, 0, 160), CANCEL = .T. *------------------------------------------------------------------------------------- PROCEDURE cmdDONGY.Click RELEASE THISFORM ENDPROC *------------------------------------------------------------------------------------- PROCEDURE load SELECT 0 USE (DBF_TEMP) ALIAS USER_NAME ENDPROC *------------------------------------------------------------------------------------- PROCEDURE init PUBLIC FREPEAT FREPEAT = .T. THIS.CAPTION = 'Quan ly mat khau' THIS.LBLNAME.CAPTION = 'Người dùng' THIS.CMDHIEUCHINH.CAPTION = '\<Sửa' THIS.CMDTHEM.CAPTION = '\<Thêm' THIS.CMDXOA.CAPTION = '\<Hủy' THIS.CMDDONGY.CAPTION = 'Th\<oát' ENDPROC PROCEDURE destroy USE IN USER_NAME DO UPD_PAS RELEASE FREPEAT ENDPROC ENDDEFINE *------------------------------------------------------------------------------------- DEFINE CLASS ASK_FRM AS FORM SCALEMODE = 0 MAXBUTTON = .F. MINBUTTON = .F. CONTROLBOX = .F. WINDOWTYPE = 1 ICON = Path_human + 'Picture\User' TOP = 2 LEFT = 2 HEIGHT = 4 WIDTH = 42 AUTOCENTER = .T. BACKCOLOR = RGB(192, 192, 192) BORDERSTYLE = 2 ENDDEFINE * DEFINE CLASS EDIT_FRM AS ASK_FRM ADD OBJECT TXTMATMA AS TEXTBOX WITH TOP = 1, LEFT = 22, HEIGHT = 1.6, WIDTH = 18, PASSWORDCHAR = '*' * PROCEDURE txtmatma.Valid IF UPPER(ALLTRIM(THISFORM.TXTMATMA.VALUE))==UPPER(ALLTRIM(USER_NAME.PASSWORD)) RELEASE THISFORM LOCAL FRMNEWPSW FRMNEWPSW = CREATEOBJECT('NEWPSW_FRM') FRMNEWPSW.SHOW(1) ELSE WAIT WINDOW TIMEOUT 0.5 'Mat khau khong thay doi ! ' FREPEAT = .F. RELEASE THISFORM ENDIF ENDPROC ADD OBJECT LBLTEN AS LABEL WITH FONTNAME = '.VnAvant', TOP = 1.25, LEFT = 0, HEIGHT = 1, WIDTH = 20, BACKCOLOR = RGB(192, 192, 192), FORECOLOR = RGB(0, 0, 160) * PROCEDURE init THIS.CAPTION = 'Thay doi mat khau' THIS.LBLTEN.CAPTION = 'Mật khẩu củ :' ENDPROC ENDDEFINE * DEFINE CLASS NEWPSW_FRM AS EDIT_FRM * PROCEDURE txtmatma.Valid PSW1 = UPPER(ALLTRIM(THISFORM.TXTMATMA.VALUE)) RELEASE THISFORM LOCAL FRMREPSW FRMREPSW = CREATEOBJECT('REPSW_FRM') FRMREPSW.SHOW(1) ENDPROC ADD OBJECT LBLTENMOI AS LABEL WITH FONTNAME = '.VnAvant', TOP = 1.25, LEFT = 0, HEIGHT = 1.25, WIDTH = 21, BACKCOLOR = RGB(192, 192, 192), FORECOLOR = RGB(0, 0, 160) * PROCEDURE init THIS.CAPTION = 'Mat khau moi' THIS.LBLTENMOI.CAPTION = 'Mật khẩu mới' ENDPROC ENDDEFINE *------------------------------------------------------------------------------------- DEFINE CLASS REPSW_FRM AS EDIT_FRM PROCEDURE INIT THISFORM.TXTMATMA.LEFT = 22 THISFORM.CAPTION = 'Lap lai mat khau' THISFORM.LBLTENLAI.CAPTION = 'Lập lại mật khẩu' ENDPROC *------------------------------------------------------------------------------------- PROCEDURE txtmatma.Valid PSW2 = UPPER(ALLTRIM(THISFORM.TXTMATMA.VALUE)) RELEASE THISFORM ENDPROC ADD OBJECT LBLTENLAI AS LABEL WITH FONTNAME = '.VnAvant', TOP = 1.25, LEFT = 0, HEIGHT = 1.25, WIDTH = 22, BACKCOLOR = RGB(192, 192, 192), FORECOLOR = RGB(0, 0, 160) ENDDEFINE *------------------------------------------------------------------------------------- DEFINE CLASS ADD_FRM AS PASS_FRM CONTROLBOX = .F. PROCEDURE txtNAME.Valid LOCATE FOR USER_NAME=THISFORM.TXTNAME.VALUE IF FOUND() RELEASE THISFORM ELSE MUSR_NAME = ALLTRIM(THISFORM.TXTNAME.VALUE) ENDIF ENDPROC *------------------------------------------------------------------------------------- PROCEDURE txtCODE.Valid PSW1 = UPPER(ALLTRIM(THISFORM.TXTCODE.VALUE)) ENDPROC *------------------------------------------------------------------------------------- PROCEDURE txtPOS.Valid MPOS = THISFORM.TXTPOS.VALUE LOCAL FRMREADDPSW FRMREADDPSW = CREATEOBJECT('READDPSW_FRM') FRMREADDPSW.SHOW(1) RELEASE THISFORM ENDPROC *------------------------------------------------------------------------------------- PROCEDURE init THIS.CAPTION = 'Them' THIS.LBLNAME.CAPTION = 'Người dùng :' THIS.LBLCODE.CAPTION = 'Mật khẩu :' THIS.LBLPOS.CAPTION = 'Chức danh:' ENDPROC ENDDEFINE *------------------------------------------------------------------------------------- DEFINE CLASS READDPSW_FRM AS PASS_FRM CONTROLBOX = .F. PROCEDURE init THIS.LBLCODE.CAPTION = 'Lập lại' THIS.LBLNAME.CAPTION = 'Người dùng :' THIS.CAPTION = 'Them' THIS.TXTCODE.TABINDEX = 1 THIS.TXTNAME.TABINDEX = 2 THIS.TXTNAME.VALUE = MUSR_NAME THIS.TXTPOS.VALUE = MPOS THIS.TXTNAME.ENABLED = .F. THIS.TXTPOS.ENABLED = .F. ENDPROC PROCEDURE txtCODE.Valid PSW2 = UPPER(ALLTRIM(THISFORM.TXTCODE.VALUE)) RELEASE THISFORM ENDPROC ENDDEFINE *------------------------------------------------------------------------------------- DEFINE CLASS DEL_FRM AS EDIT_FRM PROCEDURE init THIS.CAPTION = 'Huy' THIS.LBLTEN.CAPTION = 'Mật khẩu củ :' ENDPROC *------------------------------------------------------------------------------------- PROCEDURE txtmatma.Valid IF UPPER(ALLTRIM(THISFORM.TXTMATMA.VALUE))==UPPER(ALLTRIM(USER_NAME.PASSWORD)) SELECT USER_NAME DELETE GOTO TOP THISFORM.REFRESH WAIT WINDOW TIMEOUT 0.5 'Đã hủy !' ELSE WAIT WINDOW TIMEOUT 0.5 'Không thể hủy !' ENDIF RELEASE THISFORM ENDPROC ENDDEFINE *------------------------------------------------------------------------------------- DEFINE CLASS pass_frm AS FORM SCALEMODE = 0 MAXBUTTON = .F. MINBUTTON = .F. CONTROLBOX = .F. CLOSABLE = .F. HEIGHT = 10 WIDTH = 45 BACKCOLOR = RGB(192, 192, 192) BORDERSTYLE = 2 WINDOWTYPE = 1 AUTOCENTER = .T. SHOWTIPS = .T. *------------------------------------------------------------------------------------- PROCEDURE init THIS.CAPTION = 'Access level definition' THIS.LBLNAME.CAPTION = 'Người dùng :' THIS.LBLCODE.CAPTION = 'Mật khẩu :' THIS.LBLPOS.CAPTION = 'Chức danh:' ENDPROC ADD OBJECT TXTNAME AS TEXTBOX WITH FONTNAME = 'Arial', TOP = 1.0, LEFT = 18.0, HEIGHT = 1.5, WIDTH = 25.0, INPUTMASK = 'XXXXXXXXXXXXXXXXXXXXXXXXX' ADD OBJECT TXTCODE AS TEXTBOX WITH FONTNAME = 'Arial', TOP = 3.0, LEFT = 18.0, HEIGHT = 1.5, WIDTH = 25.0, PASSWORDCHAR = '*' ADD OBJECT TXTPOS AS TEXTBOX WITH FONTNAME = '.VnAvant', TOP = 5.0, LEFT = 18.0, HEIGHT = 1.5, WIDTH = 25.0, INPUTMASK = 'XXXXXXXXXXXXXXX' ADD OBJECT LBLNAME AS LABEL WITH FONTNAME = '.VnAvant', TOP = 1.25, LEFT = 1, HEIGHT = 1.2, WIDTH = 16.0, BACKCOLOR = RGB(192, 192, 192), FORECOLOR = RGB(0, 0, 160), CAPTION = 'Người dùng :' ADD OBJECT LBLCODE AS LABEL WITH FONTNAME = '.VnAvant', TOP = 3.25, LEFT = 1, HEIGHT = 1.2, WIDTH = 16, BACKCOLOR = RGB(192, 192, 192), FORECOLOR = RGB(0, 0, 160), CAPTION = 'Mật khẩu :' ADD OBJECT LBLPOS AS LABEL WITH FONTNAME = '.VnAvant', TOP = 5.25, LEFT = 1, HEIGHT = 1.2, WIDTH = 16, BACKCOLOR = RGB(192, 192, 192), FORECOLOR = RGB(0, 0, 160), CAPTION = 'Chức danh :' ADD OBJECT CMD1 AS COMMANDBUTTON WITH CAPTION = '\<Ok', TOP = 7.5, LEFT = 13.0, HEIGHT = 1.8, WIDTH = 10.0, FORECOLOR = RGB(0, 0, 160) ADD OBJECT CMD2 AS COMMANDBUTTON WITH CAPTION = '\<Cancel', TOP = 7.5, LEFT = 24.0, HEIGHT = 1.8, WIDTH = 10.0, FORECOLOR = RGB(0, 0, 160), CANCEL = .T. * PROCEDURE cmd1.click RELEASE THISFORM ENDPROC PROCEDURE cmd2.click RELEASE THISFORM ENDPROC ENDDEFINE *------------------------------------------------------------------------------------- PROCEDURE read_psw SELECT PASSWORD SCAN INSERT INTO TEMP VALUES (PASSWORD.USER_NAME, DECODE(PASSWORD.PASSWORD), PASSWORD.CHUCDANH) ENDSCAN USE IN PASSWORD USE IN TEMP ENDPROC *------------------------------------------------------------------------------------- FUNCTION decode PARAMETER S PRIVATE S1, I, C S1 = "" S = ALLTRIM(S) FOR I = 1 TO LEN(S) C = ASC(SUBSTR(S, I, 1)) S1 = S1+CHR(IIF(MOD(C, 2)=0, C-128, C-96)) ENDFOR RETURN S1 ENDFUNC *------------------------------------------------------------------------------------- FUNCTION ENCODE PARAMETER S PRIVATE S1, I, C S1 = "" S = ALLTRIM(S) FOR I = 1 TO LEN(S) C = ASC(UPPER(SUBSTR(S, I, 1))) S1 = S1+CHR(IIF(MOD(C, 2)=0, C+128, C+96)) ENDFOR RETURN S1 ENDFUNC *------------------------------------------------------------------------------------- PROCEDURE UPD_PAS SELECT 0 USE EXCLUSIVE (PASSWORD) ALIAS PASSWORD DELE ALL PACK SELECT 0 USE (DBF_TEMP) ALIAS TEMP SCAN FOR .NOT. DELETED() .AND. .NOT. EMPTY(USER_NAME) INSERT INTO PASSWORD VALUES (TEMP.USER_NAME, ENCODE(TEMP.PASSWORD), TEMP.CHUCDANH) ENDSCAN USE IN PASSWORD USE IN TEMP ENDPROC ------------------- File:reset.prg CLEAR PROG ALL CLOS DATA ALL CLOS ALL RELE ALL CLEAR ALL CLEA ON SHUTDOWN ON KEY ON ERROR = NUMLOCK(.F.) _RMARGIN = 255 _PEJECT = [NONE] * SET RESO ON SET HELP ON SET CONFIRM OFF SET DATE FRENCH SET DELETE ON SET ESCAPE ON SET EXACT OFF SET EXCLUSIVE OFF SET HOUR TO 24 SET NEAR ON SET PRINT OFF SET STAT BAR ON SET SAFE OFF SET TALK OFF SET REFRESH TO 1,1 REST MACRO SET SYSMENU ON SET SYSMENU TO DEFA *!* CANCEL &&De thoat khoi Read Event ------------------------------ File: smlib.PRG *--------------------- * Nguoi Viet: Hong Tu. * Dinh nghia cua so Win PROCEDURE Window PARA IconName IF PARA()<1 IconName = 'ICON01.ico' ENDIF *!* FLOOR(m_ScrRow) - 2, FLOOR(m_ScrCoL) = 30, 133 *!* DEFINE WINDOW m_WinBrw FROM 2, 0 TO FLOOR(m_ScrRow) - 2, FLOOR(m_ScrCoL) COLOR SCHEME 10 ; *!* CLOSE FLOAT GROW MINIMIZE ZOOM SYSTEM FONT m_Font_Name, m_Font_Size - 2 ; *!* ICON FILE LOCFILE(SYS(5)+ SOURCE +'\human\picture\' + IconName) m_Font_Name = 'Vn-Sans-Serif' m_Font_Size = 10 DEFINE WINDOW M_WinBrw FROM 02, 0 TO FLOOR(M_ScrRow) - 2, FLOOR(M_ScrCoL) COLOR SCHEME 10 ; CLOSE FLOAT GROW MINIMIZE ZOOM SYSTEM FONT m_Font_Name, m_Font_Size - 2 ; ICON FILE LOCFILE(path_human+'Picture\ICON01.ico') RETURN *--------------------- * Xoa cua so Win PROCEDURE Rel_Window RELEASE WINDOW m_WinBrw RETURN *--------------------- * Doi mau cua ban ghi trong man hinh browse FUNCTION Change_Color_Of_Browse(nRecord,cOldDynamicBackColor) RETURN oBrowse.SetAll("DynamicBackColor","IIF(RECNO()="+STR(nRecord)+",13172190,"+; IIF(EMPTY(cOldDynamicBackColor),"''",cOldDynamicBackColor)+")","Column") * ........................... Procedure: K_TagUn ........................ * Bo danh dau tat ca cac dong PROCEDURE K_TagUn PRIVATE _Recno PUSH KEY CLEAR _Recno = RECNO() REPLACE ALL TAG WITH " " GO _Recno POP KEY RETURN * ........................... Procedure: K_TagAll ........................ * Danh dau tat ca cac dong PROCEDURE K_TagAll PRIVATE _Recno PUSH KEY CLEAR _Recno = RECNO() REPLACE ALL TAG WITH "x" GO _Recno POP KEY RETURN * ........................... Procedure: K_Tag ........................... * danh dau/Bo danh dau mot dong PROCEDURE K_Tag PUSH KEY CLEAR IF EMPTY(TAG) REPLACE TAG WITH "x" ELSE REPLACE TAG WITH " " ENDI POP KEY RETURN *......................... Hàm đổi số ............................ * Doi so thanh chu de in chung tu FUNCTION DOI_SO_CHU PARAMETER So, DonViTinh, Doc_So_Bon * SO: So can doi * DonViTinh: Don vi tinh khi doc thanh chu (VND, USD,...) * Doc_So_Bon: Doc so 4 la "bon" hay "tu" , neu = [T] - [tu], nguoc lai la [bon] PRIVATE SoChu IF PARAMETER() < 3 Doc_So_Bon = [] ENDIF IF PARAMETER() < 2 DonViTinh = [] ENDIF Tu_Bon = ' bốn' IF UPPER(Doc_So_Bon) = 'T' Tu_Bon = ' tư' ENDIF DIMENSION MangChuSo( 10 ) STOR [ không] TO MangChuSo(1) STOR [ một] TO MangChuSo(2) STOR [ hai] TO MangChuSo(3) STOR [ ba] TO MangChuSo(4) STOR [ bốn] TO MangChuSo(5) STOR [ năm] TO MangChuSo(6) STOR [ sáu] TO MangChuSo(7) STOR [ bảy] TO MangChuSo(8) STOR [ tám] TO MangChuSo(9) STOR [ chín] TO MangChuSo(10) SoChu = [] IF So < 0 So = - So SoChu = SoChu + " âm" ENDIF So_sau_dau_phay = So - INT(So) ****Doc phan nguyen truoc So = INT(So) &&Vi ben duoi co doan S = LEFT(ALLT(S), LEN(ALLT(S)) - 1) ; && cho nen phai cho so 0 vao de neu doc so 0 thi no khong bi mat chu "g" IF So = 0 SoChu = SoChu + " " + 'không0' ELSE &&Cong them cac so khong vao dang truoc chuoi de duoc chan cac to hop 3 so So = ALLT(STR(So,16)) IF MOD(LEN(So) , 3 ) = 1 So = '00' + So ENDIF IF MOD(LEN (So), 3 ) = 2 So = '0' + So ENDIF So_Nhom = LEN(So)/3 Stt_Nhom = So_Nhom Stt_So = 1 &&Doc theo tung nhom 3 so DO WHILE Stt_So <= (LEN(So) - 2) &&Cho den vi tri cua chu so dau tien cua nhom cuoi cung So_Phu = SUBSTR(So, Stt_So, 3) Stt_Nhom = ROUND((LEN(So) - Stt_So +1) / 3, 0) IF LEN(DOI_SO_CHU_NHOM(So_Phu, Stt_Nhom, So_Nhom)) > 0 IF Stt_Nhom < 5 &&Nho hon mot ty thi phai cng them dau phay SoChu = SoChu + DOI_SO_CHU_NHOM(So_Phu, Stt_Nhom, So_Nhom) + [,] ELSE SoChu = SoChu + DOI_SO_CHU_NHOM(So_Phu, Stt_Nhom, So_Nhom) ENDIF ELSE SoChu = SoChu + DOI_SO_CHU_NHOM(So_Phu, Stt_Nhom, So_Nhom) ENDIF Stt_So = Stt_So + 3 ENDDO ENDIF SoChu = LEFT(ALLT(SoChu), LEN(ALLT(SoChu)) - 1) ****Doc phan thap phan * Neu chu so dau tien sau dau phay khac khong thi doc nhu phan so nguyen IF So_sau_dau_phay > 0 SoChu = SoChu + " phẩy" So_sau_dau_phay = ALLTR(STR(So_sau_dau_phay, 8, 6)) &&Chi doc den 6 chu so sau dau phay So_sau_dau_phay = SUBS(So_sau_dau_phay, 3, LEN(So_sau_dau_phay) - 2) &&Cat lay phan sau dau phay IF LEFT(So_sau_dau_phay, 1) '0' &&Cat nhung so 0 o ben phai do STR() di DO WHILE RIGHT(So_sau_dau_phay, 1) = '0' So_sau_dau_phay = LEFT(So_sau_dau_phay, LEN(So_sau_dau_phay) - 1) ENDDO &&Cong them cac so khong vao dang truoc chuoi de duoc chan cac to hop 3 so IF MOD(LEN(So_sau_dau_phay) , 3 ) = 1 So_sau_dau_phay = '00' + So_sau_dau_phay ENDIF IF MOD(LEN(So_sau_dau_phay), 3 ) = 2 So_sau_dau_phay = '0' + So_sau_dau_phay ENDIF So_Nhom = ROUND(LEN(So_sau_dau_phay) / 3,0) Stt_Nhom = So_Nhom Stt_So = 1 &&Doc theo tung nhom 3 so DO WHILE Stt_So <= (LEN(So_sau_dau_phay) - 2)&&Cho den vi tri cua chu so dau tien cua nhom cuoi cung So_Phu = SUBSTR(So_sau_dau_phay, Stt_So, 3) Stt_Nhom = ROUND ((LEN (So_sau_dau_phay) - Stt_So +1) / 3,0) SoChu = SoChu + DOI_SO_CHU_NHOM( So_Phu, Stt_Nhom, So_Nhom) Stt_So = Stt_So + 3 ENDDO ELSE * Neu chu so dau tien sau dau phay = 0 thi doc tung chu so mot &&Cat nhung so 0 o ben phai do STR() di DO WHILE RIGHT(So_sau_dau_phay, 1) = '0' So_sau_dau_phay = LEFT(So_sau_dau_phay, LEN(So_sau_dau_phay) - 1) ENDDO &&Doc lan luot tung chu so sau dau phay FOR i =1 TO LEN(So_sau_dau_phay) j = SUBS(So_sau_dau_phay, i, 1) SoChu = SoChu + MangChuSo(VAL(j) +1 ) ENDFOR ENDIF ENDIF SoChu = ALLTR(UPPER(LEFT(SoChu, 1)) + SUBS(SoChu, 2) + [ ] + DonViTinh) RETURN SoChu *......................... Function DOI_SO_CHU_NHOM ............................ FUNCTION DOI_SO_CHU_NHOM PARAMETER Nhom_So, Stt_Nhom, So_Nhom * Nhom_So: Nhom 3 so can doc * Stt_Nhom: Stt cua nhom trong tong so cac nhom * So_Nhom: Tong so nhom cua so can doc PRIVATE Tram, Chuc, Don_Vi, Tram_Chu, Chuc_Chu, Don_Vi_Chu, Nhom_Chu Nhom_Chu = '' Tram = LEFT(Nhom_So,1) Chuc = SUBSTR(Nhom_So,2,1) Don_Vi = RIGHT(Nhom_So,1) Tram_Chu = MangChuSo(VAL(Tram) +1 ) Chuc_Chu = MangChuSo(VAL(Chuc) +1 ) Don_Vi_Chu = MangChuSo(VAL(Don_Vi) +1 ) IF (Tram '0') .OR. ((Stt_Nhom = 1) .AND. (Stt_Nhom < So_Nhom)) Nhom_Chu = Nhom_Chu + Tram_Chu + ' trăm' ENDIF IF ALLTR(Chuc_Chu) 'không' IF ALLTR(Chuc_Chu) 'một' Nhom_Chu = Nhom_Chu + Chuc_Chu + ' mươi' IF ALLTR(Don_Vi_Chu) 'năm' IF ALLTR(Don_Vi_Chu) 'không' IF ALLTR(Don_Vi_Chu) = 'một' Nhom_Chu = Nhom_Chu + ' mốt' ELSE IF (ALLTR(Don_Vi_Chu) = 'bốn') .AND. (Stt_Nhom > 1) Nhom_Chu = Nhom_Chu + Tu_Bon ELSE Nhom_Chu = Nhom_Chu + Don_Vi_Chu ENDIF ENDIF ENDIF ELSE Nhom_Chu = Nhom_Chu + ' lăm' ENDIF ELSE Nhom_Chu = Nhom_Chu + ' mười' IF ALLTR(Don_Vi_Chu) 'năm' IF ALLTR(Don_Vi_Chu) 'không' Nhom_Chu = Nhom_Chu + Don_Vi_Chu ENDIF ELSE Nhom_Chu = Nhom_Chu + ' lăm' ENDIF ENDIF ELSE IF ALLTR(Don_Vi_Chu) 'không' Nhom_Chu = Nhom_Chu + ' linh' IF ALLTR(Don_Vi_Chu) 'bốn' Nhom_Chu = Nhom_Chu + Don_Vi_Chu ELSE Nhom_Chu = Nhom_Chu + Tu_Bon ENDIF ENDIF ENDIF IF (Tram = '0') .AND. (Chuc = '0') .AND. (Don_Vi '0') .AND. (Stt_Nhom > 1) Nhom_Chu = Don_Vi_Chu ENDIF IF (Tram = '0') .AND. (Chuc = '0') .AND. (Don_Vi '0') .AND. (So_Nhom = 1) Nhom_Chu = Don_Vi_Chu ENDIF DO CASE CASE Stt_Nhom = 2 Nhom_Chu = Nhom_Chu + ' nghìn' CASE Stt_Nhom = 3 Nhom_Chu = Nhom_Chu + ' triệu' CASE Stt_Nhom = 4 Nhom_Chu = Nhom_Chu + ' tỷ' CASE Stt_Nhom = 5 Nhom_Chu = Nhom_Chu + ' nghìn' CASE Stt_Nhom = 6 Nhom_Chu = Nhom_Chu + ' triệu' ENDCASE IF (Tram = '0') .AND. (Chuc = '0') .AND. (Don_Vi = '0') Nhom_Chu = '' ENDIF RETURN Nhom_Chu *!* ---------------------------------------- *!* PROCEDURE HookObjectBrowse *!* ---------------------------------------- PROCEDURE HookObjectBrowse oBrowse.Tag = ORDER() oBrowse.Comment = FILTER() FOR i =1 TO oBrowse.ColumnCount WITH oBrowse.Columns(i) cCaption = .Header1.Caption .RemoveObject("Header1") .AddObject("Header1", "hdrSort") .Header1.Tag = .ControlSource .Header1.Caption = cCaption ENDWITH ENDFOR FOR i =1 TO oBrowse.ColumnCount WITH oBrowse.Columns(i) .RemoveObject("Text1") .AddObject("Text1", "txtSort") .Text1.Visible = .T. ENDWITH ENDFOR IF oBrowse.Partition > 0 oBrowse.Panellink = .F. oBrowse.Panel = 0 oBrowse.ScrollBars = 0 oBrowse.Panel = 1 oBrowse.DeleteMark = .F. oBrowse.RecordMark = .F. oBrowse.Panellink = .T. oBrowse.Partition = oBrowse.Partition - 18 ENDIF ENDPROC *!* ---------------------------------------- DEFINE CLASS hdrSort AS Header PROCEDURE Init THIS.FontName = m_Font_Name THIS.FontSize = m_Font_Size THIS.FontBold = .T. THIS.Alignment = 2 THIS.BackColor = m_Back_color ENDPROC PROCEDURE DblClick IF NOT ISEXCLUSIVE() RETURN ENDIF sIndex = THIS.Tag IF NOT EMPTY(oBrowse.ToolTipText) sExecute = "oBrowse." + ALLTRIM(oBrowse.ToolTipText)+ ".Header1.ForeColor = 0" &sExecute ENDIF DO CASE CASE EMPTY(THIS.Comment) INDEX ON &sIndex TAG fOrder THIS.Comment = "1" THIS.ForeColor = 16711680 CASE THIS.Comment = "1" INDEX ON &sIndex DESCENDING TAG fOrder THIS.Comment = "2" THIS.ForeColor = 16711680 CASE THIS.Comment = "2" oldOrder = ALLTRIM(oBrowse.Tag) SET ORDER TO &oldOrder THIS.Comment = "" THIS.ForeColor = 0 ENDCASE oBrowse.Refresh oBrowse.ToolTipText = THIS.Parent.Name ENDPROC ENDDEFINE *!* ---------------------------------------- DEFINE CLASS txtSort AS TextBox PROCEDURE Init THIS.FontName = m_Font_Name THIS.FontSize = m_Font_Size THIS.BorderStyle = 0 ENDPROC PROCEDURE GotFocus THIS.StatusBarText = ALLTRIM(m_Prompt) + " - " + ALLTRIM(STR(RECNO(), 16)) + "/" + ALLTRIM(STR(RECCOUNT(), 16)) + " " + Cat_dau(ALLTRIM(THIS.Parent.Header1.Caption)) + ": " + Cat_dau(THIS.Text) ENDPROC ENDDEFINE *!* FUNCTION MsgBox(sMessageText,iDialogBoxType,cTitleBarText) FUNCTION MsgBox PARAMETER sMessageText,iDialogBoxType,cTitleBarText PRIVATE OldError IF VARTYPE(iDialogBoxType) = "C" cTitleBarText = iDialogBoxType nDialogBoxType = 0 ELSE nDialogBoxType = iDialogBoxType ENDIF IF EMPTY(m_user_pre) cMessageText = sMessageText ELSE cMessageText = IIF(; MOD(INT(SECOND()), 2) = 0, ; m_user_dear + " " + ALLTRIM(m_user_pre), ; ALLTRIM(m_user_pre) + " ơi") + ", " + sMessageText && , ECode2String('SMLIB0073'))) ENDIF PRIVATE iReturn iReturn=0 IF PARAMETER()=1 nDialogBoxType=0 ENDIF IF PARAMETER()<3 cTitleBarText=_SCREEN.Caption ENDIF IF m_Lan "V" iReturn = MESSAGEBOX(sMessageText,nDialogBoxType,cTitleBarText) RETURN iReturn ENDIF frmSet = CREATEOBJECT('FormSet') frmSet.WindowType=1 frmSet.AddObject('frmMsg','Form') frmSet.frmMsg.ControlBox=.F. frmSet.frmMsg.Height=90 frmSet.frmMsg.BorderStyle=1 frmSet.frmMsg.Caption=cTitleBarText frmSet.frmMsg.AddObject('mLabel','Label') frmSet.frmMsg.mLabel.Visible=.T. frmSet.frmMsg.mLabel.FontName=m_Font_name frmSet.frmMsg.mLabel.Caption= cMessageText frmSet.frmMsg.mLabel.Top=15 frmSet.frmMsg.mLabel.Left=50 frmSet.frmMsg.mLabel.Autosize = .T. frmSet.frmMsg.AddObject('mImage','Image') frmSet.frmMsg.mImage.Visible=.T. frmSet.frmMsg.mImage.BackStyle = 0 frmSet.frmMsg.mImage.Top=5 frmSet.frmMsg.mImage.Left=10 frmSet.frmMsg.mImage.Height=20 frmSet.frmMsg.mImage.Width=20 DO CASE CASE nDialogBoxType<256 iIndex=1 CASE nDialogBoxType<512 iIndex=2 OTHER iIndex=3 ENDCASE nDialogBoxType=MOD(nDialogBoxType,256) DO CASE CASE MOD(nDialogBoxType,80)<16 frmSet.frmMsg.mImage.Visible=.F. frmSet.frmMsg.mLabel.Left=20 CASE MOD(nDialogBoxType,80)<32 frmSet.frmMsg.mImage.Picture=k_bmp+"hM04.Bmp" CASE MOD(nDialogBoxType,80)<48 frmSet.frmMsg.mImage.Picture=k_bmp+"hM01.Bmp" CASE MOD(nDialogBoxType,80)<64 frmSet.frmMsg.mImage.Picture=k_bmp+"hM02.Bmp" CASE MOD(nDialogBoxType,80)<80 frmSet.frmMsg.mImage.Picture=k_bmp+"hM03.Bmp" ENDCASE frmSet.frmMsg.Width =frmSet.frmMsg.mLabel.Width + 2 * frmSet.frmMsg.mLabel.Left IF frmSet.frmMsg.Width < 300 frmSet.frmMsg.Width = 300 ENDIF WITH frmSet.frmMsg.mLabel .Autosize = .F. .Height = .Height * (OCCURS(CHR(13), .Caption) + OCCURS(CHR(10), .Caption) + 1) ENDWITH frmSet.frmMsg.Height = frmSet.frmMsg.mLabel.Height + 80 Do CASE CASE MOD(nDialogBoxType,16)=1 frmSet.frmMsg.AddObject('cmdOk','cmdMsg') frmSet.frmMsg.AddObject('cmdCancel','cmdMsg') frmSet.frmMsg.cmdOk.Caption="\<Nhận" frmSet.frmMsg.cmdCancel.Caption=IIF(m_Lan = 'V', "\<Bỏ qua", ECode2String('SMLIB0074')) frmSet.frmMsg.cmdOk.Left=INT((frmSet.frmMsg.width-2*frmSet.frmMsg.cmdOk.width-10)/2) frmSet.frmMsg.cmdCancel.Left=frmSet.frmMsg.cmdOk.Left+10+frmSet.frmMsg.cmdOk.Width frmSet.frmMsg.cmdOk.Visible =.T. frmSet.frmMsg.cmdCancel.Visible =.T. IF iIndex=2 frmSet.frmMsg.cmdCancel.TabIndex = 0 ENDIF CASE MOD(nDialogBoxType,16)=2 frmSet.frmMsg.AddObject('cmdAbort','cmdMsg') frmSet.frmMsg.AddObject('cmdRetry','cmdMsg') frmSet.frmMsg.AddObject('cmdIgnore','cmdMsg') frmSet.frmMsg.cmdAbort.Caption="\<Huỷ" frmSet.frmMsg.cmdRetry.Caption=IIF(m_Lan = 'V', "\<Làm lại", ECode2String('SMLIB0075')) frmSet.frmMsg.cmdIgnore.Caption=IIF(m_Lan = 'V', "\<Bỏ qua", ECode2String('SMLIB0076')) frmSet.frmMsg.cmdAbort.Left=INT((frmSet.frmMsg.width-3*frmSet.frmMsg.cmdAbort.width-20)/2) frmSet.frmMsg.cmdRetry.Left=INT((frmSet.frmMsg.width-frmSet.frmMsg.cmdAbort.width)/2) frmSet.frmMsg.cmdIgnore.Left=2*frmSet.frmMsg.cmdRetry.Left-frmSet.frmMsg.cmdAbort.Left frmSet.frmMsg.cmdAbort.Visible =.T. frmSet.frmMsg.cmdRetry.Visible =.T. frmSet.frmMsg.cmdIgnore.Visible =.T. IF iIndex=2 frmSet.frmMsg.cmdRetry.TabIndex = 0 ENDIF IF iIndex=3 frmSet.frmMsg.cmdIgnore.TabIndex = 0 ENDIF CASE MOD(nDialogBoxType,16)=3 frmSet.frmMsg.AddObject('cmdYes','cmdMsg') frmSet.frmMsg.AddObject('cmdNo','cmdMsg') frmSet.frmMsg.AddObject('cmdCancel','cmdMsg') frmSet.frmMsg.cmdYes.Caption="\<Có" frmSet.frmMsg.cmdNo.Caption="\<Không" frmSet.frmMsg.cmdCancel.Caption=IIF(m_Lan = 'V', "\<Bỏ qua", ECode2String('SMLIB0077')) frmSet.frmMsg.cmdYes.Left=INT((frmSet.frmMsg.width-3*frmSet.frmMsg.cmdYes.width-20)/2) frmSet.frmMsg.cmdNo.Left=INT((frmSet.frmMsg.width-frmSet.frmMsg.cmdYes.width)/2) frmSet.frmMsg.cmdCancel.Left=2*frmSet.frmMsg.cmdNo.Left-frmSet.frmMsg.cmdYes.Left frmSet.frmMsg.cmdYes.Visible =.T. frmSet.frmMsg.cmdNo.Visible =.T. frmSet.frmMsg.cmdCancel.Visible =.T. IF iIndex=2 frmSet.frmMsg.cmdNo.TabIndex = 0 ENDIF IF iIndex=3 frmSet.frmMsg.cmdCancel.TabIndex = 0 ENDIF CASE MOD(nDialogBoxType,16)=4 frmSet.frmMsg.AddObject('cmdYes','cmdMsg') frmSet.frmMsg.AddObject('cmdNo','cmdMsg') frmSet.frmMsg.cmdYes.Caption="\<Có" frmSet.frmMsg.cmdNo.Caption="\<Không" frmSet.frmMsg.cmdYes.Left=INT((frmSet.frmMsg.width-2*frmSet.frmMsg.cmdYes.width-10)/2) frmSet.frmMsg.cmdNo.Left=frmSet.frmMsg.cmdYes.Left+10+frmSet.frmMsg.cmdYes.Width frmSet.frmMsg.cmdYes.Visible =.T. frmSet.frmMsg.cmdNo.Visible =.T. IF iIndex=2 frmSet.frmMsg.cmdNo.TabIndex = 0 ENDIF CASE MOD(nDialogBoxType,16)=5 frmSet.frmMsg.AddObject('cmdRetry','cmdMsg') frmSet.frmMsg.AddObject('cmdCancel','cmdMsg') frmSet.frmMsg.cmdRetry.Caption=IIF(m_Lan = 'V', "\<Thử lại", ECode2String('SMLIB0078')) frmSet.frmMsg.cmdCancel.Caption=IIF(m_Lan = 'V', "\<Bỏ qua", ECode2String('SMLIB0079')) frmSet.frmMsg.cmdRetry.Left=INT((frmSet.frmMsg.width-2*frmSet.frmMsg.cmdRetry.width-10)/2) frmSet.frmMsg.cmdCancel.Left=frmSet.frmMsg.cmdRetry.Left+10+frmSet.frmMsg.cmdRetry.Width frmSet.frmMsg.cmdRetry.Visible =.T. frmSet.frmMsg.cmdCancel.Visible =.T. IF iIndex=2 frmSet.frmMsg.cmdCancel.TabIndex = 0 ENDIF OTHER frmSet.frmMsg.AddObject('cmdOk','cmdMsg') frmSet.frmMsg.cmdOk.Caption="\<Nhận" frmSet.frmMsg.cmdOk.Left=INT((frmSet.frmMsg.width-frmSet.frmMsg.cmdOk.width)/2) frmSet.frmMsg.cmdOk.Visible =.T. ENDCASE nError = 0 OldError = ON("ERROR") ON ERROR nError = 1 IF VARTYPE(_FORM) = "O" IF UPPER(_SCREEN.Activeform.Class) = "FRMTRANS" IF UPPER(_FORM.ActiveControl.BaseClass) = "GRID" _isLostfocus = .T. ENDIF ENDIF ENDIF IF nError = 1 _isLostfocus = .F. ENDIF ON ERROR &OldError frmSet.frmMsg.AutoCenter=.T. ?? CHR(7) frmSet.frmMsg.Show RETURN iReturn DEFINE CLASS cmdMsg AS COMMANDBUTTON Top = frmSet.frmMsg.mLabel.Top + frmSet.frmMsg.mLabel.Height + 30 Width=80 Height = 25 Left=20 FontName = m_Font_name PROCEDURE Click DO CASE CASE Uppe(This.Name)="CMDOK" iReturn=1 CASE Uppe(This.Name)="CMDCANCEL" iReturn=2 CASE Uppe(This.Name)="CMDYES" iReturn=6 CASE Uppe(This.Name)="CMDNO" iReturn=7 CASE Uppe(This.Name)="CMDABORT" iReturn=3 CASE Uppe(This.Name)="CMDIGNORE" iReturn=5 CASE Uppe(This.Name)="CMDRETRY" iReturn=4 ENDCASE THISFORM.Release ENDPROC ENDDEFINE ------------------------- File: Start.prg CLOSE ALL SET DEFA TO HOME() Keyboard 'ABC' Keyboard '{ENTER}' Keyboard '{ENTER}' Do Main ------------------------.

Các file đính kèm theo tài liệu này:

  • doc33323.doc