private function searchConfigurationDynamic() { $search = new Manager($this); $c = $this->schema()->columns(); foreach ($c as $key => $value) { $t = $this->schema()->columnType($value); if ($t != 'string' and $t != 'text') { $search->value($value, ['field' => $this->aliasField($value)]); } else { $search->like($value, ['before' => true, 'after' => true, 'field' => $this->aliasField($value)]); } } $search->callback('barra', ['callback' => function ($query, $args, $manager) { return $query->join(['table' => 'produtos', 'alias' => 'kprodutosbarra', 'type' => 'INNER', 'conditions' => 'kprodutosbarra.id = ProdutosKits.kit_id AND kprodutosbarra.barra RLIKE "' . $args['barra'] . '" AND kprodutosbarra.produto_kit = 1']); }]); $search->callback('nome', ['callback' => function ($query, $args, $manager) { return $query->join(['table' => 'produtos', 'alias' => 'kprodutosnome', 'type' => 'INNER', 'conditions' => 'kprodutosnome.id = ProdutosKits.kit_id AND kprodutosnome.nome RLIKE "' . $args['nome'] . '" AND kprodutosnome.produto_kit = 1']); }]); return $search; }
private function searchConfigurationDynamic() { $search = new Manager($this); $c = $this->schema()->columns(); foreach ($c as $key => $value) { $t = $this->schema()->columnType($value); if ($t != 'string' and $t != 'text') { $search->value($value, ['field' => $this->aliasField($value)]); } else { $search->like($value, ['before' => true, 'after' => true, 'field' => $this->aliasField($value)]); } } $search->callback('associacao', ['callback' => function ($query, $args, $manager) { return $query->join(['table' => 'pessoas_associacoes', 'alias' => 'PessoasAssociacoesPesquisa', 'type' => 'INNER', 'conditions' => ['PessoasAssociacoesPesquisa.pessoa_id = Pessoas.id', 'PessoasAssociacoesPesquisa.tipo_associacao' => $args['associacao'], 'PessoasAssociacoesPesquisa.status !=' => 9]]); }]); return $search; }