Knight Lab tools now embeddable on Medium

We’re excited to announce that instances of TimelineJS, StoryMapJS, and JuxtaposeJS can now be embedded directly into your Medium posts.

To make this possible, we’re using Embedly, a service that makes it easy to embed content into a variety of sites. Embedly works well with Medium, which is one of the most popular platforms that supports the service. While you may be able to embed our tools on a number of other platforms using the new method outlined below, we’ve optimized the embeds to work on Medium. We may work to integrate other platforms in the future.

The iframe generators that have helped power our tools for years will remain unchanged.

Embedding Timelines

  1. Build a Timeline as you normally would using the four-step process outlined on the TimelineJS website.
  2. In step three, choose how tall and wide you want the Timeline to appear in your Medium post.

    After pasting the URL to your spreadsheet in the appropriate box, set the desired width and height at right.
  3. Copy the link from the text area in the Medium section and paste it onto a new line in your Medium post to embed it.

    The last step: copy the URL from the bottom-most box into a new line in your Medium post.

Embedding StoryMaps

  1. Build a StoryMap as you normally would using the StoryMap website!
  2. When in the editing mode, click the “Share” button in the top right corner.
  3. Copy the link, and paste it into your Medium post where you’d like the StoryMap to show up. Every StoryMap embed will appear as a square which fills the full width of the text area within your post.

    After you click Share in the StoryMap editor, copy the URL in the link box and paste it into a new line in your Medium post.

Embedding JuxtaposeJS

  1. Build a Juxtapose slider as you normally would on the JuxtaposeJS website.
  2. Click the Publish button at the bottom of the page.
  3. Copy the link in the bottom-most text area, and paste it into your post where you’d like the slider to appear.

    After clicking the Publish button, copy the text from the bottom-most box into a new line in your Medium post.


One Important Note
The embeds will be static when posted in the Medium editor, but will become interactive when the post is published.

We’d love to hear from you about your experiences embedding our tools into Medium. If you have any issues with embedding a tool, please reach out to us via our Zendesk support system.

About the author

Bomani McClendon

Student Fellow

Latest Posts

  • A Big Change That Will Probably Affect Your Storymaps

    A big change is coming to StoryMapJS, and it will affect many, if not most existing storymaps. When making a storymap, one way to set a style and tone for your project is to set the "map type," also known as the "basemap." When we launched StoryMapJS, it included options for a few basemaps created by Stamen Design. These included the "watercolor" style, as well as the default style for new storymaps, "Toner Lite." Stamen...

    Continue Reading

  • Introducing AmyJo Brown, Knight Lab Professional Fellow

    AmyJo Brown, a veteran journalist passionate about supporting and reshaping local political journalism and who it engages, has joined the Knight Lab as a 2022-2023 professional fellow. Her focus is on building The Public Ledger, a data tool structured from local campaign finance data that is designed to track connections and make local political relationships – and their influence – more visible. “Campaign finance data has more stories to tell – if we follow the...

    Continue Reading

  • Interactive Entertainment: How UX Design Shapes Streaming Platforms

    As streaming develops into the latest age of entertainment, how are interfaces and layouts being designed to prioritize user experience and accessibility? The Covid-19 pandemic accelerated streaming services becoming the dominant form of entertainment. There are a handful of new platforms, each with thousands of hours of content, but not much change or differentiation in the user journeys. For the most part, everywhere from Netflix to illegal streaming platforms use similar video streaming UX standards, and...

    Continue Reading

  • Innovation with collaborationExperimenting with AI and investigative journalism in the Americas.

    Lee este artículo en español. How might we use AI technologies to innovate newsgathering and investigative reporting techniques? This was the question we posed to a group of seven newsrooms in Latin America and the US as part of the Americas Cohort during the 2021 JournalismAI Collab Challenges. The Collab is an initiative that brings together media organizations to experiment with AI technologies and journalism. This year,  JournalismAI, a project of Polis, the journalism think-tank at...

    Continue Reading

  • Innovación con colaboraciónCuando el periodismo de investigación experimenta con inteligencia artificial.

    Read this article in English. ¿Cómo podemos usar la inteligencia artificial para innovar las técnicas de reporteo y de periodismo de investigación? Esta es la pregunta que convocó a un grupo de siete organizaciones periodísticas en América Latina y Estados Unidos, el grupo de las Américas del 2021 JournalismAI Collab Challenges. Esta iniciativa de colaboración reúne a medios para experimentar con inteligencia artificial y periodismo. Este año, JournalismAI, un proyecto de Polis, la think-tank de periodismo...

    Continue Reading

  • AI, Automation, and Newsrooms: Finding Fitting Tools for Your Organization

    If you’d like to use technology to make your newsroom more efficient, you’ve come to the right place. Tools exist that can help you find news, manage your work in progress, and distribute your content more effectively than ever before, and we’re here to help you find the ones that are right for you. As part of the Knight Foundation’s AI for Local News program, we worked with the Associated Press to interview dozens of......

    Continue Reading

Storytelling Tools

We build easy-to-use tools that can help you tell better stories.

View More