Chuyên đề Phân tích thiết kế hệ thống quản lý nhân sự tại công ty cổ phần phần mềm quản trị doanh nghiệp CyberSoft

Hệ thống thông tin quản lí nhân sự có một vai trò quan trọng trong hoạt động kinh doanh của bất kỳ một doanh nghiệp nào dù quy mô lớn hay nhỏ và đặc biệt quan trọng đối với công ty cổ phần lớn như công ty cổ phần phần mềm quản trị doanh nghiệp. Nó là một khâu quan trọng trong quá trình kinh doanh của công ty và nó góp phần vào sự phát triển của công ty không chỉ trong giai đoạn hiện tại và cả trong tương lai. Hệ thống quản lí nhân sự tại công ty cổ phần phần mềm quản trị doanh nghiệp – CyberSoft do em viết đã hoạt động khá tốt, nó đã một phần giúp cho nhà quản lí nhanh nhậy trong vấn đề quản lí nhân viên trong công ty. Đã cập nhật được thông tin của nhân viên, thêm nhân viên, chỉnh sửa thông tin nhân viên từ đó đưa ra được báo cáo cho ban quản lí và các bộ phận khác trong công ty. Tin học ngày càng phát triển như hiện nay thì việc đưa công nghệ vào áp dụng trong công ty, các doanh nghiệp là điều cần thiết và phần mềm này cũng là một trong số những phần mềm minh chứng cho điều đó. Thay vì quản lí nhân viên bằng sổ sách, thay vì mất nhiều nhân viên quản lí, mất nhiều thời gian thì nay chỉ với phần mềm này công việc đó đã đơn giản đi rất nhiều.

doc85 trang | Chia sẻ: aloso | Lượt xem: 1994 | Lượt tải: 1download
Bạn đang xem trước 20 trang tài liệu Chuyên đề Phân tích thiết kế hệ thống quản lý nhân sự tại công ty cổ phần phần mềm quản trị doanh nghiệp CyberSoft, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
ng tác quản lý nhân sự của nhân viên đóng vai trò hết sức quan trọng đối với hoạt động của các công ty các doanh nghiệp ở Việt Nam Trong khoảng 10 năm trở lại đây công tác quản lý nhân viên (ở một số công ty trong đó có Công Ty Cổ Phần Phần Mềm quản trị doanh nghiệp) đã được tin học hóa nhằm đem lại hiệu quả cao hơn, nhanh hơn tin cậy hơn. Bài toán Quản lý nhân sự đặt ra các vấn đề cơ bản như sau: Thể hiện được mô hình tổ chức quản lý nhân viên theo chức vụ, theo trình độ văn hóa, theo trình độ ngoại ngữ… Hệ thống còn phải cho phép tạo ra các báo cáo từ lí lịch. Nhằm phục vụ công tác điều hành nhân viên và sắp xếp lịch cho nhân viên làm việc một cách khoa học và đạt hiệu quả cao nhất. In Danh sách nhân viên, in danh mục chức vụ, in danh mục tỉnh thành… Ngoài các chức năng chính như trên, hệ thống này còn cần thêm một số chức năng khác như: cập nhật các loại danh mục( danh mục tỉnh thành, danh mục ngoại ngữ, danh mục đơn vị …) các chức năng sao, chép, sửa, xóa. Qua quá trình tìm hiểu và dựa trên những bất cập hiện nay tại công ty em có định hướng sẽ viết và xin đưa ra đề tài: Đề tài: “ Phân Tích Thiết Kế Hệ thống quản lí nhân sự tại Công ty cổ phần phần mềm quản trị doanh nghiệp – CyberSoft Đề tài này là một đề tài hay nếu được phát triển nó sẽ được ứng dụng trong rất nhiều công ty khác nhau. Nếu sau này có thời gian em sẽ phát triển và cho thêm vào phần mềm một số ứng dụng nữa. Em sẽ cố gắng viết hoàn chỉnh nhất trong khả năng có thể để làm bài báo cáo thực tập được tốt nhất. 2. Giải pháp Yêu cầu chung của phần mềm: - Chương trình đơn giản và dễ sử dụng - Chương trình phải đáp ứng các quá trình sử lí số liệu một cách chính xác - Chương trình giải quyết và đưa ra các báo cáo một cách nhanh chóng - Chương trình đảm bảo an toàn về dữ liệu - Chương trình mang tính mềm dẻo và không cần đòi hỏi cấu hình máy quá cao 3. Phạm vi ứng dụng của đề tài Đề tài này nhằm giúp cho nhà quản lí, cụ thể là bộ phận nhân sự của công ty biết được tình hình về nhân viên trong công ty mình, về lí lịch qua đó hỗ chợ cho lịch làm việc và những phương án công tác thích hợp nhằm đạt hiệu quả cao nhất cho công ty. Đề tài được ứng dụng trong nội bộ của công ty triển khai dự án cụ thể ở đây là Công ty cổ phần phần mềm quản trị doanh nghiệp - CyberSoft. Bên cạnh đó đề tài có thể được ứng dụng và triển khai tại các công ty khác nhằm tạo ra hiệu quả cao nhất cho công ty. 4. Đối tượng hưởng lợi Đối với ban lãnh đạo và giám đốc của công ty: có thể nắm được tình hình nhân viên của công ty thông qua các báo cáo của phần mềm, từ đó có thể đưa ra được những quyết định chính xác cho việc quản lí, điều hành của công ty của công ty. Đối với các trưởng phòng ban: có thể bố trí, tính toán công việc một cách hợp lý, nhanh chóng và chính xác. Nắm bắt được tình hình về nhân viên trong công ty qua các báo cáo của phần mềm để có những thông tin chính xác ra quyết định và báo cáo với giám đốc. Đối với nhân viên: có thể thực hiện công việc của mình một cách chính xác hiệu quả. Không phải mất nhiều thời gian nhiều trong viêc kiểm kê, nắm bắt thông tin. Biết được các anh em trong công ty và có thể liên hệ qua lại với nhau. Tạo điều kiện kết gắn mọi nhân viên trong công ty như anh em một nhà qua đó hình thành môi trường làm việc thân thiện đoàn kết cùng chung vai gắng sức đưa công ty phát triển. Ngay cả đối với gia đình và người thân của nhân viên trong công ty cũng sẽ gặp rất nhiều thuận lợi khi biết về con em mình hiện đang làm việc tại công ty khi gặp ra sự cố. II. Kế hoạch công việc cần làm 1 - Xây dựng và quản lý chương trình quản lí nhân sự Đề xuất ý tưởng và hình thành bộ khung chương trình Lập giải pháp kĩ thuật Xây dựng Thực hiện Báo cáo tổng kết 2 - Xác định yêu cầu Lập kế hoạch Khảo sát Phân tích nghiệp vụ Phân tích yêu cầu người sử dụng Mô tả hoạt động của công ty cổ phần phần mềm quản trị doanh nghiệp Báo cáo tổng kết 3 - Phân tích, thiết kế Lập kế hoạch thiết kế Thiết kế kiến trúc Thiết kế dữ liệu Thiết kế thủ tục Thiết kế chương trình Thiết kế giao diện Báo cáo tổng kết 4 - Lập trình Lập kế hoạch lập trình Lập trình thư viện chung Báo cáo tổng kết quy trình 5- Test Lập kế hoạch Test Kịch bản Test Test hệ thống Test nghiệm thu Hồ sơ Test III. Lý thuyết về hệ thống thông tin & công nghệ phần mềm 1. Lý thuyết về hệ thống thông tin Hệ thống thông tin: Hệ thống thông tin (information system) là một hệ thống mà mục tiêu tồn tại của nó là cung cấp thông tin phục vụ cho hoạt động của con người trong một tổ chức nào đó. Ta có thể hiểu hệ thống thông tin là hệ thống mà mối liên hệ giữa các thành phần của nó cũng như mối liên hệ giữa nó với các hệ thống khác là sự trao đổi thông tin. Một số ví dụ về hệ thống thông tin: Máy tính là một hệ thống thông tin 2. Khái niệm về phần mềm và công nghệ phần mềm, phân loại phần mềm 2.1 Khái niệm về phần mềm. Phần mềm là một khái niệm mà cho đến nay có rất nhiều cách khác nhau để định nghĩa. Sau đây là một số cách định nghĩa về phần mềm: Phần mềm là tập hợp tất cả các câu lệnh do các lập trình viên viết ra để hướng máy tính làm một số công việc cụ thể nào đó. Theo giáo trình tin học đại cương của khoa tin học ĐH kinh tế quốc dân thì: “Phần mềm máy tính là các chương trình, cấu trúc dữ liệu làm cho chương trình xử lý được những thông tin thích hợp và các tài liệu mô tả phương thức sử dụng các chương trình ấy. Phần mềm luôn được bổ sung và sửa đổi một cách thường xuyên” Để có được phần mềm, các nhà lập trình phải sử dụng các ngôn ngữ lập trình để viết, ngôn ngữ lập trình là ngôn ngữ trung gian giữa ngôn ngữ giao tiếp của con người với ngôn ngữ máy, ngôn ngữ càng gần với ngôn ngữ con người thì gọi là ngôn ngữ cấp cao, càng gần ngôn ngữ máy thì gọi là ngôn ngữ cấp thấp. với các chương trình ứng dụng khác nhau và các trình điều khiển thiết bị khác nhau 2.2 Khái niệm về công nghệ phần mềm Công nghệ phần mềm là một lĩnh vực nghiên cứu mới của tin học, được triển khai trong giai đoạn phát triển rất cao của tin học và viễn thông khi phần mềm đã trở thành một ngành công nghiệp. Công nghệ phần mềm là môn khoa học nghiên cứu các phương pháp, các thủ tục và các công cụ đi từ phân tích thiết kế đến quản lý một dự án phần mềm nhằm đạt được các mục tiêu của dự án. Công nghệ phần mềm bao gồm một tập hợp với 3 yếu tố chủ chốt: Công cụ và thủ tục, giúp cho người quả lý có thể kiểm soát được quá trình phát triển phần mềm và cung cấp cho kỹ sư phần mềm một nền tảng để xây dựng một phần mềm chất lượng cao. 2.3 Phân loại phần mềm. 2.3.1 Theo phương thức hoạt động Phần mềm hệ thống dùng để vận hành máy tính và các phần cứng máy tính, ví dụ như các hệ điều hành máy tính Windows XP, Linux, Unix, các thư viện động (còn gọi là thư viện liên kết động; tiếng Anh: dynamic linked library - DLL) của hệ điều hành, các bộ điều vận (driver), phần sụn(firmware) và BIOS. Đây là các loại phần mềm mà hệ điều hành liên lạc với chúng để điều khiển và quản lý các thiết bị phần cứng. Phần mềm ứng dụng để người sử dụng có thể hoàn thành một hay nhiều công việc nào đó, ví dụ như các phần mềm văn phòng (Microsoft Offices, Lotus 1-2-3, FoxPro), phần mềm doanh nghiệp, phần mềm giáo dục, cơ sở dữ liệu, phần mềm trò chơi, chương trình tiện ích. Các phần mềm chuyển dịch mã bao gồm trình biên dịch và trình thông dịch: các loại chương trình này sẽ đọc các câu lệnh từ các mã nguồn được viết bởi các lập trình viên và dịch nó sang dạng ngôn ngữ máy mà máy tính có thể hiểu được, hay dịch nó sang một dạng khác như là tập tin đối tượng (object file) và các tập tin thư viện (library file) mà các phần mềm khác (như hệ điều hành chẳng hạn) có thể hiểu để vận hành máy tính thực thi các lệnh. 2.3.2 Theo khả năng ứng dụng Những phần mềm không phụ thuộc, nó có thể được bán cho bất kỳ khách hàng nào trên thị trường tự do. Ví dụ: phần mềm về cơ sở dữ liệu như Oracle, đồ họa như Photoshop, Corel Draw, soạn thảo và xử lý văn bản, bảng tính... Ưu điểm: Thông thường đây là những phần mềm có khả năng ứng dụng rộng rãi cho nhiều nhóm người sử dụng. Khuyết điểm: Thiếu tính uyển chuyển, tùy biến. Những phần mềm được viết theo đơn đặt hàng hay hợp đồng của một khách hàng cụ thể nào đó (một công ty, bệnh viện, trường học...). Ví dụ: phần mềm điều khiển, phần mềm hỗ trợ bán hàng... Ưu điểm: Có tính uyển chuyển, tùy biến cao để đáp ứng được nhu cầu của một nhóm người sử dụng nào đó. Khuyết điểm: Thông thường đây là những phần mềm ứng dụng chuyên ngành hẹp. * Cách phân loại thứ hai: 2.3.3 Phần mềm ứng dụng Phần mềm cho những ứng dụng tổng quát: Là những phần mềm đáp ứng được những công việc mang tính phổ thông thường ngày của hầu hết người sử dụng. Ví dụ: Chương trình duyệt Web cho phép người sử dụng có thể khai thác kho dữ liệu khổng lồ trên Internet để phục vụ cho công việc của mình: Internet Explorer, Opera… Phần mềm nhận và gửi thư điện tử giúp chúng ta giữ liên hệ với mọi đối tác cho dù họ ở bất kỳ đâu trên thế giới thông qua mạng Internet: Outlook Express. Hệ soạn thảo điều khiển máy tính hoạt động như một máy chữ để giúp người dùng biên soạn các tài liệu như công văn, thư từ… Hệ soạn thảo văn bản được sử dụng nhiều nhất là MS Word. Hệ quản trị cơ sở dữ liệu giúp lưu chữ, tổ chức, sắp sếp, cập nhật thông tin và tìm kiếm thông tin khi cần thiết. Ở Việt Nam hệ quản trị CSDL được dùng nhiều nhất là hệ quản trị: Foxpro và MS Access. Phần mềm cho những mục đích cụ thể. + Phần mềm kinh doanh: Gồm các chương trình giúp các doanh nghiệp hoàn thành những nhiệm vụ xử lý thông tin có tính chất thủ tục lặp đi lặp lại hàng ngày, hàng tháng, hàng quý hay hàng năm. Phần mềm kinh doanh khác phần mềm sản suất ở chỗ nó nhấn mạnh vào những nhiệm vụ trên phạm vi toàn cơ quan như phần mềm kế toán, quản lý nhân sự…Các phần mềm được dùng nhiều nhất hiện nay là Fast và Effect. Phần mềm giải trí bao gồm các trò chơi và các chương trình để giúp tiêu khiển, giải trí. Hiện nay, khi mức của con người càng cao thì các phần mềm thuộc loại nay đang lên ngôi. Phần mềm giáo dục và tham khảo giúp cung cấp kiến thức, kỹ năng về một chủ thể, lĩnh vực nào đó, cung cấp các bộ cơ sở dữ liệu cho phép tra cứu thông tin theo yêu cầu: Phần mềm tra cứu từ điển. 2.3.4 Phần mềm hệ thống. Phần mềm hệ thống bao gồm các chương trình quản lý, hỗ trợ các tài nguyên và điều hành các hoạt động của hệ thống máy tính. Phần mềm quản lý hệ thống Hệ điều hành: Là một bộ chương trình phục vụ cho việc quản lý chặt chẽ hệ thống tính toán và tổ chức khai thác chúng một cách tối ưu. Các chương trình tiện ích: Được xây dựng với mục đích bổ xung thêm các dịch vụ cần cho người mà hệ điều hành chưa đáp ứng được hay là đã có nhưng chọn vẹn: Winzar, Foxit reader. Các chương trình điều khiển thiết bị giúp máy tính điều khiển một thiết bị nào đó mà không có trong danh sách những thiết bị phần cứng được hệ điều hành hỗ trợ: Các loại Card màn hình. Phần mềm phát triển hệ thống: Các chương trình dịch có nhiệm vụ dịch các chương trình viết bằng ngôn ngữ thuật toán sang ngôn ngữ máy tính để có thể hiểu và xử lý được. Ngôn ngữ lập trình là công cụ để diễn tả thuật toán thành chương trình cho máy tính thực hiện. Cho đến nay đã có 5 thế hệ ngôn ngữ lập trình: Java của sun, dot net của Microsoft. 3 Chu kỳ sống của một phần mềm: 3.1 Chu kỳ sống của dự án tuần tự Giai đoạn khởi tạo. Khởi tạo dự án là một giai đoạn xác định nhu cầu của ứng dụng và xác định đầy đủ vấn đề để tập hợp đội ngũ đánh giá vấn đề đó. Bổ nhiệm các cá nhân và các đối tác liên quan, bổ nhiệm các bên tham gia của mỗi tổ chức vào nhóm xây dựng phân mềm. Đầu ra của giai đoạn này là một bản ghi hoặc một tài liệu chính thức chỉ ra các nguồn tài trợ, xác định vấn đề các bên tham gia. Giai đoạn nghiên cứu tính khả thi Tính khả thi có được từ kết quả phân tích các rủi do, chi phí và lợi nhuận liên quan đến các vấn đề kinh tế, kỹ thuật và tổ chức của người sử dụng. Các vấn đề đặt ra phải được xem xét chi tiết để đảm bảo rằng mọi khía cạnh của tính khả thi đã được xem xét đến. Báo các tổng quát về tính khả thi bao gồm: - Vấn đề đặt ra. - Tính khả thi về mặt kinh tế, kỹ thuật và tổ chức. - Những rủi ro và bất ngờ liên quan đến ứng dụng. - Ý tưởng thích hợp nhất về sản phẩm phần mềm và giải thích tại sao nó tốt hơn các sản phẩm khác cùng loại. - Các cầu huấn luyện và lịch trình dự định. - Dự đoán nhân sự cho dự án tính theo từng giai đoạn và mức độ yêu cầu. Giai đoạn phân tích. * Yêu cầu về chức năng hệ thống được thiết kế để làm gì? Khuân dạng các định nghĩa này vào phương pháp luận sử dụng trong giai đoạn phân tích. - Yêu cầu về cấu hình – các thiết bị cuối, các thông điệp, thời gian trả lời của mạng, dung lượng vào/ ra, yêu cầu thời gian sử lý. - Yêu cầu về giao diện - dữ liệu trao đổi với các ứng dụng và đơn vị khác là gì? định nghĩa bao gồm cả tính thời gian, khuôn dạng của dữ liệu trao đổi. - Các chuẩn xây dựng phần mềm - dạng cấu trúc, tính thời gian, nội dung cơ bản của tại liệu cần đưa ra trong quá trình xây dựng phần mềm. định dạng thông tin bao gồm nội dung của dữ liệu từ điển hay kho lưu trữ đối với việc thiết kế đối tượng, nội dung báo cáo dự án, các yêu cầu cần thiết khác được giám sát bởi nhóm tham gia dự án. Giai đoạn thiết kế ở mức quan niệm. Các cách gọi khác bao gồm thiết kế sơ bộ, thiết kế logic, thiết kế bên ngoài hay định danh các yêu cầu của phần mềm. Hoạt động chính của thiết kế quan niệm là định nghĩa chức năng chi tiết của tất cả các nhân tố bên ngoài của một chương trình ứng dụng, nó bao gồm màn hình hiển thị, báo cáo, đơn vị dữ liệu hội thoại, và các khuân mẫu. Cả nội dung và cách trình bày ở mức này. Hơn nữa, mô hình dữ liệu logic được chuyển sang sơ đồ cơ sở dữ liệu logic, hoặc các khung nhìn của người sử dụng. Giai đoạn thiết kế. * Những thuật ngữ khác dùng để miêu tả các hoạt động thiết kế bao gồm thiết kế chi tiết, thiết kế vật lý, thiết kế bên trong và thiết kế sản phẩm. Trong suốt giai đoạn thiết kế, kỹ sư phần mềm phải tạo, sưu tập tài liệu và kiểm tra. -Kiến trúc phần mềm: Định danh và định nghĩa chương trình, các khối độc lập, các chức năng, các luật, các đối tượng và các mối quan hệ giữa chúng. - Các thành phần và các khối của phần mềm: Định nghĩa một cách chi tiết nội dung và các chức năng của thành phần, bao gồm đầu vào\ra, sự hiển thị, báo cáo, dữ liệu, các file, các kết nôi và các tiến trình. - Giao diện: Nội dung chi tiết, tính toán thời gian, với trách nhiệm cụ thể, và thiết kế dữ liệu được trao đổi với những ứng dụng hay tổ chức khác. - Kiểm tra: Xác định chiến lược, nhiệm vụ, và tính toán thời gian cho mọi loại hình kiểm tra cần được tiến hành. - Dữ liệu: Là việc xác định cách thể hiện vật lý của dữ liệu trên các thiết bị, và các yếu tố yêu cầu, tính toán thời gian, nhiệm vụ phân giã, sao chép các bản sao dữ liệu. Giai đoạn thiết kế hệ thống. - Cấu trúc điều khiển trình ứng dụng: Xác định bằng cách nào một chương trình hay một khối độc lập được kích hoạt và nó sẽ về đâu khi kết thúc. - Cấu trúc dữ liệu và sơ đồ cài đặt vật lý: Trong môi trường Cơ sở dữ liệu, hoạt động này bao gồm việc sác định một thư viện dữ liệu tập trung, các đường hộp thoại, và vùng đệm cho việc sử dụng hệ quản trị dữ liệu. - Định kích thước: Xác định bất kỳ một trương trình và vùng đệm mà nó dự tính như là một bộ nhớ trú ngụ đối vói chế độ trực tiếp hay các tiến trình theo thời gian thực. - Thuật toán chính: Chỉ ra các vấn đề toán học cho phép kiểm tra một cách độc lập tính đúng đắn của công thức. - Các thành phần của chương trình: Định danh, tên, và tính chất sử dụng. Về mặt thể hiện tính chất bao gồm các thủ tục dữ liệu, các thủ tục, khối khác có thể bị gọi trong quá trình sử lý của khối này, kích thước hang đợi, vùng đệm và các yêu cầu của tiến trình. Giai đoạn triển khai: Việc thực hiện triển khai còn được gọi là cài đặt và cho phép sử dụng. Triển khai là quá trình một sản phẩm phần mềm được tích hợp vào môi trường làm việc và cho phép sử dụng. Thực hiện triển khai bao gồm sự hoàn chỉnh của chuyển đổi dữ liệu, cài đặt và đào tạo sử dụng. Vào thời điểm này của chu trình một dự án quá trình phát triển phần mềm kết thúc, và giai đoạn bảo hành, bảo trì bắt đầu. Việc bảo trì tiếp tục cho đến khi dự án kết thúc. Giai đoạn vận hành và bảo trì. Vận hành và bảo trì là một giai đoạn trong quá trình sản xuất phầm mềm ở đó sản phẩm phần mềm được sử dụng trong môi trường làm việc, giám sát đối với hiệu quả thống kê, và sửa đổi nếu cần thiết. Giai đoạn loại bỏ. Đây là giai đoạn trong quá trình sản xuất phần mềm mà tại đó việc cung cấp sản phẩm phần mềm kết thúc. Thông thường, các chức năng của sản phẩm phần mềm được chuyển tới một hệ thống kế tiếp. Các hoạt động thường xuyên. Có hai hoạt động phổ biến trong mỗi giai đoạn là: Kiểm kê, phê chuẩn và quản lý cấu hình. Tổng kết mỗi giai đoạn là sự kiểm tra phê chuẩn. Đó chính là mục tiêu của sản phẩm. Việc kiêm tra đưa ra khuân mẫu đúng đắn tương ứng giữa sản phẩm phần mềm và đặc tính của nó. Sự phê chuẩn đưa ra chuẩn mực về sự phù hợp hay chất lượng của sản phẩn phần mềm đối với mục đích của quá trình sử dụng. Một người quản lý dự án được chỉ định nắm giữ phiên bản chính của mỗi sản phẩm. CHƯƠNG 3: PHÂN TÍCH THIẾT KẾ HỆ THỐNG QUẢN LÍ NHÂN SỰ TẠI CÔNG TY CỔ PHÂN PHẦN MỀM QUẢN TRỊ DOANH NGHIỆP - CYBERSOFT I. Phân Tích Hệ Thống 1. Mục Đích Của Hệ Thống Nhằm mục đích để giúp cho công việc của nhân viên quản lí nhân sự tại công ty được diễn ra nhanh chóng và thuận tiện, giúp cho nhân viên cũng như giám đốc biết được tình trạng nhân viên trong công ty cũng như nhân viên biết nhau và gắn bó với nhau hơn. Chương trình giúp cho vệc lưu trữ và quản lí toàn bộ hồ sơ của nhân viên và toàn bộ thành viên trong công ty như: sơ yếu lí lịch, các thông tin về đào tạo, công tác, về xuất thân về thành phân gia đình… Chương trình đưa ra được báo cáo đầy đủ về các nhân viên một cách khoa học. Có thể tìm kiếm nhanh chóng và thuận tiện. Cập nhật bổ sung các thành phần dữ liệu của nhân viên, thành viên trong công ty một cách nhanh chóng và đơn giản. Ngoài ra chương trình còn đang hoàn thiện về quản lí lương của cán bộ công nhân viên trong công ty. Qua đây ta có thể phát triển chương trình thành một chương trình lớn có thể cung cấp cho người sử dụng nhiều mục đích và yêu cầu khác nhau. 2. Sơ Đồ Chức Năng Các chức năng gồm có: Thông tin về nhân viên. Chỉnh sửa thông tin về nhân viên. Tìm kiếm Báo cáo QUẢN LÍ NHÂN SỰ 1. Lập danh mục cơ sở 2. Chỉnh sửa thông tin nhân viên 3. Tìm kiếm nhân viên 4. Lên các báo cáo 2.1 Thêm nhân viên mới 2.2 Chỉnh sửa nhân viên đã có Sơ đồ chức năng Sơ đồ phân rã chức năng lập danh mục cơ sở 1.1 Danh mục bộ phận 1. Lập danh mục cơ sở 1.2 Danh mục bằng cấp 1.3 Danh mục cấp quyết định 1.4 Danh mục chức vụ 1.5 Danh mục chuyên ngành 1.6 Danh mục dân tộc 1.7 Danh mục hình thức đào tạo 1.8 Danh mục hình thức khen thưởng 1.9 Danh mục hình thức kỉ luật 1.10 Danh mục hình thức làm việc 1.11 Danh mục hình thức tuyển dụng 1.12 Danh mục kết quả đào tạo 1.13 Danh mục ngoại ngữ 1.14 Danh mục nhóm chức danh 1.15 Danh mục quan hệ gia đình 1.16 Danh mục trình độ chuyên môn 1.17 Danh mục trình độ chính trị 1.18 Danh mục trình độ ngoại ngữ 1.19 Danh mục trình độ tin học 1.20 Danh mục trình độ văn hóa 1.21 Danh mục tôn giáo 1.22 Danh mục tỉnh (TP) 1.23 Danh mục loại hợp đồng 1.24 Danh mục tình trạng hôn nhân 1.25 Danh mục bậc lương 1.26 Danh mục phụ cấp 1.27 Danh mục hệ số phụ cấp 1.28 Danh mục hệ số lương - Sơ đồ phân rã chức năng chính sửa thông tin nhân viên 2. Chỉnh sửa thông tin nhân viên 2.1 Thêm nhân viên mới 2.2 Chỉnh sửa nhân viên đã có - Sơ đồ phân rã chức năng tìm kiếm nhân viên 3. Tìm kiếm nhân viên Tìm kiếm nhân viên theo tên - Sơ đồ phân rã chức năng lên báo cáo 4.1 Báo cáo theo sơ yếu lí lịch 4.2 Báo cáo danh sách LĐ hết hợp đồng 4.3 BC theo quan hệ GĐ NV 4.4 BC theo quá trình khen thưởng 4.5 Theo quá trình công tác nước ngoài 4. Lên báo cáo 4.6 BC Tổng hợp tiền lương 4.7 D/S LĐ đóng bảo hiểm y tế 4.8 D/S LĐ đóng bảo hiểm xã hội 4.9 B/C Theo D/S nhân viên trong công ty 4.10 QT KT và CT nước ngoài 3. Sơ đồ ngữ cảnh Nhân viên Tin phản hồi Thông tin vào Quản lí nhân sự Hồ sơ nhân viên Bộ phận quản lí Thông tin Thông tin bổ sung Yêu cầu tìm kiếm Các phòng ban Thông tin nhân viên 3.1 Sơ đồi luồng dữ liệu mức 0 3.2 Sơ đồ luồng dữ liệu mức 1 - Lập danh mục - Cập nhật thông tin nhân viên - Tìm kiếm nhân viên 3.0 Tìm kiếm nhân viên Nhân viên Hồ sơ nhân viên Ban quản lí Thông tin nhân viên YC tìm kiếm YC Tìm kiếm Các phòng ban khác Thông tin tìm kiếm Thông tin tìm kiếm Danh mục Hồ sơ công tác - Tổng hợp báo cáo II. Thiết kế hệ thống 1. Thiết kế kiến trúc Quản lí nhân sự Quản lí hệ thống Thống kê báo cáo Quản lí kho dữ liệu Chương trình quản lí nhân sự về mặt kiến trúc gồm 3 khối chính đó là: Quản lí hệ thống, quản lí kho dữ liệu và đưa ra các thống kê báo cáo. Bộ phận quản lí nhân sự trong công ty có nhiệm vụ điều hành và quản lí toàn bộ hệ thống trong công ty: tất cá những vấn đề mà chương trình quản lí nhân sự đưa ra…cả lương và các chính sách bảo hiểm xã hội cũng như bảo hiểm y tế.Toàn bộ phần mềm còn thiếu nhưng sẽ được hoàn thành và cập nhật để trở thành một phần mềm hoàn thiện và đầy đủ. Trong kho dữ liệu là toàn bộ những thông tin vào, ra mà những nhân viên có từ khi vào doanh nghiệp. Từ những dữ liệu và những xử lí qua phần mềm thì nhân viên quản lí đưa ra được báo cáo cần thiết về nhân sự trong công ty cho ban giám đốc, cho nhân viên…và các bộ phận khác. 2. Thiết kế dữ liệu Dữ liệu của phần mềm bao gồm: hồ sơ nhân viên, danh mục hệ số lương, danh mục ngoại ngữ, danh mục tỉnh, danh mục trình độ văn hóa, danh mục trình độ tin học, danh mục bằng cấp… 2.1. Danh mục hồ sơ nhân viên Tên trường Kiểu trường Độ rộng Diễn giải MA_NV Character 8 Mã nhân viên HO Character 30 Họ TEN Character 18 Tên BI_DANH Character 48 Bí danh TEN_DUNG Character 48 Tên dùng NGAY_SINH Date 8 Ngày sinh NOI_SINH Character 48 Noi sinh GIOI_TINH Numeric 1 Giói tính ANH Character 128 Ảnh MA_DT Character 8 Mã đào tạo MA_CBQD Character 8 Mã cán bộ quyết định MA_CQD Character 8 Mã cấp quyết định MA_CN Character 8 Mã chuyên ngành học vị MA_HTDT Character 8 Mã hìng thức đào tạo MA_HTKL Character 8 Mã hình thức kỉ luật MA_HTKT Character 8 Mã hình thức khen thưởng MA_CTNN Character 8 Mã công tác nước ngoài MA_NN Character 8 Mã ngoại ngữ MA_QHGD Character 8 Mã quan hệ gia đình MA_TDCT Character 8 Mã trình độ chính trị MA_TDCM Character 8 Mã trình độ cách mạng MA_TDNN Character 8 Mã trình độ ngoại ngữ MA_TDTH Character 8 Mã trình độ tin học MA_TDVH Character 8 Mã trình độ văn hóa MA_TINH Character 8 Mã tỉnh MA_HUYEN Character 8 Mã huyện MA_TG Character 8 Mã tôn giáo QUE_QUAN Character 48 Quê quán HO_KHAU Character 48 Hộ khẩu NOI_O Character 48 Nơi ở DT Character 16 Điện thoại DT_NR Character 16 Điện thoại nhà riêng FAX Character 16 Số Fax MOBILE Character 16 Số Mobile EMAIL Character 32 Địa chỉ Email SO_CMND Character 16 Số chưng minh NGAY_CMND Date 8 Ngày cấp cntnd NOI_CMND Character 25 Noi cấp chứng minh HO_CHIEU Character 16 Hộ chiếu NGAY_HC Date 8 Ngày cấp NOI_HC Character 48 Nơi cấp HAN_HC Date 8 Hạn hộ chiếu CHIEU_CAO Numeric 5 Chiều cao CAN_NANG Numeric 4 Cân nặng NHOM_MAU Character 2 Nhóm máu TP_GD Character 48 Thành phân gia đình TP_BT Character 48 Thành phâần bản thân NGAY_CM Date 8 Ngày tham gia cách mạng NGAY_TL Date 8 Ngày thoát li NGAY_NN Date 8 Ngày nhập ngũ NGAY_XN Date 8 Ngày xuất ngũ LOAI_TB Character 8 Loại thương binh NGAY_DBDA Date 8 Ngày dự bị đảng NGAY_VDA Date 8 Ngày vào đảng NOI_VDA Character 48 Nơi vào đảng NGUOI_GT Character 48 Người giới thiệu CHUC_VUDA Character 8 Chức vụ đảng SO_THEDA Character 8 Số thẻ đảng NGAY_CTDA Date 8 Ngày cấp thẻ đảng NOI_CTDA Character 48 Nơi cấp thẻ đảng NGAY_VDO Date 8 Ngày vào đoàn NOI_VDO Character 48 Nơi vào đoàn CHUC_VUDO Character 8 Chức vụ đoàn NGAY_VCD Date 8 Ngày vào công đoàn CHUC_VUCD Character 8 Chức vụ công đoàn SO_THECD Character 16 Số thẻ công đoàn NGAY_CTCD Date 8 Ngày cấp thẻ công đoàn NOI_CTCD Character 10 Nơi cấp thẻ công đoàn MA_DVCS Character 8 Mã đơn vị cơ sở MA_BP Character 8 Mã bộ phận MA_CV Character 8 Mã chức vụ SO_HD Character 8 Số hợp đồng NGAY_KYHD Date 8 Ngày kí hợp đồng NGAY_BN Date 8 Ngày bổ nhiê,rj QD_SO Character 8 Quyết định số MA_HV Character 8 Mã học vị MA_CN_HV Character 8 Mã chuyên ngành học vị NGAY_HV Date 8 Ngày bảo vệ học vik MA_HH Character 8 Mã học hàm MA_CN_HH Character 8 Mã chuyên ngành học hàm NGAY_HH Date 8 Ngày bảo vệ học hàm NGAY_TINHL Date 8 Ngày tính lương MA_BACL Character 8 Mã bậc lương TG_TANGL Date 8 Thời gian tăng lương SO_BHXH Character 16 Số bảo hiểm xã hội NGAY_BHXH Date 8 Ngày bảo hiểm xã hội NOI_BHXH Character 16 Nơi bảo hiểm xã hội SO_BHYT Character 16 Số bảo hiễm xã hội NGAY_BHYT Date 8 Ngày bảo hiểm y tế NOI_BHYT Character 16 Nơi bảo hiểm y tế NGHI_VIEC Logical 1 Nghỉ việc NGHI_HUU Logical 1 Nghỉ hưu NGAY_NV Date 8 Ngày nghỉ việc HS_LUONG Numeric 5 Hệ số lương 2.2. Danh mục hệ số lương Tên trường Kiểu trường Độ rộng Diễn giải NGAY_HL Date 8 Ngày hiệu lực HE_SO Numeric 8 Hệ số 2.3. Danh mục ngoại ngữ Tên Trường Kiểu trường Độ rộng Diễn giải MA_NN Character 8 Mã ngoại ngữ TEN_NN Character 48 Tên ngoại ngữ TEN_NN2 Character 48 Tên ngoại ngữ 2 2.4. Danh mục trình độ văn hóa Tên Trường Kiểu trường Độ rộng Diễn giải MA_TINH Character 8 Mã Tỉnh TEN_TINH Character 48 Tên tỉnh TEN_TINH2 Character 48 Tên tỉnh 2 2.5. Danh mục trình độ tin học Tên Trường Kiểu Trường Độ rộng Diễn giải MA_TDTH Character 8 Mã trình độ tin học TEN_TDTH Character 48 Tên trình độ tin học TEN_TDTH2 Character 48 Tên trình độ tin học 2 2.6. Danh mục bằng cấp Tên Trường Kiểu trường Độ rộng Diễn giải MA_BC Character 8 Mã bằng cấp TEN_BC Character 48 Tên bằng cấp TEN_BC2 Character 48 Tên bằng cấp 2 2.7. Danh mục tôn giáo Tên Trường Kiểu trường Độ rộng Diễn giải MA_TG Character 8 Mã tôn giáo TEN_TG Character 48 Tên tôn giáo TEN_TG2 Character 48 Tên tôn giáo 2 2.8. Danh mục học vị Tên Trường Kiểu trường Độ rộng Diễn giải MA_HV Character 8 Mã học vị TEN_HV Character 48 Tên học vị TEN_HV2 Character 48 Tên học vị 2 2.9. Danh mục học hàm Tên Trường Kiểu trường Độ rộng Diễn giải MA_HH Character 8 Mã học hàm TEN_HH Character 48 Tên học hàm TEN_HH2 Character 48 Tên học hàm 2 3. Thiết kế thuật toán Thuật toán đăng nhập Kiểm tra mật khẩu Nhập mật khẩu Kiểm tra tên Nhập tên người sử dụng Bắt đầu Người dùng chưa đăng kí Sai Đúng Đúng Sai Vào chương trình Thoát 4. Thiết kế giao diện 4.1. Form đăng nhập 4.2. Giao diện chính 4.3. Form lí lịch nhân viên 4.3. Form mẫu báo cáo sơ yếu lí lịch KẾT LUẬN Hệ thống thông tin quản lí nhân sự có một vai trò quan trọng trong hoạt động kinh doanh của bất kỳ một doanh nghiệp nào dù quy mô lớn hay nhỏ và đặc biệt quan trọng đối với công ty cổ phần lớn như công ty cổ phần phần mềm quản trị doanh nghiệp. Nó là một khâu quan trọng trong quá trình kinh doanh của công ty và nó góp phần vào sự phát triển của công ty không chỉ trong giai đoạn hiện tại và cả trong tương lai. Hệ thống quản lí nhân sự tại công ty cổ phần phần mềm quản trị doanh nghiệp – CyberSoft do em viết đã hoạt động khá tốt, nó đã một phần giúp cho nhà quản lí nhanh nhậy trong vấn đề quản lí nhân viên trong công ty. Đã cập nhật được thông tin của nhân viên, thêm nhân viên, chỉnh sửa thông tin nhân viên…từ đó đưa ra được báo cáo cho ban quản lí và các bộ phận khác trong công ty. Tin học ngày càng phát triển như hiện nay thì việc đưa công nghệ vào áp dụng trong công ty, các doanh nghiệp là điều cần thiết…và phần mềm này cũng là một trong số những phần mềm minh chứng cho điều đó. Thay vì quản lí nhân viên bằng sổ sách, thay vì mất nhiều nhân viên quản lí, mất nhiều thời gian thì nay chỉ với phần mềm này công việc đó đã đơn giản đi rất nhiều. Chương trình hệ thống quản lí nhân sự tại công ty cổ phần phần mềm quản trị doanh nghiệp – CyberSoft đang trên con đường hoàn thiện và bổ sung một số đặc tính khác như: tính lương và đưa ra báo cáo về lương, tình hình công tác và một số điều nhắc nhở nhân viên cũng như định hướng làm việc cho nhân viê cụ thể. Do thời gian thực tập có hạn và do hạn chế kiến thức của bản thân nên chương trình và báo cáo đã hòan thành nhưng chưa được tốt nhất và cũng có nhiều hạn chế chưa như mong muốn …trong thời gian tới em sẽ cố gắng hoàn thiện thật tốt. Em xin chân thành cảm ơn thầy Nguyễn Anh Phương đã hướng dẫn tận tình cho em trong cả quá trình thực tập. Em xin chân thành cảm ơn anh Lê Cảnh Toàn là giám đốc công ty cổ phần phần mềm quản trị doanh nghiệp - CyberSoft đã tạo điều kiện thuận lợi cho em đến thực tập tại công ty và hướng dẫn em thực tập cũng như làm việc tại công ty. DANH MỤC TÀI LIỆU THAM KHẢO Ngôn ngữ và ứng dụng Foxpro 7.0 Giáo trình Visual foxpro 7.0, 9.0 Các câu lệnh foxpro Ví dụ và bài tập Foxpro 7.0 5 Cơ Sở Dữ Liệu 1 và 2 Trần Công Uẩn – Nhà xuất bản Thống Kê 6 Hệ Thống thông tin quản lý T.S Trương Văn Tú –T.S Trần Thị Song Minh- Nhà xuất bảnThống Kê 7 Cấu trúc Dữ Liệu và Giải Thuật PGS.TS Hàn Viết Thuận – Nhà xuất bản thống kê 8 Tự học Microfsoft Access 2000 Nhà xuất bản Thống Kê 9 Một số website http:\\ google.com, ddtinhoc.com… 10 Bài giảng Công nghệ phần mềm của PGS TS Hàn Viết Thuận. 11 Giáo trình tin học đại cương 12 Giáo trình tin học ứng dụng PHỤ LỤC Code Cap nhat danh muc chuc vu * Danh sach cac procedure va cac function * Dmcv_F3 Sua/them moi mot chuc vu * Dmcv_F8 Xoa mot chuc vu * V_Nhan Luu chuc vu * =========================== Procedure: Dmcv ===========================* * Cap nhat danh muc chuc vu IF .F. _REFOX_ = (9876543210) ENDIF SELECT 0 USE (K_Cod + [Dmcv] + M_Nam) ORDER Ma_cv ALIAS M_Dmcv ON KEY LABEL F3 DO Dmcv_F3 WITH [S] ON KEY LABEL F4 DO Dmcv_F3 WITH [M] ON KEY LABEL F8 DO Dmcv_F8 _fTen = IIF(m_Lan = "V", "Ten_cv", "Ten_cv2") _fTen2 = IIF(m_Lan = "V", "Ten_cv2", "Ten_cv") BROWSE; FIELDS ; Ma_cv, &_ften :64,; &_ften2 :64, ; Date, Time, User_Id, Date0, Time0, User_Id0 ; NAME oBrowse; NOAPPEND NOMODIFY NOWAIT; WHEN Change_Color_Of_Browse(RecNo()); WINDOW M_WinBrw ; TITLE M_Prompt + IIF(m_Lan = 'V', [. F3-Sua, F4-Them, F8-Xoa, ^F/G-Tim, Esc-Quay ra], ECode2String('dmcv0002')) Obrowse.readonly = .T. BROWSE LAST Tbrupdate.Hide ON KEY LABEL F3 ON KEY LABEL F4 ON KEY LABEL F5 ON KEY LABEL F8 USE IN M_Dmcv RETURN * ........................... Procedure: Dmcv_F3 ........................* * Object: Dmcv_F3 PROCEDURE Dmcv_F3 PARAMETER _Moi_Sua PRIVATE m.Ma_cv, m.Ten_cv, M.Date0,M.Time0,M.User_id0,M.Time, M.Date, M.User_Id,M.Status; _Col, _OrderVv,_OrderStt,_Inselect,_Used,_UsedNH,_UsedNt,; M.Kho_Ck, _RecNo, _Prompt, M.Kho_DL, M.Han_Tt,; m.ten_nh_Vv1,m.ten_nh_Vv2,m.ten_nh_Vv3, _loai_nh _InSelect = SELECT() PUSH KEY CLEAR IF _Moi_Sua=[S] AND RECNO() > RECCOUNT([M_Dmcv]) POP KEY SELECT (_InSelect) RETURN ENDIF DO SAVE_MEMVAR_CT WITH [M_Dmcv] SELECT M_Dmcv _Ma_cv = Ma_cv IF _Moi_Sua = [S] SCATTER MEMVAR MEMO ELSE SCATTER MEMVAR BLANK M.Ma_cv = _Ma_cv ENDIF _RecNo = RECNO() M.Ma_cvOld = M.Ma_cv _Prompt = IIF(_Moi_Sua=[M], IIF(m_Lan = 'V', [Them ], [Add ]), IIF(m_Lan = 'V', [Sua ] , [Edit ])) M.Nhan_Huy = 1 M.Date0 = IIF(_Moi_Sua = [M], DATE(), M.Date0) M.Time0=IIF(_Moi_Sua = [M], Time(), M.Time0) M.User_Id0 = IIF(_Moi_Sua = [M], M_User_Id, M.User_Id0) ON KEY LABEL F10 KEYBOARD CHR(23) DO FORM (K_Screen + [dmcv-F3]) NAME _Dmcv LINKED ON KEY LABEL F10 POP KEY SELECT (_InSelect) DO REST_MEMVAR_CT RETURN *........................... FUNCTION V_Nhan ............................ FUNCTION V_Nhan PARAMETER _OrdOld PRIVATE _Tk_Used, _i, _Ma_cv_Len, _Order SELECT M_Dmcv IF LASTKEY()=27 OR M.Nhan_Huy # 1 IF _RecNo <= RECCOUNT([M_Dmcv]) GO _RecNo ENDIF RETURN ENDIF IF EMPTY(M.Ma_cv) MsgBox(IIF(m_Lan = 'V', [Chua vao ma chuc vu!], ECode2String('dmcv0005')),16+0+0,M_Cyber_Ver) M.Nhan_huy = 0 RETURN ENDIF IF EMPTY(M.Ten_cv) MsgBox(IIF(m_Lan = 'V', [Chua vao ten chuc vu!], ECode2String('dmcv0006')),16+0+0,M_Cyber_Ver) M.Nhan_huy = 0 RETURN ENDIF *! Kiem tra M.Ma_cv $ M_Dmcv.Ma_cv _CodExist = .F. IF _Moi_Sua = [M] IF SEEK(ALLTRIM(M.Ma_cv)) _CodExist = .T. ENDIF ELSE && Neu sua IF SEEK(ALLTRIM(M.Ma_cv)) IF (RECNO() # _RecNo) _CodExist = .T. ELSE IF !EOF() SKIP IF Ma_cv = ALLTRIM(M.Ma_cv) _CodExist = .T. ENDIF ENDIF ENDIF ENDIF ENDIF *! Kiem tra M_Dmcv.Ma_cv $ M.Ma_cv IF (M.Ma_cv # M.Ma_cvOld) &&.AND.(!EMPTY(M.TkOld)) _Ma_cv_Len = FSIZE([Ma_cv], [M_Dmcv]) FOR _i = 1 TO LEN(ALLTRIM(M.Ma_cv)) *IF SEEK(PADR(LEFT(M.Ma_cv, _i), _Ma_cv_Len)).OR.(M.Ma_cv = ALLTRIM(Ma_cv)) IF SEEK(PADR(LEFT(M.Ma_cv, _i), _Ma_cv_Len)) IF ((_Moi_Sua = [M]) .OR. (RECNO() # _RecNo)).AND.(!EOF()) _CodExist = .T. ENDIF ENDIF NEXT ENDIF IF _CodExist MsgBox(IIF(m_Lan = 'V', [Ma da co hoac ma long nhau!], ECode2String('dmcv0007')),16+0+0,M_Cyber_Ver) M.Nhan_huy = 0 RETURN ENDIF IF _Moi_Sua = [M] M.Time0 = Time() M.Date0 = DATE() M.User_Id0 = M_User_Id ENDIF M.Time = Time() M.Date = DATE() M.User_Id = M_User_Id IF (_Moi_Sua=[S]) .AND. (M.Ma_cv==M.Ma_cvOld) &&.AND. (M.Tk == M.TkOld) SELECT M_Dmcv GO _RecNo GATHER MEMVAR MEMO FLUSH UNLOCK IN M_Dmcv ELSE SELECT M_Dmcv _OrdOld = ORDER() SET ORDER TO Ma_cv SEEK M.Ma_cv IF FOUND() MsgBox(IIF(m_Lan = 'V', [Ma da co!], ECode2String('dmcv0008')),16+0+0,M_Cyber_Ver) M.Nhan_huy = 0 RETURN ENDIF SET ORDER TO &_OrdOld IF _Moi_Sua = [M] APPEND BLANK ELSE GO _RecNo ENDIF GATHER MEMVAR MEMO FLUSH UNLOCK IN M_Dmcv ENDIF _RecNo = RECNO() SELECT M_Dmcv GO _RecNo _Dmcv.Release RETURN *.................... PROCEDURE Dmcv_F8 ..................... PROCEDURE Dmcv_F8 PRIVATE _CoKhong, _Ans, _RecNo SELE M_Dmcv IF RECNO() > RECCOUNT([M_Dmcv]) RETURN .T. ENDIF SCATTER MEMVAR _RecNo = RECNO() _Ans = MsgBox(M_SureDele, 4+32+256, M_Cyber_Ver) IF _Ans # 6 GO _Recno RETURN .T. ENDIF IF !V_F8(M.Ma_cv,"CDVV , CT00" , "Ma_cv , Ma_cv") msgbox("®· cã ph¸t sinh kh«ng ®­îc xo¸",16,M_Cyber_Ver) GO _Recno RETURN ENDIF M.Time = Time() M.Date = DATE() M.User_Id = M_User_Id M.Status="*" GATHER MEMVAR FLUSH DELETE RETURN .T. Code do c.prg IF .F. _REFOX_ = (9876543210) ENDIF PROGDIR = SYS(16) PROGDIR = "'" + LEFT(PROGDIR, RAT("\", PROGDIR)) + "'" SET DEFAULT TO &progdir DO ../Prog/startup.fxp ENDPROC Code startup *---------------------------------------------------------------------------------------------* *!* DATE : 10/02/2008 *!* Author : anhhungclau *!* Name : anhhungclau *---------------------------------------------------------------------------------------------* IF .F. _REFOX_ = (9876543210) ENDIF IF NOT "07" $ VERSION() WAIT "Phien ban chay tren Visual FoxPro 7 for Windows" WINDOW TIMEOUT 5 ON SHUTDOW QUIT ENDIF SET TALK OFF CLEAR SET STATUS BAR ON ON KEY CLEAR ALL CLOSE ALL SET CLASSLIB TO PUBLIC m_User_Name, m_User_ID, m_User_Pass, m_Is_Admin, m_Rights, m_User_Pre,; K_Image,K_picture,K_Cod,K_Data,K_Copy,K_Data_mau,K_Data_Xoa,K_Demo,K_Fonts,K_Lib,K_Prog,; K_Repo,K_repo_nt,K_Screen,K_System,K_Tran,K_Update,k_Backup,K_Tmp,K_Excel,M_LAN,M_Ma_dvcs,; M_NAM,_IdEn,m_Voucher,M_Ngay_Cuoi_Nam,m_Ngay_dau_nam, M_ngay_dk, M_ngay_ck,m_Nam0,m_ngay_ks,; M_dele_YN, M_is_dright,_isLostfocus, reccountOfPhtmp,_KT _isLostfocus = .F. _KT = .F. reccountOfPhtmp = 0 M_NAM = '' M_LAN = '' m_Nam0 = '' m.Ma_dvcs = "" m_Root = "..\" M_is_dright = "" DO Set_sys_paths && Tao dung dan DO Set_env&& Tao moi truong * Sau khi set moi truong thi moi gan bien o day neu khong se bi loi vi ko nhan ra duoc moi truong M_Ngay_Cuoi_Nam = CTOD([31/12/9999]) m_Ngay_dau_nam = CTOD([01/01/1990]) DO Init_Company IN (k_Prog + "SMSysVar") && Init IniVar DO Init_iniVar IN (k_Prog + "SMSysVar") && Init IniVar DO Init_sysVar IN (k_Prog + "SMSysVar") && Init SysVar DO Init_options IN (k_Prog + "SMSysVar") && Init Options DO Initmem0 IN (k_Prog + "SMSysVar") && Lay gia tri ten cong ty, Dia chi .... IF M_IsUpdate = 1 DO (K_Prog + "Smupdate.fxp") ENDIF DO FMCheck IN (k_Prog + "smsysvar") CreateTempDir() IF NOT DIRECTORY('&K_Excel') MD &K_Excel ENDIF IF NOT DIRECTORY('&K_Copy') MD &K_Copy ENDIF SET CLASSLIB TO (k_Lib + "Startup.vcx") SET CLASSLIB TO (k_Lib + "Tbr") ADDITIVE tbrReports = CREATEOBJECT("tbrReport") tbrUpdate = CREATEOBJECT("tbrUpdate") tbrReports.Dock(0) tbrUpdate.Dock(0) SET HELP TO (K_System + "Cyber.chm") *+ For CodeMine SET LIBRARY TO (k_Lib + "CodeMine.fll") ADDITIVE DECLARE INTEGER GetSysColor IN user32.dll INTEGER nColorValue DECLARE INTEGER GetSystemDirectory IN Kernel32.dll STRING cBuffer, INTEGER nLength *+ End For CodeMine ON KEY LABEL F12 DO (k_Prog + "SMSuspend") ON SHUTDOWN DO End *!* ON ERROR DO (K_prog + "smerror") ; *!* WITH SUBSTR(SYS(16),RAT("\", SYS(16)) + 1),PROGRAM(),LINE(),ERROR(),MESSAGE() ON KEY LABEL ALT+Q DO Squit1 ON KEY LABEL F1 DO (K_Prog + "HELP") m_is_Report = 0 m_ScrRow = SROW() m_ScrCol = SCOL() SET SEPARATOR TO m_Num_Separator SET POINT TO m_Num_Point IF EMPTY(m_Ten_cty) WAIT WIND "Khong don vi nao su dung chuong trinh " TIME 2 ON SHUTDOWN QUIT ENDIF *!* DO (K_prog + "SMChkVar") 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(K_Image + "funny.ico") SET Procedure TO (K_prog+"SMLib.Fxp") SET Procedure TO (K_prog+"SMReports.Fxp") ADDITIVE _SCREEN.BACKCOLOR = RGB(58,110,165) _SCREEN.Icon = K_Image + "funny.ico" _SCREEN.Caption = ALLTRIM(Cat_Dau(m_Ten_CTy)) 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 HideToolbar() Initbars() DO SetResource m.Nam = "" STORE 0 TO _Check, m_User_id STORE .F. TO is_Admin USE (k_cod + "DmStt") ALIAS m_DmStt SHARED SELECT m_Dmstt IF _TALLY > 0 GOTO TOP M_Ngay_Ks = m_Dmstt.Ngay_KS ENDIF USE IN M_Dmstt *!* IF M_chk_date_yn = 0 &&Neu khong chon ngay dau ky va ngay cuoi ky *!* M_Ngay_dk = M_Ngay_dau_Nam *!* M_Ngay_ck = m_Ngay_cuoi_nam *!* ELSE *!* M_Ngay_dk = CTOD('01/'+ALLTRIM(STR(MONTH(DATE()),2))+[/]+ALLTRIM(STR(YEAR(DATE()),4))) *!* M_Ngay_ck = GOMONTH(M_Ngay_dk,1)-1 *!* ENDIF DO FORM (K_Screen+"SMLogin") TO lcFlgOK IF LASTKEY() = 27 ON SHUTDOWN QUIT ENDIF IF lcFlgOK DO InitPopupOfVoucher IN (K_prog + "sminitpopup") DO (K_prog+"SMMenu") ELSE ON SHUTDOWN QUIT ENDIF IF LASTKEY() 16 QUIT ENDIF RETURN *!* ---------------------------------------- *!* Procedure Set_Env *!* ---------------------------------------- Procedure Set_Env ON ERROR &&Enable Error handle *!* NUMLOCK(.T.) &&Enable Numlock mode\ SET AUTO OFF &&Don't flush data immediately SET BELL ON &&Enable bell SET CARRY OFF &&Don't carry value of current record to the new record when addnew SET CENT ON &&Display year with 4 character SET CLOCK STATUS &&Display clock to the status bar SET CONFIRM ON &&Don't exit textbox by typing last character, have to press Enter, tab or arrow keys SET DATE FRENCH &&ddmmyy SET DECI TO 4 &&Dung cho sele m_p_gia as gia SET DELETE ON &&InVisible deleted record SET DEVELO ON &&Compile before run program if any change SET ESCAPE OFF &&Don't interrupt program when press ESC SET EXACT OFF &&Don't compare 2 string exactly SET EXCLUSIVE OFF &&Use file in share mode SET HELP ON &&Enabale online help SET HOUR TO 24 &&Set system clock to 24 hours format SET NEAR ON &&Set record pointer to the closest record if seek or locate is not found SET REFRESH TO 1,1 &&Time to Update changes made by other user on network SET STAT BAR ON &&Enable Status bar SET SAFE OFF &&Overwrite existed file without MsgBox SET TALK OFF &&Don't display command result to screen SET UDFPARMS TO REFERENCE &&Pass parameter by reference CLEAR MACRO &&Clear all marco ENDPRO *!* ---------------------------------------- *!* Procedure Set_SYS_Paths *!* ---------------------------------------- Procedure Set_SYS_Paths K_Cod = m_Root + "Cod\" K_System = m_Root + "System\" K_Data = m_Root + "Data\" K_Data_Xoa = m_Root + "Data-Xoa\" K_Data_Luu = m_Root + "Data-Luu\" K_Data_Mau = m_Root + "Data-Mau\" K_Prog = m_Root + "Prog\" K_repo = m_Root + "Repo\" K_Repo_NT = m_Root + "Repo-Nt\" K_Backup = m_Root + "Backup\" k_Image = m_Root + "Image\" K_picture = m_Root + "Picture\" k_Screen = m_Root + "Screen\" K_Lib = m_Root + "Lib\" K_Demo = m_Root + "Demo\" K_Fonts = m_Root + "Fonts\" K_Tran = m_Root + "Tran\" K_Update = m_Root + "Update\" ENDPRO *!* ---------------------------------------- *!* Procedure Dir_Err_Hand *!* ---------------------------------------- Procedure Dir_Err_Hand PARAMETERS _p_Err_Num, _p_Err_Message, _p_Err_Message1, _p_Err_Program, _p_Err_Lineno IF _p_Err_Num = 1961 MsgBox("Cã lçi khi t¹o th­ môc lµm viÖc") MsgBox(m_Cyber_Ver + IIF(m_Lan = 'V', " KÕt thóc c«ng viÖc.", ECode2String('STARTUP0003'))) DO (K_prog + "SMQuit") ENDIF ENDPRO *!* ---------------------------------------- *!* Procedure Del_File *!* ---------------------------------------- Procedure Del_File IF VARTYPE(k_Tmp) = "U" RETURN ENDIF CLOSE DATA ALL _Skeleton = k_Tmp + "*.*" _File = SYS(2000, _Skeleton) DO WHILE !EMPTY(_File) _File = k_Tmp + _File IF UPPER(ALLTRIM(_File))UPPER(ALLTRIM(k_Tmp + 'Command.dbf')) DELETE FILE &_File ENDIF _File = SYS(2000, _Skeleton, 1) ENDDO RETURN *!* ---------------------------------------- *!* FUNCTION Cat_Dau *!* ---------------------------------------- FUNCTION Cat_Dau PARAMETERS _String1 &&, _Scode PRIVATE _Bked, _AscII _Bked = "¸¹µ¶· »¼½¾Æ¨ ÊË©ÇÈÉ èéê«ìíîãäåæëçßáâ¬ÏÐÑÌÎeÒÓÔÕÖª úûüýþ ïóôñò õö÷øù­ ×ØÜÝÞ ¡¢£¤¥§®¦" _ASCII = "aaaaa aaaaaa aaaaaa oooooooooooooooooeeeeeeeeeeee yyyyy uuuuu uuuuuu iiiii AAEOODdU" IF NOT EMPTY(_String1) _String2= CHRTRAN(_String1,_Bked,_AscII) ELSE _String2='' ENDIF RETURN _String2 *---------------------------------------------------------------* 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 *!* ---------------------------------------- *!* FUNCTION Squit1 *!* ---------------------------------------- FUNCTION Squit1 _SCREEN.BACKCOLOR=RGB(255,255,255) DO DEL_FILE CLEAR EVENTS _SFORM.Release IF FILE("RESET.fxp") DO RESET ENDIF IF FILE("KEY.fxp") DO KEY ENDIF RETURN *!* ---------------------------------------- *!* FUNCTION Initbars(subMen_id) *!* ---------------------------------------- FUNCTION Initbars(subMen_id) PRIVATE sSelect SET SYSMENU ON sSelect=SELECT() USE (m_root+'SYSTem\Command') ORDER Menu_id ALIAS Command SHARED SET FILTER TO LEFT(Menu_id,5) = "01.05" &&subMen_id GO TOP DO WHILE NOT EOF() cPadNum=LEFT(Command.Menu_id,2) pName="P"+CPadNum cPrompt=Cat_dau(RTRIM(Command.Bar)) DEFINE PAD (pName) OF _MSYSMENU PROMPT cPrompt COLOR SCHEM 3 FONT m_Font_Name,9 ON PAD(PName)OF _MSYSMENU ACTIVATE POPUP &PName DEFINE POPUP (PName) MARGIN RELATIVE SHADOW COLOR SCHEM 4 FONT m_Font_Name, 9 SKIP DO WHILE LEFT(Command.Menu_id,2)=CPadNum cBarNum=VAL(SUBSTR(Command.Menu_id,7,2)) cPrompt=RTRIM(Command.Bar) IF EMPTY(Command.Picture) DEFINE BAR (cBarNum) OF (pName) PROMPT cPrompt COLOR SCHEM 3 FONT m_Font_Name,9 ELSE DEFINE BAR (cBarNum) OF (pName) PROMPT cPrompt COLOR SCHEM 3 FONT m_Font_Name,9 PICTURE (K_Image + ALLTRIM(Command.Picture)) ENDIF Pcommand='DO RunCommand WITH "'+ALLTRIM(Procedure)+'"' ON SELECTION BAR (cBarNum) OF (PName) &PCommand SKIP ENDDO ENDDO *!* DEFINE BAR 96 OF (pName) PROMPT '\-' COLOR SCHEM 3 FONT m_Font_Name,9 *!* DEFINE BAR 97 OF (pName) PROMPT IIF(M_LAN = "V",'Chän ®¬n vÞ c¬ së','Options Unit') COLOR SCHEM 3 FONT m_Font_Name,9 *!* DEFINE BAR 98 OF (pName) PROMPT '\-' COLOR SCHEM 3 FONT m_Font_Name,9 *!* DEFINE BAR 99 OF (pName) PROMPT IIF(M_LAN = "V", 'Switch to English', 'ChuyÓn sang TiÕng ViÖt') COLOR SCHEM 3 FONT m_Font_Name, 9 PICTURE (K_Image + "option.bmp") *!* DEFINE BAR 100 OF (pName) PROMPT '\-' COLOR SCHEM 3 FONT m_Font_Name,9 DEFINE BAR 101 OF (pName) PROMPT IIF(M_LAN = "V", 'Tho¸t khái ch­¬ng tr×nh', 'Exit') COLOR SCHEM 3 FONT m_Font_Name, 9 PICTURE (K_Image + "close.bmp") *!* ON SELECTION BAR 97 OF (PName) do Optiondvcs *!* ON SELECTION BAR 99 OF (PName) do SwitchLanguage ON SELECTION BAR 101 OF (PName) QUIT USE in Command SELECT(sSelect) ENDFUNC *!* ---------------------------------------- *!* Procedure End *!* ---------------------------------------- Procedure End IF MsgBox(IIF(m_Lan = 'V', "KÕt thóc ch­¬ng tr×nh?", ECode2String('STARTUP0006')),36,m_Cyber_Ver)=6 DO (K_prog + "SMBackup") DO DEL_FILE QUIT ENDIF ENDPRO *!* ---------------------------------------- *!* FUNCTION CreateTempDir *!* ---------------------------------------- FUNCTION CreateTempDir IF EMPTY(k_Tmp) k_Tmp = ".\" + TRANS(m_User_ID, "@L 999") + "\" _Sys3 = (k_Tmp + SYS(3) + ".Tmp") _Handle = FCREATE(_Sys3) IF _Handle = -1 _currErr = ON ("ERROR") ON ERROR DO Dir_Err_Hand IN (K_prog + "SBALANCE") WITH ; ERROR( ), MESSAGE( ), MESSAGE(1), PROGRAM( ), LINENO( ) MD(".\" + TRANS(m_User_ID, "@L 999")) ON ERROR &_currErr ELSE = FCLOSE(_Handle) DELETE FILE &_Sys3 ENDIF ELSE _Sys3 = (k_Tmp + SYS(3) + ".Tmp") _Handle = FCREATE(_Sys3) IF _Handle = -1 _currErr = ON ("ERROR") ON ERROR DO Dir_Err_Hand IN (K_prog + "SBALANCE") WITH ; ERROR( ), MESSAGE( ), MESSAGE(1), PROGRAM( ), LINENO( ) MD(LEFT(k_Tmp, LEN(k_Tmp)-1)) ON ERROR &_currErr ELSE = FCLOSE(_Handle) DELETE FILE &_Sys3 ENDIF ENDIF RELEASE _Chk ENDFUNC *!* ---------------------------------------- *!* Procedure UpdateMenu(pMenu_id) *!* ---------------------------------------- Procedure UpdateMenu(pMenu_id) PRIVATE sSelect,IsUpdate IsUpdate=.T. sSelect=SELECT() SELECT 0 USE (K_System + 'command') ORDER Menu_id ALIAS Command IF EMPTY(pMenu_id) SEEK(m_Menu_id) ELSE SEEK(pMenu_id) ENDIF SCATTER MEMVAR PUSH KEY CLEAR DO FORM (K_Screen + 'SMmenu-f3') POP KEY IF IsUpdate GATHER MEMVAR ENDIF USE IN Command SELECT(sSelect) ENDPRO *!* ---------------------------------------- *!* Procedure RunCommand(sProcedure) *!* ---------------------------------------- Procedure RunCommand(sProcedure) _SFORM.Hide &sProcedure _SFORM.Show ENDPRO *!* ---------------------------------------- *!* Procedure SetResource *!* ---------------------------------------- Procedure SetResource PRIVATE oldError oldError = ON("ERROR") ON ERROR DO SetResourceError IF NOT FILE(GETENV('TEMP') + "\resource.dbf") COPY FILE (K_System + "resource.dbf") TO (GETENV('TEMP') + "\resource.dbf") COPY FILE (K_System + "resource.fpt") TO (GETENV('TEMP') + "\resource.fpt") ENDIF SET RESOURCE TO (GETENV('TEMP') + "\resource.dbf") ON ERROR &oldError ENDPRO *!* ---------------------------------------- *!* Procedure SetResourceError *!* ---------------------------------------- Procedure SetResourceError MsgBox("H·y kiÓm tra l¹i b¹n ®ang ch¹y ch­¬ng tr×nh", 31, m_Cyber_ver) ON SHUTDOWN QUIT ENDPROC *!........................... FUNCTION Re_Ask ............................. FUNCTION Re_Ask PRIVATE _Ds _Ds = 0 DO FORM (K_Screen + "SmReask") IF _Ds = 1 RETURN .T. ELSE RETURN .F. ENDIF ENDFUNC *!* ---------------------------------------- *!* FUNCTION Chuyen_ma *!* ---------------------------------------- FUNCTION Chuyen_ma PARAMETERS _String1 &&, _Scode PRIVATE _Bked, _AscII _Bked = "¸¹µ¶· »¼½¾Æ¨ ÊË©ÇÈÉ èéê«ìíîãäåæëçßáâ¬ÏÐÑÌÎeÒÓÔÕÖª úûüýþ ïóôñò õö÷øù­ ×ØÜÝÞ ¡¢£¤¥§¦®" _ASCII = "aaaaa aaaaaa aaaaaa oooooooooooooooooeeeeeeeeeeee yyyyy uuuuu uuuuuu iiiii AAEOODUd" IF NOT EMPTY(_String1) _String2= CHRTRAN(_String1,_Bked,_AscII) ELSE _String2='' ENDIF RETURN _String2

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

  • doc20744.doc