view ViewerPlugin/OrthancExplorer.js @ 354:5d3672320879

IIIF support for on-the-fly pyramids
author Sebastien Jodogne <s.jodogne@gmail.com>
date Fri, 20 Dec 2024 12:40:54 +0100
parents 25630706f4ed
children
line wrap: on
line source

/**
 * Orthanc - A Lightweight, RESTful DICOM Store
 * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics
 * Department, University Hospital of Liege, Belgium
 * Copyright (C) 2017-2023 Osimis S.A., Belgium
 * Copyright (C) 2024-2024 Orthanc Team SRL, Belgium
 * Copyright (C) 2021-2024 Sebastien Jodogne, ICTEAM UCLouvain, Belgium
 *
 * This program is free software: you can redistribute it and/or
 * modify it under the terms of the GNU Affero General Public License
 * as published by the Free Software Foundation, either version 3 of
 * the License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Affero General Public License for more details.
 * 
 * You should have received a copy of the GNU Affero General Public License
 * along with this program. If not, see <http://www.gnu.org/licenses/>.
 **/


$('#series').live('pagebeforeshow', function() {
  var seriesId = $.mobile.pageData.uuid;

  $('#wsi-series-button').remove();
  $('#wsi-series-iiif-button').remove();
  $('#wsi-series-mirador-button').remove();
  $('#wsi-series-openseadragon-button').remove();

  $('#series-access').listview('refresh');

  // Test whether this is a whole-slide image by check the SOP Class
  // UID of one instance of the series
  GetResource('/series/' + seriesId, function(series) {
    GetResource('/instances/' + series['Instances'][0] + '/tags?simplify', function(instance) {
      if (instance['SOPClassUID'] == '1.2.840.10008.5.1.4.1.1.77.1.6') {

        // This is a whole-slide image, register the button
        var b = $('<a>')
          .attr('id', 'wsi-series-button')
          .attr('data-role', 'button')
          .attr('href', '#')
          .attr('data-icon', 'search')
          .attr('data-theme', 'e')
          .text('Whole-Slide Imaging Viewer')
          .button();

        b.insertAfter($('#series-info'));
        b.click(function() {
          if ($.mobile.pageData) {
            window.open('../wsi/app/viewer.html?series=' + seriesId);
          }
        });

        if (${ENABLE_IIIF} &&
            ${SERVE_OPEN_SEADRAGON}) {
          var b = $('<a>')
              .attr('id', 'wsi-series-openseadragon-button')
              .attr('data-role', 'button')
              .attr('href', '#')
              .attr('data-icon', 'search')
              .attr('data-theme', 'e')
              .text('Test IIIF in OpenSeadragon')
              .button();

          b.insertAfter($('#series-info'));
          b.click(function() {
            if ($.mobile.pageData) {
              window.open('../wsi/app/openseadragon.html?image=../iiif/tiles/' + seriesId + '/info.json');
            }
          });
        }
      }

      if (${ENABLE_IIIF}) {
        var b = $('<a>')
            .attr('data-role', 'button')
            .attr('href', '#')
            .text('Copy link to IIIF manifest');

        var li = $('<li>')
            .attr('id', 'wsi-series-iiif-button')
            .attr('data-icon', 'gear')
            .append(b);

        $('#series-access').append(li).listview('refresh');

        b.click(function(e) {
          if ($.mobile.pageData) {
            e.preventDefault();
            var url = new URL('../wsi/iiif/series/' + seriesId + '/manifest.json', window.location.href);
            navigator.clipboard.writeText(url.href);
            $(e.target).closest('li').buttonMarkup({ icon: 'check' });
          }
        });
      }

      if (${ENABLE_IIIF} &&
          ${SERVE_MIRADOR}) {
        var b = $('<a>')
            .attr('id', 'wsi-series-mirador-button')
            .attr('data-role', 'button')
            .attr('href', '#')
            .attr('data-icon', 'search')
            .attr('data-theme', 'e')
            .text('Test IIIF in Mirador')
            .button();

        b.insertAfter($('#series-info'));
        b.click(function() {
          if ($.mobile.pageData) {
            window.open('../wsi/app/mirador.html?iiif-content=../iiif/series/' + seriesId + '/manifest.json');
          }
        });
      }
    });
  });
});


$('#instance').live('pagebeforeshow', function() {
  var instanceId = $.mobile.pageData.uuid;

  $('#wsi-instance-button').remove();
  $('#wsi-instance-iiif-button').remove();
  $('#wsi-instance-mirador-button').remove();
  $('#wsi-instance-openseadragon-button').remove();

  var b = $('<a>')
    .attr('id', 'wsi-instance-button')
    .attr('data-role', 'button')
    .attr('href', '#')
    .attr('data-icon', 'search')
    .attr('data-theme', 'e')
    .text('Deep zoom viewer')
    .button();

  b.insertAfter($('#instance-info'));
  b.click(function() {
    if ($.mobile.pageData) {
      window.open('../wsi/app/viewer.html?instance=' + instanceId);
    }
  });

  if (${ENABLE_IIIF} &&
      ${SERVE_OPEN_SEADRAGON}) {
    var b = $('<a>')
        .attr('id', 'wsi-instance-openseadragon-button')
        .attr('data-role', 'button')
        .attr('href', '#')
        .attr('data-icon', 'search')
        .attr('data-theme', 'e')
        .text('Test IIIF in OpenSeadragon')
        .button();

    b.insertAfter($('#instance-info'));
    b.click(function () {
      if ($.mobile.pageData) {
        window.open('../wsi/app/openseadragon.html?image=../iiif/frames-pyramids/' + instanceId + '/0/info.json');
      }
    });
  }

  if (${ENABLE_IIIF}) {
    var b = $('<a>')
        .attr('data-role', 'button')
        .attr('href', '#')
        .text('Copy link to IIIF manifest');

    var li = $('<li>')
        .attr('id', 'wsi-instance-iiif-button')
        .attr('data-icon', 'gear')
        .append(b);

    $('#instance-access').append(li).listview('refresh');

    b.click(function(e) {
      if ($.mobile.pageData) {
        e.preventDefault();
        var url = new URL('../wsi/iiif/frames-pyramids/' + instanceId + '/0/manifest.json', window.location.href);
        navigator.clipboard.writeText(url.href);
        $(e.target).closest('li').buttonMarkup({ icon: 'check' });
      }
    });
  }

  if (${ENABLE_IIIF} &&
      ${SERVE_MIRADOR}) {
    var b = $('<a>')
        .attr('id', 'wsi-instance-mirador-button')
        .attr('data-role', 'button')
        .attr('href', '#')
        .attr('data-icon', 'search')
        .attr('data-theme', 'e')
        .text('Test IIIF in Mirador')
        .button();

    b.insertAfter($('#instance-info'));
    b.click(function() {
      if ($.mobile.pageData) {
        window.open('../wsi/app/mirador.html?iiif-content=../iiif/frames-pyramids/' + instanceId + '/0/manifest.json');
      }
    });
  }
});