Color Calendar Current Day and att code

oxicottin

Learning by pecking away....
Local time
Today, 08:32
Joined
Jun 26, 2007
Messages
888
Hello, I can’t figure out how to finish this database and needed some help "Please".

1) I wanted the current day highlighted for the calendar.
2) I also cant figure out how to turn the day the color of the employees attendance code
Example:
If I enter a vacation day on July 30th then the number 30 would change to the color of the attendance code "Green in ths case".

Thanks!
 
Last edited:
Attached is a modified version of your Sample DB....

Since the Day boxes within the calendar are Text Boxes, you can easily highlight the current day using Conditional Formatting.

Set to Expression and in the expression box enter Format(Now(),"d")=[DayN]. Where N is the number of the Day Text Box (Day1, Day2, Day3....etc.)

This can be done pragmatically as well which is the route I initially took. I have placed a Sub Procedure within the frmCalendar Form to show how to do this. You will notice however that I have commented out the call to this procedure within the Forms' OnOpen event. The reason for this is that the Conditional Formatting over-rides any change made to these Day Boxes for displaying Attendance items. This sort of eliminates the purpose of the Calendar if an Attendance Item happens to fall onto the Current Day. I left the code within the frmCalendar Forms' code module merely so you can see how this can be done. The procedure is named: SetDaysCondFormating

To set the calendar Day Boxes Background color and foreground color according to the Attendance Item that happens to fall on any specific day, I created a Function conveniently named SetCalendar. This single function pretty much does it all with respect to this task as well as applying the Attendance Item Text within the Calendar Day Text Box. Whatever method you were using before for this should no longer be required.

I took the liberty of deleting the 16 procedures placed into the OnClick events for the Attendance Items which initiated the Summary Reports. These procedures were all the same except the name of the Summary Report itself. Too much code for nothing. I created a single function named ShowReport which utilizes the same code but the report name is passed to it. The function call is placed directly into the OnClick Property Box for each Attendance Item. You want to do this sort of thing wherever you can so as to keep your project as small as possible. Try not to use duplicate code.

I also found a couple problems with your Cal Function. In general it works quite nicely except for the fact that if your Interface Calendar week starts on anything other than a Sunday, the function will not generate a proper Offset. Also, this function only supported the US Date Format. I have made a small modification to this Function so that it will handle any Country's date format and, it now doesn't matter what Week Day your Interface Calendar starts at. The Function actually now utilizes the Label Controls which display the Week Days (Monday, Tuesday, Wednesday,...etc) and works the Offset from their location. Now, you can very well start your Interface Calendar Week with Wednesday and the correct Offset will be calculated. The modifications are commented in code.

I also modified the frmInputBox Form since it was not posting the correct Date.

There were a number of Code and Interface tweaks I had done but can't remember them all (sorry). If I see something that doesn't look right to me I simply just quickly correct it while I'm looking at it. It was actually nice to see little chunks of my code in your project as I was skipping through it. It made me feel.....useful :D

In any case. I think what you wanted has been established within the attached DB.

And, on a personal note, I like your Calendar Form. I think its nifty. There are some enhancements you could make but all in all I think your doing a good job.

Good luck with your project oxicottin.

.
 

Attachments

CyberLynx, This is awsome! Thanks for all the modifications :D Did you know if I went to August 2009,10,11 and so on it would color todays date in that year as if it were the current year? I like the date buttons and other interface items you have done to this DB. I have been working on this for a Loooooooong time and never could figure out stuff and quit working on it and started it back up ect Thanks for finishing it!!!! Any more ideas would be greatly appreciated. I was also trying to figure out if an employee took a 5 day vacation then how could I select 5 boxes and then select vacation from the input box and it would enter vacation in all of them?

Thanks,
Chad
 
Last edited:
I had fixed all bugs and am trying to upload a new copy to the samples forum but no one is replying so I uploaded to this post. Thanks!
 
Last edited:
New copy with bugs fixed..... Enjoy!
Hi! I tried this sample and I noticed something weird. For the days 1 to 12 for each month the input box changes by month and not day by day. It works normaly only after each 15th of month. (I attached a pic so to make clear what I say).

Any help on this please? :confused:
 

Attachments

I just check and mine works fine? In your pic the day isnt highlighted in yellow? The day is the 3rd of oct and the day should be highlighted as well.
 
Here is the one im using but I have added a "Year View" button which shows you the entire year in a calendar view for that employee and you can print it as well. I check it and the days all work "For me" :D
 

Attachments

That is indeed very strange because I cannot make it work whatever I do. :(. It works perfect from the 13th day of the month and forward. For some reason that I don't understand it counts the first 12 days as months. Is there anything I should do and I didn't so it runs smoothly? :confused:
 
did you download the "Year View" DB and try that?
 
did you download the "Year View" DB and try that?
I downloaded the link you provided above and that works for you. No luck :(:(

There is a dll in the file that after I extract to where all other dll files are I cannon locate it :eek:. Is this has anything to do with my issue maybe ?
 
There isnt a .dll in the file I uploaded unless Vista puts one there hidden for something? The only dill I use "Which isnt in the file" is the mousehook.dll file and thats so you cant scroll with the mouse.
 
There isnt a .dll in the file I uploaded unless Vista puts one there hidden for something? The only dill I use "Which isnt in the file" is the mousehook.dll file and thats so you cant scroll with the mouse.
Very very strange. :confused:
 
I haven't looked at the posted db, but from the description of the problem THANOS is having, I'm going to guess the problem has to do with the date formatting used in his/her regional settings. Access has a problem with these, basing most of what it does assuming a mm/dd/yyyy formatting, as used in the USA. If the regional settings, such as those in British dominated countries (either past or present) actually use the dd/mm/yyyy formatting you can get the type of problem described, confusing the Access gnomes into thinking days are months.

As frequently happens, Allen Browne has an excellent article explaining the problem and describing some workarounds.

http://www.allenbrowne.com/ser-36.html
 
YES!!!! Your are absolutely right!! Some changes and works perfect.

I feel such a stupid not to think it at first since it is an issue i had again in the past. Many thanks for the hint and also many thanks to the friend who shared this very useful sample.

My respect!!
 
Here is the one im using but I have added a "Year View" button which shows you the entire year in a calendar view for that employee and you can print it as well. I check it and the days all work "For me" :D
About this, can someone guide me how to build a report that insted of year calendar of each employee show monthly results for all employees.

Thanks in advance
 
Good Morning

Absolutely Brilliant DB, I have been making use of your sample thank you very much... I was however wondering if you could possibly assist. I have been making use of the sample calendar to capture days but added to the call input a "half a day" leave taken, and wanted to do some .5 additions.

In basCalender

The count of InputId to get TotDays from TblINput

Is it possible that if it counts the ID of my input the value it returns can be .5 and not one for that entry

Code:
    'Worked Half A Day
    strSql = "SELECT Count(InputID) AS TotDays FROM tblInput "
    strSql = strSql & "WHERE ((Format([InputDate], 'yyyy')=" & CInt(gstrYear) & ") AND ((tblInput.UserID)=" & glngUserID & ") AND ((tblInput.InputText)='Half Day'));"
    Set rs = db.OpenRecordset(strSql, dbOpenSnapshot)
    frm!txtHD= rs!TotDays
    rs.Close
    strSql = "'"

So Where the summary would calculate a day it should for that entry bring a half a day.

MM any suggestions... Thank you so much in advance

Regards
N
 

Users who are viewing this thread

Back
Top Bottom