Actions

Difference between revisions of "Developer Area/Specifications in Development/Groups revamp"

From Mahara Wiki

< Developer Area‎ | Specifications in Development
Line 62: Line 62:
 
==Mockups==
 
==Mockups==
  
The mockups only show the new functionality as seen from a normal user's perspective. Existing functionality that is only available when logged in as an admin or when certain admin settings are made has not been included in here, e.g.
+
===Create / edit a group===
  
* choosing a group category
+
Depending on the role that a user has on Mahara, he may not see everything.
* allowing to auto-add new users to a group
 
  
When a group is created, its group type determines a number of default settings. Only those that are variable (in the table above labeled "a") are displayed instead of displaying all possible settings from the table above.
+
[[Image:group_01_create_edit.png|group_01_create_edit.png|600px]]
  
<div id="section_5">
+
===Invite others===
  
===Create group===
+
[[Image:group_02_group_dashboard.png|group_02_group_dashboard.png|600px]]
  
[[Image:group_01_create.png|group_01_create.png|600px]]
+
[[Image:group_03_invite_friends.png|group_03_invite_friends.png|600px]]
  
</div><div id="section_6">
+
[[Image:group_04_suggest_friends.png|group_04_suggest_friends.png|600px]]
  
===Edit group settings===
+
[[Image:group_05_add_invite_others.png|group_05_add_invite_others.png|600px]]
  
If this screen can be implemented dynamically in screen 1 then this would be preferable.
+
===Find groups===
  
[[Image:group_02_settings_open.png|group_02_settings_open.png|600px]]
+
If an admin with staff rights allows for hiding a group on the "Finds Group" page, it will not be shown.
  
[[Image:group_02_settings_closed.png|group_02_settings_closed.png|600px]]
+
[[Image:group_06_find_groups.png|groups_06_find_groups.png|600px]]
 
 
[[Image:group_02_settings_private.png|group_02_settings_private.png|600px]]
 
 
 
</div><div id="section_7">
 
 
 
===Edit access===
 
 
 
[[Image:group_03_share.png|group_03_share.png|600px]]
 
 
 
</div><div id="section_8">
 
 
 
===Find Groups page===
 
 
 
[[Image:group_04_find_groups.png|group_04_find_groups.png|600px]]
 
 
 
</div><div id="section_9">
 
 
 
===Group dashboard of a closed group===
 
 
 
[[Image:group_05_group_dashboard.png|group_05_group_dashboard.png|600px]]
 
 
 
The "invite others" button can also be located on the "Members" tab. It appears directly on the group dashboard so that members can invite others easily without another mouse click.
 
 
 
</div><div id="section_10">
 
 
 
===Invite non-members screen===
 
 
 
This screen appears when a member (not an admin) clicks on "Invite others" when that is enabled in a group. From this screen they can invite their friends only. They can also send group invitations to other users via the individual portfolio pages. There, they don't have to be friends.
 
 
 
An admin can invite multiple other users - no matter whether they are his friends or not and no matter the group type - from the "Members" tab.
 
 
 
[[Image:group_06_invite_friends.png|group_06_invite_friends.png|600px]]
 
 
 
</div></div><div id="section_11">
 
  
 
==Migration of existing groups==
 
==Migration of existing groups==
  
Groups that have been created prior to the introduction of the fewer group types need to be migrated. Depending on the existing group type, they will have additional settings to the default ones in the new group types.
+
Groups that already exist need to be migrated. Depending on the existing group type, they will have certain settings.
  
* Open membership group becomes an open group.
 
* Invite only group becomes a closed group.
 
* Request membership group becomes a closed group with the additional setting that users are allowed to request membership.
 
* Course request membership group becomes a private group with the setting that users can request membership.
 
* Course controlled membership group becomes a private group.
 
* Standard controlled membership group becomes a private group.
 
  
</div>
 
  
 
==Other things==
 
==Other things==

Revision as of 16:40, 9 July 2011

Proposal for changes to the groups (post Mahara 1.4 release)

Introduction

Groups are an integral part of Mahara. They can be used for collaborative work and learners have the possibility to engage in forum discussions, create pages together which they can then share with other Mahara users or put them into their own portfolios at the end of group work. They can also share artefacts which they use in the group pages.

Teachers can use groups to give feedback to learners and to lock down portfolios for assessment purposes.

With the growth of the user base of Mahara, groups are being used in many different ways to suit the needs of individual institutions. Therefore, re-thinking group types, making it easier to create the right group for an activity and to allow for more flexibility of who can do what in a group has become necessary.

The current group types (up to Mahara 1.4) are often exclusive of certain functionalities that would be desirable to have across the board all groups. Therefore, a consolidation of group types with the choice to select options instead of another group type seems to be a possible solution.

Groups and desired functionalities have been discussed in the following places:

The following proposal attempts to bring these discussions together to serve as basis for re-writing the groups.

Permission to set up groups

The image shows which controls site admins and institution admins should have in regard to the creation of groups. From an administrative point of view, institution admins should have most rights to allow them to tailor Mahara to their own institution's needs instead of being dependent on what a site admin decides. Thus, only basic guidelines are set by the site admin.

group_creation.png


Group settings

The role a user has on Mahara determines the settings that he can or cannot choose. For example, so called closed or private groups can only be created by institution or site staff to mimic the behavior of the current course groups.

Normal user

A normal user who is an admin of a group can allow the following:

  • Membership
    • users can join the group
    • group members can invite friends who then join immediately when they agree ("organic groups")
    • group members can suggest the group to friends who then request membership
    • users can request membership
  • Page creation
    • members can create pages
    • members can edit pages

An admin can always:

  • invite single and multiple people at once into a group
  • lock admin-created pages
  • allow public forums in a group if that feature is enabled site-wide

Staff user

If a user has the staff role on Mahara (either site or institution level), he can allow the following in addition to what a normal user can do:

  • hide group members from non-members
  • hide group members from group members and only show admin and tutor
  • hide the group on the "Find Groups" page
  • admin can add users to the group
  • admin can prevent members from leaving the group (controlled membership setting)
  • members can submit pages

Mockups

Create / edit a group

Depending on the role that a user has on Mahara, he may not see everything.

group_01_create_edit.png

Invite others

group_02_group_dashboard.png

group_03_invite_friends.png

group_04_suggest_friends.png

group_05_add_invite_others.png

Find groups

If an admin with staff rights allows for hiding a group on the "Finds Group" page, it will not be shown.

groups_06_find_groups.png

Migration of existing groups

Groups that already exist need to be migrated. Depending on the existing group type, they will have certain settings.


Other things

A couple of things in relation to groups are mentioned on [1]:

  • Notify a user when he has been added to a group.
  • Notify a user when one of his groups has been deleted.