Forums / General / ezFloat Datatype not searchable?

ezFloat Datatype not searchable?

Author Message

Christian Rößler

Wednesday 17 March 2010 8:49:16 am

Hy Community,

today i faced a problem with ezFloat datatypes and searching those.
Is there any reason why the datatype ezFloat is not searchable thus is not indexed by ezfind and/or other search engine plugins?

Viewing the ezfloat datatype class i was missing the following two functions:

  • isInformationCollector()
  • isIndexable()

Both should return true to enable indexing and information collection.
I am using ezp 4.2

Thx,
chris

Hannover, Germany
eZ-Certified http://auth.ez.no/certification/verify/395613

Nicolas Pastorino

Wednesday 17 March 2010 9:29:33 am

Hi Christian!

Yep, that is correct and pretty much is a bug to me. The issue seems old : http://issues.ez.no/IssueView.php?Id=3321&activeItem=2, you may want to comment there, and/or create a dedicated bug for your specific issue, and link it to the above.

In terms of short-term solution: are you using eZ Find ? This could help you kinda work around this issue, in a slightly hackish manner.

Let us know,
Cheers,

--
Nicolas Pastorino
Director Community - eZ
Member of the Community Project Board

eZ Publish Community on twitter: http://twitter.com/ezcommunity

t : http://twitter.com/jeanvoye
G+ : http://plus.tl/jeanvoye

Christian Rößler

Wednesday 17 March 2010 3:19:14 pm

Indeed I am playing with ezFind and implementing a nasty filter/facet search for Products and their ezFloat based Attributes using php + ez-api as business logic returning results directly into the templates using dedicated template functions.
My question intenionally was why (technically) its not possible to search for ezFloats.

I thought that adding a comment in the source would be sufficient to explain why, but did not found any so posted my question here.
The provided url by Nicolas and following some links from there I was able to get a idea why this wasn't implemented yet.
Surprisingly a patch is available for ezFloat (and ezPrice too?), also surprising is the age of this issue and a handful related ones (dated back to 2005).
So I will try to override the ezFloat class and create a extension to be update secure. Plus i will try to get all the comments from the issuetracker and the patch(es) from there and create a up-to-date patchfile based on ezp 4.2. We'll see...

btw:
ezSelection Datatype is a b*tch too. Storing the selected values (foo,bar) as text/string in solr isnt a good choice. The keys (0,1,2) should be stored instead. I found some questions in the forum and a few issues in the tracker too I think. Most problems occur when the selection-value has whitespaces in it. Try to create a filter-search for that datatype using ezfind + when multiselection is enabled... what a mess ;-)
Thanks for your reply Nicolas.

--
Chris

Hannover, Germany
eZ-Certified http://auth.ez.no/certification/verify/395613

Christian Rößler

Wednesday 24 March 2010 6:53:06 am

OK, this is he actual situation. I have managed to create the float datatype which is searchable and can collect information. I also created all the necessary templates. Everything is working fine. It is in QA / Test for a few days now.

Now i am facing 2 issues which are left and partly have to be addressed to the ez-developers:

L10n is playing mad with me. In germany we do have '.' as thousand separator and ',' as decimal separator. Other countrys might have it the other way around. This has to be addressed in the datatype-code itself when storing to DB and fetching the value from DB. Also all the templates need to address this issue. It is currently implemented in a few ezFloat templates, but seems not to work correctly. I can do this by enhancing my float-datatype-code and do some magic when fetching user-input and storing to database and when fetching from database to send to the templates...

And there seems to be a bug in ezpublish, i filed a bugreport already: 16509
The problem is, that when the datatype is marked as 'not required' and the user has typed in nothing, a 0 (zero) is stored in the database, which is not correct. It should store null. The database schema supports those null-values, but the ezcontentclassattribute-definition describes 0 (zero) as a default value which in turn is choosen... But that is NOT what the user has typed in... This affects all numeric based datatypes (eZInteger, eZFloat, eZPrice, ...).

I'll keep you posted. The Datatype itself is working. Searching and collecting information is available. Templates are fine too. I might need to wait for ez for feedback on the 0-vs-null issue before publishing it. I did not encounter any other issues yet.

cheers,
chris

Hannover, Germany
eZ-Certified http://auth.ez.no/certification/verify/395613

eZ debug

Timing: Jan 18 2025 15:17:00
Script start
Timing: Jan 18 2025 15:17:00
Module start 'content'
Timing: Jan 18 2025 15:17:01
Module end 'content'
Timing: Jan 18 2025 15:17:01
Script end

Main resources:

Total runtime1.7115 sec
Peak memory usage4,096.0000 KB
Database Queries199

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0074 587.7031180.8438
Module start 'content' 0.00741.4200 768.5469573.6328
Module end 'content' 1.42750.2839 1,342.1797336.7500
Script end 1.7114  1,678.9297 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00480.2797210.0002
Check MTime0.00160.0914210.0001
Mysql Total
Database connection0.00080.049010.0008
Mysqli_queries1.620494.68211990.0081
Looping result0.00240.14261970.0000
Template Total1.678498.120.8392
Template load0.00200.118020.0010
Template processing1.676497.950020.8382
Template load and register function0.00020.009510.0002
states
state_id_array0.00090.053510.0009
state_identifier_array0.00180.105820.0009
Override
Cache load0.00180.1045440.0000
Sytem overhead
Fetch class attribute can translate value0.00210.120830.0007
Fetch class attribute name0.00200.115750.0004
XML
Image XML parsing0.00090.051130.0003
class_abstraction
Instantiating content class attribute0.00000.000750.0000
General
dbfile0.00410.2415270.0002
String conversion0.00000.000430.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
1node/view/full.tplfull/forum_topic.tplextension/sevenx/design/simple/override/templates/full/forum_topic.tplEdit templateOverride template
4content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
14content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
10content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
1content/datatype/view/ezxmltags/li.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/li.tplEdit templateOverride template
1content/datatype/view/ezxmltags/ul.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/ul.tplEdit templateOverride template
1content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
2content/datatype/view/ezxmltags/link.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/link.tplEdit templateOverride template
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 35
 Number of unique templates used: 9

Time used to render debug report: 0.0004 secs