From 86a208a86d0f68d30dc3aada03311d03354c1358 Mon Sep 17 00:00:00 2001
From: bdalsass <95754414+bdalsass@users.noreply.github.com>
Date: Wed, 8 Feb 2023 14:34:46 +0100
Subject: [PATCH] =?UTF-8?q?N=C2=B05904=20-=20Use=20attribute=20linked=20se?=
=?UTF-8?q?t=20edit=20mode=20to=20enable=20actions=20in=20view=20(improvem?=
=?UTF-8?q?ent)?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
application/displayblock.class.inc.php | 8 +-
.../links/en.dictionary.itop.links.php | 23 +++--
.../links/fr.dictionary.itop.links.php | 23 +++--
.../Direct/BlockDirectLinksEditTable.php | 78 ++++++++--------
.../Direct/BlockDirectLinksViewTable.php | 91 +++++++++++--------
.../Indirect/BlockIndirectLinksEditTable.php | 37 ++++----
.../Indirect/BlockIndirectLinksViewTable.php | 38 ++++----
sources/Service/Links/LinkSetModel.php | 33 -------
8 files changed, 160 insertions(+), 171 deletions(-)
diff --git a/application/displayblock.class.inc.php b/application/displayblock.class.inc.php
index 79e84d605..485680eea 100644
--- a/application/displayblock.class.inc.php
+++ b/application/displayblock.class.inc.php
@@ -2172,7 +2172,7 @@ class MenuBlock extends DisplayBlock
if ($bIsCreationInModalAllowed === true) {
$oAddLinkActionButton = ButtonUIBlockFactory::MakeIconAction(
'fas fa-plus',
- Dict::S('UI:DisplayBlock:List:AddEntry:Tooltip'),
+ Dict::Format('UI:ClickToCreateNew', MetaModel::GetName($sClass)),
'UI:Links:New',
'',
false
@@ -2326,9 +2326,9 @@ class MenuBlock extends DisplayBlock
protected function AddNewObjectMenuAction(array &$aActions, string $sClass, string $sDefaultValuesAsUrlParams = ''): void
{
$aActions['UI:Menu:New'] = [
- 'label' => Dict::S('UI:Menu:New'),
- 'url' => $this->PrepareUrlForStandardMenuAction($sClass, "operation=new&class=$sClass{$sDefaultValuesAsUrlParams}"),
- ] + $this->GetDefaultParamsForMenuAction();
+ 'label' => Dict::Format('UI:ClickToCreateNew', MetaModel::GetName($sClass)),
+ 'url' => $this->PrepareUrlForStandardMenuAction($sClass, "operation=new&class=$sClass{$sDefaultValuesAsUrlParams}"),
+ ] + $this->GetDefaultParamsForMenuAction();
}
/**
diff --git a/dictionaries/ui/application/links/en.dictionary.itop.links.php b/dictionaries/ui/application/links/en.dictionary.itop.links.php
index 3e4ddfada..e66fa04ea 100644
--- a/dictionaries/ui/application/links/en.dictionary.itop.links.php
+++ b/dictionaries/ui/application/links/en.dictionary.itop.links.php
@@ -20,23 +20,26 @@
Dict::Add('EN US', 'English', 'English', array(
// Action row
- 'UI:Links:ActionRow:Detach' => 'Detach',
- 'UI:Links:ActionRow:Detach+' => 'Detach this object',
- 'UI:Links:ActionRow:Detach:Confirmation' => 'Do you really want to detach {item} from current object ?',
+ 'UI:Links:ActionRow:Detach' => 'Remove',
+ 'UI:Links:ActionRow:Detach+' => 'Remove this object',
+ 'UI:Links:ActionRow:Detach:Confirmation' => 'Do you really want to remove {item} from current object ?',
'UI:Links:ActionRow:Delete' => 'Delete',
'UI:Links:ActionRow:Delete+' => 'Delete this object',
'UI:Links:ActionRow:Delete:Confirmation' => 'Do you really want to delete {item} from current object ?',
'UI:Links:ActionRow:Modify' => 'Modify',
'UI:Links:ActionRow:Modify+' => 'Modify this object',
'UI:Links:ActionRow:Modify:Modal:Title' => 'Modify an object',
-
+
+ // Action
+ 'UI:Links:New:Modal:Title' => 'Create an object',
+
// Bulk
- 'UI:Links:Bulk:LinkWillBeCreatedForAllObjects' => 'Link all objects',
- 'UI:Links:Bulk:LinkWillBeDeletedFromAllObjects' => 'Unlink all objects',
- 'UI:Links:Bulk:LinkWillBeCreatedFor1Object' => 'Link one object',
- 'UI:Links:Bulk:LinkWillBeDeletedFrom1Object' => 'Unlink one object',
- 'UI:Links:Bulk:LinkWillBeCreatedForXObjects' => 'Link {count} objects',
- 'UI:Links:Bulk:LinkWillBeDeletedFromXObjects' => 'Unlink {count} objects',
+ 'UI:Links:Bulk:LinkWillBeCreatedForAllObjects' => 'Add to all objects',
+ 'UI:Links:Bulk:LinkWillBeDeletedFromAllObjects' => 'Remove from all objects',
+ 'UI:Links:Bulk:LinkWillBeCreatedFor1Object' => 'Add to one object',
+ 'UI:Links:Bulk:LinkWillBeDeletedFrom1Object' => 'Remove from one object',
+ 'UI:Links:Bulk:LinkWillBeCreatedForXObjects' => 'Add {count} objects',
+ 'UI:Links:Bulk:LinkWillBeDeletedFromXObjects' => 'Remove {count} objects',
'UI:Links:Bulk:LinkExistForAllObjects' => 'All objets are already linked',
'UI:Links:Bulk:LinkExistForOneObject' => 'One object is linked',
'UI:Links:Bulk:LinkExistForXObjects' => '{count} objects are linked',
diff --git a/dictionaries/ui/application/links/fr.dictionary.itop.links.php b/dictionaries/ui/application/links/fr.dictionary.itop.links.php
index ea868acbd..e3b25b598 100644
--- a/dictionaries/ui/application/links/fr.dictionary.itop.links.php
+++ b/dictionaries/ui/application/links/fr.dictionary.itop.links.php
@@ -20,23 +20,26 @@
Dict::Add('FR FR', 'French', 'Français', array(
// Action row
- 'UI:Links:ActionRow:Detach' => 'Détacher',
- 'UI:Links:ActionRow:Detach+' => 'Détacher cet objet',
- 'UI:Links:ActionRow:Detach:Confirmation' => 'Voulez-vous détacher {item} de l\'objet courant ?',
+ 'UI:Links:ActionRow:Detach' => 'Enlever',
+ 'UI:Links:ActionRow:Detach+' => 'Enlever cet objet',
+ 'UI:Links:ActionRow:Detach:Confirmation' => 'Voulez-vous Enlever {item} de l\'objet courant ?',
'UI:Links:ActionRow:Delete' => 'Supprimer',
'UI:Links:ActionRow:Delete+' => 'Supprimer cet objet',
'UI:Links:ActionRow:Delete:Confirmation' => 'Voulez-vous supprimer {item} de l\'objet courant ?',
'UI:Links:ActionRow:Modify' => 'Modifier',
'UI:Links:ActionRow:Modify+' => 'Modifier cet object',
'UI:Links:ActionRow:Modify:Modal:Title' => 'Modifier un object',
-
+
+ // Action
+ 'UI:Links:New:Modal:Title' => 'Créer un object',
+
// Bulk
- 'UI:Links:Bulk:LinkWillBeCreatedForAllObjects' => 'Lier à tous les objets',
- 'UI:Links:Bulk:LinkWillBeDeletedFromAllObjects' => 'Détacher de tous les objets',
- 'UI:Links:Bulk:LinkWillBeCreatedFor1Object' => 'Lier à un objet',
- 'UI:Links:Bulk:LinkWillBeDeletedFrom1Object' => 'Détacher de un objet',
- 'UI:Links:Bulk:LinkWillBeCreatedForXObjects' => 'Lier à {count} objets',
- 'UI:Links:Bulk:LinkWillBeDeletedFromXObjects' => 'Détacher de {count} objets',
+ 'UI:Links:Bulk:LinkWillBeCreatedForAllObjects' => 'Ajouter à tous les objets',
+ 'UI:Links:Bulk:LinkWillBeDeletedFromAllObjects' => 'Enlever de tous les objets',
+ 'UI:Links:Bulk:LinkWillBeCreatedFor1Object' => 'Ajouter à un objet',
+ 'UI:Links:Bulk:LinkWillBeDeletedFrom1Object' => 'Enlever de un objet',
+ 'UI:Links:Bulk:LinkWillBeCreatedForXObjects' => 'Ajouter à {count} objets',
+ 'UI:Links:Bulk:LinkWillBeDeletedFromXObjects' => 'Enlever de {count} objets',
'UI:Links:Bulk:LinkExistForAllObjects' => 'Tous les objets sont déjà liés',
'UI:Links:Bulk:LinkExistForOneObject' => 'Un objet est lié',
'UI:Links:Bulk:LinkExistForXObjects' => '{count} objets sont liés',
diff --git a/sources/Application/UI/Links/Direct/BlockDirectLinksEditTable.php b/sources/Application/UI/Links/Direct/BlockDirectLinksEditTable.php
index a3d3471c6..1277d677b 100644
--- a/sources/Application/UI/Links/Direct/BlockDirectLinksEditTable.php
+++ b/sources/Application/UI/Links/Direct/BlockDirectLinksEditTable.php
@@ -190,35 +190,35 @@ class BlockDirectLinksEditTable extends UIContentBlock
break;
case LINKSET_EDITMODE_ADDONLY: // The only possible action is to open (in a new window) the form to create a new object
- $oActionButtonLink = ButtonUIBlockFactory::MakeNeutral('Link', 'link');
- $oActionButtonLink->AddDataAttribute('action', 'add');
- $oActionButtonLink->SetOnClickJsCode("$('#{$this->oUILinksDirectWidget->GetInputId()}').directlinks('selectToAdd');");
- $oToolbar->AddSubBlock($oActionButtonLink);
- break;
-
- case LINKSET_EDITMODE_INPLACE: // The whole linkset can be edited 'in-place'
- $oActionButtonCreate = ButtonUIBlockFactory::MakeNeutral('Create', 'create');
+ $oActionButtonCreate = ButtonUIBlockFactory::MakeNeutral(Dict::Format('UI:ClickToCreateNew', MetaModel::GetName($this->oAttributeLinkedSet->GetLinkedClass())));
$oActionButtonCreate->AddDataAttribute('action', 'create');
$oActionButtonCreate->SetOnClickJsCode("$('#{$this->oUILinksDirectWidget->GetInputId()}').directlinks('createRow');");
$oToolbar->AddSubBlock($oActionButtonCreate);
- $oActionButtonDelete = ButtonUIBlockFactory::MakeNeutral('Delete', 'delete');
- $oActionButtonDelete->AddDataAttribute('action', 'delete');
+ break;
+
+ case LINKSET_EDITMODE_INPLACE: // The whole linkset can be edited 'in-place'
+ case LINKSET_EDITMODE_ACTIONS: // Show the usual 'Actions' popup menu
+ $oActionButtonCreate = ButtonUIBlockFactory::MakeNeutral(Dict::Format('UI:ClickToCreateNew', MetaModel::GetName($this->oAttributeLinkedSet->GetLinkedClass())));
+ $oActionButtonCreate->AddDataAttribute('action', 'create');
+ $oActionButtonCreate->SetOnClickJsCode("$('#{$this->oUILinksDirectWidget->GetInputId()}').directlinks('createRow');");
+ $oToolbar->AddSubBlock($oActionButtonCreate);
+ $oActionButtonDelete = ButtonUIBlockFactory::MakeNeutral(Dict::S('UI:Button:Delete'));
+ $oActionButtonDelete->AddDataAttribute('action', 'delete');
$oActionButtonDelete->SetOnClickJsCode("$('#{$this->oUILinksDirectWidget->GetInputId()}').directlinks('deleteSelection');");
$oToolbar->AddSubBlock($oActionButtonDelete);
break;
case LINKSET_EDITMODE_ADDREMOVE: // The whole linkset can be edited 'in-place'
- $oActionButtonUnlink = ButtonUIBlockFactory::MakeNeutral('Unlink', 'unlink');
- $oActionButtonUnlink->AddDataAttribute('action', 'detach');
- $oActionButtonUnlink->SetOnClickJsCode("$('#{$this->oUILinksDirectWidget->GetInputId()}').directlinks('removeSelection');");
- $oToolbar->AddSubBlock($oActionButtonUnlink);
- $oActionButtonLink = ButtonUIBlockFactory::MakeNeutral('Link', 'link');
+ $oActionButtonLink = ButtonUIBlockFactory::MakeNeutral(Dict::Format('UI:AddAnExisting_Class', MetaModel::GetName($this->oAttributeLinkedSet->GetLinkedClass())));
$oActionButtonLink->AddDataAttribute('action', 'add');
$oActionButtonLink->SetOnClickJsCode("$('#{$this->oUILinksDirectWidget->GetInputId()}').directlinks('selectToAdd');");
$oToolbar->AddSubBlock($oActionButtonLink);
+ $oActionButtonUnlink = ButtonUIBlockFactory::MakeNeutral(Dict::S('UI:Button:Remove'));
+ $oActionButtonUnlink->AddDataAttribute('action', 'detach');
+ $oActionButtonUnlink->SetOnClickJsCode("$('#{$this->oUILinksDirectWidget->GetInputId()}').directlinks('removeSelection');");
+ $oToolbar->AddSubBlock($oActionButtonUnlink);
break;
- case LINKSET_EDITMODE_ACTIONS: // Show the usual 'Actions' popup menu
default:
}
@@ -226,7 +226,6 @@ class BlockDirectLinksEditTable extends UIContentBlock
return $oToolbar;
}
-
/**
* Return table rows.
*
@@ -277,28 +276,35 @@ class BlockDirectLinksEditTable extends UIContentBlock
{
$aRowActions = array();
- if (!LinkSetModel::ConvertEditModeToReadOnly($this->oAttributeLinkedSet)) {
+ // until a full link set refactoring (continue using edit_mode property)
+ switch ($this->oAttributeLinkedSet->GetEditMode()) {
+ case LINKSET_EDITMODE_NONE: // The linkset is read-only
+ break;
- switch (LinkSetModel::ConvertEditModeToRelationType($this->oAttributeLinkedSet)) {
+ case LINKSET_EDITMODE_ADDONLY: // The only possible action is to open (in a new window) the form to create a new object
+ break;
- case LINKSET_RELATIONTYPE_LINK:
- $aRowActions[] = array(
- 'label' => 'UI:Links:ActionRow:Detach',
- 'tooltip' => 'UI:Links:ActionRow:Detach+',
- 'icon_classes' => 'fas fa-minus',
- 'js_row_action' => "$('#{$this->oUILinksDirectWidget->GetInputId()}').directlinks('Remove', $(':checkbox', oTrElement));",
- );
- break;
+ case LINKSET_EDITMODE_INPLACE: // The whole linkset can be edited 'in-place'
+ case LINKSET_EDITMODE_ACTIONS: // Show the usual 'Actions' popup menu
+ $aRowActions[] = array(
+ 'label' => 'UI:Links:ActionRow:Delete',
+ 'tooltip' => 'UI:Links:ActionRow:Delete+',
+ 'icon_classes' => 'fas fa-trash',
+ 'js_row_action' => "$('#{$this->oUILinksDirectWidget->GetInputId()}').directlinks('Remove', $(':checkbox', oTrElement));",
+ );
+ break;
+
+ case LINKSET_EDITMODE_ADDREMOVE: // The whole linkset can be edited 'in-place'
+ $aRowActions[] = array(
+ 'label' => 'UI:Links:ActionRow:Detach',
+ 'tooltip' => 'UI:Links:ActionRow:Detach+',
+ 'icon_classes' => 'fas fa-minus',
+ 'js_row_action' => "$('#{$this->oUILinksDirectWidget->GetInputId()}').directlinks('Remove', $(':checkbox', oTrElement));",
+ );
+ break;
+
+ default:
- case LINKSET_RELATIONTYPE_PROPERTY:
- $aRowActions[] = array(
- 'label' => 'UI:Links:ActionRow:Delete',
- 'tooltip' => 'UI:Links:ActionRow:Delete+',
- 'icon_classes' => 'fas fa-trash',
- 'js_row_action' => "$('#{$this->oUILinksDirectWidget->GetInputId()}').directlinks('Remove', $(':checkbox', oTrElement));",
- );
- break;
- }
}
return $aRowActions;
diff --git a/sources/Application/UI/Links/Direct/BlockDirectLinksViewTable.php b/sources/Application/UI/Links/Direct/BlockDirectLinksViewTable.php
index b51520600..b34ad6268 100644
--- a/sources/Application/UI/Links/Direct/BlockDirectLinksViewTable.php
+++ b/sources/Application/UI/Links/Direct/BlockDirectLinksViewTable.php
@@ -49,7 +49,7 @@ class BlockDirectLinksViewTable extends AbstractBlockLinksViewTable
}
// Add creation in modal if the linkset is not readonly
- if (!$this->oAttDef->GetReadOnly()) {
+ if ($this->oAttDef->GetEditMode() != LINKSET_EDITMODE_NONE) {
$aExtraParams['creation_in_modal_is_allowed'] = true;
$aExtraParams['creation_in_modal_js_handler'] = "{$this->GetWidgetName()}.links_view_table('CreateLinkedObject');";
}
@@ -62,44 +62,63 @@ class BlockDirectLinksViewTable extends AbstractBlockLinksViewTable
{
$aRowActions = array();
- if (!LinkSetModel::ConvertEditModeToReadOnly($this->oAttDef)) {
+ // until a full link set refactoring (continue using edit_mode property)
+ switch ($this->oAttDef->GetEditMode()) {
+ case LINKSET_EDITMODE_NONE: // The linkset is read-only
+ break;
- switch (LinkSetModel::ConvertEditModeToRelationType($this->oAttDef)) {
+ case LINKSET_EDITMODE_ADDONLY: // The only possible action is to open (in a new window) the form to create a new object
+ $aRowActions[] = array(
+ 'label' => 'UI:Links:ActionRow:Modify',
+ 'tooltip' => 'UI:Links:ActionRow:Modify+',
+ 'icon_classes' => 'fas fa-pen',
+ 'js_row_action' => "{$this->GetWidgetName()}.links_view_table('ModifyLinkedObject', aRowData['{$this->oAttDef->GetLinkedClass()}/_key_/raw']);",
+ );
+ break;
- case LINKSET_RELATIONTYPE_LINK:
- $aRowActions[] = array(
- 'label' => 'UI:Links:ActionRow:Detach',
- 'tooltip' => 'UI:Links:ActionRow:Detach+',
- 'icon_classes' => 'fas fa-minus',
- 'js_row_action' => "{$this->GetWidgetName()}.links_view_table('DetachLinkedObject', aRowData['{$this->sTargetClass}/_key_/raw'], oTrElement);",
- 'confirmation' => [
- 'message' => 'UI:Links:ActionRow:Detach:Confirmation',
- 'message_row_data' => "{$this->sTargetClass}/hyperlink",
- 'do_not_show_again_pref_key' => $this->GetDoNotShowAgainPreferenceKey(),
- ],
- );
- break;
+ case LINKSET_EDITMODE_INPLACE: // The whole linkset can be edited 'in-place'
+ case LINKSET_EDITMODE_ACTIONS: // Show the usual 'Actions' popup menu
+ $aRowActions[] = array(
+ 'label' => 'UI:Links:ActionRow:Delete',
+ 'tooltip' => 'UI:Links:ActionRow:Delete+',
+ 'icon_classes' => 'fas fa-trash',
+ 'js_row_action' => "{$this->GetWidgetName()}.links_view_table('DeleteLinkedObject', aRowData['{$this->oAttDef->GetLinkedClass()}/_key_/raw'], oTrElement);",
+ 'confirmation' => [
+ 'message' => 'UI:Links:ActionRow:Delete:Confirmation',
+ 'message_row_data' => "{$this->sTargetClass}/hyperlink",
+ 'do_not_show_again_pref_key' => $this->GetDoNotShowAgainPreferenceKey(),
+ ],
+ );
+ $aRowActions[] = array(
+ 'label' => 'UI:Links:ActionRow:Modify',
+ 'tooltip' => 'UI:Links:ActionRow:Modify+',
+ 'icon_classes' => 'fas fa-pen',
+ 'js_row_action' => "{$this->GetWidgetName()}.links_view_table('ModifyLinkedObject', aRowData['{$this->oAttDef->GetLinkedClass()}/_key_/raw']);",
+ );
+ break;
- case LINKSET_RELATIONTYPE_PROPERTY:
- $aRowActions[] = array(
- 'label' => 'UI:Links:ActionRow:Delete',
- 'tooltip' => 'UI:Links:ActionRow:Delete+',
- 'icon_classes' => 'fas fa-trash',
- 'js_row_action' => "{$this->GetWidgetName()}.links_view_table('DeleteLinkedObject', aRowData['{$this->oAttDef->GetLinkedClass()}/_key_/raw'], oTrElement);",
- 'confirmation' => [
- 'message' => 'UI:Links:ActionRow:Delete:Confirmation',
- 'message_row_data' => "{$this->sTargetClass}/hyperlink",
- 'do_not_show_again_pref_key' => $this->GetDoNotShowAgainPreferenceKey(),
- ],
- );
- break;
- }
- $aRowActions[] = array(
- 'label' => 'UI:Links:ActionRow:Modify',
- 'tooltip' => 'UI:Links:ActionRow:Modify+',
- 'icon_classes' => 'fas fa-pen',
- 'js_row_action' => "{$this->GetWidgetName()}.links_view_table('ModifyLinkedObject', aRowData['{$this->oAttDef->GetLinkedClass()}/_key_/raw']);",
- );
+ case LINKSET_EDITMODE_ADDREMOVE: // The whole linkset can be edited 'in-place'
+ $aRowActions[] = array(
+ 'label' => 'UI:Links:ActionRow:Detach',
+ 'tooltip' => 'UI:Links:ActionRow:Detach+',
+ 'icon_classes' => 'fas fa-minus',
+ 'js_row_action' => "{$this->GetWidgetName()}.links_view_table('DetachLinkedObject', aRowData['{$this->sTargetClass}/_key_/raw'], oTrElement);",
+ 'confirmation' => [
+ 'message' => 'UI:Links:ActionRow:Detach:Confirmation',
+ 'message_row_data' => "{$this->sTargetClass}/hyperlink",
+ 'do_not_show_again_pref_key' => $this->GetDoNotShowAgainPreferenceKey(),
+ ],
+ );
+ $aRowActions[] = array(
+ 'label' => 'UI:Links:ActionRow:Modify',
+ 'tooltip' => 'UI:Links:ActionRow:Modify+',
+ 'icon_classes' => 'fas fa-pen',
+ 'js_row_action' => "{$this->GetWidgetName()}.links_view_table('ModifyLinkedObject', aRowData['{$this->oAttDef->GetLinkedClass()}/_key_/raw']);",
+ );
+ break;
+
+ default:
+ break;
}
return $aRowActions;
diff --git a/sources/Application/UI/Links/Indirect/BlockIndirectLinksEditTable.php b/sources/Application/UI/Links/Indirect/BlockIndirectLinksEditTable.php
index de7d4b1bf..54eea0578 100644
--- a/sources/Application/UI/Links/Indirect/BlockIndirectLinksEditTable.php
+++ b/sources/Application/UI/Links/Indirect/BlockIndirectLinksEditTable.php
@@ -187,19 +187,16 @@ class BlockIndirectLinksEditTable extends UIContentBlock
}
// Toolbar and actions
- if (!LinkSetModel::ConvertEditModeToReadOnly($this->oAttributeLinkedSetIndirect)) {
- $oToolbar = ToolbarUIBlockFactory::MakeForButton();
- $oActionButtonUnlink = ButtonUIBlockFactory::MakeNeutral('Unlink');
- $oActionButtonUnlink->SetOnClickJsCode("oWidget{$this->oUILinksWidget->GetInputId()}.RemoveSelected();");
- $oActionButtonUnlink->AddDataAttribute('action', 'detach');
- $oToolbar->AddSubBlock($oActionButtonUnlink);
- $oActionButtonLink = ButtonUIBlockFactory::MakeNeutral('Link');
- $oActionButtonLink->SetOnClickJsCode("oWidget{$this->oUILinksWidget->GetInputId()}.AddObjects();");
- $oActionButtonLink->AddDataAttribute('action', 'add');
- $oToolbar->AddSubBlock($oActionButtonLink);
- $oTablePanel->AddToolbarBlock($oToolbar);
- }
-
+ $oToolbar = ToolbarUIBlockFactory::MakeForButton();
+ $oActionButtonUnlink = ButtonUIBlockFactory::MakeNeutral(Dict::S('UI:Button:Remove'));
+ $oActionButtonUnlink->SetOnClickJsCode("oWidget{$this->oUILinksWidget->GetInputId()}.RemoveSelected();");
+ $oActionButtonUnlink->AddDataAttribute('action', 'detach');
+ $oToolbar->AddSubBlock($oActionButtonUnlink);
+ $oActionButtonLink = ButtonUIBlockFactory::MakeNeutral(Dict::Format('UI:AddAnExisting_Class', MetaModel::GetName($this->oAttributeLinkedSetIndirect->GetLinkedClass())));
+ $oActionButtonLink->SetOnClickJsCode("oWidget{$this->oUILinksWidget->GetInputId()}.AddObjects();");
+ $oActionButtonLink->AddDataAttribute('action', 'add');
+ $oToolbar->AddSubBlock($oActionButtonLink);
+ $oTablePanel->AddToolbarBlock($oToolbar);
$oTablePanel->AddSubBlock($oDataTable);
$this->AddSubBlock($oTablePanel);
@@ -424,14 +421,12 @@ JS
{
$aRowActions = array();
- if (!LinkSetModel::ConvertEditModeToReadOnly($this->oAttributeLinkedSetIndirect)) {
- $aRowActions[] = array(
- 'label' => 'UI:Links:ActionRow:Detach',
- 'tooltip' => 'UI:Links:ActionRow:Detach+',
- 'icon_classes' => 'fas fa-minus',
- 'js_row_action' => "oWidget{$this->oUILinksWidget->GetInputId()}.Remove(oTrElement);",
- );
- }
+ $aRowActions[] = array(
+ 'label' => 'UI:Links:ActionRow:Detach',
+ 'tooltip' => 'UI:Links:ActionRow:Detach+',
+ 'icon_classes' => 'fas fa-minus',
+ 'js_row_action' => "oWidget{$this->oUILinksWidget->GetInputId()}.Remove(oTrElement);",
+ );
return $aRowActions;
}
diff --git a/sources/Application/UI/Links/Indirect/BlockIndirectLinksViewTable.php b/sources/Application/UI/Links/Indirect/BlockIndirectLinksViewTable.php
index 2b8184698..98ac36220 100644
--- a/sources/Application/UI/Links/Indirect/BlockIndirectLinksViewTable.php
+++ b/sources/Application/UI/Links/Indirect/BlockIndirectLinksViewTable.php
@@ -75,28 +75,24 @@ class BlockIndirectLinksViewTable extends AbstractBlockLinksViewTable
{
$aRowActions = array();
- if (!LinkSetModel::ConvertEditModeToReadOnly($this->oAttDef)) {
+ $aRowActions[] = array(
+ 'label' => 'UI:Links:ActionRow:Detach',
+ 'tooltip' => 'UI:Links:ActionRow:Detach+',
+ 'icon_classes' => 'fas fa-minus',
+ 'js_row_action' => "{$this->GetWidgetName()}.links_view_table('DeleteLinkedObject', aRowData['Link/_key_/raw'], oTrElement);",
+ 'confirmation' => [
+ 'message' => 'UI:Links:ActionRow:Detach:Confirmation',
+ 'message_row_data' => "Remote/hyperlink",
+ 'do_not_show_again_pref_key' => $this->GetDoNotShowAgainPreferenceKey(),
+ ],
+ );
- $aRowActions[] = array(
- 'label' => 'UI:Links:ActionRow:Detach',
- 'tooltip' => 'UI:Links:ActionRow:Detach+',
- 'icon_classes' => 'fas fa-minus',
- 'js_row_action' => "{$this->GetWidgetName()}.links_view_table('DeleteLinkedObject', aRowData['Link/_key_/raw'], oTrElement);",
- 'confirmation' => [
- 'message' => 'UI:Links:ActionRow:Detach:Confirmation',
- 'message_row_data' => "Remote/hyperlink",
- 'do_not_show_again_pref_key' => $this->GetDoNotShowAgainPreferenceKey(),
- ],
- );
-
- $aRowActions[] = array(
- 'label' => 'UI:Links:ActionRow:Modify',
- 'tooltip' => 'UI:Links:ActionRow:Modify+',
- 'icon_classes' => 'fas fa-pen',
- 'js_row_action' => "{$this->GetWidgetName()}.links_view_table('ModifyLinkedObject', aRowData['Link/_key_/raw']);",
- );
-
- }
+ $aRowActions[] = array(
+ 'label' => 'UI:Links:ActionRow:Modify',
+ 'tooltip' => 'UI:Links:ActionRow:Modify+',
+ 'icon_classes' => 'fas fa-pen',
+ 'js_row_action' => "{$this->GetWidgetName()}.links_view_table('ModifyLinkedObject', aRowData['Link/_key_/raw']);",
+ );
return $aRowActions;
}
diff --git a/sources/Service/Links/LinkSetModel.php b/sources/Service/Links/LinkSetModel.php
index e1f8f948e..909535969 100644
--- a/sources/Service/Links/LinkSetModel.php
+++ b/sources/Service/Links/LinkSetModel.php
@@ -74,37 +74,4 @@ class LinkSetModel
}
- /**
- * Convert edit_mode to relation type.
- *
- * @return string|null
- */
- static public function ConvertEditModeToRelationType(AttributeLinkedSet $oAttDef): ?string
- {
- switch ($oAttDef->GetEditMode()) {
- case LINKSET_EDITMODE_INPLACE:
- return LINKSET_RELATIONTYPE_PROPERTY;
- case LINKSET_EDITMODE_ADDREMOVE:
- return LINKSET_RELATIONTYPE_LINK;
- default:
- return null;
- }
- }
-
- /**
- * Convert edit_mode to read only.
- *
- * @return bool
- */
- static public function ConvertEditModeToReadOnly(AttributeLinkedSet $oAttDef): bool
- {
- switch ($oAttDef->GetEditMode()) {
- case LINKSET_EDITMODE_NONE:
- case LINKSET_EDITMODE_ADDONLY:
- return true;
-
- default:
- return false;
- }
- }
}
\ No newline at end of file