Added full_name field to actors, and made the administer entities permission finer grained

This commit is contained in:
naomi 2021-02-08 13:38:54 +00:00
parent 6fbaf433e8
commit 3dd71bf2c0
11 changed files with 62 additions and 38 deletions

View File

@ -6,6 +6,14 @@ body {
font-size: 1em !important; font-size: 1em !important;
} }
div[data-drupal-selector=edit-user-bulk-form] {
display: none;
}
.layout-container {
max-width: 95% !important;
}
/* Free the people from the tyranny of the useless search button */ /* Free the people from the tyranny of the useless search button */
#edit-submit-actor-search{ #edit-submit-actor-search{
display: none; display: none;

View File

@ -0,0 +1,7 @@
opencase_cases.manage_case_types:
title: 'Manage case types'
description: 'Configure types of cases and their fields'
menu_name: opencase
parent: opencase.opencase_admin_menu
url: internal:/admin/opencase/oc_case_type
weight: 2

View File

@ -10,7 +10,7 @@ field_name: field_linked_opencase_actor
entity_type: user entity_type: user
bundle: user bundle: user
label: 'Person in OpenCase' label: 'Person in OpenCase'
description: 'If this user is also a person in OpenCase (e.g. a staff member or a volunteer), start typing the name here to link them. This will ensure they have access to the right cases.' description: 'If this user is also a person in OpenCase (e.g. a staff member or a volunteer), start typing the name here to link them. This will make their name appear against activities they are involved in.'
required: false required: false
translatable: false translatable: false
default_value: { } default_value: { }

View File

@ -5,9 +5,14 @@ view edit delete all actor entities:
title: 'View/Edit/Delete all types of people' title: 'View/Edit/Delete all types of people'
description: '' description: ''
administer opencase entity bundles: administer actor bundles:
title: 'Administer OpenCase Actor/Case/Activity Types' title: 'Administer OpenCase Person Types'
description: 'Create, configure and delete types of actor (such as "Client" or "Legal Advisor"), types of case (such as "Housing" or "Asylum") and types of activity (such as "Case Note" or "Interview")'
administer case bundles:
title: 'Administer OpenCase Case Types'
administer activity bundles:
title: 'Administer OpenCase Activity Types'
administer actor entities: administer actor entities:
title: 'Administer Actor entities' title: 'Administer Actor entities'
@ -45,6 +50,11 @@ revert all case revisions:
delete all case revisions: delete all case revisions:
title: 'Delete all revisions' title: 'Delete all revisions'
description: 'Role requires permission to <em>view Case revisions</em> and <em>delete rights</em> for case entities in question or <em>administer case entities</em>.' description: 'Role requires permission to <em>view Case revisions</em> and <em>delete rights</em> for case entities in question or <em>administer case entities</em>.'
view published activity entities:
title: 'View published Activity entities'
add activity entities: add activity entities:
title: 'Create new Activity entities' title: 'Create new Activity entities'

View File

@ -24,7 +24,7 @@ use Drupal\Core\Config\Entity\ConfigEntityBundleBase;
* }, * },
* }, * },
* config_prefix = "oc_activity_type", * config_prefix = "oc_activity_type",
* admin_permission = "administer opencase entity bundles", * admin_permission = "administer activity bundles",
* bundle_of = "oc_activity", * bundle_of = "oc_activity",
* entity_keys = { * entity_keys = {
* "id" = "id", * "id" = "id",

View File

@ -115,9 +115,13 @@ class OCActor extends RevisionableContentEntityBase implements OCActorInterface
} }
} }
$name = $this->get('first_name')->value . ' '; if ($this->get('full_name')->value) {
if ($this->get('middle_names')->value) $name .= $this->get('middle_names')->value . ' '; $name = $this->get('full_name')->value . ' ';
$name .= $this->get('last_name')->value . ' '; } else {
$name = $this->get('first_name')->value . ' ';
if ($this->get('middle_names')->value) $name .= $this->get('middle_names')->value . ' ';
$name .= $this->get('last_name')->value . ' ';
}
$name .= '(' . $this->type->entity->label() . ')'; $name .= '(' . $this->type->entity->label() . ')';
$this->setName($name); $this->setName($name);
@ -238,6 +242,24 @@ class OCActor extends RevisionableContentEntityBase implements OCActorInterface
'weight' => -10, 'weight' => -10,
]); ]);
// When configuring a person type, you will need to choose whether to have full name or first and last name fields displayed.
$fields['full_name'] = BaseFieldDefinition::create('string')
->setDescription(t('The person\'s name.'))
->setLabel(t('Name'))
->setRevisionable(TRUE)
->setSettings([
'max_length' => 20,
'text_processing' => 0,
])
->setDisplayConfigurable("form", true)
->setDisplayConfigurable("view", true)
->setDefaultValue('')
->setDisplayOptions('form', [
'type' => 'string_textfield',
'weight' => -50,
])
->setRequired(TRUE);
$fields['first_name'] = BaseFieldDefinition::create('string') $fields['first_name'] = BaseFieldDefinition::create('string')
->setLabel(t('First Name')) ->setLabel(t('First Name'))
->setDescription(t("The person's first name.")) ->setDescription(t("The person's first name."))

View File

@ -24,7 +24,7 @@ use Drupal\Core\Config\Entity\ConfigEntityBundleBase;
* }, * },
* }, * },
* config_prefix = "oc_actor_type", * config_prefix = "oc_actor_type",
* admin_permission = "administer opencase entity bundles", * admin_permission = "administer actor bundles",
* bundle_of = "oc_actor", * bundle_of = "oc_actor",
* entity_keys = { * entity_keys = {
* "id" = "id", * "id" = "id",

View File

@ -144,24 +144,7 @@ class OCBankAccount extends ContentEntityBase implements OCBankAccountInterface
->setDescription(t('The user ID of author of the Bank Account entity.')) ->setDescription(t('The user ID of author of the Bank Account entity.'))
->setRevisionable(TRUE) ->setRevisionable(TRUE)
->setSetting('target_type', 'user') ->setSetting('target_type', 'user')
->setSetting('handler', 'default') ->setSetting('handler', 'default');
->setDisplayOptions('view', [
'label' => 'hidden',
'type' => 'author',
'weight' => 0,
])
->setDisplayOptions('form', [
'type' => 'entity_reference_autocomplete',
'weight' => 5,
'settings' => [
'match_operator' => 'CONTAINS',
'size' => '60',
'autocomplete_type' => 'tags',
'placeholder' => '',
],
])
->setDisplayConfigurable('form', TRUE)
->setDisplayConfigurable('view', TRUE);
$fields['name'] = BaseFieldDefinition::create('string') $fields['name'] = BaseFieldDefinition::create('string')
->setLabel(t('Name')) ->setLabel(t('Name'))

View File

@ -24,7 +24,7 @@ use Drupal\Core\Config\Entity\ConfigEntityBundleBase;
* }, * },
* }, * },
* config_prefix = "oc_case_type", * config_prefix = "oc_case_type",
* admin_permission = "administer opencase entity bundles", * admin_permission = "administer case bundles",
* bundle_of = "oc_case", * bundle_of = "oc_case",
* entity_keys = { * entity_keys = {
* "id" = "id", * "id" = "id",

View File

@ -49,15 +49,16 @@ class ContextualMenu extends BlockBase {
*/ */
private function generateLinksForAddingNewActivities($title, $query = []) { private function generateLinksForAddingNewActivities($title, $query = []) {
$title = t($title); $title = t($title);
$markup = "<h1>$title: </h1>"; $markup = "<br /><p><strong>$title: </strong>";
$allActivityTypes = \Drupal::service('entity_type.bundle.info')->getBundleInfo('oc_activity'); $allActivityTypes = \Drupal::service('entity_type.bundle.info')->getBundleInfo('oc_activity');
foreach($allActivityTypes as $machine_name => $activityType) { foreach($allActivityTypes as $machine_name => $activityType) {
$label = $activityType['label']; $label = $activityType['label'];
$url = \Drupal\Core\Url::fromRoute("entity.oc_activity.add_form", ['oc_activity_type' => $machine_name]); $url = \Drupal\Core\Url::fromRoute("entity.oc_activity.add_form", ['oc_activity_type' => $machine_name]);
$url->setOption('query', $query); $url->setOption('query', $query);
$link = \Drupal\Core\Link::fromTextAndUrl($label, $url)->toString(); $link = \Drupal\Core\Link::fromTextAndUrl($label, $url)->toString();
$markup .= "<p>$link</p>"; $markup .= "&nbsp;&nbsp; $link";
} }
$markup .= "</p>";
return "<div class='openactor_add_links'>$markup</div>"; return "<div class='openactor_add_links'>$markup</div>";
} }
} }

View File

@ -50,13 +50,6 @@ opencase.manage_person_types:
parent: opencase.opencase_admin_menu parent: opencase.opencase_admin_menu
url: internal:/admin/opencase/oc_actor_type url: internal:/admin/opencase/oc_actor_type
weight: 1 weight: 1
opencase.manage_case_types:
title: 'Manage case types'
description: 'Configure types of cases and their fields'
menu_name: opencase
parent: opencase.opencase_admin_menu
url: internal:/admin/opencase/oc_case_type
weight: 2
opencase.manage_activity_types: opencase.manage_activity_types:
title: 'Manage activity types' title: 'Manage activity types'
description: 'Configure types of activities and their fields' description: 'Configure types of activities and their fields'