This is a Next.js project bootstrapped with create-next-app
.
Techniche is a revolutionary platform designed to streamline coding interviews for recruiters and hiring managers. Our comprehensive suite of features includes a coding editor, a customizable dashboard, a captivating landing page, and secure sign-in authentication powered by NextAuth.
-
Coding Editor: Our intuitive coding editor provides a seamless environment for conducting coding interviews. With syntax highlighting, code completion, and real-time collaboration features, recruiters can assess candidates' coding skills with ease.
-
Customizable Dashboard: Tailored to recruiters' needs, our dashboard offers insightful analytics, candidate profiles, and interview scheduling tools. Stay organized and make informed decisions throughout the recruitment process.
-
Engaging Landing Page: Make a lasting impression with our captivating landing page, designed to showcase your company's brand and values. With stunning visuals and compelling content, attract top talent and create a memorable candidate experience.
-
Secure Authentication: NextAuth integration ensures robust authentication mechanisms, safeguarding sensitive candidate and recruiter data. Rest assured that your information is protected with industry-leading security protocols.
- Database: MongoDB, housed within a Docker container, offers scalability and flexibility for storing candidate information securely.
- Frontend Framework: Next.js and React provide a powerful combination for building dynamic and interactive user interfaces.
- UI Design: Material UI enhances the user experience with sleek, responsive, and customizable components.
- Authentication: NextAuth simplifies and secures the authentication process, allowing seamless sign-in for recruiters and candidates alike.
- Recruiters sign in securely using NextAuth authentication.
- They access the customizable dashboard to manage interviews, review candidate profiles, and analyze performance metrics.
- Recruiters conduct coding interviews using the integrated coding editor, assessing candidates' technical skills in real time.
- Candidate data is securely stored and managed in MongoDB, ensuring compliance with data privacy regulations.
- The engaging landing page attracts top talent and fosters a positive candidate experience, reflecting your company's culture and values.
With Techniche, recruiters can optimize the technical interview process, identify top talent efficiently, and build high-performing teams that drive innovation and success.
Experience the future of technical recruiting with CodeMaster today!
First, run the development server:
npm run dev
# or
yarn dev
# or
pnpm dev
# or
bun dev
Open http://localhost:3000 with your browser to see the result.
You can start editing the page by modifying app/page.js
. The page auto-updates as you edit the file.
This project uses next/font
to automatically optimize and load Inter, a custom Google Font.
To learn more about Next.js, take a look at the following resources:
- Next.js Documentation - learn about Next.js features and API.
- Learn Next.js - an interactive Next.js tutorial.
You can check out the Next.js GitHub repository - your feedback and contributions are welcome!
MUI is a React.js library that uses React components to represent re-usable UI components. You can view the UI components it provides for us out-of-the-box in the components library; to view the code, just click "show code" underneath an example to learn how to use the component.
Before starting docker compose
, you'll have to tell it about the environment variables
it expects to be present - you'll have to manually load your .env.local
file:
set -a; source .env.local; set +a
This loads the environment variables, and allows them to be passed to child processes.
MongoDB is our database - to start an instance of MongoDB, we can use
docker compose
; where it will start and configure it for local development. From a new terminal,
run the following:
docker compose up mongo
Note: DON'T INSTALL MONGODB - DOCKER DOES IT FOR YOU
After you're done, you can type Ctrl+C
to stop the database. If you want to wipe it from your
system, you can run the down
subcommand:
docker compose down
Here's a step-by-step guide on connecting to your database:
- Install the mongodb package using npm: npm install mongodb
- Import MongoClient from the mongodb package: const { MongoClient } = require('mongodb');
- Connect to your MongoDB database using the connection string. If your MongoDB is running in another Docker container, make sure to use the name of that container as the hostname in your connection string.
- Use the db method to get a reference to your database, and the collection method to get a reference to the collection you want to interact with.
- Use the insertOne, find, updateOne, etc. methods to interact with your collection.
Here's how the code would look:
const { MongoClient } = require('mongodb');
async function main() { const uri = process.env.MONGODB_URI; const client = new MongoClient(uri, { useNewUrlParser: true, useUnifiedTopology: true });
try { await client.connect();
const database = client.db(process.env.DB);
const users = database.collection('users');
// Insert a document
const doc = { email: process.env.ADMIN_EMAIL, isAdmin: true };
const result = await users.insertOne(doc);
console.log(`Inserted document with _id: ${result.insertedId}`);
} finally { await client.close(); } }
main().catch(console.error);
- Remember to replace process.env.MONGODB_URI with your actual MongoDB connection string, and process.env.DB with the name of your database. Also, make sure to handle errors appropriately in your production code.
Is the codebase getting a little too big? Try generating some inline documentation, so you can search through it quickly in your browser:
npm run docs
This will create a folder ./docs/
with a bunch of html in it. Open docs/index.html
and you'll
see references to the code in the codebase.