245 lines
9.1 KiB
Plaintext
245 lines
9.1 KiB
Plaintext
Function NDW_DATEPICKER_EVENTS(CtrlEntId, Event, Param1, Param2, Param3, Param4, Param5, Param6, Param7, Param8, Param9, Param10, Param11, Param12, Param13, Param14, Param15)
|
|
|
|
/***********************************************************************************************************************
|
|
|
|
This program is proprietary and is not to be used by or disclosed to others, nor is it to be copied without written
|
|
permission from SRP Computer Solutions, Inc.
|
|
|
|
Name : NDW_DatePicker_Events
|
|
|
|
Description : Event commuter module for the NDW_DatePicker window.
|
|
|
|
Notes : This is typically called by setting up a QuickEvent to execute a procedure and
|
|
the procedure will be this function. The Parameters field would then contain
|
|
the necessary parameters to for proper event routing in this routine. The syntax
|
|
for these parameters are:
|
|
|
|
'event name','@SELF',['@PARAM1','@PARAMx']
|
|
|
|
'event name' is the actual event that is being called (e.g. 'CREATE'). It should
|
|
be surrounded by single quotes. '@SELF' will tell NDW_DatePicker_Events what
|
|
the fully qualified name of the current control is. '@PARAMx' is to pass any
|
|
additional parameters that the current event may have. '@SELF' and '@PARAMx'
|
|
also need to be surrounded by single quotes.
|
|
|
|
Parameters :
|
|
Event [in] -- The event that is being executed in the window.
|
|
CtrlEntId [in] -- The control that is calling the event.
|
|
Param1-13 [in] -- Additional parameters that the event is passing through.
|
|
|
|
History : (Date, Initials, Notes)
|
|
12/06/07 rch Original programmer.
|
|
05/27/10 rch Ported to FRAMEWORKS from DM.
|
|
08/25/10 rch Fix horizontal positioning when control is too far right for calendar to fit.
|
|
10/14/10 rch Replace GetWindowRect with calls to SRP_Get_Window_Rect.
|
|
11/10/10 rch Default new Font property to Tahoma, 8pt size.
|
|
03/04/13 dmb Add support for this window to be called as a modeless dialog. - [SRPFW-9]
|
|
10/05/13 dmb Retrofit form and commuter to use the default FrameWorks system font. - [SRPFW-17]
|
|
10/05/13 dmb Improve the logic that determines the position of the form when it is going to appear on
|
|
a second monitor. Previously the logic would always force it to appear on the first
|
|
monitor. - [SRPFW-18]
|
|
|
|
***********************************************************************************************************************/
|
|
|
|
$Insert APP_INSERTS
|
|
$Insert EVENT_SETUP
|
|
|
|
Declare function SendMessage, Send_Message, SRP_Get_Window_Rect
|
|
*Declare subroutine GetWindowRect
|
|
|
|
Equ DTM_READCELLRECT$ to 1079
|
|
Equ DTM_GETCELLLEFTBOTTOM$ to 1160
|
|
Equ DTA_CURRENT$ to 1
|
|
|
|
// Update the arguments so that the OpenInsight OLE event will treate the ActiveX event as a native event handler.
|
|
If Event EQ 'OLE' then
|
|
Transfer Event to OIEvent
|
|
Transfer Param1 to Event
|
|
Transfer Param2 to Param1
|
|
Transfer Param3 to Param2
|
|
Transfer Param4 to Param3
|
|
Transfer Param5 to Param4
|
|
Transfer Param6 to Param5
|
|
Transfer Param7 to Param6
|
|
Transfer Param8 to Param7
|
|
end
|
|
|
|
Begin Case
|
|
Case Control EQ Window
|
|
Begin Case
|
|
Case Event EQ "CREATE" ; GoSub CREATE
|
|
Case Event EQ "INACTIVATED" ; GoSub INACTIVATED
|
|
End Case
|
|
|
|
Case Event EQ "CLICK"
|
|
Begin Case
|
|
Case Control EQ "PUB_OK" ; GoSub CLICK.PUB_OK
|
|
End Case
|
|
|
|
Case Control EQ "OLE_DATEPICKER"
|
|
Begin Case
|
|
Case Event EQ "OnDblClick" ; GoSub OnDblClick.OLE_DATEPICKER
|
|
End Case
|
|
End Case
|
|
|
|
If Assigned(EventFlow) else EventFlow = EVENT_CONTINUE$
|
|
|
|
Return EventFlow
|
|
|
|
|
|
CREATE:
|
|
CreateParam = Param1
|
|
// If CreateParam has a value then this is the control that needs to get the return result. It also means this
|
|
// window was launched as a modeless dialog box rather than modal. This will determine how this window should be
|
|
// closed.
|
|
* Set_Property(@Window, '@PARENTCONTROL', CreateParam)
|
|
|
|
GoSub Set_OLE_Controls
|
|
|
|
GoSub Determine_Position
|
|
|
|
SRP_Show_Window(@Window, '', '', '', True$, '', True$, True$, Size, False$)
|
|
return
|
|
|
|
INACTIVATED:
|
|
Post_Event(@Window, 'CLOSE')
|
|
return
|
|
|
|
CLICK.PUB_OK:
|
|
GoSub Return_Date
|
|
return
|
|
|
|
OnDblClick.OLE_DATEPICKER:
|
|
GoSub Return_Date
|
|
return
|
|
|
|
********************************************
|
|
* Internal procedures follow
|
|
********************************************
|
|
|
|
Determine_Position:
|
|
// Determine the Parent window
|
|
MdiActive = Get_Property(Parent, "MDIACTIVE")
|
|
If Len(MdiActive) then
|
|
Parent = MdiActive
|
|
end
|
|
|
|
// Determine the control to do the lookup for
|
|
CtrlId = Get_Property(Parent, "FOCUS")
|
|
|
|
// Get some property values
|
|
Ctrls = Parent :@RM: @Window :@RM: CtrlId :@RM: CtrlId :@RM: CtrlId :@RM: CtrlId :@RM: "SYSTEM"
|
|
Props = "MDIFRAME" :@RM: "SIZE" :@RM: "TYPE" :@RM: "HANDLE" :@RM: "SELPOS" :@RM: "ORIG_TEXT" :@RM: "SIZE"
|
|
Vals = Get_Property(Ctrls, Props)
|
|
|
|
Frame = Field(Vals, @RM, 1)
|
|
Size = Field(Vals, @RM, 2)
|
|
Type = Field(Vals, @RM, 3)
|
|
CtlHdl = Field(Vals, @RM, 4)
|
|
SelPos = Field(Vals, @RM, 5)
|
|
ProgID = Field(Vals, @RM, 6) ; // To check for OLE EditTables
|
|
Screen = Field(Vals, @RM, 7)
|
|
|
|
// If no frame, use window size to determine if calendar should show below or above control
|
|
If Frame then
|
|
WinSize = SRP_Get_Window_Rect(Frame)
|
|
end else
|
|
WinSize = SRP_Get_Window_Rect(Parent)
|
|
end
|
|
|
|
Table = (Type EQ "EDITTABLE") OR (ProgID _EQC "SRP.EditTable.1")
|
|
If Table else
|
|
SelPos = ""
|
|
end
|
|
|
|
If ProgID _EQC "SRP.EditTable.1" then
|
|
// OLE EditTables need to use the CellText property
|
|
ColNo = SelPos<1>
|
|
RowNo = SelPos<2>
|
|
Convert @FM to ";" in SelPos
|
|
DfltDate = Iconv(Get_Property(CtrlId, "OLE.CellText[":SelPos:"]"), "D")
|
|
end else
|
|
DfltDate = Get_Property(CtrlId, "INVALUE", SelPos)
|
|
end
|
|
// Set initial selection to date passed in and make it visible
|
|
If DfltDate then
|
|
Set_Property(@Window:".OLE_DATEPICKER", "OLE.Selection", DfltDate)
|
|
Send_Message(@Window:".OLE_DATEPICKER", "OLE.EnsureVisible", DfltDate)
|
|
end
|
|
|
|
Rect = Str(\00\, 16)
|
|
|
|
CtlSize = SRP_Get_Window_Rect(CtrlId)
|
|
xPos = CtlSize<1>
|
|
yPos = CtlSize<2>
|
|
|
|
If Table then
|
|
// add x, y and y+h of cell
|
|
If ProgID _EQC "SRP.EditTable.1" then
|
|
CellSize = Send_Message(CtrlId, "OLE.GetCellRect", ColNo:@FM:RowNo)
|
|
*xPos += CellSize<1>
|
|
xPos += CellSize<1> + 1 ; // This makes alignment better
|
|
yPos += CellSize<2>
|
|
cyPos = yPos + CellSize<4>
|
|
end else
|
|
LeftBottom = SendMessage(CtlHdl, DTM_GETCELLLEFTBOTTOM$, DTA_CURRENT$, 0)
|
|
xPos += mod(LeftBottom, 65536)
|
|
cyPos = yPos + int(LeftBottom / 65536)
|
|
|
|
// Get y position with different SendMessage call
|
|
SendMessage(CtlHdl, DTM_READCELLRECT$, DTA_CURRENT$, GetPointer(Rect))
|
|
yPos += seq(Rect [5,1]) + (seq(Rect [6,1]) * 256)
|
|
end
|
|
end else
|
|
// get y+h of control
|
|
cyPos = CtlSize<2> + CtlSize<4>
|
|
end
|
|
|
|
// get y+h of frame or parent window
|
|
MaxCy = WinSize<2> + WinSize<4>
|
|
|
|
// Set x and y of calendar window
|
|
Size<1> = xPos
|
|
If Size<1> + Size<3> GT Screen<1> AND (Screen<1> GT Size<1>) then
|
|
// Shift calendar to left to fit on screen
|
|
Size<1> = Screen<1> - Size<3>
|
|
end
|
|
If cyPos+Size<4> GT MaxCy then
|
|
// Position above control so calendar shows fully
|
|
Size<2> = yPos - Size<4>
|
|
end else
|
|
Size<2> = cyPos
|
|
end
|
|
return
|
|
|
|
Return_Date:
|
|
|
|
ParentControl = Get_Property(@Window, '@PARENTCONTROL')
|
|
SelDate = Get_Property(@Window : '.OLE_DATEPICKER', 'OLE.Selection')
|
|
If Len(ParentControl) then
|
|
Send_Event(ParentControl, 'UPDATE', SelDate)
|
|
Post_Event(@Window, 'CLOSE')
|
|
end else
|
|
End_Dialog(@Window, SelDate)
|
|
end
|
|
|
|
// Since we are ending the window now, there is no need to allow the event chain to continue.
|
|
// If we do, then we will get the "labeled common variable has been freed and is no longer valid" error.
|
|
EventFlow = EVENT_CONTINUE_NO_SYSTEM$
|
|
return
|
|
|
|
Set_OLE_Controls:
|
|
|
|
Ctrl = @Window : '.OLE_DATEPICKER'
|
|
SizeWindow = Get_Property(@Window, 'SIZE')
|
|
SizePicker = -1 : @FM : -1 : @FM : SizeWindow<3> : @FM : SizeWindow<4>
|
|
Set_Property(Ctrl, 'SIZE', SizePicker)
|
|
Set_Property(Ctrl, 'OLE.Theme', 'Windows7Blue')
|
|
Set_Property(Ctrl, 'OLE.Font', SystemFont$)
|
|
Set_Property(Ctrl, 'OLE.Selection', CreateParam)
|
|
|
|
// Use asynchronous event handling (because in Dialog Box)
|
|
Send_Message(@Window:".OLE_DATEPICKER", "QUALIFY_EVENT", "ALL_OLES", 1)
|
|
|
|
return
|