copycorpus
[iramuteq] / search_list.py
1 # -*- coding: utf-8 -*-
2
3 #----------------------------------------------------------------------------
4 # Author:       Pierre Ratinaud
5
6
7 #comes from ListCtrl.py from the demo tool of wxPython:
8 # Author:       Robin Dunn & Gary Dumer
9 #
10 # Created:
11 # Copyright:    (c) 1998 by Total Control Software
12 # Licence:      wxWindows license
13 #----------------------------------------------------------------------------
14
15 import os
16 import sys
17 import  wx
18 import  wx.lib.mixins.listctrl  as  listmix
19 import cStringIO
20 import tempfile
21 from functions import exec_rcode, MessageImage
22 from dialog import message
23 from chemins import ffr
24 from PrintRScript import barplot, dendroandbarplot
25 #---------------------------------------------------------------------------
26
27 #class List(wx.ListCtrl, listmix.ListCtrlAutoWidthMixin):
28 #    def __init__(self, parent, ID, pos=wx.DefaultPosition,
29 #                 size=wx.DefaultSize, style=0):
30 #        wx.ListCtrl.__init__(self, parent, ID, pos, size, style)
31 #        listmix.ListCtrlAutoWidthMixin.__init__(self)
32
33 class SearchList(wx.ListCtrl, listmix.ListCtrlAutoWidthMixin, listmix.ColumnSorterMixin): #wx.Panel, listmix.ColumnSorterMixin):
34     def __init__(self, parent,gparent, dlist,first, nbactives, nbetoiles, add_dendro=True):
35         wx.ListCtrl.__init__( self, parent, -1, style=wx.LC_REPORT|wx.LC_VIRTUAL|wx.LC_HRULES|wx.LC_VRULES)
36         self.parent=parent
37         self.gparent=gparent
38         self.dlist=dlist
39         self.add_dendro=add_dendro
40         self.first = ['id','formes'] + first
41         self.lenact = nbactives
42         self.lensup = len(dlist) - (self.lenact + nbetoiles)
43
44         #adding some art
45         self.il = wx.ImageList(16, 16)
46         a={"sm_up":"GO_UP","sm_dn":"GO_DOWN","w_idx":"WARNING","e_idx":"ERROR","i_idx":"QUESTION"}
47         for k,v in a.items():
48             s="self.%s= self.il.Add(wx.ArtProvider_GetBitmap(wx.ART_%s,wx.ART_TOOLBAR,(16,16)))" % (k,v)
49             exec(s)
50         self.SetImageList(self.il, wx.IMAGE_LIST_SMALL)
51
52         self.attr1 = wx.ListItemAttr()
53         self.attr1.SetBackgroundColour((220, 220, 220))
54         self.attrsg = wx.ListItemAttr()
55         self.attrsg.SetBackgroundColour((230, 230, 230))
56         self.attr2 = wx.ListItemAttr()
57         self.attr2.SetBackgroundColour((190, 249, 236))
58         self.attr2s = wx.ListItemAttr()
59         self.attr2s.SetBackgroundColour((211, 252, 244))        
60         self.attr3 = wx.ListItemAttr()
61         self.attr3.SetBackgroundColour((245, 180, 180))
62         self.attr3s = wx.ListItemAttr()
63         self.attr3s.SetBackgroundColour((245, 190, 190))
64
65         tID = wx.NewId()
66
67         self.dlist = dlist 
68
69         self.Bind(wx.EVT_LIST_ITEM_SELECTED, self.OnItemSelected, self)
70         #self.Bind(wx.EVT_LIST_COL_CLICK, self.OnColClick)
71         
72         # for wxMSW
73         self.Bind(wx.EVT_COMMAND_RIGHT_CLICK, self.OnRightClick)
74
75         # for wxGTK
76         self.Bind(wx.EVT_RIGHT_UP, self.OnRightClick)
77         
78         
79         self.itemDataMap = dlist
80         self.itemIndexMap = dlist.keys()
81         self.SetItemCount(len(dlist))
82         listmix.ColumnSorterMixin.__init__(self, len(first)+2)
83
84         
85 #-----------------------------------------------------------------------------------------    
86
87         first = ['id','formes']+first
88         for i, name in enumerate(first) :
89             self.InsertColumn(i, name, wx.LIST_FORMAT_LEFT)
90         
91         self.SetColumnWidth(0, wx.LIST_AUTOSIZE)
92         for i in range(1,len(first)-1):
93             self.SetColumnWidth(i, 130)
94         
95         self.SortListItems(0, True)
96
97     # Used by the ColumnSorterMixin, see wx/lib/mixins/listctrl.py
98     def GetListCtrl(self):
99         return self
100
101     # Used by the ColumnSorterMixin, see wx/lib/mixins/listctrl.py
102     def GetSortImages(self):
103         return (self.sm_dn, self.sm_up)
104
105
106     def OnRightDown(self, event):
107         x = event.GetX()
108         y = event.GetY()
109         item, flags = self.HitTest((x, y))
110
111         if flags & wx.LIST_HITTEST_ONITEM:
112             self.Select(item)
113
114         event.Skip()
115
116     def getColumnText(self, index, col):
117         item = self.GetItem(index, col)
118         return item.GetText()
119
120     def OnGetItemText(self, item, col):
121         index=self.itemIndexMap[item]
122         s = self.itemDataMap[index][col]
123         return s
124
125     def OnGetItemData(self, item) :
126         index = self.itemIndexMap[item]
127         s = self.itemDataMap[index]
128         return s
129
130     def OnItemSelected(self, event):
131         self.currentItem = event.m_itemIndex
132         event.Skip()
133
134     def OnGetItemAttr(self, item):
135         index=self.itemIndexMap[item]
136         #genre=self.itemDataMap[index][2]
137         if index < self.lenact :
138             if item % 2 :
139                 return self.attr1
140             else :
141                 return self.attrsg
142         elif index >= self.lenact and index < (self.lenact + self.lensup) :
143             if item % 2 :
144                 return self.attr2
145             else :
146                 return self.attr2s
147         elif index >= (self.lenact + self.lensup) :
148             if item % 2 :
149                 return self.attr3
150             else :
151                 return self.attr3s
152         else :
153             return None
154
155     def SortItems(self,sorter=cmp):
156         items = list(self.itemDataMap.keys())
157         items.sort(sorter)
158         self.itemIndexMap = items
159         
160         # redraw the list
161         self.Refresh()
162
163     def OnRightClick(self, event):
164
165         # only do this part the first time so the events are only bound once
166         if not hasattr(self, "popupID1"):
167 #            self.popupID1 = wx.NewId()
168             #self.popupID2 = wx.NewId()
169             self.popupID3 = wx.NewId()
170             if self.add_dendro :
171                 self.id_adddendro = wx.NewId()
172                 self.Bind(wx.EVT_MENU, self.ongraphdendro, id = self.id_adddendro)
173 #            self.Bind(wx.EVT_MENU, self.OnPopupOne, id=self.popupID1)
174             #self.Bind(wx.EVT_MENU, self.OnPopupTwo, id=self.popupID2)
175             self.Bind(wx.EVT_MENU, self.OnPopupThree, id=self.popupID3)
176
177
178         # make a menu
179         menu = wx.Menu()
180         # add some items
181 #        menu.Append(self.popupID1, u"Formes associées")
182         #menu.Append(self.popupID2, u"Concordancier")
183         menu.Append(self.popupID3, "Graphique")
184         if self.add_dendro :
185             menu.Append(self.id_adddendro, u"Graphique + dendrogramme")
186
187         self.PopupMenu(menu)
188         menu.Destroy()
189
190     def getselectedwords(self) :
191         words = [self.getColumnText(self.GetFirstSelected(), 6)]
192         last = self.GetFirstSelected()
193         while self.GetNextSelected(last) != -1:
194             last = self.GetNextSelected(last)
195             words.append(self.getColumnText(last, 6))
196         return words
197
198     def OnPopupOne(self, event):
199         activenotebook = self.parent.nb.GetSelection()
200         page = self.parent.nb.GetPage(activenotebook)
201         corpus = page.corpus
202         word = self.getColumnText(self.GetFirstSelected(), 0)
203         lems = corpus.lems
204         rep = []
205         for forme in lems[word] :
206              rep.append([forme, corpus.formes[forme][0]])
207         win = message(self, u"Formes associées", size=(300, 200))
208         win.html = '<html>\n' + '<br>'.join([' : '.join([str(val) for val in forme]) for forme in rep]) + '\n</html>'
209         win.HtmlPage.SetPage(win.html)
210         win.Show(True)
211
212     def OnPopupTwo(self, event):
213         activenotebook = self.parent.nb.GetSelection()
214         page = self.parent.nb.GetPage(activenotebook)
215         item=self.getColumnText(self.GetFirstSelected(), 0)
216         corpus = page.corpus
217         win = message(self, u"Concordancier", size=(600, 200))
218         avap=60
219         listmot = corpus.lems[item]
220         uce_ok = [corpus.formes[forme][1] for forme in listmot]
221         uce_ok = list(set([tuple(val) for line in uce_ok for val in line]))
222         txt = '<h1>Concordancier</h1>'
223         for uce in uce_ok:
224             content = ' '+' '.join(corpus.ucis_paras_uces[uce[0]][uce[1]][uce[2]])+' '
225             for form in listmot :
226                 sp = ''
227                 i = 0
228                 forme = ' ' + form + ' '
229                 while i < len(content):
230                     coordword = content[i:].find(forme)
231                     if coordword != -1 and i == 0:
232                         txt += '<br><b>' + ' '.join(corpus.ucis[uce[0]][0]) + '</b><br>'
233                         if coordword < avap:
234                             sp = '&nbsp;' * (avap - coordword)
235                             deb = i
236                         else:
237                             deb = i + coordword - avap
238                         if len(content) < i + coordword + avap:
239                             fin = len(content) - 1
240                         else:
241                             fin = i + coordword + avap
242                         txt += '<TT>' + sp + content[deb:fin].replace(forme, '<font color=red>' + forme + '</font>') + '</TT><br>'
243                         i += coordword + len(forme)
244                         sp = ''
245                     elif coordword != -1 and i != 0 :
246                         if coordword < avap:
247                             sp = '&nbsp;' * (avap - coordword)
248                             deb = i
249                         else:
250                             deb = i + coordword - avap
251                         if len(content) < i + coordword + avap:
252                             fin = len(content) - 1
253                         else:
254                             fin = i + coordword + avap
255                         txt += '<TT>' + sp + content[deb:fin].replace(forme, '<font color=red>' + forme + '</font>') + '</TT><br>'
256                         i += coordword + len(forme)
257                         sp = ''                   
258                     else:
259                         i = len(content)
260                         sp = ''
261         win.HtmlPage.SetPage(txt)
262         win.Show(True)
263
264     def OnPopupThree(self, event) :
265         datas = [self.OnGetItemData(self.GetFirstSelected())]
266         last = self.GetFirstSelected()
267         while self.GetNextSelected(last) != -1:
268             last = self.GetNextSelected(last)
269             data = self.OnGetItemData(last)
270             datas += [data]
271         colnames = self.first[2:]
272         rownames = [val[1] for val in datas]
273         table = [[str(val) for val in line[2:]] for line in datas]
274         tmpgraph = tempfile.mktemp(dir=self.parent.parent.TEMPDIR)
275         txt =  barplot(table, rownames, colnames, self.parent.parent.RscriptsPath['Rgraph'], tmpgraph)
276         tmpscript = tempfile.mktemp(dir=self.parent.parent.TEMPDIR)
277         with open(tmpscript,'w') as f :
278             f.write(txt)
279         exec_rcode(self.parent.parent.RPath, tmpscript, wait = True)
280         win = MessageImage(self, u"Graphique", size=(700, 500))
281         win.addsaveimage(tmpgraph)
282         txt = "<img src='%s'>" % tmpgraph
283         win.HtmlPage.SetPage(txt)
284         win.Show(True)
285
286     def ongraphdendro(self, evt) :
287         corpus = self.parent.corpus
288         datas = [self.OnGetItemData(self.GetFirstSelected())]
289         last = self.GetFirstSelected()
290         while self.GetNextSelected(last) != -1:
291             last = self.GetNextSelected(last)
292             data = self.OnGetItemData(last)
293             datas += [data]
294         colnames = self.first[2:]
295         rownames = [val[1] for val in datas]
296         table = [[str(val) for val in line[2:]] for line in datas]
297         tmpgraph = tempfile.mktemp(dir=self.parent.parent.TEMPDIR)
298         txt =  dendroandbarplot(table, rownames, colnames, self.parent.parent.RscriptsPath['Rgraph'], tmpgraph, dendro=corpus.dictpathout['Rdendro'])
299         tmpscript = tempfile.mktemp(dir=self.parent.parent.TEMPDIR)
300         with open(tmpscript,'w') as f :
301             f.write(txt)
302         exec_rcode(self.parent.parent.RPath, tmpscript, wait = True)
303         win = MessageImage(self, u"Graphique", size=(700, 500))
304         win.addsaveimage(tmpgraph)
305         txt = "<img src='%s'>" % tmpgraph
306         win.HtmlPage.SetPage(txt)
307         win.Show(True)
308
309 #class message(wx.Dialog):
310 #    def __init__(self, *args, **kwds):
311 #        # begin wxGlade: MyFrame.__init__
312 #        kwds["style"] = wx.DEFAULT_FRAME_STYLE
313 #        wx.Frame.__init__(self, *args, **kwds)
314 #        self.HtmlPage=wx.html.HtmlWindow(self, -1)
315 #        if "gtk2" in wx.PlatformInfo:
316 #            self.HtmlPage.SetStandardFonts()
317 #        self.HtmlPage.SetFonts('Courier','Courier')
318 #        
319 #        
320 #        self.button_1 = wx.Button(self, -1, "Fermer")
321 #        self.Bind(wx.EVT_BUTTON, self.OnCloseMe, self.button_1)
322 #        self.Bind(wx.EVT_CLOSE, self.OnCloseWindow)
323 #        self.__do_layout()
324 #        # end wxGlade
325 #
326 #    def __do_layout(self):
327 #        # begin wxGlade: MyFrame.__do_layout
328 #        sizer_1 = wx.BoxSizer(wx.VERTICAL)
329 #        sizer_2 = wx.BoxSizer(wx.VERTICAL)
330 #        sizer_2.Add(self.HtmlPage, 1, wx.EXPAND|wx.ADJUST_MINSIZE, 0)
331 #        sizer_2.Add(self.button_1, 0, wx.ALIGN_CENTER_HORIZONTAL|wx.ADJUST_MINSIZE, 0)
332 #        sizer_1.Add(sizer_2, 1, wx.EXPAND, 0)
333 #        self.SetAutoLayout(True)
334 #        self.SetSizer(sizer_1)
335 #        self.Layout()
336 #        # end wxGlade
337 #        
338 #    def OnCloseMe(self, event):
339 #        self.Close(True)
340 #
341 #    def OnCloseWindow(self, event):
342 #        self.Destroy()
343 #
344 #
345 #def getSmallUpArrowData():
346 #    return \
347 #'\x89PNG\r\n\x1a\n\x00\x00\x00\rIHDR\x00\x00\x00\x10\x00\x00\x00\x10\x08\x06\
348 #\x00\x00\x00\x1f\xf3\xffa\x00\x00\x00\x04sBIT\x08\x08\x08\x08|\x08d\x88\x00\
349 #\x00\x00<IDAT8\x8dcddbf\xa0\x040Q\xa4{h\x18\xf0\xff\xdf\xdf\xffd\x1b\x00\xd3\
350 #\x8c\xcf\x10\x9c\x06\xa0k\xc2e\x08m\xc2\x00\x97m\xd8\xc41\x0c \x14h\xe8\xf2\
351 #\x8c\xa3)q\x10\x18\x00\x00R\xd8#\xec\xb2\xcd\xc1Y\x00\x00\x00\x00IEND\xaeB`\
352 #\x82' 
353 #
354 #def getSmallUpArrowBitmap():
355 #    return wx.BitmapFromImage(getSmallUpArrowImage())
356 #
357 #def getSmallUpArrowImage():
358 #    stream = cStringIO.StringIO(getSmallUpArrowData())
359 #    return wx.ImageFromStream(stream)
360 #
361 ##----------------------------------------------------------------------
362 #def getSmallDnArrowData():
363 #    return \
364 #"\x89PNG\r\n\x1a\n\x00\x00\x00\rIHDR\x00\x00\x00\x10\x00\x00\x00\x10\x08\x06\
365 #\x00\x00\x00\x1f\xf3\xffa\x00\x00\x00\x04sBIT\x08\x08\x08\x08|\x08d\x88\x00\
366 #\x00\x00HIDAT8\x8dcddbf\xa0\x040Q\xa4{\xd4\x00\x06\x06\x06\x06\x06\x16t\x81\
367 #\xff\xff\xfe\xfe'\xa4\x89\x91\x89\x99\x11\xa7\x0b\x90%\ti\xc6j\x00>C\xb0\x89\
368 #\xd3.\x10\xd1m\xc3\xe5*\xbc.\x80i\xc2\x17.\x8c\xa3y\x81\x01\x00\xa1\x0e\x04e\
369 #?\x84B\xef\x00\x00\x00\x00IEND\xaeB`\x82" 
370 #
371 #def getSmallDnArrowBitmap():
372 #    return wx.BitmapFromImage(getSmallDnArrowImage())
373 #
374 #def getSmallDnArrowImage():
375 #    stream = cStringIO.StringIO(getSmallDnArrowData())
376 #    return wx.ImageFromStream(stream)