On working with dictionaries, the user need to save specified selection and restore it, for example, at the next start of form. The selection can be stored in different places (file on disk, registry, table on server and so on). Consider methods for saving and restoring the selection.
A range of methods used to save and restore the selection is implemented in the IDimSelection interface:
ToVariant and Parse - selection is saved and restored by value of the ID attribute.
AttributeToVariant and ParseAttribute - selection is saved and restored by the selected attribute (this attribute should contain a unique index in the dictionary).
The methods are based on working with array of the Variant type, containing values of the selected element attribute.
Consider possible variant of saving and restoring the selection from OS registry. Selection is saved as character string in the registry parameter Selection1 in the registry section HKEY_CURRENT_USER\UserProject\Selection.
Procedure to write selection to the registry:
Sub WriteSelToRegistry(s: String);
Var
CurrentKey, ProjKey: IRegistryKey;
Begin
CurrentKey := RegistryClass.CurrentUser;
//Open the registry section, in which selection is stored
If CurrentKey.SubKeyExists("UserProject\Selection") Then
ProjKey := CurrentKey.OpenSubKey("UserProject\Selection", True);
Else
ProjKey := CurrentKey.CreateSubKey("UserProject\Selection");
End If;
//Record of selection in the registry parameter Selection1
ProjKey.WriteString("Selection1", s);
End Sub WriteSelToRegistry;
Function to read selection from the registry:
Function ReadSelFromRegistry: String;
Var
CurrentKey, ProjKey: IRegistryKey;
s: String;
Begin
CurrentKey := RegistryClass.CurrentUser;
//Open the registry section, in which selection is stored
If CurrentKey.SubKeyExists("UserProject\Selection") Then
ProjKey := CurrentKey.OpenSubKey("UserProject\Selection", True);
Else
ProjKey := CurrentKey.CreateSubKey("UserProject\Selection");
End If;
//Read selection from the registry parameter Selection1
s := ProjKey.ReadStringDef("Selection1", "");
Return s;
End Function ReadSelFromRegistry;
To form selection as character string, the IDimSelection.ToString method can be used, or the method String.Join:
Var
Selection: IDimSelection;
Sel: String;
Begin
//Receive selection
Selection := UiDimension1.Selection;
//For compatibility with the ToVariant method, save selection by values of the ID identifier
Sel := Selection.ToString("ID");
WriteSelToRegistry(Sel);
or:
Var
Selection: IDimSelection;
VarSel: Array Of Variant;
StrSel: Array Of String;
Sel: String;
i: Integer;
Begin
Selection := //Receive selection
VarSel := Selection.ToVariant As Array;
StrSel := New String[VarSel.Length];
For i := 0 To VarSel.Length - 1 Do
//Create symbol array, for further integration to the string
StrSel[i] := VarSel[i] As String;
End For;
//For matching with work of method ToString, save selection with delimiter ","
Sel := String.Join(",", StrSel);
WriteSelToRegistry(Sel);
To restore selection from the registry, the ReadSelFromRegistry function described above reads saved value from the registry, and parses the received string into array of the Variant type containing number values of identifiers:
Var
Selection: IDimSelection;
Sel: String;
StrSel: Array Of String;
VarSel: Array Of Variant;
i: Integer;
Begin
Selection := //Receive selection
//Read character value of selection
Sel := ReadSelFromRegistry;
//Converting of selection in symbol array
StrSel := Sel.Split(",");
//Create array of the Variant type, in which number values of identifiers are typed in
//The Variant type is required for the method IDimSelection.Parse
VarSel := New Variant[StrSel.Length];
For i := 0 To StrSel.Length - 1 Do
VarSel[i] := Integer.Parse(StrSel[i]);
End For;
//Restore selection
Selection.Parse(VarSel);
The received selection can be used where necessary.
See also: