Forums / Developer / Best way to multi-filter

Best way to multi-filter

Author Message

Brendan Pike

Friday 01 September 2006 2:09:18 am

I built a simlpe two drop down multifilter which works quite nicely, I want to add a 3rd dropdown and things a no longer looking so good. This was the method I is below, I found that things like attribute_filters and the like would die if no value was found which is why I started splitting them into every selection possability. But using this method and adding a 3rd gets a little crazy, can someone tell me what a more sane approach would be please.

{if and($#:view_parameters.filter_1, $#:view_parameters.filter_2|not)}
   {def $children=fetch('content','list',hash(parent_node_id, $#:view_parameters.filter_2, (snip)
{elseif and($#:view_parameters.filter_1|not, $#:view_parameters.filter_2)}
   {def $children=fetch('content','tree',hash(parent_node_id, $node.node_id, (snip)
{elseif and($#:view_parameters.filter_1, $#:view_parameters.filter_2)}
   {def $children=fetch('content','list',hash(parent_node_id, $#:view_parameters.filter_2, (snip)
{else}
{def $children=fetch('content','tree',hash(parent_node_id, $node.node_id, (snip)
{/if}

www.dbinformatics.com.au

We are always interested in hearing from experienced eZ PHP programmers and eZ template designers interested in contract work.

Norman Leutner

Friday 01 September 2006 6:38:15 am

I'm having the same problem on some sites.

Take a look at http://ez.no/partner/worldwide_ez_publish_partners

<form action="/ezposttoview/action" method="post">

Maybe someone from ez can share his information and tell us something about that function and how ez solved this ;)

Mit freundlichen Grüßen
Best regards

Norman Leutner

____________________________________________________________
eZ Publish Platinum Partner - http://www.all2e.com
http://ez.no/partners/worldwide_partners/all2e_gmbh

Claudia Kosny

Saturday 02 September 2006 7:03:11 am

Hello Norman/Brendan

I am not exactly sure what you mean. The way I understand you the problem is to build the attribute filter in a way that it includes all attributes that are set to certain values in the posted form. So why don't you just go through each of the posted data, create the proper hash out of it and append it to the attribute filter?
Something like
set my_filter = array('and')
go through all items in post data
filter the ones wie are interested in, if necessary
if the posted item has a value (which means it was set to 'all' in the form)
my_filter|append(hash('class/attribute', '=', 'value of posted item'))

Then check whether the my_filter contains more data than the initial 'and' and use it in the fetch function.

So if that is not exactly what you want to do, please explain a bit more.

Greetings from Luxembourg

Claudia

Brendan Pike

Saturday 02 September 2006 8:19:05 am

Hi Claudia

Thanks for your response, I have searched ez.no and nothing really touches on this need so it will be a valuable forum post for myself Norman and others too I'm sure. I think your response will work for most of my filters but not all. I'll provide more detail so you can correct me if I am taking an incorrect approach.

So far I am filtering on the following:
1. (staff) The objects I'm fetching have added locations into "staff folders", so to view only specific staff objects I replace the fetch parent_node_id with (staff) as I'm not aware of any other way to filter on locations since its not a class attribute.
2. (jobstate) an enhanced selection attribute. array( 'job/job_status', '=', $#:view_parameters.jobstate)
3. (client) I can use the owner attribute for this, array( array( 'owner', '=', $#:view_parameters.client )
4. I also have 3 permanent filters set in order to hide certain owners from thet fetch, ie. array( 'owner', '!=', '522')

Please show me how the code should look. greatly appreciated :)

www.dbinformatics.com.au

We are always interested in hearing from experienced eZ PHP programmers and eZ template designers interested in contract work.

Claudia Kosny

Saturday 02 September 2006 2:07:38 pm

Hello Brendan

Regarding the location I have no idea what to do. Maybe an extended attribute filter
could do the job, but I wouldn't know how to do it. Therefore I added just some code
of what I assume you are doing with the node ids.
In my example I did not use view parameters as I do not have such a page available
right now. But there should be no problem replacing the declared dummy variables
with view parameters.

Please note I checked for each variable whether it has any content, which means that variables that exist but hold a value of 0 (zero) will be filtered here.You might want to change that.

 
{* dummy variables which stand in for view parameters *}
{def $staff='3'
     $jobstate='foo'
     $owner='bar'
     $otherAttrib=''}

{* this will be our attribute filter *}
{def $my_filter=array()}

{* put each single attribute which you want to filter in array, 
here you can also add additional checks (e.g check for integer or so)*}
{if and(is_set($jobstate), $jobstate)}
 {set $my_filter=$my_filter|append(array('job/job_status', '=', $jobstate))}
{/if}
{if and(is_set($owner), $owner)}
 {set $my_filter=$my_filter|append(array('owner', '=', $owner))}
{/if}
{if and(is_set($otherAttrib), $otherAttrib)}
 {set $my_filter=$my_filter|append(array('job/otherAttrib', '=', $otherAttrib))}
{/if}

{* add your preset filters here the same way *}


{* prepend 'and' if necessary *}
{if $my_filter|count()|gt(1)}
 {set $my_filter=$my_filter|prepend('and')}
{/if}


{* I am not sure whether this is what you do with staff nodes *}
{def $fetch_parent_id=''}
{if and(is_set($staff), is_integer($staff), $staff|gt(2))}
 {set $fetch_parent_id = $staff}
{else}
 {set $fetch_parent_id = 2}
{/if}

{if $my_filter|count()|gt(0)}
 {* fetch with attribute filter *}
 {def $nodeArr = fetch('content', 'tree', hash('parent_node_id', $fetch_parent_id,
                                              'attribute_filter', $my_filter))}
{else}
 {* fetch without attribute filter *}
 {def $nodeArr = fetch('content', 'tree', hash('parent_node_id', $fetch_parent_id))}
{/if}

Hope that this is what you were trying to achieve

Greetings from Luxembourg

Claudia

Norman Leutner

Sunday 03 September 2006 5:01:36 am

Thanks Claudia for the idea of creating a filter array.
I think this helps shortening the code very well...

 

Mit freundlichen Grüßen
Best regards

Norman Leutner

____________________________________________________________
eZ Publish Platinum Partner - http://www.all2e.com
http://ez.no/partners/worldwide_partners/all2e_gmbh

Brendan Pike

Sunday 03 September 2006 7:27:59 pm

Thank you for taking the time Claudia, that certainly helped me create a far cleaner / faster and more flexible code. I noticed your other thread on specific date fetching too, I'll be trying to implement that for a show all from August type thing soon. Very valuable posts :)

www.dbinformatics.com.au

We are always interested in hearing from experienced eZ PHP programmers and eZ template designers interested in contract work.

eZ debug

Timing: Jan 18 2025 19:12:15
Script start
Timing: Jan 18 2025 19:12:15
Module start 'content'
Timing: Jan 18 2025 19:12:15
Module end 'content'
Timing: Jan 18 2025 19:12:15
Script end

Main resources:

Total runtime0.1979 sec
Peak memory usage2,048.0000 KB
Database Queries141

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0074 587.7109180.8359
Module start 'content' 0.00740.0073 768.5469105.9922
Module end 'content' 0.01460.1832 874.5391534.7734
Script end 0.1978  1,409.3125 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00452.2819200.0002
Check MTime0.00150.7721200.0001
Mysql Total
Database connection0.00120.600810.0012
Mysqli_queries0.144472.96701410.0010
Looping result0.00140.73261390.0000
Template Total0.182792.310.1827
Template load0.00100.481010.0010
Template processing0.181791.828710.1817
Override
Cache load0.00070.333510.0007
Sytem overhead
Fetch class attribute can translate value0.00070.330910.0007
XML
Image XML parsing0.00040.184910.0004
General
dbfile0.00281.4295200.0001
String conversion0.00000.003630.0000
Note: percentages do not add up to 100% because some accumulators overlap

CSS/JS files loaded with "ezjscPacker" during request:

CacheTypePacklevelSourceFiles
CSS0extension/community/design/community/stylesheets/ext/jquery.autocomplete.css
extension/community_design/design/suncana/stylesheets/scrollbars.css
extension/community_design/design/suncana/stylesheets/tabs.css
extension/community_design/design/suncana/stylesheets/roadmap.css
extension/community_design/design/suncana/stylesheets/content.css
extension/community_design/design/suncana/stylesheets/star-rating.css
extension/community_design/design/suncana/stylesheets/syntax_and_custom_tags.css
extension/community_design/design/suncana/stylesheets/buttons.css
extension/community_design/design/suncana/stylesheets/tweetbox.css
extension/community_design/design/suncana/stylesheets/jquery.fancybox-1.3.4.css
extension/bcsmoothgallery/design/standard/stylesheets/magnific-popup.css
extension/sevenx/design/simple/stylesheets/star_rating.css
extension/sevenx/design/simple/stylesheets/libs/fontawesome/css/all.min.css
extension/sevenx/design/simple/stylesheets/main.v02.css
extension/sevenx/design/simple/stylesheets/main.v02.res.css
JS0extension/ezjscore/design/standard/lib/yui/3.17.2/build/yui/yui-min.js
extension/ezjscore/design/standard/javascript/jquery-3.7.0.min.js
extension/community_design/design/suncana/javascript/jquery.ui.core.min.js
extension/community_design/design/suncana/javascript/jquery.ui.widget.min.js
extension/community_design/design/suncana/javascript/jquery.easing.1.3.js
extension/community_design/design/suncana/javascript/jquery.ui.tabs.js
extension/community_design/design/suncana/javascript/jquery.hoverIntent.min.js
extension/community_design/design/suncana/javascript/jquery.popmenu.js
extension/community_design/design/suncana/javascript/jScrollPane.js
extension/community_design/design/suncana/javascript/jquery.mousewheel.js
extension/community_design/design/suncana/javascript/jquery.cycle.all.js
extension/sevenx/design/simple/javascript/jquery.scrollTo.js
extension/community_design/design/suncana/javascript/jquery.cookie.js
extension/community_design/design/suncana/javascript/ezstarrating_jquery.js
extension/community_design/design/suncana/javascript/jquery.initboxes.js
extension/community_design/design/suncana/javascript/app.js
extension/community_design/design/suncana/javascript/twitterwidget.js
extension/community_design/design/suncana/javascript/community.js
extension/community_design/design/suncana/javascript/roadmap.js
extension/community_design/design/suncana/javascript/ez.js
extension/community_design/design/suncana/javascript/ezshareevents.js
extension/sevenx/design/simple/javascript/main.js

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 1
 Number of unique templates used: 1

Time used to render debug report: 0.0001 secs