[Rt-commit] rt branch, 5.0/add-viewonly-custom-field-column, created. rt-5.0.0-31-gb70aa953b0

Dianne Skoll dianne at bestpractical.com
Mon Oct 5 09:37:31 EDT 2020


The branch, 5.0/add-viewonly-custom-field-column has been created
        at  b70aa953b055467848a84566d4a94ef607b96d90 (commit)

- Log -----------------------------------------------------------------
commit b70aa953b055467848a84566d4a94ef607b96d90
Author: Dianne Skoll <dianne at bestpractical.com>
Date:   Mon Oct 5 09:18:30 2020 -0400

    Add "CF_ViewOnly" column type for view-only (non-editable) custom fields.
    
    The idea here is to allow inline editing, but have the ability to turn off
    inline editing on a per-custom-field basis for search results.  This will
    eliminate slowness for custom fields whose "edit" rendering is expensive
    to compute while still permitting inline editing.

diff --git a/share/html/Elements/ColumnMap b/share/html/Elements/ColumnMap
index 17a39a0ec5..3ba4132029 100644
--- a/share/html/Elements/ColumnMap
+++ b/share/html/Elements/ColumnMap
@@ -236,7 +236,7 @@ $WCOLUMN_MAP = $COLUMN_MAP = {
     (map {
         my $value = RT->Config->Get($_);
         $_ => { value => sub { return \$value } };
-    
+
     } qw(WebPath WebBaseURL WebURL)),
     WebRequestPath    => { value => sub { substr( $m->request_path, 1 ) } },
     WebRequestPathDir => { value => sub { substr( $m->request_comp->dir_path, 1 ) } },
@@ -255,6 +255,15 @@ $WCOLUMN_MAP = $COLUMN_MAP = {
 
 $COLUMN_MAP->{'CF'} = $COLUMN_MAP->{'CustomField'};
 
+# Add a CF_ViewOnly column for custom fields, but with editing disabled
+$COLUMN_MAP->{'CF_ViewOnly'} = {};
+
+# We copy all keys from CF to CF_ViewOnly except for "edit"
+foreach my $key (keys(%{$COLUMN_MAP->{'CF'}})) {
+        next if $key eq 'edit';
+        $COLUMN_MAP->{'CF_ViewOnly'}->{$key} = $COLUMN_MAP->{'CF'}->{$key};
+}
+
 Scalar::Util::weaken($WCOLUMN_MAP);
 
 my $ROLE_MAP = {};
diff --git a/share/html/Search/Elements/BuildFormatString b/share/html/Search/Elements/BuildFormatString
index 5e32941657..72c0bc3356 100644
--- a/share/html/Search/Elements/BuildFormatString
+++ b/share/html/Search/Elements/BuildFormatString
@@ -106,6 +106,10 @@ if ( $Class eq 'RT::Transactions' ) {
 
     while ( my $CustomField = $CustomFields->Next ) {
         push @fields, "CustomField.{" . $CustomField->Name . "}";
+        # If inline editing is enabled, add a display-only version
+        if (RT->Config->Get('InlineEdit', $session{CurrentUser})) {
+            push @fields, "CF_ViewOnly.{" . $CustomField->Name . "}";
+        }
     }
 }
 elsif ( $Class eq 'RT::Assets' ) {
@@ -140,6 +144,10 @@ elsif ( $Class eq 'RT::Assets' ) {
     $CustomFields->LimitToCatalog(0);
     while ( my $CustomField = $CustomFields->Next ) {
         push @fields, "CustomField.{" . $CustomField->Name . "}";
+        # If inline editing is enabled, add a display-only version
+        if (RT->Config->Get('InlineEdit', $session{CurrentUser})) {
+            push @fields, "CF_ViewOnly.{" . $CustomField->Name . "}";
+        }
     }
 
 }
@@ -197,6 +205,10 @@ else {
 
     while ( my $CustomField = $CustomFields->Next ) {
         push @fields, "CustomField.{" . $CustomField->Name . "}";
+        # If inline editing is enabled, add a display-only version
+        if (RT->Config->Get('InlineEdit', $session{CurrentUser})) {
+            push @fields, "CF_ViewOnly.{" . $CustomField->Name . "}";
+        }
     }
 
     my $CustomRoles = RT::CustomRoles->new( $session{'CurrentUser'} );

-----------------------------------------------------------------------


More information about the rt-commit mailing list