mirror of
				https://gitlab.com/Chill-Projet/chill-bundles.git
				synced 2025-10-24 22:23:13 +00:00 
			
		
		
		
	Add unaccent function
map the extension unaccent from postgresql
This commit is contained in:
		| @@ -60,5 +60,16 @@ class ChillMainExtension extends Extension implements PrependExtensionInterface | ||||
|                 'resources' => array('ChillMainBundle:Form:fields.html.twig')) | ||||
|         ); | ||||
|         $container->prependExtensionConfig('twig', $twigConfig); | ||||
|          | ||||
|         //add DQL function to ORM (default entity_manager) | ||||
|         $container->prependExtensionConfig('doctrine', array( | ||||
|            'orm' => array( | ||||
|               'dql' => array( | ||||
|                  'string_functions' => array( | ||||
|                     'unaccent' => 'Chill\MainBundle\Doctrine\DQL\Unaccent' | ||||
|                  ) | ||||
|               ) | ||||
|            ) | ||||
|         )); | ||||
|     } | ||||
| } | ||||
|   | ||||
							
								
								
									
										53
									
								
								Doctrine/DQL/Unaccent.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								Doctrine/DQL/Unaccent.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,53 @@ | ||||
| <?php | ||||
|  | ||||
| /* | ||||
|  * Chill is a software for social workers | ||||
|  * Copyright (C) 2015 Julien Fastré <julien.fastre@champs-libres.coop> | ||||
|  * | ||||
|  * This program is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU Affero General Public License as published by | ||||
|  * the Free Software Foundation, either version 3 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  * | ||||
|  * This program is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  * GNU Affero General Public License for more details. | ||||
|  * | ||||
|  * You should have received a copy of the GNU Affero General Public License | ||||
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
|  */ | ||||
|  | ||||
| namespace Chill\MainBundle\Doctrine\DQL; | ||||
|  | ||||
| use Doctrine\ORM\Query\AST\Functions\FunctionNode; | ||||
| use Doctrine\ORM\Query\Lexer; | ||||
|  | ||||
| /** | ||||
|  * Unaccent string using postgresql extension unaccent :  | ||||
|  * http://www.postgresql.org/docs/current/static/unaccent.html | ||||
|  *  | ||||
|  * Usage : StringFunction UNACCENT(string) | ||||
|  * | ||||
|  * @author Julien Fastré <julien.fastre@champs-libres.coop> | ||||
|  */ | ||||
| class Unaccent extends FunctionNode | ||||
| { | ||||
|     private $string; | ||||
|      | ||||
|     public function getSql(\Doctrine\ORM\Query\SqlWalker $sqlWalker) | ||||
|     { | ||||
|         return 'UNACCENT(' . $this->string->dispatch($sqlWalker) .")"; | ||||
|     } | ||||
|  | ||||
|     public function parse(\Doctrine\ORM\Query\Parser $parser) | ||||
|     { | ||||
|         $parser->match(Lexer::T_IDENTIFIER); | ||||
|         $parser->match(Lexer::T_OPEN_PARENTHESIS); | ||||
|          | ||||
|         $this->string = $parser->StringPrimary(); | ||||
|          | ||||
|         $parser->match(Lexer::T_CLOSE_PARENTHESIS); | ||||
|     } | ||||
|  | ||||
| } | ||||
		Reference in New Issue
	
	Block a user