rem This is the Employee Payroll Record Entry Program %INCLUDE ALL.BAS dim n(2,20),k$(4,20) z5$="b:ep" z6$=z5$+"back":z7$=z5$+"size" repeat$="-----------------------------" fill$=" " l$="$$##,###.##":u$="##########":v$="####" for z=1 to 70:delim$=delim$+"=":next z false=0:true=-1 RESTORE 540 K$(4,1)="1 - NEW ENTRY":K$(4,2)="2 - EXAMINE EXISTING ENTRY" 550 K$(4,3)="3 - MODIFY EXISTING ENTRY" 560 K$(4,4)="4 - DELETE EXISTING ENTRY" 570 K$(4,5)="5 - CREATE NEW FILE":K$(4,6)="6 - CLEAR EXISTING FILE" 580 K$(4,7)="7 - BACK-UP AND SORT FILE":K$(4,8)="8 - LIST FILE" 590 K$(4,9)="9 - FINISHED" 1100 K$(1,1)="EMPLOYEE #":K$(1,2)="ACCT NUMBER":K$(1,3)="NAME" 1105 K$(1,4)="COMPANY":K$(1,5)="ADDRESS":K$(1,6)="CITY":K$(1,7)="STATE" 1110 K$(1,8)="ZIP CODE":K$(1,9)="PHONE (AAA) NNN NNNN" 1130 K$(1,10)="SOC SEC #":K$(1,11)="EMPLOYMENT DATE" 1132 K$(1,12)="TERMINATION DATE" 1135 K$(1,13)="MARITAL STATUS":K$(1,14)="HOURLY OR SALARIED (H OR S)" 1140 K$(1,15)="PAY PERIODS - W/B/S/M":K$(1,16)="NUMBER OF EXEMPTIONS" 1145 K$(1,17)="HOURLY RATE":K$(1,18)="HOURS THIS PERIOD" 1146 K$(1,19)="Q-T-D HOURS":K$(1,20)="Y-T-D HOURS" 1200 K$(2,1)="1 - EMPLOYEE #":K$(2,2)="2 - ACCT NUMBER":K$(2,3)="3 - NAME" 1205 K$(2,4)="4 - COMPANY":K$(2,5)="5 - ADDRESS":K$(2,6)="6 - CITY" 1206 K$(2,7)="7 - STATE" 1210 K$(2,8)="8 - ZIP CODE":K$(2,9)="9 - PHONE (AAA) NNN NNNN" 1230 K$(2,10)="10- SOC SEC #":K$(2,11)="11- EMPLOYMENT DATE" 1232 K$(2,12)="12- TERMINATION DATE" 1235 K$(2,13)="13- MARITAL STATUS":K$(2,14)="14- HMUR OR SALARY (H OR S)" 1240 K$(2,15)="15- PAY PERIODS - W/B/S/M":K$(2,16)="16- NUMBER OF EXEMPTIONS" 1245 K$(2,17)="17- HOURLY RATE" for z=1 to 17:read n(1,z):next z data 8,10,24,24,24,17,2,5,14,11,8,8,1,1,1,4,6 print clear$:print 1500 if end #1 then 6000 if end #2 then 15000 open z5$ recl 512 as 1 close 1 open z7$ as 2 read #2;z2,z3,flag close 2 1600 REM 1620 PRINT CLEAR$ if z2>z3 then print "*** OUT OF RECORD SPACE ***" PRINT "EMPLOYEE INFORMATION ENTRY PROGRAM" PRINT "----------------------------------" PRINT:PRINT "THERE ARE ";Z3;" AVAILABLE RECORDS" PRINT "OF THESE THERE ARE:";TAB(30);(Z3-Z2)+1;" RECORDS OPEN" PRINT ;TAB(30);Z2-1;" RECORDS USED" PRINT 1650 PRINT "THIS IS A LIST OF OPERATIONS." 1655 PRINT 1660 FOR Z=1 TO 9:PRINT K$(4,Z):NEXT Z:PRINT 1665 PRINT "INDICATE WHAT YOU WOULD LIKE TO DO BY TYPING" 1670 PRINT "THE CORRESPONDING NUMBER." 1675 PRINT 1680 INPUT Z IF Z<1 OR Z>9 then 1620 1682 IF Z=1 THEN new$="N" 1685 ON Z GOSUB 2000,3000,4000,5000,6000,7000,8000,9000,10000 1690 FOR Z=1 TO 20:N(2,Z)=0:N(0,Z)=0:NEXT Z 1695 N$="":new$="" 1700 FOR Z=1 TO 20:K$(3,Z)=" ":NEXT Z 1705 GOTO 1600 2000 PRINT clear$:PRINT 2005 PRINT "RECORD NUMBER";z2:PRINT 2015 FOR Z=1 TO 2 PRINT CUR$ 2020 PRINT TAB(30);left$(repeat$,n(1,z)) PRINT UP$; 2025 PRINT K$(1,Z);TAB(30); 2030 INPUT N(2,Z):PRINT chr$(13) PRINT CLEAR$ 2035 NEXT Z 2040 FOR Z=3 TO 15 PRINT CUR$ 2045 PRINT TAB(30);left$(repeat$,n(1,z)) PRINT UP$; 2050 PRINT K$(1,Z);TAB(30); 2055 INPUT line K$(3,Z):PRINT chr$(13) if len(k$(3,z))>n(1,z) then k$(3,z)=left$(k$(3,z),n(1,z)) 2060 I=(N(1,Z)-LEN(K$(3,Z))):K$(3,Z)=K$(3,Z)+left$(fill$,i) PRINT CLEAR$ 2065 NEXT Z 2066 N$="" 2070 FOR Z=3 TO 15:N$=N$+K$(3,Z):NEXT Z 2075 FOR Z=16 TO 17 PRINT CUR$ 2080 PRINT TAB(30);left$(repeat$,n(1,z)) PRINT UP$; 2085 PRINT K$(1,Z);TAB(30); 2090 INPUT N(2,Z):PRINT chr$(13) PRINT CLEAR$ 2095 NEXT Z 2100 Z1=Z2 2105 PRINT clear$; 2110 PRINT "RECORD NUMBER";z1;TAB(31); 2112 PRINT "1 - EMPLOYEE #";TAB(46);:print using u$;n(2,1) 2114 PRINT "2 - ACCT NUMBER";TAB(18);:print using u$;n(2,2); 2116 PRINT TAB(31);"3 - NAME";TAB(46);K$(3,3) 2118 PRINT TAB(31);"4 - COMPANY";TAB(46);K$(3,4) 2120 PRINT TAB(31);"5 - ADDRESS";TAB(46);K$(3,5) 2122 PRINT TAB(31);"6 - CITY";TAB(46);K$(3,6) 2124 PRINT TAB(31);"7 - STATE";TAB(46);K$(3,7);TAB(51);"8 - ZIP"; 2126 PRINT TAB(61);K$(3,8) 2128 PRINT "9 - PHONE";TAB(16);K$(3,9);TAB(31);"10- SOC SEC #"; 2130 PRINT TAB(46);K$(3,10) 2132 PRINT "11- EMPLOYED";TAB(16);K$(3,11);TAB(31);"12- TERMINATED"; 2134 PRINT TAB(46);K$(3,12) 2136 PRINT "13- MARITAL";TAB(16);K$(3,13);TAB(31);"14- HOUR OR SA"; 2138 PRINT TAB(46);K$(3,14) 2140 PRINT "15- PAY PERIOD";TAB(16);K$(3,15);TAB(31);"16- # OF EXEM"; 2142 PRINT TAB(46);:print using v$;n(2,16);:PRINT TAB(51);"17- RATE"; print using l$;n(2,17) print delim$ 2146 PRINT TAB(16);"CURRENT";TAB(36);"QUARTER TO DATE";TAB(56);"YEAR TO DATE" print "Hours";tab(16); print using u$;n(2,18);tab(36);n(2,19);tab(56);n(2,20) print "Gross Pay";tab(16); print using l$;n(0,1);tab(36);n(0,2);tab(56);n(0,3) print "FICA";tab(16); print using l$;n(0,4);tab(36);n(0,5);tab(56);n(0,6) print "Fed Tax";tab(16); print using l$;n(0,7);tab(36);n(0,8);tab(56);n(0,9) print "State Tax";tab(16); print using l$;n(0,10);tab(36);n(0,11);tab(56);n(0,12) print "SDI";tab(16); print using l$;n(0,13);tab(36);n(0,14);tab(56);n(0,15) print "Misc Ded";tab(16); print using l$;n(0,16);tab(36);n(0,17);tab(56);n(0,18) 2175 INPUT "IF AN ITEM IS TO BE CHANGED, TYPE THE NUMBER - ELSE 18 ";Z 2176 IF Z>17 THEN 2216 2177 IF Z<1 THEN 2105 2178 IF Z>2 AND Z<16 THEN 2200 2180 PRINT TAB(30);left$(repeat$,n(1,z)) PRINT UP$; 2185 PRINT K$(1,Z);TAB(30); 2190 INPUT N(2,Z) 2195 GOTO 2225 2200 PRINT TAB(30);left$(repeat$,n(1,z)) PRINT UP$; 2205 PRINT K$(1,Z);TAB(30); 2210 INPUT line K$(3,Z) if len(k$(3,z))>n(1,z) then k$(3,z)=left$(k$(3,z),n(1,z)) 2215 I=(N(1,Z)-LEN(K$(3,Z))):K$(3,Z)=K$(3,Z)+left$(fill$,i) 2216 N$="" 2217 FOR I=3 TO 15:N$=N$+K$(3,I):NEXT I 2225 INPUT "ANY MORE CHANGES";line temp$ 2230 IF left$(temp$,1)="y" OR left$(temp$,1)="Y" THEN 2105 2235 PRINT 2240 INPUT "IS RECORD TO BE ENTERED";line temp$ 2245 PRINT 2250 IF left$(temp$,1)="y" OR left$(temp$,1)="Y" THEN 2280 2255 IF left$(temp$,1)<>"n" AND left$(temp$,1)<>"N" THEN 2235 2260 PRINT clear$:PRINT 2270 PRINT "*** RECORD NOT ENTERED ***":PRINT:PRINT 2275 FOR Z=1 TO 200:NEXT Z:RETURN 2280 open z5$ recl 512 as 1 print #1,z1;N(2,1),N(2,2),N$,N(2,16),N(2,17),N(2,18),N(2,19),N(2,20),\ N(0,1),N(0,2),N(0,3),N(0,4),N(0,5),N(0,6),N(0,7),\ N(0,8),N(0,9),N(0,10),N(0,11),N(0,12),N(0,13),\ N(0,14),N(0,15),N(0,16),N(0,17),N(0,18) close 1 2295 IF new$="N" THEN Z2=Z2+1 IF new$="N" THEN flag=true:open z7$ as 1:print #1;z2,z3,flag:close 1 2300 RETURN 3000 PRINT clear$:PRINT:INPUT "RECORD NUMBER";Z1:PRINT clear$; 3003 IF Z1>=Z2 THEN 3000 3004 IF Z1<1 THEN RETURN 3005 open z5$ recl 512 as 1 read #1,z1;N(2,1),N(2,2),N$,N(2,16),N(2,17),N(2,18),N(2,19),N(2,20),\ N(0,1),N(0,2),N(0,3),N(0,4),N(0,5),N(0,6),N(0,7),\ N(0,8),N(0,9),N(0,10),N(0,11),N(0,12),N(0,13),\ N(0,14),N(0,15),N(0,16),N(0,17),N(0,18) 3008 Z9=1:FOR Z=3 TO 15:K$(3,Z)=MID$(N$,Z9,N(1,Z)):Z9=Z9+N(1,Z):NEXT Z 3009 close 1 3010 PRINT "RECORD NUMBER";z1;TAB(31); 3012 PRINT "EMPLOYEE #";TAB(46);:print using u$;n(2,1) 3014 PRINT "ACCT NUMBER";TAB(18);:print using u$;n(2,2); 3016 PRINT TAB(31);"NAME";TAB(46);K$(3,3) 3018 PRINT TAB(31);"COMPANY";TAB(46);K$(3,4) 3020 PRINT TAB(31);"ADDRESS";TAB(46);K$(3,5) 3022 PRINT TAB(31);"CITY";TAB(46);K$(3,6) 3024 PRINT TAB(31);"STATE";TAB(46);K$(3,7);TAB(51);"ZIP"; 3026 PRINT TAB(61);K$(3,8) 3028 PRINT "PHONE";TAB(16);K$(3,9);TAB(31);"SOC SEC #"; 3030 PRINT TAB(46);K$(3,10) 3032 PRINT "EMPLOYED";TAB(16);K$(3,11);TAB(31);"TERMINATED"; 3034 PRINT TAB(46);K$(3,12) 3036 PRINT "MARITAL";TAB(16);K$(3,13);TAB(31);"HOUR OR SA"; 3038 PRINT TAB(46);K$(3,14) 3040 PRINT "PAY PERIOD";TAB(16);K$(3,15);TAB(31);"# OF EXEM"; 3042 PRINT TAB(46);:print using v$;n(2,16);:PRINT TAB(51);"RATE"; print using l$;n(2,17) print delim$ 3046 PRINT TAB(16);"CURRENT";TAB(36);"QUARTER TO DATE";TAB(56);"YEAR TO DATE" print "Hours";tab(16); print using u$;n(2,18);tab(36);n(2,19);tab(56);n(2,20) print "Gross Pay";tab(16); print using l$;n(0,1);tab(36);n(0,2);tab(56);n(0,3) print "FICA";tab(16); print using l$;n(0,4);tab(36);n(0,5);tab(56);n(0,6) print "Fed Tax";tab(16); print using l$;n(0,7);tab(36);n(0,8);tab(56);n(0,9) print "State Tax";tab(16); print using l$;n(0,10);tab(36);n(0,11);tab(56);n(0,12) print "SDI";tab(16); print using l$;n(0,13);tab(36);n(0,14);tab(56);n(0,15) print "Misc Ded";tab(16); print using l$;n(0,16);tab(36);n(0,17);tab(56);n(0,18) 3075 PRINT "FOR NEW RECORD, TYPE N-RETURN , OTHERWISE F-RETURN" 3085 INPUT temp$ 3090 IF left$(temp$,1)="n" or left$(temp$,1)="N" THEN 3000 3095 RETURN 4000 PRINT clear$:PRINT 4005 N$="" 4010 INPUT "RECORD NUMBER";Z1 4015 IF Z1<1 THEN PRINT "*** NO SUCH RECORD ***":GOTO 1620 4020 IF Z1>Z3 THEN PRINT "*** OUT OF RANGE ***":GOTO 1620 4025 IF Z1>=Z2 THEN PRINT "NO RECORD NUMBER";z1:GOTO 1620 4030 open z5$ recl 512 as 1 read #1,z1;N(2,1),N(2,2),N$,N(2,16),N(2,17),N(2,18),N(2,19),N(2,20),\ N(0,1),N(0,2),N(0,3),N(0,4),N(0,5),N(0,6),N(0,7),\ N(0,8),N(0,9),N(0,10),N(0,11),N(0,12),N(0,13),\ N(0,14),N(0,15),N(0,16),N(0,17),N(0,18) 4040 close 1 4045 IF N(2,1)=0 THEN PRINT "*** DELETED RECORD ***":GOTO 1620 4050 Z9=1 4055 FOR Z=3 TO 15 4060 K$(3,Z)=MID$(N$,Z9,N(1,Z)) 4065 Z9=Z9+N(1,Z) 4070 NEXT Z 4075 GOTO 2105 5000 PRINT clear$:PRINT:INPUT "RECORD NUMBER";Z1:PRINT clear$:PRINT 5002 IF Z1<1 THEN PRINT "*** NO SUCH RECORD ***":GOTO 1620 5004 IF Z1>Z3 THEN PRINT "*** OUT OF RANGE ***":GOTO 1620 5005 IF Z1>=Z2 THEN PRINT "NO RECORD NUMBER";z1:GOTO 1620 5006 open z5$ recl 512 as 1 read #1,z1;N(2,1),N(2,2),N$,N(2,16),N(2,17),N(2,18),N(2,19),N(2,20),\ N(0,1),N(0,2),N(0,3),N(0,4),N(0,5),N(0,6),N(0,7),\ N(0,8),N(0,9),N(0,10),N(0,11),N(0,12),N(0,13),\ N(0,14),N(0,15),N(0,16),N(0,17),N(0,18) 5009 close 1 5010 Z9=1:FOR Z=3 TO 15:K$(3,Z)=MID$(N$,Z9,N(1,Z)):Z9=Z9+N(1,Z):NEXT Z 5011 PRINT "RECORD NUMBER";z1;TAB(31); 5012 PRINT "EMPLOYEE #";TAB(46);:print using u$;n(2,1) 5014 PRINT "ACCT NUMBER";TAB(18);:print using u$;n(2,2); 5016 PRINT TAB(31);"NAME";TAB(46);K$(3,3) 5018 PRINT TAB(31);"COMPANY";TAB(46);K$(3,4) 5020 PRINT TAB(31);"ADDRESS";TAB(46);K$(3,5) 5022 PRINT TAB(31);"CITY";TAB(46);K$(3,6) 5024 PRINT TAB(31);"STATE";TAB(46);K$(3,7);TAB(51);"ZIP"; 5026 PRINT TAB(61);K$(3,8) 5028 PRINT "PHONE";TAB(16);K$(3,9);TAB(31);"SOC SEC #"; 5030 PRINT TAB(46);K$(3,10) 5032 PRINT "EMPLOYED";TAB(16);K$(3,11);TAB(31);"TERMINATED"; 5034 PRINT TAB(46);K$(3,12) 5036 PRINT "MARITAL";TAB(16);K$(3,13);TAB(31);"HOUR OR SA"; 5038 PRINT TAB(46);K$(3,14) 5040 PRINT "PAY PERIOD";TAB(16);K$(3,15);TAB(31);"# OF EXEM"; 5042 PRINT TAB(46);:print using v$;n(2,16);:PRINT TAB(51);"RATE"; print using l$;n(2,17) 5074 PRINT 5100 INPUT "IS RECORD TO BE DELETED (MUST BE YES TO DELETE)";line temp$ 5105 IF left$(temp$,1)="n" OR left$(temp$,1)="N" THEN RETURN 5110 IF ucase$(temp$)<>"YES" THEN 5100 5115 N(2,1)=0 5120 open z5$ recl 512 as 1 print #1,z1;N(2,1),N(2,2),N$,N(2,16),N(2,17),N(2,18),N(2,19),N(2,20),\ N(0,1),N(0,2),N(0,3),N(0,4),N(0,5),N(0,6),N(0,7),\ N(0,8),N(0,9),N(0,10),N(0,11),N(0,12),N(0,13),\ N(0,14),N(0,15),N(0,16),N(0,17),N(0,18) 5130 close 1 5135 RETURN 6000 PRINT clear$:PRINT 6005 PRINT "IF YOU HAVE ARRIVED HERE, AND HAVE AN EMPLOYEE FILE" 6010 PRINT "ALREADY ON A DISK, YOU SHOULD INSTALL THAT DISK THEN" 6015 PRINT "TYPE THE LETTER C FOLLOWED BY A RETURN TO CONTINUE." 6020 PRINT 6025 PRINT "IF YOU WISH TO CREATE A NEW FILE, TYPE THE LETTER N" 6030 PRINT "FOLLOWED BY RETURN.":PRINT 6035 INPUT line temp$ 6040 IF ucase$(temp$)="C" then initialize:GOTO 1500 6045 PRINT clear$:PRINT 6050 INPUT "NUMBER OF RECORDS DESIRED";z3 6055 PRINT n$="":for z=1 to 150:n$=n$+" ":next z 6060 FOR I=1 TO 20:N(2,I)=0:N(0,I)=0:NEXT I 6065 create z5$ recl 512 as 1 6070 FOR Z1=1 TO z3+2 print #1,z1;N(2,1),N(2,2),N$,N(2,16),N(2,17),N(2,18),N(2,19),N(2,20),\ N(0,1),N(0,2),N(0,3),N(0,4),N(0,5),N(0,6),N(0,7),\ N(0,8),N(0,9),N(0,10),N(0,11),N(0,12),N(0,13),\ N(0,14),N(0,15),N(0,16),N(0,17),N(0,18) 6085 NEXT Z1 6090 close 1 6095 PRINT clear$:PRINT 6100 PRINT "EMPLOYEE FILE CREATED AND CLEARED.":PRINT 6105 PRINT z3;"RECORDS CREATED.":PRINT 6110 PRINT "TO CONTINUE, TYPE RETURN.":INPUT line temp$ Z2=1 create z7$ as 1:print #1;Z2,Z3:close 1 6115 GOTO 1500 7000 n$="":for z=1 to 150:n$=n$+" ":next z for z=1 to 20:n(2,z)=0:n(0,z)=0:next z 7006 INPUT "ARE YOU SURE !!! (YES OR NO)";line temp$ 7007 IF ucase$(temp$)<>"YES" THEN RETURN open z5$ recl 512 as 1 7010 FOR Z1=1 TO z3+2 print #1,z1;N(2,1),N(2,2),N$,N(2,16),N(2,17),N(2,18),N(2,19),N(2,20),\ N(0,1),N(0,2),N(0,3),N(0,4),N(0,5),N(0,6),N(0,7),\ N(0,8),N(0,9),N(0,10),N(0,11),N(0,12),N(0,13),\ N(0,14),N(0,15),N(0,16),N(0,17),N(0,18) 7025 NEXT Z1 7030 close 1 7035 PRINT clear$:PRINT 7040 PRINT "EMPLOYEE FILE CLEARED!":PRINT 7045 PRINT "TO CONTINUE, TYPE RETURN." 7050 INPUT line temp$ Z2=1 open z7$ as 1:print #1;Z2,Z3:close 1 7060 RETURN 8000 CHAIN "EPSORT" 9000 CHAIN "EPLIST" 10000 CHAIN "master5" 15000 print clear$:print:print "CHECKING FILE LENGTH" PRINT:PRINT "*** PLEASE WAIT ***" CLOSE 2 open z5$ recl 512 as 1 z3=(size(z5$)*block.size)/512 for z2=1 to z3 read #1,z2;n(2,1),n(2,2) if n(2,2)=0 then 15300 next z2 15300 z3=int(z3)-2 close 1 flag=false create z7$ as 1 print #1;z2,z3,flag close 1 GOTO 1500