Details
Description
Case http://jira.icefaces.org/browse/ICE-2657 outlines a problem and fix for dynamically closing portlets and properly disposing of the related ICEfaces Views.
However, while doing some testing, I found that, if I put multiple instances of the same portlet on the same page with the following script added:
<script id="id1234" type="text/javascript">
//this function filters executes the callback function only if the 'e' element is included in the closed portlet
//function created to factored into a library
function filterEvent(element, callback) {
return function(p) {
var id = '_' + p.portletId + '_';
var parent = element;
while (parent) {
if (parent.id == id) {
callback();
break;
} else {
parent = parent.parentNode;
}
}
}
}
if (Liferay.Publisher) {
var e = 'id1234'.asElement();
Liferay.Publisher.subscribe('closePortlet', filterEvent(e, function() {
$element(e).findBridge().disposeAndNotify();
}));
}
</script>
closing a portlet doesn't always result in the View being disposed immediately. For example, if I put two copies of the chat portlet on the page (with the script added to the portlet content) and then attempt to close one, it may or may not dispose immediately (seems to depend which one it is - it appears to be the "first" one that was added to the page).
I put some logging into the View class to print out when an instance was created and when the dispose method was called on the instance. First I added two instance of the portlet to the page. When the page had finished reloading, I saw this.
View.View: 2
View.View: 3
So far so good - two views are created, one for each portlet. When I closed portlet view "2", nothing happened. When I closed portlet view "3", it printed out.
Disposing of View: 3
When I reloaded the page (or switched tabs or closed the browser), it immediately printed out:
Disposing of View: 2
So it seems that the disposal fired correctly from the client but didn't fully complete on the server for some reason. The good news is that it is not hanging around for the session to expire. Maybe it's related to the fact that both script instances have the same ID in the disposal script. Since we don't have an outputScript component yet (http://jira.icefaces.org/browse/ICE-2827) we may want to recommend a more programmatic solution using an outputText component to write out the script and dynamically ensure that the IDs are distinct. There are some caveats with doing this (see http://jira.icefaces.org/browse/ICE-3159).
However, while doing some testing, I found that, if I put multiple instances of the same portlet on the same page with the following script added:
<script id="id1234" type="text/javascript">
//this function filters executes the callback function only if the 'e' element is included in the closed portlet
//function created to factored into a library
function filterEvent(element, callback) {
return function(p) {
var id = '_' + p.portletId + '_';
var parent = element;
while (parent) {
if (parent.id == id) {
callback();
break;
} else {
parent = parent.parentNode;
}
}
}
}
if (Liferay.Publisher) {
var e = 'id1234'.asElement();
Liferay.Publisher.subscribe('closePortlet', filterEvent(e, function() {
$element(e).findBridge().disposeAndNotify();
}));
}
</script>
closing a portlet doesn't always result in the View being disposed immediately. For example, if I put two copies of the chat portlet on the page (with the script added to the portlet content) and then attempt to close one, it may or may not dispose immediately (seems to depend which one it is - it appears to be the "first" one that was added to the page).
I put some logging into the View class to print out when an instance was created and when the dispose method was called on the instance. First I added two instance of the portlet to the page. When the page had finished reloading, I saw this.
View.View: 2
View.View: 3
So far so good - two views are created, one for each portlet. When I closed portlet view "2", nothing happened. When I closed portlet view "3", it printed out.
Disposing of View: 3
When I reloaded the page (or switched tabs or closed the browser), it immediately printed out:
Disposing of View: 2
So it seems that the disposal fired correctly from the client but didn't fully complete on the server for some reason. The good news is that it is not hanging around for the session to expire. Maybe it's related to the fact that both script instances have the same ID in the disposal script. Since we don't have an outputScript component yet (http://jira.icefaces.org/browse/ICE-2827) we may want to recommend a more programmatic solution using an outputText component to write out the script and dynamically ensure that the IDs are distinct. There are some caveats with doing this (see http://jira.icefaces.org/browse/ICE-3159).
Issue Links
- depends on
-
ICE-3416 The content of <script> tags are being wrapped by <span> tags.
- Closed
Activity
Deryk Sinotte
created issue -
Deryk Sinotte
made changes -
Field | Original Value | New Value |
---|---|---|
Assignee | Mircea Toma [ mircea.toma ] | |
Priority | Major [ 3 ] | Minor [ 4 ] |
Mircea Toma
made changes -
Status | Open [ 1 ] | Resolved [ 5 ] |
Resolution | Fixed [ 1 ] |
Deryk Sinotte
made changes -
Ken Fyten
made changes -
Status | Resolved [ 5 ] | Closed [ 6 ] |
Assignee | Mircea Toma [ mircea.toma ] |
Adjust priority and assign to Mircea