# -*- coding: utf-8 -*- #---------------------------------------------------------------------------- # Author: Pierre Ratinaud # #comes from ListCtrl.py from the demo tool of wxPython: # Author: Robin Dunn & Gary Dumer # # Created: # Copyright: (c) 1998 by Total Control Software # Licence: wxWindows license #---------------------------------------------------------------------------- import os import sys import wx import wx.lib.mixins.listctrl as listmix import cStringIO import tempfile from functions import exec_rcode from dialog import message, BarFrame from chemins import ffr #--------------------------------------------------------------------------- class SearchList(wx.ListCtrl, listmix.ListCtrlAutoWidthMixin, listmix.ColumnSorterMixin): #wx.Panel, listmix.ColumnSorterMixin): def __init__(self, parent,gparent, dlist,first, nbactives, nbetoiles, add_dendro=True): wx.ListCtrl.__init__( self, parent, -1, style=wx.LC_REPORT|wx.LC_VIRTUAL|wx.LC_HRULES|wx.LC_VRULES) self.parent=parent self.gparent=gparent self.dlist=dlist self.add_dendro=add_dendro self.first = ['id','formes'] + first self.lenact = nbactives self.lensup = len(dlist) - (self.lenact + nbetoiles) #adding some art self.il = wx.ImageList(16, 16) a={"sm_up":"GO_UP","sm_dn":"GO_DOWN","w_idx":"WARNING","e_idx":"ERROR","i_idx":"QUESTION"} for k,v in a.items(): s="self.%s= self.il.Add(wx.ArtProvider_GetBitmap(wx.ART_%s,wx.ART_TOOLBAR,(16,16)))" % (k,v) exec(s) self.SetImageList(self.il, wx.IMAGE_LIST_SMALL) self.attr1 = wx.ListItemAttr() self.attr1.SetBackgroundColour((220, 220, 220)) self.attrsg = wx.ListItemAttr() self.attrsg.SetBackgroundColour((230, 230, 230)) self.attr2 = wx.ListItemAttr() self.attr2.SetBackgroundColour((190, 249, 236)) self.attr2s = wx.ListItemAttr() self.attr2s.SetBackgroundColour((211, 252, 244)) self.attr3 = wx.ListItemAttr() self.attr3.SetBackgroundColour((245, 180, 180)) self.attr3s = wx.ListItemAttr() self.attr3s.SetBackgroundColour((245, 190, 190)) tID = wx.NewId() self.dlist = dlist self.Bind(wx.EVT_LIST_ITEM_SELECTED, self.OnItemSelected, self) #self.Bind(wx.EVT_LIST_COL_CLICK, self.OnColClick) # for wxMSW self.Bind(wx.EVT_COMMAND_RIGHT_CLICK, self.OnRightClick) # for wxGTK self.Bind(wx.EVT_RIGHT_UP, self.OnRightClick) self.itemDataMap = dlist self.itemIndexMap = dlist.keys() self.SetItemCount(len(dlist)) listmix.ColumnSorterMixin.__init__(self, len(first)+2) #----------------------------------------------------------------------------------------- first = ['id','formes']+first for i, name in enumerate(first) : self.InsertColumn(i, name, wx.LIST_FORMAT_LEFT) self.SetColumnWidth(0, wx.LIST_AUTOSIZE) for i in range(1,len(first)-1): self.SetColumnWidth(i, 130) self.SortListItems(0, True) # Used by the ColumnSorterMixin, see wx/lib/mixins/listctrl.py def GetListCtrl(self): return self # Used by the ColumnSorterMixin, see wx/lib/mixins/listctrl.py def GetSortImages(self): return (self.sm_dn, self.sm_up) def OnRightDown(self, event): x = event.GetX() y = event.GetY() item, flags = self.HitTest((x, y)) if flags & wx.LIST_HITTEST_ONITEM: self.Select(item) event.Skip() def getColumnText(self, index, col): item = self.GetItem(index, col) return item.GetText() def OnGetItemText(self, item, col): index=self.itemIndexMap[item] s = self.itemDataMap[index][col] return s def OnGetItemData(self, item) : index = self.itemIndexMap[item] s = self.itemDataMap[index] return s def OnItemSelected(self, event): self.currentItem = event.m_itemIndex event.Skip() def OnGetItemAttr(self, item): index=self.itemIndexMap[item] #genre=self.itemDataMap[index][2] if index < self.lenact : if item % 2 : return self.attr1 else : return self.attrsg elif index >= self.lenact and index < (self.lenact + self.lensup) : if item % 2 : return self.attr2 else : return self.attr2s elif index >= (self.lenact + self.lensup) : if item % 2 : return self.attr3 else : return self.attr3s else : return None def SortItems(self,sorter=cmp): items = list(self.itemDataMap.keys()) items.sort(sorter) self.itemIndexMap = items # redraw the list self.Refresh() def OnRightClick(self, event): # only do this part the first time so the events are only bound once if not hasattr(self, "popupID1"): # self.popupID1 = wx.NewId() #self.popupID2 = wx.NewId() self.popupID3 = wx.NewId() if self.add_dendro : self.id_adddendro = wx.NewId() self.Bind(wx.EVT_MENU, self.ongraphdendro, id = self.id_adddendro) # self.Bind(wx.EVT_MENU, self.OnPopupOne, id=self.popupID1) #self.Bind(wx.EVT_MENU, self.OnPopupTwo, id=self.popupID2) self.Bind(wx.EVT_MENU, self.OnPopupThree, id=self.popupID3) # make a menu menu = wx.Menu() # add some items # menu.Append(self.popupID1, u"Formes associƩes") #menu.Append(self.popupID2, u"Concordancier") menu.Append(self.popupID3, "Graphique") if self.add_dendro : menu.Append(self.id_adddendro, u"Graphique + dendrogramme") self.PopupMenu(menu) menu.Destroy() def getselectedwords(self) : words = [self.getColumnText(self.GetFirstSelected(), 6)] last = self.GetFirstSelected() while self.GetNextSelected(last) != -1: last = self.GetNextSelected(last) words.append(self.getColumnText(last, 6)) return words def OnPopupOne(self, event): activenotebook = self.parent.nb.GetSelection() page = self.parent.nb.GetPage(activenotebook) corpus = page.corpus word = self.getColumnText(self.GetFirstSelected(), 0) lems = corpus.lems rep = [] for forme in lems[word] : rep.append([forme, corpus.formes[forme][0]]) win = message(self, u"Formes associƩes", size=(300, 200)) win.html = '\n' + '
'.join([' : '.join([str(val) for val in forme]) for forme in rep]) + '\n' win.HtmlPage.SetPage(win.html) win.Show(True) def OnPopupTwo(self, event): activenotebook = self.parent.nb.GetSelection() page = self.parent.nb.GetPage(activenotebook) item=self.getColumnText(self.GetFirstSelected(), 0) corpus = page.corpus win = message(self, u"Concordancier", size=(600, 200)) avap=60 listmot = corpus.lems[item] uce_ok = [corpus.formes[forme][1] for forme in listmot] uce_ok = list(set([tuple(val) for line in uce_ok for val in line])) txt = '

Concordancier

' for uce in uce_ok: content = ' '+' '.join(corpus.ucis_paras_uces[uce[0]][uce[1]][uce[2]])+' ' for form in listmot : sp = '' i = 0 forme = ' ' + form + ' ' while i < len(content): coordword = content[i:].find(forme) if coordword != -1 and i == 0: txt += '
' + ' '.join(corpus.ucis[uce[0]][0]) + '
' if coordword < avap: sp = ' ' * (avap - coordword) deb = i else: deb = i + coordword - avap if len(content) < i + coordword + avap: fin = len(content) - 1 else: fin = i + coordword + avap txt += '' + sp + content[deb:fin].replace(forme, '' + forme + '') + '
' i += coordword + len(forme) sp = '' elif coordword != -1 and i != 0 : if coordword < avap: sp = ' ' * (avap - coordword) deb = i else: deb = i + coordword - avap if len(content) < i + coordword + avap: fin = len(content) - 1 else: fin = i + coordword + avap txt += '' + sp + content[deb:fin].replace(forme, '' + forme + '') + '
' i += coordword + len(forme) sp = '' else: i = len(content) sp = '' win.HtmlPage.SetPage(txt) win.Show(True) def OnPopupThree(self, event) : datas = [self.OnGetItemData(self.GetFirstSelected())] last = self.GetFirstSelected() while self.GetNextSelected(last) != -1: last = self.GetNextSelected(last) data = self.OnGetItemData(last) datas += [data] colnames = self.first[2:] rownames = [val[1] for val in datas] table = [[str(val) for val in line[2:]] for line in datas] BarFrame(self.parent.parent, table, colnames, rownames) # tmpgraph = tempfile.mktemp(dir=self.parent.parent.TEMPDIR) # txt = barplot(table, rownames, colnames, self.parent.parent.RscriptsPath['Rgraph'], tmpgraph) # tmpscript = tempfile.mktemp(dir=self.parent.parent.TEMPDIR) # with open(tmpscript,'w') as f : # f.write(txt) # exec_rcode(self.parent.parent.RPath, tmpscript, wait = True) # win = MessageImage(self, u"Graphique", size=(700, 500)) # win.addsaveimage(tmpgraph) # txt = "" % tmpgraph # win.HtmlPage.SetPage(txt) # win.Show(True) def ongraphdendro(self, evt) : corpus = self.parent.corpus datas = [self.OnGetItemData(self.GetFirstSelected())] last = self.GetFirstSelected() while self.GetNextSelected(last) != -1: last = self.GetNextSelected(last) data = self.OnGetItemData(last) datas += [data] colnames = self.first[2:] rownames = [val[1] for val in datas] table = [[str(val) for val in line[2:]] for line in datas] tmpgraph = tempfile.mktemp(dir=self.parent.parent.TEMPDIR) BarFrame(self.parent.parent, table, colnames, rownames, tree = corpus.dictpathout['Rdendro']) # txt = dendroandbarplot(table, rownames, colnames, self.parent.parent.RscriptsPath['Rgraph'], tmpgraph, dendro=corpus.dictpathout['Rdendro']) # tmpscript = tempfile.mktemp(dir=self.parent.parent.TEMPDIR) # with open(tmpscript,'w') as f : # f.write(txt) # exec_rcode(self.parent.parent.RPath, tmpscript, wait = True) # win = MessageImage(self, u"Graphique", size=(700, 500)) # win.addsaveimage(tmpgraph) # txt = "" % tmpgraph # win.HtmlPage.SetPage(txt) # win.Show(True)