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 🙏

© 2026 – Pkg Stats / Ryan Hefner

@russian-flags/regions

v1.0.1

Published

SVG flags of Russian regions for JavaScript and TypeScript: ESM imports, lazy loaders, metadata, and ISO 3166-2 region codes.

Readme

@russian-flags/regions

English version

Нативная ESM-коллекция SVG-флагов регионов России. Пакет можно использовать как npm-зависимость в JavaScript/TypeScript-проекте или как набор готовых SVG-файлов и ленивых загрузчиков без React.

Пакет содержит 89 регионов: республики, края, области, города федерального значения, автономную область и автономные округа.

Превью

| Регион | Код | ISO-код | Автокод | Флаг | | --- | --- | --- | --- | --- | | Санкт-Петербург | SPE | RU-SPE | 78 | | | Москва | MOW | RU-MOW | 77 | | | Севастополь | SEV | RU-SEV | 92, 93 | | | Новосибирская область | NVS | RU-NVS | 54 | |

Возможности

  • 89 локальных SVG-флагов в составе пакета.
  • ESM-сборка с TypeScript-типами.
  • Ленивые загрузчики для каждого флага.
  • Поиск региона по коду, ISO-коду, автомобильному коду, названию или алиасу.
  • Прямой импорт SVG-файлов через flags/<code> или svg/<code>.
  • Подходит для обычного JavaScript, TypeScript и современных сборщиков.

Установка

npm install @russian-flags/regions

Для локальной проверки из папки проекта:

npm install .

Быстрый старт

import { loadFlag, regions } from "@russian-flags/regions";

console.log(regions[0]);
// {
//   code: "AD",
//   isoCode: "RU-AD",
//   nameRu: "Республика Адыгея",
//   nameEn: "Republic of Adygea",
//   numericCodes: [1],
//   aliases: ["ADYGEA", "АДЫГЕЯ"]
// }

const image = await loadFlag("TA", {
  alt: "Флаг Республики Татарстан",
  className: "flag",
});

document.body.append(image);

loadFlag - алиас для loadFlagImage. Функция лениво импортирует модуль нужного флага, создает <img> и по умолчанию ставит loading="lazy" и decoding="async".

Подключение SVG напрямую

Если нужен только файл флага, можно импортировать SVG напрямую. Entry-point'ы для файлов сделаны в нижнем регистре:

import tatarstanFlag from "@russian-flags/regions/flags/ta";
import tatarstanSvg from "@russian-flags/regions/svg/ta";

console.log(tatarstanFlag);
console.log(tatarstanSvg);

Вариант с расширением тоже поддерживается:

import tatarstanFlag from "@russian-flags/regions/flags/ta.svg";
import tatarstanSvg from "@russian-flags/regions/svg/ta.svg";

flags/<code> и svg/<code> указывают на один и тот же файл внутри пакета:

dist/flags/<code>.svg

После публикации пакет также можно использовать как источник SVG через npm CDN:

<img src="https://unpkg.com/@russian-flags/regions/dist/flags/ta.svg" alt="Флаг Республики Татарстан" />

Поиск региона

В большинство функций можно передавать:

  • короткий код: "TA";
  • ISO-код: "RU-TA";
  • автомобильный код: 16, "16" или "016";
  • русское или английское название;
  • алиас из справочника, например "TATARSTAN".
import {
  getRegionMeta,
  regionCodes,
  regions,
  resolveRegionCode,
} from "@russian-flags/regions";

console.log(regions.length); // 89
console.log(regionCodes.includes("TA")); // true

console.log(resolveRegionCode("RU-TA")); // "TA"
console.log(resolveRegionCode(16)); // "TA"
console.log(resolveRegionCode("tatarstan")); // "TA"
console.log(resolveRegionCode("Республика Татарстан")); // "TA"
console.log(resolveRegionCode("unknown")); // undefined

console.log(getRegionMeta("RU-TA")?.nameRu); // "Республика Татарстан"

Ввод нормализуется: пробелы по краям удаляются, префикс RU- отбрасывается, регистр не важен, пробелы и дефисы приводятся к _.

Ленивое отображение списка

import { loadFlag, regions } from "@russian-flags/regions";

for (const region of regions) {
  const row = document.createElement("tr");
  row.dataset.code = region.code;
  row.textContent = region.nameRu;
  document.querySelector("tbody").append(row);
}

const observer = new IntersectionObserver((entries) => {
  for (const entry of entries) {
    if (!entry.isIntersecting) continue;

    observer.unobserve(entry.target);

    loadFlag(entry.target.dataset.code).then((image) => {
      entry.target.append(image);
    });
  }
});

document
  .querySelectorAll("tr[data-code]")
  .forEach((row) => observer.observe(row));

Preload

preloadFlag запускает загрузку модуля флага без ожидания результата. Это удобно на hover, focus или перед появлением строки во viewport.

import { preloadFlag } from "@russian-flags/regions";

button.addEventListener("pointerenter", () => {
  preloadFlag("TA");
});

Неизвестные значения игнорируются и не выбрасывают ошибку.

API

| Экспорт | Описание | | --- | --- | | regions | Массив метаданных { code, isoCode, nameRu, nameEn, numericCodes, aliases }. | | regionCodes | Массив всех доступных коротких кодов регионов. | | normalizeRegionCode(input) | Нормализует пользовательский ввод перед поиском. | | resolveRegionCode(input) | Возвращает короткий код региона по коду, ISO-коду, номеру, названию или алиасу. | | isRegionCode(input) | Type guard для канонического RegionCode. | | getRegionMeta(input) | Возвращает метаданные региона или undefined. | | getFlagModuleLoader(input) | Возвращает ленивый загрузчик модуля флага или undefined. | | getRegionFlagModuleLoader(input) | Алиас для getFlagModuleLoader. | | loadFlagModule(input) | Лениво импортирует модуль флага. Бросает ошибку для неизвестного значения. | | loadRegionFlagModule(input) | Алиас для loadFlagModule. | | loadFlagImage(input, options) | Загружает флаг и возвращает HTMLImageElement. | | loadRegionFlagImage(input, options) | Алиас для loadFlagImage. | | loadFlag(input, options) | Алиас для loadFlagImage. | | preloadFlag(input) | Запускает загрузку модуля без ожидания результата. | | preloadRegionFlag(input) | Алиас для preloadFlag. | | createFlagImage(src, defaultAlt, options) | Создает и настраивает <img> для SVG-флага. |

Типы

Пакет поставляет .d.ts файлы и экспортирует основные типы:

import type {
  FlagImageOptions,
  FlagModule,
  RegionCode,
  RegionInput,
  RegionMeta,
} from "@russian-flags/regions";

FlagImageOptions поддерживает:

| Поле | Назначение | | --- | --- | | alt | Альтернативный текст изображения. | | decoding | Значение свойства HTMLImageElement.decoding. | | loading | Значение свойства HTMLImageElement.loading. | | className | CSS-класс изображения. | | title | Атрибут title. | | id | Атрибут id. | | width, height | Размеры изображения. | | style | Inline-стили. | | dataset | Значения для data-*. | | attributes | Произвольные HTML-атрибуты. |

Совместимость

Пакет рассчитан на современные ESM-проекты и браузерное окружение. Функции loadFlag, loadFlagImage и createFlagImage создают HTMLImageElement, поэтому для них нужен DOM.

Метаданные (regions, regionCodes, resolveRegionCode, getRegionMeta) можно использовать отдельно, например для поиска, автокомплита или генерации списка доступных флагов.

Демо

cd examples
npm install
npm run dev

Vite откроет страницу примера в браузере. Пример устанавливает пакет из корня репозитория через file:.. и импортирует @russian-flags/regions так же, как это будет делать обычное приложение-потребитель.

Разработка

npm install
npm run build
npm test
npm run typecheck
npm run pack:dry

Сборка устроена так:

  1. scripts/build-source.js читает src/regions.ts, проверяет assets/<code>/index.svg и генерирует TypeScript-исходники.
  2. scripts/build.js собирает JavaScript через esbuild и копирует SVG в dist/flags/<code>.svg.
  3. tsc -p tsconfig.build.json генерирует .d.ts файлы в dist.

Чтобы добавить новый регион, добавьте запись в src/regions.ts, положите SVG в assets/<code-in-lowercase>/index.svg и запустите сборку.

Репозиторий

Лицензия

Код пакета распространяется по лицензии MIT. SVG-флаги не входят в MIT-лицензию кода и сохраняют свои исходные лицензии.