1 <?xml version=
"1.0" encoding=
"UTF-8"?>
2 <!DOCTYPE script:module PUBLIC
"-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd">
3 <script:module xmlns:
script=
"http://openoffice.org/2000/script" script:
name=
"Event" script:
language=
"StarBasic">
4 REM =======================================================================================================================
5 REM === The Access2Base library is a part of the LibreOffice project. ===
6 REM === Full documentation is available on http://www.access2base.com ===
7 REM =======================================================================================================================
14 REM -----------------------------------------------------------------------------------------------------------------------
15 REM --- CLASS ROOT FIELDS ---
16 REM -----------------------------------------------------------------------------------------------------------------------
18 Private _Type As String
' Must be EVENT
19 Private _EventSource As Object
20 Private _EventType As String
21 Private _EventName As String
22 Private _SubComponentName As String
23 Private _SubComponentType As Long
24 Private _ContextShortcut As String
25 Private _ButtonLeft As Boolean
' com.sun.star.awt.MouseButton.XXX
26 Private _ButtonRight As Boolean
27 Private _ButtonMiddle As Boolean
28 Private _XPos As Variant
' Null or Long
29 Private _YPos As Variant
' Null or Long
30 Private _ClickCount As Long
31 Private _KeyCode As Integer
' com.sun.star.awt.Key.XXX
32 Private _KeyChar As String
33 Private _KeyFunction As Integer
' com.sun.star.awt.KeyFunction.XXX
34 Private _KeyAlt As Boolean
35 Private _KeyCtrl As Boolean
36 Private _KeyShift As Boolean
37 Private _FocusChangeTemporary As Boolean
' False if user action in same window
38 Private _RowChangeAction As Long
' com.sun.star.sdb.RowChangeAction.XXX
39 Private _Recommendation As String
' "IGNORE
" or
""
41 REM -----------------------------------------------------------------------------------------------------------------------
42 REM --- CONSTRUCTORS / DESTRUCTORS ---
43 REM -----------------------------------------------------------------------------------------------------------------------
44 Private Sub Class_Initialize()
46 _EventSource = Nothing
47 _EventType =
""
48 _EventName =
""
49 _SubComponentName =
""
50 _SubComponentType = -
1
51 _ContextShortcut =
""
52 _ButtonLeft = False
' See com.sun.star.awt.MouseButton.XXX
59 _KeyChar =
""
60 _KeyFunction = com.sun.star.awt.KeyFunction.DONTKNOW
64 _FocusChangeTemporary = False
66 _Recommendation =
""
67 End Sub
' Constructor
69 REM -----------------------------------------------------------------------------------------------------------------------
70 Private Sub Class_Terminate()
71 On Local Error Resume Next
72 Call Class_Initialize()
73 End Sub
' Destructor
75 REM -----------------------------------------------------------------------------------------------------------------------
77 Call Class_Terminate()
78 End Sub
' Explicit destructor
80 REM -----------------------------------------------------------------------------------------------------------------------
81 REM --- CLASS GET/LET/SET PROPERTIES ---
82 REM -----------------------------------------------------------------------------------------------------------------------
83 Property Get ButtonLeft() As Variant
84 ButtonLeft = _PropertyGet(
"ButtonLeft
")
85 End Property
' ButtonLeft (get)
87 REM -----------------------------------------------------------------------------------------------------------------------
88 Property Get ButtonMiddle() As Variant
89 ButtonMiddle = _PropertyGet(
"ButtonMiddle
")
90 End Property
' ButtonMiddle (get)
92 REM -----------------------------------------------------------------------------------------------------------------------
93 Property Get ButtonRight() As Variant
94 ButtonRight = _PropertyGet(
"ButtonRight
")
95 End Property
' ButtonRight (get)
97 REM -----------------------------------------------------------------------------------------------------------------------
98 Property Get ClickCount() As Variant
99 ClickCount = _PropertyGet(
"ClickCount
")
100 End Property
' ClickCount (get)
102 REM -----------------------------------------------------------------------------------------------------------------------
103 Property Get ContextShortcut() As Variant
104 ContextShortcut = _PropertyGet(
"ContextShortcut
")
105 End Property
' ContextShortcut (get)
107 REM -----------------------------------------------------------------------------------------------------------------------
108 Property Get EventName() As Variant
109 EventName = _PropertyGet(
"EventName
")
110 End Property
' EventName (get)
112 REM -----------------------------------------------------------------------------------------------------------------------
113 Property Get EventSource() As Variant
114 EventSource = _PropertyGet(
"EventSource
")
115 End Property
' EventSource (get)
117 REM -----------------------------------------------------------------------------------------------------------------------
118 Property Get EventType() As Variant
119 EventType = _PropertyGet(
"EventType
")
120 End Property
' EventType (get)
122 REM -----------------------------------------------------------------------------------------------------------------------
123 Property Get FocusChangeTemporary() As Variant
124 FocusChangeTemporary = _PropertyGet(
"FocusChangeTemporary
")
125 End Property
' FocusChangeTemporary (get)
127 REM -----------------------------------------------------------------------------------------------------------------------
128 Property Get KeyAlt() As Variant
129 KeyAlt = _PropertyGet(
"KeyAlt
")
130 End Property
' KeyAlt (get)
132 REM -----------------------------------------------------------------------------------------------------------------------
133 Property Get KeyChar() As Variant
134 KeyChar = _PropertyGet(
"KeyChar
")
135 End Property
' KeyChar (get)
137 REM -----------------------------------------------------------------------------------------------------------------------
138 Property Get KeyCode() As Variant
139 KeyCode = _PropertyGet(
"KeyCode
")
140 End Property
' KeyCode (get)
142 REM -----------------------------------------------------------------------------------------------------------------------
143 Property Get KeyCtrl() As Variant
144 KeyCtrl = _PropertyGet(
"KeyCtrl
")
145 End Property
' KeyCtrl (get)
147 REM -----------------------------------------------------------------------------------------------------------------------
148 Property Get KeyFunction() As Variant
149 KeyFunction = _PropertyGet(
"KeyFunction
")
150 End Property
' KeyFunction (get)
152 REM -----------------------------------------------------------------------------------------------------------------------
153 Property Get KeyShift() As Variant
154 KeyShift = _PropertyGet(
"KeyShift
")
155 End Property
' KeyShift (get)
157 REM -----------------------------------------------------------------------------------------------------------------------
158 Property Get ObjectType() As String
159 ObjectType = _PropertyGet(
"ObjectType
")
160 End Property
' ObjectType (get)
162 REM -----------------------------------------------------------------------------------------------------------------------
163 Public Function Properties(ByVal Optional pvIndex As Variant) As Variant
165 ' a Collection object if pvIndex absent
166 ' a Property object otherwise
168 Dim vProperty As Variant, vPropertiesList() As Variant, sObject As String
169 vPropertiesList = _PropertiesList()
170 sObject = Utils._PCase(_Type)
171 If IsMissing(pvIndex) Then
172 vProperty = PropertiesGet._Properties(sObject, _This, vPropertiesList)
174 vProperty = PropertiesGet._Properties(sObject, _This, vPropertiesList, pvIndex)
175 vProperty._Value = _PropertyGet(vPropertiesList(pvIndex))
179 Set Properties = vProperty
181 End Function
' Properties
183 REM -----------------------------------------------------------------------------------------------------------------------
184 Property Get Recommendation() As Variant
185 Recommendation = _PropertyGet(
"Recommendation
")
186 End Property
' Recommendation (get)
188 REM -----------------------------------------------------------------------------------------------------------------------
189 Property Get RowChangeAction() As Variant
190 RowChangeAction = _PropertyGet(
"RowChangeAction
")
191 End Property
' RowChangeAction (get)
193 REM -----------------------------------------------------------------------------------------------------------------------
194 Public Function Source() As Variant
195 ' Return the object having fired the event: Form, Control or SubForm
196 ' Else return the root Database object
197 Source = _PropertyGet(
"Source
")
198 End Function
' Source (get)
200 REM -----------------------------------------------------------------------------------------------------------------------
201 Property Get SubComponentName() As String
202 SubComponentName = _PropertyGet(
"SubComponentName
")
203 End Property
' SubComponentName (get)
205 REM -----------------------------------------------------------------------------------------------------------------------
206 Property Get SubComponentType() As Long
207 SubComponentType = _PropertyGet(
"SubComponentType
")
208 End Property
' SubComponentType (get)
210 REM -----------------------------------------------------------------------------------------------------------------------
211 Property Get XPos() As Variant
212 XPos = _PropertyGet(
"XPos
")
213 End Property
' XPos (get)
215 REM -----------------------------------------------------------------------------------------------------------------------
216 Property Get YPos() As Variant
217 YPos = _PropertyGet(
"YPos
")
218 End Property
' YPos (get)
220 REM -----------------------------------------------------------------------------------------------------------------------
221 REM --- CLASS METHODS ---
222 REM -----------------------------------------------------------------------------------------------------------------------
223 Public Function getProperty(Optional ByVal pvProperty As Variant) As Variant
224 ' Return property value of psProperty property name
226 Utils._SetCalledSub(
"Form.getProperty
")
227 If IsMissing(pvProperty) Then Call _TraceArguments()
228 getProperty = _PropertyGet(pvProperty)
229 Utils._ResetCalledSub(
"Form.getProperty
")
231 End Function
' getProperty
233 REM -----------------------------------------------------------------------------------------------------------------------
234 Public Function hasProperty(ByVal Optional pvProperty As Variant) As Boolean
235 ' Return True if object has a valid property called pvProperty (case-insensitive comparison !)
237 If IsMissing(pvProperty) Then hasProperty = PropertiesGet._hasProperty(_Type, _PropertiesList()) Else hasProperty = PropertiesGet._hasProperty(_Type, _PropertiesList(), pvProperty)
240 End Function
' hasProperty
242 REM -----------------------------------------------------------------------------------------------------------------------
243 REM --- PRIVATE FUNCTIONS ---
244 REM -----------------------------------------------------------------------------------------------------------------------
245 Public Sub _Initialize(poEvent As Object)
247 Dim oObject As Object, i As Integer
248 Dim sShortcut As String, sAddShortcut As String, sArray() As String
249 Dim sImplementation As String, oSelection As Object
250 Dim iCurrentDoc As Integer, oDoc As Object
251 Dim vPersistent As Variant
252 Const cstDatabaseForm =
"com.sun.star.comp.forms.ODatabaseForm
"
254 If _ErrorHandler() Then On Local Error Goto Error_Function
256 Set oObject = poEvent.Source
257 _EventSource = oObject
258 sArray = Split(Utils._getUNOTypeName(poEvent),
".
")
259 _EventType = UCase(sArray(UBound(sArray)))
260 If Utils._hasUNOProperty(poEvent,
"EventName
") Then _EventName = poEvent.EventName
262 Select Case _EventType
263 Case
"DOCUMENTEVENT
"
264 'SubComponent processing
265 Select Case UCase(_EventName)
266 Case UCase(
"OnSubComponentClosed
"), UCase(
"OnSubComponentOpened
")
267 Set oSelection = poEvent.ViewController.getSelection()(
0)
268 _SubComponentName = oSelection.Name
269 With com.sun.star.sdb.application.DatabaseObject
270 Select Case oSelection.Type
271 Case .TABLE : _SubComponentType = acTable
272 Case .QUERY : _SubComponentType = acQuery
273 Case .FORM : _SubComponentType = acForm
274 Case .REPORT : _SubComponentType = acReport
280 Case
"EVENTOBJECT
"
281 Case
"ACTIONEVENT
"
282 Case
"FOCUSEVENT
"
283 _FocusChangeTemporary = poEvent.Temporary
284 Case
"ITEMEVENT
"
285 Case
"INPUTEVENT
",
"KEYEVENT
"
286 _KeyCode = poEvent.KeyCode
287 _KeyChar = poEvent.KeyChar
288 _KeyFunction = poEvent.KeyFunc
289 _KeyAlt = Utils._BitShift(poEvent.Modifiers, com.sun.star.awt.KeyModifier.MOD2)
290 _KeyCtrl = Utils._BitShift(poEvent.Modifiers, com.sun.star.awt.KeyModifier.MOD1)
291 _KeyShift = Utils._BitShift(poEvent.Modifiers, com.sun.star.awt.KeyModifier.SHIFT)
292 Case
"MOUSEEVENT
"
293 _ButtonLeft = Utils._BitShift(poEvent.Buttons, com.sun.star.awt.MouseButton.LEFT)
294 _ButtonRight = Utils._BitShift(poEvent.Buttons, com.sun.star.awt.MouseButton.RIGHT)
295 _ButtonMiddle = Utils._BitShift(poEvent.Buttons, com.sun.star.awt.MouseButton.MIDDLE)
298 _ClickCount = poEvent.ClickCount
299 Case
"ROWCHANGEEVENT
"
300 _RowChangeAction = poEvent.Action
301 Case
"TEXTEVENT
"
302 Case
"ADJUSTMENTEVENT
",
"DOCKINGEVENT
",
"ENDDOCKINGEVENT
",
"ENDPOPUPMODEEVENT
",
"ENHANCEDMOUSEEVENT
" _
303 ,
"MENUEVENT
",
"PAINTEVENT
",
"SPINEVENT
",
"VCLCONTAINEREVENT
",
"WINDOWEVENT
"
309 ' Evaluate ContextShortcut
310 sShortcut =
""
311 sImplementation = Utils._ImplementationName(oObject)
314 Case sImplementation =
"stardiv.Toolkit.UnoDialogControl
" ' Dialog
315 _ContextShortcut =
"Dialogs!
" & _EventSource.Model.Name
317 Case Left(sImplementation,
16) =
"stardiv.Toolkit.
" ' Control in Dialog
318 _ContextShortcut =
"Dialogs!
" & _EventSource.Context.Model.Name _
319 & "!
" & _EventSource.Model.Name
324 iCurrentDoc = _A2B_.CurrentDocIndex(, False)
325 If iCurrentDoc
< 0 Then Goto Exit_Function
326 Set oDoc = _A2B_.CurrentDocument(iCurrentDoc)
328 ' To manage
2x triggers of
"Before record action
" form event
329 If _EventType =
"ROWCHANGEEVENT
" And sImplementation
<> "com.sun.star.comp.forms.ODatabaseForm
" Then _Recommendation =
"IGNORE
"
331 Do While sImplementation
<> "SwXTextDocument
"
332 sAddShortcut =
""
333 Select Case sImplementation
334 Case
"com.sun.star.comp.forms.OFormsCollection
" ' Do nothing
336 If Utils._hasUNOProperty(oObject,
"Model
") Then
337 If oObject.Model.Name
<> "MainForm
" And oObject.Model.Name
<> "Form
" Then sAddShortcut = Utils._Surround(oObject.Model.Name)
338 ElseIf Utils._hasUNOProperty(oObject,
"Name
") Then
339 If oObject.Name
<> "MainForm
" And oObject.Name
<> "Form
" Then sAddShortcut = Utils._Surround(oObject.Name)
341 If sAddShortcut
<> "" Then
342 If sImplementation = cstDatabaseForm And oDoc.DbConnect = DBCONNECTBASE Then sAddShortcut = sAddShortcut
& ".Form
"
343 sShortcut = sAddShortcut
& Iif(Len(sShortcut)
> 0,
"!
" & sShortcut,
"")
347 Case Utils._hasUNOProperty(oObject,
"Model
")
348 Set oObject = oObject.Model.Parent
349 Case Utils._hasUNOProperty(oObject,
"Parent
")
350 Set oObject = oObject.Parent
354 sImplementation = Utils._ImplementationName(oObject)
356 ' Add Forms! prefix
357 Select Case oDoc.DbConnect
359 vPersistent = Split(oObject.StringValue,
"/
")
360 sAddShortcut = Utils._Surround(_GetHierarchicalName(vPersistent(UBound(vPersistent) -
1)))
361 sShortcut =
"Forms!
" & sAddShortcut
& "!
" & sShortcut
363 sShortcut =
"Forms!
0!
" & sShortcut
366 sArray = Split(sShortcut,
"!
")
367 ' If presence of
"Forms!myform!myform.Form
", eliminate
2nd element
368 ' Eliminate anyway blanco subcomponents (e.g. Forms!!myForm)
369 If UBound(sArray)
>=
2 Then
370 If UCase(sArray(
1))
& ".FORM
" = UCase(sArray(
2)) Then sArray(
1) =
""
371 sArray = Utils._TrimArray(sArray)
373 ' If first element ends with .Form, remove suffix
374 If UBound(sArray)
>=
1 Then
375 If Len(sArray(
1))
> 5 And Right(sArray(
1),
5) =
".Form
" Then sArray(
1) = left(sArray(
1), Len(sArray(
1)) -
5)
376 sShortcut = Join(sArray,
"!
")
378 If Len(sShortcut)
>=
2 Then
379 If Right(sShortcut,
1) =
"!
" Then
380 _ContextShortcut = Left(sShortcut, Len(sShortcut) -
1)
382 _ContextShortcut = sShortcut
389 TraceError(TRACEWARNING, Err,
"Event.Initialize
", Erl)
391 End Sub
' _Initialize V0.9
.1
393 REM -----------------------------------------------------------------------------------------------------------------------
394 Private Function _PropertiesList() As Variant
396 Dim sSubComponentName As String, sSubComponentType As String
397 sSubComponentName = Iif(_SubComponentType
> -
1,
"SubComponentName
",
"")
398 sSubComponentType = Iif(_SubComponentType
> -
1,
"SubComponentType
",
"")
399 Dim sXPos As String, sYPos As String
400 sXPos = Iif(IsNull(_XPos),
"",
"XPos
")
401 sYPos = Iif(IsNull(_YPos),
"",
"YPos
")
403 _PropertiesList = Utils._TrimArray(Array( _
404 "ButtonLeft
",
"ButtonRight
",
"ButtonMiddle
",
"ClickCount
" _
405 ,
"ContextShortcut
",
"EventName
",
"EventType
",
"FocusChangeTemporary
", _
406 ,
"KeyAlt
",
"KeyChar
",
"KeyCode
",
"KeyCtrl
",
"KeyFunction
",
"KeyShift
" _
407 ,
"ObjectType
",
"Recommendation
",
"RowChangeAction
",
"Source
" _
408 , sSubComponentName, sSubComponentType, sXPos, sYPos _
411 End Function
' _PropertiesList
413 REM -----------------------------------------------------------------------------------------------------------------------
414 Private Function _PropertyGet(ByVal psProperty As String) As Variant
415 ' Return property value of the psProperty property name
417 If _ErrorHandler() Then On Local Error Goto Error_Function
418 Utils._SetCalledSub(
"Event.get
" & psProperty)
422 Select Case UCase(psProperty)
423 Case UCase(
"ButtonLeft
")
424 _PropertyGet = _ButtonLeft
425 Case UCase(
"ButtonMiddle
")
426 _PropertyGet = _ButtonMiddle
427 Case UCase(
"ButtonRight
")
428 _PropertyGet = _ButtonRight
429 Case UCase(
"ClickCount
")
430 _PropertyGet = _ClickCount
431 Case UCase(
"ContextShortcut
")
432 _PropertyGet = _ContextShortcut
433 Case UCase(
"FocusChangeTemporary
")
434 _PropertyGet = _FocusChangeTemporary
435 Case UCase(
"EventName
")
436 _PropertyGet = _EventName
437 Case UCase(
"EventSource
")
438 _PropertyGet = _EventSource
439 Case UCase(
"EventType
")
440 _PropertyGet = _EventType
441 Case UCase(
"KeyAlt
")
442 _PropertyGet = _KeyAlt
443 Case UCase(
"KeyChar
")
444 _PropertyGet = _KeyChar
445 Case UCase(
"KeyCode
")
446 _PropertyGet = _KeyCode
447 Case UCase(
"KeyCtrl
")
448 _PropertyGet = _KeyCtrl
449 Case UCase(
"KeyFunction
")
450 _PropertyGet = _KeyFunction
451 Case UCase(
"KeyShift
")
452 _PropertyGet = _KeyShift
453 Case UCase(
"ObjectType
")
455 Case UCase(
"Recommendation
")
456 _PropertyGet = _Recommendation
457 Case UCase(
"RowChangeAction
")
458 _PropertyGet = _RowChangeAction
459 Case UCase(
"Source
")
460 If _ContextShortcut =
"" Then
461 _PropertyGet = _EventSource
463 _PropertyGet = getObject(_ContextShortcut)
465 Case UCase(
"SubComponentName
")
466 _PropertyGet = _SubComponentName
467 Case UCase(
"SubComponentType
")
468 _PropertyGet = _SubComponentType
469 Case UCase(
"XPos
")
470 If IsNull(_XPos) Then Goto Trace_Error
472 Case UCase(
"YPos
")
473 If IsNull(_YPos) Then Goto Trace_Error
480 Utils._ResetCalledSub(
"Event.get
" & psProperty)
483 ' Errors are not displayed to avoid display infinite cycling
484 TraceError(TRACEWARNING, ERRPROPERTY, Utils._CalledSub(),
0, False, psProperty)
488 TraceError(TRACEABORT, Err,
"Event._PropertyGet
", Erl)
491 End Function
' _PropertyGet V1.1
.0