[Rt-commit] rt branch, 5.0/allow-asset-autocomplete, created. rt-5.0.0-137-gf38cafae73

Craig Kaiser craig at bestpractical.com
Mon Dec 7 15:59:44 EST 2020


The branch, 5.0/allow-asset-autocomplete has been created
        at  f38cafae73dd4d4cc074b8b90e66e96a670acfb9 (commit)

- Log -----------------------------------------------------------------
commit 02f188f371fdc2eae43f3093fdabe8f53cf9293f
Author: craig kaiser <craig at bestpractical.com>
Date:   Mon Dec 7 15:33:35 2020 -0500

    Add autocomplete for assets input

diff --git a/share/html/Helpers/Autocomplete/Assets b/share/html/Helpers/Autocomplete/Assets
new file mode 100644
index 0000000000..c7abdddfed
--- /dev/null
+++ b/share/html/Helpers/Autocomplete/Assets
@@ -0,0 +1,43 @@
+% $r->content_type('application/json; charset=utf-8');
+<% JSON( \@suggestions ) |n %>
+% $m->abort;
+
+<%ARGS>
+$term       => undef
+$max        => 10
+$op         => 'STARTSWITH'
+$right      => undef
+$return     => 'id'
+$queue      => undef
+</%ARGS>
+
+<%INIT>
+# Only allow certain return fields
+$return = 'Name'
+    unless $return =~ /^(?:id|Name)$/;
+
+$m->abort unless defined $return
+             and defined $term
+             and length $term;
+
+# Sanity check the operator
+$op = 'STARTSWITH' unless $op =~ /^(?:LIKE|(?:START|END)SWITH|=|!=)$/i;
+
+my $assets = RT::Assets->new( $session{CurrentUser} );
+
+$assets->RowsPerPage( $max );
+$assets->Limit(
+    FIELD           => 'Name',
+    OPERATOR        => $op,
+    VALUE           => $term,
+    ENTRYAGGREGATOR => 'OR',
+    CASESENSITIVE   => 0,
+);
+
+my @suggestions;
+while (my $a = $assets->Next) {
+    next if $right and not $a->CurrentUserHasRight($right);
+    my $value = $a->$return;
+    push @suggestions, { label => $a->Name, value => $value };
+}
+</%INIT>
diff --git a/share/html/Ticket/Elements/ShowAssets b/share/html/Ticket/Elements/ShowAssets
index bebb094ec0..441ccd257e 100644
--- a/share/html/Ticket/Elements/ShowAssets
+++ b/share/html/Ticket/Elements/ShowAssets
@@ -213,7 +213,7 @@ if ($ShowRelatedTickets) {
     <label><&|/l&>Add an asset to this ticket:</&></label>
     <div class="form-row">
       <div class="form-group mx-sm-3 mb-2">
-        <input class="form-control mb-2" size="10" name="<% $Ticket->id %>-RefersTo" placeholder="<&|/l&>Asset #</&>" type="text">
+        <input data-autocomplete="Assets" class="form-control mb-2" size="10" name="<% $Ticket->id %>-RefersTo" placeholder="<&|/l&>Asset #</&>" type="text">
       </div>
       <button type="submit" name="AddAsset" value="Add" class="button btn btn-primary form-control mb-2">Add</button>
     </div>
diff --git a/share/static/js/autocomplete.js b/share/static/js/autocomplete.js
index c56ea33218..7413c4bf81 100644
--- a/share/static/js/autocomplete.js
+++ b/share/static/js/autocomplete.js
@@ -7,7 +7,8 @@ window.RT.Autocomplete.Classes = {
     Groups: 'group',
     Tickets: 'tickets',
     Queues: 'queues',
-    Articles: 'articles'
+    Articles: 'articles',
+    Assets: 'assets'
 };
 
 Selectize.define('rt_drag_drop', function(options) {

commit 456c88fee760955d645c23a8876399c272e5900b
Author: craig kaiser <craig at bestpractical.com>
Date:   Mon Dec 7 15:54:36 2020 -0500

    Remove custom asset form submission processing
    
    Assets can be processed using normal form submission values that do not
    need to be pre-processed by JS.

diff --git a/share/static/js/assets.js b/share/static/js/assets.js
index a70a4dcd62..deac8c06aa 100644
--- a/share/static/js/assets.js
+++ b/share/static/js/assets.js
@@ -10,14 +10,6 @@ jQuery(function() {
         // since the plugin only runs on page load.
         jQuery('.selectpicker').selectpicker('refresh');
     };
-
-    jQuery(".ticket-assets form").submit(function(){
-        var input = jQuery("[name*=RefersTo]", this);
-        if (input.val())
-            input.val(input.val().match(/\S+/g)
-                                 .map(function(x){return "asset:"+x})
-                                 .join(" "));
-    });
     jQuery("#page-actions-create-linked-ticket").click(function(ev){
         ev.preventDefault();
         var url = this.href.replace(/\/Asset\/CreateLinkedTicket\.html\?/g,

commit f38cafae73dd4d4cc074b8b90e66e96a670acfb9
Author: craig kaiser <craig at bestpractical.com>
Date:   Mon Dec 7 15:56:40 2020 -0500

    Allow name to be returned for asset autocomplete

diff --git a/share/html/Helpers/Autocomplete/Assets b/share/html/Helpers/Autocomplete/Assets
index c7abdddfed..7e3f5db8cf 100644
--- a/share/html/Helpers/Autocomplete/Assets
+++ b/share/html/Helpers/Autocomplete/Assets
@@ -7,7 +7,7 @@ $term       => undef
 $max        => 10
 $op         => 'STARTSWITH'
 $right      => undef
-$return     => 'id'
+$return     => 'Name'
 $queue      => undef
 </%ARGS>
 
diff --git a/share/html/Ticket/Elements/ShowAssets b/share/html/Ticket/Elements/ShowAssets
index 441ccd257e..cd62353df6 100644
--- a/share/html/Ticket/Elements/ShowAssets
+++ b/share/html/Ticket/Elements/ShowAssets
@@ -213,7 +213,7 @@ if ($ShowRelatedTickets) {
     <label><&|/l&>Add an asset to this ticket:</&></label>
     <div class="form-row">
       <div class="form-group mx-sm-3 mb-2">
-        <input data-autocomplete="Assets" class="form-control mb-2" size="10" name="<% $Ticket->id %>-RefersTo" placeholder="<&|/l&>Asset #</&>" type="text">
+        <input data-autocomplete="Assets" class="form-control mb-2" size="10" name="<% $Ticket->id %>-RefersTo" placeholder="<&|/l&>Asset # or Name</&>" type="text">
       </div>
       <button type="submit" name="AddAsset" value="Add" class="button btn btn-primary form-control mb-2">Add</button>
     </div>

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


More information about the rt-commit mailing list