terça-feira, 26 de novembro de 2013

Reporting Services - Matrix - Largura das Colunas Dinâmicas


Apesar da flexibilidade do componente Matrix, sempre nós, desenvolvedores - ou o usuário final - vamos solicitar algo que este ou algum componente não vai atender!!

Mas graças a criatividade humana (use com moderação :) ) podemos pelo menos chegar a um resultado satisfatório, pois já que não é possível configurar a largura de cada coluna que será criada, vamos adicionar um artifício para, hora mostrar ou não uma coluna adicional, criada ao lado da coluna na Matrix. Usei como "inspiração" a idéia registrada no blog do Leigh Waldie.

Então, vamos imaginar que a Matrix irá criar várias colunas, infelizmente todas com a mesma largura. Para deixar isto um pouco melhor, vamos criar um recurso para mostrar as colunas "com larguras diferentes".

Primeiro, vamos adicionar a coluna auxiliar, do lado direito da única coluna do objeto Matrix, e dentro do grupo já existente desta coluna genérica (Inside Group - Right) , como ilustrado abaixo:



Agora o truque consiste em "ligarmos" o modo avançado para edição das propriedades da [Column Groups] do relatório, visualizar a [segunda] propriedade "Static" - segunda, pois se refere a coluna auxiliar que estamos manipulando - e finalmente adicionar a expressão desejada no atributo [Hidden]. No meu caso, quero somente habilitar a Coluna Auxiliar se o [valor] da Matrix tiver um comprimento maior ou igual a 10, conforme ilustrado:



Não esqueça de efetuar um [merge] das colunas do seu [Data Region] para uma visualização correta dos dados, já que você agora possui uma coluna auxiliar que aparece/desaparece.



E como resultado final, note que somente para colunas com conteúdo [menor ou igual a 10] não temos o "apoio" da Coluna Auxiliar (no caso, as colunas [Revisão] e [Data de Recebimento]), como ilustrado abaixo:



[]s

Nenhum comentário:

Postar um comentário

<< Ao enviar um comentário, favor clicar na opção [Enviar por e-mail comentários de acompanhamento para gtezini@gmail.com] >>