ebi-gene-expression-group/atlas-heatmap

Error: URNs do not have any generally defined hierarchical components

Closed this issue · 15 comments

I was just using the 3.5.13 version of the expression-atlas-heatmap-highcharts, as discussed in #3 . Now I'm getting the following error:
screen shot 2017-10-09 at 10 44 28

Have you ever dealt with this kind of error?

Hi Max,

It seems that URI.js, the library we use to build URLs, is unhappy about the parameters it’s using to build the URL to load some images in the anatomogram to the left of the heatmp. More specifically, the call that produces the error is the following (simplified):

URI(require(`./img/some_image.png`), atlasUrl).toString()

The above builds the link to img/some_image.png relative to atlasUrl. atlasUrl is by default https://www.ebi.ac.uk/gxa/, so the only way to know what’s going on is to set a breakpoint in the anatomogram code to know what’s the result of the require call. I can help you with that if you want.

The only thing I can think of, right now, is that in your environemnt require returns a URN. If that’s the case, I can reproduce the error you’re getting:

> URI('sch:/foo/bar', 'http://www.ebi.ac.uk/gxa/')
Error: URNs do not have any generally defined hierarchical components
    at URI.p.absoluteTo (/Users/amunoz/dev/ebi/ge/anatomogram/node_modules/urijs/src/URI.js:2118:13)
    at new URI (/Users/amunoz/dev/ebi/ge/anatomogram/node_modules/urijs/src/URI.js:74:19)
    at URI (/Users/amunoz/dev/ebi/ge/anatomogram/node_modules/urijs/src/URI.js:43:18)

Okay, that looks similar! What is the solution for this?

You said you're using Angular, how are you building the project - does your tooling also involve webpack? If not what in your project is processing the requires?

An (unsatisfactory but you might want to go for it if e.g. you need to get something done quickly) solution is to put on your page

https://www.ebi.ac.uk/gxa/resources/js-bundles/vendorCommons.bundle.js
https://www.ebi.ac.uk/gxa/resources/js-bundles/expressionAtlasHeatmapHighcharts.bundle.js

which will populate your environment with the global expressionAtlasHeatmapHighcharts , and call render on that.

@tschaka1904 As @wbazant pointed out, we need to know how your requires are processed and what’s their output to know why URI.js is complaining.

I'm using the Angular-CLI, which runs webpack under-the-hood. @wbazant I'm using your suggested solution at the moment.

How are you processing images in your environment? We use file-loader in our build with the following configuration (the sample is for Webpack 3):

{
  test: /\.(jpe?g|png|gif)$/i,
  use: [
    {
      loader: 'file-loader',
      options: {
        query: {
          name: '[hash].[ext]',
          hash: 'sha512',
          digest: 'hex'
        }
      }
    }]
}

In this way, the image is renamed to its SHA512 hash followed by the extension, which is what the require line will return, resolved to atlasUrl. If you process images in some other way then it will probably fail.

I didn't specify that, as I'm using the Angular-CLI and the whole Webpack config happens under-the-hood.

Max, from the little I’ve read about Angular and Webpack, it looks like there’s a non-editable default configuration.

In light of that, and to solve the issue, could you add just a simple console.log(require('some_image.png') to your project so see how the require is resolved, and then we can look at adding a patch to fix the error? Adding some logging inside node_modules/urijs would also help but maybe it’s not necessary.

Yes. I could get around it and get full control using ng eject, but I'd like to avoid that. To your question:

console.error(require('assets/images/legend/small-mol.png'));

resolves in:



I'm not in the office today, but we can have a chat tomorrow.

Yep, as we suspected the image is inlined as a URN with url-loader.

We’ve published a new version of the anatomogram package where this issue is (hopefully) fixed. If you remove atlas-heatmap and anatomogram from node_modules and reinstall it it will pull the latest version. Let us know if that fixes the issue.

Thanks, @alfonsomunozpomer!

It still seems to have problems to find the SVG for the organism image. I'm getting a 404:
https://www.ebi.ac.uk/gxa/homo_sapiens.male.4626c730027e5ff70254.svg

Other than that it starts working:
screen shot 2017-10-10 at 14 41 52

It looks like when you require a SVG it’s resolved to file.hash.svg. Can you somehow paste the Webpack config that Angular is using or its log? I’d suppose that Webpack is processing homo_sapiens.male.svg and emitting homo_sapiens.male.4626c730027e5ff70254.svg, but it’d be good to know if it’s placing it in some specific directory. I guess that in order to solve this issue we’ll need to add a parameter to specify the location of your assets.

Closing after one month of inactivity.