1
0
Fork 0
mirror of synced 2024-07-01 20:50:49 +12:00
appwrite/app/views/console/users/view.phtml

227 lines
13 KiB
PHTML
Raw Normal View History

2019-08-08 06:10:53 +12:00
<div
data-service="users.getUser"
data-name="user"
data-event="load,user-update"
data-param-user-id="{{router.params.id}}"
data-success="trigger"
data-success-param-trigger-events="user-load">
2019-05-09 18:54:39 +12:00
<div class="cover">
<h1 class="zone xl margin-bottom-large">
2019-09-27 09:42:38 +12:00
<a data-ls-attrs="href=/console/users?project={{router.params.project}}" class="back text-size-small"><i class="icon-left-open"></i> Users</a>
2019-05-09 18:54:39 +12:00
<br />
2019-05-10 04:15:51 +12:00
<span data-ls-bind="{{user.name}}">&nbsp;</span>
2019-05-09 18:54:39 +12:00
</h1>
</div>
<div class="zone xl">
2019-05-09 20:23:22 +12:00
<ul class="phases clear" data-ui-phases data-selected="{{router.params.tab}}">
<li data-state="/console/users/view?id={{router.params.id}}&project={{router.params.project}}">
2019-05-09 18:54:39 +12:00
<h2>General</h2>
2019-05-12 03:26:03 +12:00
<div data-ls-if="{{user.status}} === <?php echo \Auth\Auth::USER_STATUS_BLOCKED; ?>" style="display: none" class="box padding-small danger margin-bottom-xxl">
2019-05-09 18:54:39 +12:00
This user account is blocked.
</div>
<div class="row responsive margin-top-xl">
<div class="col span-8">
<div class="box margin-bottom-large">
2019-08-12 09:52:36 +12:00
<div class="text-align-center">
2019-08-09 16:49:47 +12:00
<img src="" data-ls-attrs="src={{user|gravatar}}" data-size="200" alt="User Avatar" class="avatar huge margin-top-negative-xxl" />
2019-05-09 18:54:39 +12:00
2019-08-24 07:07:17 +12:00
<div class="margin-top-small" data-ls-bind="Member since {{user.registration|date-text}}"></div>
2019-05-09 18:54:39 +12:00
<div class="margin-top-small">
2019-05-12 03:26:03 +12:00
<span data-ls-if="{{user.confirm}} === true" style="display: none;">
2019-05-09 18:54:39 +12:00
<span class="tag green">Verified</span>
</span>
2019-05-12 03:26:03 +12:00
<span data-ls-if="{{user.confirm}} !== true" style="display: none;">
2019-05-09 18:54:39 +12:00
<span class="tag">Unverified</span>
</span>
</div>
2019-05-10 04:15:51 +12:00
<div class="margin-top-small" data-ls-bind="{{user.email}}"></div>
2019-05-09 18:54:39 +12:00
</div>
</div>
<h3 class="margin-bottom">Preferences</h3>
2019-08-08 06:10:53 +12:00
<div class="box margin-bottom"
data-service="users.getUserPrefs"
data-name="user-prefs"
data-event="load"
data-param-user-id="{{router.params.id}}"
data-success="trigger"
data-success-param-trigger-events="user-prefs-load">
2019-05-09 18:54:39 +12:00
<div data-ls-if="!{{user-prefs|isEmptyObject}}" style="display: none;">
2019-05-09 18:54:39 +12:00
<table class="vertical">
<thead>
2019-08-06 18:42:47 +12:00
<tr>
<th>Key</th>
<th>Value</th>
</tr>
2019-05-09 18:54:39 +12:00
</thead>
<tbody data-ls-loop="user-prefs" data-ls-as="pref">
2019-08-06 18:42:47 +12:00
<tr>
<td data-title="Key: ">
<span data-ls-bind="{{$index}}"></span>
</td>
<td data-title="Value: ">
<span data-ls-bind="{{pref}}"></span>
</td>
</tr>
2019-05-09 18:54:39 +12:00
</tbody>
</table>
</div>
<div data-ls-if="{{user-prefs|isEmptyObject}}" style="display: none;">
2019-05-09 18:54:39 +12:00
No user preferences found
</div>
</div>
</div>
<div class="col span-4">
<label>User ID</label>
<div class="input-copy margin-bottom-large">
2019-05-10 04:15:51 +12:00
<input id="uid" type="text" autocomplete="off" placeholder="" data-ls-bind="{{user.$uid}}" disabled data-forms-copy>
2019-05-09 18:54:39 +12:00
</div>
2019-05-12 03:26:03 +12:00
<div data-ls-if="{{user.status}} !== <?php echo \Auth\Auth::USER_STATUS_BLOCKED; ?>" style="display: none">
2019-08-08 06:10:53 +12:00
<form name="users.updateStatus" class="margin-bottom"
data-service="users.updateUserStatus"
data-event="submit"
data-param-user-id="{{router.params.id}}"
data-success="alert,trigger"
data-success-param-alert-text="Blocked User Successfully"
data-success-param-trigger-events="user-update"
2019-08-08 17:09:49 +12:00
data-failure="alert"
2019-08-09 01:43:24 +12:00
data-failure-param-alert-text="Failed to Block User"
data-failure-param-alert-classname="error">
2019-08-08 06:10:53 +12:00
2019-05-09 18:54:39 +12:00
<button name="status" type="submit" class="danger fill" value="<?php echo \Auth\Auth::USER_STATUS_BLOCKED; ?>">Block Account</button>
</form>
</div>
2019-05-12 03:26:03 +12:00
<div data-ls-if="{{user.status}} === <?php echo \Auth\Auth::USER_STATUS_BLOCKED; ?>" style="display: none">
2019-08-08 06:10:53 +12:00
<form name="users.updateStatus" class="margin-bottom"
data-service="users.updateUserStatus"
data-event="submit"
data-param-user-id="{{router.params.id}}"
data-success="alert,trigger"
data-success-param-alert-text="Blocked Activated Successfully"
data-success-param-trigger-events="user-update"
2019-08-08 17:09:49 +12:00
data-failure="alert"
2019-08-09 01:43:24 +12:00
data-failure-param-alert-text="Failed to Activate User"
data-failure-param-alert-classname="error">
2019-05-09 18:54:39 +12:00
<button name="status" type="submit" class="fill" value="<?php echo \Auth\Auth::USER_STATUS_ACTIVATED; ?>">Activate Account</button>
</form>
</div>
</div>
</div>
</li>
2019-05-09 20:23:22 +12:00
<li data-state="/console/users/view/devices?id={{router.params.id}}&project={{router.params.project}}">
2019-05-09 18:54:39 +12:00
<h2>Devices</h2>
2019-08-08 06:10:53 +12:00
<div
data-service="users.getUserSessions"
data-name="sessions"
data-param-user-id="{{router.params.id}}"
data-event="load,user-update">
2019-05-09 18:54:39 +12:00
2019-05-12 03:26:03 +12:00
<div data-ls-if="{{sessions.length}} === 0" style="display: none" class="margin-top-xl margin-bottom-xl">
2019-05-09 18:54:39 +12:00
No sessions available
</div>
2019-05-12 03:26:03 +12:00
<div data-ls-if="{{sessions.length}} !== 0" style="display: none">
2019-05-09 18:54:39 +12:00
<div class="box margin-bottom">
<ul data-ls-loop="sessions" data-ls-as="session" class="list">
<li class="clear">
2019-08-08 06:10:53 +12:00
<form class="pull-end"
data-service="users.deleteUsersSession"
data-event="submit"
data-loading="Loading..."
data-success="trigger"
data-success-param-trigger-events="user-update"
2019-08-08 17:09:49 +12:00
data-failure="alert"
2019-08-09 01:43:24 +12:00
data-failure-param-alert-text="Failed to logout session"
data-failure-param-alert-classname="error">
2019-05-10 04:15:51 +12:00
<input type="hidden" name="userId" data-ls-bind="{{router.params.id}}">
<input type="hidden" name="sessionId" data-ls-bind="{{session.id}}">
2019-05-09 18:54:39 +12:00
<button class="danger">Logout</button>
</form>
2019-12-07 08:54:23 +13:00
<img data-ls-attrs="src={{env.API}}/avatars/browsers/{{session.client.short_name|lowercase}}?width=120&height=120&project={{env.PROJECT}},title={{session.client.name}},alt={{session.client.name}}" class="avatar trans pull-start margin-end" />
2019-05-09 18:54:39 +12:00
2019-05-10 04:15:51 +12:00
<span data-ls-bind="{{session.client.name}}"></span> <span data-ls-bind="{{session.client.version}}"></span> on <span data-ls-bind="{{session.model}}"></span> <span data-ls-bind="{{session.OS.name}}"></span> <span data-ls-bind="{{session.OS.version}}"></span>
2019-05-09 18:54:39 +12:00
2019-08-24 07:07:17 +12:00
<div class="margin-top-small">
2019-12-07 08:54:23 +13:00
<img data-ls-attrs="src={{env.API}}/avatars/flags/{{session.geo.isoCode}}?width=80&height=80&project={{env.PROJECT}}" class="avatar xs margin-end-small inline" />
2019-05-10 04:15:51 +12:00
<small data-ls-bind="{{session.ip}}"></small> / <small data-ls-bind="{{session.geo.country}}"></small>
2019-05-09 18:54:39 +12:00
</div>
</li>
</ul>
</div>
2019-08-08 06:10:53 +12:00
<form class="inline margin-bottom-large"
data-service="users.deleteUsersSessions"
data-param-user-id="{{router.params.id}}"
data-event="submit"
data-success="trigger"
data-success-param-trigger-events="user-update"
2019-08-08 17:09:49 +12:00
data-failure="alert"
2019-08-09 01:43:24 +12:00
data-failure-param-alert-text="Failed to logout all sessions"
data-failure-param-alert-classname="error">
2019-05-09 18:54:39 +12:00
<button class="danger">Logout from all devices</button>
</form>
</div>
</div>
</li>
2019-05-09 20:23:22 +12:00
<li data-state="/console/users/view/audit?id={{router.params.id}}&project={{router.params.project}}">
2019-05-09 18:54:39 +12:00
<h2>Audit Log</h2>
2019-08-08 06:10:53 +12:00
<div
data-service="users.getUserLogs"
data-name="logs"
data-param-user-id="{{router.params.id}}"
data-event="load,logs-load">
2019-05-09 18:54:39 +12:00
2019-05-12 03:26:03 +12:00
<div data-ls-if="{{logs.length}} === 0" style="display: none" class="margin-top-xl margin-bottom-xl">
2019-05-09 18:54:39 +12:00
No logs available
</div>
2019-05-12 03:26:03 +12:00
<div class="box" data-ls-if="{{logs.length}} !== 0" style="display: none">
2019-05-09 18:54:39 +12:00
<table class="vertical small">
<thead>
2019-08-06 18:42:47 +12:00
<tr>
2019-09-27 06:47:48 +12:00
<th width="140">Date</th>
<th width="175">Event</th>
<th>Client</th>
<th width="90">Location</th>
<th width="90">IP</th>
2019-08-06 18:42:47 +12:00
</tr>
2019-05-09 18:54:39 +12:00
</thead>
<tbody data-ls-loop="logs" data-ls-as="log">
2019-08-06 18:42:47 +12:00
<tr>
2019-09-27 06:47:48 +12:00
<td data-title="Date: "><span data-ls-bind="{{log.time|date-time}}"></span></td>
<td data-title="Event: "><span data-ls-bind="{{log.event}}"></span></td>
<td data-title="Client: ">
2019-12-07 08:54:23 +13:00
<img data-ls-attrs="src={{env.API}}/avatars/browsers/{{log.client.short_name|lowercase}}?width=80&height=80&project={{env.PROJECT}},title={{log.client.name}},alt={{log.client.name}}" class="avatar xs inline margin-end-small" />
2019-08-06 18:42:47 +12:00
<span data-ls-bind="{{log.client.name}} {{log.client.version}} on {{log.model}} {{log.OS.name}} {{log.OS.version}}"></span>
</td>
2019-09-27 06:47:48 +12:00
<td data-title="Location: ">
2019-12-07 08:54:23 +13:00
<img data-ls-attrs="src={{env.API}}/avatars/flags/{{log.geo.isoCode}}?width=80&height=80&project={{env.PROJECT}}" class="avatar xs inline margin-end-small" />
2019-08-06 18:42:47 +12:00
<span data-ls-bind="{{log.geo.country}}"></span>
</td>
2019-09-27 06:47:48 +12:00
<td data-title="IP: "><span data-ls-bind="{{log.ip}}"></span></td>
2019-08-06 18:42:47 +12:00
</tr>
2019-05-09 18:54:39 +12:00
</tbody>
</table>
</div>
</div>
</li>
</ul>
</div>
</div>