Skip to content

Latest commit

 

History

History
64 lines (37 loc) · 2.32 KB

README.md

File metadata and controls

64 lines (37 loc) · 2.32 KB

Dynamic Form Project

This is a dynamic form builder application built using Angular. It allows users to create custom forms with various types of input fields, including text, number, date, select, radio, and checkbox. The form configurations are stored in the FormsService, and the application supports various functionalities like adding, deleting, and editing form entries.

Note: This project was done for a recruitment interview at Bugloos.

Bugloos Angular Task

Getting Started

To get started with this project, follow the steps below:

  1. Clone the repository:

git clone https://github.com/aliosmanyuksel/dynamic-form.git

cd dynamic-form

  1. Install dependencies:

npm install

  1. Start the development server:

ng serve

The application will be available at http://localhost:4200/.

Folder Structure

The project follows the following folder structure:

  • src/app/core: Contains shared core modules, services, and utilities.
  • src/app/shared: Contains shared components, directives, and pipes.
  • src/app/modules/dynamic-form: Contains the main dynamic-form module with form components and other related files.

How to Use

  1. Define the form fields in forms.service.ts: Modify the formConfig array with the desired form fields, their types, and other configurations.

  2. Use the dynamic-form component: In your application, you can use the dynamic-form component to render the dynamic form with the configured fields.

<!-- YourComponent.html --> <ng-container *ngIf="formConfig"> <dynamic-form [fields]="formConfig"></dynamic-form> </ng-container>

  1. Handle form submissions: The form submission logic can be handled in the FormComponent. You can define beforeSubmitService and afterSubmitService functions for each field in the formConfig array to perform operations before and after form submission.

Contributions

Contributions are welcome! If you find any issues or have suggestions for improvements, please open an issue or create a pull request.

License

This project is licensed under the MIT License.