A versatile React component library for dynamic forms and animations.
- DynamicForm: A flexible form component that generates fields based on a configuration and handles validation.
- FadeIn: An animation component for smoothly fading in content.
- SlideUp: An animation component for sliding content up from an initial offset.
You can install the library via npm:
npm install samples-lib-reactOr using yarn:
yarn add samples-lib-reactThe DynamicForm component allows you to create a form dynamically based on a configuration.
Props:
- fields: An array of field configurations. Each field must have- name,- label,- type, and- validationproperties.
- onSubmit: A function that receives the form values when the form is submitted.
Example Usage:
import React from 'react';
import DynamicForm from 'samples-lib-react';
const App: React.FC = () => {
  const handleSubmit = (values: { [key: string]: any }) => {
    console.log('Form values:', values);
  };
  
  const fields = [
    {
      name: 'email',
      label: 'Email',
      type: 'email',
      validation: (value: string) => value.includes('@') ? null : 'Invalid email',
      className: 'input-email', // Adicionando classe CSS para estilização
    },
    {
      name: 'password',
      label: 'Password',
      type: 'password',
      validation: (value: string) => value.length >= 6 ? null : 'Password too short',
      className: 'input-password', // Adicionando classe CSS para estilização
    },
  ];
  return <DynamicForm fields={fields} onSubmit={handleSubmit} />;
};The FadeIn component animates its children by fading them in.
Props:
- children: The content to animate.
- duration: The duration of the animation in milliseconds (default: 500).
- delay: The delay before the animation starts in milliseconds (default: 0).
Example Usage:
import React from 'react';
import FadeIn from 'samples-lib-react/components/Animations/FadeIn';
const App: React.FC = () => {
  return (
    <FadeIn duration={1000} delay={500}>
      <h1>Hello, World!</h1>
    </FadeIn>
  );
};The SlideUp component animates its children by sliding them up from an initial offset.
Props:
- children: The content to animate.
- duration: The duration of the animation in milliseconds (default: 500).
- delay: The delay before the animation starts in milliseconds (default: 0).
- initialOffset: The initial offset for the animation (default: '100%').
Example Usage:
import React from 'react';
import SlideUp from 'samples-lib-react/components/Animations/SlideUp';
const App: React.FC = () => {
  return (
    <SlideUp duration={1000} delay={500} initialOffset="50%">
      <h1>Welcome to the SlideUp Animation</h1>
    </SlideUp>
  );
};<DynamicForm />
- fields: { name: string, label: string, type: string, validation: (value: any) => string | null }[]
- onSubmit: (values: { [key: string]: any }) => void
<FadeIn />
- children: React.ReactNode
- duration: number(default: 500)
- delay: number(default: 0)
<SlideUp />
- children: React.ReactNode
- duration: number(default: 500)
- delay: number(default: 0)
- initialOffset: string(default: '100%')
Validation Functions
The library provides several utility functions for validation and formatting:
- validateEmail(email: string): string | null
- validateRequired(value: any): string | null
- validatePassword(password: string): string | null
- validateUsername(username: string): string | null
- validateDate(date: string): string | null
- validatePhoneNumber(phoneNumber: string): string | null
- validateAndFormatPhoneNumber(number: string, countryCode: CountryCode): { valid: boolean, formatted: string | null, error: string | null }
- validateAngolanBI(bi: string): string | null
Example Usage:
import { validateEmail, validatePassword, validateAndFormatPhoneNumber, validateAngolanBI } from 'samples-lib-react/utils/validators';
const emailError = validateEmail('[email protected]');
const passwordError = validatePassword('Passw0rd!');
const phoneValidation = validateAndFormatPhoneNumber('+1234567890', 'US');
const biError = validateAngolanBI('123456789BA001');
console.log(emailError); // null if valid, or an error message
console.log(passwordError); // null if valid, or an error message
console.log(phoneValidation); // { valid: true, formatted: '+1 234 567-890', error: null }
console.log(biError); // null if valid, or an error message<DynamicForm />
- fields: { name: string, label: string, type: string, validation: (value: any) => string | null }[]
- onSubmit: (values: { [key: string]: any }) => void
<FadeIn />
- children: React.ReactNode
- duration: number(default: 500)
- delay: number(default: 0)
<SlideUp />
- children: React.ReactNode
- duration: number(default: 500)
- delay: number(default: 0)
- initialOffset: string(default: '100%')
validateEmail(email: string): string | null
Validates an email address.
validateRequired(value: any): string | null
Checks if a field is required and not empty.
validatePassword(password: string): string | null
Validates a password based on length, character types, and special characters.
validateUsername(username: string): string | null
Validates a username based on allowed characters and length.
validateDate(date: string): string | null
Validates a date in the format YYYY-MM-DD.
validatePhoneNumber(phoneNumber: string): string | null
Validates a phone number in E.164 format.
validateAndFormatPhoneNumber(number: string, countryCode: CountryCode): { valid: boolean, formatted: string | null, error: string | null }
Validates and formats phone numbers for supported country codes.
validateAngolanBI(bi: string): string | null
Validates an Angolan ID card number.
We welcome contributions to improve the library. To contribute:
- Fork the repository.
- Create a new branch for your changes.
- Make your changes and test thoroughly.
- Submit a pull request with a detailed description of your changes.
For more detailed contributing guidelines, please refer to CONTRIBUTING.md.
To run tests, use:
npm testOr:
yarn testEnsure that all tests pass before submitting changes.
This library is licensed under the MIT License.
For questions or support, please reach out to [email protected] or open an issue on the GitHub repository.
See CHANGELOG.md for the latest updates and version changes.
We welcome contributions to improve the library. To contribute:
- Fork the repository.
- Create a new branch for your changes.
- Make your changes and test thoroughly.
- Submit a pull request with a detailed description of your changes.
For more detailed contributing guidelines, please refer to CONTRIBUTING.md.
To run tests, use:
npm testOr:
yarn testEnsure that all tests pass before submitting changes.
This library is licensed under the MIT License.
For questions or support, please reach out to [email protected] or open an issue on the GitHub repository.
See CHANGELOG.md for the latest updates and version changes.
Esse README fornece uma visão geral completa e útil para qualquer usuário desta biblioteca.