terça-feira, 11 de julho de 2017

Knockout.js currency formatter.

Aqui trabalhando com knockout.js, criando um custom binding para manter os valores de inputs em formato de Moeda.

quinta-feira, 9 de fevereiro de 2017

Atualizando Select com Knockout.js

Utilizando knockout.js como atualizar a lista de um select à partir da escolha em outro select? Pra muitos pode ser simples de cara, mas vou adimitir: para mim não foi, fui complicando às coisas ao invés de simplificar, quebrei um pouco a cabeça com isso e não tive bons resultados. Até que, lendo um post de um blog que falava sobre observables computed me veio a iluminação! E resolvi partilhar vai que ajudo alguém. Suponhamos uma aplicação na qual serão escolhidos items, estes itens estão organizados em categorias. Em uma lista seleciono a categoria, e à partir da minha seleção uma segunda lista é abastecida com as opções daquela categoria. Vou ser sincero, Pra começar vejamos uns dados de exemplo:
var produtos = [
 {
  grupo:"higiene pessoal",
  itens:[{'nome':'creme dental','valor':6.95},
                       {'nome':'shampoo','valor':12.49}]
 },
 {
  grupo:"material de limpeza",
  itens:[{'nome':'sabão em pó 2kg','valor':13.80},
                       {'nome':'detergente 500ml','valor':2.80}]
 },
 {
  grupo:"padaria",
  itens:[{'nome':'biscoito de polvilho 500g','valor':4.5},
                       {'nome':'pão de forma integral','valor':8.35}]
 }
];
A seguir nosso html:

<label>Categoria:</label><select data-bind="options:produtos,
      optionsText:'grupo',
      value:categoriaEscolhida,
      optionsCaption:'categoria...'"></select>
    <label>Produto:</label><select data-bind="options:itens,
      optionsText:'nome',
      value:itenEscolhido,
      optionsCaption:'Escolha o item'"></select>


E por último nosso código javascript:
var MarketModel = function(){
 this.produtos = ko.observableArray(produtos);
 this.categoriaEscolhida = ko.observable(this.produtos()[0]);
 this.itens = ko.computed(function(){
  return this.categoriaEscolhida().itens;
 },this);
};
A mágica acontece no observable do tipo computed. Resumidamente, pois a documentação é muito clara, computed é um campo calculado que sempre será atualizado quando as variáveis observáveis das quais ele depende forem atualizadas.Assim, toda vez que categoriaEscolhida for atualizada, itens também será. Simples assim.

segunda-feira, 19 de dezembro de 2016

Impressão com NodeJS

Esta é uma simples solução para quando temos uma aplicação de Intranet com NodeJS, e que gera documentos que precisam ser impressos, contudo os usuários desta intranet compartilham uma única impressora conectada ao e instalada no servidor.
Vamos utilizar o pacote printer. Para instalar basta
 npm install -g node-gyp
 npm install printer --msvs_version=2013
Continuando com a simplicidade, agora vamos a um exemplo:

var fs = require('fs');
var printer = require("printer");
fs.readFile("teste.pdf", 'utf8', function(err, file){
  if (err) throw err;
  console.log("Trying to print...");
  printer.printDirect({data:file,
      type: 'PDF',
      success:function(jobID){
 console.log("Trabalho enviado à impressora - ID: "+jobID);
      },
      error:function(err){
 console.log(err);
      }
  });
});

Neste exemplo utilizamos um pdf qualquer para ser impresso na impressora configurada como padrão. Existem várias opções customizáveis, acho válido citar que os dados podem vir de um arquivo ou de uma string. Você pode por exemplo utilizar renderizadores de templates em html como handlebars e passar a string diretamente para impressão. Você pode adicionar um parâmetro printer com o nome de uma impressora que não seja a padrão se houver mais de uma conectada ao servidor. Pois então, esta foi uma pequena dica!

quarta-feira, 20 de abril de 2016

Validação Customizada de Formulários com Angular

Angular facilita a organização de nossas aplicações em tudo, inclusive na validação de formulários. Porém nenhum framework existente cobre a necessidade de todos os programadores. Com certeza em algum momento você vai querer adicionar alguma funcionalidade à sua aplicação que não é coberta pelo framework. No presente post eu quero inserir uma validação para cpf de um input em meu formulário e não quebrar a validação de angular e não ter de fazer gambiarras. Vamos lá, faremos isto utilizando directives. Para executar esta tarefa me baseei no Post de Ben Lesh e na documentação oficial. 
O pulo do gato é bem descrito por Ben Lesh, utilizando a função $setValidity pertencente ao ngModelController definimos se o valor de um ngModel de determinado campo é válido ou não. Vale à pena conhecer a documentação de ngModelController.

Vamos ao código:
 
dir.directive("cpfValidate", function(){
 return{
  // iremos utilizar a diretiva como atributo
  restrict: 'A', 
  // o elemento a ser validado deve conter o atributo ng-model
  require: 'ngModel',
  link: function(scope, elem, attr, ctrl) {
   /*
    $parser é um array de funções para sanitizar os dados,
    aqui eu adiciono a minha função de validação.
   */
   ctrl.$parsers.unshift(function(value) {
    /* 
     TestaCPF é uma função qualquer para testar um cpf 
     você pode implementar a sua ou copiar na internet.
    */
    var valid = TestaCPF(value);
    ctrl.$setValidity('cpfValidate', valid);
    // se for válido retorno valid, else retorna undefined.
    return valid ? value : undefined;
   });
  }
 };
});

segunda-feira, 11 de maio de 2015

Estatísticas, R e Java - JRI

Bom neste post, quero apresentar de forma simples como pedir ao R para realizar alguns cálculos e retornar o resultado para uma aplicação em Java.


Vamos ao código:

 Rengine re = new Rengine("--vanilla");
public REXP eval(String c) throws Exception{

 REXP r = rengine.eval(c);

 if(r == null){

 rengine.eval("traceback()");

 throw new Exception("Não teve retorno!!!");

 }

return r;

}
Aqui o que temos é uma função que encapsula a avaliação para o caso.

CMake, RInside, Rcpp e R

Recentemente comecei a experimentar os pacotes RInside e Rcpp para R, que permitem programar em C++ para R e também trazer o R para "dentro" de aplicações em C++. Falando em C++, gosto muito de utilizar o CMake para gerar meus makefiles, contudo com o CMakeLists.txt presente juntos aos códigos exemplo que vem junto com RInside não foi possível compilar os programas. Você pode ver este script aqui.. Eram reportados alguns erros, e, tentando contorná-los identifiquei um que parece ser o suficiente . Mesmo não sendo o intuito deste post falar sobre cmake quero compartilhar a idéia de RInside e CMake funcionam muito bem. Vamos lá: o que eu fiz foi trocar o nome da variável na linha 87 de ${RINSIDELIBS_l} para ${RINSIDELIBS} e pronto.
Bons projetos

segunda-feira, 13 de janeiro de 2014

Chamando o R dentro de uma aplicação Java com JRI e Eclipse


  1. Motivação
  2. JRI
    1. Download e Instalação
    2. Configuração
      1. Linux
      2. Windows( a fazer )
    3. Execução

1.Motivação

Você quer fazer um software que utilize o R como motor mas que tenha uma interface usável por usuários não habituados ao ambiente R. Existem algumas bibliotecas em C e Java que permitem que você chame o R dentro de suas aplicações. Aqui vou mostrar como utilizo o JRI para Java. Porém, tive dificuldades para fazer as coisas funcionarem, e você talvez também esteja tendo problemas. Aqui pretendo então dizer passo a passo como fiz.

2.JRI


  2.1.Download e Instalação

Entre no R e digite e execute a linha a abaixo. O ideal é executar o R como administrador, se possível.

install.package('rJava')

  2.2.Configuração

     2.2.1 Linux

É necessário definir algumas variáveis de ambiente. Utilizando seu editor de texto preferido você abrirá o arquivo '.profile' que está na seu home e adicionará algumas linhas.

Obs: O arquivo '.profile' é invisível ao explorador de arquivo, você deve configurar o explorador para exibir arquivos ocultos, ou simplesmente abra um terminal e digite: 'gedit .profile' .

Obs: não digite as aspas

Caso você não queira editar o .profile basta digitar estas linhas toda vez que reiniciar o PC. (não recomendo)

Após editar o .profile é necessário reiniciar a máquina.


As linhas a serem adicionadas são estas a seguir(lembre de checar estes caminhos na sua máquina):

export R_HOME=/usr/lib/R # "Este é o caminho para a pasta que contém a instalação do R, e não caminho para o executável!"

Se tiver dúvida sobre o caminho, no terminal digite: R RHOME

export LD_LIBRARY_PATH=/usr/lib/R/site-library/rJava/jri/

export CLASSPATH=.: /usr/lib/R/site-library/rJava/jri/

2.2.2 Windows

Neste sistema operacional, temos de definir algumas variáveis de ambiente:
  • Caminho para o executável do R
  • Caminho para a jri.dll

3 Execução

Para executar darei alguns detalhes para o as IDEs Netbeans e eclipse.