@verida/vue-account
v0.1.38
Published
Open Source Vue Components for Verida
Downloads
31
Readme
verida user account component
Open Source Vue Components for Verida
- This component can be customized to suit your application styles and themes .
NB: This supports vue 3 only
Usage
yarn add @verida/vue-account3
The @verida/vue-account
component library registration enables the vda-account
and vda-login` component to be accessed across your application and share some global state.
main.js
import { createApp } from 'vue';
import App from './App.vue';
import Account from '@verida/vue-account';
const app = createApp(App);
app.use(Account);
app.mount('#app');
- NOTE : You can retrieve the user application
context
from the parameter of theonSuccess
function passed as a prop .
This works for both the vda-login
and vda-account
Using the vda-login
component
This component is used to handle SSO (Single Sign on) login it leverages our @verida/client-ts
and @verida/account-web-vault
packages under the hood.
<template>
<div id="app">
<vda-login
@onError="onError"
@onSuccess="onSuccess"
@onLogout="onLogout"
:contextName="contextName"
:openUrl="openUrl"
:logo="logo"
:loginText: 'LOGIN_TEXT',
/>
</div>
</template>
<script lang="ts">
import { defineComponent } from "vue";
export default defineComponent({
name: "Login",
data() {
return {
contextName: "Verida: Account Component",
logo: "https://assets.verida.io/verida_login_request_logo_170x170.png",
openUrl: "http://172.20.10.3:8081/",
};
},
methods: {
onSuccess(response: any) {
console.log(response)
},
onError(error: Error) {
console.log("Login Error", error);
},
},
});
</script>
Using the vda-account
component
This component is used to display a logged-in user profile details such as name
, did
and avatar
this happens after the vda-login
component has been used for performing and SSO (Single Sign on) Login.
You can add a custom button in your application and call the
veridaConnect()
in the window objectYou can listen for an event
connected
after a successful SSO Login , see example code belowExample code :
<template>
<div id="app">
<vda-account
:logo="logo"
:contextName="contextName"
:openUrl="openUrl"
@onLogout="onLogout"
@onError="onError"
@onSuccess="onSuccess"
/>
<button @click="handleConnectButtonClick">Connect</button>
</div>
</template>
<script lang="ts">
import { defineComponent } from "vue";
export default defineComponent({
name: "Login",
data() {
return {
contextName: "Verida: Account Component",
logo: "https://assets.verida.io/verida_login_request_logo_170x170.png",
openUrl: "http://172.20.10.3:8081/",
};
},
async created() {
this.$VeridaHelper.on("connected", (context) => {
console.log("App context", context);
});
},
methods: {
async handleConnectButtonClick() {
if (window.veridaConnect) {
await window.veridaConnect();
}
},
onLogout() {
console.log("hello");
},
onSuccess(response: any) {
// The response is the application context of the connected user..
console.log(response)
},
onError(error) {
console.log("Login Error", error);
},
},
});
</script>
Props
vda-account
| Props | Type | Required | Description |
| --------------- | -------- | -------- | ------------------------------------------------------------------------------------------------------------------------------------------- |
| styles | string | false |
| loaderIconColor | string | false | a Hexa-decimal color e.g (#0000) |
| logo | string | false | 170x170 png file |
| contextName | string | true | application name e.g Verida : My APP
|
| onLogout | function | true | a callback function to perform logout action |
| navItems | array of object | true | an array of object that has list of additional navItems that can be added to the original navItems
- navitems
interface
{
title:string;
img: string;
link: string;
}
vda-login
| Props | Type | Required | Description |
| --------------- | -------- | -------- | ------------------------------------------------------------------------------------------------------------------------------------------- |
| onError | function | true | a callback function that log errors |
| logo | string | false | 170x170 png file |
| contextName | string | true | application name e.g Verida : My APP
| |
| loginText | string | false | Login Screen Text | |