added see al org's page and menu item, made fields configurable for actor

This commit is contained in:
Nick 2022-04-08 14:00:44 +02:00
parent b85cbaf398
commit 20ed3d4f39
5 changed files with 94 additions and 106 deletions

View File

@ -267,6 +267,7 @@ class OCActivity extends RevisionableContentEntityBase implements OCActivityInte
->setDescription('If this box is not ticked this record will be hidden from view for most users. Users with access to unpublished entities will be able to restore it if needed.') ->setDescription('If this box is not ticked this record will be hidden from view for most users. Users with access to unpublished entities will be able to restore it if needed.')
->setRevisionable(TRUE) ->setRevisionable(TRUE)
->setDisplayConfigurable('form', TRUE) ->setDisplayConfigurable('form', TRUE)
->setDisplayConfigurable('view', true)
->setDefaultValue(TRUE); ->setDefaultValue(TRUE);
$fields['user_id'] = BaseFieldDefinition::create('entity_reference') $fields['user_id'] = BaseFieldDefinition::create('entity_reference')
@ -277,10 +278,7 @@ class OCActivity extends RevisionableContentEntityBase implements OCActivityInte
->setSetting('handler', 'default') ->setSetting('handler', 'default')
->setTranslatable(TRUE) ->setTranslatable(TRUE)
->setDisplayConfigurable('view', true) ->setDisplayConfigurable('view', true)
->setDisplayOptions('view', [ ->setDisplayConfigurable('form', TRUE);
'label' => 'above',
'type' => 'author',
]);
$fields['name'] = BaseFieldDefinition::create('string') $fields['name'] = BaseFieldDefinition::create('string')
->setLabel(t('Subject')) ->setLabel(t('Subject'))
@ -292,15 +290,6 @@ class OCActivity extends RevisionableContentEntityBase implements OCActivityInte
->setDefaultValue('') ->setDefaultValue('')
->setDisplayConfigurable('form', true) ->setDisplayConfigurable('form', true)
->setDisplayConfigurable('view', true) ->setDisplayConfigurable('view', true)
->setDisplayOptions('view', [
'label' => 'hidden',
'type' => 'string',
'weight' => -3,
])
->setDisplayOptions('form', [
'type' => 'string_textfield',
'weight' => -3,
])
->setRequired(TRUE); ->setRequired(TRUE);
$fields['description'] = BaseFieldDefinition::create('string_long') $fields['description'] = BaseFieldDefinition::create('string_long')
@ -310,7 +299,6 @@ class OCActivity extends RevisionableContentEntityBase implements OCActivityInte
'max_length' => 50, 'max_length' => 50,
'text_processing' => 0, 'text_processing' => 0,
]) ])
->setDefaultValue('')
->setDisplayConfigurable('form', true) ->setDisplayConfigurable('form', true)
->setDisplayConfigurable('view', true) ->setDisplayConfigurable('view', true)
->setRequired(FALSE); ->setRequired(FALSE);
@ -322,15 +310,7 @@ class OCActivity extends RevisionableContentEntityBase implements OCActivityInte
'suffix' => 'minutes', 'suffix' => 'minutes',
]) ])
->SetDisplayConfigurable("form", true) ->SetDisplayConfigurable("form", true)
->SetDisplayConfigurable("view", true) ->SetDisplayConfigurable("view", true);
->setDefaultValue('')
->setDisplayOptions('view', [
'label' => 'above',
'weight' => -3,
])
->setDisplayOptions('form', [
'weight' => -3,
]);
$fields['created'] = BaseFieldDefinition::create('created') $fields['created'] = BaseFieldDefinition::create('created')
->setLabel(t('Created')) ->setLabel(t('Created'))

View File

@ -122,7 +122,7 @@ class OCActor extends RevisionableContentEntityBase implements OCActorInterface
$name = $this->get('first_name')->value . ' '; $name = $this->get('first_name')->value . ' ';
if ($this->get('middle_names')->value) $name .= $this->get('middle_names')->value . ' '; if ($this->get('middle_names')->value) $name .= $this->get('middle_names')->value . ' ';
$name .= $this->get('last_name')->value . ' '; $name .= $this->get('last_name')->value . ' ';
$this->setName($name); $this->setName($name);
// If no revision author has been set explicitly, make the oc_actor owner the // If no revision author has been set explicitly, make the oc_actor owner the
@ -218,6 +218,7 @@ class OCActor extends RevisionableContentEntityBase implements OCActorInterface
->setDescription('If this box is not ticked this record will be hidden from view for most users. Users with access to unpublished entities will be able to restore it if needed.') ->setDescription('If this box is not ticked this record will be hidden from view for most users. Users with access to unpublished entities will be able to restore it if needed.')
->setRevisionable(TRUE) ->setRevisionable(TRUE)
->setDisplayConfigurable("form", true) ->setDisplayConfigurable("form", true)
->setDisplayConfigurable("view", true)
->setDefaultValue(TRUE); ->setDefaultValue(TRUE);
// The name gets set on preSave, from the first middle and last // The name gets set on preSave, from the first middle and last
@ -226,7 +227,7 @@ class OCActor extends RevisionableContentEntityBase implements OCActorInterface
->setSettings([ ->setSettings([
'max_length' => 100, 'max_length' => 100,
'text_processing' => 0, 'text_processing' => 0,
]); ]);
$fields['user_id'] = BaseFieldDefinition::create('entity_reference') $fields['user_id'] = BaseFieldDefinition::create('entity_reference')
->setLabel(t('Entered by')) ->setLabel(t('Entered by'))
@ -234,6 +235,8 @@ class OCActor extends RevisionableContentEntityBase implements OCActorInterface
->setRevisionable(TRUE) ->setRevisionable(TRUE)
->setSetting('target_type', 'user') ->setSetting('target_type', 'user')
->setSetting('handler', 'default') ->setSetting('handler', 'default')
->setDisplayConfigurable("form", true)
->setDisplayConfigurable("view", true)
->setTranslatable(TRUE); ->setTranslatable(TRUE);
$fields['first_name'] = BaseFieldDefinition::create('string') $fields['first_name'] = BaseFieldDefinition::create('string')
@ -247,10 +250,6 @@ class OCActor extends RevisionableContentEntityBase implements OCActorInterface
->setDisplayConfigurable("form", true) ->setDisplayConfigurable("form", true)
->setDisplayConfigurable("view", true) ->setDisplayConfigurable("view", true)
->setDefaultValue('') ->setDefaultValue('')
->setDisplayOptions('form', [
'type' => 'string_textfield',
'weight' => -100,
])
->setRequired(TRUE); ->setRequired(TRUE);
$fields['middle_names'] = BaseFieldDefinition::create('string') $fields['middle_names'] = BaseFieldDefinition::create('string')
@ -264,10 +263,6 @@ class OCActor extends RevisionableContentEntityBase implements OCActorInterface
->setDisplayConfigurable("form", true) ->setDisplayConfigurable("form", true)
->setDisplayConfigurable("view", true) ->setDisplayConfigurable("view", true)
->setDefaultValue('') ->setDefaultValue('')
->setDisplayOptions('form', [
'type' => 'string_textfield',
'weight' => -99,
])
->setRequired(FALSE); ->setRequired(FALSE);
$fields['last_name'] = BaseFieldDefinition::create('string') $fields['last_name'] = BaseFieldDefinition::create('string')
@ -281,10 +276,6 @@ class OCActor extends RevisionableContentEntityBase implements OCActorInterface
'text_processing' => 0, 'text_processing' => 0,
]) ])
->setDefaultValue('') ->setDefaultValue('')
->setDisplayOptions('form', [
'type' => 'string_textfield',
'weight' => -98,
])
->setRequired(TRUE); ->setRequired(TRUE);
// Contact details. // Contact details.
@ -297,16 +288,7 @@ class OCActor extends RevisionableContentEntityBase implements OCActorInterface
'text_processing' => 0, 'text_processing' => 0,
)) ))
->setDisplayConfigurable("form", true) ->setDisplayConfigurable("form", true)
->setDisplayConfigurable("view", true) ->setDisplayConfigurable("view", true);
->setDisplayOptions('view', array(
'label' => 'above',
'type' => 'string',
'weight' => -5,
))
->setDisplayOptions('form', array(
'type' => 'string_textfield',
'weight' => -5,
));
$fields['phone'] = BaseFieldDefinition::create('string') $fields['phone'] = BaseFieldDefinition::create('string')
->setLabel(t('Main Phone Number')) ->setLabel(t('Main Phone Number'))
->setRevisionable(TRUE) ->setRevisionable(TRUE)
@ -316,16 +298,7 @@ class OCActor extends RevisionableContentEntityBase implements OCActorInterface
'text_processing' => 0, 'text_processing' => 0,
)) ))
->setDisplayConfigurable("form", true) ->setDisplayConfigurable("form", true)
->setDisplayConfigurable("view", true) ->setDisplayConfigurable("view", true);
->setDisplayOptions('view', array(
'label' => 'above',
'type' => 'string',
'weight' => -4,
))
->setDisplayOptions('form', array(
'type' => 'string_textfield',
'weight' => -4,
));
$fields['phone2'] = BaseFieldDefinition::create('string') $fields['phone2'] = BaseFieldDefinition::create('string')
->setRevisionable(TRUE) ->setRevisionable(TRUE)
->setLabel(t('Alternative Phone Number')) ->setLabel(t('Alternative Phone Number'))
@ -335,16 +308,7 @@ class OCActor extends RevisionableContentEntityBase implements OCActorInterface
'text_processing' => 0, 'text_processing' => 0,
)) ))
->setDisplayConfigurable("form", true) ->setDisplayConfigurable("form", true)
->setDisplayConfigurable("view", true) ->setDisplayConfigurable("view", true);
->setDisplayOptions('view', array(
'label' => 'above',
'type' => 'string',
'weight' => -3,
))
->setDisplayOptions('form', array(
'type' => 'string_textfield',
'weight' => -3,
));
$fields['postal_address'] = BaseFieldDefinition::create('string_long') $fields['postal_address'] = BaseFieldDefinition::create('string_long')
->setRevisionable(TRUE) ->setRevisionable(TRUE)
->setLabel(t('Postal Address')) ->setLabel(t('Postal Address'))
@ -355,16 +319,7 @@ class OCActor extends RevisionableContentEntityBase implements OCActorInterface
'text_processing' => 0, 'text_processing' => 0,
)) ))
->setDisplayConfigurable("form", true) ->setDisplayConfigurable("form", true)
->setDisplayConfigurable("view", true) ->setDisplayConfigurable("view", true);
->setDisplayOptions('view', array(
'label' => 'above',
'type' => 'basic_string',
'weight' => -2,
))
->setDisplayOptions('form', array(
'type' => 'string_textarea',
'weight' => -2,
));
$fields['post_code'] = BaseFieldDefinition::create('string') $fields['post_code'] = BaseFieldDefinition::create('string')
->setRevisionable(TRUE) ->setRevisionable(TRUE)
->setLabel(t('Post Code')) ->setLabel(t('Post Code'))
@ -374,16 +329,7 @@ class OCActor extends RevisionableContentEntityBase implements OCActorInterface
'text_processing' => 0, 'text_processing' => 0,
)) ))
->setDisplayConfigurable("form", true) ->setDisplayConfigurable("form", true)
->setDisplayConfigurable("view", true) ->setDisplayConfigurable("view", true);
->setDisplayOptions('view', array(
'label' => 'above',
'type' => 'string',
'weight' => -1,
))
->setDisplayOptions('form', array(
'type' => 'string_textfield',
'weight' => -1,
));
$fields['created'] = BaseFieldDefinition::create('created') $fields['created'] = BaseFieldDefinition::create('created')
->setLabel(t('Created')) ->setLabel(t('Created'))
@ -400,13 +346,6 @@ class OCActor extends RevisionableContentEntityBase implements OCActorInterface
->setRevisionable(TRUE) ->setRevisionable(TRUE)
->setTranslatable(TRUE); ->setTranslatable(TRUE);
$fields['user_login'] = BaseFieldDefinition::create('boolean')
->setLabel(t('Login Access'))
->setDescription(t('Whether this person should be able to log into the system.'))
->setDisplayConfigurable('form', true)
->setDisplayConfigurable('display', true)
->setDefaultValue(FALSE);
return $fields; return $fields;
} }

View File

@ -1,16 +1,21 @@
opencase.see_all: opencase.see_all:
title: 'See all...' title: 'See all...'
menu_name: opencase menu_name: opencase
route_name: opencase.opencase_cases_menu route_name: opencase.opencase_cases_menu
weight: weight:
opencase.see_all_people_links: opencase.see_all_people_links:
class: Drupal\opencase\Plugin\Menu\SeeAllActorsMenuLink class: Drupal\opencase\Plugin\Menu\SeeAllActorsMenuLink
deriver: Drupal\opencase\Plugin\Derivative\SeeAllActorsMenuLink deriver: Drupal\opencase\Plugin\Derivative\SeeAllActorsMenuLink
menu_name: opencase menu_name: opencase
parent: opencase.see_all parent: opencase.see_all
opencase.see_all_organisations_links:
class: Drupal\opencase\Plugin\Menu\SeeAllOrganisationsMenuLink
deriver: Drupal\opencase\Plugin\Derivative\SeeAllOrganisationsMenuLink
menu_name: opencase
parent: opencase.see_all
opencase.opencase_add_new_things_menu: opencase.opencase_add_new_things_menu:
title: 'Add new...' title: 'Add new...'
menu_name: opencase menu_name: opencase
route_name: opencase.opencase_add_new_things_menu route_name: opencase.opencase_add_new_things_menu
weight: 1 weight: 1
opencase.add_people_links: opencase.add_people_links:
@ -38,59 +43,59 @@ opencase.opencase_admin_menu:
title: 'Administration' title: 'Administration'
description: 'Management and Configuration' description: 'Management and Configuration'
route_name: opencase.opencase_admin_menu route_name: opencase.opencase_admin_menu
menu_name: opencase menu_name: opencase
weight: 100 weight: 100
opencase.manage_user_logins: opencase.manage_user_logins:
title: 'Manage user logins' title: 'Manage user logins'
description: 'Manage who can access the system' description: 'Manage who can access the system'
menu_name: opencase menu_name: opencase
parent: opencase.opencase_admin_menu parent: opencase.opencase_admin_menu
url: internal:/admin/people url: internal:/admin/people
weight: 0 weight: 0
opencase.manage_organisation_types: opencase.manage_organisation_types:
title: 'Manage organisation types' title: 'Manage organisation types'
description: 'Configure types of people and their fields' description: 'Configure types of people and their fields'
menu_name: opencase menu_name: opencase
parent: opencase.opencase_admin_menu parent: opencase.opencase_admin_menu
url: internal:/admin/opencase/oc_organisation_type url: internal:/admin/opencase/oc_organisation_type
weight: 1 weight: 1
opencase.manage_person_types: opencase.manage_person_types:
title: 'Manage person types' title: 'Manage person types'
description: 'Configure types of people and their fields' description: 'Configure types of people and their fields'
menu_name: opencase menu_name: opencase
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_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'
menu_name: opencase menu_name: opencase
parent: opencase.opencase_admin_menu parent: opencase.opencase_admin_menu
url: internal:/admin/opencase/oc_activity_type url: internal:/admin/opencase/oc_activity_type
weight: 3 weight: 3
opencase.manage_case_fee_types: opencase.manage_case_fee_types:
title: 'Manage case fee types' title: 'Manage case fee types'
description: 'Configure types of case fees and their fields' description: 'Configure types of case fees and their fields'
menu_name: opencase menu_name: opencase
parent: opencase.opencase_admin_menu parent: opencase.opencase_admin_menu
url: internal:/opencase/oc_case_fee_type url: internal:/opencase/oc_case_fee_type
weight: 3 weight: 3
opencase.manage_case_provision_types: opencase.manage_case_provision_types:
title: 'Manage case provision types' title: 'Manage case provision types'
description: 'Configure types of case provisions and their fields' description: 'Configure types of case provisions and their fields'
menu_name: opencase menu_name: opencase
parent: opencase.opencase_admin_menu parent: opencase.opencase_admin_menu
url: internal:/opencase/oc_case_provision_type url: internal:/opencase/oc_case_provision_type
weight: 3 weight: 3
opencase.manage_event_types: opencase.manage_event_types:
title: 'Manage event types' title: 'Manage event types'
description: 'Configure types of people and their fields' description: 'Configure types of people and their fields'
menu_name: opencase menu_name: opencase
parent: opencase.opencase_admin_menu parent: opencase.opencase_admin_menu
url: internal:/admin/opencase/oc_event_type url: internal:/admin/opencase/oc_event_type
weight: 1 weight: 1
opencase.reporting: opencase.reporting:
title: 'Reporting' title: 'Reporting'
menu_name: opencase menu_name: opencase
route_name: opencase.opencase_reporting_menu route_name: opencase.opencase_reporting_menu
weight: 0 weight: 0

View File

@ -0,0 +1,55 @@
<?php
namespace Drupal\opencase\Plugin\Derivative;
use Drupal\Component\Plugin\Derivative\DeriverBase;
use Drupal\Core\Plugin\Discovery\ContainerDeriverInterface;
use Drupal\Core\Entity\EntityTypeManagerInterface;
use Symfony\Component\DependencyInjection\ContainerInterface;
/**
 * Derivative class that provides the menu links adding various types of organisations
 */
class SeeAllOrganisationsMenuLink extends DeriverBase implements ContainerDeriverInterface {
/**
   * @var EntityTypeManagerInterface $entityTypeManager.
   */
protected $entityTypeManager;
/**
   * Creates a AddActorsMenuLink instance.
   *
   * @param $base_plugin_id
   * @param EntityTypeManagerInterface $entity_type_manager
   */
public function __construct($base_plugin_id, EntityTypeManagerInterface $entity_type_manager) {
$this->entityTypeManager = $entity_type_manager;
}
/**
   * {@inheritdoc}
   */
public static function create(ContainerInterface $container, $base_plugin_id) {
return new static(
$base_plugin_id,
$container->get('entity_type.manager')
);
}
/**
   * {@inheritdoc}
   */
public function getDerivativeDefinitions($base_plugin_definition) {
$links = [];
$organisationTypes = $this->entityTypeManager->getStorage('oc_organisation_type')->loadMultiple();
foreach ($organisationTypes as $id => $organisationType) {
$links[$id] = [
'title' => $organisationType->label(),
'route_name' => "view.organisations.page_1",
'route_parameters' => ['type' => $organisationType->id()]
] + $base_plugin_definition;
}
return $links;
}
}

View File

@ -0,0 +1,9 @@
<?php
namespace Drupal\opencase\Plugin\Menu;
use Drupal\Core\Menu\MenuLinkDefault;
/**
* Represents a menu link for seeing all organisations of various types.
*/
class SeeAllOrganisationsMenuLink extends MenuLinkDefault {}