Skip to content
Snippets Groups Projects
Commit f3db2da3 authored by srosse's avatar srosse
Browse files

Merge OpenOLAT 10.3 to OpenOLAT default branch with a16ff2d80256d3695c8c5c2bec9f96437f94ac50

parents 2a63309a f4bbed11
No related branches found
No related tags found
No related merge requests found
Showing
with 53 additions and 40 deletions
...@@ -32,7 +32,7 @@ FileResource.WIKI=Wiki ...@@ -32,7 +32,7 @@ FileResource.WIKI=Wiki
FileResource.XLS=Excel FileResource.XLS=Excel
FolderModule=Ordner FolderModule=Ordner
Forum=Forum Forum=Forum
GroupTask=Gruppenaufgabe GroupTask=Aufgabe
Inbox=Inbox Inbox=Inbox
EPStructuredMap=ePortfolio EPStructuredMap=ePortfolio
InfoMessage=Mitteilungen InfoMessage=Mitteilungen
......
...@@ -33,7 +33,7 @@ FileResource.WIKI=Wiki ...@@ -33,7 +33,7 @@ FileResource.WIKI=Wiki
FileResource.XLS=Excel FileResource.XLS=Excel
FolderModule=Folder FolderModule=Folder
Forum=Forum Forum=Forum
GroupTask=Group task GroupTask=Task
Inbox=Inbox Inbox=Inbox
InfoMessage=Messages InfoMessage=Messages
LibrarySite=Library LibrarySite=Library
......
...@@ -33,7 +33,7 @@ FileResource.WIKI=Wiki ...@@ -33,7 +33,7 @@ FileResource.WIKI=Wiki
FileResource.XLS=Excel FileResource.XLS=Excel
FolderModule=Dossier FolderModule=Dossier
Forum=Forum Forum=Forum
GroupTask=Devoir de groupe GroupTask=Devoir
Inbox=Bo\u00EEte de r\u00E9ception Inbox=Bo\u00EEte de r\u00E9ception
InfoMessage=Communications InfoMessage=Communications
LibrarySite=Biblioth\u00E8que LibrarySite=Biblioth\u00E8que
......
...@@ -33,7 +33,7 @@ FileResource.WIKI=Wiki ...@@ -33,7 +33,7 @@ FileResource.WIKI=Wiki
FileResource.XLS=Excel FileResource.XLS=Excel
FolderModule=Pasta FolderModule=Pasta
Forum=F\u00F3rum Forum=F\u00F3rum
GroupTask=Tarefa de grupo GroupTask=Tarefa
Inbox=Caixa de entrada Inbox=Caixa de entrada
InfoMessage=Mensagens InfoMessage=Mensagens
LibrarySite=Biblioteca LibrarySite=Biblioteca
......
...@@ -38,6 +38,7 @@ import org.olat.core.gui.components.velocity.VelocityContainer; ...@@ -38,6 +38,7 @@ import org.olat.core.gui.components.velocity.VelocityContainer;
import org.olat.core.gui.control.Event; import org.olat.core.gui.control.Event;
import org.olat.core.gui.control.WindowControl; import org.olat.core.gui.control.WindowControl;
import org.olat.core.gui.control.controller.BasicController; import org.olat.core.gui.control.controller.BasicController;
import org.springframework.beans.factory.annotation.Autowired;
/** /**
* Description: <br> * Description: <br>
...@@ -50,13 +51,13 @@ public class ContextualSubscriptionController extends BasicController { ...@@ -50,13 +51,13 @@ public class ContextualSubscriptionController extends BasicController {
private VelocityContainer myContent; private VelocityContainer myContent;
private Link subscribeButton; private Link subscribeButton;
private Link unsubscribeButton; private Link unsubscribeButton;
private Panel allPanel;
private Panel detailsPanel;
private NotificationsManager notifManager;
private SubscriptionContext subscriptionContext; private SubscriptionContext subscriptionContext;
private boolean isSubscribed; private boolean isSubscribed;
private final PublisherData publisherData; private final PublisherData publisherData;
@Autowired
private NotificationsManager notifManager;
/** /**
* @param ureq * @param ureq
* @param subscriptionContext * @param subscriptionContext
...@@ -73,9 +74,6 @@ public class ContextualSubscriptionController extends BasicController { ...@@ -73,9 +74,6 @@ public class ContextualSubscriptionController extends BasicController {
putInitialPanel(new Panel("empty:nosubscription")); putInitialPanel(new Panel("empty:nosubscription"));
return; return;
} }
detailsPanel = new Panel("subscription_detail");
allPanel = new Panel("subscription_all");
subscribeButton = LinkFactory.createCustomLink("command.subscribe", "command.subscribe", "off", Link.LINK, myContent, this); subscribeButton = LinkFactory.createCustomLink("command.subscribe", "command.subscribe", "off", Link.LINK, myContent, this);
subscribeButton.setCustomEnabledLinkCSS("o_noti_subscribe_link o_button_toggle"); subscribeButton.setCustomEnabledLinkCSS("o_noti_subscribe_link o_button_toggle");
...@@ -87,14 +85,11 @@ public class ContextualSubscriptionController extends BasicController { ...@@ -87,14 +85,11 @@ public class ContextualSubscriptionController extends BasicController {
unsubscribeButton.setIconRightCSS("o_icon o_icon_toggle"); unsubscribeButton.setIconRightCSS("o_icon o_icon_toggle");
unsubscribeButton.setTitle("command.unsubscribe"); unsubscribeButton.setTitle("command.unsubscribe");
notifManager = NotificationsManager.getInstance();
// if subscribed, offer a unsubscribe button and vica versa. // if subscribed, offer a unsubscribe button and vica versa.
isSubscribed = notifManager.isSubscribed(ureq.getIdentity(), subscriptionContext); isSubscribed = notifManager.isSubscribed(ureq.getIdentity(), subscriptionContext);
updateUI(); updateUI();
myContent.put("detailsPanel", detailsPanel); putInitialPanel(myContent);
allPanel.setContent(myContent);
putInitialPanel(allPanel);
} }
public boolean isSubscribed() { public boolean isSubscribed() {
......
<div id="$r.getCId()" class="o_noti"> <div id="$r.getCId()" class="o_noti">
<a href="javascript:$r.contextHelpJSCommand("Personal Menu#_abonnements")" title="$r.translateInAttribute("help.button")" class="o_label"> <a href="javascript:$r.contextHelpJSCommand("Personal Menu#_abonnements")" title="$r.translateInAttribute("help.button")" class="o_label">
<i class="o_icon o_icon_notification"></i> <i class="o_icon o_icon_notification"></i> <span>$r.translate("actions.title")</span></a>
<span>
$r.translate("actions.title")
</span>
</a>
#if ($subscribed) #if ($subscribed)
$r.render("command.unsubscribe") $r.render("command.unsubscribe")
#else #else
......
<div class="o_iframedisplay"> <div class="o_iframedisplay">
<script type="text/javascript"> <script type="text/javascript">
/* <![CDATA[ */ /* <![CDATA[ */
window.open("${mapperUri}?$r.uuid", "_win_$sourcedId", "status=1,toolbar=1,location=1,menubar=1,resizable=1#if($width!='auto'),width=${width}#end #if($height!='auto'),height=${height}#{end}"); window.open("${mapperUri}?$r.uuid", "_win_$sourcedId", "status=1,toolbar=1,location=1,menubar=1,resizable=1,scrollbars=yes#if($width!='auto'),width=${width}#end #if($height!='auto'),height=${height}#{end}");
/* ]]> */ /* ]]> */
</script> </script>
</div> </div>
......
...@@ -295,8 +295,6 @@ public class GTAManagerImpl implements GTAManager, DeletableGroupData { ...@@ -295,8 +295,6 @@ public class GTAManagerImpl implements GTAManager, DeletableGroupData {
SubscriptionContext sc = new SubscriptionContext("CourseModule", courseEnv.getCourseResourceableId(), cNode.getIdent()); SubscriptionContext sc = new SubscriptionContext("CourseModule", courseEnv.getCourseResourceableId(), cNode.getIdent());
return sc; return sc;
} }
@Override @Override
public List<BusinessGroup> filterBusinessGroups(List<BusinessGroup> groups, GTACourseNode cNode) { public List<BusinessGroup> filterBusinessGroups(List<BusinessGroup> groups, GTACourseNode cNode) {
......
...@@ -78,6 +78,7 @@ public abstract class GTAAbstractController extends BasicController { ...@@ -78,6 +78,7 @@ public abstract class GTAAbstractController extends BasicController {
protected final ModuleConfiguration config; protected final ModuleConfiguration config;
protected final RepositoryEntry courseEntry; protected final RepositoryEntry courseEntry;
protected final boolean withSubscription;
protected final PublisherData publisherData; protected final PublisherData publisherData;
protected final SubscriptionContext subsContext; protected final SubscriptionContext subsContext;
...@@ -104,22 +105,23 @@ public abstract class GTAAbstractController extends BasicController { ...@@ -104,22 +105,23 @@ public abstract class GTAAbstractController extends BasicController {
protected UserCourseInformationsManager userCourseInformationsManager; protected UserCourseInformationsManager userCourseInformationsManager;
public GTAAbstractController(UserRequest ureq, WindowControl wControl, public GTAAbstractController(UserRequest ureq, WindowControl wControl,
GTACourseNode gtaNode, CourseEnvironment courseEnv, boolean withTitle, boolean withGrading) { GTACourseNode gtaNode, CourseEnvironment courseEnv, boolean withTitle, boolean withGrading, boolean withSubscription) {
this(ureq, wControl, gtaNode, courseEnv, null, null, null, withTitle, withGrading); this(ureq, wControl, gtaNode, courseEnv, null, null, null, withTitle, withGrading, withSubscription);
} }
public GTAAbstractController(UserRequest ureq, WindowControl wControl, public GTAAbstractController(UserRequest ureq, WindowControl wControl,
GTACourseNode gtaNode, CourseEnvironment courseEnv, UserCourseEnvironment userCourseEnv, boolean withTitle, boolean withGrading) { GTACourseNode gtaNode, CourseEnvironment courseEnv, UserCourseEnvironment userCourseEnv, boolean withTitle, boolean withGrading, boolean withSubscription) {
this(ureq, wControl, gtaNode, courseEnv, userCourseEnv, null, null, withTitle, withGrading); this(ureq, wControl, gtaNode, courseEnv, userCourseEnv, null, null, withTitle, withGrading, withSubscription);
} }
public GTAAbstractController(UserRequest ureq, WindowControl wControl, public GTAAbstractController(UserRequest ureq, WindowControl wControl,
GTACourseNode gtaNode, CourseEnvironment courseEnv, UserCourseEnvironment userCourseEnv, GTACourseNode gtaNode, CourseEnvironment courseEnv, UserCourseEnvironment userCourseEnv,
BusinessGroup assessedGroup, Identity assessedIdentity, boolean withTitle, boolean withGrading) { BusinessGroup assessedGroup, Identity assessedIdentity, boolean withTitle, boolean withGrading, boolean withSubscription) {
super(ureq, wControl); super(ureq, wControl);
this.withTitle = withTitle; this.withTitle = withTitle;
this.withGrading = withGrading; this.withGrading = withGrading;
this.withSubscription = withSubscription;
this.gtaNode = gtaNode; this.gtaNode = gtaNode;
this.config = gtaNode.getModuleConfiguration(); this.config = gtaNode.getModuleConfiguration();
...@@ -163,7 +165,7 @@ public abstract class GTAAbstractController extends BasicController { ...@@ -163,7 +165,7 @@ public abstract class GTAAbstractController extends BasicController {
task = gtaManager.getTask(assessedIdentity, taskList); task = gtaManager.getTask(assessedIdentity, taskList);
} }
if (subsContext != null) { if (withSubscription && subsContext != null) {
contextualSubscriptionCtr = new ContextualSubscriptionController(ureq, getWindowControl(), subsContext, publisherData); contextualSubscriptionCtr = new ContextualSubscriptionController(ureq, getWindowControl(), subsContext, publisherData);
listenTo(contextualSubscriptionCtr); listenTo(contextualSubscriptionCtr);
mainVC.put("contextualSubscription", contextualSubscriptionCtr.getInitialComponent()); mainVC.put("contextualSubscription", contextualSubscriptionCtr.getInitialComponent());
......
...@@ -160,14 +160,14 @@ public class GTAAssessmentDetailsController extends BasicController { ...@@ -160,14 +160,14 @@ public class GTAAssessmentDetailsController extends BasicController {
private void doSelectBusinessGroup(UserRequest ureq, BusinessGroup group) { private void doSelectBusinessGroup(UserRequest ureq, BusinessGroup group) {
removeAsListenerAndDispose(coachingCtrl); removeAsListenerAndDispose(coachingCtrl);
coachingCtrl = new GTACoachController(ureq, getWindowControl(), courseEnv, gtaNode, group, true, true); coachingCtrl = new GTACoachController(ureq, getWindowControl(), courseEnv, gtaNode, group, true, true, true);
listenTo(coachingCtrl); listenTo(coachingCtrl);
mainVC.put("selection", coachingCtrl.getInitialComponent()); mainVC.put("selection", coachingCtrl.getInitialComponent());
} }
private void doSelectParticipant(UserRequest ureq, Identity identity) { private void doSelectParticipant(UserRequest ureq, Identity identity) {
removeAsListenerAndDispose(coachingCtrl); removeAsListenerAndDispose(coachingCtrl);
coachingCtrl = new GTACoachController(ureq, getWindowControl(), courseEnv, gtaNode, identity, false, false); coachingCtrl = new GTACoachController(ureq, getWindowControl(), courseEnv, gtaNode, identity, false, false, true);
listenTo(coachingCtrl); listenTo(coachingCtrl);
mainVC.put("selection", coachingCtrl.getInitialComponent()); mainVC.put("selection", coachingCtrl.getInitialComponent());
} }
......
...@@ -83,13 +83,13 @@ public class GTACoachController extends GTAAbstractController { ...@@ -83,13 +83,13 @@ public class GTACoachController extends GTAAbstractController {
private UserManager userManager; private UserManager userManager;
public GTACoachController(UserRequest ureq, WindowControl wControl, CourseEnvironment courseEnv, GTACourseNode gtaNode, public GTACoachController(UserRequest ureq, WindowControl wControl, CourseEnvironment courseEnv, GTACourseNode gtaNode,
BusinessGroup assessedGroup, boolean withTitle, boolean withGrading) { BusinessGroup assessedGroup, boolean withTitle, boolean withGrading, boolean withSubscription) {
this(ureq, wControl, courseEnv, gtaNode, assessedGroup, null, withTitle, withGrading); this(ureq, wControl, courseEnv, gtaNode, assessedGroup, null, withTitle, withGrading, withSubscription);
} }
public GTACoachController(UserRequest ureq, WindowControl wControl, CourseEnvironment courseEnv, GTACourseNode gtaNode, public GTACoachController(UserRequest ureq, WindowControl wControl, CourseEnvironment courseEnv, GTACourseNode gtaNode,
Identity assessedIdentity, boolean withTitle, boolean withGrading) { Identity assessedIdentity, boolean withTitle, boolean withGrading, boolean withSubscription) {
this(ureq, wControl, courseEnv, gtaNode, null, assessedIdentity, withTitle, withGrading); this(ureq, wControl, courseEnv, gtaNode, null, assessedIdentity, withTitle, withGrading, withSubscription);
} }
/** /**
...@@ -104,8 +104,8 @@ public class GTACoachController extends GTAAbstractController { ...@@ -104,8 +104,8 @@ public class GTACoachController extends GTAAbstractController {
* @param withGrading Allow to remove the grading panel in assessment tool * @param withGrading Allow to remove the grading panel in assessment tool
*/ */
private GTACoachController(UserRequest ureq, WindowControl wControl, CourseEnvironment courseEnv, GTACourseNode gtaNode, private GTACoachController(UserRequest ureq, WindowControl wControl, CourseEnvironment courseEnv, GTACourseNode gtaNode,
BusinessGroup assessedGroup, Identity assessedIdentity, boolean withTitle, boolean withGrading) { BusinessGroup assessedGroup, Identity assessedIdentity, boolean withTitle, boolean withGrading, boolean withSubscription) {
super(ureq, wControl, gtaNode, courseEnv, null, assessedGroup, assessedIdentity, withTitle, withGrading); super(ureq, wControl, gtaNode, courseEnv, null, assessedGroup, assessedIdentity, withTitle, withGrading, withSubscription);
} }
@Override @Override
......
...@@ -23,6 +23,9 @@ import java.util.Collections; ...@@ -23,6 +23,9 @@ import java.util.Collections;
import java.util.List; import java.util.List;
import org.olat.basesecurity.BaseSecurity; import org.olat.basesecurity.BaseSecurity;
import org.olat.core.commons.services.notifications.PublisherData;
import org.olat.core.commons.services.notifications.SubscriptionContext;
import org.olat.core.commons.services.notifications.ui.ContextualSubscriptionController;
import org.olat.core.gui.UserRequest; import org.olat.core.gui.UserRequest;
import org.olat.core.gui.components.Component; import org.olat.core.gui.components.Component;
import org.olat.core.gui.components.link.Link; import org.olat.core.gui.components.link.Link;
...@@ -62,6 +65,9 @@ public class GTACoachSelectionController extends BasicController { ...@@ -62,6 +65,9 @@ public class GTACoachSelectionController extends BasicController {
private final GTACourseNode gtaNode; private final GTACourseNode gtaNode;
private final CourseEnvironment courseEnv; private final CourseEnvironment courseEnv;
protected final PublisherData publisherData;
protected final SubscriptionContext subsContext;
@Autowired @Autowired
private GTAManager gtaManager; private GTAManager gtaManager;
@Autowired @Autowired
...@@ -76,6 +82,14 @@ public class GTACoachSelectionController extends BasicController { ...@@ -76,6 +82,14 @@ public class GTACoachSelectionController extends BasicController {
mainVC = createVelocityContainer("coach_selection"); mainVC = createVelocityContainer("coach_selection");
backLink = LinkFactory.createLinkBack(mainVC, this); backLink = LinkFactory.createLinkBack(mainVC, this);
publisherData = gtaManager.getPublisherData(courseEnv, gtaNode);
subsContext = gtaManager.getSubscriptionContext(courseEnv, gtaNode);
if (subsContext != null) {
ContextualSubscriptionController contextualSubscriptionCtr = new ContextualSubscriptionController(ureq, getWindowControl(), subsContext, publisherData);
listenTo(contextualSubscriptionCtr);
mainVC.put("contextualSubscription", contextualSubscriptionCtr.getInitialComponent());
}
ModuleConfiguration config = gtaNode.getModuleConfiguration(); ModuleConfiguration config = gtaNode.getModuleConfiguration();
if(GTAType.group.name().equals(config.getStringValue(GTACourseNode.GTASK_TYPE))) { if(GTAType.group.name().equals(config.getStringValue(GTACourseNode.GTASK_TYPE))) {
List<BusinessGroup> groups; List<BusinessGroup> groups;
...@@ -157,14 +171,14 @@ public class GTACoachSelectionController extends BasicController { ...@@ -157,14 +171,14 @@ public class GTACoachSelectionController extends BasicController {
private void doSelectBusinessGroup(UserRequest ureq, BusinessGroup group) { private void doSelectBusinessGroup(UserRequest ureq, BusinessGroup group) {
removeAsListenerAndDispose(coachingCtrl); removeAsListenerAndDispose(coachingCtrl);
coachingCtrl = new GTACoachController(ureq, getWindowControl(), courseEnv, gtaNode, group, true, true); coachingCtrl = new GTACoachController(ureq, getWindowControl(), courseEnv, gtaNode, group, true, true, false);
listenTo(coachingCtrl); listenTo(coachingCtrl);
mainVC.put("selection", coachingCtrl.getInitialComponent()); mainVC.put("selection", coachingCtrl.getInitialComponent());
} }
private void doSelectParticipant(UserRequest ureq, Identity identity) { private void doSelectParticipant(UserRequest ureq, Identity identity) {
removeAsListenerAndDispose(coachingCtrl); removeAsListenerAndDispose(coachingCtrl);
coachingCtrl = new GTACoachController(ureq, getWindowControl(), courseEnv, gtaNode, identity, true, true); coachingCtrl = new GTACoachController(ureq, getWindowControl(), courseEnv, gtaNode, identity, true, true, false);
listenTo(coachingCtrl); listenTo(coachingCtrl);
mainVC.put("selection", coachingCtrl.getInitialComponent()); mainVC.put("selection", coachingCtrl.getInitialComponent());
} }
......
...@@ -91,7 +91,7 @@ public class GTAParticipantController extends GTAAbstractController { ...@@ -91,7 +91,7 @@ public class GTAParticipantController extends GTAAbstractController {
public GTAParticipantController(UserRequest ureq, WindowControl wControl, public GTAParticipantController(UserRequest ureq, WindowControl wControl,
GTACourseNode gtaNode, UserCourseEnvironment userCourseEnv) { GTACourseNode gtaNode, UserCourseEnvironment userCourseEnv) {
super(ureq, wControl, gtaNode, userCourseEnv.getCourseEnvironment(), userCourseEnv, true, true); super(ureq, wControl, gtaNode, userCourseEnv.getCourseEnvironment(), userCourseEnv, true, true, true);
} }
@Override @Override
......
$r.render("contextualSubscription") #if($r.available("contextualSubscription"))
<div class="clearfix">$r.render("contextualSubscription")</div>
#end
#if($groupName && !$groupName.isEmpty()) #if($groupName && !$groupName.isEmpty())
<h4> <h4>
......
...@@ -5,7 +5,13 @@ ...@@ -5,7 +5,13 @@
#if($r.available("list")) #if($r.available("list"))
$r.render("backLink") $r.render("backLink")
#end #end
#if($r.available("contextualSubscription"))
$r.render("contextualSubscription")
#end
$r.render("selection") $r.render("selection")
#elseif($r.available("list")) #elseif($r.available("list"))
#if($r.available("contextualSubscription"))
<div class="clearfix">$r.render("contextualSubscription")</div>
#end
$r.render("list") $r.render("list")
#end #end
\ No newline at end of file
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment