summaryrefslogtreecommitdiff
path: root/wizards
diff options
context:
space:
mode:
authorXisco Fauli <anistenis@gmail.com>2011-07-31 18:40:11 +0200
committerBjoern Michaelsen <bjoern.michaelsen@canonical.com>2011-08-18 02:57:44 +0200
commitb46e5dd918c010f56947144c82fd6dee5838ff16 (patch)
tree1caea25386667cf12dd94ca22da4a3635d379304 /wizards
parent927ba7df4028bda0f1b38698d9f85e2ca7124850 (diff)
Fix a scroll problem
Diffstat (limited to 'wizards')
-rw-r--r--wizards/com/sun/star/wizards/agenda/TopicsControl.py113
-rw-r--r--wizards/com/sun/star/wizards/ui/ControlScroller.py14
2 files changed, 62 insertions, 65 deletions
diff --git a/wizards/com/sun/star/wizards/agenda/TopicsControl.py b/wizards/com/sun/star/wizards/agenda/TopicsControl.py
index 74d95d120244..b5bb0820e75f 100644
--- a/wizards/com/sun/star/wizards/agenda/TopicsControl.py
+++ b/wizards/com/sun/star/wizards/agenda/TopicsControl.py
@@ -83,8 +83,6 @@ class TopicsControl(ControlScroller):
TOPIC = "txtTopicTopic_"
RESP = "cbTopicResp_"
TIME = "txtTopicTime_"
- I_12 = 12
- I_8 = 8
nscrollvalue = 0
LABEL_PROPS = (PropertyNames.PROPERTY_HEIGHT, PropertyNames.PROPERTY_LABEL,
PropertyNames.PROPERTY_POSITION_X, PropertyNames.PROPERTY_POSITION_Y,
@@ -148,8 +146,8 @@ class TopicsControl(ControlScroller):
self.setTotalFieldCount(l + 1)
# if the new row is visible, it must have been disabled
# so it should be now enabled...
- if l - TopicsControl.nscrollvalue < self.nblockincrement:
- self.ControlGroupVector[l - TopicsControl.nscrollvalue].\
+ if l - ControlScroller.nscrollvalue < self.nblockincrement:
+ self.ControlGroupVector[l - ControlScroller.nscrollvalue].\
setEnabled(True)
'''
@@ -171,15 +169,15 @@ class TopicsControl(ControlScroller):
def removeLastRow(self):
l = len(ControlScroller.scrollfields)
# if we should scroll up...
- if (l - TopicsControl.nscrollvalue) >= 1 \
- and (l - TopicsControl.nscrollvalue) <= self.nblockincrement \
- and TopicsControl.nscrollvalue > 0:
- while (l - TopicsControl.nscrollvalue >= 1) \
- and l - TopicsControl.nscrollvalue <= self.nblockincrement \
- and TopicsControl.nscrollvalue > 0:
- setScrollValue(TopicsControl.nscrollvalue - 1)
+ if (l - ControlScroller.nscrollvalue) >= 1 \
+ and (l - ControlScroller.nscrollvalue) <= self.nblockincrement \
+ and ControlScroller.nscrollvalue > 0:
+ while (l - ControlScroller.nscrollvalue >= 1) \
+ and l - ControlScroller.nscrollvalue <= self.nblockincrement \
+ and ControlScroller.nscrollvalue > 0:
+ self.setScrollValue(ControlScroller.nscrollvalue - 1)
# if we should disable a row...
- elif TopicsControl.nscrollvalue == 0 and l - 1 < self.nblockincrement:
+ elif ControlScroller.nscrollvalue == 0 and l - 1 < self.nblockincrement:
self.ControlGroupVector[l - 1].setEnabled(False)
self.unregisterControlGroup(l - 1)
@@ -214,7 +212,7 @@ class TopicsControl(ControlScroller):
name = Helper.getUnoPropertyValue(
control.Model, PropertyNames.PROPERTY_NAME)
num = name[name.index("_") + 1:]
- TopicsControl.lastFocusRow = int(num) + TopicsControl.nscrollvalue
+ TopicsControl.lastFocusRow = int(num) + ControlScroller.nscrollvalue
TopicsControl.lastFocusControl = control
# enable/disable the buttons...
self.enableButtons()
@@ -262,8 +260,8 @@ class TopicsControl(ControlScroller):
pv1[2].Value = pv2[2].Value
pv1[3].Value = pv2[3].Value
self.updateDocumentRow(i)
- if i - TopicsControl.nscrollvalue < self.nblockincrement:
- self.fillupControl(i - TopicsControl.nscrollvalue)
+ if i - ControlScroller.nscrollvalue < self.nblockincrement:
+ self.fillupControl(i - ControlScroller.nscrollvalue)
self.removeLastRow()
# update the live preview background document
@@ -292,8 +290,8 @@ class TopicsControl(ControlScroller):
pv1[2].Value = pv2[2].Value
pv1[3].Value = pv2[3].Value
self.updateDocumentRow(i)
- if i - TopicsControl.nscrollvalue < self.nblockincrement:
- self.fillupControl(i - TopicsControl.nscrollvalue)
+ if i - ControlScroller.nscrollvalue < self.nblockincrement:
+ self.fillupControl(i - ControlScroller.nscrollvalue)
# after rotating all the properties from this row on,
# we clear the row, so it is practically a new one...
@@ -304,7 +302,7 @@ class TopicsControl(ControlScroller):
# update the preview document.
self.updateDocumentRow(TopicsControl.lastFocusRow)
self.fillupControl(
- TopicsControl.lastFocusRow - TopicsControl.nscrollvalue)
+ TopicsControl.lastFocusRow - ControlScroller.nscrollvalue)
self.enableButtons()
if TopicsControl.lastFocusControl is not None:
@@ -360,7 +358,7 @@ class TopicsControl(ControlScroller):
def isRowEmpty(self, row):
data = self.getTopicData(row)
# now - is this row empty?
- return data[1].Value and data[2].Value and data[3].Value
+ return data[1].Value and data[2].Value and data[3].Value
'''
update the preview document and
@@ -375,7 +373,7 @@ class TopicsControl(ControlScroller):
with TopicsControl.lock:
try:
# First, I update the document
- data = self.getTopicData(guiRow + TopicsControl.nscrollvalue)
+ data = self.getTopicData(guiRow + ControlScroller.nscrollvalue)
if data is None:
return
@@ -386,14 +384,14 @@ class TopicsControl(ControlScroller):
TopicsControl.oldData = dataValue
self.updateDocumentCell(
- guiRow + TopicsControl.nscrollvalue, column, data)
- if self.isRowEmpty(guiRow + TopicsControl.nscrollvalue):
+ guiRow + ControlScroller.nscrollvalue, column, data)
+ if self.isRowEmpty(guiRow + ControlScroller.nscrollvalue):
'''
if this is the row before the last one
(the last row is always empty)
delete the last row...
'''
- if (guiRow + TopicsControl.nscrollvalue) \
+ if (guiRow + ControlScroller.nscrollvalue) \
== len(ControlScroller.scrollfields) - 2:
self.removeLastRow()
'''now consequentially check the last two rows,
@@ -405,7 +403,7 @@ class TopicsControl(ControlScroller):
and isRowEmpty(len(ControlScroller.scrollfields) - 2):
removeLastRow()
cr = self.ControlGroupVector[
- ControlScroller.scrollfields.size - TopicsControl.nscrollvalue - 1]
+ ControlScroller.scrollfields.size - ControlScroller.nscrollvalue - 1]
# if a remove was performed, set focus
#to the last row with some data in it...
self.focus(getControl(cr, column))
@@ -415,7 +413,7 @@ class TopicsControl(ControlScroller):
else:
# row contains data
# is this the last row?
- if (guiRow + TopicsControl.nscrollvalue + 1) \
+ if (guiRow + ControlScroller.nscrollvalue + 1) \
== len(ControlScroller.scrollfields):
self.insertRowAtEnd()
@@ -446,9 +444,9 @@ class TopicsControl(ControlScroller):
try:
if event.KeyCode == TAB and event.Modifiers == 0:
# if there is another row...
- if (self.nblockincrement + TopicsControl.nscrollvalue) \
+ if (self.nblockincrement + ControlScroller.nscrollvalue) \
< len(ControlScroller.scrollfields):
- self.setScrollValue(TopicsControl.nscrollvalue + 1)
+ self.setScrollValue(ControlScroller.nscrollvalue + 1)
self.focus(self.getControlByIndex(self.ControlGroupVector[4], 1))
except Exception:
traceback.print_exc()
@@ -463,8 +461,8 @@ class TopicsControl(ControlScroller):
# if tab with shift was pressed...
if (event.KeyCode == TAB) and \
(event.Modifiers == SHIFT):
- if TopicsControl.nscrollvalue > 0:
- setScrollValue(TopicsControl.nscrollvalue - 1)
+ if ControlScroller.nscrollvalue > 0:
+ setScrollValue(ControlScroller.nscrollvalue - 1)
focus(self.lastTime)
'''
@@ -490,26 +488,26 @@ class TopicsControl(ControlScroller):
def rowDown(self, guiRow=None, control=None):
try:
if guiRow is None and control is None:
- guiRow = TopicsControl.lastFocusRow - TopicsControl.nscrollvalue
+ guiRow = TopicsControl.lastFocusRow - ControlScroller.nscrollvalue
control = TopicsControl.lastFocusControl
# only perform if this is not the last row.
- actuallRow = guiRow + TopicsControl.nscrollvalue
+ actuallRow = guiRow + ControlScroller.nscrollvalue
if actuallRow + 1 < len(ControlScroller.scrollfields):
# get the current selection
selection = control.Selection
# the last row should scroll...
- scroll = guiRow == (self.nblockincrement - 1)
+ scroll = (guiRow == self.nblockincrement - 1)
if scroll:
- setScrollValue(TopicsControl.nscrollvalue + 1)
+ self.setScrollValue(ControlScroller.nscrollvalue + 1)
- scroll1 = TopicsControl.nscrollvalue
+ scroll1 = ControlScroller.nscrollvalue
if scroll:
aux = -1
else:
aux = 1
self.switchRows(guiRow, guiRow + aux)
- if TopicsControl.nscrollvalue != scroll1:
- guiRow += (TopicsControl.nscrollvalue - scroll1)
+ if ControlScroller.nscrollvalue != scroll1:
+ guiRow += (ControlScroller.nscrollvalue - scroll1)
self.setSelection(guiRow + (not scroll), control, selection)
except Exception:
@@ -523,17 +521,17 @@ class TopicsControl(ControlScroller):
def rowUp(self, guiRow=None, control=None):
try:
if guiRow is None and control is None:
- guiRow = TopicsControl.lastFocusRow - TopicsControl.nscrollvalue
+ guiRow = TopicsControl.lastFocusRow - ControlScroller.nscrollvalue
control = TopicsControl.lastFocusControl
# only perform if this is not the first row
- actuallRow = guiRow + TopicsControl.nscrollvalue
+ actuallRow = guiRow + ControlScroller.nscrollvalue
if actuallRow > 0:
# get the current selection
selection = control.Selection
# the last row should scroll...
scroll = (guiRow == 0)
if scroll:
- setScrollValue(TopicsControl.nscrollvalue - 1)
+ self.setScrollValue(ControlScroller.nscrollvalue - 1)
if scroll:
aux = 1
else:
@@ -553,7 +551,7 @@ class TopicsControl(ControlScroller):
@synchronized(lock)
def cursorUp(self, guiRow, control):
# is this the last full row ?
- actuallRow = guiRow + TopicsControl.nscrollvalue
+ actuallRow = guiRow + ControlScroller.nscrollvalue
#if this is the first row
if actuallRow == 0:
return
@@ -561,7 +559,7 @@ class TopicsControl(ControlScroller):
scroll = (guiRow == 0)
if scroll:
- setScrollValue(TopicsControl.nscrollvalue - 1)
+ self.setScrollValue(ControlScroller.nscrollvalue - 1)
upperRow = self.ControlGroupVector[guiRow]
else:
upperRow = self.ControlGroupVector[guiRow - 1]
@@ -578,7 +576,7 @@ class TopicsControl(ControlScroller):
@synchronized(lock)
def cursorDown(self, guiRow, control):
# is this the last full row ?
- actuallRow = guiRow + TopicsControl.nscrollvalue
+ actuallRow = guiRow + ControlScroller.nscrollvalue
#if this is the last row, exit
if actuallRow == len(ControlScroller.scrollfields) - 1:
return
@@ -586,7 +584,7 @@ class TopicsControl(ControlScroller):
scroll = (guiRow == self.nblockincrement - 1)
if scroll:
- setScrollValue(TopicsControl.nscrollvalue + 1)
+ self.setScrollValue(ControlScroller.nscrollvalue + 1)
lowerRow = self.ControlGroupVector[guiRow]
else:
# if we scrolled we are done...
@@ -602,8 +600,8 @@ class TopicsControl(ControlScroller):
'''
def switchRows(self, row1, row2):
- o1 = ControlScroller.scrollfields[row1 + TopicsControl.nscrollvalue]
- o2 = ControlScroller.scrollfields[row2 + TopicsControl.nscrollvalue]
+ o1 = ControlScroller.scrollfields[row1 + ControlScroller.nscrollvalue]
+ o2 = ControlScroller.scrollfields[row2 + ControlScroller.nscrollvalue]
temp = None
for i in xrange(1, len(o1)):
temp = o1[i].Value
@@ -611,15 +609,15 @@ class TopicsControl(ControlScroller):
o2[i].Value = temp
self.fillupControl(row1)
self.fillupControl(row2)
- self.updateDocumentRow(row1 + TopicsControl.nscrollvalue, o1)
- self.updateDocumentRow(row2 + TopicsControl.nscrollvalue, o2)
+ self.updateDocumentRow(row1 + ControlScroller.nscrollvalue, o1)
+ self.updateDocumentRow(row2 + ControlScroller.nscrollvalue, o2)
'''
if we changed the last row, add another one...
'''
- if (row1 + TopicsControl.nscrollvalue + 1 == \
+ if (row1 + ControlScroller.nscrollvalue + 1 == \
len(ControlScroller.scrollfields)) \
- or (row2 + TopicsControl.nscrollvalue + 1 == \
+ or (row2 + ControlScroller.nscrollvalue + 1 == \
len(ControlScroller.scrollfields)):
self.insertRowAtEnd()
@@ -629,8 +627,8 @@ class TopicsControl(ControlScroller):
have two empty rows at the end.
If so, delete the last one...
'''
- elif (row1 + TopicsControl.nscrollvalue) + \
- (row2 + TopicsControl.nscrollvalue) \
+ elif (row1 + ControlScroller.nscrollvalue) + \
+ (row2 + ControlScroller.nscrollvalue) \
== (len(ControlScroller.scrollfields) * 2 - 5):
if self.isRowEmpty(len(ControlScroller.scrollfields) - 2) \
and self.isRowEmpty(len(ControlScroller.scrollfields) - 1):
@@ -765,8 +763,8 @@ Note that the instance methods of this class
are being called and handle controls of
a single row.
'''
-class ControlRow(object):
+class ControlRow(object):
tabIndex = 520
'''
@@ -788,25 +786,22 @@ class ControlRow(object):
self.label = self.dialog.insertLabel(
TopicsControl.LABEL + str(i),
TopicsControl.LABEL_PROPS,
- (TopicsControl.I_8, "" + str(i + 1) + ".",
+ (8, "" + str(i + 1) + ".",
x + 4, y + 2, ControlScroller.iStep, tabindex, 10))
self.textbox = self.dialog.insertTextField(
TopicsControl.TOPIC + str(i), "topicTextChanged",
TopicsControl.TEXT_PROPS,
- (TopicsControl.I_12,
- HelpIds.getHelpIdString(ControlScroller.curHelpIndex + i * 3 + 1),
+ (12, HelpIds.getHelpIdString(ControlScroller.curHelpIndex + i * 3 + 1),
x + 15, y, ControlScroller.iStep, tabindex + 1, 84), self)
self.combobox = self.dialog.insertTextField(
TopicsControl.RESP + str(i), "responsibleTextChanged",
TopicsControl.TEXT_PROPS,
- (TopicsControl.I_12,
- HelpIds.getHelpIdString(ControlScroller.curHelpIndex + i * 3 + 2),
+ (12, HelpIds.getHelpIdString(ControlScroller.curHelpIndex + i * 3 + 2),
x + 103, y, ControlScroller.iStep, tabindex + 2, 68), self)
self.timebox = self.dialog.insertTextField(
TopicsControl.TIME + str(i), "timeTextChanged",
TopicsControl.TEXT_PROPS,
- (TopicsControl.I_12,
- HelpIds.getHelpIdString(ControlScroller.curHelpIndex + i * 3 + 3),
+ (12, HelpIds.getHelpIdString(ControlScroller.curHelpIndex + i * 3 + 3),
x + 175, y, ControlScroller.iStep, tabindex + 3, 20), self)
self.setEnabled(False)
self.textbox.addKeyListener(KeyListenerProcAdapter(self.keyPressed))
diff --git a/wizards/com/sun/star/wizards/ui/ControlScroller.py b/wizards/com/sun/star/wizards/ui/ControlScroller.py
index 16a34c597d64..701e494ff056 100644
--- a/wizards/com/sun/star/wizards/ui/ControlScroller.py
+++ b/wizards/com/sun/star/wizards/ui/ControlScroller.py
@@ -17,7 +17,6 @@ class ControlScroller(object):
iStep = None
curHelpIndex = None
-
# TODO add parameters for tabindices and helpindex
def __init__(self, _CurUnoDialog, _xMSF, _iStep, _iCompPosX, _iCompPosY,
_iCompWidth, _nblockincrement, _nlinedistance, _firsthelpindex):
@@ -113,8 +112,9 @@ class ControlScroller(object):
except Exception:
traceback.print_exc()
+ @classmethod
def fillupControls(self, binitialize):
- for i in xrange(0, ControlScroller.nblockincrement):
+ for i in xrange(ControlScroller.nblockincrement):
if i < self.ncurfieldcount:
self.fillupControl(i)
@@ -125,12 +125,13 @@ class ControlScroller(object):
def fillupControl(self, guiRow):
nameProps = ControlScroller.scrollfields[guiRow]
valueProps = ControlScroller.scrollfields[guiRow + ControlScroller.nscrollvalue]
- for i in nameProps:
- if ControlScroller.CurUnoDialog.xDialogModel.hasByName(i.Name):
- self.setControlData(i.Name, i.Value)
+ for index, item in enumerate(nameProps):
+ if ControlScroller.CurUnoDialog.xDialogModel.hasByName(item.Name):
+ self.setControlData(item.Name, valueProps[index].Value)
else:
raise AttributeError("No such control !")
+ @classmethod
def setScrollValue(self, _nscrollvalue, _ntotfieldcount=None):
if _ntotfieldcount is not None:
self.setTotalFieldCount(_ntotfieldcount)
@@ -178,6 +179,7 @@ class ControlScroller(object):
m += 1
n += 1
+ @classmethod
def scrollControls(self):
try:
self.scrollRowsInfo()
@@ -187,11 +189,11 @@ class ControlScroller(object):
>= self.ntotfieldcount:
ControlScroller.nscrollvalue = \
self.ntotfieldcount - ControlScroller.nblockincrement
-
self.fillupControls(False)
except Exception:
traceback.print_exc()
+ @classmethod
def scrollRowsInfo(self):
if len(ControlScroller.scrollfields) > 0:
cols = len(ControlScroller.scrollfields[0])