I'm not sure if you're asking why deep copies are useful or something else.
Maybe you're handing over your data to a library developed by someone else and you want to make sure the library cannot mutate your original data, so you opt to pass a deep copy instead.
Or maybe you are the author of said library and you want to make sure you preserve the original data so you copy it on input rather than on output.
There are many situations where deep-copying is useful but I agree that you should use the simplest pattern that works for your use-case.
if "current" is a deep object here and contains other objects/arrays, you risk that wherever you are sending this shallow copy will mutate those deeper values and potentially mess things up for the code where "current" came from.
Maybe it's not a situation that comes up often, but it would be fairly hard to debug and guarding yourself against mysterious problems in advance is always neat.
You could make the same argument backwards though - many people may find it easier to do deep copies rather than throwing extra software they might not necessarily be familiar with.
Maybe you're handing over your data to a library developed by someone else and you want to make sure the library cannot mutate your original data, so you opt to pass a deep copy instead. Or maybe you are the author of said library and you want to make sure you preserve the original data so you copy it on input rather than on output.
There are many situations where deep-copying is useful but I agree that you should use the simplest pattern that works for your use-case.