Skip to content

Latest commit

Β 

History

History
197 lines (116 loc) Β· 8.29 KB

README.md

File metadata and controls

197 lines (116 loc) Β· 8.29 KB

🎹 Virtual Keyboard Project Using React.JS 🎹

πŸŽ‰ Welcome to the Virtual Keyboard project! πŸŽ‰ This innovative and interactive tool allows users πŸ‘₯ to type πŸ–ŠοΈ seamlessly using a software-based virtual keyboard ⌨️ built with ReactJS βš›οΈ. The project implements functional components 🧩 and manages state πŸ”„ efficiently. Users can interact 🀲 with the virtual keyboard ⌨️ by clicking πŸ–±οΈ on keys, which allows for a smooth and responsive typing experience ⌨️. The keypress πŸ”‘ and character input logic 🧩 are implemented using JSX πŸ–₯️.

πŸ“‹ Description

The Virtual Keyboard ⌨️ is a software-based input interface πŸ’» that mimics a physical keyboard ⌨️ on a digital device πŸ–₯️. Its key functionalities 🧩 include:

  • User Input Simulation πŸ’¬: Allows users πŸ‘₯ to input text πŸ–‹οΈ and commands πŸ–₯️ by clicking πŸ–±οΈ on virtual keys πŸ”‘, replicating the functionality of a physical keyboard ⌨️.
  • Accessibility β™Ώ: Enhances accessibility for individuals with physical disabilities πŸ‘©β€πŸ¦½πŸ‘¨β€πŸ¦½ by providing alternative input methods πŸ–₯️.
  • Security πŸ”: Used for secure data entry πŸ›‘οΈ, protecting against keyloggers πŸ”’ and other security threats 🚫.
  • Integration πŸ”„: Can be integrated into various applications πŸ–₯️, including kiosks 🏬, touch-screen devices πŸ“±, and software interfaces πŸ’», to facilitate text input πŸ–‹οΈ and interaction 🀝.

πŸ› οΈ Technologies Used / Prerequisites

  • ReactJS βš›οΈ: JavaScript library πŸ“š for building user interfaces πŸ–₯️.
  • CSS 🎨: For styling 🎨 the virtual keyboard ⌨️.
  • JSX πŸ–₯️: Syntax extension for JavaScript πŸ’».
  • Functional Components in React βš›οΈ: For creating reusable components 🧩.

πŸš€ Approach and Functionalities

To create πŸ› οΈ the Virtual Keyboard ⌨️ application, the project involves:

Steps to Create the Application

  1. Set Up πŸ› οΈ a React project βš›οΈ using the command πŸ–₯️:

    npx create-react-app <<name_of_project>> πŸŽ‰
  2. Navigate πŸšΆβ€β™‚οΈ to the project folder πŸ“‚ using:

    cd <<Name_of_project>> πŸ“‚
  3. Install πŸ“₯ the required modules πŸ”„ using:

    npm i styled-components πŸ’…
  4. Create πŸ› οΈ a folder called components πŸ“‚ and add πŸ–₯️ two new files πŸ“„ inside it:

    • Keyboard.js ⌨️
    • Keyboard.css 🎨
  5. Import πŸ“₯ the icon pack 🌟 into the index.html file πŸ“‚ of the public folder πŸ“‚:

    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.2.0/css/all.min.css" integrity="sha512-xh6O/CkQoPOWDdYTDqeRdPCVd1SpvCA9XXcUnZS2FmJNp1coAFzvtCN9BmamE+4aHK8yyUHUSCcJHgXloTyT2A==" crossorigin="anonymous" referrerpolicy="no-referrer" />

Example Code

  • index.html πŸ–₯️: This is an automatically created file πŸ“‚ in the public folder πŸ“‚. We just need to import πŸ–₯️ the icon pack 🌟 in its <head> tag πŸ–₯️.

  • App.js βš›οΈ: This file πŸ“„ imports the Keyboard ⌨️ component 🧩 and exports it πŸ–₯️.

  • Keyboard.js ⌨️: This file πŸ“„ contains the logic 🧩 for the virtual keyboard ⌨️, keypress πŸ”‘, and input text block πŸ–‹οΈ with state variable πŸ”„ which the computer πŸ’» chooses a value πŸ–₯️.

  • Keyboard.css 🎨: This file πŸ“„ contains the design 🎨 of the Virtual Keyboard ⌨️ elements 🧩.

πŸ—οΈ How to Run the Project

Steps to Run the Application

  1. Start πŸš€ the project by typing πŸ–₯️ the following command πŸ–₯️ in the terminal πŸ’»:

    npm start πŸš€
  2. Open πŸ”“ your web browser 🌐 and type πŸ–₯️ the following URL 🌐:

    http://localhost:3000/ 🌐
    

πŸ“Έ Screenshots (Output)

Here’s a sneak peek πŸ–ΌοΈ of the Virtual Keyboard ⌨️ in action ⏳:

virtual

πŸ“¦ Clone the Repository

To clone the repository πŸ“¦ and start using the Virtual Keyboard ⌨️, follow these steps:

  1. Clone πŸ–₯️ the repository using the following command πŸ–₯️:

    git clone https://github.com/nidhiupman568/VirtualKeyboard-Using-React.JS.git πŸ“¦
  2. Navigate πŸšΆβ€β™‚οΈ into the project directory πŸ“‚:

    cd virtual-keyboard πŸ“‚
  3. Install πŸ“₯ the dependencies πŸ”„:

    npm install πŸ“₯
  4. Start πŸš€ the development server πŸ’»:

    npm start πŸš€
  5. Open πŸ”“ your web browser 🌐 and type πŸ–₯️ the following URL 🌐:

    http://localhost:3000/ 🌐
    

🀝 Contributing

Feel free to contribute 🀝 to the project by submitting pull requests πŸš€. Your contributions help improve the Virtual Keyboard ⌨️ and make it better for everyone 🌟.

πŸŽ‰ Enjoy using the Virtual Keyboard ⌨️! πŸŽ‰ Feel free to share πŸ—£οΈ your feedback πŸ“ or contribute 🀝 to the project. Happy typing! βŒ¨οΈπŸ’¬

Getting Started with Create React App

This project was bootstrapped with Create React App.

Available Scripts

In the project directory, you can run:

npm start

Runs the app in the development mode.
Open http://localhost:3000 to view it in your browser.

The page will reload when you make changes.
You may also see any lint errors in the console.

npm test

Launches the test runner in the interactive watch mode.
See the section about running tests for more information.

npm run build

Builds the app for production to the build folder.
It correctly bundles React in production mode and optimizes the build for the best performance.

The build is minified and the filenames include the hashes.
Your app is ready to be deployed!

See the section about deployment for more information.

npm run eject

Note: this is a one-way operation. Once you eject, you can't go back!

If you aren't satisfied with the build tool and configuration choices, you can eject at any time. This command will remove the single build dependency from your project.

Instead, it will copy all the configuration files and the transitive dependencies (webpack, Babel, ESLint, etc) right into your project so you have full control over them. All of the commands except eject will still work, but they will point to the copied scripts so you can tweak them. At this point you're on your own.

You don't have to ever use eject. The curated feature set is suitable for small and middle deployments, and you shouldn't feel obligated to use this feature. However we understand that this tool wouldn't be useful if you couldn't customize it when you are ready for it.

Learn More

You can learn more in the Create React App documentation.

To learn React, check out the React documentation.

Code Splitting

This section has moved here: https://facebook.github.io/create-react-app/docs/code-splitting

Analyzing the Bundle Size

This section has moved here: https://facebook.github.io/create-react-app/docs/analyzing-the-bundle-size

Making a Progressive Web App

This section has moved here: https://facebook.github.io/create-react-app/docs/making-a-progressive-web-app

Advanced Configuration

This section has moved here: https://facebook.github.io/create-react-app/docs/advanced-configuration

Deployment

This section has moved here: https://facebook.github.io/create-react-app/docs/deployment

npm run build fails to minify

This section has moved here: https://facebook.github.io/create-react-app/docs/troubleshooting#npm-run-build-fails-to-minify