TEAM OBJECT
A TEAM is a basic organizational object that represents a group of PROFESSIONAL OBJECT or other TEAM objects that share some common attribute (e.g. they belong to the same hospital unit)
BASIC CONCEPTS
TEAM OWNERSHIP
A TEAM belongs to one of the following groups depending on how it is created:
Root level TEAMS: Are the TEAMS created by the superadministrator of the platform, and are not owned by any other TEAM
Owned TEAMS: When a PROFESSIONAL user initiates a session in the platform, it is always working as a member of certain TEAM, which is the session’s active TEAM. If that PROFESSIONAL has administrative privileges to create other TEAMS, then the new TEAMS will be considered to be owned by the session’s active TEAM. Therefore, the new TEAMS are “Owned TEAMS”.
A owned TEAM can be administered by the members of the "owner" team with administrative roles.
Example:
Let’s suppose that a Linkcare instance is deployed in a Hospital called “BARCELONA HOSPITAL”. Then the superuser can create a root level TEAM called “BARCELONA HOSPITAL” and add a PROFESSIONAL member with administrative roles to create and manage other TEAMS.
When the administrative user of the hospital initiates a session in the platform, he will be working as a member of the “BARCELONA HOSPITAL” TEAM. if now, for example he creates a new TEAM called “CARDIOLOGY” to group the professionals of the cardiology unit, then the new “CARDIOLOGY” TEAM will be owned by the “BARCELONA HOSPITAL” TEAM (because it was the session’s active TEAM when the administrator user created it).
From now on, any user member of “BARCELONA HOSPITAL“ with privileges to manage TEAMS will have the capability of managing the “CARDIOLOGY” TEAM.
TEAM MEMBERSHIPS
Once created, a team can insert members under two different approaches: The classical administration approach, and the networked approach.
PROFESSIONAL MEMBERS
A PROFESSIONAL member is a professional (doctor, nurse, etc..) that has been invited to be part of a TEAM and has been assigned with ROLES that give him the ability to perform certain actions.
A TEAM administrator can create and administer professional members in the TEAM and assign ROLES individually to each member.
TEAM MEMBERS
In an attempt to reduce administration costs and allow mutual interaction, it is also possible to add a TEAM as member of another TEAM and assign ROLES to it. Under this approach, all the PROFESSIONALs in the new TEAM member will also be granted with the ROLES assigned to the TEAM.
Note that a PROFESSIONAL that belongs to a TEAM member will inherit the ROLES assigned to that TEAM only if he has also that ROLE in the TEAM.
Example
Let’s suppose that the TEAM “CARDIOLOGY” is added as member of the TEAM “BARCELONA HOSPITAL” with role “Case Manager”.
Let’s also suppose that the TEAM “CARDIOLOGY” contains 2 PROFESSIONALS:
“Professional A” with role “Case Manager”
“Professional B” with role “Supervisor”
In this situation, “Professional A” can act as a “Case Manager” of the “BARCELONA HOSPITAL”, because he is a “Case Manager” of the “CARDIOLOGY” TEAM, and the “CARDIOLOGY” TEAM has the role “Case Manager” as a member of “BARCELONA HOSPITAL”
Nevertheless, the “Professional B” cannot act as a “Case Manager” of “BARCELONA HOSPITAL” even though he belongs to the “CARDIOLOGY” TEAM (which has role “Case Manager” in “BARCELONA HOSPITAL”), because he is not a “Case Manager” in the “CARDIOLOGY” TEAM.
INVITATIONS
When a PROFESSIONAL or a TEAM are added as members of another TEAM, they cannot in fact be added directly (for compliance with data privacy legislation) and instead, they are “invited” to join the TEAM.
By creating an invitation, a TEAM administrator may use some basic contact information (i.e. mail address or phone number) to send an invitation request. The recipient of the invitation may accept the invitation by clicked on the invitation link, and proceed to set his or her profile settings.
Pending invitation can be monitored in the team administrator dashboard. Once accepted or declined, the action is reported to the team administrator for follow up. Pending invitations can be re-send timely until a final response is received.
REQUESTS
In the opposite direction, individual teams or users may prefer to first register in Linkcare and then request to be part of a team by issuing a membership request. Membership requests are reported to the requested team administrators who can accept or decline the membership request. If the request is accepted, the team administrator may then set the accepted member roles. Membership requests can be re-send or cancelled by the request issuer.
PRIVATE TEAMS (PRACTICE TEAMS)
A TEAM is considered a “Private Team” when it is assigned to a specific professional USER (do not mistake “assigned” with “member of”). This is used normally by doctors that have their own office where they attend the patients.
In all other aspects, a PRIVATE TEAM behaves exactly the same than any other regular TEAM. It is possible to add members, assign ROLES, etc.
A USER can have only one PRIVATE TEAM.
A PRIVATE TEAM is created automatically by means of the following API functions:
team_user_insert () : When a USER is added to an existing TEAM, it is possible to indicate that the USER should also have his own private TEAM. See the description of the function to get more details about the memberships and roles that are established between the TEAMS involved and the USER
user_set () : when the property
team_private
is set to true, a PRIVATE TEAM is created for that USER.
TEAM OBJECT PROPERTIES
PROPERTY | NAME | TYPE | DESCRIPTION | COMMENTS |
---|---|---|---|---|
NICKNAME | Nickname | TXT | The TEAM nickname is a short single-word identifier for the TEAM | A TEAM nickname must be a unique name for all the Linkcare community. The TEAM nickname can be replaced at any time |
CATEGORY | Category | CHOICE of #TEAM.CATEGORY CODES | This property describes the kind of TEAM | See the TEAM CATEGORIES section for more details |
OWNER | Owner | TEAM | The TEAM owner is the original creator of the TEAM. | TEAM owners can be any another TEAM |
USER | User | USER | Used in PRIVATE TEAMS | If a USER is informed the TEAM is considered a PRIVATE TEAM of this USER |
ACCESS | Access | CHOICE of #TEAM:ACCESSES | The access property defines wether the TEAM is for private use or can include other MEMBERS |
|
PROFILE:* | Profile | PROPERTY SET | This is a set of properties that help to describe the TEAM | See the TEAM PROFILE section for more details |
ADDRESES | Addresses | [ADDRESS] | A list of ADDRESSES | |
MEMBERS | Members | [MEMBER] | A list of MEMBERS | A MEMBER can be any USER or TEAM of the Linkcare community |
CHANNELS | Contact channels | A list of CHANNEL objects | Contains the possible contact channels for a TEAM. |
TEAM PROFILE
PROPERTY | NAME | TYPE | DESCRIPTION | COMMENTS |
---|---|---|---|---|
PROFILE:NAME | Name | This is the official name of a TEAM | ||
PROFILE:DESCRIPTION | Description | A brief description of the TEAM purpose, goals, history.. | The TEAM profile is a MULTILINGUAL file. TEAM profile descriptions can be defined in multiple languages using the multi language (ML) | |
PROFILE:LOGO | Logo | The TEAM logo | The TEAM logo can be dynamically retrieved to be inserted into Linkcare's FORMS and REPORTS | |
PROFILE:BADGE | Badge | This is a small (16 x 16 pixels) badge image | The TEAM badge is used in many places at Linkcare. It allows to quickly identify the TEAM involved in some transactions, such as ADMISSIONS, TASKS or EVENTS |
TEAM CATEGORY CODES
See: TEAM.CATEGORY CODES
WEB SERVICES
The following web services allow to access and modify TEAMS:
BROWSING TEAMS:
WS | DESCRIPTION |
---|---|
Lists all teams from Linkcare ( that the user has permissions of Team Manager or Team Editor and his individual team). | |
Returns a team by name or description. | |
Lists all members of a team. | |
Returns a list of teams in which the specified team is a member. | |
Returns list of program published subscriptions for team. |
EDITING TEAMS:
WS | DESCRIPTION |
---|---|
To retrieve the information about a team or to request a empty team template | |
Gets images, addresses and contact data of team | |
Get image with type = $type . Returns content of image base64 encoded | |
Creates new team in Linkcare | |
Saves the team main details | |
Saves image ID’s, addresses and contact data of team | |
Saves image with type = $type in database and it includes in a team (if the there is team reference in the input parameters) . Content of image must be base64 encoded | |
Removes team from Linkcare and his professionals and roles | |
Get the list of possible types of a team |
MANAGING TEAMS' EVENTS:
WS | DESCRIPTION |
---|---|
Gets pending requests and invitations of a team. | |
List all events of a team/user or list of events from all the teams of the user. | |
Gets a team event (request, invitations to the team...) | |
Sets a team event ( request, invitations to the team...) | |
Inserts a team event ( request, invitations to the team...) | |
Removes an event from a team. |
MANAGING TEAMS' MEMBERS:
WS | DESCRIPTION |
---|---|
Returns a list of possible choices related with teams' membership. | |
Get the member data with roles in a team. | |
Links a user/team in a team with the selected roles. | |
Removes a member and his roles from a team. | |
Obtains a list of possible roles. |