blob: 0d153b7058e2f0b0fea0299896e230e5d6da2e79 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
|
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd">
<script:module xmlns:script="http://openoffice.org/2000/script" script:name="Writer" script:language="StarBasic">REM ***** BASIC *****
Sub ConvertWriterTables()
Dim CellString as String
Dim oParagraphs as Object
Dim oPara as Object
Dim i as integer
Dim sCellNames()
Dim oCell as Object
oParagraphs = oDocument.Text.CreateEnumeration
While oParagraphs.HasMoreElements
oPara = oParagraphs.NextElement
If NOT oPara.supportsService("com.sun.star.text.Paragraph") Then
' Note: As cells might be splitted or merged
' you cannot refer to them via their indices
sCellNames = oPara.CellNames
For i = 0 To Ubound(sCellNames)
If sCellNames(i) <> "" Then
oCell = oPara.getCellByName(sCellNames(i))
If CheckFormatType(oCell) Then
SwitchNumberFormat(oCell, oFormats, sEuroSign)
ModifyObjectValuewithCurrFactor(oCell)
End If
End If
Next
End If
Wend
End Sub
Sub ModifyObjectValuewithCurrFactor(oDocObject as Object)
oDocObjectValue = oDocObject.Value
oDocObject.Value = oDocObjectValue/CurrFactor
End Sub
Sub ConvertTextFields()
Dim oTextFields as Object
Dim oTextField as Object
Dim FieldValue
Dim oDocObjectValue as double
Dim InstanceNames(500) as String
Dim CurInstanceName as String
Dim MaxIndex as Integer
MaxIndex = 0
oTextfields = oDocument.getTextfields.CreateEnumeration
While oTextFields.hasmoreElements
oTextField = oTextFields.NextElement
If oTextField.PropertySetInfo.HasPropertybyName("NumberFormat") Then
If CheckFormatType(oTextField) Then
If oTextField.PropertySetInfo.HasPropertybyName("Value") Then
If Not oTextField.SupportsService("com.sun.star.text.TextField.GetExpression") Then
oTextField.Content = CStr(Round(oTextField.Value/CurrFactor,2))
End If
ElseIf oTextField.TextFieldMaster.PropertySetInfo.HasPropertyByName("Value") Then
CurInstanceName = oTextField.TextFieldMaster.InstanceName
If Not FieldinArray(InstanceNames(), MaxIndex, CurInstanceName) Then
oTextField.TextFieldMaster.Content = CStr(Round(oTextField.TextFieldMaster.Value/CurrFactor,2))
InstanceNames(MaxIndex) = CurInstanceName
MaxIndex = MaxIndex + 1
End If
End If
SwitchNumberFormat(oTextField, oFormats, sEuroSign)
End If
End If
Wend
oDocument.GetTextFields.refresh()
End Sub
</script:module>
|