support a second filter in filtered decks

This commit is contained in:
Damien Elmes 2018-01-14 13:08:38 +10:00
parent a062e1bc29
commit 1e0b97f25b
4 changed files with 139 additions and 29 deletions

View file

@ -38,7 +38,7 @@ defaultDynamicDeck = {
'usn': 0,
'delays': None,
'separate': True,
# list of (search, limit, order); we only use first element for now
# list of (search, limit, order); we only use first two elements for now
'terms': [["", 100, 0]],
'resched': True,
'return': True, # currently unused

View file

@ -983,28 +983,30 @@ select id from cards where did in %s and queue = 2 and due <= ? limit ?)"""
assert deck['dyn']
# move any existing cards back first, then fill
self.emptyDyn(did)
ids = self._fillDyn(deck)
if not ids:
cnt = self._fillDyn(deck)
if not cnt:
return
# and change to our new deck
self.col.decks.select(did)
return ids
return cnt
def _fillDyn(self, deck):
search, limit, order = deck['terms'][0]
orderlimit = self._dynOrder(order, limit)
if search.strip():
search = "(%s)" % search
search = "%s -is:suspended -is:buried -deck:filtered" % search
try:
ids = self.col.findCards(search, order=orderlimit)
except:
ids = []
return ids
# move the cards over
self.col.log(deck['id'], ids)
self._moveToDyn(deck['id'], ids)
return ids
start = -100000
total = 0
for search, limit, order in deck['terms']:
orderlimit = self._dynOrder(order, limit)
if search.strip():
search = "(%s)" % search
search = "%s -is:suspended -is:buried -deck:filtered" % search
try:
ids = self.col.findCards(search, order=orderlimit)
except:
return total
# move the cards over
self.col.log(deck['id'], ids)
self._moveToDyn(deck['id'], ids, start=start+total)
total += len(ids)
return total
def emptyDyn(self, did, lim=None):
if not lim:
@ -1069,13 +1071,14 @@ group by did
t = "c.due"
return t + " limit %d" % l
def _moveToDyn(self, did, ids):
def _moveToDyn(self, did, ids, start=-100000):
deck = self.col.decks.get(did)
data = []
t = intTime(); u = self.col.usn()
for c, id in enumerate(ids):
# start at -100000 so that reviews are all due
data.append((did, -100000+c, u, id))
due = start
for id in ids:
data.append((did, due, u, id))
due += 1
query = """
update cards set

View file

@ -28,7 +28,8 @@ class DeckConf(QDialog):
self.setupOrder()
self.loadConf()
if search:
self.form.search.setText(search)
self.form.search.setText(search + " is:due")
self.form.search_2.setText(search + " is:new")
self.form.search.selectAll()
self.show()
self.exec_()
@ -37,24 +38,51 @@ class DeckConf(QDialog):
def setupOrder(self):
import anki.consts as cs
self.form.order.addItems(list(cs.dynOrderLabels().values()))
self.form.order_2.addItems(list(cs.dynOrderLabels().values()))
def loadConf(self):
f = self.form
d = self.deck
f.resched.setChecked(d['resched'])
search, limit, order = d['terms'][0]
f.search.setText(search)
f.resched.setChecked(d['resched'])
f.order.setCurrentIndex(order)
f.limit.setValue(limit)
if len(d['terms']) > 1:
search, limit, order = d['terms'][1]
f.search_2.setText(search)
f.order_2.setCurrentIndex(order)
f.limit_2.setValue(limit)
f.secondFilter.setChecked(True)
f.filter2group.setVisible(True)
else:
f.order_2.setCurrentIndex(5)
f.limit_2.setValue(20)
f.secondFilter.setChecked(False)
f.filter2group.setVisible(False)
def saveConf(self):
f = self.form
d = self.deck
d['delays'] = None
d['terms'][0] = [f.search.text(),
f.limit.value(),
f.order.currentIndex()]
d['resched'] = f.resched.isChecked()
d['delays'] = None
terms = [[
f.search.text(),
f.limit.value(),
f.order.currentIndex()]]
if f.secondFilter.isChecked():
terms.append([
f.search_2.text(),
f.limit_2.value(),
f.order_2.currentIndex()])
d['terms'] = terms
self.mw.col.decks.save(d)
return True

View file

@ -7,7 +7,7 @@
<x>0</x>
<y>0</y>
<width>445</width>
<height>301</height>
<height>354</height>
</rect>
</property>
<property name="windowTitle">
@ -66,6 +66,58 @@
</layout>
</widget>
</item>
<item>
<widget class="QGroupBox" name="filter2group">
<property name="title">
<string>Filter 2</string>
</property>
<layout class="QGridLayout" name="gridLayout_3">
<item row="1" column="0">
<widget class="QLabel" name="label_6">
<property name="text">
<string>Limit to</string>
</property>
</widget>
</item>
<item row="1" column="3" colspan="2">
<widget class="QComboBox" name="order_2"/>
</item>
<item row="0" column="1" colspan="4">
<widget class="QLineEdit" name="search_2"/>
</item>
<item row="0" column="0">
<widget class="QLabel" name="label_3">
<property name="text">
<string>Search</string>
</property>
</widget>
</item>
<item row="1" column="1">
<widget class="QSpinBox" name="limit_2">
<property name="maximumSize">
<size>
<width>60</width>
<height>16777215</height>
</size>
</property>
<property name="minimum">
<number>1</number>
</property>
<property name="maximum">
<number>99999</number>
</property>
</widget>
</item>
<item row="1" column="2">
<widget class="QLabel" name="label_4">
<property name="text">
<string>cards selected by</string>
</property>
</widget>
</item>
</layout>
</widget>
</item>
<item>
<widget class="QGroupBox" name="groupBox_2">
<property name="title">
@ -82,6 +134,13 @@
</property>
</widget>
</item>
<item row="1" column="0">
<widget class="QCheckBox" name="secondFilter">
<property name="text">
<string>Enable second filter</string>
</property>
</widget>
</item>
</layout>
</widget>
</item>
@ -114,7 +173,11 @@
<tabstop>search</tabstop>
<tabstop>limit</tabstop>
<tabstop>order</tabstop>
<tabstop>search_2</tabstop>
<tabstop>limit_2</tabstop>
<tabstop>order_2</tabstop>
<tabstop>resched</tabstop>
<tabstop>secondFilter</tabstop>
<tabstop>buttonBox</tabstop>
</tabstops>
<resources/>
@ -151,5 +214,21 @@
</hint>
</hints>
</connection>
<connection>
<sender>secondFilter</sender>
<signal>toggled(bool)</signal>
<receiver>filter2group</receiver>
<slot>setVisible(bool)</slot>
<hints>
<hint type="sourcelabel">
<x>125</x>
<y>265</y>
</hint>
<hint type="destinationlabel">
<x>222</x>
<y>155</y>
</hint>
</hints>
</connection>
</connections>
</ui>