Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

i am gettting issue when i go in mobile screen that time i have component inside ResizableAndDraggable component its not working #940

Open
st4rkjatt opened this issue May 1, 2024 · 2 comments

Comments

@st4rkjatt
Copy link

import React, { useState, useEffect } from 'react';
import ResizableAndDraggable from './components/ResizableAndDraggable';
import { InputField } from './components/InputField';
import './App.css'
import { ToastContainer } from 'react-toastify';
import 'react-toastify/dist/ReactToastify.css';
import { useDispatch, useSelector } from 'react-redux';
import { GetAllUserSliceAction, UserEditSliceAction, UserSliceAction } from './reduxToolkit/slice/userSlice';

function debounce(fn, ms) {
let timer
return _ => {
clearTimeout(timer)
timer = setTimeout(_ => {
timer = null
fn.apply(this, arguments)
}, ms)
};
}

const App = () => {
// Initialize scale for resizing
const scale = 1;

// State for window size
const [windowSize, setWindowSize] = useState({
width: window.innerWidth,
height: window.innerHeight,
});

// State for form inputs
const [form, setForm] = useState({ name: '', email: '' });

// State for all users
const [isEdit, setIsEdit] = useState(false);

// Redux dispatch
const dispatch = useDispatch();

// Redux selector to get data from store
const result = useSelector((state) => state.addUserReducer);

// Function to handle window resize

useEffect(() => {
// Dispatch action to get all users
dispatch(GetAllUserSliceAction());

// Handle window resize

const debouncedHandleResize = debounce(function handleResize() {
  setWindowSize({
    width: window.innerWidth,
    height: window.innerHeight,
  });
}, 1000)

// Add event listener for window resize
window.addEventListener('resize', debouncedHandleResize);

// Cleanup on component unmount
return () => {
  window.removeEventListener('resize', debouncedHandleResize);
};

},[]);

// Function to handle input change
const onChange = (e) => {
setForm({ ...form, [e.target.name]: e.target.value });
}

// Function to handle form submission
const handleSubmit = (e) => {
e.preventDefault();

// Dispatch action based on whether it's an edit or add operation
if (isEdit) {
  dispatch(UserEditSliceAction(form));
  setIsEdit(false);
  setForm({ name: '', email: '' });
} else {
  dispatch(UserSliceAction(form));
  setForm({ name: '', email: '' });
}

}

// Function to handle edit button click
const handleClick = (user) => {
setIsEdit(true);
setForm(user);
}

// Return JSX
return (
<>


{/* First resizable and draggable component /}
<ResizableAndDraggable
id={1}
initialSize={{ width: windowSize.width / 5, height: windowSize.height / 3 }}
initialPosition={{ x: windowSize.width / 10, y: windowSize.height / 20 }}
scale={scale}
>
{/
Content for the first component */}


Add Count : {result.count ? result.count.addCount : 0}


Edit Count : {result.count ? result.count.updateCount : 0}


    {/* Second resizable and draggable component */}
    <ResizableAndDraggable
      id={2}
      initialSize={{ width: windowSize.width / 1.9, height: windowSize.height / 3 }}
      initialPosition={{ x: windowSize.width / 3, y: windowSize.height / 20 }}
      scale={scale}
    >
      {/* Form for adding/editing users */}
      <form className="max-w-lg max-h-full mx-auto bg-white rounded-md px-5 py-1 grid" onSubmit={handleSubmit}>
        <h2 className='text-sm sm:text-xl text-center font-semibold text-black'>Add User</h2>
        <InputField label={"Name"} name={"name"} type={"text"} placeholder={"Enter your name"} required={true} value={form.name} onChange={onChange} />
        <InputField label={"Email"} name={"email"} type={"email"} placeholder={"Enter your email"} required={true} value={form.email} onChange={onChange} />
        <div className='text-center'>
          <button type="submit" className="text-white bg-blue-700 hover:bg-blue-800 focus:ring-4 focus:outline-none focus:ring-blue-300 sm:font-medium rounded-lg text-sm w-full sm:w-auto px-2 sm:px-5 p-1 sm:p-1.5 lg:py-2 text-center dark:bg-blue-600 dark:hover:bg-blue-700 dark:focus:ring-blue-800">
            {isEdit ? "Edit" : "Add"}
          </button>
        </div>
      </form>
    </ResizableAndDraggable>

    {/* Third resizable and draggable component */}
    <ResizableAndDraggable
      id={3}
      initialSize={{ width: windowSize.width / 1.3, height: windowSize.height / 2 }}
      initialPosition={{ x: windowSize.width / 10, y: (windowSize.height / 2.2) }}
      scale={scale}
    >
      {/* Table for displaying user data */}
      <div className="relative overflow-y-auto max-h-full mx-auto shadow-md sm:rounded-lg">
        <div className="overflow-x-auto">
          <table className="w-full text-sm text-left rtl:text-right text-gray-500 dark:text-gray-400">
            <thead className="text-xs text-gray-700 uppercase bg-gray-50 dark:bg-gray-700 dark:text-gray-400">
              <tr>
                <th scope="col" className="px-6 py-3">
                  Name
                </th>
                <th scope="col" className="px-6 py-3">
                  Email
                </th>
                <th scope="col" className="px-6 py-3">
                  Created At
                </th>
                <th scope="col" className="px-6 py-3">
                  <span className="">Action</span>
                </th>
              </tr>
            </thead>
            <tbody className="divide-y divide-gray-200 dark:divide-gray-700">
              {/* Map over user data to display in table */}
              {result.result && result.result.map((user, index) => {
                return (
                  <tr key={index} className="bg-white hover:bg-gray-50 dark:bg-gray-800 dark:hover:bg-gray-700">
                    <th scope="row" className="px-6 py-4 font-medium text-gray-900 whitespace-nowrap dark:text-white">
                      {user.name}
                    </th>
                    <td className="px-6 py-4">
                      {user.email}
                    </td>
                    <td className="px-6 py-4">
                      {user.createdAt}
                    </td>
                    <td className="px-6 py-4">
                      <a href="#" className="font-medium text-blue-600 dark:text-blue-500 hover:underline" onClick={() => { handleClick(user) }}>Edit</a>
                    </td>
                  </tr>
                )
              })}
            </tbody>
          </table>
        </div>
      </div>
    </ResizableAndDraggable>
  </div>
</>

);
};

export default App;

// and this is my reusable component
import React, { useState } from 'react';
import { Rnd } from 'react-rnd';

const ResizableAndDraggable = ({ initialSize, initialPosition, onLayoutChange, scale, children }) => {
// State to manage the size of the resizable component
const [rndSize, setRndSize] = useState(initialSize);

// State to manage the position of the draggable component
const [rndPosition, setRndPosition] = useState(initialPosition);

// Function to handle resizing of the component
const handleResize = (e, direction, ref, delta, position) => {
// Update the size state based on the new size
const newSize = {
width: ref.style.width,
height: ref.style.height,
};
setRndSize(newSize);
};

// Function to handle dragging of the component
const handleDrag = (e, d) => {
// Update the position state based on the new position
setRndPosition({ x: d.x, y: d.y });
};

return (
<Rnd
className='border-[1px] border-white-400 bg-slate-100/50 rounded-md h-full'
bounds="parent"
draggable
lockAspectRatio={false}
// onLayoutChange={onLayoutChange} // You can uncomment this if needed
onResize={handleResize}
onDrag={handleDrag}
resizeHandleStyles={{
bottomRight: {
bottom: '20px',
right: '10px',
cursor: 'bottom',
width: '16px',
height: '16px',
},
}}
size={{
// Adjust size based on the scale factor
width: rndSize.width * scale,
height: rndSize.height * scale,
}}
position={rndPosition}
>
{children}

);
};

export default ResizableAndDraggable;
and this is live link https://662ad77ff6a679254276f9b4--polite-buttercream-92ca7d.netlify.app/# and this is my git repo
https://github.com/st4rkjatt/dummyFronted

@st4rkjatt
Copy link
Author

st4rkjatt commented May 1, 2024

I wanted to make this feature available on all devices, but I was unsuccessful. On Android devices, I am unable to add or delete items, and the on-change function only works during drag and resize operations.

@dufferzz
Copy link

Try using the "cancel" prop and add the corrosponding classname/selector on your form submit buttons to prevent react-rnd from triggering onPress from those elements.

I had the same issue [clicky things not onClicking, just trying to drag] on iPad but everything worked fine on PC.

<ResizableAndDraggable
      id={2}
cancel=".cancel"
[...]
/>
<Button className="cancel" type="submit">Submit</Button>

From the docs:
cancel?: string;
The cancel property disables specifies a selector to be used to prevent drag initialization (e.g. .body).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants