In progress of adding revision views & making entity displays nicer

This commit is contained in:
Naomi 2020-05-13 15:41:59 +01:00
parent b83f0b44b4
commit 18e32335f5
10 changed files with 164 additions and 53 deletions

View File

@ -46,3 +46,27 @@ body {
td.views-field { td.views-field {
vertical-align: top; vertical-align: top;
} }
/* Entity displays */
.oc_entity .left {
display: inline-block;
width: 45%;
padding: 1em;
}
.oc_entity .right {
display: inline-block;
width: 45%;
padding: 1em;
float: right;
}
.oc_entity .field {
margin-top: 1em;
}
/* Make entity reference field labels match normal field labels */
.field--type-entity-reference .field__label {
font-family: Georgia, "Times New Roman", Times, serif;
font-size: 1em !important;
font-weight: bold !important;
}

View File

@ -20,11 +20,17 @@ use Drupal\Core\Render\Element;
* - attributes: HTML attributes for the containing element. * - attributes: HTML attributes for the containing element.
*/ */
function template_preprocess_oc_actor(array &$variables) { function template_preprocess_oc_actor(array &$variables) {
// Fetch OCActor Entity Object. // Make the id available to the template and also separate the fields
$oc_actor = $variables['elements']['#oc_actor']; // into two sections to be displayed in two columns.
$variables['id'] = $variables['elements']['#oc_actor']->get('id')[0]->get('value')->getValue();
// Helpful $content variable for templates. $variables['contact_details'] = array();
$variables['fields_other_than_contact_details'] = array();
foreach (Element::children($variables['elements']) as $key) { foreach (Element::children($variables['elements']) as $key) {
$variables['content'][$key] = $variables['elements'][$key]; $variables['content'][$key] = $variables['elements'][$key];
if (in_array($key, ['email', 'phone', 'phone2', 'postal_address', 'post_code'])) {
$variables['contact_details'][$key] = $variables['elements'][$key];
} else {
$variables['fields_other_than_contact_details'][$key] = $variables['elements'][$key];
}
} }
} }

View File

@ -20,11 +20,18 @@ use Drupal\Core\Render\Element;
* - attributes: HTML attributes for the containing element. * - attributes: HTML attributes for the containing element.
*/ */
function template_preprocess_oc_case(array &$variables) { function template_preprocess_oc_case(array &$variables) {
// Fetch OCCase Entity Object. // Separate the fields into two sections to be displayed in two columns.
$oc_case = $variables['elements']['#oc_case']; // Remove the name (title) field as this is displayed anyway.
$variables['id'] = $variables['elements']['#oc_case']->get('id')[0]->get('value')->getValue();
// Helpful $content variable for templates. $variables['base_fields'] = array();
$variables['other_fields'] = array();
foreach (Element::children($variables['elements']) as $key) { foreach (Element::children($variables['elements']) as $key) {
$variables['content'][$key] = $variables['elements'][$key]; $variables['content'][$key] = $variables['elements'][$key];
if (in_array($key, ['created', 'changed', 'files', 'actors_involved', 'status', 'user_id'])) {
$variables['base_fields'][$key] = $variables['elements'][$key];
} else {
$variables['other_fields'][$key] = $variables['elements'][$key];
unset($variables['other_fields']['name']);
}
} }
} }

View File

@ -1,5 +1,62 @@
<?php <?php
// Change date formats on created and changed dates.
function opencase_entities_update_801910() {
$update_manager = \Drupal::entityDefinitionUpdateManager();
$field = $update_manager->getFieldStorageDefinition('created', 'oc_case');
$properties = array(
'targetEntityType' => $field->getTargetEntityTypeId(),
'bundle' => $field->getTargetBundle()
);
if ($view_displays = \Drupal::entityTypeManager()->getStorage('entity_view_display')->loadByProperties($properties)) {
foreach ($view_displays as $view_display) {
$view_display->setComponent('created', array(
'type' => 'datetime_default',
'settings' => ['format_type' => 'short'],
) + $component)->save();
}
}
}
// Make contact details revisionable.
function opencase_entities_update_80191() {
$update_manager = \Drupal::entityDefinitionUpdateManager();
$contact_details_fields = ['email', 'phone', 'phone2', 'postal_address', 'post_code'];
foreach($contact_details_fields as $field) {
$definition = $update_manager->getFieldStorageDefinition($field, 'oc_actor');
$definition->setRevisionable(TRUE);
}
}
use \Drupal\Core\Entity\Sql\SqlContentEntityStorageSchemaConverter;
/**
* Update my_entity to be revisionable.
*/
function opencase_entities_update_8019(&$sandbox) {
$schema_converter = new SqlContentEntityStorageSchemaConverter(
'oc_actor',
\Drupal::entityTypeManager(),
\Drupal::entityDefinitionUpdateManager(),
\Drupal::service('entity.last_installed_schema.repository'),
\Drupal::keyValue('entity.storage_schema.sql'),
\Drupal::database()
);
$contact_details_fields = ['email', 'phone', 'phone2', 'postal_address', 'post_code'];
$schema_converter->convertToRevisionable($sandbox, $contact_details_fields);
}
// Make contact details revisionable.
function opencase_entities_update_8018() {
$update_manager = \Drupal::entityDefinitionUpdateManager();
$contact_details_fields = ['email', 'phone', 'phone2', 'postal_address', 'post_code'];
foreach($contact_details_fields as $field) {
$definition = $update_manager->getFieldStorageDefinition($field, 'oc_actor');
$update_manager->updateFieldStorageDefinition($definition);
}
}
function opencase_entities_update_8016() { function opencase_entities_update_8016() {
$update_manager = \Drupal::entityDefinitionUpdateManager(); $update_manager = \Drupal::entityDefinitionUpdateManager();
$definition = $update_manager->getFieldStorageDefinition('activity_date_time', 'oc_activity'); $definition = $update_manager->getFieldStorageDefinition('activity_date_time', 'oc_activity');
@ -30,4 +87,3 @@ function opencase_entities_update_8003() {
\Drupal::entityDefinitionUpdateManager() \Drupal::entityDefinitionUpdateManager()
->installFieldStorageDefinition('activity_date_time', 'oc_activity', 'oc_activity', $storage_definition); ->installFieldStorageDefinition('activity_date_time', 'oc_activity', 'oc_activity', $storage_definition);
} }

View File

@ -247,11 +247,6 @@ class OCActor extends RevisionableContentEntityBase implements OCActorInterface
'text_processing' => 0, 'text_processing' => 0,
]) ])
->setDefaultValue('') ->setDefaultValue('')
->setDisplayOptions('view', [
'label' => 'above',
'type' => 'string',
'weight' => -9,
])
->setDisplayOptions('form', [ ->setDisplayOptions('form', [
'type' => 'string_textfield', 'type' => 'string_textfield',
'weight' => -9, 'weight' => -9,
@ -267,11 +262,6 @@ class OCActor extends RevisionableContentEntityBase implements OCActorInterface
'text_processing' => 0, 'text_processing' => 0,
]) ])
->setDefaultValue('') ->setDefaultValue('')
->setDisplayOptions('view', [
'label' => 'above',
'type' => 'string',
'weight' => -8,
])
->setDisplayOptions('form', [ ->setDisplayOptions('form', [
'type' => 'string_textfield', 'type' => 'string_textfield',
'weight' => -8, 'weight' => -8,
@ -287,11 +277,6 @@ class OCActor extends RevisionableContentEntityBase implements OCActorInterface
'text_processing' => 0, 'text_processing' => 0,
]) ])
->setDefaultValue('') ->setDefaultValue('')
->setDisplayOptions('view', [
'label' => 'above',
'type' => 'string',
'weight' => -7,
])
->setDisplayOptions('form', [ ->setDisplayOptions('form', [
'type' => 'string_textfield', 'type' => 'string_textfield',
'weight' => -7, 'weight' => -7,
@ -313,6 +298,7 @@ class OCActor extends RevisionableContentEntityBase implements OCActorInterface
// so it is not exposed to user configuration. // so it is not exposed to user configuration.
$fields['email'] = BaseFieldDefinition::create('string') $fields['email'] = BaseFieldDefinition::create('string')
->setLabel(t('Email Address')) ->setLabel(t('Email Address'))
->setRevisionable(TRUE)
->setSettings(array( ->setSettings(array(
'default_value' => '', 'default_value' => '',
'max_length' => 30, 'max_length' => 30,
@ -329,6 +315,7 @@ class OCActor extends RevisionableContentEntityBase implements OCActorInterface
)); ));
$fields['phone'] = BaseFieldDefinition::create('string') $fields['phone'] = BaseFieldDefinition::create('string')
->setLabel(t('Main Phone Number')) ->setLabel(t('Main Phone Number'))
->setRevisionable(TRUE)
->setSettings(array( ->setSettings(array(
'default_value' => '', 'default_value' => '',
'max_length' => 20, 'max_length' => 20,
@ -344,6 +331,7 @@ class OCActor extends RevisionableContentEntityBase implements OCActorInterface
'weight' => -4, 'weight' => -4,
)); ));
$fields['phone2'] = BaseFieldDefinition::create('string') $fields['phone2'] = BaseFieldDefinition::create('string')
->setRevisionable(TRUE)
->setLabel(t('Alternative Phone Number')) ->setLabel(t('Alternative Phone Number'))
->setSettings(array( ->setSettings(array(
'default_value' => '', 'default_value' => '',
@ -360,6 +348,7 @@ class OCActor extends RevisionableContentEntityBase implements OCActorInterface
'weight' => -3, 'weight' => -3,
)); ));
$fields['postal_address'] = BaseFieldDefinition::create('string_long') $fields['postal_address'] = BaseFieldDefinition::create('string_long')
->setRevisionable(TRUE)
->setLabel(t('Postal Address')) ->setLabel(t('Postal Address'))
->setDescription(t('Full address, apart from post code.')) ->setDescription(t('Full address, apart from post code.'))
->setSettings(array( ->setSettings(array(
@ -377,6 +366,7 @@ class OCActor extends RevisionableContentEntityBase implements OCActorInterface
'weight' => -2, 'weight' => -2,
)); ));
$fields['post_code'] = BaseFieldDefinition::create('string') $fields['post_code'] = BaseFieldDefinition::create('string')
->setRevisionable(TRUE)
->setLabel(t('Post Code')) ->setLabel(t('Post Code'))
->setSettings(array( ->setSettings(array(
'default_value' => '', 'default_value' => '',

View File

@ -222,16 +222,15 @@ class OCCase extends RevisionableContentEntityBase implements OCCaseInterface {
->setDefaultValue(TRUE); ->setDefaultValue(TRUE);
$fields['user_id'] = BaseFieldDefinition::create('entity_reference') $fields['user_id'] = BaseFieldDefinition::create('entity_reference')
->setLabel(t('Entered by')) ->setLabel(t('Created by'))
->setDescription(t('The user ID of author of the Case entity.')) ->setDescription(t('The user ID of author of the Case entity.'))
->setRevisionable(TRUE) ->setRevisionable(TRUE)
->setSetting('target_type', 'user') ->setSetting('target_type', 'user')
->setSetting('handler', 'default') ->setSetting('handler', 'default')
->setTranslatable(TRUE) ->setTranslatable(TRUE)
->setDisplayOptions('view', [ ->setDisplayOptions('view', [
'label' => 'inline', 'label' => 'above',
'type' => 'author', 'type' => 'author',
'weight' => -4,
]); ]);
$fields['name'] = BaseFieldDefinition::create('string') $fields['name'] = BaseFieldDefinition::create('string')
->setLabel(t('Case Title')) ->setLabel(t('Case Title'))
@ -245,7 +244,6 @@ class OCCase extends RevisionableContentEntityBase implements OCCaseInterface {
->setDisplayOptions('view', [ ->setDisplayOptions('view', [
'label' => 'hidden', 'label' => 'hidden',
'type' => 'string', 'type' => 'string',
'weight' => -3,
]) ])
->setDisplayOptions('form', [ ->setDisplayOptions('form', [
'type' => 'string_textfield', 'type' => 'string_textfield',
@ -261,6 +259,7 @@ class OCCase extends RevisionableContentEntityBase implements OCCaseInterface {
->setTranslatable(TRUE) ->setTranslatable(TRUE)
->setCardinality(-1) ->setCardinality(-1)
->setDisplayOptions('form', [ ->setDisplayOptions('form', [
'label' => 'above',
'type' => 'entity_reference_autocomplete', 'type' => 'entity_reference_autocomplete',
'weight' => -2, 'weight' => -2,
'settings' => [ 'settings' => [
@ -272,7 +271,6 @@ class OCCase extends RevisionableContentEntityBase implements OCCaseInterface {
]) ])
->setDisplayOptions('view', [ ->setDisplayOptions('view', [
'label' => 'above', 'label' => 'above',
'weight' => -2
]) ])
->setDefaultValueCallback('Drupal\opencase_entities\Entity\OCCase::defaultVal') ->setDefaultValueCallback('Drupal\opencase_entities\Entity\OCCase::defaultVal')
->setRequired(TRUE); ->setRequired(TRUE);
@ -295,17 +293,30 @@ class OCCase extends RevisionableContentEntityBase implements OCCaseInterface {
]) ])
->setDisplayOptions('view', [ ->setDisplayOptions('view', [
'label' => 'above', 'label' => 'above',
'weight' => -1,
'settings' => ['use_description_as_link_text' => 'true'] 'settings' => ['use_description_as_link_text' => 'true']
]); ]);
$fields['created'] = BaseFieldDefinition::create('created') $fields['created'] = BaseFieldDefinition::create('created')
->setLabel(t('Created')) ->setLabel(t('Created on'))
->setDescription(t('The time that the entity was created.')); ->setDescription(t('When the case was created.'))
->setDisplayOptions('view', [
'type' => "datetime_default",
'label' => 'above',
'settings' => [
'date_format' => 'short'
]
]);
$fields['changed'] = BaseFieldDefinition::create('changed') $fields['changed'] = BaseFieldDefinition::create('changed')
->setLabel(t('Changed')) ->setLabel(t('Last updated'))
->setDescription(t('The time that the entity was last edited.')); ->setDescription(t('When the case was last edited.'))
->setDisplayOptions('view', [
'type' => "datetime_custom",
'label' => 'above',
'settings' => [
'date_format' => 'm/d/Y'
]
]);
$fields['revision_translation_affected'] = BaseFieldDefinition::create('boolean') $fields['revision_translation_affected'] = BaseFieldDefinition::create('boolean')
->setLabel(t('Revision translation affected')) ->setLabel(t('Revision translation affected'))

View File

@ -38,18 +38,11 @@ class OCActorForm extends ContentEntityForm {
*/ */
public function save(array $form, FormStateInterface $form_state) { public function save(array $form, FormStateInterface $form_state) {
$entity = $this->entity; $entity = $this->entity;
// Always make a new revision for a person. They are not changed often and people are likely to
// Save as a new revision if requested to do so. // want to know what has happened to them over time.
if (!$form_state->isValueEmpty('new_revision') && $form_state->getValue('new_revision') != FALSE) { $entity->setNewRevision();
$entity->setNewRevision(); $entity->setRevisionCreationTime(REQUEST_TIME);
$entity->setRevisionUserId(\Drupal::currentUser()->id());
// If a new revision is created, save the current user as revision author.
$entity->setRevisionCreationTime(REQUEST_TIME);
$entity->setRevisionUserId(\Drupal::currentUser()->id());
}
else {
$entity->setNewRevision(FALSE);
}
$status = parent::save($form, $form_state); $status = parent::save($form, $form_state);

View File

@ -16,7 +16,20 @@
*/ */
#} #}
<div{{ attributes.addClass('oc_actor') }}> <div{{ attributes.addClass('oc_actor') }}>
{% if content %} <div class="oc_entity">
{{- content -}} <div class="left">
{% endif %} {% for field in fields_other_than_contact_details %}
{{ field }}
{% endfor %}
</div>
<div class="right">
<div id ="contact_details">
<h2>Contact Details</h2>
<a class="field" href="/opencase/oc_actor/{{ id }}/contact_details_history">See history</a>
{% for field in contact_details %}
{{ field }}
{% endfor %}
</div>
</div>
</div>
</div> </div>

View File

@ -16,7 +16,18 @@
*/ */
#} #}
<div{{ attributes.addClass('oc_case') }}> <div{{ attributes.addClass('oc_case') }}>
{% if content %} <h2>{{ title }}</h2>
{{- content -}} <div class="oc_entity">
{% endif %} <div class="left">
{{ base_fields.actors_involved }}
{{ base_fields.changed }}
{{ base_fields.created }}
{{ base_fields.user_id }}
</div>
<div class="right">
{% for field in other_fields %}
{{ field }}
{% endfor %}
</div>
</div>
</div> </div>

View File

@ -2,7 +2,7 @@ name: 'OpenCase'
type: module type: module
description: 'Simple Case Management' description: 'Simple Case Management'
core: 8.x core: 8.x
version: 8.x-1.6.5 version: 8.x-1.8
package: 'OpenCase' package: 'OpenCase'
dependencies: dependencies:
- opencase_entities - opencase_entities