Skip to main content

How to setup Apps in your project

Overview

In this guide, we'll walk through the process of developing applications within our template, using the Invoice app as an example. This guide will cover API integration, database management, and the organization of server files and components, providing a clear blueprint for developing applications similar to our Invoice app.

warning

When adding new apps that require dependencies not included in our package, it's essential to install the necessary packages. This ensures that all app functionalities are supported and operational within our project framework. Proper package management is crucial for the seamless integration and performance of new apps. You may refer to all the dependencies from here.

Server File and API Integration

Location and Structure

  • Path: The server files for pages are located at src/app/[lang]/(dashboard)/(private)/apps (if translation (i18n) feature is implemented) or src/app/(dashboard)/(private)/apps (if translation (i18n) feature is not implemented).

  • Example: For the invoice app, find the server file at src/app/[lang]/(dashboard)/(private)/apps/invoice/preview/[id]/page.tsx.

API Call Implementation

  • Handling API Calls: In the Invoice app example, the server file includes a function getData to fetch data from the API.
const getData = async () => {
const res = await fetch(`${process.env.API_URL}/apps/invoice`) // Your API URL
if (!res.ok) {
throw new Error('Failed to fetch invoice data');
}
return res.json();
};

const PreviewPage = async (props: { params: Promise<{ id: string }> }) => {
const params = await props.params;

const data = await getData();
const filteredData = data.filter((invoice: InvoiceType) => invoice.id === params.id)[0];

if (!filteredData) {
redirect('/not-found');
}

return <Preview invoiceData={filteredData} id={params.id} />;
};

export default PreviewPage;

Creating APIs

API File Location

For more on Next.js routing conventions, visit Next.js Routing.

  • Path: APIs specific to apps are created in src/app/api/apps.

  • Routing: The API routing adheres to Next.js app router conventions.

  • Example: The API for the Invoice app is defined in src/app/api/apps/invoice/route.ts.

import { NextResponse } from 'next/server';
import { db } from '@/app/api/fake-db/apps/invoice';

export async function GET() {
return NextResponse.json(db);
}

Using Fake Databases

Storing Fake Data

  • Path: Fake database files for apps are stored at src/fake-db/apps.

  • Example: The Invoice app's fake database is located at src/fake-db/apps/invoice/index.ts.

import type { InvoiceType } from '@/types/apps/invoiceTypes';

export const db: InvoiceType[] = [
// ...Invoice data...
];

For steps on integrating real databases and API calls, refer to Using Real APIs.

Component and Style Management

Component Location

  • Path: The components for apps are located at src/views/apps.

  • Example: The Invoice app's components are located at src/views/apps/invoice.

Styling Approach

  • Recommended Styling: Use Tailwind classes for styling. If custom styles is not possible with Tailwind then only create a styles.module.css file in the respective page folder.

  • Example: For the Invoice app, styles are organized in src/views/apps/invoice/preview.

By adhering to the structure and practices detailed in this guide, developers can seamlessly integrate their apps into our template, ensuring consistency in code quality and style. The Invoice app example provides practical insight into applying these methodologies effectively.