diff --git a/materio_search_api.admin.inc b/materio_search_api.admin.inc
index 1e1032c3..9edfdb04 100755
--- a/materio_search_api.admin.inc
+++ b/materio_search_api.admin.inc
@@ -34,12 +34,6 @@ function materio_search_api_settings(){
'#title' => t('Autocomplete search api index for %lang contents.', array('%lang'=>$name)),
);
- $form['advancedsearchindex_'.$lcode] = array(
- '#type'=>'select',
- '#options'=>$index_options,
- '#default_value' => variable_get('advancedsearchindex_'.$lcode, -1),
- '#title' => t('Advanced search api index for %lang contents.', array('%lang'=>$name)),
- );
}
@@ -75,19 +69,5 @@ function materio_search_api_settings(){
);
}
- $vocabularies = taxonomy_get_vocabularies();
- // dsm($vocabularies, 'vocabularies');
- foreach ($vocabularies as $vid => $voc){
- $vocs_options[$vid] = $voc->name;
- }
-
- $form['advancedsearchvocs'] = array(
- '#type'=>'select',
- '#options'=>$vocs_options,
- '#default_value' => variable_get('advancedsearchvocs', array()),
- '#title' => t('Advanced Search Vocabularies'),
- '#multiple' => true,
- );
-
return system_settings_form($form);
}
\ No newline at end of file
diff --git a/materio_search_api.module b/materio_search_api.module
index c6db4f01..3459d6b8 100755
--- a/materio_search_api.module
+++ b/materio_search_api.module
@@ -38,10 +38,6 @@ function materio_search_api_permission() {
'title' => t('use Materio search api filters'),
'description' => t('Use materio search api filters.'),
),
- 'use materio search api advanced search' => array(
- 'title' => t('use materio search api advanced search'),
- 'description' => t('Use materio search api advanced search.'),
- ),
);
}
@@ -440,11 +436,6 @@ function materio_search_api_block_info() {
'cache' => DRUPAL_NO_CACHE
);
- $blocks['materio_sa_adv_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'),
@@ -496,13 +487,6 @@ function materio_search_api_block_view($delta = '') {
// }
// break;
- # NOT USED
- case 'materio_sa_adv_search':
- if(user_access('use materio search api advanced search')){
- $block['subject'] = t('Advanced Search');
- $block['content'] = theme('materio_search_api_advanced_search_block', array());
- }
- break;
}
return $block;
}
@@ -677,240 +661,6 @@ function materio_search_api_search_form_submit($form, &$form_state){
}
-/**
- * materiobase_advancedsearch_form()
- */
-function materio_search_api_advanced_search_form($form, &$form_state){
- // dsm($form_state, 'form_state');
- // dsm($form, 'form');
- // global $user;
- $as_tree = materio_serach_api_get_advancedsearch_tree();
- // dsm($as_tree, 'as_tree');
-
- $keys = arg();
- $path = array_shift($keys);
- // dsm($keys, 'keys');
- if($path == 'explore' && $keys[0] == "advanced"){
- $advanced = true;
- array_shift($keys);
- $default_keys = $keys;
- }
-
- $form = array(
- 'title' => array(
- '#prefix' => "
",
- '#markup' => t("Advanced Search"),
- '#suffix' => "
",
- )
- );
-
- $form['slider'] = array(
- '#type' => 'fieldset',
- // '#title' => $voc->name,
- '#tree' => true,
- );
-
- foreach ($as_tree as $vid => $tree) {
-
- // $voc = taxonomy_vocabulary_load($vid);
- // dsm($voc, 'voc');
-
- $form['slider']['voc-'.$vid] = array(
- '#type' => 'fieldset',
- // '#title' => $voc->name,
- '#tree' => true,
- );
-
- foreach ($tree as $term) {
- // dsm($term, 'term');
-
- $form['slider']['voc-'.$vid]['tree-'.$term['tid']] = array(
- '#type' => 'fieldset',
- // '#title' => $term->name,
- '#attributes' => array("class"=>array("treelevel1")),
- '#tree' => true,
- );
-
- $placeholder = t("Select an option");
- $form['slider']['voc-'.$vid]['tree-'.$term['tid']]['children'] = array(
- '#type' => 'select',
- '#title' => $term['name'],
- '#attributes' => array(
- "class"=>array("treelevel1"),
- "title"=>$placeholder,
- "data-placeholder" => $placeholder,
- ), //, "form-control"
- '#theme_wrappers' => array('materio_search_api_form_element'),
- '#empty_option' => $placeholder,
- '#empty_value' => 1,
- );
-
- $options = array();
- foreach ($term['children'] as $tid => $child) {
-
- $options[$tid] = $child['name'];
-
- $classes2 = array("treelevel2", $child['tid']);
-
- $options2 = array();
- $dflt_values2 = array();
- foreach ($child['children'] as $tid2 => $child2) {
- $options2[$tid2] = $child2['name'];
- // default Values
- if(in_array($tid2, $default_keys))
- $dflt_values2[] = $tid2;
- }
-
- if(count($options2)){
-
- if(count($dflt_values2))
- $classes2[] = 'visible';
-
- $form['slider']['voc-'.$vid]['tree-'.$term['tid']]['tid-'.$child['tid']] = array(
- '#type' => 'select',
- '#title' => $child['name'],
- '#multiple' => true,
- '#attributes' => array(
- "class" => $classes2, // , "form-control"
- "title" => "-Please select-",
- "tid" => $child['tid'],
- ),
- '#theme_wrappers' => array('materio_search_api_form_element'),
- // '#empty_option' => '-Please select-',
- // '#empty_value' => 1,
- '#options' => $options2,
- '#default_value' => $dflt_values2,
- );
- }
- }
- if(count($options)){
- $form['slider']['voc-'.$vid]['tree-'.$term['tid']]['children']['#options'] = $options;
- }else{
- unset($form['slider']['voc-'.$vid]['tree-'.$term['tid']]);
- }
- }
-
- }
-
- $form['slider']['show'] = array(
- '#type' => 'image_button',
- '#src' => drupal_get_path('module', 'materio_search_api') . '/images/search.png',
- '#value' => t('Find'),
- // '#attributes' => array("class"=>array("btn","btn-lg")),
- '#prefix' => '',
- '#suffix' => '
',
- );
- return $form;
-}
-
-function materio_serach_api_get_advancedsearch_tree(){
- $as_tree = array();
- $vocabularies = variable_get('advancedsearchvocs', array());
-
- foreach ($vocabularies as $vid) {
- // dsm($vid, "vid");
-
- // $voc = taxonomy_vocabulary_load($vid);
- // dsm($voc, 'voc');
-
- $tree = taxonomy_get_tree($vid, 0, 1, TRUE);
- // dsm($tree, 'tree');
-
- if(!count($tree)) continue;
-
- foreach ($tree as $term) {
- // dsm($term, "term : ".$term->name);
-
- if(!isset($term->field_used_on_advanced_search['und'][0]['value'])
- || $term->field_used_on_advanced_search['und'][0]['value'] == 0)
- continue;
-
- $children = taxonomy_get_children($term->tid, $vid);
- // dsm($children, "children");
-
- if(!count($children)) continue;
-
- foreach ($children as $tid => $child) {
- $child = taxonomy_term_load($child->tid);
- // dsm($child, 'child : '.$child->name);
- if($child->field_used_on_advanced_search['und'][0]['value'] == 0)
- continue;
-
- // $children2 = taxonomy_get_children($child->tid, $vid);
- $children2 = taxonomy_get_children_all($child->tid, $vid);
- // dsm($children2, "children2");
-
- if(!count($children2)) continue;
-
- foreach ($children2 as $tid2 => $child2) {
- $child2 = taxonomy_term_load($tid2);
- // dsm($child2, 'child2 : '.$child2->name);
- if(!isset($child2->field_used_on_advanced_search['und'][0]['value'])
- || $child2->field_used_on_advanced_search['und'][0]['value'] == 0)
- continue;
-
- $as_tree[$vid][$term->tid]['children'][$child->tid]['children'][$child2->tid] = array('tid'=>$child2->tid,'name'=>$child2->name);
- }
-
- if(isset($as_tree[$vid][$term->tid]['children'][$child->tid]['children']))
- $as_tree[$vid][$term->tid]['children'][$child->tid] += array("tid"=>$child->tid,"name"=>$child->name);
- }
-
- if(isset($as_tree[$vid][$term->tid]['children']))
- $as_tree[$vid][$term->tid] += array("tid"=>$term->tid,"name"=>$term->name);
- }
- }
-
- return $as_tree;
-}
-
-function taxonomy_get_children_all($tid, $vid = 0, $key = 'tid'){
- $c = taxonomy_get_children($tid, $vid, $key);
- $result = array();
- foreach ($c as $t => $d){
- $result[$t] = $d;
- $below = taxonomy_get_children_all($t, $vid, $key);
- if (!empty($below)) {
- foreach ($below as $nt => $nd){
- $result[$nt] = $nd;
- }
- }
- }
- return $result;
-}
-
-function materio_search_api_advanced_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_advanced_search_form_submit($form, &$form_state){
- // dsm($form, 'form');
- // dsm($form_state, 'form_state');
- $fs_values = $form_state['values']['slider'];
- unset($fs_values['show']);
- // dsm($fs_values, 'values');
-
- foreach($fs_values as $voc => $trees){
- foreach($trees as $tree => $values){
- foreach ($values as $values => $selected) {
- if(is_array($selected) && count($selected)){
- foreach ($selected as $tid) {
- $tids[] = $tid;
- }
- }
- }
- }
- }
-
- $form_state['redirect'] = 'explore/advanced/'.implode('/', $tids);
-}
-
-
/**
* viewmode
*/
diff --git a/materio_search_api.pages.inc b/materio_search_api.pages.inc
index 3de2fb6f..1e424f8b 100755
--- a/materio_search_api.pages.inc
+++ b/materio_search_api.pages.inc
@@ -130,19 +130,8 @@ function materio_search_api_results_search(){
// retreive typed words separated by slashes as a sentence
$keys = func_get_args();
// dsm($args, 'args');
- if($keys[0] == "advanced"){
- $advanced = true;
- array_shift($keys);
- // dsm($keys, 'shifted keys');
- // foreach ($args as $arg) {
- // $typed[] = $arg;//(integer)$arg;
- // }
- $typed = implode(' +', $keys);
- }else{
- $advanced = false;
- $typed = implode('/', $keys);
- }
-
+ $typed = implode('/', $keys);
+
// remove query page params
preg_match_all('/\?page=([0-9]+)/', $typed, $pages);
@@ -155,13 +144,7 @@ function materio_search_api_results_search(){
global $language;
global $user;
- if($advanced && user_access('use materio search api advanced search')){
- // dsm('advanced search');
- $index_machine_name = variable_get('advancedsearchindex_'.$language->language, -1);
- // dsm($index_machine_name, '$index_machine_name');
- $index = search_api_index_load($index_machine_name);
- }
- else if(user_access('use materio search api')){
+ if(user_access('use materio search api')){
// dsm('normal search');
# switch index depending on key words type full text or taxonomy term (autocomplete selection)
$searchmode = isset($user->data['materiosearchapi_searchmode']) ? $user->data['materiosearchapi_searchmode'] : "fulltext";
@@ -183,7 +166,7 @@ function materio_search_api_results_search(){
$index = search_api_index_load($index_machine_name);
}
- if(!user_access('use materio search api advanced search') && !user_access('use materio search api')){
+ if(!user_access('use materio search api')){
# potential results index for anonymous and free user
$could_index_machine_name = variable_get('mainsearchindex_'.$language->language, -1);
$could_index = search_api_index_load($index_machine_name);
@@ -215,9 +198,7 @@ function materio_search_api_results_search(){
: $default_bundles;
# choose solr query options
- $query_options = $advanced
- ? array('conjunction'=>'AND', 'parse mode'=>'direct')
- : array('conjunction'=>'OR', 'parse mode'=>'direct');
+ $query_options = array('conjunction'=>'OR', 'parse mode'=>'direct');
#create the solr query
$query = search_api_query($index_machine_name, $query_options)
@@ -262,9 +243,8 @@ function materio_search_api_results_search(){
if(user_access('use materio search api for breves')
|| user_access('use materio search api')
- || user_access('use materio search api advanced search'))
{
- if(user_access('use materio search api') || user_access('use materio search api advanced search')){
+ if( user_access('use materio search api') ){
if(is_array($results['results'])){
$items = $index->loadItems(array_keys($results['results']));
}else{
@@ -316,16 +296,7 @@ function materio_search_api_results_search(){
// page title
- if($advanced){
- foreach($keys as $tid){
- $t = taxonomy_term_load($tid);
- $ptk[] = $t->name;
- }
- $page_title = implode(' +', $ptk);
- }
- else{
- $page_title = $typed;
- }
+ $page_title = $typed;
drupal_set_title(''.check_plain($page_title), PASS_THROUGH);
// render results