1
0
Fork 0
mirror of https://github.com/documize/community.git synced 2025-07-19 13:19:43 +02:00
documize/gui/app/templates/components/customize/user-list.hbs

265 lines
11 KiB
Handlebars
Raw Normal View History

2018-12-14 15:47:41 +00:00
<div class="view-customize">
{{#if isAuthProviderKeycloak}}
2018-12-14 15:47:41 +00:00
{{ui/ui-spacer size=300}}
{{#if syncInProgress}}
{{ui/ui-button color=constants.Color.Gray light=true icon=constants.Icon.Locked label="Keycloak user sync running..."}}
{{else}}
{{ui/ui-button color=constants.Color.Yellow light=true icon=constants.Icon.Locked label="Sync with Keycloak" onClick=(action "onSyncKeycloak")}}
{{/if}}
2018-09-04 17:19:26 +01:00
{{/if}}
2018-12-14 15:47:41 +00:00
2018-09-04 17:19:26 +01:00
{{#if isAuthProviderLDAP}}
2018-12-14 15:47:41 +00:00
{{ui/ui-spacer size=300}}
{{#if syncInProgress}}
{{ui/ui-button color=constants.Color.Gray light=true icon=constants.Icon.Locked label="LDAP user sync running..."}}
{{else}}
{{ui/ui-button color=constants.Color.Yellow light=true icon=constants.Icon.Locked label="Sync with LDAP" onClick=(action "onSyncLDAP")}}
{{/if}}
{{/if}}
2018-04-05 19:59:57 +01:00
2018-12-14 15:47:41 +00:00
{{ui/ui-spacer size=300}}
<div class="explain-user-perms">
2018-12-16 12:56:50 +00:00
<div class="title" {{action "togglePerms"}}>
Permissions Explained
{{#if showPermExplain}}
<i class="dicon {{constants.Icon.ArrowSmallUp}}" />
{{else}}
<i class="dicon {{constants.Icon.ArrowSmallDown}}" />
{{/if}}
</div>
<div class="perms">
<div class="perm-name">Spaces</div>
<div class="perm-desc">Can add spaces, both personal and shared with others</div>
<div class="perm-name">Visible</div>
<div class="perm-desc">Can see names of users and groups, can disable for external users like customers/partners</div>
<div class="perm-name">Admin</div>
<div class="perm-desc">Can manage all aspects of Documize, like this screen</div>
<div class="perm-name">Analytics</div>
<div class="perm-desc">Can view analytical reports<</div>
<div class="perm-name">Active</div>
<div class="perm-desc">Can login and use Documize</div>
</div>
2018-03-01 19:14:27 +00:00
</div>
2018-12-14 15:47:41 +00:00
{{ui/ui-spacer size=300}}
2018-03-01 19:14:27 +00:00
2018-12-14 15:47:41 +00:00
<div class="form-group">
2018-03-01 19:14:27 +00:00
{{focus-input type="text" class="form-control" placeholder="filter users" value=filter}}
<small class="form-text text-muted">search firstname, lastname, email</small>
</div>
2018-12-14 15:47:41 +00:00
<div class="text-center">
{{#ui/ui-toolbar dark=false light=false raised=false large=true bordered=false tooltip="Maximum users to display"}}
2018-12-16 12:56:50 +00:00
{{ui/ui-toolbar-label color=constants.Color.Gray label="5" selected=(eq userLimit 5) onClick=(action "onLimit" 5)}}
{{ui/ui-toolbar-label color=constants.Color.Gray label="10" selected=(eq userLimit 10) onClick=(action "onLimit" 10)}}
{{ui/ui-toolbar-label color=constants.Color.Gray label="25" selected=(eq userLimit 25) onClick=(action "onLimit" 25)}}
{{ui/ui-toolbar-label color=constants.Color.Gray label="50" selected=(eq userLimit 50) onClick=(action "onLimit" 50)}}
{{ui/ui-toolbar-label color=constants.Color.Gray label="100" selected=(eq userLimit 100) onClick=(action "onLimit" 100)}}
{{ui/ui-toolbar-label color=constants.Color.Gray label="250" selected=(eq userLimit 250) onClick=(action "onLimit" 250)}}
{{ui/ui-toolbar-label color=constants.Color.Gray label="500" selected=(eq userLimit 500) onClick=(action "onLimit" 500)}}
{{ui/ui-toolbar-label color=constants.Color.Gray label="1,000" selected=(eq userLimit 1000) onClick=(action "onLimit" 1000)}}
{{ui/ui-toolbar-label color=constants.Color.Gray label="ALL" selected=(eq userLimit 99999) onClick=(action "onLimit" 99999)}}
2018-12-14 15:47:41 +00:00
{{/ui/ui-toolbar}}
</div>
2018-03-01 19:14:27 +00:00
<table class="table table-responsive table-borderless user-table">
2018-03-01 10:58:55 +00:00
<thead>
<tr>
2018-12-14 15:47:41 +00:00
<th class="no-width"></th>
<th>
2018-03-01 19:14:27 +00:00
{{#if hasSelectedUsers}}
2018-12-14 15:47:41 +00:00
{{ui/ui-button
id="bulk-delete-users"
color=constants.Color.Red
light=false
icon=constants.Icon.Delete
label="Delete selected users"
onClick=(action "onShowDeleteBulk")}}
2018-04-05 19:59:57 +01:00
{{/if}}
2018-03-01 19:14:27 +00:00
</th>
<th class="no-width">Spaces</th>
<th class="no-width">Visible</th>
2018-04-05 19:59:57 +01:00
<th class="no-width">Analytics</th>
2018-12-14 15:47:41 +00:00
<th class="no-width">Admin</th>
2018-03-01 10:58:55 +00:00
<th class="no-width">Active</th>
2018-12-14 15:47:41 +00:00
<th class="no-width"></th>
2018-03-01 10:58:55 +00:00
</tr>
</thead>
<tbody>
2018-03-01 19:14:27 +00:00
{{#each users key="id" as |user|}}
2018-12-14 15:47:41 +00:00
<tr>
<td class="no-width text-center align-middle">
2018-03-01 10:58:55 +00:00
{{#if user.me}}
2018-12-14 15:47:41 +00:00
<i class="user-checkbox dicon {{constants.Icon.NotAllowed}}" />
2018-12-12 13:35:16 +00:00
{{else if user.selected}}
2018-12-14 15:47:41 +00:00
<i class="user-checkbox dicon {{constants.Icon.CheckboxChecked}}" {{action "toggleSelect" user}} />
2018-03-01 10:58:55 +00:00
{{else}}
2018-12-14 15:47:41 +00:00
<i class="user-checkbox dicon {{constants.Icon.Checkbox}}" {{action "toggleSelect" user}} />
2018-03-01 10:58:55 +00:00
{{/if}}
2018-12-14 15:47:41 +00:00
</td>
<td class="{{unless user.active "inactive-user"}} {{if user.admin "admin-user"}}">
<div class="name" {{action "onShowEdit" user.id}}>
{{user.fullname}}
<div class="email">{{user.email}}</div>
</div>
2018-12-12 13:35:16 +00:00
<div class="groups" {{action "onShowGroupsModal" user.id}}>
{{#each user.groups as |group|}}
2018-12-14 15:47:41 +00:00
<span class="group">
{{group.name}}{{#if (not-eq group user.groups.lastObject)}}, {{/if}}
</span>
2018-12-12 13:35:16 +00:00
{{else}}
2018-12-14 15:47:41 +00:00
<span class="group">&lt;no groups&gt;</span>
2018-12-12 13:35:16 +00:00
{{/each}}
</div>
2018-12-14 15:47:41 +00:00
</td>
<td class="no-width text-center align-middle">
{{#if user.editor}}
<i class="user-checkbox dicon {{constants.Icon.CheckboxChecked}}" {{action "toggleEditor" user.id}} />
{{else}}
<i class="user-checkbox dicon {{constants.Icon.Checkbox}}" {{action "toggleEditor" user.id}} />
{{/if}}
</td>
<td class="no-width text-center align-middle">
{{#if user.viewUsers}}
<i class="user-checkbox dicon {{constants.Icon.CheckboxChecked}}" {{action "toggleUsers" user.id}} />
{{else}}
<i class="user-checkbox dicon {{constants.Icon.Checkbox}}" {{action "toggleUsers" user.id}} />
{{/if}}
</td>
<td class="no-width text-center align-middle">
{{#if user.analytics}}
<i class="user-checkbox dicon {{constants.Icon.CheckboxChecked}}" {{action "toggleAnalytics" user.id}} />
{{else}}
<i class="user-checkbox dicon {{constants.Icon.Checkbox}}" {{action "toggleAnalytics" user.id}} />
{{/if}}
</td>
<td class="no-width text-center align-middle">
{{#if user.me}}
<i class="user-checkbox dicon {{constants.Icon.NotAllowed}}" />
{{else if user.admin}}
<i class="user-checkbox dicon {{constants.Icon.CheckboxChecked}}" {{action "toggleAdmin" user.id}} />
{{else}}
<i class="user-checkbox dicon {{constants.Icon.Checkbox}}" {{action "toggleAdmin" user.id}} />
{{/if}}
</td>
<td class="no-width text-center align-middle">
{{#if user.me}}
<i class="user-checkbox dicon {{constants.Icon.NotAllowed}}" />
{{else if user.active}}
<i class="user-checkbox dicon {{constants.Icon.CheckboxChecked}}" {{action "toggleActive" user.id}} />
{{else}}
<i class="user-checkbox dicon {{constants.Icon.Checkbox}}" {{action "toggleActive" user.id}} />
{{/if}}
</td>
<td class="no-width text-center align-middle">
{{#ui/ui-toolbar dark=false light=true raised=true large=false bordered=true}}
{{ui/ui-toolbar-icon icon=constants.Icon.Edit color=constants.Color.Gray tooltip="Edit user" onClick=(action "onShowEdit" user.id)}}
{{ui/ui-toolbar-icon icon=constants.Icon.AddUser color=constants.Color.Gray tooltip="Assign user groups" onClick=(action "onShowGroupsModal" user.id)}}
{{#unless user.me}}
{{ui/ui-toolbar-icon icon=constants.Icon.Delete color=constants.Color.Red tooltip="Delete user" onClick=(action "onShowDelete" user.id)}}
{{/unless}}
{{/ui/ui-toolbar}}
</td>
</tr>
2018-03-01 10:58:55 +00:00
{{/each}}
</tbody>
</table>
</div>
2018-12-14 15:47:41 +00:00
{{#ui/ui-dialog title="Delete User" confirmCaption="Delete" buttonColor=constants.Color.Red show=showDeleteDialog onAction=(action "onDelete")}}
<p>Are you sure you want to delete {{deleteUser.fullname}}?</p>
{{/ui/ui-dialog}}
2018-03-01 10:58:55 +00:00
<div id="edit-user-modal" class="modal" tabindex="-1" role="dialog">
<div class="modal-dialog" role="document">
<div class="modal-content">
<div class="modal-header">User {{editUser.firstname}} {{editUser.lastname}}</div>
<div class="modal-body">
<form>
<div class="form-group">
<label for="edit-firstname">Firstname</label>
{{input id="edit-firstname" class="form-control" type="text" value=editUser.firstname}}
</div>
<div class="form-group">
<label for="edit-lastname">Lastname</label>
{{input id="edit-lastname" type="text" class="form-control" value=editUser.lastname}}
</div>
<div class="form-group">
<label for="edit-email">Email</label>
{{input id="edit-email" type="text" class="form-control" value=editUser.email}}
</div>
{{#if isAuthProviderDocumize}}
2018-12-12 13:35:16 +00:00
<div class="row">
<div class="col-md-6">
<div class="form-group">
<label for="edit-password">Password</label>
{{input id="edit-password" type="password" class="form-control" value=password.password}}
<small class="form-text text-muted">Optional new password</small>
2018-03-01 10:58:55 +00:00
</div>
2018-12-12 13:35:16 +00:00
</div>
<div class="col-md-6">
<div class="form-group">
<label for="edit-confirmPassword">Confirm Password</label>
{{input id="edit-confirmPassword" type="password" class="form-control" value=password.confirmation}}
<small class="form-text text-muted">Confirm new password</small>
2018-03-01 10:58:55 +00:00
</div>
</div>
2018-12-12 13:35:16 +00:00
</div>
2018-03-01 10:58:55 +00:00
{{/if}}
</form>
</div>
<div class="modal-footer">
2018-12-14 15:47:41 +00:00
{{ui/ui-button color=constants.Color.Gray light=true label=constants.Label.Close dismiss=true}}
{{ui/ui-button color=constants.Color.Green light=true label=constants.Label.Update onClick=(action "onUpdate")}}
2018-03-01 10:58:55 +00:00
</div>
</div>
</div>
</div>
2018-03-01 19:14:27 +00:00
<div id="admin-user-delete-modal" class="modal" tabindex="-1" role="dialog">
<div class="modal-dialog" role="document">
<div class="modal-content">
<div class="modal-header">Delete Users</div>
<div class="modal-body">
<p>Are you sure you want to delete selected users?</p>
</div>
<div class="modal-footer">
2018-12-14 15:47:41 +00:00
{{ui/ui-button color=constants.Color.Gray light=true label=constants.Label.Close dismiss=true}}
{{ui/ui-button color=constants.Color.Red light=true label=constants.Label.Delete onClick=(action "onBulkDelete")}}
2018-03-01 19:14:27 +00:00
</div>
</div>
</div>
</div>
<div id="group-member-modal" class="modal" tabindex="-1" role="dialog">
<div class="modal-dialog modal-lg" role="document">
<div class="modal-content">
<div class="modal-header">{{selectedUser.fullname}}</div>
<div class="modal-body">
<div class="view-customize">
2018-12-14 15:47:41 +00:00
<div class="group-membership">
2018-03-01 19:14:27 +00:00
{{#each groups as |group|}}
2018-12-12 13:35:16 +00:00
<div class="row item">
<div class="col-10 group-name">{{group.name}}
{{#if group.purpose}}
2018-12-14 15:47:41 +00:00
<span class="group-purpose">&nbsp;&mdash;&nbsp;{{group.purpose}}</span>
2018-12-12 13:35:16 +00:00
{{/if}}
2018-03-01 19:14:27 +00:00
</div>
2018-12-12 13:35:16 +00:00
<div class="col-2 text-right">
{{#if group.isMember}}
2018-12-14 15:47:41 +00:00
{{ui/ui-button color=constants.Color.Red light=true label=constants.Label.Leave onClick=(action "onLeaveGroup" group.id)}}
2018-12-12 13:35:16 +00:00
{{else}}
2018-12-14 15:47:41 +00:00
{{ui/ui-button color=constants.Color.Green light=true label=constants.Label.Join onClick=(action "onJoinGroup" group.id)}}
2018-12-12 13:35:16 +00:00
{{/if}}
</div>
</div>
2018-03-01 19:14:27 +00:00
{{/each}}
</div>
</div>
</div>
<div class="modal-footer">
2018-12-14 15:47:41 +00:00
{{ui/ui-button color=constants.Color.Gray light=true label=constants.Label.Close dismiss=true}}
2018-03-01 19:14:27 +00:00
</div>
</div>
</div>
2018-12-12 13:35:16 +00:00
</div>