X-Git-Url: http://iramuteq.org/git?p=iramuteq;a=blobdiff_plain;f=listlex.py;h=4b417e3dc0969e4f6be4883efbcf958ff5e98e81;hp=5d34a66b9afa356ba2f20f7a21741777ba65b14c;hb=ab23968410d4e2eff482fd16a639801b457d5063;hpb=a503f041dc4947ee21c1d353ddd05ddb13a5e322 diff --git a/listlex.py b/listlex.py index 5d34a66..4b417e3 100644 --- a/listlex.py +++ b/listlex.py @@ -59,34 +59,34 @@ class ListForSpec(wx.ListCtrl, listmix.ListCtrlAutoWidthMixin, listmix.ColumnSor self.dlist = dlist - self.Bind(wx.EVT_LIST_ITEM_SELECTED, self.OnItemSelected, self) - - # for wxMSW - self.Bind(wx.EVT_COMMAND_RIGHT_CLICK, self.OnRightClick) + i=0 + for name in first : + self.InsertColumn(i,name,wx.LIST_FORMAT_LEFT) + i+=1 + + self.SetColumnWidth(0, 180) - # for wxGTK - self.Bind(wx.EVT_RIGHT_UP, self.OnRightClick) - + for i in range(1,len(first)-1): + self.SetColumnWidth(i, len(first[i]) * 10) self.itemDataMap = dlist self.itemIndexMap = dlist.keys() self.SetItemCount(len(dlist)) - listmix.ListCtrlAutoWidthMixin.__init__(self) + #listmix.ListCtrlAutoWidthMixin.__init__(self) listmix.ColumnSorterMixin.__init__(self, len(first)) - self.SortListItems(1, False) + self.SortListItems(1, 0) #----------------------------------------------------------------------------------------- + self.Bind(wx.EVT_LIST_ITEM_SELECTED, self.OnItemSelected, self) + + # for wxMSW + self.Bind(wx.EVT_COMMAND_RIGHT_CLICK, self.OnRightClick) - i=0 - for name in first : - self.InsertColumn(i,name,wx.LIST_FORMAT_LEFT) - i+=1 - - self.SetColumnWidth(0, 180) + # for wxGTK + self.Bind(wx.EVT_RIGHT_UP, self.OnRightClick) - for i in range(1,len(first)-1): - self.SetColumnWidth(i, len(first[i]) * 10) +#----------------------------------------------------------------------------------------- def OnGetItemText(self, item, col): index=self.itemIndexMap[item] @@ -107,8 +107,7 @@ class ListForSpec(wx.ListCtrl, listmix.ListCtrlAutoWidthMixin, listmix.ColumnSor # 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() @@ -127,7 +126,14 @@ class ListForSpec(wx.ListCtrl, listmix.ListCtrlAutoWidthMixin, listmix.ColumnSor index=self.itemIndexMap[item] s = self.itemDataMap[index] return s - + + def SortItems(self,sorter=cmp): + items = list(self.itemDataMap.keys()) + items.sort(sorter) + self.itemIndexMap = items + # redraw the list + self.Refresh() + def OnItemSelected(self, event): self.currentItem = event.m_itemIndex event.Skip() @@ -162,12 +168,19 @@ class ListForSpec(wx.ListCtrl, listmix.ListCtrlAutoWidthMixin, listmix.ColumnSor 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, 1)) + 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) + word = self.getselectedwords()[0] lems = corpus.getlems() rep = [] for forme in lems[word].formes : @@ -259,12 +272,7 @@ class ListForSpec(wx.ListCtrl, listmix.ListCtrlAutoWidthMixin, listmix.ColumnSor win.HtmlPage.SetPage(txt) win.Show(True) - def SortItems(self,sorter=cmp): - items = list(self.itemDataMap.keys()) - items.sort(sorter) - self.itemIndexMap = items - # redraw the list - self.Refresh() + class message(wx.Frame): def __init__(self, *args, **kwds):