Skip to content

Latest commit

 

History

History
127 lines (95 loc) · 2.82 KB

README.md

File metadata and controls

127 lines (95 loc) · 2.82 KB

Indicative Vue

CI/CD - GHPackages

Esse projeto é uma abstração do Validation utilizado no Adonis com o pacote indicative

Instalação

Baixe o pacote rodando em seu terminal:

  npm i @ks-labs/indicative-vue

Instale o pacote no seu projeto Vue.js

  ...
  import IndicativeVue from "@ks-labs/indicative-vue";
  ...
  Vue.use(IndicativeVue);
  ...

Uso

O Indicative Vue espera a seguinte estrutura de pasta:

src/
| - validation
  | - User.js
main.js
App.vue

O conteúdo no arquivo User.js segue o mesmo padrão utilizado no Adonis.js

// src/validation/User.js
class User {
  get rules() {
    return {
      name: "string",
    };
  }

  get messages() {
    return {
      "name.string": "Campo Nome deve ser do tipo string.",
    };
  }

  ...

}

module.exports = new User();

Após a instalação do pacote um novo metodo ficara disponivel na instancia do Vue.js permitindo ser utilizado dessa forma:

const result = await this.$indicative(
  { toi: "1de3" },
  require("@/validation/User.js")
);

// result = { valid: true or false, errors: [] *caso possua* }

Retorno dos erros

Caso possua erro por padrão o retorno de erro ira percorrer a DOM buscando identificadores referentes a keys inseridas no metodo rules e apos isso ira adicionar a classe "is-invalid" para todos. A mensagem de erro sera adicionada diretamente na tag que possuir o seguinte padrão [field.name]_message.

Ou seja:

<input id="name" type="text" />
<p id="name_message"></p>

Caso você deseja retornar somente a lista de erro podera alterar as opções no plugin da seguinte forma:

    ...
  import IndicativeVue from "@ks-labs/indicative-vue";
  ...
  Vue.use(IndicativeVue, {return_error: true});
  ...

Criar validações e sanitizor customizados

Você podera criar validações customizadas seguindo o padrão do indicative e inserindo-as nas opções do plugin

// src/customValidation/NameValidation.js

export const name = {
  async: false,
  validate: function(data: any, field: any) {
    data = data.original;
    if (data[field]) return true;
    else throw Error;
  },
};

E na configuração do plugin:

      ...
  import IndicativeVue from "@ks-labs/indicative-vue";
  import CustomValidations from 'src/customValidation/NameValidation.js'
  ...
  Vue.use(IndicativeVue, {
    return_error: true,
    validations: {
      CustomValidations
      }
    });
  ...

E da mesma forma podera ser feita com os Sanitizor. Para mais informações de como criar Validações e Sanitizor customizados acesse a documentação do Indicative