Developer Area/Specifications in Development/Groups revamp
From Mahara Wiki
< Developer Area | Specifications in DevelopmentRevision as of 15:37, 9 July 2011 by Anitsirk
Proposal for changes to the groups (post Mahara 1.4 release)
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:
- Community access to course groups
- Feature request: Review groups with hidden membership
- Merging open / invite / request group types
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.
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.
A normal user who is an admin of a group can allow the following:
- 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
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
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.
- choosing a group category
- 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.
Edit group settings
If this screen can be implemented dynamically in screen 1 then this would be preferable.
Find Groups page
Group dashboard of a closed group
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.
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.
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.
- 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.
A couple of things in relation to groups are mentioned on :
- Notify a user when he has been added to a group.
- Notify a user when one of his groups has been deleted.