npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

poe-item-renderer

v1.0.0

Published

Provides two Web Components for showing PoE items, built without frameworks, using only a thin compile-time abstraction - StencilJS.

Downloads

3

Readme

Item renderer Build

Provides two Web Components for showing PoE items, built without frameworks, using only a thin compile-time abstraction - StencilJS.

This library doesn't include any positioning logic. You can delegate it to libraries like Tippy and Popper.

This library isn't affiliated with Grinding Gear Games in any way. Game content and materials are trademarks and copyrights of their respective publisher and its licensors.


%JSON.stringify(item)% where item is https://www.pathofexile.com/developer/docs/reference#type-Item

Since the font affects the required size, it should be loaded before using the web component. If you show popup immediatly after page loads, add preload into the head.

<link rel="preload" href="Fontin-SmallCaps.ttf" ...>

Item icon

Properties

show-sockets: boolean Always show sockets

<poe-item-icon>
  <script type="application/json">%JSON.stringify(item)%</script>
</poe-item-icon>

Item popup

<poe-item-popup>
  <script type="application/json">%JSON.stringify(item)%</script>
</poe-item-popup>
  • There are no properties that disable something from being rendered. To hide the line, just set the field in item object to undefined before passing it to component.
  • PoE shows level of item only when it has itemLevel field. If you want it to show up, assign ilvl to the itemLevel.

Development

npm install
npm start

Technical notes

Color definitions can be found in Metadata/UI/UISettings.xml

PoE scales interface depending on window height, reference height is 1600px.

PoE CDN when used with parameter ?scale=1 (boolean) scales image if it were shown in window with height 974px. (actual ratio is 600/986)

PoE API tries to not but leaks text markup, specification for it can be found here https://gist.github.com/SnosMe/151549b532df8ea08025a76ae2920ca4

Fontin font is not hinted. To "fix" text rendering on non-HiDPI devices, an additional text shadow has been added in CSS.


... although I don't love how it looks in some of the cases where a stat description ends up breaking to multiple lines. One of the things which is considered when ordering new stats on unique items (but not the only or most important one) is the "shape" they give to the item descriptions as a whole.

— Mark_GGG source

And as expected, porting it to the web isn't straightforward.

TLDR. Layout is made visually around width of stat descriptions, calculating layout requires second pass with JS to free excessive space (artifact of block flow algorithm).

Constraints:

  1. Popup Minimum width
  2. Popup Maximum width
  3. Minimum width of some blocks (greater than #1)
  4. Block that expands Popup width to #2
  5. Block that inherits width from #4 (and wrap lines to fit in this width)
  6. Block that expands Popup width to #2 (they form distinct group of blocks and don't affect #4,5)