1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636 |
- <?php
- /**
- * @file
- * This is the file description for Materiobasemod module.
- *
- * In this more verbose, multi-line description, you can specify what this
- * file does exactly. Make sure to wrap your documentation in column 78 so
- * that the file can be displayed nicely in default-sized consoles.
- */
- // define(MATERIO_SEARCH_API_RESULTS_PATH, 'explore');
- /**
- * Implements hook_permission().
- */
- function materio_search_api_permission() {
- return array(
- 'access to materio database' => array(
- 'title' => t('Access to materio database'),
- 'description' => t('Access to materio database.'),
- ),
- 'use materio search api' => array(
- 'title' => t('Use materio search api'),
- 'description' => t('Use materio search api.'),
- ),
- 'use materio search api for breves' => array(
- 'title' => t('Use materio search api for breves'),
- 'description' => t('Use materio search api for breves.'),
- ),
- 'use materio search api autocomplete' => array(
- 'title' => t('Use materio search api autocomplete'),
- 'description' => t('Use materio search api autocomplete.'),
- ),
- 'use materio search api viewmode selection' => array(
- 'title' => t('Use materio search api viewmode selection'),
- 'description' => t('Use materio search api viewmode selection.'),
- ),
- 'administer materio_search_api' => array(
- 'title' => t('administer Materio search api'),
- 'description' => t('Administer materio search api.'),
- ),
- 'use materio search api filters' => array(
- 'title' => t('use Materio search api filters'),
- 'description' => t('Use materio search api filters.'),
- ),
- 'use materio advanced search' => array(
- 'title' => t('Use materio advanced search'),
- 'description' => t('Use materio advanced search.'),
- ),
- );
- }
- /**
- * Implements hook_menu().
- */
- function materio_search_api_menu() {
- $items = array();
- $base = array(
- 'type' => MENU_CALLBACK,
- 'file' => 'materio_search_api.pages.inc',
- );
- $items['admin/config/search/search_api/materiosearchapi'] = array(
- 'title' => 'Materio Search Api',
- 'page callback' => 'drupal_get_form',
- 'page arguments' => array('materio_search_api_settings'),
- 'access arguments' => array('administer materio_search_api'),
- 'file' => 'materio_search_api.admin.inc',
- 'type' => MENU_LOCAL_TASK,
- );
- $items['materiosearchapi/autocomplete/dbselect'] = $base+array(
- 'access arguments' => array('use materio search api autocomplete'),
- 'page callback' => 'materio_search_api_autocomplete_dbselect',
- );
- $items['materiosearchapi/autocomplete/searchapi'] = $base+array(
- 'access arguments' => array('use materio search api autocomplete'),
- 'page callback' => 'materio_search_api_autocomplete_searchapi',
- );
- $items['explore'] = $base+array(
- // 'access arguments' => array('use materio search api'),
- 'access callback' => 'materio_search_api_access_search',
- 'page callback' => 'materio_search_api_results_search',
- 'title' => t('Explore'),
- //'page argument' => array(1,2,3),
- );
- $items['actuality'] = $base+array(
- // 'access arguments' => array(),
- 'page callback' => 'materio_search_api_actuality',
- // 'page argument' => array(),
- 'access callback' => TRUE,
- );
- $items['materiosearchapi/viewmode/change'] = $base+array(
- 'access arguments' => array('use materio search api viewmode selection'),
- 'page callback' => 'materio_search_api_viewmode_change',
- 'page argument' => array(3),
- );
- return $items;
- }
- function materio_search_api_access_search(){
- return true;
- // return user_access('use materio search api for breves') || user_access('use materio search api');
- }
- /**
- * - - - - - - - - - - - - SOLR - - - - - - - - - - - -
- */
- /**
- * Implements hook_search_api_data_type_info().
- *
- * Declare our new type to Search API so it can be selected for a field.
- */
- function materio_search_api_search_api_data_type_info() {
- return array(
- 'edge_n2_kw_text' => array(
- 'name' => t('Fulltext (partial matching)'),
- 'fallback' => 'text',
- 'prefix' => 'tem',
- 'always multiValued' => TRUE,
- ),
- 'edge_n2_kw_mapped_text' => array(
- 'name' => t('Fulltext without accents (partial matching)'),
- 'fallback' => 'text',
- 'prefix' => 'temmap',
- 'always multiValued' => TRUE,
- ),
- // 'term_tid' => array(
- // 'name' => t('Taxonomy term tid'),
- // 'fallback' => 'integer',
- // 'prefix' => 'im',
- // 'always multiValued' => TRUE,
- // ),
- );
- }
- /**
- * Implements hook_search_api_solr_dynamic_field_info().
- *
- * Tell Search API Solr how to index our new data type.
- */
- function materio_search_api_search_api_solr_dynamic_field_info() {
- return array(
- 'edge_n2_kw_text' => array(
- 'prefix' => 'tem',
- 'always multiValued' => TRUE,
- ),
- 'edge_n2_kw_mapped_text' => array(
- 'prefix' => 'temmap',
- 'always multiValued' => TRUE,
- ),
- // 'term_tid' => array(
- // 'prefix' => 'im',
- // 'always multiValued' => TRUE,
- // ),
- );
- }
- /**
- * hook_entity_property_info_alter().
- *
- * define own fields
- * - main taxonomy terms, the purpose is to be able to attribute differente boost on serach api depending on term order
- * - companies infos (address) : retrieve for materiau content type the companie info from the tode node
- *
- */
- function materio_search_api_entity_property_info_alter(&$info){
- // dsm($info, 'hook_entity_property_info_alter | info');
- // watchdog('materio solr', 'materio_search_api_entity_property_info_alter', array());
- // NODE PROPERTIES
- $node_props = &$info['node']['properties'];
- $fields = msa_get_custom_onto_taxo_searchable_fields();
- foreach ($fields['termname'] as $field) {
- $node_props[$field['name']] = array(
- 'type'=>$field['type'],
- 'label'=> $field['label'],
- 'getter callback'=>$field['getter']
- );
- }
- foreach ($fields['tid'] as $field) {
- $node_props[$field['name']] = array(
- 'type'=>$field['type'],
- 'label'=> $field['label'],
- 'getter callback'=>$field['getter']
- );
- }
- // for ($i=1; $i <= 5 ; $i++) {
- // $node_props['materio_search_api_onthologie_term_'.$i.'_text'] = array(
- // 'type'=>'text',
- // 'label'=> t('Main onthologie term '.$i. ' as text (+ synonyms)'),
- // 'getter callback'=>'materio_search_api_get_onthologie_term_'.$i.'_text',
- // );
- // $node_props['materio_search_api_onthologie_term_'.$i.'_tid'] = array(
- // 'type'=>'text',
- // 'label'=> t('Main onthologie term '.$i. ' as tid'),
- // 'getter callback'=>'materio_search_api_get_onthologie_term_'.$i.'_tid',
- // );
- // }
- //
- // $node_props['materio_search_api_onthologie_term_others_text'] = array(
- // 'type'=>'list<text>',
- // 'label'=> t('Others onthologie terms as text (+ synonyms)'),
- // 'getter callback'=>'materio_search_api_get_taxonomy_terms_others_text',
- // );
- // $node_props['materio_search_api_onthologie_term_others_tid'] = array(
- // 'type'=>'list<text>',
- // 'label'=> t('Others onthologie terms as tid'),
- // 'getter callback'=>'materio_search_api_get_taxonomy_terms_others_tid',
- // );
- $node_props['materio_search_api_taglibres_text'] = array(
- 'type'=>'list<text>',
- 'label'=> t('Tag libres terms as text (+ synonyms)'),
- 'getter callback'=>'materio_search_api_get_taglibres_terms_text',
- );
- $node_materiau_props = &$info['node']['bundles']['materiau']['properties'];
- $node_materiau_props['materio_search_api_node_propertie_companie'] = array(
- 'type'=>'list<text>',
- 'label'=> t('Manufacturers and distributors companies localised (dont addresse)'),
- 'getter callback'=>'materio_search_api_get_node_propertie_companie',
- );
- // TAXONOMIE TERMS PROPERTIES
- $term_props = &$info['taxonomy_term']['properties'];
- $term_props['materio_search_api_term_property_dup_name'] = array(
- 'label' => t("Term name field dup"),
- 'description' => t("Duplicate the term name field to apply different filter in solr (remove accents for instance)"),
- 'type' => 'text',
- 'getter callback' => 'materio_search_api_term_property_dup_name',
- );
- // $term_props['materio_search_api_term_property_name_translated'] = array(
- // 'label' => t("Term name translated"),
- // 'description' => t(""),
- // 'type' => 'text',
- // 'getter callback' => 'materio_search_api_term_property_name_translated',
- // );
- }
- function msa_get_custom_onto_taxo_searchable_fields(){
- for ($i=1; $i <= 5 ; $i++) {
- $fields_name['termname'][] = array(
- 'type' => 'text',
- 'name' => 'materio_search_api_onthologie_term_'.$i.'_text',
- 'label' => t('Main onthologie term '.$i. ' as text (+ synonyms)'),
- 'getter' => 'materio_search_api_get_onthologie_term_'.$i.'_text'
- );
- $fields_name['tid'][] = array(
- 'type' => 'text',
- 'name' => 'materio_search_api_onthologie_term_'.$i.'_tid',
- 'label' => t('Main onthologie term '.$i. ' as tid'),
- 'getter' => 'materio_search_api_get_onthologie_term_'.$i.'_tid'
- );
- }
- $fields_name['termname'][] = array(
- 'type'=>'list<text>',
- 'name' => 'materio_search_api_onthologie_term_others_text',
- 'label' => t('Others onthologie terms as text (+ synonyms)'),
- 'getter' => 'materio_search_api_get_taxonomy_terms_others_text'
- );
- $fields_name['tid'][] = array(
- 'type'=>'list<text>',
- 'name' => 'materio_search_api_onthologie_term_others_tid',
- 'label' => t('Others onthologie terms as tid'),
- 'getter' => 'materio_search_api_get_taxonomy_terms_others_tid'
- );
- return $fields_name;
- }
- /**
- * taxonomy propoerties as text + synonymes
- */
- function materio_search_api_get_onthologie_term_1_text($item){
- // dsm($item, 'item');
- return materio_search_api_get_taxo_term_field_text($item, "field_onthologie", 0);
- }
- function materio_search_api_get_onthologie_term_2_text($item){
- // dsm($item, 'item');
- return materio_search_api_get_taxo_term_field_text($item, "field_onthologie", 1);
- }
- function materio_search_api_get_onthologie_term_3_text($item){
- // dsm($item, 'item');
- return materio_search_api_get_taxo_term_field_text($item, "field_onthologie", 2);
- }
- function materio_search_api_get_onthologie_term_4_text($item){
- // dsm($item, 'item');
- return materio_search_api_get_taxo_term_field_text($item, "field_onthologie", 3);
- }
- function materio_search_api_get_onthologie_term_5_text($item){
- // dsm($item, 'item');
- return materio_search_api_get_taxo_term_field_text($item, "field_onthologie", 4);
- }
- function materio_search_api_get_taxonomy_terms_others_text($item){
- // dsm($item, 'item');
- $delta = 5;
- $terms = array();
- while( isset($item->field_onthologie['und'][$delta]) ){
- $terms[] = materio_search_api_get_taxo_term_field_text($item, "field_onthologie", $delta);
- $delta++;
- }
- return $terms;
- }
- function materio_search_api_get_taglibres_terms_text($item){
- // dsm($item, 'item');
- $delta = 0;
- $terms = array();
- while( isset($item->field_tags_libres['und'][$delta]) ){
- $terms[] = materio_search_api_get_taxo_term_field_text($item, "field_tags_libres", $delta);
- $delta++;
- }
- return $terms;
- }
- function materio_search_api_get_taxo_term_field_text($item, $field_name, $delta){
- // dsm($item, 'item');
- // dsm($delta, 'delta');
- if(isset($item->{$field_name}['und'][$delta])){
- // print '** item **'."\n";
- // print_r($item);
- $term = taxonomy_term_load($item->{$field_name}['und'][$delta]['tid']);
- // use entity metadata wrappers as they are SMART
- $wrapper = entity_metadata_wrapper('taxonomy_term', $term);
- // print '** wrapper **'."\n";
- // print_r($wrapper);
- // print "\n";
- $keywords[] = $wrapper->language($item->language)->name_field->raw();
- // print '** term_name **'."\n";
- // print_r($term->name);
- // print "\n";
- // print_r($term_name);
- // print "\n";
- $synonymes = array();
- foreach ($wrapper->language($item->language)->synonyms_synonym->value() as $index => $synonym) {
- // print '** synonym **'."\n";
- // print_r($synonym);
- // print "\n";
- $keywords[] = $synonym;
- }
- return implode(" ", $keywords);
- }
- return null;
- }
- /**
- * taxonomy properties as tid
- */
- function materio_search_api_get_onthologie_term_1_tid($item){
- // dsm($item, 'item');
- return materio_search_api_get_taxo_term_field_tid($item, "field_onthologie", 0);
- }
- function materio_search_api_get_onthologie_term_2_tid($item){
- // dsm($item, 'item');
- return materio_search_api_get_taxo_term_field_tid($item, "field_onthologie", 1);
- }
- function materio_search_api_get_onthologie_term_3_tid($item){
- // dsm($item, 'item');
- return materio_search_api_get_taxo_term_field_tid($item, "field_onthologie", 2);
- }
- function materio_search_api_get_onthologie_term_4_tid($item){
- // dsm($item, 'item');
- return materio_search_api_get_taxo_term_field_tid($item, "field_onthologie", 3);
- }
- function materio_search_api_get_onthologie_term_5_tid($item){
- // dsm($item, 'item');
- return materio_search_api_get_taxo_term_field_tid($item, "field_onthologie", 4);
- }
- function materio_search_api_get_taxonomy_terms_others_tid($item){
- // dsm($item, 'item');
- $delta = 5;
- $terms = array();
- while( isset($item->field_onthologie['und'][$delta]) ){
- $terms[] = materio_search_api_get_taxo_term_field_tid($item, "field_onthologie", $delta);
- $delta++;
- }
- return $terms;
- }
- function materio_search_api_get_taxo_term_field_tid($item, $field_name, $delta){
- // dsm($item, 'item');
- // dsm($delta, 'delta');
- $tid = null;
- if(isset($item->{$field_name}['und'][$delta]))
- $tid = $item->{$field_name}['und'][$delta]['tid'];
- // print 'tid = '.$tid."\n";
- return $tid;
- }
- /**
- *
- */
- function materio_search_api_get_node_propertie_companie($item){
- // dsm($item, '$item');
- $lang = "fr";//$item->language;
- $languages = language_list();
- global $language;
- $language = $languages[$lang];
- $cies = array();
- $cie_fields = array("field_company_fab", "field_company_distrib");
- foreach ($cie_fields as $cie_field_name) {
- $delta = 0;
- while( isset($item->{$cie_field_name}['und'][$delta]) ){
- $tid = $item->{$cie_field_name}['und'][$delta]['tid'];
- $cie_term = taxonomy_term_load($tid);
- if($cie_node = company_get_tode_node($cie_term)){
- $cie_node->language = $lang;
- $cie_view = node_view($cie_node, "full", $lang);
- $cie_rendered = rip_tags(drupal_render($cie_view));
- // dsm($cie_rendered, 'cie_rendered');
- $cies[] = $cie_rendered;
- }
- $delta++;
- }
- }
- return $cies;
- }
- function company_get_tode_node($term){
- if(module_exists('tode'))
- if( $entitys = tode_get_nids_from_term($term))
- if(isset($entitys['node']))
- foreach ($entitys['node'] as $nid => $n)
- return node_load($nid);
- return false;
- }
- function rip_tags($string) {
- // ----- remove HTML TAGs -----
- $string = preg_replace ('/<[^>]*>/', ' ', $string);
- // ----- remove control characters -----
- $string = str_replace("\r", '', $string); // --- replace with empty space
- $string = str_replace("\n", ' ', $string); // --- replace with space
- $string = str_replace("\t", ' ', $string); // --- replace with space
- // $string = str_replace(" ", ' ', $string); // --- replace with space
- // $string = str_replace("'", '\'', $string); // --- replace with space
- // ----- remove multiple spaces -----
- $string = trim(preg_replace('/ {2,}/', ' ', $string));
- // ----- remove html entities
- preg_match_all('/&[^;]+;/', $string, $entities);
- foreach ($entities[0] as $entity) {
- $string = str_replace($entity, mb_convert_encoding($entity, 'UTF-8', 'HTML-ENTITIES'), $string);
- }
- return $string;
- }
- /**
- * Taxonomy terms properties
- */
- function materio_search_api_term_property_dup_name($term){
- $lang = $term->language;
- return $term->name_field[$lang][0]['value'];
- }
- // function materio_search_api_term_property_name_translated($term){
- // if($term->vid == 4){
- // print_r(get_defined_vars());
- //
- // // print_r($term);
- //
- // $trans = module_exists('i18n_taxonomy')
- // ? i18n_taxonomy_term_name($term, 'fr')
- // : $term->name;
- //
- // print_r($trans);
- // print "\n";
- // }
- // }
- // ____ __ __
- // / __ )/ /___ _____/ /_______
- // / __ / / __ \/ ___/ //_/ ___/
- // / /_/ / / /_/ / /__/ ,< (__ )
- // /_____/_/\____/\___/_/|_/____/
- /**
- * Implements hook_block_info().
- */
- function materio_search_api_block_info() {
- $blocks['materio_search_api_search'] = array(
- 'info' => t('Materio search api search'),
- 'cache' => DRUPAL_NO_CACHE
- );
- $blocks['mo_searchapi_advanced_search'] = array(
- 'info' => t('Materio search api advanced search'),
- 'cache' => DRUPAL_NO_CACHE
- );
- # NOT USED
- $blocks['materio_search_api_viewmode'] = array(
- 'info' => t('Materio search api view mode selection'),
- 'cache' => DRUPAL_NO_CACHE
- );
- // $blocks['materio_search_api_filters'] = array(
- // 'info' => t('Materio search api filters'),
- // 'cache' => DRUPAL_NO_CACHE
- // );
- return $blocks;
- }
- /**
- * Implements hook_block_view().
- */
- function materio_search_api_block_view($delta = '') {
- // This example comes from node.module. Note that you can also return a
- // renderable array rather than rendered HTML for 'content'.
- $block = array();
- switch ($delta) {
- case 'materio_search_api_search':
- if (user_access('use materio search api') && user_access('use materio advanced search')) {
- $block['subject'] = t('Search');
- $block['content'] = theme('materio_search_api_double_search_block', array());
- }else if (user_access('use materio search api') || user_access('use materio search api for breves')) {
- $block['subject'] = t('Search');
- $block['content'] = theme('materio_search_api_search_block', array());
- }
- break;
- case 'mo_searchapi_advanced_search':
- if (user_access('use materio advanced search')) {
- $block['subject'] = t('Advanced Search');
- $block['content'] = theme('materio_search_api_advanced_search_block', array());
- }
- break;
- case 'materio_search_api_viewmode':
- // restrict display on node page for materiau and breve
- $block_is_visible = true;
- $q = parse_url($_GET['q']);
- $parts = explode('/', $q['path']);
- if($parts[0] == "node"){
- $node = node_load($parts[1]);
- $block_is_visible = in_array($node->type, array('materiau','breve')) ? true : false;
- }
- if (user_access('use materio search api viewmode selection') && $block_is_visible) {
- $block['subject'] = t('View mode');
- $block['content'] = theme('materio_search_api_select_viewmode_block', array());
- }
- break;
- // case 'materio_search_api_filters':
- // if (user_access('use materio search api filters')) {
- // $block['subject'] = t('Filters');
- // $block['content'] = theme('materio_search_api_filters_block', array());
- // }
- // break;
- }
- return $block;
- }
- /**
- * Implements hook_entity_info_alter().
- */
- function materio_search_api_entity_info_alter(&$entity_info) {
- $entity_info['node']['view modes']['cardsmall'] = array(
- 'label' => t('Small cards'),
- 'custom settings' => TRUE,
- );
- $entity_info['node']['view modes']['cardmedium'] = array(
- 'label' => t('Medium cards'),
- 'custom settings' => TRUE,
- );
- $entity_info['node']['view modes']['cardbig'] = array(
- 'label' => t('Big cards'),
- 'custom settings' => TRUE,
- );
- $entity_info['node']['view modes']['cardfull'] = array(
- 'label' => t('Full cards'),
- 'custom settings' => TRUE,
- );
- }
- /**
- * Implements hook_node_view_alter().
- */
- function materio_search_api_node_view_alter(&$build) {
- $node = $build['#node'];
- if (arg(0) == 'node' && arg(1) == $node->nid) {
- // dsm($build, 'build');
- global $user;
- $viewmode = isset($user->data['materiosearchapi_viewmode']) ? $user->data['materiosearchapi_viewmode'] : variable_get('defaultviewmode', 'full');
- // dsm($viewmode, 'viewmode');
- $node = $build['#node'];
- if($build['#view_mode'] != $viewmode && $build['#view_mode'] != "bookmark" & in_array($node->type, array('breve', 'materiau'))){
- $build = node_view($node, $viewmode);
- }
- }
- }
- /**
- * Implements hook_node_view().
- */
- function materio_search_api_node_view($node, $view_mode, $langcode) {
- if (in_array($view_mode, array('cardsmall','cardmedium', 'cardbig', 'cardfull'))) {
- # PRINT 7.1
- // print_node_view($node, 'full');
- // print_pdf_node_view($node, 'full');
- # PRINT 7.2-beta
- // call for hook_node_view of print module to insert link
- print_ui_node_view($node, 'full');
- // dsm($node, 'node');
- }
- }
- // _____ __ ______
- // / ___/___ ____ ___________/ /_ / ____/___ _________ ___
- // \__ \/ _ \/ __ `/ ___/ ___/ __ \ / /_ / __ \/ ___/ __ `__ \
- // ___/ / __/ /_/ / / / /__/ / / / / __/ / /_/ / / / / / / / /
- // /____/\___/\__,_/_/ \___/_/ /_/ /_/ \____/_/ /_/ /_/ /_/
- /**
- * materiobase_search_form()
- */
- function materio_search_api_search_form($form, &$form_state){
- // dsm($form_state, 'form_state');
- // dsm($form, 'form');
- global $user;
- $form = array();
- $args = arg();
- $path = array_shift($args);
- if (isset($args[0]) && $args[0] == "filters") {
- $path .= '/'.array_shift($args);
- }
- $is_explore = $path == 'explore' || $path == 'explore/filters';
- $keys = implode('/', $args);
- if(user_access('use materio search api autocomplete')){ // use materio search api autocomplete | use materio search api filters
- $query = new EntityFieldQuery();
- $query->entityCondition('entity_type', 'node')
- ->entityCondition('bundle', 'materiau')
- ->propertyCondition('status', 1);
- $count = $query->count()->execute();
- $default_value = t("search among our !fiches cards", array("!fiches"=>$count));
- }else{
- $default_value = '';
- }
- $form['searchfield'] = array(
- '#type' => 'textfield',
- '#default_value' => $is_explore ? $keys : $default_value, // TODO: set the search page path global or a variable in settings
- '#autocomplete_path' => 'materiosearchapi/autocomplete/searchapi',
- //'#autocomplete_path' => 'materiosearchapi/autocomplete/dbselect',
- '#size' => 30,
- '#maxlength' => 1024,
- '#attributes' => array("default"=>$default_value),
- );
- if(user_access('use materio search api filters')){
- $index = search_api_index_load(variable_get('mainsearchindex', -1));
- $indexed_bundles = $index->options['data_alter_callbacks']['search_api_alter_bundle_filter']['settings']['bundles'];
- foreach ($indexed_bundles as $bundle) {
- $bundles_options[$bundle] = $bundle;
- $default_bundles[] = $bundle;
- }
- $user_bundles_filter = isset($user->data['materiosearchapi_bundlesfilter']) ? $user->data['materiosearchapi_bundlesfilter'] : $default_bundles;
- $form['bundles_filter'] = array(
- '#type'=>'checkboxes',
- '#options' => $bundles_options,
- '#default_value' => $user_bundles_filter,
- // '#attributes' => array('class'=>array('btn-group')),
- );
- }
- $form['create'] = array(
- '#type' => 'image_button',
- '#src' => drupal_get_path('module', 'materio_search_api') . '/images/search.png',
- '#value' => t('Search'),
- '#prefix' => '<div class="search-btn-wrapper">',
- '#suffix'=> '</div>'
- );
- // add a back to search/base home bouton if on explore/foo
- if ($path == 'explore' || $path == 'explore/filters' || $path == 'bookmarks' || $path == 'lists' ) {
- // buttons form container
- $form['rightcol'] = array(
- '#type' => 'container',
- );
- $link = l('<i class="fi-home"></i>', base_path().'actuality', array(
- 'html'=>true,
- 'attributes'=>array('class'=>'back-search-home')
- ));
- $form['rightcol']['actu'] = array(
- '#type' => 'markup',
- '#markup' => $link,
- //'<a href="'.base_path().'actuality" class="back-search-home"><i class="fi-home"></i></a>'
- );
- }
- return $form;
- }
- function materio_search_api_search_form_validate($form, &$form_state){
- // dsm($form, '$form');
- // dsm($form_state, '$form_state');
- // dsm(strlen($form_state['values']['searchfield']));
- if (strlen(trim($form_state['values']['searchfield'])) <= 1) {
- form_set_error('searchfield', 'Please enter at least 2 characters keyword.');
- }
- }
- function materio_search_api_search_form_submit($form, &$form_state){
- // dsm($form_state, 'form_state');
- global $user;
- if(user_access('use materio search api filters')){
- foreach($form_state['values']['bundles_filter'] as $bundle => $value)
- if($value)
- $bundles[] = $bundle;
- # if no filter checked we checked them all by default
- if(!isset($bundles))
- foreach($form_state['values']['bundles_filter'] as $bundle => $value)
- $bundles[] = $bundle;
- }else{
- # if user have no access to filters
- $index = search_api_index_load(variable_get('mainsearchindex', -1));
- $indexed_bundles = $index->options['data_alter_callbacks']['search_api_alter_bundle_filter']['settings']['bundles'];
- foreach ($indexed_bundles as $bundle) {
- $bundles[] = $bundle;
- }
- }
- user_save($user, array("data"=>array('materiosearchapi_bundlesfilter' => $bundles)));
- $form_state['redirect'] = 'explore/'.$form_state['values']['searchfield'];
- }
- // ___ __ __ _____ __
- // / | ____/ / ______ _____ ________ ____/ / / ___/___ ____ ___________/ /_
- // / /| |/ __ / | / / __ `/ __ \/ ___/ _ \/ __ / \__ \/ _ \/ __ `/ ___/ ___/ __ \
- // / ___ / /_/ /| |/ / /_/ / / / / /__/ __/ /_/ / ___/ / __/ /_/ / / / /__/ / / /
- // /_/ |_\__,_/ |___/\__,_/_/ /_/\___/\___/\__,_/ /____/\___/\__,_/_/ \___/_/ /_/
- /**
- * materio_search_api_advanced_search_form()
- */
- function materio_search_api_advanced_search_form($form, &$form_state){
- // dsm($form_state, 'form_state');
- // dsm($form, 'form');
- // get vid from settings
- $vid = variable_get('msa-advancedsearchvocabulary', null);
- if($vid){
- $voc = taxonomy_vocabulary_load($vid);
- $voc_machinename = $voc->machine_name;
- // dsm($voc, "voc");
- $hidden_terms = variable_get('msa-hiddentaxoterms', array());
- // dsm($hidden_terms, 'hidden_terms');
- $values = isset($form_state['values']) ? $form_state['values'] : null;
- // dsm($values, "values");
- $args = arg();
- // dsm($args, 'args');
- // get the first elemt of url args
- $path = array_shift($args);
- if (isset($args[0]) && $args[0] == "filters") {
- $path .= '/'.array_shift($args);
- }
- // get the keywords from args and reconstruct the filter lines with default values
- $args_values = array();
- if($path == 'explore/filters' && $args[0] !== "ajax"){
- // WORKING WITH TIDS instead of term name
- $tids = explode("+", $args[0]);
- foreach ($tids as $key => $tid) {
- $term = taxonomy_term_load($tid);
- // dsm($term, $term->tid.' : '.$term->name);
- // get parents
- if(isset($term->tid)){
- $parents = taxonomy_get_parents_all($tid);
- // dsm($parents, 'parents');
- // build default values
- for ($p=count($parents)-1; $p >=0 ; $p--) {
- $args_values[$key][] = $parents[$p]->tid;
- }
- }
- }
- }
- // dsm($args_values, 'args_values');
- // TODO: show result count live
- // TODO: filter next select form item
- // define number of lines,
- // 1 by default
- // or from url arguments
- // or let it as it is if already chanched by ajax
- if(!isset($form_state['filterlines'])){
- if(count($args_values)){
- $form_state['filterlines'] = count($args_values);
- }else{
- $form_state['filterlines'] = 1;
- }
- }
- // dsm($form_state['filterlines'], "form_state['filterlines']");
- // filters form container
- $form['filters'] = array(
- '#type' => 'container',
- '#attributes' => array('class' => array("advancedsearch-filters")),
- '#prefix' => '<div id="advancedsearch-filters-wrapper">',
- '#suffix' => '</div>',
- );
- $form['filters']['filters-table'] = array(
- '#type' => 'container',
- '#attributes' => array('class' => array("advanced-search-form-table"))
- );
- // form headers
- // $form['filters']['filters-table']['headers'] = array(
- // '#type' => 'container',
- // '#attributes' => array('class' => array("advanced-search-form-headers")),
- // 'category' => array(
- // '#markup' => t("Category"),
- // '#prefix' => '<div>','#suffix' => '</div>',
- // ),
- // 'main' => array(
- // '#markup' => t("Main Filter"),
- // '#prefix' => '<div>','#suffix' => '</div>',
- // ),
- // 'child' => array(
- // '#markup' => t("Child Filter"),
- // '#prefix' => '<div>','#suffix' => '</div>',
- // )
- // );
- $trigger = FALSE;
- if (!empty($form_state['triggering_element']['#name'])) {
- $trigger = $form_state['triggering_element'];
- }
- $rmline = false;
- if ($trigger) {
- // dsm($form_state['triggering_element'], $form_state['triggering_element']['#name']);
- // dsm($values, 'form state values');
- // add a line if needed
- if($trigger['#name'] == 'addfilters'){
- $form_state['filterlines'] = $form_state['filterlines']+1;
- }
- // remove a line if needed
- if(strpos($trigger['#name'], 'rm-filter-') === 0){
- // $form_state['filterlines'] = $form_state['filterlines']+1;
- $rmline = $trigger['#return_value'];
- // dsm($rmline, "rmline");
- }
- }
- // build first level taxonomy tree and select options
- $taxotree = taxonomy_get_tree($vid, 0, 1, true);
- // $taxotree = msa_get_taxo_tree($vid, 0, 1);
- // dsm($taxotree, "taxotree");
- // return $form;
- foreach ($taxotree as $index => $term) {
- // TODO: get translated tag name
- if(!in_array($term->tid, $hidden_terms)){
- $level_0_ops[$term->tid] = $term->name;
- }
- }
- // build filters lines (ajax enabled)
- for ($l=0; $l < $form_state['filterlines']; $l++) {
- // if rmline this line,
- // continue the loop without creating the line
- if($l === $rmline){
- continue;
- }
- // if we are after the removed line,
- // create a second counter ($ll) to keep a continuous order for form items
- // and keep the current counter ($l) to retrieve de current values
- // if before removed line or no removed line at all, $l = $ll
- if($rmline !== false && $l >= $rmline){
- $ll = $l-1;
- }else{
- $ll = $l;
- }
- // dsm("l : ".$l." | ll : ".$ll);
- $form['filters']['filters-table']['filterline-'.$ll] = array(
- '#type' => 'container',
- '#attributes' => array('class' => array("filter-line"))
- );
- // get the default value
- // from from_state values if ajax
- // or from url args
- // or 0
- $default0 = null;
- if(isset($values['filter-'.$l.'-0']) && $values['filter-'.$l.'-0']){
- $default0 = $values['filter-'.$l.'-0'];
- }elseif(isset($args_values[$l][0])){
- $default0 = $args_values[$l][0];
- }
- // dsm($default0, "default 0");
- // form select element for first level
- $form['filters']['filters-table']['filterline-'.$ll]['filter-'.$ll.'-0'] = array(
- '#type' => 'select',
- '#options' => $level_0_ops,
- '#name' => 'filter-'.$ll.'-0',
- '#empty_option' => t("Choose a category"),
- // '#empty_values' => 0,
- '#default_value' => $default0,
- '#ajax' => array(
- 'callback' => 'materio_search_api_advanced_search_select_callback',
- 'wrapper' => 'advancedsearch-filters-wrapper',
- ),
- );
- // without this line, form api will mess with default values
- $form_state["input"]['filter-'.$ll.'-0'] = $default0;
- // add level 1 filter if level 0 chosen
- if(is_null($default0)){
- // $form['filters']['filterline-'.$ll]['filter-'.$ll.'-1']
- $form['filters']['filters-table']['filterline-'.$ll]['filter-'.$ll.'-1'] = array(
- '#markup' => t("Main Filter"),
- '#prefix' => '<div class="filter-markup"><span>',
- '#suffix' => '</span></div>',
- );
- // the definition of this markup appears twice, i may avoid that ...
- $form['filters']['filters-table']['filterline-'.$ll]['filter-'.$ll.'-2'] = array(
- '#markup' => t("Child Filter"),
- '#prefix' => '<div class="filter-markup"><span>',
- '#suffix' => '</span></div>',
- );
- }else{
- // build second level taxonomy tree and select options
- $taxotree1 = taxonomy_get_tree($vid, $default0, 1, true);
- // dsm($taxotree1, 'taxotree1');
- $level_1_ops = array();
- foreach ($taxotree1 as $index => $term) {
- // TODO: get translated tag name
- // $term = taxonomy_term_load($tid);
- $level_1_ops[$term->tid] = $term->name;
- }
- // get the default value
- // from from_state values if ajax
- // or from url args
- // or 0
- $default1 = null;
- if(isset($values['filter-'.$l.'-1']) && $values['filter-'.$l.'-1']){
- $default1 = $values['filter-'.$l.'-1'];
- }elseif(isset($args_values[$l][1])){
- $default1 = $args_values[$l][1];
- }
- // dsm($default1, "default 1");
- // form select element for second level
- $form['filters']['filters-table']['filterline-'.$ll]['filter-'.$ll.'-1'] = array(
- '#type' => 'select',
- '#options' => $level_1_ops,
- '#name' => 'filter-'.$ll.'-1',
- '#empty_option' => t("Choose a main filter"),
- // '#empty_values' => 0,
- '#default_value' => $default1,
- '#ajax' => array(
- 'callback' => 'materio_search_api_advanced_search_select_callback',
- 'wrapper' => 'advancedsearch-filters-wrapper',
- ),
- );
- // without this line, form api will mess with default values
- $form_state["input"]['filter-'.$ll.'-1'] = $default1;
- // add level 2 filter if level 1 chosen
- if(is_null($default1)){
- $form['filters']['filters-table']['filterline-'.$ll]['filter-'.$ll.'-2'] = array(
- '#markup' => t("Child Filter"),
- '#prefix' => '<div class="filter-markup"><span>',
- '#suffix' => '</span></div>',
- );
- }else{
- // build second level taxonomy tree and select options
- $taxotree2 = taxonomy_get_tree($vid, $default1, 1, true);
- if(!count($taxotree2)){
- $form['filters']['filters-table']['filterline-'.$ll]['filter-'.$ll.'-2'] = array(
- '#markup' => t("No Child"),
- '#prefix' => '<div class="filter-markup"><span>',
- '#suffix' => '</span></div>',
- );
- }else{
- // $default2 = isset($args_values[$l][2]) ? $args_values[$l][2] : 0;
- $default2 = null;
- if(isset($values['filter-'.$l.'-2']) && $values['filter-'.$l.'-2']){
- $default2 = $values['filter-'.$l.'-2'];
- }elseif(isset($args_values[$l][2])){
- $default2 = $args_values[$l][2];
- }
- // dsm($default2, "default 2");
- $level_2_ops = array();
- foreach ($taxotree2 as $index => $term) {
- // TODO: get translated tag name
- $level_2_ops[$term->tid] = t($term->name);
- }
- // form select element for third level
- $form['filters']['filters-table']['filterline-'.$ll]['filter-'.$ll.'-2'] = array(
- '#type' => 'select',
- '#options' => $level_2_ops,
- '#name' => 'filter-'.$ll.'-2',
- '#empty_option' => t("Refine with a child filter"),
- // '#empty_values' => 0,
- '#default_value' => $default2,
- );
- // without this line, form api will mess with default values
- $form_state["input"]['filter-'.$ll.'-2'] = $default2;
- }
- }
- }
- // add remove the line button
- $form['filters']['filters-table']['filterline-'.$ll]['rm-filter-'.$ll] = array(
- '#type' => 'image_button',
- '#src' => drupal_get_path('module', 'materio_search_api') . '/images/rmfilter.png',
- '#title' => t('Remove this filter line'),
- '#name' => 'rm-filter-'.$ll,
- '#return_value' => $ll,
- '#executes_submit_callback' => false,
- '#ajax' => array(
- 'callback' => 'materio_search_api_advanced_search_rmline_callback',
- 'wrapper' => 'advancedsearch-filters-wrapper',
- // 'trigger_as' => array("name"=>"rmfilters".$l),
- ),
- "#attributes" => array('class'=>array('rm-btn')),
- );
- } // end of lines loop
- if($rmline !== false){
- $form_state['filterlines'] = $form_state['filterlines']-1;
- }
- // button to add a new line of criterias
- $form['filters']['addfilters'] = array(
- '#type' => 'image_button',
- '#src' => drupal_get_path('module', 'materio_search_api') . '/images/addfilter.png',
- '#title' => t('Add a filter line'),
- '#name' => "addfilters",
- '#return_value' => "add",
- '#ajax' => array(
- 'callback' => 'materio_search_api_advanced_search_addfilter_callback',
- 'wrapper' => 'advancedsearch-filters-wrapper',
- ),
- '#executes_submit_callback' => false,
- '#attributes' => array('class'=>array('add-filter'))
- );
- // buttons form container
- $form['rightcol'] = array(
- '#type' => 'container',
- "#attributes" => array('class'=>array('right-col')),
- );
- // add a back to search/base home bouton if on explore/foo
- if ($path == 'explore' || $path == 'explore/filters' || $path == 'bookmarks' || $path == 'lists' ) {
- $link = l('<i class="fi-home"></i>', base_path().'actuality', array(
- 'html'=>true,
- 'attributes'=>array('class'=>'back-search-home')
- ));
- $form['rightcol']['actu'] = array(
- '#type' => 'markup',
- '#markup' => $link,
- );
- }
- // submit the search
- $form['rightcol']['search'] = array(
- '#type' => 'image_button',
- '#src' => drupal_get_path('module', 'materio_search_api') . '/images/search.png',
- '#title' => t('Search'),
- '#name' => "search",
- '#return_value' => "search",
- '#prefix' => '<div class="search-btn-wrapper">',
- '#suffix'=> '</div>'
- );
- }else{
- $form['novoc'] = array(
- '#markup' => "Please choose a vocabulary to search from in materio search api settings"
- );
- }
- // dsm($form, 'form');
- return $form;
- }
- function msa_get_taxo_tree($vid, $parent, $depth){
- $query = new EntityFieldQuery();
- $query->entityCondition('entity_type', 'taxonomy_term')
- ->propertyCondition('vid', $vid);
- // ->propertyCondition('parent', $parent);
- // ->propertyCondition('status', 1);
- // ->entityCondition('bundle', $voc_machinename)
- $result = $query->execute();
- if (isset($result['taxonomy_term'])) {
- $terms = $result['taxonomy_term'];
- // At first we need to get field's id. If you already know field id, you can ommit this step
- // Get all fields attached to a given node type
- $fields = field_info_instances('taxonomy_term');
- // Get id of body field
- // $field_id = $fields['name']['field_id'];
- // Attach a field of selected id only to get value for it
- field_attach_load('taxonomy_term', $terms, FIELD_LOAD_CURRENT, array('field_id' => 'name'));
- // Get values of our node field
- // $output = field_get_items('node', $stories, 'field_story_image');
- }
- return $terms;
- }
- function materio_search_api_advanced_search_select_callback($form, &$form_state) {
- return $form['filters'];
- }
- function materio_search_api_advanced_search_addfilter_callback($form, &$form_state) {
- return $form['filters'];
- }
- function materio_search_api_advanced_search_rmline_callback($form, &$form_state) {
- return $form['filters'];
- }
- function materio_search_api_advanced_search_form_validate($form, &$form_state){
- if($form_state['triggering_element']['#name'] == 'search'){
- // dsm($form, '$form');
- dsm($form_state, 'form_state');
- if (!isset($form_state['values']['filter-0-1']) || $form_state['values']['filter-0-1'] == '') {
- form_set_error('filters', 'Please choose at least 1 keyword.');
- }
- }
- }
- function materio_search_api_advanced_search_form_submit($form, &$form_state){
- // dsm($form_state, 'form_state');
- $values = $form_state['values'];
- $filterlines = isset($form_state['filterlines']) ? $form_state['filterlines'] : 0;
- // $keywords = array();
- // extract last tag of each lines
- for ($l=0; $l < $filterlines ; $l++) {
- for ($i=2; $i > 0 ; $i--) {
- if(isset($values['filter-'.$l.'-'.$i]) && $values['filter-'.$l.'-'.$i]){
- // $term = taxonomy_term_load($values['filter-'.$l.'-'.$i]);
- // $keywords[$term->tid] = '"'.$term->name.'"';
- // $tids[] = '"'.$values['filter-'.$l.'-'.$i].'"';
- $tids[] = $values['filter-'.$l.'-'.$i];
- continue 2;
- }else{
- continue;
- }
- }
- }
- // dsm($keywords, 'keywordstid');
- $keywords_str = implode("+", $tids);
- // dsm($keywords_str);
- $form_state['redirect'] = 'explore/filters/'.$keywords_str; //rawurlencode($keywords_str);
- }
- /**
- * viewmode
- */
- function _materio_search_api_change_viewmode($vm){
- // dsm($vm, '_materio_search_api_change_viewmode');
- global $user;
- // dsm($user, 'user');
- $entity_infos = entity_get_info();
- // dsm($entity_infos, 'entity_infos');
- if (in_array($vm, variable_get('availableviewmodes', array()))) {
- user_save($user, array("data"=>array('materiosearchapi_viewmode' => $vm)));
- $rep = array('statut'=>'saved');
- }else{
- $rep = array('statut'=>'viewmode not allowed');
- }
- return $rep;
- }
- /**
- * - - - - - - - - - - - - THEME - - - - - - - - - - - -
- */
- /**
- * Implements hook_theme().
- */
- function materio_search_api_theme($existing, $type, $theme, $path) {
- return array(
- 'materio_search_api_search_block' => array(
- 'arguments' => array(),
- 'template' => 'materio-search-api-search-block',
- 'path' => drupal_get_path('module', 'materio_search_api').'/templates',
- ),
- 'materio_search_api_advanced_search_block' => array(
- 'arguments' => array(),
- 'template' => 'materio-search-api-advanced-search-block',
- 'path' => drupal_get_path('module', 'materio_search_api').'/templates',
- ),
- 'materio_search_api_double_search_block' => array(
- 'arguments' => array(),
- 'template' => 'materio-search-api-double-search-block',
- 'path' => drupal_get_path('module', 'materio_search_api').'/templates',
- ),
- 'materio_search_api_select_viewmode_block' => array(
- 'arguments' => array(),
- 'template' => 'materio-search-api-select-viewmode-block',
- 'path' => drupal_get_path('module', 'materio_search_api').'/templates',
- ),
- // 'materio_search_api_filters_block' => array(
- // 'arguments' => array(),
- // 'template' => 'materio-search-api-filters-block',
- // 'path' => drupal_get_path('module', 'materio_search_api').'/templates',
- // ),
- 'materio_search_api_results' => array(
- 'arguments' => array(),
- 'template' => 'materio-search-api-results',
- 'path' => drupal_get_path('module', 'materio_search_api').'/templates',
- 'variables' => array(
- 'index' => NULL,
- 'results' => array('result count' => 0),
- 'items' => array(),
- 'view_mode' => 'teaser',
- 'keys' => '',
- // 'page_machine_name' => NULL,
- 'spellcheck' => NULL,
- 'pager' => NULL,
- ),
- ),
- // 'materio_search_api_performance' => array(
- // 'render element' => 'element',
- // ),
- 'materio_search_api_actuality' => array(
- 'template' => 'materio-search-api-actuality',
- 'path' => drupal_get_path('module', 'materio_search_api').'/templates',
- 'arguments' => array(
- 'items' => array(),
- 'view_mode' => "teaser",
- 'pager' => NULL,
- 'count' => 0,
- )
- ),
- 'materio_search_api_form_element' => array(
- 'render element' => 'element',
- ),
- );
- }
- /**
- * Implements theme for rendering search-performance
- */
- // function theme_materio_search_api_performance($variables) {
- // $element = array_shift($variables);
- // return $element['#markup'];
- // }
- /**
- * template_preprocess_materiobase_advanced_search_block();
- */
- function template_preprocess_materio_search_api_search_block(&$vars){
- // dsm($vars, '$vars');
- $vars['searchform'] = drupal_get_form("materio_search_api_search_form");
- }
- /**
- * template_preprocess_materiobase_advanced_search_block();
- */
- function template_preprocess_materio_search_api_advanced_search_block(&$vars){
- // dsm($vars, '$vars');
- $vars['searchform'] = drupal_get_form("materio_search_api_advanced_search_form");
- }
- /**
- * template_preprocess_materiobase_search_block();
- */
- function template_preprocess_materio_search_api_double_search_block(&$vars){
- // dsm($vars, '$vars');
- $vars['search_title'] = t("Text search");
- $vars['searchform'] = drupal_get_form("materio_search_api_search_form");
- $vars['advanced_search_title'] = t("Filtered search");
- $vars['advanced_searchform'] = drupal_get_form("materio_search_api_advanced_search_form");
- }
- function template_preprocess_materio_search_api_select_viewmode_block(&$vars){
- global $user;
- $active = isset($user->data['materiosearchapi_viewmode']) ? $user->data['materiosearchapi_viewmode'] : variable_get('defaultviewmode', 'full');
- $availableviewmodes = variable_get('availableviewmodes', -1);
- // dsm($availableviewmodes);
- $entity_infos = entity_get_info();
- // dsm($entity_infos, 'entity_infos');
- $content = '<div class="btn-group btn-group-vertical">';
- foreach ($entity_infos['node']['view modes'] as $viewmode => $value) {
- if(in_array($viewmode, $availableviewmodes)){
- $link = l(
- '<i class="icon-materio-viewmode-'.$viewmode.($active == $viewmode ? " active" : '').'"></i><span class="inner">'.$value['label'].'</span>',
- 'materiosearchapi/viewmode/change/'.$viewmode,
- array(
- 'query' => drupal_get_destination(),
- 'html' => true,
- 'attributes' => array(
- 'class' => array(
- 'viewmode-link',
- 'viewmode-'.$viewmode,
- $active == $viewmode ? " active" : ''
- ),
- 'rel' => $viewmode
- )
- )
- );
- $content .= $link;
- }
- }
- $content .= '</div>';
- $vars['content'] = $content;
- }
- // function template_preprocess_materio_search_api_filters_block(&$vars){
- // $index_machine_name = variable_get('mainsearchindex', -1);
- // $index = search_api_index_load($index_machine_name);
- // dsm($index, 'index');
- // // $entity_infos = entity_get_info($index->item_type);
- // // dsm($entity_infos, 'entity_infos');
- // $indexed_bundles = $index->options['data_alter_callbacks']['search_api_alter_bundle_filter']['settings']['bundles'];
- // dsm($indexed_bundles, 'indexed_bundles');
- // $vars['content'] = drupal_get_form('materio_search_api_filters_form', $indexed_bundles);
- // }
- // function materio_search_api_filters_form($form, $form_state, $bundles){
- // $form = array();
- // dsm($bundles, 'bundles');
- // foreach ($bundles as $bundle) {
- // $form[$bundle . '_filter'] = array(
- // '#type'=>'checkbox',
- // '#default_value' => -1,
- // '#title' => $bundle,
- // );
- // }
- // return $form;
- // }
- /**
- * Function for preprocessing the variables for the search_api_page_results
- * template.
- *
- * @param array $variables
- * An associative array containing:
- * - $index: The index this search was executed on.
- * - $results: An array of search results, as returned by
- * SearchApiQueryInterface::execute().
- * - $keys: The keywords of the executed search.
- *
- * @see materio-search-api-results.tpl.php
- */
- function template_preprocess_materio_search_api_results(array &$vars) {
- // dsm($vars, 'vars');
- $results = $vars['results'];
- if(isset($results['result count'])){
- $vars['result_count'] = $results['result count'];
- $vars['sec'] = round($results['performance']['complete'], 3);
- $vars['keywords'] = $vars['keys'];
- if(isset($results['breves count'])){
- // for free users
- // dsm("free users");
- $vars['perfascard'] = true;
- $perfoutput = format_plural(
- $results['breves count'],
- 'The search found 1 news ',
- 'The search found @count news '
- );
- $perfoutput .= format_plural(
- $vars['result_count'] - $results['breves count'],
- 'with 1 associated matter.',
- 'with @count associated matters.'
- );
- $perfoutput .= '<br />';
- $perfoutput .= format_plural(
- $results['could results']['result count'],
- ' You could have found 1 result with a ',
- ' You could have found <strong>@count results</strong> with a '
- );
- $perfoutput .= l(t('full access to materiO\'.'), 'node/11187');
- $perfoutput .= l(t('Pricing'), 'node/11187', array("attributes"=>array("class"=>array('button'))));
- $vars['search_performance'] = $perfoutput;
- }else{
- // for members
- $vars['perfascard'] = false;
- // $vars['search_performance'] = format_plural(
- // // $results['result count'],
- // $vars['result_count'],
- // 'The search found 1 result ',
- // 'The search found @count results '
- // )
- $vars['search_performance'] = t('The search found @count result(s) with keywords @keys.', array(
- "@count"=>$vars['result_count'],
- "@keys"=>$vars['keywords'])
- );
- // TODO indicate how many materials and how many news
- // $vars['search_performance'] = t('The search found @count result(s) with keywords @keys. @mat materials and @new news.', array(
- // "@count"=>$vars['result_count'],
- // "@keys"=>$vars['keywords'],
- // "@mat"=>4,
- // "@new"=>7)
- // );
- }
- }else{
- //for anonymous
- $vars['perfascard'] = true;
- $perfoutput = t('You can\'t access to the materiO\' search tool without an account.').'<br />';
- $perfoutput .= format_plural(
- $results['could results']['result count'],
- ' You could have found 1 result with a ',
- ' You could have found <strong>@count results</strong> with a '
- );
- $perfoutput .= l(t('full access to materiO\'.'), 'node/11187');
- $perfoutput .= l(t('Pricing'), 'node/11187', array("attributes"=>array("class"=>array('button'))));
- $vars['search_performance'] = $perfoutput;
- }
- //dsm($vars, '$vars');
- }
- function template_preprocess_materio_search_api_actuality(&$vars){
- // dsm($vars, 'template_preprocess_materio_search_api_actuality | vars');
- // $vars['actualities_infos'] = t('Actualities by materiO\'');
- $vars['actualities_infos'] = t('');
- }
- function theme_materio_search_api_form_element($variables) {
- // dsm($variables, 'variables');
- $element = &$variables['element'];
- // This function is invoked as theme wrapper, but the rendered form element
- // may not necessarily have been processed by form_builder().
- $element += array(
- '#title_display' => 'before',
- );
- // Add element #id for #type 'item'.
- if (isset($element['#markup']) && !empty($element['#id'])) {
- $attributes['id'] = $element['#id'];
- }
- // Add element's #type and #name as class to aid with JS/CSS selectors.
- $attributes['class'] = array('form-item');
- if (!empty($element['#type'])) {
- $attributes['class'][] = 'form-type-' . strtr($element['#type'], '_', '-');
- }
- if (!empty($element['#name'])) {
- $attributes['class'][] = 'form-item-' . strtr($element['#name'], array(' ' => '-', '_' => '-', '[' => '-', ']' => ''));
- }
- // Add a class for disabled elements to facilitate cross-browser styling.
- if (!empty($element['#attributes']['disabled'])) {
- $attributes['class'][] = 'form-disabled';
- }
- # adding element class to wrapper
- foreach ($element['#attributes']['class'] as $value) {
- $attributes['class'][] = $value;
- }
- foreach ($element['#attributes'] as $attr => $value) {
- if(!in_array($attr, array('class', 'multiple', 'id', 'type', 'name'))){
- $attributes[$attr] = $value;
- }
- }
- $output = '<div' . drupal_attributes($attributes) . '>' . "\n";
- // If #title is not set, we don't display any label or required marker.
- if (!isset($element['#title'])) {
- $element['#title_display'] = 'none';
- }
- $prefix = isset($element['#field_prefix']) ? '<span class="field-prefix">' . $element['#field_prefix'] . '</span> ' : '';
- $suffix = isset($element['#field_suffix']) ? ' <span class="field-suffix">' . $element['#field_suffix'] . '</span>' : '';
- switch ($element['#title_display']) {
- case 'before':
- case 'invisible':
- $output .= ' ' . theme('form_element_label', $variables);
- $output .= ' ' . $prefix . $element['#children'] . $suffix . "\n";
- break;
- case 'after':
- $output .= ' ' . $prefix . $element['#children'] . $suffix;
- $output .= ' ' . theme('form_element_label', $variables) . "\n";
- break;
- case 'none':
- case 'attribute':
- // Output no label and no required marker, only the children.
- $output .= ' ' . $prefix . $element['#children'] . $suffix . "\n";
- break;
- }
- if (!empty($element['#description'])) {
- $output .= '<div class="description">' . $element['#description'] . "</div>\n";
- }
- $output .= "</div>\n";
- return $output;
- }
- /**
- * - - - - - - - - - - - - SEARCH API PAGE - - - - - - - - - - - -
- */
- /**
- * Implements hook_block_view_alter().
- */
- function materio_search_api_block_view_alter(&$data, $block) {
- // this alter prepopulate the search form provide by search_api_page
- if ($block->module == 'search_api_page') {
- $page = search_api_page_load($block->delta);
- $item = menu_get_item();
- if (isset($page->path) && $page->path == $item['path']) {
- $keys = arg(count(arg(NULL, $page->path)));
- if ($keys) {
- $data['content']['keys_' . $page->id]['#default_value'] = $keys;
- $data['content']['keys_' . $page->id]['#value'] = $keys;
- }
- }
- }
- }
|