Skip to main content

Bibsonomy/Zotero plugin for managing refernces in APIS framework

Project description

APIS Bibsonomy

APIS Bibsonomy is a small addon to the APIS system. It allows to store references in Bibsonomy instances and use these references in APIS. It is very generic and should work with most Django installations/projects.

Installation

  • Install the package:

    pip install apis-bibsonomy

  • Add the package to your installed apps:

    INSTALLED_APPS = [
    ...
    'apis_bibsonomy'
    ]
    
  • And migrate your DB:

    python manage.py migrate

Some functionality from APIS Bibsonomy uses htmx, so you should include htmx into your web application.

Configuration

APIS Bibsonomy needs an URL of the bibsonomy or zotero instance, a username, a API token and an (optional) collection to search in.

You need to add a configuration section to your APIS settings:

APIS_BIBSONOMY = [{
   'type': 'bibsomomy', #or zotero
   'url': 'http://url.at', #url of the bibsonomy instance or zotero.org
   'user': 'username', #for zotero use the user id number found in settings
   'API key': 'api_key',
   'group': 'group'
}]

If you want the plugin to add the reference buttons to certain fields you need to add these fields to the config:

APIS_BIBSONOMY_FIELDS = ['name', 'first_name', 'profession']

Restart your server and you are good to go.

htmx

APIS Bibsonomy uses htmx. The delete buttons for references trigger deletion via the API delete route which give an empty response on success. HTMX needs to be configured to swap the content even if the response is empty:

document.body.addEventListener('htmx:beforeSwap', function(event) {
  if (event.detail.xhr.status === 204) {
    // Swap content even when the response is empty.
    event.detail.shouldSwap = true;
  }
});

Usage

not needed if you are using standard APIS templates

  • Include the base template somewhere in the header of your template:

{% include 'apis_bibsonomy/apis_bibsonomy_include.html' %}

  • Load the templatetag:

{% load bibsonomy_templatetags %}

  • Include the form somewhere in your template (set hidden=True if you intend to use buttons):

{% bibsonomy_form content_type='person' hidden=True %}

  • And finally add html tags as anker element for the reference forms to your template (dont forget to set "bibsonomy-anker" as class):

<button class="bibsonomy-anker" data-bibs-contenttype="person" data-bibs-object_pk={{instance.pk}} data-bibs-attribute="Attribute name (optional)">Ref</button>

  • If you want to batch add reference forms to attribute fields in a whole form add a hidden anker element. You need to additionally add the names of the form fields you want to have reference forms for to data-bibs-form-elements=""

<button class="bibsonomy-anker-hidden" data-bibs-contenttype="person" data-bibs-object_pk={{instance.pk}} data-bibs-form-elements="first_name|name|gender|start_date_written|lat">Ref</button>

Licenses

The book icon used for the reference link is the SVG from the Import Contacts icon from the material symbols

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

apis_bibsonomy-0.12.1.tar.gz (14.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

apis_bibsonomy-0.12.1-py3-none-any.whl (22.7 kB view details)

Uploaded Python 3

File details

Details for the file apis_bibsonomy-0.12.1.tar.gz.

File metadata

  • Download URL: apis_bibsonomy-0.12.1.tar.gz
  • Upload date:
  • Size: 14.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for apis_bibsonomy-0.12.1.tar.gz
Algorithm Hash digest
SHA256 c6367d9431c5b0d93315b0ea3dfaaaaa8c0ac8b996274eaff7ce7bb99f0583fc
MD5 fd2ae5d6eabc56c3b0c8e5b9c7aa405a
BLAKE2b-256 398abdd4c6d3a7752fc6fcc623b3b1bb39fa32e6c020d8af7a53afcf026f6dbe

See more details on using hashes here.

Provenance

The following attestation bundles were made for apis_bibsonomy-0.12.1.tar.gz:

Publisher: publish.yml on acdh-oeaw/apis-bibsonomy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file apis_bibsonomy-0.12.1-py3-none-any.whl.

File metadata

File hashes

Hashes for apis_bibsonomy-0.12.1-py3-none-any.whl
Algorithm Hash digest
SHA256 0e52a6e37365b14bf86f8c5b6e40ad92fb6ba4445164edb1e3f040504b512e11
MD5 e976c21b69e698be75ee05f31b7bc4d1
BLAKE2b-256 da327fef64c6eb511f6364eca74cd172411d0ce5dd08a6b08d0f25e9d9bdca09

See more details on using hashes here.

Provenance

The following attestation bundles were made for apis_bibsonomy-0.12.1-py3-none-any.whl:

Publisher: publish.yml on acdh-oeaw/apis-bibsonomy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page