SFDocuments.Form service/text/sbasic/shared/03/sf_form.xhpForm service
SFDocuments.Form service
The Form service provides methods and properties to manage forms in %PRODUCTNAME documents. This service supports forms in Base, Calc and Writer documents and allows to:Open and activate forms.Navigate through records shown by the form.Get access to the controls inside the form.Get access to subforms of a parent form.The SFDocuments.Form service is available from %PRODUCTNAME 7.2 onwards.Forms are usually used in %PRODUCTNAME documents to create user interfaces connected to relational databases. Hence, the Form service provides quick access to the linked database through the SFDatabases.Database service.The SFDocuments.Form service is closely related to the SFDocuments.FormControl service.
Definitions
FormDocument
Forms are usually created in Base documents, but they can be added to Writer and Calc documents as well.In Base, each form you create using the functionality or through the Form Wizard is actually a FormDocument that can be handled with the Form service. Base documents can contain an unlimited number of form documents.Below is an example showing the hierarchy of all the elements involved in accessing forms and subforms in a Base document. Suppose you have a Base file named Employees.odb and inside it you created a form document to add new employees to the database. The form document contains a main form named EmployeeData that gives access to a table. There is also a subform WorksAtPlant that allows you to associate the new employee to one of the plants of the company.Employees.odb (Base document) | |-- AddEmployee (FormDocument) | |-- EmployeeData (Main Form) | |-- WorksAtPlant (SubForm)A FormDocument can be seen as a set of forms that provide access to datasets such as database tables and queries from within %PRODUCTNAME documents. The names of forms and subforms inside a FormDocument can be accessed using the Form Navigator.
Forms and Subforms
A form document is composed of one or more forms which, in turn, may also contain any number of subforms. A Form is an abstract set of controls that are linked to a specified data source, which can be a database table, a query or a SQL SELECT statement.In Calc and Writer documents, each form can be linked to datasets located in different databases. On the other hand, in Base documents the database contained in the document is common to all forms.To invoke the SFDocuments.Form service refer to the methods Forms(), FormDocuments() and OpenFormDocument() of the SFDocuments.Document service
Service invocation
Before using the Form service the ScriptForge library needs to be loaded or imported:
In Writer documents
The code snippet below shows how to access the form named Form1 that is inside a Writer file:Dim oDoc As Object, myForm As Object, ui as ObjectSet ui = CreateScriptService("UI")Set oDoc = ui.OpenDocument("/home/user/Documents/MyForm.odt")Set myForm = oDoc.Forms("Form1")from scriptforge import CreateScriptServiceui = CreateScriptService('UI') doc = ui.OpenDocument('/home/user/Documents/MyForm.odt')my_form = doc.Forms('Form1')Forms can be accessed by their names or by their indices, as shown below:Set myForm = oDoc.Forms(0)my_form = doc.Forms(0)If you try to access a FormDocument that is currently opened in Design Mode an exception will be raised.
In Calc documents
A form in a Calc file must have a unique name inside its sheet. Hence, the Forms method requires two arguments, the first indicating the sheet name and the second specifying the form name.Dim oDoc As Object, myForm As Object, ui as ObjectSet ui = CreateScriptService("UI")Set oDoc = ui.OpenDocument("/home/user/Documents/MyForms.ods")Set myForm = oDoc.Forms("Sheet1", "Form1")This is achieved identically using Python:ui = CreateScriptService('UI')doc = ui.OpenDocument('/home/user/Documents/MyForms.ods')my_form = doc.Forms('Sheet1', 'Form1')
In Base documents
A FormDocument inside a Base document is accessed by its name. The following example opens the form document named thisFormDocument and accesses the form MainForm:Dim oDb As Object, myForm As ObjectSet oDb = CreateScriptService("SFDocuments.Document", ThisDatabaseDocument)' The statement below is necessary only if the form hasn't been opened yetoDb.OpenFormDocument("thisFormDocument")Set myForm = oDoc.Forms("thisFormDocument", "MainForm")' Or, alternatively, to access the form by its index ...Set myForm = oDb.Forms("thisFormDocument", 0)To perform any action on a form using the Form service, the FormDocument must have been opened either manually by the user or programmatically in a user script. The latter can be done by calling the OpenFormDocument method of the Base service.To access a given subform of a form use the SubForms method. Note that in the example below mySubForm is a new instance of the Form service.Dim mySubForm As ObjectSet mySubForm = myForm.SubForms("mySubForm")Previous examples translate in Python as:db = CreateScriptService('SFDocuments.Document', XSCRIPTCONTEXT.getDocument())# The statement below is necessary only if the form hasn't been opened yetform_doc = db.OpenFormDocument('thisFormDocument')form = form_doc.Forms('thisFormDocument', 'MainForm')# Or, alternatively, to access the form by its index ...form = form_doc.Forms('thisFormDocument', 0)sub_form = form.SubForms('mySubForm')
In Form events
To invoke the Form service when a form event takes place:Sub OnEvent(ByRef poEvent As Object) Dim myForm As Object Set myForm = CreateScriptService("SFDocuments.FormEvent", poEvent) '(...)End subdef OnEvent(event: uno): form = CreateScriptService('SFDocuments.FormEvent', event) passIt is recommended to free resources after use of the Form service.myForm.Dispose() ' Basicform.Dispose() # PythonThis operation is done implicitly when a form document is closed with the CloseFormDocument() method described below.
Properties
NameReadonlyTypeDescriptionAllowDeletesNoBooleanSpecifies if the form allows to delete records.AllowInsertsNoBooleanSpecifies if the form allows to add records.AllowUpdatesNoBooleanSpecifies if the form allows to update records.BaseFormYesStringSpecifies the hierarchical name of the Base Form containing the actual form.BookmarkNoVariantSpecifies uniquely the current record of the form's underlying table, query or SQL statement.CurrentRecordNoLongIdentifies the current record in the dataset being viewed on a form. If the row number is positive, the cursor moves to the given row number with respect to the beginning of the result set. Row count starts at 1. If the given row number is negative, the cursor moves to an absolute row position with respect to the end of the result set. Row -1 refers to the last row in the result set.FilterNoStringSpecifies a subset of records to be displayed as a SQLWHERE-clause without the WHERE keyword.LinkChildFieldsYesStringSpecifies how records in a child subform are linked to records in its parent form.LinkParentFieldsYesStringSpecifies how records in a child subform are linked to records in its parent form.NameYesStringThe name of the current form.OrderByNoStringSpecifies in which order the records should be displayed as a SQLORDER BY clause without the ORDER BY keywords.ParentYesObjectThe parent of the current form. It can be either a SFDocuments.Form or a SFDocuments.Document object.RecordSourceNoStringSpecifies the source of the data, as a table name, a query name or a SQL statement.XFormYesUNO objectThe UNO object representing interactions with the form. Refer to XForm and DataForm in the API documentation for detailed information.
Event properties
The properties below return or set URI strings that define the script triggered by the event.
NameReadOnlyBasic IDE DescriptionOnApproveCursorMoveNoBefore record changeOnApproveParameterNoFill parametersOnApproveResetNoPrior to resetOnApproveRowChangeNoBefore record actionOnApproveSubmitNoBefore submittingOnConfirmDeleteNoConfirm deletionOnCursorMovedNoAfter record changeOnErrorOccurredNoError occurredOnLoadedNoWhen loadingOnReloadedNoWhen reloadingOnReloadingNoBefore reloadingOnResettedNoAfter resettingOnRowChangedNoAfter record actionOnUnloadedNoWhen unloadingOnUnloadingNoBefore unloading
To learn more about URI strings, refer to the Scripting Framework URI Specification.
List of methods in the Form service
Activate
Controls
GetDatabase
MoveFirst
MoveLast
MoveNext
MoveNew
MovePrevious
Requery
SubForms
Activate -------------------------------------------------------------------------------------------------------------------------- Form service;Activate
Activate
Sets the focus on the current Form instance. Returns True if focusing was successful.The behavior of the Activate method depends on the type of document where the form is located:In Writer documents: Sets the focus on that document.In Calc documents: Sets the focus on the sheet to which the form belongs.In Base documents: Sets the focus on the FormDocument the Form refers to.svc.Activate(): boolThe following example assumes you want to activate the form named FormA located in Sheet1 of the currently open Calc file. It first gets access to the document using the Document service and ThisComponent and then activates the form.'Gets hold of the form that will be activatedDim oDoc as Object, myForm as ObjectSet oDoc = CreateScriptService("Document", ThisComponent)Set myForm = oDoc.Forms("Sheet1", "FormA")'Activates the formmyForm.Activate()doc = CreateScriptService('Document', XSCRIPTCONTEXT.getDocument())form = doc.Forms('Sheet1', 'FormA')form.Activate()ThisComponent applies to Calc and Writer documents. For Base documents use ThisDataBaseDocument. CloseFormDocument --------------------------------------------------------------------------------------------------------------------------
CloseFormDocument
This method is deprecated, use ScriptForge.FormDocument.CloseDocument method instead.Closes the form document containing the actual Form instance. The Form instance is disposed.svc.CloseFormDocument(): boolmyForm.CloseFormDocument() ' Basicform.CloseFormDocument() # Python Controls -------------------------------------------------------------------------------------------------------------------------- Form service;Controls
Controls
The value returned by the Controls method depends on the arguments provided:If the method is called without arguments, then it returns the list of the controls contained in the form. Be aware that the returned list does not contain any subform controls.If the optional ControlName argument is provided, the method returns a FormControl class instance referring to the specified control.svc.Controls(opt controlname: str): anycontrolname : A valid control name as a case-sensitive string. If absent, the list of control names is returned as a zero-based array.Dim myForm As Object, myList As Variant, myControl As ObjectSet myForm = myDoc.Forms("myForm")myList = myform.Controls()Set myControl = myform.Controls("myTextBox") ' SFDocuments.FormControlform = doc.Forms('myForm')form_names = form.Controls()form_control = form.Controls('myTextBox') # SFDocuments.FormControl GetDatabase -------------------------------------------------------------------------------------------------------------------------- Form service;GetDatabase
GetDatabase
Return a SFDatabases.Database instance giving access to the execution of SQL commands on the database the current form is connected to and/or that is stored in the current Base document.Each form has its own database connection, except in Base documents where they all share the same connection.svc.GetDatabase(opt user: str, opt password: str): svcuser, password: The login optional parameters (Default = "").Dim myDb As Object ' SFDatabases.DatabaseSet myDb = oForm.GetDatabase()db = form.GetDatabase() # SFDatabases.Database MoveFirst -------------------------------------------------------------------------------------------------------------------------- Form service;MoveFirst
MoveFirst
The form cursor is positioned on the first record. Returns True if successful.svc.MoveFirst(): boolmyForm.MoveFirst() ' Basicform.MoveFirst() # Python MoveLast -------------------------------------------------------------------------------------------------------------------------- Form service;MoveLast
MoveLast
The form cursor is positioned on the last record. Returns True if successful.svc.MoveLast(): boolmyForm.MoveLast() ' Basicform.MoveLast() # Python MoveNew -------------------------------------------------------------------------------------------------------------------------- Form service;MoveNew
MoveNew
The form cursor is positioned on the new record area. Returns True if successful.svc.MoveNew(): boolmyForm.MoveNew() ' Basicform.MoveNew() # Python MoveNext -------------------------------------------------------------------------------------------------------------------------- Form service;MoveNext
MoveNext
The form cursor is positioned on the next record. Returns True if successful.svc.MoveNext(opt offset: int): booloffset: The number of records to go forward (Default = 1).myForm.MoveNext() ' Basicform.MoveNext() # Python MovePrevious -------------------------------------------------------------------------------------------------------------------------- Form service;MovePrevious
MovePrevious
The form cursor is positioned on the previous record. Returns True if successful.svc.MovePrevious(opt offset: int): booloffset: The number of records to go backwards (Default = 1).myForm.MovePrevious() ' Basicform.MovePrevious() # Python Requery -------------------------------------------------------------------------------------------------------------------------- Form service;Requery
Requery
Reloads the current data from the database and refreshes the form. The cursor is positioned on the first record. Returns True if successful.svc.Requery(): boolmyForm.Requery() ' Basicform.Requery() # Python Subforms -------------------------------------------------------------------------------------------------------------------------- Form service;Subforms
Subforms
The value returned by the Subforms method depends on the arguments provided:If the method is called without any arguments, then it returns the list of subforms contained in the current form or subform instance.If the optional subform argument is provided, the method returns a new SFDocuments.Form instance based on the specified form/subform name or index.svc.Subforms(): str[0..*]svc.Subforms(subform: str): svcsvc.Subforms(subform: int): svcsubform: A subform stored in the current Form class instance given by its name or index.When this argument is absent, the method returns a list of available subforms as a zero-based array. If the form has a single subform, you can set subform = 0 to get access to it.Dim myForm As Object, myList As Variant, mySubform As ObjectmyList = myform.Subforms()Set mySubform = myForm.Subforms("mySubform") ' SFDocuments.Formsubform_names = form.Subforms()subform = form.Subforms('mySubform') # SFDocuments.Form