/**
* <a href="http://www.openolat.org">
* OpenOLAT - Online Learning and Training</a><br>
* <p>
* Licensed under the Apache License, Version 2.0 (the "License"); <br>
* you may not use this file except in compliance with the License.<br>
* You may obtain a copy of the License at the
* <a href="http://www.apache.org/licenses/LICENSE-2.0">Apache homepage</a>
* <p>
* Unless required by applicable law or agreed to in writing,<br>
* software distributed under the License is distributed on an "AS IS" BASIS, <br>
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. <br>
* See the License for the specific language governing permissions and <br>
* limitations under the License.
* <p>
* Initial code contributed and copyrighted by<br>
* frentix GmbH, http://www.frentix.com
* <p>
*/
package org.olat.core.gui.control.generic.breadcrumb;
import org.olat.core.gui.UserRequest;
import org.olat.core.gui.control.WindowControl;
import org.olat.core.gui.control.controller.BasicController;
/**
* <h3>Description:</h3>
* This abstract class serves as a base for controllers that can be used in a
* bread crumb path navigation controller. It provides methods to activate and
* deactivate child controllers.
* <p>
* Initial Date: 09.09.2008 <br>
*
* @author Florian Gnaegi, frentix GmbH, http://www.frentix.com
*/
public abstract class CrumbBasicController extends BasicController implements CrumbController {
private BreadCrumbController breadCrumbCtr;
private CrumbController childCrumbCtr;
/**
* Constructor inherited from basic controller
* @param ureq
* @param control
*/
protected CrumbBasicController(UserRequest ureq, WindowControl control) {
super(ureq, control);
}
/* (non-Javadoc)
* @see org.olat.core.gui.control.generic.breadcrumb.CrumbController#getCrumbLinkText()
*/
public abstract String getCrumbLinkText();
/* (non-Javadoc)
* @see org.olat.core.gui.control.generic.breadcrumb.CrumbController#getCrumbLinkHooverText()
*/
public abstract String getCrumbLinkHooverText();
/*
* (non-Javadoc)
* @see org.olat.core.gui.control.generic.breadcrumb.CrumbController#getChildCrumbController()
*/
public CrumbController getChildCrumbController() {
return childCrumbCtr;
}
/*
* (non-Javadoc)
* @see org.olat.core.gui.control.generic.breadcrumb.CrumbController#setBreadCrumbController(org.olat.core.gui.control.generic.breadcrumb.BreadCrumbController)
*/
public void setBreadCrumbController(BreadCrumbController breadCrumbCtr) {
this.breadCrumbCtr = breadCrumbCtr;
}
/*
* (non-Javadoc)
* @see org.olat.core.gui.control.generic.breadcrumb.CrumbController#activateAndListenToChildCrumbController(org.olat.core.gui.control.generic.breadcrumb.CrumbController)
*/
public void activateAndListenToChildCrumbController(CrumbController childCrumbController) {
// remove old one
deactivateAndDisposeChildCrumbController();
childCrumbCtr = childCrumbController;
listenTo(childCrumbCtr); // auto cleanup
childCrumbCtr.setBreadCrumbController(this.breadCrumbCtr);
breadCrumbCtr.putToBreadCrumbStack(childCrumbCtr);
}
/*
* (non-Javadoc)
* @see org.olat.core.gui.control.generic.breadcrumb.CrumbController#deactivateAndDisposeChildCrumbController()
*/
public void deactivateAndDisposeChildCrumbController() {
if (childCrumbCtr != null) {
childCrumbCtr.deactivateAndDisposeChildCrumbController();
removeAsListenerAndDispose(childCrumbCtr);
childCrumbCtr = null;
}
}
/*
* (non-Javadoc)
* @see org.olat.core.gui.control.generic.breadcrumb.CrumbController#removeFromBreadCrumbPathAndDispose()
*/
public void removeFromBreadCrumbPathAndDispose() {
this.breadCrumbCtr.removeFromBreadCrumb(this);
}
/*
* (non-Javadoc)
* @see org.olat.core.gui.control.generic.breadcrumb.CrumbController#resetCrumbTexts()
*/
public void resetCrumbTexts() {
this.breadCrumbCtr.resetCrumbTexts();
}
}