2010-09-18 07:24:46 +00:00
|
|
|
##########################################################################
|
|
|
|
#
|
|
|
|
# Portions of this file are under the following copyright and license:
|
|
|
|
#
|
|
|
|
#
|
|
|
|
# Copyright (c) 2003-2004 Danny Brewer
|
|
|
|
# d29583@groovegarden.com
|
|
|
|
#
|
|
|
|
# This library is free software; you can redistribute it and/or
|
|
|
|
# modify it under the terms of the GNU Lesser General Public
|
|
|
|
# License as published by the Free Software Foundation; either
|
|
|
|
# version 2.1 of the License, or (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This library is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
# Lesser General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU Lesser General Public
|
|
|
|
# License along with this library; if not, write to the Free Software
|
|
|
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
#
|
|
|
|
# See: http://www.gnu.org/licenses/lgpl.html
|
|
|
|
#
|
|
|
|
#
|
|
|
|
# and other portions are under the following copyright and license:
|
|
|
|
#
|
|
|
|
#
|
|
|
|
# OpenERP, Open Source Management Solution>..
|
|
|
|
# Copyright (C) 2004-2010 OpenERP SA (<http://openerp.com>).
|
|
|
|
#
|
|
|
|
# This program is free software: you can redistribute it and/or modify
|
2010-10-28 06:54:18 +00:00
|
|
|
# it under the terms of the GNU Affero General Public License as published by
|
2010-09-18 07:24:46 +00:00
|
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
2010-10-28 06:54:18 +00:00
|
|
|
# GNU Affero General Public License for more details.
|
2010-09-18 07:24:46 +00:00
|
|
|
#
|
2010-10-28 06:54:18 +00:00
|
|
|
# You should have received a copy of the GNU Affero General Public License
|
2010-09-18 07:24:46 +00:00
|
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
#
|
|
|
|
#
|
|
|
|
##############################################################################
|
|
|
|
import uno
|
|
|
|
import string
|
|
|
|
import unohelper
|
|
|
|
import xmlrpclib
|
|
|
|
from com.sun.star.task import XJobExecutor
|
|
|
|
if __name__<>"package":
|
|
|
|
from lib.gui import *
|
|
|
|
from lib.error import ErrorDialog
|
|
|
|
from lib.functions import *
|
|
|
|
from ServerParameter import *
|
|
|
|
from lib.logreport import *
|
|
|
|
from lib.rpc import *
|
|
|
|
from LoginTest import *
|
|
|
|
|
|
|
|
database="test_db1"
|
|
|
|
uid = 3
|
|
|
|
|
|
|
|
|
|
|
|
#class RepeatIn:
|
|
|
|
class RepeatIn( unohelper.Base, XJobExecutor ):
|
2012-03-05 18:40:03 +00:00
|
|
|
def __init__(self, sObject="", sVariable="", sFields="", sDisplayName="", bFromModify=False):
|
2010-09-18 07:24:46 +00:00
|
|
|
# Interface Design
|
|
|
|
LoginTest()
|
|
|
|
self.logobj=Logger()
|
|
|
|
if not loginstatus and __name__=="package":
|
|
|
|
exit(1)
|
|
|
|
|
|
|
|
self.win = DBModalDialog(60, 50, 180, 250, "RepeatIn Builder")
|
|
|
|
self.win.addFixedText("lblVariable", 2, 12, 60, 15, "Objects to loop on :")
|
|
|
|
self.win.addComboBox("cmbVariable", 180-120-2, 10, 120, 15,True, itemListenerProc=self.cmbVariable_selected)
|
|
|
|
self.insVariable = self.win.getControl( "cmbVariable" )
|
|
|
|
|
|
|
|
self.win.addFixedText("lblFields", 10, 32, 60, 15, "Field to loop on :")
|
|
|
|
self.win.addComboListBox("lstFields", 180-120-2, 30, 120, 150, False,itemListenerProc=self.lstbox_selected)
|
|
|
|
self.insField = self.win.getControl( "lstFields" )
|
|
|
|
|
|
|
|
self.win.addFixedText("lblName", 12, 187, 60, 15, "Variable name :")
|
|
|
|
self.win.addEdit("txtName", 180-120-2, 185, 120, 15,)
|
|
|
|
|
|
|
|
self.win.addFixedText("lblUName", 8, 207, 60, 15, "Displayed name :")
|
|
|
|
self.win.addEdit("txtUName", 180-120-2, 205, 120, 15,)
|
|
|
|
|
|
|
|
self.win.addButton('btnOK',-2 ,-10,45,15,'Ok', actionListenerProc = self.btnOk_clicked )
|
|
|
|
|
|
|
|
self.win.addButton('btnCancel',-2 - 45 - 5 ,-10,45,15,'Cancel', actionListenerProc = self.btnCancel_clicked )
|
|
|
|
|
|
|
|
global passwd
|
|
|
|
self.password = passwd
|
|
|
|
global url
|
|
|
|
self.sock=RPCSession(url)
|
|
|
|
# Variable Declaration
|
|
|
|
self.sValue=None
|
|
|
|
self.sObj=None
|
|
|
|
self.aSectionList=[]
|
|
|
|
self.sGVariable=sVariable
|
|
|
|
self.sGDisplayName=sDisplayName
|
|
|
|
self.aItemList=[]
|
|
|
|
self.aComponentAdd=[]
|
|
|
|
self.aObjectList=[]
|
|
|
|
self.aListRepeatIn=[]
|
|
|
|
self.aVariableList=[]
|
|
|
|
# Call method to perform Enumration on Report Document
|
|
|
|
EnumDocument(self.aItemList,self.aComponentAdd)
|
|
|
|
# Perform checking that Field-1 and Field - 4 is available or not alos get Combobox
|
|
|
|
# filled if condition is true
|
|
|
|
desktop = getDesktop()
|
|
|
|
doc = desktop.getCurrentComponent()
|
|
|
|
docinfo = doc.getDocumentInfo()
|
|
|
|
# Check weather Field-1 is available if not then exit from application
|
|
|
|
self.sMyHost= ""
|
|
|
|
|
|
|
|
if not docinfo.getUserFieldValue(3) == "" and not docinfo.getUserFieldValue(0)=="":
|
|
|
|
self.sMyHost= docinfo.getUserFieldValue(0)
|
|
|
|
self.count=0
|
|
|
|
oParEnum = doc.getTextFields().createEnumeration()
|
|
|
|
|
|
|
|
while oParEnum.hasMoreElements():
|
|
|
|
oPar = oParEnum.nextElement()
|
|
|
|
if oPar.supportsService("com.sun.star.text.TextField.DropDown"):
|
|
|
|
self.count += 1
|
|
|
|
|
|
|
|
getList(self.aObjectList, self.sMyHost,self.count)
|
|
|
|
cursor = doc.getCurrentController().getViewCursor()
|
|
|
|
text = cursor.getText()
|
|
|
|
tcur = text.createTextCursorByRange(cursor)
|
|
|
|
|
|
|
|
self.aVariableList.extend( filter( lambda obj: obj[:obj.find(" ")] == "List", self.aObjectList ) )
|
|
|
|
|
|
|
|
for i in range(len(self.aItemList)):
|
|
|
|
try:
|
|
|
|
anItem = self.aItemList[i][1]
|
|
|
|
component = self.aComponentAdd[i]
|
|
|
|
|
|
|
|
if component == "Document":
|
|
|
|
sLVal = anItem[anItem.find(",'") + 2:anItem.find("')")]
|
|
|
|
self.aVariableList.extend( filter( lambda obj: obj[:obj.find("(")] == sLVal, self.aObjectList ) )
|
|
|
|
|
|
|
|
if tcur.TextSection:
|
|
|
|
getRecersiveSection(tcur.TextSection,self.aSectionList)
|
|
|
|
if component in self.aSectionList:
|
|
|
|
sLVal = anItem[anItem.find(",'") + 2:anItem.find("')")]
|
|
|
|
self.aVariableList.extend( filter( lambda obj: obj[:obj.find("(")] == sLVal, self.aObjectList ) )
|
|
|
|
|
|
|
|
if tcur.TextTable:
|
|
|
|
if not component == "Document" and component[component.rfind(".") + 1:] == tcur.TextTable.Name:
|
|
|
|
VariableScope( tcur, self.aVariableList, self.aObjectList, self.aComponentAdd, self.aItemList, component )
|
|
|
|
except :
|
|
|
|
import traceback,sys
|
|
|
|
info = reduce(lambda x, y: x+y, traceback.format_exception(sys.exc_type, sys.exc_value, sys.exc_traceback))
|
|
|
|
self.logobj.log_write('RepeatIn', LOG_ERROR, info)
|
|
|
|
self.bModify=bFromModify
|
|
|
|
|
|
|
|
if self.bModify==True:
|
|
|
|
|
|
|
|
if sObject=="":
|
|
|
|
self.insVariable.setText("List of "+docinfo.getUserFieldValue(3))
|
|
|
|
self.insField.addItem("objects",self.win.getListBoxItemCount("lstFields"))
|
|
|
|
self.win.setEditText("txtName", sVariable)
|
|
|
|
self.win.setEditText("txtUName",sDisplayName)
|
|
|
|
self.sValue= "objects"
|
|
|
|
else:
|
|
|
|
sItem=""
|
2013-03-04 17:31:32 +00:00
|
|
|
for anObject in self.aObjectList:
|
|
|
|
if anObject[:anObject.find("(")] == sObject:
|
|
|
|
sItem = anObject
|
|
|
|
self.insVariable.setText( sItem )
|
|
|
|
|
|
|
|
genTree(
|
|
|
|
sItem[sItem.find("(")+1:sItem.find(")")],
|
|
|
|
self.aListRepeatIn,
|
|
|
|
self.insField,
|
|
|
|
self.sMyHost,
|
|
|
|
2,
|
|
|
|
ending=['one2many','many2many'],
|
|
|
|
recur=['one2many','many2many']
|
|
|
|
)
|
2010-09-18 07:24:46 +00:00
|
|
|
|
|
|
|
self.sValue= self.win.getListBoxItem("lstFields",self.aListRepeatIn.index(sFields))
|
|
|
|
|
|
|
|
for var in self.aVariableList:
|
|
|
|
|
2013-03-04 17:31:32 +00:00
|
|
|
if var[:8] <> 'List of ':
|
|
|
|
self.model_ids = self.sock.execute(database, uid, self.password, 'ir.model' , 'search', [('model','=',var[var.find("(")+1:var.find(")")])])
|
2010-09-18 07:24:46 +00:00
|
|
|
else:
|
2013-03-04 17:31:32 +00:00
|
|
|
self.model_ids = self.sock.execute(database, uid, self.password, 'ir.model' , 'search', [('model','=',var[8:])])
|
2010-09-18 07:24:46 +00:00
|
|
|
fields=['name','model']
|
|
|
|
self.model_res = self.sock.execute(database, uid, self.password, 'ir.model', 'read', self.model_ids,fields)
|
|
|
|
if self.model_res <> []:
|
2013-03-04 17:31:32 +00:00
|
|
|
if var[:8]<>'List of ':
|
2010-09-18 07:24:46 +00:00
|
|
|
self.insVariable.addItem(var[:var.find("(")+1] + self.model_res[0]['name'] + ")" ,self.insVariable.getItemCount())
|
|
|
|
else:
|
|
|
|
self.insVariable.addItem('List of ' + self.model_res[0]['name'] ,self.insVariable.getItemCount())
|
|
|
|
else:
|
|
|
|
self.insVariable.addItem(var ,self.insVariable.getItemCount())
|
|
|
|
|
|
|
|
self.win.doModalDialog("lstFields",self.sValue)
|
|
|
|
else:
|
|
|
|
ErrorDialog("Please Select Appropriate module" ,"Create new report from: \nOpenERP -> Open a New Report")
|
|
|
|
self.win.endExecute()
|
|
|
|
|
2012-03-05 18:40:03 +00:00
|
|
|
def lstbox_selected(self, oItemEvent):
|
2010-09-18 07:24:46 +00:00
|
|
|
sItem=self.win.getListBoxSelectedItem("lstFields")
|
|
|
|
sMain=self.aListRepeatIn[self.win.getListBoxSelectedItemPos("lstFields")]
|
|
|
|
|
|
|
|
if self.bModify==True:
|
|
|
|
self.win.setEditText("txtName", self.sGVariable)
|
|
|
|
self.win.setEditText("txtUName",self.sGDisplayName)
|
|
|
|
else:
|
2013-03-04 17:31:32 +00:00
|
|
|
self.win.setEditText("txtName",sMain[sMain.rfind("/")+1:])
|
|
|
|
self.win.setEditText("txtUName","|-."+sItem[sItem.rfind("/")+1:]+".-|")
|
2010-09-18 07:24:46 +00:00
|
|
|
|
2012-03-05 18:40:03 +00:00
|
|
|
def cmbVariable_selected(self, oItemEvent):
|
2010-09-18 07:24:46 +00:00
|
|
|
|
|
|
|
if self.count > 0 :
|
|
|
|
|
|
|
|
desktop=getDesktop()
|
|
|
|
doc =desktop.getCurrentComponent()
|
|
|
|
docinfo=doc.getDocumentInfo()
|
|
|
|
self.win.removeListBoxItems("lstFields", 0, self.win.getListBoxItemCount("lstFields"))
|
|
|
|
sItem=self.win.getComboBoxText("cmbVariable")
|
|
|
|
for var in self.aVariableList:
|
2013-03-04 17:31:32 +00:00
|
|
|
if var[:8]=='List of ':
|
|
|
|
if var[:8]==sItem[:8]:
|
2010-09-18 07:24:46 +00:00
|
|
|
sItem = var
|
2013-03-04 17:31:32 +00:00
|
|
|
elif var[:var.find("(")+1] == sItem[:sItem.find("(")+1]:
|
2010-09-18 07:24:46 +00:00
|
|
|
sItem = var
|
|
|
|
self.aListRepeatIn=[]
|
|
|
|
|
2013-03-04 17:31:32 +00:00
|
|
|
data = ( sItem[sItem.rfind(" ") + 1:] == docinfo.getUserFieldValue(3) ) and docinfo.getUserFieldValue(3) or sItem[sItem.find("(")+1:sItem.find(")")]
|
|
|
|
genTree( data, self.aListRepeatIn, self.insField, self.sMyHost, 2, ending=['one2many','many2many'], recur=['one2many','many2many'] )
|
2010-09-18 07:24:46 +00:00
|
|
|
|
|
|
|
self.win.selectListBoxItemPos("lstFields", 0, True )
|
|
|
|
|
|
|
|
else:
|
|
|
|
sItem=self.win.getComboBoxText("cmbVariable")
|
|
|
|
for var in self.aVariableList:
|
|
|
|
if var[:8]=='List of ' and var[:8] == sItem[:8]:
|
|
|
|
sItem = var
|
|
|
|
if sItem.find(".")==-1:
|
|
|
|
temp=sItem[sItem.rfind("x_"):]
|
|
|
|
else:
|
|
|
|
temp=sItem[sItem.rfind(".")+1:]
|
|
|
|
self.win.setEditText("txtName",temp)
|
|
|
|
self.win.setEditText("txtUName","|-."+temp+".-|")
|
|
|
|
self.insField.addItem("objects",self.win.getListBoxItemCount("lstFields"))
|
|
|
|
self.win.selectListBoxItemPos("lstFields", 0, True )
|
|
|
|
|
|
|
|
def btnOk_clicked(self, oActionEvent):
|
|
|
|
desktop=getDesktop()
|
|
|
|
doc = desktop.getCurrentComponent()
|
|
|
|
cursor = doc.getCurrentController().getViewCursor()
|
|
|
|
selectedItem = self.win.getListBoxSelectedItem( "lstFields" )
|
|
|
|
selectedItemPos = self.win.getListBoxSelectedItemPos( "lstFields" )
|
|
|
|
txtName = self.win.getEditText( "txtName" )
|
|
|
|
txtUName = self.win.getEditText( "txtUName" )
|
|
|
|
if selectedItem != "" and txtName != "" and txtUName != "":
|
|
|
|
sKey=u""+ txtUName
|
|
|
|
if selectedItem == "objects":
|
|
|
|
sValue=u"[[ repeatIn(" + selectedItem + ",'" + txtName + "') ]]"
|
|
|
|
else:
|
|
|
|
sObjName=self.win.getComboBoxText("cmbVariable")
|
|
|
|
sObjName=sObjName[:sObjName.find("(")]
|
|
|
|
sValue=u"[[ repeatIn(" + sObjName + self.aListRepeatIn[selectedItemPos].replace("/",".") + ",'" + txtName +"') ]]"
|
|
|
|
|
|
|
|
if self.bModify == True:
|
|
|
|
oCurObj = cursor.TextField
|
|
|
|
oCurObj.Items = (sKey,sValue)
|
|
|
|
oCurObj.update()
|
|
|
|
else:
|
|
|
|
oInputList = doc.createInstance("com.sun.star.text.TextField.DropDown")
|
|
|
|
if self.win.getListBoxSelectedItem("lstFields") == "objects":
|
|
|
|
oInputList.Items = (sKey,sValue)
|
|
|
|
doc.Text.insertTextContent(cursor,oInputList,False)
|
|
|
|
else:
|
|
|
|
sValue=u"[[ repeatIn(" + sObjName + self.aListRepeatIn[selectedItemPos].replace("/",".") + ",'" + txtName +"') ]]"
|
|
|
|
if cursor.TextTable==None:
|
|
|
|
oInputList.Items = (sKey,sValue)
|
|
|
|
doc.Text.insertTextContent(cursor,oInputList,False)
|
|
|
|
else:
|
|
|
|
oInputList.Items = (sKey,sValue)
|
|
|
|
widget = ( cursor.TextTable or selectedItem <> 'objects' ) and cursor.TextTable.getCellByName( cursor.Cell.CellName ) or doc.Text
|
|
|
|
widget.insertTextContent(cursor,oInputList,False)
|
|
|
|
self.win.endExecute()
|
|
|
|
else:
|
2012-07-25 11:55:11 +00:00
|
|
|
ErrorDialog("Please fill appropriate data in Object Field or Name field \nor select particular value from the list of fields.")
|
2010-09-18 07:24:46 +00:00
|
|
|
|
2012-03-05 18:40:03 +00:00
|
|
|
def btnCancel_clicked(self, oActionEvent):
|
2010-09-18 07:24:46 +00:00
|
|
|
self.win.endExecute()
|
|
|
|
|
|
|
|
if __name__<>"package" and __name__=="__main__":
|
|
|
|
RepeatIn()
|
|
|
|
elif __name__=="package":
|
|
|
|
g_ImplementationHelper = unohelper.ImplementationHelper()
|
|
|
|
g_ImplementationHelper.addImplementation( RepeatIn, "org.openoffice.openerp.report.repeatln", ("com.sun.star.task.Job",),)
|
2011-11-22 08:51:38 +00:00
|
|
|
|
|
|
|
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
|