Skip to content
/ tailor Public

A developer tool which tries to simplify inspecting spacings on websites

License

Notifications You must be signed in to change notification settings

Stanko/tailor

Repository files navigation

Tailor

Tailor is a developer tool that simplifies inspecting spacings on websites. While holding the toggle key (Alt or option), hover around the page to inspect elements. Size, margin, and padding will be highlighted, and font information will be displayed in the panel.

While Tailor is active, you can also click on an element to lock it and enter the measuring mode. Now, Tailor will display the distance between the locked element and any other element you hover over.

You can try it yourself on the demo page - https://muffinman.io/tailor/

Desktop only.

Our QA team does extensive checks to ensure that spacings, paddings, and font sizes match the designs. I created this library/extension hoping to make their lives easier.

Browser Extensions

Library

You can also use Tailor directly in your projects. Install the package:

npm install @stanko/tailor

Load the CSS and instantiate it:

import Tailor from "@stanko/tailor";
import "@stanko/tailor/dist/tailor.css";

new Tailor();

I would suggest disabling it in production, something like:

if (NODE_END !== "production") {
  new Tailor();
}

Tailor is only available as an ESM module.

Bookmarklet

You can also load Tailor using this bookmarklet. However, please be aware that depending on a site's security policies, it may not load.

Please drop the following code into the console or bookmark:

javascript: void (async function () {
  const Tailor = await import("https://esm.sh/@stanko/tailor");
  new Tailor.default();
  const style = document.createElement("link");
  style.setAttribute("href", "https://esm.sh/@stanko/tailor/dist/tailor.css");
  style.setAttribute("rel", "stylesheet");
  document.head.append(style);
})();

Setup

  • Use node version from .nvmrc - nvm use
  • Install dependencies - npm install
  • Copy git hooks - sh ./tools/copy-hooks.sh

Development server

Developing extensions

Firefox

Project uses web-ext for Firefox extension development.

  • Start extension in development mode - npm run firefox:run
  • Build Firefox extension - npm run firefox:run

Chrome

  • For now, copy manifest-chrome.json to manifest.json and load the unpacked extension
  • Build Chrome extension - npm run chrome:build

TODO

  • Info panel improvements
  • Handle touch events when simulating phones/tablets in devtools

About

A developer tool which tries to simplify inspecting spacings on websites

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published