Join requests now present an "are you sure?" modal
This commit is contained in:
@@ -224,40 +224,22 @@ function bindOrganisationButtons(el, options) {
|
|||||||
el.find('.js-organisation-join').click(function(e) {
|
el.find('.js-organisation-join').click(function(e) {
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
|
|
||||||
var data = {};
|
$("body").ufModal({
|
||||||
data[site.csrf.keys.name] = site.csrf.name;
|
sourceUrl: site.uri.public + "/modals/organisations/o/" + $(this).data('slug') + "/members/confirm-join",
|
||||||
data[site.csrf.keys.value] = site.csrf.value;
|
ajaxParams: {
|
||||||
|
slug: $(this).data('slug')
|
||||||
|
},
|
||||||
|
msgTarget: $("#alerts-page")
|
||||||
|
});
|
||||||
|
|
||||||
var url = site.uri.public + '/api/organisations/o/' + $(this).data('slug') + '/members';
|
$("body").on('renderSuccess.ufModal', function() {
|
||||||
var debugAjax = (typeof site !== "undefined") && site.debug.ajax;
|
var modal = $(this).ufModal('getModal');
|
||||||
|
var form = modal.find('.js-form');
|
||||||
|
|
||||||
return $.ajax({
|
form.ufForm()
|
||||||
type: "POST",
|
.on("submitSuccess.ufForm", function() {
|
||||||
url: url,
|
window.location.reload();
|
||||||
data: data,
|
});
|
||||||
dataType: debugAjax ? 'html' : 'json',
|
|
||||||
}).fail(function(jqXHR) {
|
|
||||||
// Error messages
|
|
||||||
if (debugAjax && jqXHR.responseText) {
|
|
||||||
document.write(jqXHR.responseText);
|
|
||||||
document.close();
|
|
||||||
} else {
|
|
||||||
console.log("Error (" + jqXHR.status + "): " + jqXHR.responseText);
|
|
||||||
|
|
||||||
// Display errors on failure
|
|
||||||
// TODO: ufAlerts widget should have a 'destroy' method
|
|
||||||
if (!$("#alerts-page").data('ufAlerts')) {
|
|
||||||
$("#alerts-page").ufAlerts();
|
|
||||||
} else {
|
|
||||||
$("#alerts-page").ufAlerts('clear');
|
|
||||||
}
|
|
||||||
|
|
||||||
$("#alerts-page").ufAlerts('fetch').ufAlerts('render');
|
|
||||||
}
|
|
||||||
|
|
||||||
return jqXHR;
|
|
||||||
}).done(function(response) {
|
|
||||||
window.location.reload();
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@@ -31,6 +31,10 @@ return [
|
|||||||
'EDIT' => 'Edit organistion',
|
'EDIT' => 'Edit organistion',
|
||||||
'UPDATE' => 'Details updated for organistion <strong>{{name}}</strong>',
|
'UPDATE' => 'Details updated for organistion <strong>{{name}}</strong>',
|
||||||
|
|
||||||
|
|
||||||
|
'JOIN' => 'Join organisation',
|
||||||
|
'JOIN_CONFIRM' => 'Are you sure you want to join the organisation <strong>{{name}}</strong>?',
|
||||||
|
'JOIN_YES' => 'Yes, join organisation.',
|
||||||
'JOIN_SUCCESSFUL' => 'Successfully joined organisation <strong>{{name}}</strong>',
|
'JOIN_SUCCESSFUL' => 'Successfully joined organisation <strong>{{name}}</strong>',
|
||||||
|
|
||||||
'LEAVE' => 'Leave organisation',
|
'LEAVE' => 'Leave organisation',
|
||||||
@@ -93,11 +97,12 @@ return [
|
|||||||
'DENY' => 'Deny organisation registration',
|
'DENY' => 'Deny organisation registration',
|
||||||
],
|
],
|
||||||
'JOIN_REQUEST' => [
|
'JOIN_REQUEST' => [
|
||||||
'SUBMIT_SUCCESSFUL' => 'Request to join organisation <strong>{{name}}</strong> sent',
|
|
||||||
|
|
||||||
'ALREADY_IN_ONE' => 'You cannot join another organisation because you are already in one (only one organisation allowed).',
|
'ALREADY_IN_ONE' => 'You cannot join another organisation because you are already in one (only one organisation allowed).',
|
||||||
|
|
||||||
'REQUEST' => 'Request to join organisation',
|
'REQUEST' => 'Request to join organisation',
|
||||||
|
'REQUEST_CONFIRM' => 'Are you sure you want to request to join the organisation <strong>{{name}}</strong>?',
|
||||||
|
'APPROVAL_REQUIRED' => 'Joining organisations requires approval. You will receive an email once your join request has been approved.',
|
||||||
|
'SUBMIT_SUCCESSFUL' => 'Request to join organisation <strong>{{name}}</strong> sent',
|
||||||
|
|
||||||
'CANCEL' => 'Cancel request to join organisation',
|
'CANCEL' => 'Cancel request to join organisation',
|
||||||
'CANCEL_CONFIRM' => 'Are you sure you want to cancel your request to join the organisation <strong>{{name}}</strong>?',
|
'CANCEL_CONFIRM' => 'Are you sure you want to cancel your request to join the organisation <strong>{{name}}</strong>?',
|
||||||
|
|||||||
@@ -37,6 +37,7 @@ $app->group('/api/organisations/o/{slug}/members', function () {
|
|||||||
|
|
||||||
|
|
||||||
$app->group('/modals/organisations/o/{slug}/members', function () {
|
$app->group('/modals/organisations/o/{slug}/members', function () {
|
||||||
|
$this->get('/confirm-join', 'UserFrosting\Sprinkle\Organisations\Controller\OrganisationMembersController:getModalConfirmJoin');
|
||||||
$this->get('/confirm-leave', 'UserFrosting\Sprinkle\Organisations\Controller\OrganisationMembersController:getModalConfirmLeave');
|
$this->get('/confirm-leave', 'UserFrosting\Sprinkle\Organisations\Controller\OrganisationMembersController:getModalConfirmLeave');
|
||||||
$this->get('/confirm-cancel', 'UserFrosting\Sprinkle\Organisations\Controller\OrganisationMembersController:getModalConfirmCancel');
|
$this->get('/confirm-cancel', 'UserFrosting\Sprinkle\Organisations\Controller\OrganisationMembersController:getModalConfirmCancel');
|
||||||
$this->get('/confirm-remove', 'UserFrosting\Sprinkle\Organisations\Controller\OrganisationMembersController:getModalConfirmRemove');
|
$this->get('/confirm-remove', 'UserFrosting\Sprinkle\Organisations\Controller\OrganisationMembersController:getModalConfirmRemove');
|
||||||
|
|||||||
@@ -105,7 +105,7 @@ class OrganisationMembersController extends SimpleController
|
|||||||
Capsule::transaction(function () use ($organisation, $currentUser, $classMapper, $config) {
|
Capsule::transaction(function () use ($organisation, $currentUser, $classMapper, $config) {
|
||||||
$organisation->members()->attach($currentUser->id, [
|
$organisation->members()->attach($currentUser->id, [
|
||||||
'flag_admin' => false,
|
'flag_admin' => false,
|
||||||
'flag_approved' => !$config['organisation']['membership']['require_approval'],
|
'flag_approved' => !$config['organisation.membership.require_approval'],
|
||||||
]);
|
]);
|
||||||
|
|
||||||
$organisation->save();
|
$organisation->save();
|
||||||
@@ -976,6 +976,55 @@ class OrganisationMembersController extends SimpleController
|
|||||||
return $sprunje->toResponse($response);
|
return $sprunje->toResponse($response);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get join confirmation modal.
|
||||||
|
*
|
||||||
|
* @param Request $request
|
||||||
|
* @param Response $response
|
||||||
|
* @param array $args
|
||||||
|
*
|
||||||
|
* @throws NotFoundException If organisation is not found
|
||||||
|
* @throws ForbiddenException If user is not authorized to access page
|
||||||
|
* @throws BadRequestException
|
||||||
|
*/
|
||||||
|
public function getModalConfirmJoin(Request $request, Response $response, $args)
|
||||||
|
{
|
||||||
|
/** @var \UserFrosting\Sprinkle\Account\Authorize\AuthorizationManager $authorizer */
|
||||||
|
$authorizer = $this->ci->authorizer;
|
||||||
|
|
||||||
|
/** @var \UserFrosting\Sprinkle\Core\Util\ClassMapper $classMapper */
|
||||||
|
$classMapper = $this->ci->classMapper;
|
||||||
|
|
||||||
|
/** @var \UserFrosting\Support\Repository\Repository $config */
|
||||||
|
$config = $this->ci->config;
|
||||||
|
|
||||||
|
/** @var \UserFrosting\Sprinkle\Account\Database\Models\Interfaces\UserInterface $currentUser */
|
||||||
|
$currentUser = $this->ci->currentUser;
|
||||||
|
|
||||||
|
|
||||||
|
$organisation = $this->getOrganisationFromParams($args);
|
||||||
|
|
||||||
|
// If the organisation no longer exists, forward to main organisation listing page
|
||||||
|
if (!$organisation) {
|
||||||
|
throw new NotFoundException();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Access-controlled page
|
||||||
|
if (!$authorizer->checkAccess($currentUser, 'join_organisation', [
|
||||||
|
'organisation' => $organisation,
|
||||||
|
])) {
|
||||||
|
throw new ForbiddenException();
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->ci->view->render($response, 'modals/confirm-join-organisation.html.twig', [
|
||||||
|
'organisation' => $organisation,
|
||||||
|
'approval_required' => $config['organisation.membership.require_approval'],
|
||||||
|
'form' => [
|
||||||
|
'action' => "api/organisations/o/{$organisation->slug}/members",
|
||||||
|
],
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get leave confirmation modal.
|
* Get leave confirmation modal.
|
||||||
*
|
*
|
||||||
|
|||||||
24
templates/modals/confirm-join-organisation.html.twig
Normal file
24
templates/modals/confirm-join-organisation.html.twig
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
{% extends "modals/modal.html.twig" %}
|
||||||
|
|
||||||
|
{% block modal_title %}{% if approval_required %}{{translate("ORGANISATION.JOIN_REQUEST.REQUEST")}}{% else %}{{translate("ORGANISATION.JOIN")}}{% endif %}{% endblock %}
|
||||||
|
|
||||||
|
{% block modal_body %}
|
||||||
|
<form class="js-form" method="post" action="{{site.uri.public}}/{{form.action}}">
|
||||||
|
{% include "forms/csrf.html.twig" %}
|
||||||
|
<div class="js-form-alerts">
|
||||||
|
</div>
|
||||||
|
{% if approval_required %}
|
||||||
|
<h4>
|
||||||
|
{{translate("ORGANISATION.JOIN_REQUEST.REQUEST_CONFIRM", {name: organisation.name})}}
|
||||||
|
<small>{{translate("ORGANISATION.JOIN_REQUEST.APPROVAL_REQUIRED")}}</small>
|
||||||
|
</h4>
|
||||||
|
{% else %}
|
||||||
|
<h4>{{translate("ORGANISATION.JOIN_CONFIRM", {name: organisation.name})}}</h4>
|
||||||
|
{% endif %}
|
||||||
|
<br>
|
||||||
|
<div class="btn-group-action">
|
||||||
|
<button type="submit" class="btn btn-success btn-lg btn-block">{{translate("ORGANISATION.JOIN_YES")}}</button>
|
||||||
|
<button type="button" class="btn btn-default btn-lg btn-block" data-dismiss="modal">{{translate("CANCEL")}}</button>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
{% endblock %}
|
||||||
Reference in New Issue
Block a user