fix issue where search was not saving prefs
This commit is contained in:
3
TODO
3
TODO
@@ -1,6 +1,7 @@
|
|||||||
## GENERAL
|
## GENERAL
|
||||||
|
|
||||||
* search allow noo
|
* search
|
||||||
|
-- allow changes to noo (done, but not in prefs yet)
|
||||||
- PREFS:
|
- PREFS:
|
||||||
- allow default and choosing search noo
|
- allow default and choosing search noo
|
||||||
- can't force fullscreen on page load, so remove it from prefs
|
- can't force fullscreen on page load, so remove it from prefs
|
||||||
|
|||||||
10
files.py
10
files.py
@@ -273,11 +273,6 @@ def GetEntriesInSearchView( OPT ):
|
|||||||
join=f"Entry.query.join(File).distinct().join(FaceFileLink).join(Face).join(FaceRefimgLink).join(Refimg).join(PersonRefimgLink).join(Person).filter(Person.tag.ilike('%{search_term}%'))"
|
join=f"Entry.query.join(File).distinct().join(FaceFileLink).join(Face).join(FaceRefimgLink).join(Refimg).join(PersonRefimgLink).join(Person).filter(Person.tag.ilike('%{search_term}%'))"
|
||||||
if 'AI:' in OPT.orig_search_term:
|
if 'AI:' in OPT.orig_search_term:
|
||||||
all_entries = eval( f"{join}.{OPT.order}.offset(OPT.offset).limit(OPT.how_many).all()")
|
all_entries = eval( f"{join}.{OPT.order}.offset(OPT.offset).limit(OPT.how_many).all()")
|
||||||
if OPT.last_eid == 0:
|
|
||||||
OPT.num_entries = eval( f"{join}.count()" )
|
|
||||||
last_entry = eval( f"{join}.{OPT.last_order}.limit(1).first()" )
|
|
||||||
if last_entry:
|
|
||||||
OPT.last_eid = last_entry.id
|
|
||||||
else:
|
else:
|
||||||
file_data=eval( f"Entry.query.join(File).filter(Entry.name.ilike('%{search_term}%')).{OPT.order}.offset({OPT.offset}).limit({OPT.how_many}).all()" )
|
file_data=eval( f"Entry.query.join(File).filter(Entry.name.ilike('%{search_term}%')).{OPT.order}.offset({OPT.offset}).limit({OPT.how_many}).all()" )
|
||||||
dir_data =eval( f"Entry.query.join(File).join(EntryDirLink).join(Dir).filter(Dir.rel_path.ilike('%{search_term}%')).{OPT.order}.offset({OPT.offset}).limit({OPT.how_many}).all()" )
|
dir_data =eval( f"Entry.query.join(File).join(EntryDirLink).join(Dir).filter(Dir.rel_path.ilike('%{search_term}%')).{OPT.order}.offset({OPT.offset}).limit({OPT.how_many}).all()" )
|
||||||
@@ -312,6 +307,9 @@ def GetEntriesInSearchView( OPT ):
|
|||||||
by_dirname=f"select e.id from entry e, entry_dir_link edl where edl.entry_id = e.id and edl.dir_eid in ( select d.eid from dir d where d.rel_path ilike '%%{search_term}%%' )"
|
by_dirname=f"select e.id from entry e, entry_dir_link edl where edl.entry_id = e.id and edl.dir_eid in ( select d.eid from dir d where d.rel_path ilike '%%{search_term}%%' )"
|
||||||
by_ai =f"select e.id from entry e, face_file_link ffl, face_refimg_link frl, person_refimg_link prl, person p where e.id = ffl.file_eid and frl.face_id = ffl.face_id and frl.refimg_id = prl.refimg_id and prl.person_id = p.id and p.tag ilike '%%{search_term}%%'"
|
by_ai =f"select e.id from entry e, face_file_link ffl, face_refimg_link frl, person_refimg_link prl, person p where e.id = ffl.file_eid and frl.face_id = ffl.face_id and frl.refimg_id = prl.refimg_id and prl.person_id = p.id and p.tag ilike '%%{search_term}%%'"
|
||||||
|
|
||||||
|
if 'AI:' in OPT.orig_search_term:
|
||||||
|
sel_no_order=f"select e.*, f.* from entry e, file f where e.id=f.eid and e.id in ( {by_ai} ) "
|
||||||
|
else:
|
||||||
sel_no_order=f"select e.*, f.* from entry e, file f where e.id=f.eid and e.id in ( {by_fname} union {by_dirname} union {by_ai} ) "
|
sel_no_order=f"select e.*, f.* from entry e, file f where e.id=f.eid and e.id in ( {by_fname} union {by_dirname} union {by_ai} ) "
|
||||||
|
|
||||||
#num_entries
|
#num_entries
|
||||||
@@ -326,7 +324,7 @@ def GetEntriesInSearchView( OPT ):
|
|||||||
for l in last_entry:
|
for l in last_entry:
|
||||||
OPT.last_eid = l.id
|
OPT.last_eid = l.id
|
||||||
# store first/last eid into prefs
|
# store first/last eid into prefs
|
||||||
pref=PA_UserState.query.filter(PA_UserState.pa_user_dn==current_user.dn,PA_UserState.path_type==OPT.path_type,PA_UserState.orig_ptype==OPT.orig_ptype,PA_UserState.orig_search_term==search_term).first()
|
pref=PA_UserState.query.filter(PA_UserState.pa_user_dn==current_user.dn,PA_UserState.path_type==OPT.path_type,PA_UserState.orig_ptype==OPT.orig_ptype,PA_UserState.orig_search_term==OPT.orig_search_term).first()
|
||||||
UpdatePref( pref, OPT )
|
UpdatePref( pref, OPT )
|
||||||
return all_entries
|
return all_entries
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user