Here is my routeAction where I've the code for creating a user account. I'm using appwrite for this.
export const useCreateUserAccount = routeAction$(
async (user, { fail }) => {
try {
const result = await account.create(
ID.unique(),
user.email.toString(),
user.password.toString(),
user.name.toString()
)
console.log('user account created successfully: ', result)
return {
status: true,
error_message: '',
error_code: '',
data: result,
message: 'user account created successfully'
};
} catch (error) {
console.log('Exception caught: ', error)
return fail(500, {
status: false,
error_message: 'User could not be added',
error_code: '',
data: error,
message: ''
});
}
// return {
// status: true,
// error_message: '',
// error_code: '',
// data: result,
// message: 'user account created successfully'
// };
},
zod$({
name: z.string().min(1),
email: z.string().email(),
password: z.string().min(8),
})
);
User account creation is working fine. But, there are 2 issues I'm facing at here -
try
section & enable the commented return statement(at the end of the function), I'm getting I'm getting error as can't find name result
.{ !action.value?.status && <p>{action.value?.data}</p> }
----------Updated Code-----------
After a long struggle of hit & trial, I finally managed to calm down my typescript linter from yelling at me. Here is my updated code. I hope it'll help someone who is new like me to both Qwik & Typescript :D
import { component$, useStore } from '@builder.io/qwik';
import type { DocumentHead } from '@builder.io/qwik-city';
import { Link, routeAction$, zod$, z, Form } from '@builder.io/qwik-city';
import { account } from '~/appwrite.config';
import { ID } from 'appwrite'
export const useCreateUserAccount = routeAction$(
async (user, { fail }) => {
type SuccessResponse = {
status: boolean,
data: {
id: string,
name: string,
email: string,
phone: string,
emailVerification: boolean,
phoneVerification: boolean,
},
message: string
}
type ErrorResponse = {
status: boolean,
error: {
message: string,
code: number,
type: string,
version: string
}
message: string
}
let result
try {
result = await account.create(
ID.unique(),
user.email.toString(),
user.password.toString(),
user.name.toString()
)
console.log('user account created successfully: ', result)
} catch (error: any) {
console.log('Exception caught: ', error)
const errorResponse: ErrorResponse = {
status: false,
error: {
message: error.response.message,
code: error.response.code,
type: error.response.type,
version: error.response.version,
},
message: 'Exception caught when creating user account'
}
return fail(500, errorResponse);
}
const response: SuccessResponse = {
status: true,
data: {
id: result['$id'],
name: result['name'],
email: result['email'],
phone: result['phone'],
emailVerification: result['emailVerification'],
phoneVerification: result['phoneVerification'],
},
message: 'user account created successfully'
};
return response
},
zod$({
name: z.string().min(1),
email: z.string().email(),
password: z.string().min(8),
})
);
the "result" variable is declared locally (block-scoped ) in the try catch block. therefore, it is not visible outside of this block. you have to declare it locally to the function:
...
async (user, { fail }) => {
let result;
try {
result = await account.create(...