Security News
pnpm 10.0.0 Blocks Lifecycle Scripts by Default
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
formvuelatte
Advanced tools
For the full guide with examples, visit https://formvuelatte.netlify.com
FormVueLatte is a zero dependency library that allows you to generate schema-driven forms with extreme ease.
The schema that you use for your form can be as flexible as you need it to be, it can be modified at run-time with an expected reactive result, and can even be fetched directly from you backend's API.
To add FormVueLatte to your project, start by installing the package through your favorite package manager.
yarn add formvuelatte
// OR
npm install formvuelatte
Now that you have the package in your project, import
it to your component.
import { SchemaForm } from 'formvuelatte'
The SchemaForm
requires two props
. The first is the schema
, which is the configuration of your form. The second one is value
, which will hold the state of the form.
<SchemaForm :schema="mySchema" :value="formData" />
The SchemaForm
will $emit
input events when your components update. This means that you are able to either use v-model
on it, or manually capture the @input
event with a method of your own, as well as inject the :value
property. Either or.
Below you will find an example of the previous concepts.
<template>
<SchemaForm :schema="mySchema" v-model="formData" />
</template>
<script>
export default {
data() {
return {
formData: {},
mySchema: {
//some schema here
}
}
}
}
</script>
The SchemaForm
component requires you to pass it a schema
property. This schema
can be both an object
or an array
, although under the hood it will be transformed to an array
.
In its simplest form, the schema
requires you to provide a name: value
pair for each of the form components you want to add to your form. Let's assume for this example that you have a component in your project called FormText
which exposes an <input>
tag with some CSS.
<template>
<SchemaForm :schema="schema" />
</template>
<script>
import { SchemaForm } from 'formvuelatte'
import FormText from 'path/to/FormText';
export default {
components: { SchemaForm },
data() {
return {
schema: {
name: {
component: FormText // Note that is NOT a string
},
lastName: {
component: FormText // We pass the component that we imported directly
}
}
}
}
}
</script>
Now that you have your schema bound into the schema
prop, you need to make sure that your components are understood by SchemaForm
.
In order for SchemaForm
to understand your components, they need to use the FormMixin
mixin that FormVueLatte provides.
// FormText.vue
import { FormMixin } from 'formvuelatte'
export default {
[...]
mixins: [ FormMixin ],
[...]
}
In its simplest form, make sure that when your form element
wants to make a change to the value
, it calls the update
method with the new value.
Here's an example using the <input>
tag.
<input
:value="value"
@input="update($event.target.value)"
/>
The FormMixin
adds a required value
property to your component (for it to comply with v-model capabilities).
Once you've imported the mixin to your components, make sure your component makes use of the update
method provided by the mixin.
The update
method $emit
s the input
event with whatever value you pass to it.
FAQs
Schema Form Generator
The npm package formvuelatte receives a total of 5 weekly downloads. As such, formvuelatte popularity was classified as not popular.
We found that formvuelatte demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.