मैं व्यू 3 और डी 7 के लिए कस्टम एक्सपोजर फिल्टर कैसे बना सकता हूं, इसके बारे में कहां जान सकता हूं?


18

मैं सीखने की कोशिश कर रहा हूं कि किसी योगदान किए गए मॉड्यूल (चयन या अन्य) के लिए कस्टम एक्सपोजर फिल्टर कैसे बनाया जाए। मुझे Drupal 6 के लिए यह ट्यूटोरियल मिला, लेकिन कोड Drupal 7 पर आउट-ऑफ-द-बॉक्स काम नहीं करता है।

मैंने पदानुक्रमित चयन मॉड्यूल में कोड को देखने की भी कोशिश की, लेकिन मैं जो करने की कोशिश कर रहा हूं, उससे कहीं अधिक जटिल प्रतीत होता है।

क्या किसी के पास ट्यूटोरियल या मॉड्यूल के लिए कोई सुझाव है जो कस्टम एक्सपोज़र फ़िल्टर को अपेक्षाकृत सरल तरीके से लागू करता है (जैसे, स्थान मॉड्यूल जैसे कस्टम हैंडलर्स की एक बड़ी संख्या नहीं) जिसे मैं सीख सकता हूं?

जवाबों:


6

संक्षिप्त उत्तर: कहीं नहीं।

लेकिन आप यहाँ और वहाँ जानकारी के बिट्स पा सकते हैं।

देखने के लिए पहली जगह दृश्य स्रोतों में है, विशेष रूप से मौजूदा फिल्टर के कार्यान्वयन, सरल लोगों के साथ शुरू।

वैयक्तिक, मैंने इस सूत्र में भाग लिया, जो बहुत शिक्षाप्रद था, लेकिन पूरी तरह से संतोषजनक नहीं था, जैसा कि आप देखेंगे कि क्या आप इसे पढ़ते हैं। मुझे लगता है कि यहां की जानकारी हालांकि उपयोगी है, और मैं कम से कम यह कह सकता हूं कि यह उस समय लिखा गया था जब यह लिखा गया था।


2
यहाँ पिछले Drupalcon से एक सम्मेलन है जिसे मैंने अभी खोजा है और इसमें अविश्वसनीय रूप से उपयोगी जानकारी शामिल है, जिसमें Api.drupal.org प्रलेखन के भाग का उल्लेख भी शामिल है जिसके बारे में मुझे जानकारी नहीं थी। यह मैं अब तक के बारे में पता विकास विचारों के लिए सबसे अच्छी शुरुआत है।
काउंट्ज़ेरो

10

मैं उसी प्रश्न के उत्तर को खोजने के लिए इंटरनेट के आसपास दुबका हुआ था और यही मुझे परिणाम में मिला है:

  1. अपने कस्टम मॉड्यूल में कई हुक लागू करें। बदलें modulenameऔर filternameअपने वास्तविक नामों के साथ।

    /**
     * Implements hook_views_api().
     */
    function modulename_views_api() {
      return array(
        'api' => 2,
        'path' => drupal_get_path('module', 'modulename') . '/inc',
      );
    }
    
    /**
     * Implementation of hook_views_handlers() to register all of the basic handlers
     * views uses.
     */
    function modulename_views_handlers() {
      return array(
        'info' => array(
          // path to handler files
          'path' => drupal_get_path('module', 'modulename') . '/inc',
        ),
        'handlers' => array(
          // register our custom filter, with the class/file name and parent class
          'modulename_handler_filter_filtername' => array(
            'parent' => 'views_handler_filter',
          ),
        ),
      );
    }
    
    function modulename_views_data() {
      $data = array();
    
      $data['node']['filtername'] = array(
        'group' => t('Custom'),
        'real field' => 'my_custom_filter_field',
        'title' => t('My custom filter'),
        'help' => t('Some more detailed description if you need it.'),
        'filter' => array(
          'handler' => 'modulename_handler_filter_filtername',
        ),
      );
    
      return $data;
    }
  2. incअपने मॉड्यूल फ़ोल्डर के अंदर नामित फ़ोल्डर बनाएं और modulename_handler_filter_filtername.incवहां नामित फ़ाइल बनाएं (इस फ़ाइल के अंतर्निहित संदर्भ के लिए ऊपर कोड देखें)। वास्तविक मॉड्यूल और फ़िल्टर नामों का उपयोग करना न भूलें।

  3. उस modulename_handler_filter_filtername.incफ़ाइल में कोड का पालन करें । इस उदाहरण के लिए मैंने जिस कोड का उपयोग किया था, वह वर्षों से मौजूद रेडियो बटनों का एक समूह बनाता है। तो आप साल भर में निर्मित नोड्स को फ़िल्टर कर सकते हैं, केवल उन वर्षों का उपयोग करके जिनमें नोड्स बनाए गए थे।

    class modulename_handler_filter_filtername extends views_handler_filter {
    
      /**
       * Options form subform for setting exposed filter options.
       */
      function value_form(&$form, &$form_state) {
        parent::value_form($form, $form_state);
    
        // get list of years from database
        $query = db_select('node', 'n');
        $query->addExpression("FROM_UNIXTIME(n.created, '%Y')", 'year');
        if (isset($this->view->filter['type'])) {
          $query->condition('n.type', $this->view->filter['type']->value, 'IN');
        }
        $result = $query->orderBy('year', 'ASC')
          ->execute()
          ->fetchAllAssoc('year');
    
        $years = array(
          '0' => t('All'),
        );
        foreach ($result as $k => $v) {
          $years[$k] = $k;
        }
    
        // create form element with options retrieved from database
        $form['value']['year'] = array(
          '#type' => 'radios',
          '#options' => $years,
          '#default_value' => end($years),
        );
      }
    
      /**
       * Alters Views query when filter is used.
       */
      function query() {
        // make sure base table is included in the query
        $this->ensure_my_table();
    
        // retrieve real filter name from view options
        // this requires 'real field' filter option to be set (see code above)
        $real_field_name = $this->real_field;
        // get the value of the submitted filter
        $value = $this->view->exposed_data[$real_field_name];
    
        // finally, alter Views query
        if (is_numeric($value) && $value != 0) {
          /* 
            Having several custom exposed filters, make sure subsitution patterns
            (e.g. :filtername_value below) don't match across different filters.
            I spent some time figuring out why all my filters had the same value.
            It looks like the query skeleton is built first and then all replacements
            are made in bulk. Prefixing value with filter name looks good imo.
          */
          $this->query->add_where_expression($this->options['group'],
            "FROM_UNIXTIME(node.created, '%Y') = :filtername_value",
            array(':filtername_value' => $value));
        }
      }
    }

बस आपको सरलतम कस्टम एक्सपोज़र फ़िल्टर काम करने की आवश्यकता है!

ध्यान दें कि क्वेरी की FROM_UNIXTIMEस्थिति में उपयोग करने SELECTसे आपका डेटाबेस धीमा हो सकता है।


पहला: धन्यवाद! सबसे अच्छा गाइड कभी !, दूसरा: उन लोगों के लिए जो क्वेरी के अधिक उन्नत उपयोग की तलाश कर रहे हैं (), देखें_हैंडलर_फिल्टर_न्यूमेरिक.इन
hkoosha

इसके अलावा, एक और अधिक सुरुचिपूर्ण उपयोग है जहां आपको क्वेरी और प्रतिस्थापन को मैन्युअल रूप से लिखना नहीं है, जैसे $this->query->add_where($this->options['group'], $real_field_name, $this->value['value'], $this->operator);:। यह उपरोक्त लिंक में पाया जा सकता है।
हकोशा

2
यह मेरे लिए Drupal 7 पर काम करता है। हालाँकि, इस काम को करने के लिए मुझे 1) हुक_व्यूज़_हैंडलर फ़ंक्शन के कार्यान्वयन को हटाना और 2) .info फ़ाइल में इसे जोड़ें: फ़ाइलें [] = inc / modulename_handler_filter_filtername.inc 3) मैंने इस दो बदलावों को आधारित किया है। पर इस पोस्ट 4) बहुत धन्यवाद!
रोजर

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.