2020-06-07 16:57:56 +12:00
< div
data-service="teams.get"
data-name="team"
2020-06-08 16:40:13 +12:00
data-event="load,teams.update,teams.deleteMembership,teams.createMembership"
2020-06-07 16:57:56 +12:00
data-param-team-id="{{router.params.id}}"
data-success="trigger"
data-success-param-trigger-events="teams.get">
< div class = "cover" >
< h1 class = "zone xl margin-bottom-large" >
< a data-ls-attrs = "href=/console/users/teams?project={{router.params.project}}" class = "back text-size-small" > < i class = "icon-left-open" > < / i > Teams< / a >
< br / >
2021-07-29 20:09:24 +12:00
< span data-ls-bind = "{{team.name}}" > < / span >
< span data-ls-if = "{{team.name|escape}} === ''" > Unknown< / span >
2020-06-07 16:57:56 +12:00
< / h1 >
< / div >
< div data-ui-modal class = "modal width-large box close" data-button-hide = "on" data-open-event = "open-json" >
2021-08-04 18:39:23 +12:00
< button type = "button" class = "close pull-end" data-ui-modal-close = "" > < i class = "icon-cancel" > < / i > < / button >
2020-06-07 16:57:56 +12:00
< h2 > JSON View< / h2 >
< div class = "margin-bottom" >
< input type = "hidden" data-ls-bind = "{{team}}" data-forms-code / >
< / div >
< button data-ui-modal-close = "" type = "button" class = "reverse" > Cancel< / button >
< / div >
< div class = "zone xl" >
< ul class = "phases clear" data-ui-phases data-selected = "{{router.params.tab}}" >
2020-06-07 19:48:06 +12:00
< li data-state = "/console/users/teams/team?id={{router.params.id}}&project={{router.params.project}}" >
2021-07-29 20:33:38 +12:00
< h2 > Overview< / h2 >
2021-08-04 18:39:23 +12:00
2020-06-07 19:48:06 +12:00
< div class = "row responsive margin-top-negative" >
2020-06-08 16:40:13 +12:00
< div class = "col span-8 margin-bottom-large" >
2021-07-29 20:33:38 +12:00
< label > < / label >
< div class = "box margin-bottom-large" >
< form
data-analytics
data-analytics-activity
data-analytics-event="submit"
data-analytics-category="console"
data-analytics-label="Update Team"
data-service="teams.update"
data-scope="sdk"
data-event="submit"
data-success="alert,trigger"
data-success-param-alert-text="Updated team successfully"
data-success-param-trigger-events="teams.update"
data-failure="alert"
data-failure-param-alert-text="Failed to update team"
data-failure-param-alert-classname="error">
< input data-ls-attrs = "id=team-id-{{team.$id}}" name = "teamId" type = "hidden" disabled data-ls-bind = "{{team.$id}}" / >
< label for = "name" > Name< / label >
< input data-ls-attrs = "id=team-name-{{team.$id}}" name = "name" type = "text" autocomplete = "off" data-ls-bind = "{{team.name}}" maxlength = "128" / >
< hr / >
< button > Update< / button >
< / form >
< / div >
< h3 class = "margin-bottom" > Members< / h3 >
2020-06-07 21:29:51 +12:00
< div
data-service="teams.getMemberships"
2020-06-08 16:40:13 +12:00
data-event="load,teams.create,teams.update,teams.delete,teams.deleteMembership,teams.createMembership"
2020-06-07 21:29:51 +12:00
data-param-team-id="{{router.params.id}}"
data-param-limit="<?php echo APP_PAGING_LIMIT ; ?> "
data-param-offset="{{router.params.offset}}"
data-param-order-type="DESC"
data-scope="sdk"
2020-06-08 16:40:13 +12:00
data-name="project-members">
2020-06-07 16:57:56 +12:00
2022-02-28 22:25:38 +13:00
< div data-ls-if = "0 == {{project-members.total}}" class = "box margin-bottom" >
2020-06-07 21:29:51 +12:00
< h3 class = "margin-bottom-small text-bold" > No Memberships Found< / h3 >
2020-06-08 20:01:11 +12:00
< p class = "margin-bottom-no" > Add your first team member to get started< / p >
2020-06-07 21:29:51 +12:00
< / div >
2022-02-28 22:25:38 +13:00
< div data-ls-if = "0 != {{project-members.total}}" >
< div class = "margin-bottom-small margin-end-small text-align-end text-size-small margin-top-negative text-fade" > < span data-ls-bind = "{{project-members.total}}" > < / span > memberships found< / div >
2020-06-08 16:40:13 +12:00
< div class = "box margin-bottom" >
< ul data-ls-loop = "project-members.memberships" data-ls-as = "member" class = "list" >
< li class = "clear" >
< form class = "pull-end"
2021-01-18 19:29:26 +13:00
data-analytics
data-analytics-activity
2020-06-08 16:40:13 +12:00
data-analytics-event="submit"
data-analytics-category="console"
data-analytics-label="Delete Team Membership"
data-service="teams.deleteMembership"
data-event="submit"
data-success="alert,trigger"
2021-10-30 05:11:35 +13:00
data-confirm="Are you sure you want to remove that user from the team?"
2020-06-08 16:40:13 +12:00
data-success-param-alert-text="Member Removed Successfully"
data-success-param-trigger-events="teams.deleteMembership"
data-failure="alert"
data-failure-param-alert-text="Failed to Remove Member"
data-failure-param-alert-classname="error">
< input name = "teamId" data-ls-attrs = "id={{member.$id}}" type = "hidden" data-ls-bind = "{{router.params.id}}" >
2021-05-08 03:49:23 +12:00
< input name = "membershipId" data-ls-attrs = "id=leave-membershipId-{{member.$id}}" type = "hidden" data-ls-bind = "{{member.$id}}" >
2020-06-08 16:40:13 +12:00
2020-06-09 04:15:13 +12:00
< button class = "danger" > Remove< / button >
2020-06-08 16:40:13 +12:00
< / form >
2022-05-13 01:20:46 +12:00
< img src = "" data-ls-attrs = "src={{member.userName|avatar}}" data-size = "200" alt = "User Avatar" class = "avatar pull-start margin-end" loading = "lazy" width = "60" height = "60" / >
2020-06-08 16:40:13 +12:00
< div class = "margin-bottom-tiny" >
2022-05-13 01:20:46 +12:00
< a data-ls-attrs = "href=/console/users/user?id={{member.userId}}&project={{router.params.project}}" > < span data-ls-bind = "{{member.userName}}" > < / span > < / a >
2020-07-19 09:15:02 +12:00
< span data-ls-if = "1 == {{member.roles.length}}" class = "text-fade tooltip" data-ls-bind = "{{member.roles.length}} role" data-ls-attrs = "data-tooltip={{member.roles|arraySentence}}" > < / span >
< span data-ls-if = "2 <= {{member.roles.length}}" class = "text-fade tooltip" data-ls-bind = "{{member.roles.length}} roles" data-ls-attrs = "data-tooltip={{member.roles|arraySentence}}" > < / span >
2020-06-08 16:40:13 +12:00
< / div >
2022-05-13 01:20:46 +12:00
< small class = "text-size-small text-fade" data-ls-bind = "{{member.userEmail}}" > < / small > < span data-ls-if = "false === {{member.confirm}}" class = "text-danger text-size-small" > Pending Approval< / span >
2020-06-08 16:40:13 +12:00
< / li >
< / ul >
2020-06-07 21:29:51 +12:00
< / div >
< / div >
2020-06-08 16:40:13 +12:00
< div data-ui-modal class = "box modal close" data-button-text = "Add Member" data-button-class = "pull-start" >
2020-06-08 00:29:12 +12:00
< button type = "button" class = "close pull-end" data-ui-modal-close = "" > < i class = "icon-cancel" > < / i > < / button >
2020-06-08 16:40:13 +12:00
< h1 > Add Member< / h1 >
< form name = "teams.createTeamMembership"
2021-01-18 19:29:26 +13:00
data-analytics
data-analytics-activity
2020-06-08 00:29:12 +12:00
data-analytics-event="submit"
data-analytics-category="console"
2020-06-08 16:40:13 +12:00
data-analytics-label="Create Team Membership"
data-service="teams.createMembership"
2020-06-08 00:29:12 +12:00
data-event="submit"
2022-05-27 17:33:13 +12:00
data-loading="Adding user, please wait..."
2020-06-08 00:29:12 +12:00
data-success="alert,trigger,reset"
2022-05-27 17:33:13 +12:00
data-success-param-alert-text="User added successfully"
2020-06-08 16:40:13 +12:00
data-success-param-trigger-events="teams.createMembership"
2020-06-08 00:29:12 +12:00
data-failure="alert"
2022-05-27 17:33:13 +12:00
data-failure-param-alert-text="Failed to add user"
2020-06-08 00:29:12 +12:00
data-failure-param-alert-classname="error">
2020-06-08 16:40:13 +12:00
< input name = "teamId" id = "team-teamId" type = "hidden" data-ls-bind = "{{team.$id}}" >
2021-02-19 00:57:30 +13:00
< input name = "url" type = "hidden" data-ls-bind = "{{env.ENDPOINT}}" / >
2021-08-04 18:39:23 +12:00
2020-06-08 16:40:13 +12:00
< label for = "email" > Email< / label >
< input name = "email" id = "email" type = "email" autocomplete = "email" required >
2021-08-04 18:39:23 +12:00
2020-06-08 16:40:13 +12:00
< label for = "team-name" > Name < small > (optional)< / small > < / label >
2020-09-08 09:28:40 +12:00
< input name = "name" id = "team-name" type = "text" autocomplete = "name" maxlength = "128" / >
2020-06-08 00:29:12 +12:00
2020-06-08 16:40:13 +12:00
< label for = "roles" > Roles< / label >
< input type = "hidden" id = "team-roles" name = "roles" data-forms-tags data-cast-to = "json" data-ls-bind = " <?php echo $this -> escape ( json_encode ([ 'owner' ])); ?> " placeholder = "Add any role you like" />
2020-06-08 00:29:12 +12:00
< hr / >
2020-06-08 16:40:13 +12:00
< div class = "clear" >
2020-06-08 17:42:01 +12:00
< button > Add Member< / button >
2020-06-08 16:40:13 +12:00
< button data-ui-modal-close = "" type = "button" class = "reverse" > Cancel< / button >
< / div >
2020-06-08 00:29:12 +12:00
< / form >
< / div >
< div class = "clear text-align-center paging pull-end" >
2020-06-07 21:29:51 +12:00
< form
2020-06-08 16:40:13 +12:00
data-service="teams.getMemberships"
2020-06-07 21:29:51 +12:00
data-event="submit"
2020-06-08 16:40:13 +12:00
data-param-team-id="{{router.params.id}}"
2020-06-07 21:29:51 +12:00
data-param-search="{{router.params.search}}"
data-param-limit="<?php echo APP_PAGING_LIMIT ; ?> "
data-param-order-type="DESC"
data-scope="sdk"
2020-06-08 16:40:13 +12:00
data-name="project-members"
2020-06-07 21:29:51 +12:00
data-success="state"
data-success-param-state-keys="search,offset">
2022-02-28 22:26:55 +13:00
< button name = "offset" data-paging-back data-offset = "{{router.params.offset}}" data-total = "{{project-members.total}}" class = "margin-end round small" aria-label = "Back" > < i class = "icon-left-open" > < / i > < / button >
2020-06-07 21:29:51 +12:00
< / form >
2022-02-28 22:25:38 +13:00
< span data-ls-bind = "{{router.params.offset|pageCurrent}} / {{project-members.total|pageTotal}}" > < / span >
2020-06-07 21:29:51 +12:00
< form
2020-06-08 16:40:13 +12:00
data-service="teams.getMemberships"
2020-06-07 21:29:51 +12:00
data-event="submit"
2020-06-08 16:40:13 +12:00
data-param-team-id="{{router.params.id}}"
2020-06-07 21:29:51 +12:00
data-param-search="{{router.params.search}}"
data-param-limit="<?php echo APP_PAGING_LIMIT ; ?> "
data-param-order-type="DESC"
data-scope="sdk"
2020-06-08 16:40:13 +12:00
data-name="project-members"
2020-06-07 21:29:51 +12:00
data-success="state"
data-success-param-state-keys="search,offset">
2022-02-28 22:26:55 +13:00
< button name = "offset" data-paging-next data-offset = "{{router.params.offset}}" data-total = "{{project-members.total}}" class = "margin-start round small" aria-label = "Next" > < i class = "icon-right-open" > < / i > < / button >
2020-06-07 21:29:51 +12:00
< / form >
< / div >
< / div >
2020-06-07 16:57:56 +12:00
< / div >
< div class = "col span-4 sticky-top" >
< label > Team ID< / label >
< div class = "input-copy margin-bottom" >
< input id = "uid" type = "text" autocomplete = "off" placeholder = "" data-ls-bind = "{{team.$id}}" disabled data-forms-copy >
< / div >
< ul class = "margin-bottom-large text-fade text-size-small" >
< li class = "margin-bottom-small" > < i class = "icon-angle-circled-right margin-start-tiny margin-end-tiny" > < / i > < button data-ls-ui-trigger = "open-json" class = "link text-size-small" > View as JSON< / button > < / li >
2020-07-15 23:22:38 +12:00
< li class = "margin-bottom-small" > < i class = "icon-angle-circled-right margin-start-tiny margin-end-tiny" > < / i > Created: < span data-ls-bind = "{{team.dateCreated|dateText}}" > < / span > < / li >
2020-06-07 16:57:56 +12:00
< / ul >
2020-06-07 18:22:51 +12:00
< form name = "teams.delete" class = "margin-bottom"
2021-01-18 19:29:26 +13:00
data-analytics
data-analytics-activity
2020-06-07 18:22:51 +12:00
data-analytics-event="submit"
data-analytics-category="console"
2020-06-07 20:09:05 +12:00
data-analytics-label="Delete Team"
data-service="teams.delete"
2020-06-07 18:22:51 +12:00
data-event="submit"
2020-06-07 20:09:05 +12:00
data-confirm="Are you sure you want to delete this team?"
2020-06-07 18:22:51 +12:00
data-param-team-id="{{router.params.id}}"
2020-06-07 20:09:05 +12:00
data-success="alert,trigger,redirect"
2020-06-07 18:22:51 +12:00
data-success-param-alert-text="Team deleted successfully"
data-success-param-trigger-events="users.update"
2020-06-07 20:09:05 +12:00
data-success-param-redirect-url="/console/users/teams?project={{router.params.project}}"
2020-06-07 18:22:51 +12:00
data-failure="alert"
data-failure-param-alert-text="Failed to delete team"
data-failure-param-alert-classname="error">
< button type = "submit" class = "danger fill" > Delete Team< / button >
< / form >
2020-06-07 16:57:56 +12:00
< / div >
< / div >
< / li >
2022-04-22 02:07:08 +12:00
< li data-state = "/console/users/teams/team/audit?id={{router.params.id}}&project={{router.params.project}}" >
< h2 > Activity< / h2 >
2021-08-04 18:39:23 +12:00
2022-04-22 02:07:08 +12:00
< div
data-service="teams.listLogs"
data-name="logs"
data-param-team-id="{{router.params.id}}"
data-event="load,logs-load">
< div class = "box margin-top margin-bottom" data-ls-if = "{{logs.logs.length}} === 0" style = "display: none" class = "margin-top-xxl margin-bottom-xxl text-align-center" >
< h3 class = "text-bold margin-bottom-no" > No logs available.< / h3 >
< / div >
< div class = "box" data-ls-if = "{{logs.logs.length}} !== 0" style = "display: none" >
< table class = "vertical small" >
< thead >
< tr >
< th width = "140" > Date< / th >
< th width = "175" > Event< / th >
< th > Client< / th >
< th width = "90" > Location< / th >
< th width = "90" > IP< / th >
< / tr >
< / thead >
< tbody data-ls-loop = "logs.logs" data-ls-as = "log" >
< tr >
< td data-title = "Date: " > < span data-ls-bind = "{{log.time|dateTime}}" > < / span > < / td >
< td data-title = "Event: " > < span data-ls-bind = "{{log.event}}" > < / span > < / td >
< td data-title = "Client: " >
< img onerror = "this.onerror=null;this.className='avatar hide'" data-ls-if = "{{log.clientCode|lowercase}} !== 'cli'" data-ls-attrs = "src={{env.API}}/avatars/browsers/{{log.clientCode|lowercase}}?width=80&height=80&project={{env.PROJECT}},title={{log.clientName}},alt={{log.clientName}}" class = "avatar xxs inline margin-end-small" / >
< img onerror = "this.onerror=null;this.className='avatar hide'" data-ls-if = "{{log.clientCode|lowercase}} === 'cli'" data-ls-attrs = "src=/images/clients/terminal.png?buster= <?php echo APP_CACHE_BUSTER ; ?> ,title={{log.clientName}},alt={{log.clientName}}" class = "avatar xxs inline margin-end-small" />
< span data-ls-if = "({{log.clientName}})" data-ls-bind = "{{log.clientName}} {{log.clientVersion}} on {{log.model}} {{log.osName}} {{log.osVersion}}" > < / span >
< div data-ls-if = "(!{{log.clientName}})" class = "text-align-center text-fade" > Unknown< / div >
< / td >
< td data-title = "Location: " >
< img onerror = "this.onerror=null;this.className='avatar hide'" data-ls-if = "{{log.countryCode}} !== '--'" data-ls-attrs = "src={{env.API}}/avatars/flags/{{log.countryCode}}?width=80&height=80&project={{env.PROJECT}}" class = "avatar xxs inline margin-end-small" / >
< span data-ls-bind = "{{log.countryName}}" > < / span >
< / td >
< td data-title = "IP: " > < span data-ls-bind = "{{log.ip}}" > < / span > < / td >
< / tr >
< / tbody >
< / table >
< / div >
< / div >
< / li >
2020-06-07 16:57:56 +12:00
< / ul >
< / div >
< / div >