Skip to content
This repository was archived by the owner on Apr 12, 2024. It is now read-only.

angular.copy behaves differently in iOS devices #16152

Closed
1 of 3 tasks
mcenkbatman opened this issue Aug 7, 2017 · 2 comments
Closed
1 of 3 tasks

angular.copy behaves differently in iOS devices #16152

mcenkbatman opened this issue Aug 7, 2017 · 2 comments

Comments

@mcenkbatman
Copy link

I'm submitting a ...

  • bug report
  • feature request
  • other (Please do not submit support requests here (see above))

Current behavior:

I am using angular.copy function in one of my projects in a function I use for file uploading. This project is being used in both mobile and desktop. I figured out that in iOS devices (I only tested it with iOS 10) angular.copy doesn't copy the files property of input element on neither Safari nor Chrome appropriately. It works perfect with other platforms like Android Chrome and MacOS safari and chrome
Expected / new behavior:

angular.copy should behave similary on iOS browsers as would behave in Android browsers

Minimal reproduction of the problem with instructions:

Here is a plunker , demonstrating length of files of input element before and after copy. Please try it on an iOS device to see the bug. http://plnkr.co/edit/7EBbitlnY8TRL7dD2QUe

Angular version: 1.4.x

Browser: [Mobile Chrome 59 | iOS 10 Safari ]

only on iOS devices

Anything else:

@mcenkbatman mcenkbatman changed the title angular.copy behaves different in iOS devices angular.copy behaves differently in iOS devices Aug 7, 2017
@frederikprijck
Copy link
Contributor

frederikprijck commented Aug 7, 2017

This doesn't look like a direct issue with AngularJS. As you're providing an HTML node, this code is going to be triggered when copying: https://github.com/angular/angular.js/blob/master/src/Angular.js#L1010

This is making use of Node.cloneNode, which looks like to have issues on iOS.

You can try it by running this fork on IOS: http://plnkr.co/edit/yal7FE7bBnMhhddwtvLp?p=preview (I added an alert when running Node.cloneNode)

Make sure to read #14352 as well.

@gkalpak gkalpak closed this as completed Aug 7, 2017
@gkalpak
Copy link
Member

gkalpak commented Aug 7, 2017

(As explained in #14352 (comment), angular.copy() does not (and will not) handle all possible edge-cases. Its primary purpose is facilitating AngularJS's internal needs.)

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

No branches or pull requests

3 participants