Rich:PopupPanel コンポーネントを使用して一部のコンテンツを表示していますが、ユーザーがそれらを最大化して復元できるようにしたいと考えています。コンポーネントのサイズ変更と配置は既に実装していますが、問題は popupPanel が最大化されている間に移動されないようにし、復元されたときにそれを許可する方法です。
これは、popupPanel の最大化と復元を担当するボタンのコードです。
<!-- language: lang-js -->
<a4j:commandLink id="maximizeRestoreButton" execute="@none"
render="@none" value="Maximize"
oncomplete="
var comp = #{rich:component(cc.attrs.popupId)};
if (comp.isMaximized) {
var rv = comp.restoreValues;
comp.moveTo(rv.top, rv.left);
comp.resize(rv.width - comp.width(), rv.height - comp.height());
comp.isMaximized = false;
} else {
var rv = new Object();
rv.top = comp.getTop();
rv.left = comp.getLeft();
rv.width = comp.width();
rv.height = comp.height();
comp.moveTo(0,0);
comp.resize(window.innerWidth - comp.width(), window.innerHeight - comp.height());
comp.isMaximized = true;
comp.restoreValues = rv;
}
return false;" />