source: sandbox/expresso-solr/expressoMail1_2/solrclient/library/Solarium/Result/Select/Facet/Range.php @ 7588

Revision 7588, 4.1 KB checked in by adir, 11 years ago (diff)

Ticket #000 - Adicionando a integracao de buscas com Solr na base a ser isnerida na comunidade

Line 
1<?php
2/**
3 * Copyright 2011 Bas de Nooijer. All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions are met:
7 *
8 * 1. Redistributions of source code must retain the above copyright notice,
9 *    this list of conditions and the following disclaimer.
10 *
11 * 2. Redistributions in binary form must reproduce the above copyright notice,
12 *    this listof conditions and the following disclaimer in the documentation
13 *    and/or other materials provided with the distribution.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDER AND CONTRIBUTORS "AS IS"
16 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
19 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
20 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
21 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
22 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
23 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
24 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
25 * POSSIBILITY OF SUCH DAMAGE.
26 *
27 * The views and conclusions contained in the software and documentation are
28 * those of the authors and should not be interpreted as representing official
29 * policies, either expressed or implied, of the copyright holder.
30 *
31 * @copyright Copyright 2011 Bas de Nooijer <solarium@raspberry.nl>
32 * @license http://github.com/basdenooijer/solarium/raw/master/COPYING
33 * @link http://www.solarium-project.org/
34 *
35 * @package Solarium
36 * @subpackage Result
37 */
38
39/**
40 * Select range facet result
41 *
42 * A multiquery facet will usually return a dataset of multiple count, in each
43 * row a range as key and it's count. You can access the values as an array using
44 * {@link getValues()} or iterate this object.
45 *
46 * The extra counts 'before', 'between' and 'after' are only available if the
47 * right settings for the option 'other' were used in the query.
48 *
49 * @package Solarium
50 * @subpackage Result
51 */
52class Solarium_Result_Select_Facet_Range extends Solarium_Result_Select_Facet_Field
53{
54
55    /**
56     * Count of all records with field values lower then lower bound of the first range
57     *
58     * @var int
59     */
60    protected $_before;
61
62    /**
63     * Count of all records with field values greater then the upper bound of the last range
64     *
65     * @var int
66     */
67    protected $_after;
68
69    /**
70     * Count all records with field values between the start and end bounds of all ranges
71     *
72     * @var int
73     */
74    protected $_between;
75
76    /**
77     * Constructor
78     *
79     * @param array $values
80     * @param int $before
81     * @param int $after
82     * @param int $between
83     * @return void
84     */
85    public function __construct($values, $before, $after, $between)
86    {
87        $this->_values = $values;
88        $this->_before = $before;
89        $this->_after = $after;
90        $this->_between = $between;
91    }
92
93    /**
94     * Get 'before' count
95     *
96     * Count of all records with field values lower then lower bound of the first range
97     * Only available if the 'other' setting was used in the query facet.
98     *
99     * @return int
100     */
101    public function getBefore()
102    {
103        return $this->_before;
104    }
105
106    /**
107     * Get 'after' count
108     *
109     * Count of all records with field values greater then the upper bound of the last range
110     * Only available if the 'other' setting was used in the query facet.
111     *
112     * @return int
113     */
114    public function getAfter()
115    {
116        return $this->_after;
117    }
118
119    /**
120     * Get 'between' count
121     *
122     * Count all records with field values between the start and end bounds of all ranges
123     * Only available if the 'other' setting was used in the query facet.
124     *
125     * @return int
126     */
127    public function getBetween()
128    {
129        return $this->_between;
130    }
131
132}
Note: See TracBrowser for help on using the repository browser.