Como utilizar a biblioteca jsondiffpatch? – javascript json array

Pergunta:


Estou tendo dúvidas de como manipular os dados com a biblioteca jsondiffpatch

O array original:

[
  {"id":1004,"idproduto":3,"forma":"Alface","preco":1,"quantidade":1},
  {"id":1000,"idproduto":3,"forma":"Bacon","preco":2,"quantidade":1},
  {"id":1001,"idproduto":3,"forma":"Queijo Cheedar","preco":2,"quantidade":3}
]

O array modificado:

[
  {"id":1004,"idproduto":3,"forma":"Alface","preco":1,"quantidade":2},
  {"id":1001,"idproduto":3,"forma":"Queijo Cheedar","preco":2,"quantidade":1},
  {"id":1002,"idproduto":2,"forma":"Bacon","preco":2,"quantidade":1}
]

A resposta da biblioteca é:

[0: {
quantidade: [1,2]
},1: {
quantidade: [3,1]
},2{
  "id": 1002,
  "idproduto": 2,
  "forma": "Bacon",
  "preco": 2,
  "quantidade": 1
}]

Ele exibe a diferença certa. A minha dúvida é: Com base nessa diferença, como manipulo esse array para virar um novo??

Da seguinte forma:

[
  {"id":1004,"idproduto":3,"forma":"Alface","preco":1,"quantidade":1},
  {"id":1001,"idproduto":3,"forma":"Queijo Cheedar","preco":2,"quantidade":-2},
  {"id":1002,"idproduto":2,"forma":"Bacon","preco":2,"quantidade":1}
]

Autor da pergunta Willian

Segundo a documentação da biblioteca é só usar a função patch que já vem com a biblioteca.

Ex.:

var original = [
    {"id":1004,"idproduto":3,"forma":"Alface","preco":1,"quantidade":1},
    {"id":1000,"idproduto":3,"forma":"Bacon","preco":2,"quantidade":1},
    {"id":1001,"idproduto":3,"forma":"Queijo Cheedar","preco":2,"quantidade":3}
];

var modificado = [
    {"id":1004,"idproduto":3,"forma":"Alface","preco":1,"quantidade":2},
    {"id":1001,"idproduto":3,"forma":"Queijo Cheedar","preco":2,"quantidade":1},
    {"id":1002,"idproduto":2,"forma":"Bacon","preco":2,"quantidade":1}
];

var diferenca = jsondiffpatch.diff(original, modificado);

// modifica o original
jsondiffpatch.patch(original, diferenca);

console.log(original);

Editei o Fiddle para que fizesse o patch da biblioteca.
Fiddle

EDIT: Modifiquei o código e adicionei o Fiddle

(Disclaimer: sou o autor do jsondiffpatch, e meu portugues nao e o melhor 🙂 )

Acho que vc pode obter o resultado que ta esperando com um “filtro” para gerar diferenças entre números desse jeito. o codigo:

var diffpatcher = jsondiffpatch.create({
  objectHash: function(obj) {
    return obj.id; // esse e o jeito de identificar objectos no seu array mesmo tendo mudado de posiçao
  }
});

var numericDiffFilter = function(context) {
  if (typeof context.left === 'number' && typeof context.right === 'number' && context.left !== context.right) {
    // dois numeros, deixar so a diferença (em lugar do array com os dois valores)
    context.setResult(context.right - context.left).exit();
  }
};
// a filterName is useful if I want to allow other filters to be inserted before/after this one
numericDiffFilter.filterName = 'numeric';

// inserir o novo filtro antes do "trivial" o primeiro quando se comparam dois valores
diffpatcher.processor.pipes.diff.before('trivial', numericDiffFilter);

// os valores que vc botou (eu corregi o id do Bacon que parece foi um typo):
var l = [
  {"id":1004,"idproduto":3,"forma":"Alface","preco":1,"quantidade":1},
  {"id":1000,"idproduto":3,"forma":"Bacon","preco":2,"quantidade":1},
  {"id":1001,"idproduto":3,"forma":"Queijo Cheedar","preco":2,"quantidade":3}
];
var r = [
  {"id":1004,"idproduto":3,"forma":"Alface","preco":1,"quantidade":2},
  {"id":1001,"idproduto":3,"forma":"Queijo Cheedar","preco":2,"quantidade":1},
  {"id":1000,"idproduto":2,"forma":"Bacon","preco":2,"quantidade":1}
];

var delta = diffpatcher.diff(l, r);

o resultado em delta e:

{
  "0": {
    "quantidade": 1
  },
  "1": {
    "quantidade": -2
  },
  // o idproduto do Bacon diminiu (typo?)
  "2": {
    "idproduto": -1
  },
  "_t": "a",
  // o Queijo moveu da posicao 2 a posicao 1
  "_2": [
    "",
    1,
    3
  ]
}

Logicamente agora esse delta ja nao pode ser usado com .patch() mas acho que isso e esperado neste caso (mas isso pode se resolver escrevendo un filtro de patch).

Documentação sobre estes filtros (plugins): https://github.com/benjamine/jsondiffpatch/blob/master/docs/plugins.md

Fonte

Related Posts:

Qual a diferença entre AppCompatActivity e Activity? – android android-activity
Pergunta: Qual a diferença da AppCompatActivity para Activity ? A partir de qual versão a AppCompatActivity foi adicionada ao Android? Autor da pergunta Luhhh A diferença reside ...
Como abreviar palavras em PHP? – php string
Pergunta: Possuo informações comuns como nome de pessoas e endereços, e preciso que elas contenham no máximo 30 caracteres sem cortar palavras. Exemplo: 'Avenida Natalino João Brescansin' ...
Qual é a finalidade de um parêntese vazio numa declaração Lambda? – c# expressões-lambda característica-linguagem
Pergunta: Criei um exemplo de uma declaração Lambda sem argumentos, entretanto, estou com duvidas referente a omissão do parêntese vazio () na declaração. Veja o exemplo: class ...
Boas práticas para URI em API RESTful – api rest restful
Pergunta: Estou com dúvida em relação às URIs de alguns recursos da api que estou desenvolvendo. Tenho os recursos projetos e atividades com relação 1-N, ...
Dúvidas sobre a integração do MySQL com Java – java mysql netbeans
Pergunta: Estou criando um sistema no NetBeans, utilizando a linguagem Java e o banco de dados MySQL. Escrevi o seguinte código para realizar a conexão ...
Qual é a finalidade da pasta Model do framework Inphinit? – php inphinit
Pergunta: No Inphinit micro-framework existe a pasta Model que fica dentro da pasta application, e nela é onde ficam as classes, mas eu estou muito ...
Uso do ‘@’ em variáveis – javascript typescript coffeescript
Pergunta: Vejo em algumas linguagens que compilam para javascript, como TypeScript e CoffeeScript, o uso do @ em variáveis, como também, casos em que o ...
Qual tamanho máximo um arquivo JSON pode ter? – json arquivo
Pergunta: Vou dar um exemplo para conseguir explicar minha duvida: Preciso recuperar informação de imagens vindas de uma API, esse banco de imagens me retorna JSON's ...
O que é Teste de Regressão? – terminologia engenharia-de-software testes
Pergunta: Na matéria de Teste de Software o professor abordou um termo chamado Teste de Regressão, isto dentro da disciplina de teste de software. Sendo ...
O que é um construtor da linguagem? – php característica-linguagem
Pergunta: Em PHP, já li e ouvi várias vezes a respeito dos Construtores da Linguagem. Os casos que sempre ouvi falar deles foi em casos ...
Função intrínseca para converter numérico para string – cobol
Pergunta: Estou a tentar saber se existe alguma função intrínseca do COBOL para converter um data numérico para string sem precisar usar a cláusula REDEFINES: ( ...
Porque usar implements? – java android
Pergunta: Qual a diferença entre usar btn.setOnClickListener(new OnClickListener() { e public class MainActivity extends Activity implements OnClickListener{ Estive fazendo um curso de Android e meu professor falou que ...
O que é XHTML e quando deve ser usado? – html xml xhtml
Pergunta: O que eu sei é que o XHTML precisa ser XML válido. Isso implica, por exemplo, que todas as tags precisam ser fechadas. Por ...
Uma placa aceleradora de vídeo pode melhorar o desempenho não-gráfico? [fechada] – desempenho
Pergunta: Para desenvolver em Ruby on Rails, eu utilizo aqui uma máquina virtual do VirtualBox com Ubuntu Server 14.04 sem interface gráfica instalada. Recentemente descobri uma ...
Concat() VS Union() – c# .net
Pergunta: Qual a diferença entre Concat() e Union() ? Quando usar Concat() e quando usar Union() ? Somente pode ser usado em list ? ...

Deixe uma resposta

O seu endereço de email não será publicado. Campos obrigatórios marcados com *