-
Notifications
You must be signed in to change notification settings - Fork 218
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
CEs dropped in flux container that are within a gridelemnts container get lost. #2075
Comments
@paul-siteway I doubt there's anything I could do about this problem. Gridelements works by overriding the I would suggest that you report this issue to the Gridelements tracker and reference this comment. It should be a relatively simple matter for Gridelements to implement a sort of condition that disables their special |
@NamelessCoder Paul sent me to this bug report to check if the idea might be working. First of all - the colPos is -1 not -99 Second the problem is not, that Gridelements is overriding something, but that Flux does not, although it would be responsible for the specific action. While the D&D action works fine, when you drag the element out of a Flux Container into a Gridelements-Container column, it is broken, when the user drags the element back into the Flux container. So Flux misses to (re)assign the necessary values to its child elements, which is something Gridelements does not have to take care of. My recommendation for @paul-siteway was to stop using both approaches at the same time, since it does not give the users any benefit but increases the possible problems. Still if they are used together, we should make sure that each container variant takes care of its children properly without interfering with the child elements of the other. |
@Bunnyfield Flux doesn't actually do any assigning of colPos values as such. Instead, it uses the core's functionality to render a standard content area with a special colPos. The colPos is extracted and assigned by the core just like any vanilla drop zone. Unless the dropzone is somehow modified, or the record's colPos value is somehow changed in a DataHandler hook (Flux does not do this) I would expect Flux to be unaffected. I see for example in Grideleements' DataHandler hook listener, that if @paul-siteway it might help us to determine the actual cause if you could provide a dump of the child content record's columns before and after the last move. |
@NamelessCoder Thanks for the quick reply and the investigation. If PreProcessFieldArray would be the culprit, we need to find out, why the drop action actually provides this key in the field array, because usually the fieldArray only contains values that have been changed in the editing form and/or during a drop or paste action. So while dropping into a Flux container I would not expect the key "tx_gridelements_container" in that field array at all. Still it could be there with a value of 0 though, to make sure it will be changed back from a positive value. - Maybe this could be part of a fix already. |
@Bunnyfield I'm just shooting from the hip here, but could the problem be that Gridelements JS is triggering and/or assigning a drop event listener recursively on every content drop-zone within a Gridelements container, rather than just on direct-child drop-zones, causing the XHR data that gets dispatched when dropping the element in a Flux column inside a Gridelements column to unexpectedly be extended to contain Maybe @paul-siteway could also check the browser's XHR log to see what data is being dispatched when dropping a content element in a Flux column within a Gridelements column. |
If this would be the case, nested Gridelements containers should have the same problem - but lets wait for some data from @paul-siteway |
TYPO3 V: 10.4.36
EXT:gridelements : 10.4.3
FluxContainerWithinGridElement.mov
The text was updated successfully, but these errors were encountered: