Sha256: 0cbfe488207402d6fd75ba742b1c134da7c9a4884823fb8501057bbf6f4952fb

Contents?: true

Size: 1.83 KB

Versions: 45

Compression:

Stored size: 1.83 KB

Contents

// Autocomplete for linked data elements using a select2 autocomplete widget
// After selecting something, the seleted item is immutable
export default class LinkedData {
  constructor(element, url) {
    this.url = url
    this.element = element
    this.activate()
  }

  activate() {
    this.element
      .select2(this.options(this.element))
      .on("change", (e) => { this.selected(e) })
  }

  // Called when a choice is made
  selected(e) {
    let result = this.element.select2("data")
    this.element.select2("destroy")
    this.element.val(result.label).attr("readonly", "readonly")
    this.setIdentifier(result.id)
  }

  // Store the uri in the associated hidden id field
  setIdentifier(uri) {
    this.element.closest('.field-wrapper').find('[data-id]').val(uri);
  }

  options(element) {
    return {
      // placeholder: $(this).attr("value") || "Search for a location",
      minimumInputLength: 2,
      id: function(object) {
        return object.id;
      },
      text: function(object) {
        return object.label;
      },
      initSelection: function(element, callback) {
        // Called when Select2 is created to allow the user to initialize the
        // selection based on the value of the element select2 is attached to.
        // Essentially this is an id->object mapping function.

        // TODO: Presently we're just showing a URI, but we should show the label.
        var data = {
          id: element.val(),
          label: element.val()
        };
        callback(data);
      },
      ajax: { // Use the jQuery.ajax wrapper provided by Select2
        url: this.url,
        dataType: "json",
        data: function (term, page) {
          return {
            q: term // Search term
          };
        },
        results: function(data, page) {
          return { results: data };
        }
      }
    }
  }
}

Version data entries

45 entries across 45 versions & 1 rubygems

Version Path
hyrax-3.3.0 app/assets/javascripts/hyrax/autocomplete/linked_data.es6
hyrax-3.2.0 app/assets/javascripts/hyrax/autocomplete/linked_data.es6
hyrax-2.9.6 app/assets/javascripts/hyrax/autocomplete/linked_data.es6
hyrax-3.1.0 app/assets/javascripts/hyrax/autocomplete/linked_data.es6
hyrax-2.9.5 app/assets/javascripts/hyrax/autocomplete/linked_data.es6
hyrax-3.0.2 app/assets/javascripts/hyrax/autocomplete/linked_data.es6
hyrax-3.0.1 app/assets/javascripts/hyrax/autocomplete/linked_data.es6
hyrax-3.0.0 app/assets/javascripts/hyrax/autocomplete/linked_data.es6
hyrax-3.0.0.pre.rc4 app/assets/javascripts/hyrax/autocomplete/linked_data.es6
hyrax-2.9.4 app/assets/javascripts/hyrax/autocomplete/linked_data.es6
hyrax-3.0.0.pre.rc3 app/assets/javascripts/hyrax/autocomplete/linked_data.es6
hyrax-2.9.3 app/assets/javascripts/hyrax/autocomplete/linked_data.es6
hyrax-2.9.2 app/assets/javascripts/hyrax/autocomplete/linked_data.es6
hyrax-2.9.1 app/assets/javascripts/hyrax/autocomplete/linked_data.es6
hyrax-2.9.0 app/assets/javascripts/hyrax/autocomplete/linked_data.es6
hyrax-3.0.0.pre.rc2 app/assets/javascripts/hyrax/autocomplete/linked_data.es6
hyrax-2.8.0 app/assets/javascripts/hyrax/autocomplete/linked_data.es6
hyrax-2.7.2 app/assets/javascripts/hyrax/autocomplete/linked_data.es6
hyrax-2.7.1 app/assets/javascripts/hyrax/autocomplete/linked_data.es6
hyrax-2.7.0 app/assets/javascripts/hyrax/autocomplete/linked_data.es6