macaan.ai is an AI-powered appliance troubleshooting and repair ecosystem designed to make home equipment repair easy. It provides homeowners with all the assistance they need, all in one place. This project replicates one page from the admin app, where customer service agents resolve tickets submitted by homeowners.
The application is deployed on Vercel and can be accessed at: https://macaanai.vercel.app.
The project is organized as follows:
macaan.ai/
├── app/ # Contains the main application code (pages, components, etc.)
├── public/ # Static assets such as images, fonts, etc.
├── .eslintrc.json # ESLint configuration file
├── .gitignore # Ignored files for git version control
├── next.config.mjs # Next.js configuration
├── package.json # Project dependencies and scripts
├── package-lock.json # Dependency lock file
├── postcss.config.mjs # PostCSS configuration
├── tailwind.config.ts # Tailwind CSS configuration
├── tsconfig.json # TypeScript configuration
└── README.md # Project documentation
To get started with this project, clone the repository and install the dependencies:
git clone https://github.com/asadDev02/macaan.ai
cd macaan.ai
yarn install
To run the application in development mode:
yarn dev
This will start the development server, and you can view the app by navigating to http://localhost:3000
.
For production build:
yarn build
yarn start
Data validation in this project is handled using Yup in combination with React Hook Form's Yup resolver. This setup allows for schema-based validation, providing a simple and efficient way to validate form inputs.
To add validation logic, define a Yup schema and pass it to the form using yupResolver
:
import { useForm } from "react-hook-form";
import { yupResolver } from "@hookform/resolvers/yup";
import * as yup from "yup";
const schema = yup.object().shape({
name: yup.string().required("Name is required"),
email: yup
.string()
.email("Invalid email format")
.required("Email is required"),
});
const {
register,
handleSubmit,
formState: { errors },
} = useForm({
resolver: yupResolver(schema),
});
const onSubmit = (data) => {
console.log(data);
};
This ensures that any form submissions meet the defined validation criteria before being processed.
The project includes the following key dependencies:
Linting and formatting are enforced via ESLint and Prettier to maintain code quality and consistency. You can run lint checks with:
yarn lint
This project is licensed under the MIT License.