@@ -92,26 +92,26 @@ discard block |
||
| 92 | 92 | //Need to check capitalisation of terms suggested that are different |
| 93 | 93 | |
| 94 | 94 | $chr = mb_substr ($possiblyUppercase, 0, 1, "UTF-8"); |
| 95 | - if (mb_strtolower($chr, "UTF-8") != $chr) { |
|
| 96 | - $upperLowercaseWord = $lowercaseWord; |
|
| 97 | - $upperLowercaseWord[0] = $chr; |
|
| 95 | + if (mb_strtolower($chr, "UTF-8") != $chr) { |
|
| 96 | + $upperLowercaseWord = $lowercaseWord; |
|
| 97 | + $upperLowercaseWord[0] = $chr; |
|
| 98 | 98 | |
| 99 | - //$possiblyUppercaseHighlighted = str_replace($lowercaseWord, $possiblyUppercase, $possiblyUppercaseHighlighted); |
|
| 100 | - $withHighlights = str_replace($lowercaseWord, $upperLowercaseWord, $possiblyUppercaseHighlighted); |
|
| 99 | + //$possiblyUppercaseHighlighted = str_replace($lowercaseWord, $possiblyUppercase, $possiblyUppercaseHighlighted); |
|
| 100 | + $withHighlights = str_replace($lowercaseWord, $upperLowercaseWord, $possiblyUppercaseHighlighted); |
|
| 101 | 101 | |
| 102 | - $lowercaseWord[0] = $chr; |
|
| 102 | + $lowercaseWord[0] = $chr; |
|
| 103 | 103 | |
| 104 | - //str_replace(search, replace, subject) |
|
| 104 | + //str_replace(search, replace, subject) |
|
| 105 | 105 | |
| 106 | - array_push($plain, $lowercaseWord); |
|
| 107 | - array_push($highlighted, $withHighlights); |
|
| 108 | - } else { |
|
| 109 | - //No need to capitalise, so add suggested word |
|
| 110 | - array_push($plain, $lowercaseWord); |
|
| 106 | + array_push($plain, $lowercaseWord); |
|
| 107 | + array_push($highlighted, $withHighlights); |
|
| 108 | + } else { |
|
| 109 | + //No need to capitalise, so add suggested word |
|
| 110 | + array_push($plain, $lowercaseWord); |
|
| 111 | 111 | |
| 112 | - //No need to capitalise, so add suggested highlighted word |
|
| 113 | - array_push($highlighted, $possiblyUppercaseHighlighted); |
|
| 114 | - } |
|
| 112 | + //No need to capitalise, so add suggested highlighted word |
|
| 113 | + array_push($highlighted, $possiblyUppercaseHighlighted); |
|
| 114 | + } |
|
| 115 | 115 | } |
| 116 | 116 | } |
| 117 | 117 | |
@@ -144,37 +144,37 @@ discard block |
||
| 144 | 144 | |
| 145 | 145 | $explanation = explode('-ConstantScore', $explanation)[0]; |
| 146 | 146 | |
| 147 | - $bracketPos = strpos($explanation, ')~'); |
|
| 147 | + $bracketPos = strpos($explanation, ')~'); |
|
| 148 | 148 | |
| 149 | - if (substr($explanation, 0,2) == '((') { |
|
| 150 | - $explanation = substr($explanation, 2, $bracketPos-2); |
|
| 151 | - } elseif (substr($explanation, 0,1) == '(') { |
|
| 152 | - $explanation = substr($explanation, 1, $bracketPos-2); |
|
| 153 | - } |
|
| 149 | + if (substr($explanation, 0,2) == '((') { |
|
| 150 | + $explanation = substr($explanation, 2, $bracketPos-2); |
|
| 151 | + } elseif (substr($explanation, 0,1) == '(') { |
|
| 152 | + $explanation = substr($explanation, 1, $bracketPos-2); |
|
| 153 | + } |
|
| 154 | 154 | |
| 155 | - $terms = array(); |
|
| 155 | + $terms = array(); |
|
| 156 | 156 | |
| 157 | - //Field name(s) => terms |
|
| 158 | - $splits = explode(' ', $explanation); |
|
| 157 | + //Field name(s) => terms |
|
| 158 | + $splits = explode(' ', $explanation); |
|
| 159 | 159 | |
| 160 | - foreach ($splits as $fieldAndTerm) { |
|
| 161 | - $splits = explode(':', $fieldAndTerm); |
|
| 160 | + foreach ($splits as $fieldAndTerm) { |
|
| 161 | + $splits = explode(':', $fieldAndTerm); |
|
| 162 | 162 | |
| 163 | - // This is the no terms case |
|
| 164 | - if (sizeof($splits) < 2) { |
|
| 165 | - break; |
|
| 166 | - } |
|
| 163 | + // This is the no terms case |
|
| 164 | + if (sizeof($splits) < 2) { |
|
| 165 | + break; |
|
| 166 | + } |
|
| 167 | 167 | |
| 168 | - $fieldname = $splits[0]; |
|
| 169 | - $term = $splits[1]; |
|
| 168 | + $fieldname = $splits[0]; |
|
| 169 | + $term = $splits[1]; |
|
| 170 | 170 | |
| 171 | - if (!isset($terms[$fieldname])) { |
|
| 172 | - $terms[$fieldname] = array(); |
|
| 173 | - } |
|
| 171 | + if (!isset($terms[$fieldname])) { |
|
| 172 | + $terms[$fieldname] = array(); |
|
| 173 | + } |
|
| 174 | 174 | |
| 175 | - array_push($terms[$fieldname], $term); |
|
| 176 | - } |
|
| 175 | + array_push($terms[$fieldname], $term); |
|
| 176 | + } |
|
| 177 | 177 | |
| 178 | - return $terms; |
|
| 178 | + return $terms; |
|
| 179 | 179 | } |
| 180 | 180 | } |
@@ -196,7 +196,7 @@ discard block |
||
| 196 | 196 | } |
| 197 | 197 | |
| 198 | 198 | /** |
| 199 | - * @return function print content to either web browser or command line. Can be optionally supressed |
|
| 199 | + * @return \Closure print content to either web browser or command line. Can be optionally supressed |
|
| 200 | 200 | */ |
| 201 | 201 | public static function getPrinter() { |
| 202 | 202 | return function ($content) { |
@@ -211,6 +211,7 @@ discard block |
||
| 211 | 211 | * Set to true to show output on the command line or browser, false to not |
| 212 | 212 | * |
| 213 | 213 | * @param $newcli_printer_output true to show output, false to hide it |
| 214 | + * @param boolean $new_cli_printer_output |
|
| 214 | 215 | */ |
| 215 | 216 | public static function setPrinterOutput($new_cli_printer_output) { |
| 216 | 217 | self::$cli_printer_output = $new_cli_printer_output; |
@@ -28,7 +28,7 @@ discard block |
||
| 28 | 28 | * @var string $content Text to display when in command line mode |
| 29 | 29 | */ |
| 30 | 30 | public static function message($content) { |
| 31 | - if (\Director::is_cli() && self::$cli_printer_output == true) { |
|
| 31 | + if(\Director::is_cli() && self::$cli_printer_output == true) { |
|
| 32 | 32 | echo "$content\n"; |
| 33 | 33 | } |
| 34 | 34 | } |
@@ -53,7 +53,7 @@ discard block |
||
| 53 | 53 | $options = $alternativeQuerySuggestions[0]['options']; |
| 54 | 54 | |
| 55 | 55 | $resultArray = null; |
| 56 | - if (sizeof($options) > 0) { |
|
| 56 | + if(sizeof($options) > 0) { |
|
| 57 | 57 | //take the first suggestion |
| 58 | 58 | $suggestedPhrase = $options[0]['text']; |
| 59 | 59 | $suggestedPhraseHighlighted = $options[0]['highlighted']; |
@@ -62,10 +62,10 @@ discard block |
||
| 62 | 62 | $originalParts = explode(' ', $originalQuery); |
| 63 | 63 | $suggestedParts = explode(' ', $suggestedPhrase); |
| 64 | 64 | |
| 65 | - $markedHighlightedParts = ' '.$suggestedPhraseHighlighted.' '; |
|
| 66 | - $markedHighlightedParts = str_replace(' '.$preTags, ' '.self::$pre_marker, $markedHighlightedParts); |
|
| 65 | + $markedHighlightedParts = ' ' . $suggestedPhraseHighlighted . ' '; |
|
| 66 | + $markedHighlightedParts = str_replace(' ' . $preTags, ' ' . self::$pre_marker, $markedHighlightedParts); |
|
| 67 | 67 | |
| 68 | - $markedHighlightedParts = str_replace($postTags.' ', self::$post_marker, $markedHighlightedParts); |
|
| 68 | + $markedHighlightedParts = str_replace($postTags . ' ', self::$post_marker, $markedHighlightedParts); |
|
| 69 | 69 | |
| 70 | 70 | $markedHighlightedParts = trim($markedHighlightedParts); |
| 71 | 71 | $markedHighlightedParts = trim($markedHighlightedParts); |
@@ -76,7 +76,7 @@ discard block |
||
| 76 | 76 | $lowerToUpper = array(); |
| 77 | 77 | $lowerToHighlighted = array(); |
| 78 | 78 | $ctr = 0; |
| 79 | - foreach ($suggestedParts as $lowercaseWord) { |
|
| 79 | + foreach($suggestedParts as $lowercaseWord) { |
|
| 80 | 80 | $lowerToUpper[$lowercaseWord] = $originalParts[$ctr]; |
| 81 | 81 | $lowerToHighlighted[$lowercaseWord] = $highlightedParts[$ctr]; |
| 82 | 82 | $ctr++; |
@@ -84,19 +84,19 @@ discard block |
||
| 84 | 84 | |
| 85 | 85 | $plain = array(); |
| 86 | 86 | $highlighted = array(); |
| 87 | - foreach ($suggestedParts as $lowercaseWord) { |
|
| 87 | + foreach($suggestedParts as $lowercaseWord) { |
|
| 88 | 88 | $possiblyUppercase = $lowerToUpper[$lowercaseWord]; |
| 89 | 89 | $possiblyUppercaseHighlighted = $lowerToHighlighted[$lowercaseWord]; |
| 90 | 90 | |
| 91 | 91 | //If the terms are identical other than case, e.g. new => New, then simply swap |
| 92 | - if (strtolower($possiblyUppercase) == $lowercaseWord) { |
|
| 92 | + if(strtolower($possiblyUppercase) == $lowercaseWord) { |
|
| 93 | 93 | array_push($plain, $possiblyUppercase); |
| 94 | 94 | array_push($highlighted, $possiblyUppercase); |
| 95 | 95 | } else { |
| 96 | 96 | //Need to check capitalisation of terms suggested that are different |
| 97 | 97 | |
| 98 | - $chr = mb_substr ($possiblyUppercase, 0, 1, "UTF-8"); |
|
| 99 | - if (mb_strtolower($chr, "UTF-8") != $chr) { |
|
| 98 | + $chr = mb_substr($possiblyUppercase, 0, 1, "UTF-8"); |
|
| 99 | + if(mb_strtolower($chr, "UTF-8") != $chr) { |
|
| 100 | 100 | $upperLowercaseWord = $lowercaseWord; |
| 101 | 101 | $upperLowercaseWord[0] = $chr; |
| 102 | 102 | |
@@ -119,9 +119,9 @@ discard block |
||
| 119 | 119 | } |
| 120 | 120 | } |
| 121 | 121 | |
| 122 | - $highlighted = ' '.implode(' ', $highlighted).' '; |
|
| 123 | - $highlighted = str_replace(self::$pre_marker, ' '.$preTags, $highlighted); |
|
| 124 | - $highlighted = str_replace(self::$post_marker, $postTags.' ', $highlighted); |
|
| 122 | + $highlighted = ' ' . implode(' ', $highlighted) . ' '; |
|
| 123 | + $highlighted = str_replace(self::$pre_marker, ' ' . $preTags, $highlighted); |
|
| 124 | + $highlighted = str_replace(self::$post_marker, $postTags . ' ', $highlighted); |
|
| 125 | 125 | |
| 126 | 126 | $resultArray['suggestedQuery'] = implode(' ', $plain); |
| 127 | 127 | $resultArray['suggestedQueryHighlighted'] = trim($highlighted); |
@@ -150,10 +150,10 @@ discard block |
||
| 150 | 150 | |
| 151 | 151 | $bracketPos = strpos($explanation, ')~'); |
| 152 | 152 | |
| 153 | - if (substr($explanation, 0,2) == '((') { |
|
| 154 | - $explanation = substr($explanation, 2, $bracketPos-2); |
|
| 155 | - } elseif (substr($explanation, 0,1) == '(') { |
|
| 156 | - $explanation = substr($explanation, 1, $bracketPos-2); |
|
| 153 | + if(substr($explanation, 0, 2) == '((') { |
|
| 154 | + $explanation = substr($explanation, 2, $bracketPos - 2); |
|
| 155 | + } elseif(substr($explanation, 0, 1) == '(') { |
|
| 156 | + $explanation = substr($explanation, 1, $bracketPos - 2); |
|
| 157 | 157 | } |
| 158 | 158 | |
| 159 | 159 | $terms = array(); |
@@ -161,18 +161,18 @@ discard block |
||
| 161 | 161 | //Field name(s) => terms |
| 162 | 162 | $splits = explode(' ', $explanation); |
| 163 | 163 | |
| 164 | - foreach ($splits as $fieldAndTerm) { |
|
| 164 | + foreach($splits as $fieldAndTerm) { |
|
| 165 | 165 | $splits = explode(':', $fieldAndTerm); |
| 166 | 166 | |
| 167 | 167 | // This is the no terms case |
| 168 | - if (sizeof($splits) < 2) { |
|
| 168 | + if(sizeof($splits) < 2) { |
|
| 169 | 169 | break; |
| 170 | 170 | } |
| 171 | 171 | |
| 172 | 172 | $fieldname = $splits[0]; |
| 173 | 173 | $term = $splits[1]; |
| 174 | 174 | |
| 175 | - if (!isset($terms[$fieldname])) { |
|
| 175 | + if(!isset($terms[$fieldname])) { |
|
| 176 | 176 | $terms[$fieldname] = array(); |
| 177 | 177 | } |
| 178 | 178 | |
@@ -199,8 +199,8 @@ discard block |
||
| 199 | 199 | * @return function print content to either web browser or command line. Can be optionally supressed |
| 200 | 200 | */ |
| 201 | 201 | public static function getPrinter() { |
| 202 | - return function ($content) { |
|
| 203 | - if (self::$cli_printer_output == true) { |
|
| 202 | + return function($content) { |
|
| 203 | + if(self::$cli_printer_output == true) { |
|
| 204 | 204 | print(\Director::is_cli() ? "T1 $content\n" : "T2 <p>$content</p>"); |
| 205 | 205 | } |
| 206 | 206 | |
@@ -31,13 +31,13 @@ |
||
| 31 | 31 | public function testRequireDefaultRecords() { |
| 32 | 32 | $this->AutoCompleteOption->requireDefaultRecords(); |
| 33 | 33 | |
| 34 | - $similar = AutoCompleteOption::get()->filter('Name','Similar')->first(); |
|
| 34 | + $similar = AutoCompleteOption::get()->filter('Name', 'Similar')->first(); |
|
| 35 | 35 | $this->assertEquals(1, $similar->ID); |
| 36 | 36 | |
| 37 | - $search = AutoCompleteOption::get()->filter('Name','Search')->first(); |
|
| 37 | + $search = AutoCompleteOption::get()->filter('Name', 'Search')->first(); |
|
| 38 | 38 | $this->assertEquals(2, $search->ID); |
| 39 | 39 | |
| 40 | - $goto = AutoCompleteOption::get()->filter('Name','GoToRecord')->first(); |
|
| 40 | + $goto = AutoCompleteOption::get()->filter('Name', 'GoToRecord')->first(); |
|
| 41 | 41 | $this->assertEquals(3, $goto->ID); |
| 42 | 42 | |
| 43 | 43 | } |
@@ -14,7 +14,7 @@ |
||
| 14 | 14 | |
| 15 | 15 | $fields = $sc->getCMSFields(); |
| 16 | 16 | |
| 17 | - $tab = $this->checkTabExists($fields,'Main'); |
|
| 17 | + $tab = $this->checkTabExists($fields, 'Main'); |
|
| 18 | 18 | |
| 19 | 19 | //Check fields |
| 20 | 20 | $nf = $this->checkFieldExists($tab, 'Name'); |
@@ -9,7 +9,7 @@ |
||
| 9 | 9 | public function setUp() { |
| 10 | 10 | // this needs to be called in order to create the list of searchable |
| 11 | 11 | // classes and fields that are available. Simulates part of a build |
| 12 | - $classes = array('SearchableTestPage','SiteTree','Page','FlickrPhotoTO','FlickrSetTO', |
|
| 12 | + $classes = array('SearchableTestPage', 'SiteTree', 'Page', 'FlickrPhotoTO', 'FlickrSetTO', |
|
| 13 | 13 | 'FlickrTagTO', 'FlickrAuthorTO', 'FlickrSetTO'); |
| 14 | 14 | $this->requireDefaultRecordsFrom = $classes; |
| 15 | 15 | |
@@ -139,37 +139,37 @@ discard block |
||
| 139 | 139 | * Add a mapping for the location of the photograph |
| 140 | 140 | */ |
| 141 | 141 | public function updateElasticsearchMapping(\Elastica\Type\Mapping $mapping) |
| 142 | - { |
|
| 143 | - // get the properties of the individual fields as an array |
|
| 144 | - $properties = $mapping->getProperties(); |
|
| 145 | - |
|
| 146 | - // add a location with geo point |
|
| 147 | - $precision1cm = array('format' => 'compressed', 'precision' => '1cm'); |
|
| 148 | - $properties['location'] = array( |
|
| 149 | - 'type' => 'geo_point', |
|
| 150 | - 'fielddata' => $precision1cm, |
|
| 151 | - ); |
|
| 152 | - |
|
| 153 | - $properties['ShutterSpeed'] = array( |
|
| 154 | - 'type' => 'string', |
|
| 155 | - 'index' => 'not_analyzed' |
|
| 142 | + { |
|
| 143 | + // get the properties of the individual fields as an array |
|
| 144 | + $properties = $mapping->getProperties(); |
|
| 145 | + |
|
| 146 | + // add a location with geo point |
|
| 147 | + $precision1cm = array('format' => 'compressed', 'precision' => '1cm'); |
|
| 148 | + $properties['location'] = array( |
|
| 149 | + 'type' => 'geo_point', |
|
| 150 | + 'fielddata' => $precision1cm, |
|
| 156 | 151 | ); |
| 157 | 152 | |
| 158 | - $properties['Aperture'] = array( |
|
| 159 | - // do not use float as the rounding makes facets impossible |
|
| 160 | - 'type' => 'double' |
|
| 161 | - ); |
|
| 153 | + $properties['ShutterSpeed'] = array( |
|
| 154 | + 'type' => 'string', |
|
| 155 | + 'index' => 'not_analyzed' |
|
| 156 | + ); |
|
| 162 | 157 | |
| 163 | - $properties['FlickrID'] = array('type' => 'integer'); |
|
| 158 | + $properties['Aperture'] = array( |
|
| 159 | + // do not use float as the rounding makes facets impossible |
|
| 160 | + 'type' => 'double' |
|
| 161 | + ); |
|
| 164 | 162 | |
| 165 | - // by default casted as a string, we want a date 2015-07-25 18:15:33 y-M-d H:m:s |
|
| 166 | - //$properties['TakenAt'] = array('type' => 'date', 'format' => 'y-M-d H:m:s'); |
|
| 163 | + $properties['FlickrID'] = array('type' => 'integer'); |
|
| 167 | 164 | |
| 168 | - // set the new properties on the mapping |
|
| 169 | - $mapping->setProperties($properties); |
|
| 165 | + // by default casted as a string, we want a date 2015-07-25 18:15:33 y-M-d H:m:s |
|
| 166 | + //$properties['TakenAt'] = array('type' => 'date', 'format' => 'y-M-d H:m:s'); |
|
| 170 | 167 | |
| 171 | - return $mapping; |
|
| 172 | - } |
|
| 168 | + // set the new properties on the mapping |
|
| 169 | + $mapping->setProperties($properties); |
|
| 170 | + |
|
| 171 | + return $mapping; |
|
| 172 | + } |
|
| 173 | 173 | |
| 174 | 174 | |
| 175 | 175 | /** |
@@ -205,7 +205,7 @@ discard block |
||
| 205 | 205 | } |
| 206 | 206 | $sortable = $sortable . '|' . $this->owner->ShutterSpeed; |
| 207 | 207 | $document->set('ShutterSpeed', $sortable); |
| 208 | - return $document; |
|
| 208 | + return $document; |
|
| 209 | 209 | } |
| 210 | 210 | |
| 211 | 211 | |
@@ -6,8 +6,8 @@ discard block |
||
| 6 | 6 | * @subpackage tests |
| 7 | 7 | */ |
| 8 | 8 | class FlickrPhotoTO extends DataObject implements TestOnly { |
| 9 | - private static $searchable_fields = array('Title','FlickrID','Description','TakenAt', 'TakenAtDT', 'FirstViewed', |
|
| 10 | - 'Aperture','ShutterSpeed','FocalLength35mm','ISO','AspectRatio', 'TestMethod', 'TestMethodHTML'); |
|
| 9 | + private static $searchable_fields = array('Title', 'FlickrID', 'Description', 'TakenAt', 'TakenAtDT', 'FirstViewed', |
|
| 10 | + 'Aperture', 'ShutterSpeed', 'FocalLength35mm', 'ISO', 'AspectRatio', 'TestMethod', 'TestMethodHTML'); |
|
| 11 | 11 | |
| 12 | 12 | private static $searchable_relationships = array('Photographer', 'FlickrTagTOs', 'FlickrSetTOs'); |
| 13 | 13 | |
@@ -88,7 +88,7 @@ discard block |
||
| 88 | 88 | * @subpackage tests |
| 89 | 89 | */ |
| 90 | 90 | class FlickrSetTO extends DataObject implements TestOnly { |
| 91 | - private static $searchable_fields = array('Title','FlickrID','Description'); |
|
| 91 | + private static $searchable_fields = array('Title', 'FlickrID', 'Description'); |
|
| 92 | 92 | |
| 93 | 93 | private static $db = array( |
| 94 | 94 | 'Title' => 'Varchar(255)', |
@@ -133,7 +133,7 @@ discard block |
||
| 133 | 133 | |
| 134 | 134 | |
| 135 | 135 | |
| 136 | -class FlickrPhotoTOTestIndexingExtension extends Extension implements ElasticaIndexingHelperInterface,TestOnly { |
|
| 136 | +class FlickrPhotoTOTestIndexingExtension extends Extension implements ElasticaIndexingHelperInterface, TestOnly { |
|
| 137 | 137 | |
| 138 | 138 | /** |
| 139 | 139 | * Add a mapping for the location of the photograph |
@@ -145,7 +145,7 @@ discard block |
||
| 145 | 145 | |
| 146 | 146 | // add a location with geo point |
| 147 | 147 | $precision1cm = array('format' => 'compressed', 'precision' => '1cm'); |
| 148 | - $properties['location'] = array( |
|
| 148 | + $properties['location'] = array( |
|
| 149 | 149 | 'type' => 'geo_point', |
| 150 | 150 | 'fielddata' => $precision1cm, |
| 151 | 151 | ); |
@@ -181,27 +181,27 @@ discard block |
||
| 181 | 181 | { |
| 182 | 182 | // self::$ctr++; |
| 183 | 183 | |
| 184 | - if ($this->owner->Lat != null && $this->owner->Lon != null) { |
|
| 184 | + if($this->owner->Lat != null && $this->owner->Lon != null) { |
|
| 185 | 185 | $coors = array('lat' => $this->owner->Lat, 'lon' => $this->owner->Lon); |
| 186 | - $document->set('location',$coors); |
|
| 186 | + $document->set('location', $coors); |
|
| 187 | 187 | } |
| 188 | 188 | |
| 189 | 189 | $sortable = $this->owner->ShutterSpeed; |
| 190 | 190 | $sortable = explode('/', $sortable); |
| 191 | - if (sizeof($sortable) == 1) { |
|
| 191 | + if(sizeof($sortable) == 1) { |
|
| 192 | 192 | $sortable = trim($sortable[0]); |
| 193 | 193 | |
| 194 | - if ($this->owner->ShutterSpeed == null) { |
|
| 194 | + if($this->owner->ShutterSpeed == null) { |
|
| 195 | 195 | $sortable = null; |
| 196 | 196 | } |
| 197 | 197 | |
| 198 | - if ($sortable == 1) { |
|
| 198 | + if($sortable == 1) { |
|
| 199 | 199 | $sortable = '1.000000'; |
| 200 | 200 | } |
| 201 | 201 | |
| 202 | - } else if (sizeof($sortable) == 2) { |
|
| 203 | - $sortable = floatval($sortable[0])/intval($sortable[1]); |
|
| 204 | - $sortable = round($sortable,6); |
|
| 202 | + } else if(sizeof($sortable) == 2) { |
|
| 203 | + $sortable = floatval($sortable[0]) / intval($sortable[1]); |
|
| 204 | + $sortable = round($sortable, 6); |
|
| 205 | 205 | } |
| 206 | 206 | $sortable = $sortable . '|' . $this->owner->ShutterSpeed; |
| 207 | 207 | $document->set('ShutterSpeed', $sortable); |
@@ -5,7 +5,7 @@ |
||
| 5 | 5 | * @subpackage tests |
| 6 | 6 | */ |
| 7 | 7 | class SearchableTestPage extends Page implements TestOnly { |
| 8 | - private static $searchable_fields = array('Country','PageDate'); |
|
| 8 | + private static $searchable_fields = array('Country', 'PageDate'); |
|
| 9 | 9 | |
| 10 | 10 | private static $db = array( |
| 11 | 11 | 'Country' => 'Varchar', |
@@ -10,11 +10,11 @@ discard block |
||
| 10 | 10 | |
| 11 | 11 | public function __construct() { |
| 12 | 12 | $aspectAgg = new RangedAggregation('Aspect', 'AspectRatio'); |
| 13 | - $aspectAgg->addRange(0.0000001, 0.3, 'Panoramic'); |
|
| 14 | - $aspectAgg->addRange(0.3, 0.9, 'Horizontal'); |
|
| 15 | - $aspectAgg->addRange(0.9, 1.2, 'Square'); |
|
| 16 | - $aspectAgg->addRange(1.2, 1.79, 'Vertical'); |
|
| 17 | - $aspectAgg->addRange(1.79, 1e7, 'Tallest'); |
|
| 13 | + $aspectAgg->addRange(0.0000001, 0.3, 'Panoramic'); |
|
| 14 | + $aspectAgg->addRange(0.3, 0.9, 'Horizontal'); |
|
| 15 | + $aspectAgg->addRange(0.9, 1.2, 'Square'); |
|
| 16 | + $aspectAgg->addRange(1.2, 1.79, 'Vertical'); |
|
| 17 | + $aspectAgg->addRange(1.79, 1e7, 'Tallest'); |
|
| 18 | 18 | } |
| 19 | 19 | |
| 20 | 20 | private static $titleFieldMapping = array( |
@@ -73,7 +73,7 @@ discard block |
||
| 73 | 73 | |
| 74 | 74 | |
| 75 | 75 | $aspectRangedAgg = RangedAggregation::getByTitle('Aspect'); |
| 76 | - $query->addAggregation($aspectRangedAgg->getRangeAgg()); |
|
| 76 | + $query->addAggregation($aspectRangedAgg->getRangeAgg()); |
|
| 77 | 77 | |
| 78 | 78 | // leave this out for the moment as way too many terms being returned slowing things down |
| 79 | 79 | /* |
@@ -6,7 +6,7 @@ discard block |
||
| 6 | 6 | use SilverStripe\Elastica\RangedAggregation; |
| 7 | 7 | |
| 8 | 8 | |
| 9 | -class FlickrPhotoTOElasticaSearchHelper implements ElasticaSearchHelperInterface,TestOnly { |
|
| 9 | +class FlickrPhotoTOElasticaSearchHelper implements ElasticaSearchHelperInterface, TestOnly { |
|
| 10 | 10 | |
| 11 | 11 | public function __construct() { |
| 12 | 12 | $aspectAgg = new RangedAggregation('Aspect', 'AspectRatio'); |
@@ -36,7 +36,7 @@ discard block |
||
| 36 | 36 | 'query_string' => array('query' => '*') |
| 37 | 37 | ); |
| 38 | 38 | |
| 39 | - if ($query->OriginalQueryText == '') { |
|
| 39 | + if($query->OriginalQueryText == '') { |
|
| 40 | 40 | $query->setSort(array('TakenAt'=> 'desc')); |
| 41 | 41 | } |
| 42 | 42 | |
@@ -104,27 +104,27 @@ discard block |
||
| 104 | 104 | // shutter speed is stored as decimal to 6 decimal places, then a |
| 105 | 105 | // vertical bar followed by the displayed speed as a fraction or a |
| 106 | 106 | // whole number. This puts the decimal back for matching purposes |
| 107 | - if (isset($filters['ShutterSpeed'])) { |
|
| 107 | + if(isset($filters['ShutterSpeed'])) { |
|
| 108 | 108 | |
| 109 | 109 | $sortable = $filters['ShutterSpeed']; |
| 110 | 110 | |
| 111 | 111 | echo "SORTABLE:$sortable\n"; |
| 112 | 112 | |
| 113 | 113 | $sortable = explode('/', $sortable); |
| 114 | - if (sizeof($sortable) == 1) { |
|
| 114 | + if(sizeof($sortable) == 1) { |
|
| 115 | 115 | $sortable = trim($sortable[0]); |
| 116 | 116 | |
| 117 | - if ($sortable === '1') { |
|
| 117 | + if($sortable === '1') { |
|
| 118 | 118 | $sortable = '1.000000|1'; |
| 119 | 119 | } |
| 120 | 120 | |
| 121 | - } else if (sizeof($sortable) == 2) { |
|
| 122 | - if ($sortable[0] === '' || $sortable[1] === '') { |
|
| 121 | + } else if(sizeof($sortable) == 2) { |
|
| 122 | + if($sortable[0] === '' || $sortable[1] === '') { |
|
| 123 | 123 | $sortable = ''; |
| 124 | 124 | |
| 125 | 125 | } else { |
| 126 | - $sortable = floatval($sortable[0])/intval($sortable[1]); |
|
| 127 | - $sortable = round($sortable,6); |
|
| 126 | + $sortable = floatval($sortable[0]) / intval($sortable[1]); |
|
| 127 | + $sortable = round($sortable, 6); |
|
| 128 | 128 | $sortable = $sortable . '|' . $filters['ShutterSpeed']; |
| 129 | 129 | } |
| 130 | 130 | |
@@ -147,7 +147,7 @@ discard block |
||
| 147 | 147 | // the shutter speeds are of the form decimal number | fraction, keep the latter half |
| 148 | 148 | $shutterSpeeds = $aggs['ShutterSpeed']['buckets']; |
| 149 | 149 | $ctr = 0; |
| 150 | - foreach ($shutterSpeeds as $bucket) { |
|
| 150 | + foreach($shutterSpeeds as $bucket) { |
|
| 151 | 151 | $key = $bucket['key']; |
| 152 | 152 | $splits = explode('|', $key); |
| 153 | 153 | $shutterSpeeds[$ctr]['key'] = end($splits); |
@@ -17,8 +17,8 @@ |
||
| 17 | 17 | sort($terms); |
| 18 | 18 | $expected = array('Description', 'Description.shingles', 'Description.standard', |
| 19 | 19 | 'ShutterSpeed', |
| 20 | - 'TestMethod','TestMethod.shingles','TestMethod.standard', |
|
| 21 | - 'TestMethodHTML','TestMethodHTML.shingles','TestMethodHTML.standard', |
|
| 20 | + 'TestMethod', 'TestMethod.shingles', 'TestMethod.standard', |
|
| 21 | + 'TestMethodHTML', 'TestMethodHTML.shingles', 'TestMethodHTML.standard', |
|
| 22 | 22 | 'Title', 'Title.autocomplete', 'Title.shingles', 'Title.standard'); |
| 23 | 23 | $this->assertEquals($expected, $terms); |
| 24 | 24 | |
@@ -122,7 +122,7 @@ discard block |
||
| 122 | 122 | |
| 123 | 123 | $qg->setShowResultsForEmptyQuery(false); |
| 124 | 124 | $qs = array('multi_match' => array( |
| 125 | - 'fields' => array('Title','Title.*','Description','Description.*'), |
|
| 125 | + 'fields' => array('Title', 'Title.*', 'Description', 'Description.*'), |
|
| 126 | 126 | 'type' => 'most_fields', |
| 127 | 127 | 'query' => 'New Zealand', |
| 128 | 128 | 'lenient' => true |
@@ -158,7 +158,7 @@ discard block |
||
| 158 | 158 | $qg->setShowResultsForEmptyQuery(false); |
| 159 | 159 | $qs = array( |
| 160 | 160 | 'multi_match' => array( |
| 161 | - 'fields' => array('Title','Title.*','Description','Description.*'), |
|
| 161 | + 'fields' => array('Title', 'Title.*', 'Description', 'Description.*'), |
|
| 162 | 162 | 'type' => 'most_fields', |
| 163 | 163 | 'query' => '', |
| 164 | 164 | 'lenient' => true |
@@ -369,8 +369,8 @@ discard block |
||
| 369 | 369 | 'filtered' => array( |
| 370 | 370 | 'filter' => |
| 371 | 371 | array('and' => array( |
| 372 | - 0 => array( 'term' => array('ISO' => 400)), |
|
| 373 | - 1 => array( 'range' => array( |
|
| 372 | + 0 => array('term' => array('ISO' => 400)), |
|
| 373 | + 1 => array('range' => array( |
|
| 374 | 374 | 'AspectRatio' => array( |
| 375 | 375 | 'gte' => '0.9', |
| 376 | 376 | 'lt' => '1.2' |
@@ -413,14 +413,14 @@ discard block |
||
| 413 | 413 | 'query' => array( |
| 414 | 414 | 'filtered' => array('filter' => |
| 415 | 415 | array('and' => array( |
| 416 | - 0 => array( 'term' => array('ISO' => 400)), |
|
| 417 | - 1 => array( 'range' => array( |
|
| 416 | + 0 => array('term' => array('ISO' => 400)), |
|
| 417 | + 1 => array('range' => array( |
|
| 418 | 418 | 'AspectRatio' => array( |
| 419 | 419 | 'gte' => '0.9', |
| 420 | 420 | 'lt' => '1.2' |
| 421 | 421 | ) |
| 422 | 422 | )), |
| 423 | - 2 => array( 'term' => array('Aperture' => 5.6)), |
|
| 423 | + 2 => array('term' => array('Aperture' => 5.6)), |
|
| 424 | 424 | ) |
| 425 | 425 | )) |
| 426 | 426 | ), |
@@ -472,7 +472,7 @@ discard block |
||
| 472 | 472 | $expected['query']['filtered']['query']['multi_match'] = array( |
| 473 | 473 | 'query' => 'New Zealand', |
| 474 | 474 | 'lenient' => true, |
| 475 | - 'fields' => array('Title^2', 'Title.*^2','Content', 'Content.*'), |
|
| 475 | + 'fields' => array('Title^2', 'Title.*^2', 'Content', 'Content.*'), |
|
| 476 | 476 | 'type' => 'most_fields' |
| 477 | 477 | ); |
| 478 | 478 | |
@@ -503,8 +503,8 @@ discard block |
||
| 503 | 503 | 'filtered' => array( |
| 504 | 504 | 'filter' => |
| 505 | 505 | array('and' => array( |
| 506 | - 0 => array( 'term' => array('ISO' => 400)), |
|
| 507 | - 1 => array( 'range' => array( |
|
| 506 | + 0 => array('term' => array('ISO' => 400)), |
|
| 507 | + 1 => array('range' => array( |
|
| 508 | 508 | 'AspectRatio' => array( |
| 509 | 509 | 'gte' => '0.9', |
| 510 | 510 | 'lt' => '1.2' |
@@ -525,7 +525,7 @@ discard block |
||
| 525 | 525 | $expected['query']['filtered']['query']['multi_match'] = array( |
| 526 | 526 | 'query' => 'New Zealand', |
| 527 | 527 | 'lenient' => true, |
| 528 | - 'fields' => array('Title^2', 'Title.*^2','Content', 'Content.*'), |
|
| 528 | + 'fields' => array('Title^2', 'Title.*^2', 'Content', 'Content.*'), |
|
| 529 | 529 | 'type' => 'most_fields' |
| 530 | 530 | ); |
| 531 | 531 | $expected['suggest'] = $this->getDefaultSuggest('New Zealand'); |
@@ -553,14 +553,14 @@ discard block |
||
| 553 | 553 | 'query' => array( |
| 554 | 554 | 'filtered' => array('filter' => |
| 555 | 555 | array('and' => array( |
| 556 | - 0 => array( 'term' => array('ISO' => 400)), |
|
| 557 | - 1 => array( 'range' => array( |
|
| 556 | + 0 => array('term' => array('ISO' => 400)), |
|
| 557 | + 1 => array('range' => array( |
|
| 558 | 558 | 'AspectRatio' => array( |
| 559 | 559 | 'gte' => '0.9', |
| 560 | 560 | 'lt' => '1.2' |
| 561 | 561 | ) |
| 562 | 562 | )), |
| 563 | - 2 => array( 'term' => array('Aperture' => 5.6)), |
|
| 563 | + 2 => array('term' => array('Aperture' => 5.6)), |
|
| 564 | 564 | ) |
| 565 | 565 | )) |
| 566 | 566 | ), |
@@ -575,7 +575,7 @@ discard block |
||
| 575 | 575 | $expected['query']['filtered']['query']['multi_match'] = array( |
| 576 | 576 | 'query' => 'New Zealand', |
| 577 | 577 | 'lenient' => true, |
| 578 | - 'fields' => array('Title^2', 'Title.*^2','Content', 'Content.*'), |
|
| 578 | + 'fields' => array('Title^2', 'Title.*^2', 'Content', 'Content.*'), |
|
| 579 | 579 | 'type' => 'most_fields' |
| 580 | 580 | ); |
| 581 | 581 | $expected['suggest'] = $this->getDefaultSuggest('New Zealand'); |
@@ -590,7 +590,7 @@ discard block |
||
| 590 | 590 | $qg = new QueryGenerator(); |
| 591 | 591 | $qg->setClasses('FlickrPhotoTO'); |
| 592 | 592 | $fields = array('Title' => 1, 'Description' => 1); |
| 593 | - $expected = array('Title', 'Title.*','Description', 'Description.*'); |
|
| 593 | + $expected = array('Title', 'Title.*', 'Description', 'Description.*'); |
|
| 594 | 594 | $this->assertEquals($expected, $qg->convertWeightedFieldsForElastica($fields)); |
| 595 | 595 | } |
| 596 | 596 | |
@@ -599,7 +599,7 @@ discard block |
||
| 599 | 599 | $qg = new QueryGenerator(); |
| 600 | 600 | $qg->setClasses('FlickrPhotoTO'); |
| 601 | 601 | $fields = array('Title' => 2, 'Description' => 1); |
| 602 | - $expected = array('Title^2', 'Title.*^2','Description', 'Description.*'); |
|
| 602 | + $expected = array('Title^2', 'Title.*^2', 'Description', 'Description.*'); |
|
| 603 | 603 | $this->assertEquals($expected, $qg->convertWeightedFieldsForElastica($fields)); |
| 604 | 604 | } |
| 605 | 605 | |
@@ -631,10 +631,10 @@ discard block |
||
| 631 | 631 | $qg = new QueryGenerator(); |
| 632 | 632 | $qg->setClasses('FlickrPhotoTO,Page'); |
| 633 | 633 | $fields = array('Title' => 2, 'Description' => 1); |
| 634 | - $expected = array('Title^2', 'Title.*^2','Description', 'Description.*'); |
|
| 634 | + $expected = array('Title^2', 'Title.*^2', 'Description', 'Description.*'); |
|
| 635 | 635 | $this->assertEquals($expected, $qg->convertWeightedFieldsForElastica($fields)); |
| 636 | 636 | |
| 637 | - $qg->setClasses(array('FlickrPhotoTO','Page')); |
|
| 637 | + $qg->setClasses(array('FlickrPhotoTO', 'Page')); |
|
| 638 | 638 | $this->assertEquals($expected, $qg->convertWeightedFieldsForElastica($fields)); |
| 639 | 639 | |
| 640 | 640 | } |
@@ -648,7 +648,7 @@ discard block |
||
| 648 | 648 | $qg = new QueryGenerator(); |
| 649 | 649 | $qg->setClasses('FlickrPhotoTO,Page'); |
| 650 | 650 | $fields = array('Title' => 2, 'Description' => 1); |
| 651 | - $expected = array('Title^2', 'Title.*^2','Description', 'Description.*'); |
|
| 651 | + $expected = array('Title^2', 'Title.*^2', 'Description', 'Description.*'); |
|
| 652 | 652 | $this->assertEquals($expected, $qg->convertWeightedFieldsForElastica($fields)); |
| 653 | 653 | |
| 654 | 654 | //Execute a 2nd time |
@@ -667,11 +667,11 @@ discard block |
||
| 667 | 667 | $qg = new QueryGenerator(); |
| 668 | 668 | $qg->setClasses(null); // select all of site tree classes |
| 669 | 669 | $fields = array('Title' => 2, 'Content' => 1); |
| 670 | - $expected = array('Title^2', 'Title.*^2','Content', 'Content.*'); |
|
| 670 | + $expected = array('Title^2', 'Title.*^2', 'Content', 'Content.*'); |
|
| 671 | 671 | $this->assertEquals($expected, $qg->convertWeightedFieldsForElastica($fields)); |
| 672 | 672 | |
| 673 | 673 | echo "--------------------\n"; |
| 674 | - $qg->setClasses(array('FlickrPhotoTO','Page')); |
|
| 674 | + $qg->setClasses(array('FlickrPhotoTO', 'Page')); |
|
| 675 | 675 | $this->assertEquals($expected, $qg->convertWeightedFieldsForElastica($fields)); |
| 676 | 676 | |
| 677 | 677 | } |
@@ -720,21 +720,21 @@ discard block |
||
| 720 | 720 | 'order' => array('_term' => 'asc') |
| 721 | 721 | ) |
| 722 | 722 | ); |
| 723 | - $result['ShutterSpeed'] = array( |
|
| 723 | + $result['ShutterSpeed'] = array( |
|
| 724 | 724 | 'terms' => array( |
| 725 | 725 | 'field' => 'ShutterSpeed', |
| 726 | 726 | 'size' => 0, |
| 727 | 727 | 'order' => array('_term' => 'asc') |
| 728 | 728 | ) |
| 729 | 729 | ); |
| 730 | - $result['FocalLength35mm'] = array( |
|
| 730 | + $result['FocalLength35mm'] = array( |
|
| 731 | 731 | 'terms' => array( |
| 732 | 732 | 'field' => 'FocalLength35mm', |
| 733 | 733 | 'size' => 0, |
| 734 | 734 | 'order' => array('_term' => 'asc') |
| 735 | 735 | ) |
| 736 | 736 | ); |
| 737 | - $result['ISO'] = array( |
|
| 737 | + $result['ISO'] = array( |
|
| 738 | 738 | 'terms' => array( |
| 739 | 739 | 'field' => 'ISO', |
| 740 | 740 | 'size' => 0, |
@@ -749,7 +749,7 @@ discard block |
||
| 749 | 749 | $ranges[3] = array('from' => '1.2', 'to' => '1.79', 'key' => 'Vertical'); |
| 750 | 750 | $ranges[4] = array('from' => '1.79', 'to' => '10000000', 'key' => 'Tallest'); |
| 751 | 751 | |
| 752 | - $result['Aspect'] = array( |
|
| 752 | + $result['Aspect'] = array( |
|
| 753 | 753 | 'range' => array( |
| 754 | 754 | 'field' => 'AspectRatio', |
| 755 | 755 | 'ranges' => $ranges |
@@ -769,7 +769,7 @@ discard block |
||
| 769 | 769 | |
| 770 | 770 | public function testToQuotedCSVFromArray() { |
| 771 | 771 | $expected = "'Bangkok','Nonthaburi','Saraburi','Chiang Mai'"; |
| 772 | - $items = array('Bangkok','Nonthaburi','Saraburi','Chiang Mai'); |
|
| 772 | + $items = array('Bangkok', 'Nonthaburi', 'Saraburi', 'Chiang Mai'); |
|
| 773 | 773 | $quoted = QueryGenerator::convertToQuotedCSV($items); |
| 774 | 774 | $this->assertEquals($expected, $quoted); |
| 775 | 775 | } |