fixed #1998 disabled roles not posted so not saved, so removed from user
This commit is contained in:
parent
dd38d8d2b2
commit
6255d58a95
|
@ -4,7 +4,7 @@
|
|||
use \Drupal\Core\Link;
|
||||
// use Drupal\Core\Entity\EntityInterface;
|
||||
use Drupal\Core\Entity\EntityFormInterface;
|
||||
// use Drupal\Core\Form\FormStateInterface;
|
||||
use Drupal\Core\Form\FormStateInterface;
|
||||
use Drupal\user\EntityOwnerInterface;
|
||||
|
||||
|
||||
|
@ -50,6 +50,8 @@ function materio_commerce_form_role_delegation_role_assign_form_alter(&$form, &$
|
|||
$licenses = $license_storage->loadByProperties(['uid' => $account->id()]);
|
||||
|
||||
if ($licenses) {
|
||||
// reorganise licenses by role
|
||||
// and record by role if a license is active
|
||||
$licenses_by_role = [];
|
||||
foreach ($licenses as $lid => $license) {
|
||||
$licensed_role_id = $license->license_role->target_id;
|
||||
|
@ -59,6 +61,7 @@ function materio_commerce_form_role_delegation_role_assign_form_alter(&$form, &$
|
|||
$licenses_by_role[$licensed_role_id]['license_active'] = true;
|
||||
}
|
||||
}
|
||||
// loop throught roles then licenses by role
|
||||
foreach ($licenses_by_role as $rid => $role_licenses) {
|
||||
$license_active = isset($role_licenses['license_active']) ? true : false;
|
||||
$description = "";
|
||||
|
@ -68,6 +71,7 @@ function materio_commerce_form_role_delegation_role_assign_form_alter(&$form, &$
|
|||
|
||||
$description = t("This role is granted by a license. It cannot be removed manually.<br/>");
|
||||
}
|
||||
// reverse the licenses to display the last first
|
||||
$reversed_licenses = array_reverse($role_licenses['licenses']);
|
||||
foreach ($reversed_licenses as $license) {
|
||||
$license_state = $license->getState()->getValue()['value'];
|
||||
|
@ -141,6 +145,8 @@ function materio_commerce_form_user_form_alter(&$form, &$form_state, $form_id) {
|
|||
$licenses = $license_storage->loadByProperties(['uid' => $entity->id()]);
|
||||
|
||||
if ($licenses) {
|
||||
// reorganise licenses by role
|
||||
// and record by role if a license is active
|
||||
$licenses_by_role = [];
|
||||
foreach ($licenses as $lid => $license) {
|
||||
$licensed_role_id = $license->license_role->target_id;
|
||||
|
@ -150,15 +156,34 @@ function materio_commerce_form_user_form_alter(&$form, &$form_state, $form_id) {
|
|||
$licenses_by_role[$licensed_role_id]['license_active'] = true;
|
||||
}
|
||||
}
|
||||
|
||||
// we need to validate the form as disabled cekbox are not sent on submit
|
||||
// as it remove the disabled roles
|
||||
$form["#validate"][] = 'materio_commerce_form_user_form_validate';
|
||||
// hidden licensed role will be re-injected in 'role_change' field values during our validate
|
||||
$form['licensed_roles'] = array(
|
||||
'#type'=>"container",
|
||||
'#tree' => true
|
||||
);
|
||||
// loop throught roles then licenses by role
|
||||
$form["role_change"]["widget"]['#options_attributes'] = [];
|
||||
foreach ($licenses_by_role as $rid => $role_licenses) {
|
||||
$license_active = isset($role_licenses['license_active']) ? true : false;
|
||||
$description = "";
|
||||
if($license_active) {
|
||||
$form["role_change"]["widget"][$rid]['#disabled'] = TRUE;
|
||||
$form["role_change"]["widget"][$rid]['#default_value'] = TRUE;
|
||||
// $form["role_change"][$rid]['#default_value'] = TRUE;
|
||||
|
||||
$description = t("This role is granted by a license. It cannot be removed manually.<br/>");
|
||||
|
||||
// record the role in hidden element, as disabled checkboxes are not posted
|
||||
// we'll re-establish the right values in validate function
|
||||
$form['licensed_roles'][$rid] = array(
|
||||
'#type' => 'hidden',
|
||||
'#value' => $rid
|
||||
);
|
||||
}
|
||||
// reverse the licenses to display the last first
|
||||
$reversed_licenses = array_reverse($role_licenses['licenses']);
|
||||
foreach ($reversed_licenses as $license) {
|
||||
$license_state = $license->getState()->getValue()['value'];
|
||||
|
@ -201,5 +226,14 @@ function materio_commerce_form_user_form_alter(&$form, &$form_state, $form_id) {
|
|||
}
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
function materio_commerce_form_user_form_validate($form, FormStateInterface &$form_state) {
|
||||
$values = $form_state->getValues();
|
||||
if (!empty($values['licensed_roles'])) {
|
||||
foreach ($values['licensed_roles'] as $rid => $value) {
|
||||
$values['role_change'][] = array("target_id"=>$value);
|
||||
}
|
||||
$form_state->setValues($values);
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue