@weavix/sdk-core 0.0.2 → 0.0.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -10,4 +10,10 @@ export declare const METHOD_NOT_SUPPORTED = 1003;
10
10
  export declare const MISSING_REQUIRED_SCOPE = 1004;
11
11
  /** Код ошибки: непредвиденная или неклассифицированная ошибка. */
12
12
  export declare const UNKNOWN_ERROR = 6666;
13
+ /** Storage record version does not match the current one. */
14
+ export declare const VERSION_CONFLICT = 1010;
15
+ /** Data size exceeds 256 KiB after the operation. */
16
+ export declare const DATA_TOO_LARGE = 1011;
17
+ /** bucket failed validation (format or length). */
18
+ export declare const BAD_KEY = 1012;
13
19
  //# sourceMappingURL=ErrorCodes.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"ErrorCodes.d.ts","sourceRoot":"","sources":["../../../src/bridge/types/ErrorCodes.ts"],"names":[],"mappings":"AAAA,gGAAgG;AAChG,eAAO,MAAM,8BAA8B,OAAO,CAAC;AAEnD,wGAAwG;AACxG,eAAO,MAAM,wBAAwB,OAAO,CAAC;AAE7C,8GAA8G;AAC9G,eAAO,MAAM,gBAAgB,OAAO,CAAC;AAErC,4FAA4F;AAC5F,eAAO,MAAM,oBAAoB,OAAO,CAAC;AAEzC,yFAAyF;AACzF,eAAO,MAAM,sBAAsB,OAAO,CAAC;AAE3C,kEAAkE;AAClE,eAAO,MAAM,aAAa,OAAO,CAAC"}
1
+ {"version":3,"file":"ErrorCodes.d.ts","sourceRoot":"","sources":["../../../src/bridge/types/ErrorCodes.ts"],"names":[],"mappings":"AAAA,gGAAgG;AAChG,eAAO,MAAM,8BAA8B,OAAO,CAAC;AAEnD,wGAAwG;AACxG,eAAO,MAAM,wBAAwB,OAAO,CAAC;AAE7C,8GAA8G;AAC9G,eAAO,MAAM,gBAAgB,OAAO,CAAC;AAErC,4FAA4F;AAC5F,eAAO,MAAM,oBAAoB,OAAO,CAAC;AAEzC,yFAAyF;AACzF,eAAO,MAAM,sBAAsB,OAAO,CAAC;AAE3C,kEAAkE;AAClE,eAAO,MAAM,aAAa,OAAO,CAAC;AAElC,6DAA6D;AAC7D,eAAO,MAAM,gBAAgB,OAAO,CAAC;AAErC,qDAAqD;AACrD,eAAO,MAAM,cAAc,OAAO,CAAC;AAEnC,mDAAmD;AACnD,eAAO,MAAM,OAAO,OAAO,CAAC"}
package/dist/index.d.ts CHANGED
@@ -1,6 +1,6 @@
1
1
  export { initBridge, sendRequest } from './bridge/bridge';
2
2
  export type { BaseMessage } from './bridge/types/BaseMessage';
3
- export { METHOD_NOT_SUPPORTED, MISSING_REQUIRED_SCOPE, PLUGIN_ID_IS_NOT_CORRECT, PLUGIN_ID_OR_SLOT_NOT_PROVIDED, UNKNOWN_ERROR, VALIDATION_ERROR, } from './bridge/types/ErrorCodes';
3
+ export { BAD_KEY, DATA_TOO_LARGE, METHOD_NOT_SUPPORTED, MISSING_REQUIRED_SCOPE, PLUGIN_ID_IS_NOT_CORRECT, PLUGIN_ID_OR_SLOT_NOT_PROVIDED, UNKNOWN_ERROR, VALIDATION_ERROR, VERSION_CONFLICT, } from './bridge/types/ErrorCodes';
4
4
  export { PluginActionError } from './bridge/types/PluginActionError';
5
5
  export type { PluginConfirmPayload, PluginToastAction, PluginToastPayload, UiContract, } from './bridge/types/UiContract';
6
6
  export { getHandler, setHandler } from './handlers/handlers';
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAG1D,YAAY,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AAC9D,OAAO,EACH,oBAAoB,EACpB,sBAAsB,EACtB,wBAAwB,EACxB,8BAA8B,EAC9B,aAAa,EACb,gBAAgB,GACnB,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AACrE,YAAY,EACR,oBAAoB,EACpB,iBAAiB,EACjB,kBAAkB,EAClB,UAAU,GACb,MAAM,2BAA2B,CAAC;AAGnC,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAG7D,OAAO,EAAE,iBAAiB,EAAE,QAAQ,EAAE,EAAE,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AACnF,YAAY,EACR,YAAY,EACZ,iBAAiB,EACjB,iBAAiB,EACjB,eAAe,EACf,WAAW,GACd,MAAM,gBAAgB,CAAC;AAGxB,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AACvC,YAAY,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAClE,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AACvC,YAAY,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAC9D,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAC;AAGnC,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,YAAY,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAG5D,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAC5D,YAAY,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAC9D,YAAY,EACR,wBAAwB,EACxB,4BAA4B,GAC/B,MAAM,uCAAuC,CAAC;AAC/C,YAAY,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAGpE,YAAY,EAAE,KAAK,EAAE,MAAM,sBAAsB,CAAC;AAGlD,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAC;AAClD,YAAY,EAAE,YAAY,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAG1D,YAAY,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AAC9D,OAAO,EACH,OAAO,EACP,cAAc,EACd,oBAAoB,EACpB,sBAAsB,EACtB,wBAAwB,EACxB,8BAA8B,EAC9B,aAAa,EACb,gBAAgB,EAChB,gBAAgB,GACnB,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AACrE,YAAY,EACR,oBAAoB,EACpB,iBAAiB,EACjB,kBAAkB,EAClB,UAAU,GACb,MAAM,2BAA2B,CAAC;AAGnC,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAG7D,OAAO,EAAE,iBAAiB,EAAE,QAAQ,EAAE,EAAE,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AACnF,YAAY,EACR,YAAY,EACZ,iBAAiB,EACjB,iBAAiB,EACjB,eAAe,EACf,WAAW,GACd,MAAM,gBAAgB,CAAC;AAGxB,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AACvC,YAAY,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAClE,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AACvC,YAAY,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAC9D,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAC;AAGnC,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,YAAY,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAG5D,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAC5D,YAAY,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAC9D,YAAY,EACR,wBAAwB,EACxB,4BAA4B,GAC/B,MAAM,uCAAuC,CAAC;AAC/C,YAAY,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAGpE,YAAY,EAAE,KAAK,EAAE,MAAM,sBAAsB,CAAC;AAGlD,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAC;AAClD,YAAY,EAAE,YAAY,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC"}
package/dist/index.mjs CHANGED
@@ -25,7 +25,7 @@ function R(i) {
25
25
  console.error(`[EventBus] Error in subscriber for "${i.method}":`, n);
26
26
  }
27
27
  }
28
- function _() {
28
+ function U() {
29
29
  m.clear(), g.clear();
30
30
  }
31
31
  const P = {
@@ -39,7 +39,7 @@ function H(i, e) {
39
39
  function S(i) {
40
40
  return E[i];
41
41
  }
42
- const q = 1e3, N = 1001, B = 1002, k = 1003, D = 1004, I = 6666;
42
+ const q = 1e3, N = 1001, B = 1002, D = 1003, k = 1004, I = 6666, x = 1010, F = 1011, $ = 1012;
43
43
  class y extends Error {
44
44
  constructor(e, t, s) {
45
45
  super(t), this.name = "PluginActionError", this.code = e, this.errorData = s;
@@ -218,7 +218,7 @@ class L {
218
218
  }
219
219
  }
220
220
  }
221
- class z {
221
+ class A {
222
222
  constructor() {
223
223
  this.toaster = new L(), this.confirm = new T();
224
224
  }
@@ -226,8 +226,8 @@ class z {
226
226
  return u("navigate", e);
227
227
  }
228
228
  }
229
- const x = new z();
230
- function F(i, e, t) {
229
+ const G = new A();
230
+ function V(i, e, t) {
231
231
  if (e === "")
232
232
  return t;
233
233
  const s = e.split(".");
@@ -239,13 +239,13 @@ function F(i, e, t) {
239
239
  return t;
240
240
  return n ?? t;
241
241
  }
242
- function $(i, e, t = "ru") {
242
+ function X(i, e, t = "ru") {
243
243
  if (typeof i == "string")
244
244
  return i;
245
245
  const s = (e ?? t).toLowerCase(), n = t.toLowerCase();
246
246
  return i[s] || i[n] || i.ru || i.en || "";
247
247
  }
248
- class A {
248
+ class _ {
249
249
  constructor(e) {
250
250
  this.lastHeight = 0, this.isUpdating = !1, this.consecutiveSmallIncreases = 0, this.MAX_CONSECUTIVE_SMALL_INCREASES = 5, this.SMALL_INCREASE_THRESHOLD_PX = 10, this.resizeCallback = e;
251
251
  }
@@ -293,7 +293,7 @@ class A {
293
293
  this.resizeObserver?.disconnect(), clearTimeout(this.resizeTimeout), this.isUpdating = !1, this.consecutiveSmallIncreases = 0;
294
294
  }
295
295
  }
296
- class U {
296
+ class z {
297
297
  constructor() {
298
298
  this.slot = null, this.service = null, this.origin = null, this.innerUrl = null, this.queryParams = null, this.entityId = null, this.entityMeta = void 0, this.contextLevel = "full";
299
299
  }
@@ -344,7 +344,7 @@ class U {
344
344
  const f = s.get("contextLevel");
345
345
  this.contextLevel = f === "basic" ? "basic" : "full", this.innerUrl = s.get("innerUrl") ?? "";
346
346
  const p = s.get("queryParams");
347
- this.queryParams = p ? JSON.parse(decodeURIComponent(p)) : {}, t && (this.autoResizeManager = new A(
347
+ this.queryParams = p ? JSON.parse(decodeURIComponent(p)) : {}, t && (this.autoResizeManager = new _(
348
348
  (b) => this.updateContentSize({ height: b })
349
349
  ), this.autoResizeManager.enable());
350
350
  }
@@ -386,30 +386,33 @@ class U {
386
386
  this.autoResizeManager?.disable();
387
387
  }
388
388
  }
389
- const X = new U();
389
+ const Y = new z();
390
390
  export {
391
- A as AutoResizeManager,
391
+ _ as AutoResizeManager,
392
+ $ as BAD_KEY,
392
393
  T as Confirm,
393
- U as HostApi,
394
- k as METHOD_NOT_SUPPORTED,
395
- D as MISSING_REQUIRED_SCOPE,
394
+ F as DATA_TOO_LARGE,
395
+ z as HostApi,
396
+ D as METHOD_NOT_SUPPORTED,
397
+ k as MISSING_REQUIRED_SCOPE,
396
398
  N as PLUGIN_ID_IS_NOT_CORRECT,
397
399
  q as PLUGIN_ID_OR_SLOT_NOT_PROVIDED,
398
400
  y as PluginActionError,
399
401
  L as Toaster,
400
402
  I as UNKNOWN_ERROR,
401
403
  B as VALIDATION_ERROR,
404
+ x as VERSION_CONFLICT,
402
405
  R as dispatchHostEvent,
403
406
  P as eventBus,
404
- F as getField,
407
+ V as getField,
405
408
  S as getHandler,
406
- $ as getLocalizedString,
407
- X as hostApi,
409
+ X as getLocalizedString,
410
+ Y as hostApi,
408
411
  M as initBridge,
409
412
  w as on,
410
- _ as resetEventBus,
413
+ U as resetEventBus,
411
414
  u as sendRequest,
412
415
  H as setHandler,
413
- x as uiApi
416
+ G as uiApi
414
417
  };
415
418
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../src/events/eventBus.ts","../src/handlers/handlers.ts","../src/bridge/types/ErrorCodes.ts","../src/bridge/types/PluginActionError.ts","../src/bridge/bridge.ts","../src/ui/Confirm.ts","../src/ui/Toaster.ts","../src/ui/uiApi.ts","../src/utils/getField.ts","../src/utils/localization.ts","../src/host/utils/autoResize.ts","../src/host/hostApi.ts"],"sourcesContent":["import type {\n EventMessage,\n HostEventCallback,\n HostEventContract,\n HostEventMethod,\n Unsubscribe,\n} from './types';\n\nconst subscribers = new Map<HostEventMethod, Set<(result: unknown) => void>>();\nconst lastValues = new Map<HostEventMethod, unknown>();\n\n/**\n * Subscribe to a host-pushed event.\n * If a value was already dispatched for this method, the callback is called\n * synchronously with the cached value before returning.\n * @param method - Event method name (e.g. `'theme.changed'`)\n * @param callback - Function called with the typed event payload\n * @returns An `Unsubscribe` function that removes this subscription\n */\nexport function on<M extends HostEventMethod>(\n method: M,\n callback: HostEventCallback<M>,\n): Unsubscribe {\n let set = subscribers.get(method);\n if (!set) {\n set = new Set();\n subscribers.set(method, set);\n }\n\n const cb = callback as (result: unknown) => void;\n set.add(cb);\n\n // Replay last known value to the new subscriber immediately\n if (lastValues.has(method)) {\n try {\n // eslint-disable-next-line callback-return -- sync replay to new subscriber; return value unused\n cb(lastValues.get(method));\n } catch (err) {\n console.error(`[EventBus] Error replaying cached value for \"${method}\":`, err);\n }\n }\n\n return () => {\n set.delete(cb);\n if (set.size === 0) {\n subscribers.delete(method);\n }\n };\n}\n\n/**\n * Dispatch an incoming event message to all registered subscribers.\n * Caches the value so late subscribers receive it on subscription.\n */\nexport function dispatchHostEvent(message: EventMessage): void {\n const method = message.method as HostEventMethod;\n lastValues.set(method, message.result);\n\n const set = subscribers.get(method);\n if (!set) {\n return;\n }\n for (const cb of set) {\n try {\n // eslint-disable-next-line callback-return -- notify subscribers; return value unused\n cb(message.result);\n } catch (err) {\n console.error(`[EventBus] Error in subscriber for \"${message.method}\":`, err);\n }\n }\n}\n\n/**\n * Clears all cached last values and subscribers from the event bus.\n * Intended for use in tests to prevent state leaking between test cases.\n */\nexport function resetEventBus(): void {\n lastValues.clear();\n subscribers.clear();\n}\n\n/**\n * Public event emitter — subscribe to host-pushed events.\n * Only events defined in `HostEventContract` are accepted.\n * @example\n * ```ts\n * import { eventBus } from '@yandex-data-ui/tracker-plugin-sdk-core';\n *\n * const unsubscribe = eventBus.on('theme.changed', (theme) => {\n * console.log('Theme:', theme);\n * });\n *\n * unsubscribe();\n * ```\n */\nexport const eventBus = {\n on<M extends HostEventMethod>(\n method: M,\n callback: (result: HostEventContract[M]['result']) => void,\n ): Unsubscribe {\n return on(method, callback);\n },\n};\n","type AnyHandler = (...args: unknown[]) => unknown;\n\nconst handlers: Record<string, AnyHandler> = {};\n\n/**\n * Регистрирует handler по имени. Тип не проверяется на runtime'е;\n * type-safety обеспечивается typed wrapper'ом в публикуемых пакетах.\n */\nexport function setHandler(name: string, handler: AnyHandler): void {\n handlers[name] = handler;\n}\n\n/**\n * Возвращает зарегистрированный handler по имени, или undefined.\n */\nexport function getHandler(name: string): AnyHandler | undefined {\n return handlers[name];\n}\n","/** Код ошибки: не переданы обязательные параметры инициализации плагина (pluginId или slot). */\nexport const PLUGIN_ID_OR_SLOT_NOT_PROVIDED = 1000;\n\n/** Код ошибки: переданный pluginId не совпадает с зарегистрированным плагином или неверного формата. */\nexport const PLUGIN_ID_IS_NOT_CORRECT = 1001;\n\n/** Код ошибки: данные запроса не прошли валидацию (неверный формат, обязательные поля отсутствуют и т.п.). */\nexport const VALIDATION_ERROR = 1002;\n\n/** Код ошибки: запрошенный метод API не поддерживается в данной конфигурации или версии. */\nexport const METHOD_NOT_SUPPORTED = 1003;\n\n/** Код ошибки: у плагина нет необходимого scope (разрешения) для выполнения операции. */\nexport const MISSING_REQUIRED_SCOPE = 1004;\n\n/** Код ошибки: непредвиденная или неклассифицированная ошибка. */\nexport const UNKNOWN_ERROR = 6666;\n","export class PluginActionError extends Error {\n readonly code: number;\n\n readonly errorData?: unknown;\n\n constructor(code: number, message: string, errorData?: unknown) {\n super(message);\n this.name = 'PluginActionError';\n this.code = code;\n this.errorData = errorData;\n }\n}\n","import { dispatchHostEvent } from '../events/eventBus';\nimport type { EventMessage } from '../events/types';\nimport { getHandler } from '../handlers/handlers';\nimport { UNKNOWN_ERROR } from './types/ErrorCodes';\nimport type { BaseMessage } from './types/BaseMessage';\nimport { PluginActionError } from './types/PluginActionError';\n\ntype RequestOptions = { timeout?: number };\n\ntype PendingRequest = {\n resolve: (value: unknown) => void;\n reject: (error: Error) => void;\n timeoutId: ReturnType<typeof setTimeout>;\n};\n\ntype RawRequestMessage = BaseMessage & {\n method: string;\n payload: unknown;\n};\n\ntype RawResponseMessage = BaseMessage & {\n type: 'response';\n result: unknown;\n error?: string;\n errorCode?: number;\n errorData?: unknown;\n};\n\ntype RawIncomingRequestMessage = BaseMessage & {\n type: 'request';\n result: { method: string; payload: unknown };\n error?: string;\n};\n\nclass PluginBridge {\n private pluginId: string;\n private elementId: string;\n private targetOrigin: string;\n private slot: string;\n private entityId: string | null;\n private entityMeta: Record<string, string> | undefined;\n private pendingRequests: Map<string, PendingRequest> = new Map();\n private messageListener: ((event: MessageEvent) => void) | null = null;\n private readonly requestTimeout = 10000;\n\n constructor(\n pluginId: string,\n elementId: string,\n slot: string,\n entityId: string | null,\n targetOrigin: string,\n entityMeta?: Record<string, string>,\n ) {\n this.pluginId = pluginId;\n this.elementId = elementId;\n this.targetOrigin = targetOrigin;\n this.entityId = entityId;\n this.entityMeta = entityMeta;\n this.slot = slot;\n this.initListener();\n }\n\n request(method: string, payload?: unknown, options?: RequestOptions): Promise<unknown> {\n return new Promise((resolve, reject) => {\n const messageId = this.generateMessageId();\n const timeoutMs = options?.timeout ?? this.requestTimeout;\n\n const requestMessage: RawRequestMessage = {\n messageId,\n method,\n payload,\n };\n\n const timeoutId = setTimeout(() => {\n const pending = this.pendingRequests.get(messageId);\n if (pending) {\n this.pendingRequests.delete(messageId);\n reject(new Error(`Request timeout: ${method} exceeded ${timeoutMs}ms`));\n }\n }, timeoutMs);\n\n this.pendingRequests.set(messageId, { resolve, reject, timeoutId });\n\n try {\n this.send(requestMessage);\n } catch (e) {\n clearTimeout(timeoutId);\n this.pendingRequests.delete(messageId);\n reject(e as Error);\n }\n });\n }\n\n send<T = unknown>(message: T): void {\n window.parent.postMessage(\n {\n pluginId: this.pluginId,\n elementId: this.elementId,\n slot: this.slot,\n entityId: this.entityId,\n entityMeta: this.entityMeta,\n ...message,\n },\n this.targetOrigin,\n );\n }\n\n destroy(): void {\n if (this.messageListener) {\n window.removeEventListener('message', this.messageListener);\n this.messageListener = null;\n }\n\n this.pendingRequests.forEach((pending) => {\n clearTimeout(pending.timeoutId);\n });\n this.pendingRequests.clear();\n }\n\n private initListener(): void {\n this.messageListener = async (event: MessageEvent) => {\n if (event.origin !== this.targetOrigin) {\n console.info(\n '[Bridge] Ignored message from origin:',\n event.origin,\n '(expected:',\n this.targetOrigin,\n ')',\n );\n return;\n }\n\n const message = event.data;\n console.info('[Bridge] Received message:', message);\n\n if (message.type === 'event') {\n console.info('[Bridge] Dispatching host event:', message.method, message.result);\n dispatchHostEvent(message as EventMessage);\n return;\n }\n\n console.info('[Bridge] Received message:', event.data);\n\n if (!message.messageId) {\n console.info('[Bridge] Ignored message without messageId:', message);\n return;\n }\n\n const typedMessage = message as RawResponseMessage | RawIncomingRequestMessage;\n const pending = this.pendingRequests.get(typedMessage.messageId);\n\n if (!pending) {\n if (typedMessage.type === 'request') {\n const incoming = typedMessage as RawIncomingRequestMessage;\n const method = incoming.result.method;\n const handler = getHandler(method);\n\n if (!handler) {\n this.send({\n messageId: typedMessage.messageId,\n type: 'response',\n result: null,\n errorCode: UNKNOWN_ERROR,\n error: `No handler for method ${method}`,\n });\n return;\n }\n\n try {\n const data = handler();\n this.send({\n messageId: typedMessage.messageId,\n payload: data,\n method: 'responseData',\n type: 'response',\n });\n } catch (e) {\n const err = e instanceof Error ? e : new Error(String(e));\n const errorCode =\n err instanceof PluginActionError ? err.code : UNKNOWN_ERROR;\n this.send({\n messageId: typedMessage.messageId,\n type: 'response',\n result: null,\n errorCode,\n error: err.message,\n });\n }\n }\n\n return;\n }\n\n clearTimeout(pending.timeoutId);\n this.pendingRequests.delete(typedMessage.messageId);\n\n const response = typedMessage as RawResponseMessage;\n if (response.type === 'response' && response.errorCode) {\n pending.reject(\n new PluginActionError(\n response.errorCode,\n response.error ?? 'Unknown error',\n response.errorData,\n ),\n );\n } else {\n pending.resolve(response.result);\n }\n };\n\n window.addEventListener('message', this.messageListener);\n }\n\n private generateMessageId(): string {\n return crypto.randomUUID();\n }\n}\n\nlet bridgeInstance: PluginBridge | null = null;\n\nexport function initBridge(\n pluginId: string,\n elementId: string,\n slot: string,\n entityId: string | null,\n targetOrigin: string,\n entityMeta?: Record<string, string>,\n): PluginBridge {\n if (bridgeInstance) {\n bridgeInstance.destroy();\n }\n bridgeInstance = new PluginBridge(\n pluginId,\n elementId,\n slot,\n entityId,\n targetOrigin,\n entityMeta,\n );\n return bridgeInstance;\n}\n\nfunction getBridge(): PluginBridge {\n if (!bridgeInstance) {\n throw new Error('Bridge not initialized. Call initBridge first.');\n }\n return bridgeInstance;\n}\n\nexport function sendRequest(\n method: string,\n payload?: unknown,\n options?: RequestOptions,\n): Promise<unknown> {\n return getBridge().request(method, payload, options);\n}\n","import { sendRequest } from '../bridge/bridge';\n\nexport type ConfirmOptions = {\n title?: string;\n message: string;\n textButtonApply?: string;\n textButtonCancel?: string;\n theme?: 'normal' | 'danger';\n};\n\nexport type ConfirmResult = { confirmed: boolean };\n\nconst CONFIRM_TIMEOUT_MS = 300_000;\n\nexport class Confirm {\n show(options: ConfirmOptions): Promise<ConfirmResult> {\n return sendRequest('confirm.show', options, {\n timeout: CONFIRM_TIMEOUT_MS,\n }) as Promise<ConfirmResult>;\n }\n}\n","import { sendRequest } from '../bridge/bridge';\nimport { on } from '../events/eventBus';\n\nexport type ToastAction = {\n label: string;\n onClick: () => void;\n};\n\nexport type ToastOptions = {\n name?: string;\n title: string;\n content?: string;\n theme?: 'success' | 'danger' | 'warning' | 'info';\n autoHiding?: number;\n isClosable?: boolean;\n actions?: ToastAction[];\n};\n\nexport class Toaster {\n private callbackMap = new Map<string, () => void>();\n private toastActionIds = new Map<string, string[]>();\n private eventSubscribed = false;\n\n async add(options: ToastOptions): Promise<{ name: string }> {\n this.ensureEventSubscription();\n\n const actionIds: string[] = [];\n const serializedActions = options.actions?.map((action) => {\n const actionId = crypto.randomUUID();\n\n this.callbackMap.set(actionId, action.onClick);\n actionIds.push(actionId);\n\n return { id: actionId, label: action.label };\n });\n\n const result = (await sendRequest('toast.add', {\n name: options.name,\n title: options.title,\n content: options.content,\n theme: options.theme,\n autoHiding: options.autoHiding,\n isClosable: options.isClosable,\n actions: serializedActions,\n })) as { name: string };\n\n if (actionIds.length > 0) {\n this.toastActionIds.set(result.name, actionIds);\n }\n\n const autoHiding = options.autoHiding ?? 5000;\n\n setTimeout(() => this.cleanupCallbacksForToast(result.name), autoHiding + 1000);\n\n return result;\n }\n\n private ensureEventSubscription() {\n if (this.eventSubscribed) return;\n this.eventSubscribed = true;\n\n on('toast.action.clicked', ({ name, actionId }) => {\n const callback = this.callbackMap.get(actionId);\n\n // eslint-disable-next-line callback-return -- optional void callback for side effects\n callback?.();\n this.cleanupCallbacksForToast(name);\n });\n }\n\n private cleanupCallbacksForToast(name: string) {\n const actionIds = this.toastActionIds.get(name);\n\n if (actionIds) {\n for (const id of actionIds) {\n this.callbackMap.delete(id);\n }\n this.toastActionIds.delete(name);\n }\n }\n}\n","import { sendRequest } from '../bridge/bridge';\nimport type { NavigateRequest } from '../host/types/NavigateRequest';\nimport { Confirm } from './Confirm';\nimport { Toaster } from './Toaster';\n\nclass UiApi {\n readonly toaster = new Toaster();\n readonly confirm = new Confirm();\n\n navigate(payload: NavigateRequest): Promise<unknown> {\n return sendRequest('navigate', payload);\n }\n}\n\nexport const uiApi = new UiApi();\n","/**\n * Извлекает значение из объекта по точечному пути (dot notation).\n * Предназначена для работы с полями типа Record<string, unknown>, например со значениями полей задачи (Issue).\n *\n * Поддерживает вложенные пути: `'priority.display'`, `'assignee.display.ru'` и т.д.\n * Если любой сегмент пути отсутствует или не является объектом — возвращается defaultValue или undefined.\n * @param obj - Объект с произвольной структурой (например, issue или issue.values)\n * @param path - Путь к полю через точку, например `'priority.display'` или `'summary'`\n * @param defaultValue - Значение по умолчанию, если путь не найден\n * @returns Значение по пути, defaultValue или undefined\n * @example\n * ```ts\n * // Поле верхнего уровня\n * getField(issue, 'key'); // 'QUEUE-123'\n *\n * // Вложенное поле (например, приоритет с display)\n * getField(issue, 'priority.display'); // 'много' | undefined\n *\n * // С типизацией и значением по умолчанию\n * const name = getField<string>(issue, 'summary', 'Без названия');\n *\n * // Элемент массива по индексу (массивы — объекты с числовыми ключами)\n * getField(tags, '0'); // первый элемент\n * ```\n */\nexport function getField<T = unknown>(\n obj: Record<string, unknown>,\n path: string,\n defaultValue?: T,\n): T | undefined {\n if (path === '') {\n return defaultValue;\n }\n\n const keys = path.split('.');\n let result: unknown = obj;\n\n for (const key of keys) {\n if (\n result !== null &&\n typeof result === 'object' &&\n Object.prototype.hasOwnProperty.call(result, key)\n ) {\n result = (result as Record<string, unknown>)[key];\n } else {\n return defaultValue;\n }\n }\n\n return (result as T | undefined) ?? defaultValue;\n}\n","/**\n * Структурный shape `LocalizedString` — общая база, к которой структурно\n * совместимы api-types `LocalizedString` обоих flavors. Реальная функция\n * `getLocalizedString` читает только ключи `ru` и `en`, поэтому более\n * узкие api-types-варианты (с дополнительными ключами) совместимы.\n */\nexport type LocalizedString = string | { ru?: string; en?: string };\n\n/**\n * Получить локализованную строку на основе языка\n * @param value - Локализованная строка\n * @param language - Код языка ('ru' или 'en')\n * @param fallbackLanguage - Резервный язык (по умолчанию 'ru')\n */\nexport function getLocalizedString(\n value: LocalizedString,\n language: string | undefined,\n fallbackLanguage = 'ru',\n): string {\n if (typeof value === 'string') {\n return value;\n }\n\n const lang = (language ?? fallbackLanguage).toLowerCase() as 'ru' | 'en';\n const fallback = fallbackLanguage.toLowerCase() as 'ru' | 'en';\n\n return value[lang] || value[fallback] || value.ru || value.en || '';\n}\n","export type ResizeCallback = (height: number) => Promise<void> | void;\n\nexport class AutoResizeManager {\n private resizeCallback: ResizeCallback;\n private resizeObserver?: ResizeObserver;\n private resizeTimeout?: ReturnType<typeof setTimeout>;\n private lastHeight = 0;\n private isUpdating = false;\n private consecutiveSmallIncreases = 0;\n private readonly MAX_CONSECUTIVE_SMALL_INCREASES = 5;\n private readonly SMALL_INCREASE_THRESHOLD_PX = 10;\n\n constructor(resizeCallback: ResizeCallback) {\n this.resizeCallback = resizeCallback;\n }\n\n enable(): void {\n if (!document.body) {\n console.error('[AutoResize] document.body does not exist yet');\n return;\n }\n\n const sendHeight = async () => {\n if (this.isUpdating) {\n return;\n }\n\n // Use body.scrollHeight as primary source in iframe\n // documentElement.scrollHeight can cache old values\n const root = document.getElementById('root');\n const bodyStyles = window.getComputedStyle(document.body);\n const marginTop = parseInt(bodyStyles.marginTop, 10) || 0;\n const marginBottom = parseInt(bodyStyles.marginBottom, 10) || 0;\n\n const measuredHeight = Math.max(\n document.body.scrollHeight,\n document.body.offsetHeight,\n root ? root.scrollHeight + marginTop + marginBottom : 0,\n );\n\n // Add small buffer to compensate for rounding errors\n const height = measuredHeight + 4;\n\n if (height !== this.lastHeight) {\n // Detect infinite loop: if height keeps increasing by small amounts\n // This prevents issues with elements using viewport units (vh, %)\n if (height > this.lastHeight) {\n const increase = height - this.lastHeight;\n\n // Only count small increases as potential loop indicators\n // Large increases are normal (user adding content)\n if (increase <= this.SMALL_INCREASE_THRESHOLD_PX) {\n this.consecutiveSmallIncreases++;\n\n if (this.consecutiveSmallIncreases > this.MAX_CONSECUTIVE_SMALL_INCREASES) {\n console.warn(\n '[AutoResize] Infinite loop detected. Stopping auto-resize. ' +\n 'This may be caused by elements with viewport-relative units (vh, %).',\n );\n this.disable();\n return;\n }\n } else {\n // Large increase - reset counter (normal content addition)\n this.consecutiveSmallIncreases = 0;\n }\n } else {\n // Height decreased - reset counter\n this.consecutiveSmallIncreases = 0;\n }\n\n this.isUpdating = true;\n this.lastHeight = height;\n\n try {\n await this.resizeCallback(height);\n } catch (error) {\n console.error('[AutoResize] Failed to update content size:', error);\n } finally {\n this.isUpdating = false;\n }\n }\n };\n\n const debouncedSendHeight = () => {\n clearTimeout(this.resizeTimeout);\n this.resizeTimeout = setTimeout(sendHeight, 100);\n };\n\n this.resizeObserver = new ResizeObserver(debouncedSendHeight);\n this.resizeObserver.observe(document.body);\n\n // Send initial height\n sendHeight();\n }\n\n disable(): void {\n this.resizeObserver?.disconnect();\n clearTimeout(this.resizeTimeout);\n this.isUpdating = false;\n this.consecutiveSmallIncreases = 0;\n }\n}\n","import { initBridge, sendRequest } from '../bridge/bridge';\nimport type { ContentSizeUpdateRequest } from './types/ContentSizeUpdateRequest';\nimport { AutoResizeManager } from './utils/autoResize';\n\nexport interface HostInitOptions {\n /**\n * Автоматически изменять размер контейнера плагина\n * при изменении содержимого\n * @default true\n */\n autoResize?: boolean;\n}\n\n/**\n * Untyped runtime класс HostApi. Methods, которые возвращают значения,\n * зависящие от SlotContextMap, типизированы как `unknown` или `string`.\n * Type-safety добавляется в публикуемых пакетах через typed wrapper.\n */\nexport type ContextLevel = 'basic' | 'full';\n\nexport type BasicContext = {\n entityId: string;\n entityMeta?: Record<string, string>;\n};\n\nexport class HostApi {\n private autoResizeManager?: AutoResizeManager;\n private slot: string | null = null;\n private service: string | null = null;\n private origin: string | null = null;\n private innerUrl: string | null = null;\n private queryParams: Record<string, string> | null = null;\n private entityId: string | null = null;\n private entityMeta: Record<string, string> | undefined = undefined;\n private contextLevel: ContextLevel = 'full';\n\n getTheme(): Promise<unknown> {\n return sendRequest('theme.get');\n }\n\n getLanguage(): Promise<unknown> {\n return sendRequest('language.get');\n }\n\n getUserId(): Promise<unknown> {\n return sendRequest('userId.get');\n }\n\n getIsYateam(): Promise<unknown> {\n return sendRequest('isYateam.get');\n }\n\n getContext(): Promise<unknown> {\n return sendRequest('context.get');\n }\n\n updateContentSize(payload: ContentSizeUpdateRequest): Promise<unknown> {\n return sendRequest('contentSize.update', payload);\n }\n\n notifyReady(): Promise<unknown> {\n return sendRequest('plugin.ready');\n }\n\n close(payload: unknown): Promise<unknown> {\n return sendRequest('plugin.close', payload);\n }\n\n init(options: HostInitOptions): void {\n const { autoResize = true } = options;\n\n const searchParams = new URLSearchParams(location.search);\n this.service = searchParams.get('service');\n if (this.service === null) {\n throw new Error(\n 'Missing required URL parameter \"service\". A plugin cannot run outside the host application context. ' +\n 'Open the plugin from the host application.',\n );\n }\n const slot = searchParams.get('slot');\n if (!slot) {\n throw new Error('Slot is not defined');\n }\n const targetOrigin = searchParams.get('parentOrigin');\n if (!targetOrigin) {\n throw new Error('Target origin is not defined');\n }\n const pluginId = searchParams.get('id');\n if (!pluginId) {\n throw new Error('Plugin id is not defined');\n }\n const elementId = searchParams.get('elementId');\n if (!elementId) {\n throw new Error('Element id is not defined');\n }\n const entityId = searchParams.get('entityId');\n const entityMetaRaw = searchParams.get('entityMeta');\n const entityMeta = entityMetaRaw\n ? (JSON.parse(entityMetaRaw) as Record<string, string>)\n : undefined;\n initBridge(pluginId, elementId, slot, entityId, targetOrigin, entityMeta);\n\n this.slot = slot;\n this.origin = targetOrigin;\n this.entityId = entityId;\n this.entityMeta = entityMeta;\n\n const contextLevelParam = searchParams.get('contextLevel');\n this.contextLevel = contextLevelParam === 'basic' ? 'basic' : 'full';\n\n this.innerUrl = searchParams.get('innerUrl') ?? '';\n const queryParamsRaw = searchParams.get('queryParams');\n this.queryParams = queryParamsRaw ? JSON.parse(decodeURIComponent(queryParamsRaw)) : {};\n\n if (autoResize) {\n this.autoResizeManager = new AutoResizeManager(\n (height) => this.updateContentSize({ height }) as unknown as Promise<void>,\n );\n this.autoResizeManager.enable();\n }\n }\n\n getSlot(): string {\n if (this.slot === null) {\n throw new Error('Plugin not initialized. Call init() first.');\n }\n return this.slot;\n }\n\n getService(): string {\n if (this.service === null) {\n throw new Error('Service not initialized. Call init() first.');\n }\n return this.service;\n }\n\n getOrigin(): string {\n if (this.origin === null) {\n throw new Error('Origin not initialized. Call init() first.');\n }\n return this.origin;\n }\n\n getInnerUrl(): string {\n if (this.innerUrl === null) {\n throw new Error('Plugin not initialized. Call init() first.');\n }\n return this.innerUrl;\n }\n\n getQueryParams(): Record<string, string> {\n if (this.queryParams === null) {\n throw new Error('Plugin not initialized. Call init() first.');\n }\n return this.queryParams;\n }\n\n getEntityId(): string | null {\n return this.entityId;\n }\n\n getEntityMeta(): Record<string, string> | undefined {\n return this.entityMeta;\n }\n\n getContextLevel(): ContextLevel {\n return this.contextLevel;\n }\n\n disableAutoResize(): void {\n this.autoResizeManager?.disable();\n }\n}\n\nexport const hostApi = new HostApi();\n"],"names":["subscribers","lastValues","on","method","callback","set","cb","err","dispatchHostEvent","message","resetEventBus","eventBus","handlers","setHandler","name","handler","getHandler","PLUGIN_ID_OR_SLOT_NOT_PROVIDED","PLUGIN_ID_IS_NOT_CORRECT","VALIDATION_ERROR","METHOD_NOT_SUPPORTED","MISSING_REQUIRED_SCOPE","UNKNOWN_ERROR","PluginActionError","code","errorData","PluginBridge","pluginId","elementId","slot","entityId","targetOrigin","entityMeta","payload","options","resolve","reject","messageId","timeoutMs","requestMessage","timeoutId","e","pending","event","typedMessage","data","errorCode","response","bridgeInstance","initBridge","getBridge","sendRequest","CONFIRM_TIMEOUT_MS","Confirm","Toaster","actionIds","serializedActions","action","actionId","result","autoHiding","id","UiApi","uiApi","getField","obj","path","defaultValue","keys","key","getLocalizedString","value","language","fallbackLanguage","lang","fallback","AutoResizeManager","resizeCallback","sendHeight","root","bodyStyles","marginTop","marginBottom","height","error","debouncedSendHeight","HostApi","autoResize","searchParams","entityMetaRaw","contextLevelParam","queryParamsRaw","hostApi"],"mappings":"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"}
1
+ {"version":3,"file":"index.mjs","sources":["../src/events/eventBus.ts","../src/handlers/handlers.ts","../src/bridge/types/ErrorCodes.ts","../src/bridge/types/PluginActionError.ts","../src/bridge/bridge.ts","../src/ui/Confirm.ts","../src/ui/Toaster.ts","../src/ui/uiApi.ts","../src/utils/getField.ts","../src/utils/localization.ts","../src/host/utils/autoResize.ts","../src/host/hostApi.ts"],"sourcesContent":["import type {\n EventMessage,\n HostEventCallback,\n HostEventContract,\n HostEventMethod,\n Unsubscribe,\n} from './types';\n\nconst subscribers = new Map<HostEventMethod, Set<(result: unknown) => void>>();\nconst lastValues = new Map<HostEventMethod, unknown>();\n\n/**\n * Subscribe to a host-pushed event.\n * If a value was already dispatched for this method, the callback is called\n * synchronously with the cached value before returning.\n * @param method - Event method name (e.g. `'theme.changed'`)\n * @param callback - Function called with the typed event payload\n * @returns An `Unsubscribe` function that removes this subscription\n */\nexport function on<M extends HostEventMethod>(\n method: M,\n callback: HostEventCallback<M>,\n): Unsubscribe {\n let set = subscribers.get(method);\n if (!set) {\n set = new Set();\n subscribers.set(method, set);\n }\n\n const cb = callback as (result: unknown) => void;\n set.add(cb);\n\n // Replay last known value to the new subscriber immediately\n if (lastValues.has(method)) {\n try {\n // eslint-disable-next-line callback-return -- sync replay to new subscriber; return value unused\n cb(lastValues.get(method));\n } catch (err) {\n console.error(`[EventBus] Error replaying cached value for \"${method}\":`, err);\n }\n }\n\n return () => {\n set.delete(cb);\n if (set.size === 0) {\n subscribers.delete(method);\n }\n };\n}\n\n/**\n * Dispatch an incoming event message to all registered subscribers.\n * Caches the value so late subscribers receive it on subscription.\n */\nexport function dispatchHostEvent(message: EventMessage): void {\n const method = message.method as HostEventMethod;\n lastValues.set(method, message.result);\n\n const set = subscribers.get(method);\n if (!set) {\n return;\n }\n for (const cb of set) {\n try {\n // eslint-disable-next-line callback-return -- notify subscribers; return value unused\n cb(message.result);\n } catch (err) {\n console.error(`[EventBus] Error in subscriber for \"${message.method}\":`, err);\n }\n }\n}\n\n/**\n * Clears all cached last values and subscribers from the event bus.\n * Intended for use in tests to prevent state leaking between test cases.\n */\nexport function resetEventBus(): void {\n lastValues.clear();\n subscribers.clear();\n}\n\n/**\n * Public event emitter — subscribe to host-pushed events.\n * Only events defined in `HostEventContract` are accepted.\n * @example\n * ```ts\n * import { eventBus } from '@yandex-data-ui/tracker-plugin-sdk-core';\n *\n * const unsubscribe = eventBus.on('theme.changed', (theme) => {\n * console.log('Theme:', theme);\n * });\n *\n * unsubscribe();\n * ```\n */\nexport const eventBus = {\n on<M extends HostEventMethod>(\n method: M,\n callback: (result: HostEventContract[M]['result']) => void,\n ): Unsubscribe {\n return on(method, callback);\n },\n};\n","type AnyHandler = (...args: unknown[]) => unknown;\n\nconst handlers: Record<string, AnyHandler> = {};\n\n/**\n * Регистрирует handler по имени. Тип не проверяется на runtime'е;\n * type-safety обеспечивается typed wrapper'ом в публикуемых пакетах.\n */\nexport function setHandler(name: string, handler: AnyHandler): void {\n handlers[name] = handler;\n}\n\n/**\n * Возвращает зарегистрированный handler по имени, или undefined.\n */\nexport function getHandler(name: string): AnyHandler | undefined {\n return handlers[name];\n}\n","/** Код ошибки: не переданы обязательные параметры инициализации плагина (pluginId или slot). */\nexport const PLUGIN_ID_OR_SLOT_NOT_PROVIDED = 1000;\n\n/** Код ошибки: переданный pluginId не совпадает с зарегистрированным плагином или неверного формата. */\nexport const PLUGIN_ID_IS_NOT_CORRECT = 1001;\n\n/** Код ошибки: данные запроса не прошли валидацию (неверный формат, обязательные поля отсутствуют и т.п.). */\nexport const VALIDATION_ERROR = 1002;\n\n/** Код ошибки: запрошенный метод API не поддерживается в данной конфигурации или версии. */\nexport const METHOD_NOT_SUPPORTED = 1003;\n\n/** Код ошибки: у плагина нет необходимого scope (разрешения) для выполнения операции. */\nexport const MISSING_REQUIRED_SCOPE = 1004;\n\n/** Код ошибки: непредвиденная или неклассифицированная ошибка. */\nexport const UNKNOWN_ERROR = 6666;\n\n/** Storage record version does not match the current one. */\nexport const VERSION_CONFLICT = 1010;\n\n/** Data size exceeds 256 KiB after the operation. */\nexport const DATA_TOO_LARGE = 1011;\n\n/** bucket failed validation (format or length). */\nexport const BAD_KEY = 1012;\n","export class PluginActionError extends Error {\n readonly code: number;\n\n readonly errorData?: unknown;\n\n constructor(code: number, message: string, errorData?: unknown) {\n super(message);\n this.name = 'PluginActionError';\n this.code = code;\n this.errorData = errorData;\n }\n}\n","import { dispatchHostEvent } from '../events/eventBus';\nimport type { EventMessage } from '../events/types';\nimport { getHandler } from '../handlers/handlers';\nimport { UNKNOWN_ERROR } from './types/ErrorCodes';\nimport type { BaseMessage } from './types/BaseMessage';\nimport { PluginActionError } from './types/PluginActionError';\n\ntype RequestOptions = { timeout?: number };\n\ntype PendingRequest = {\n resolve: (value: unknown) => void;\n reject: (error: Error) => void;\n timeoutId: ReturnType<typeof setTimeout>;\n};\n\ntype RawRequestMessage = BaseMessage & {\n method: string;\n payload: unknown;\n};\n\ntype RawResponseMessage = BaseMessage & {\n type: 'response';\n result: unknown;\n error?: string;\n errorCode?: number;\n errorData?: unknown;\n};\n\ntype RawIncomingRequestMessage = BaseMessage & {\n type: 'request';\n result: { method: string; payload: unknown };\n error?: string;\n};\n\nclass PluginBridge {\n private pluginId: string;\n private elementId: string;\n private targetOrigin: string;\n private slot: string;\n private entityId: string | null;\n private entityMeta: Record<string, string> | undefined;\n private pendingRequests: Map<string, PendingRequest> = new Map();\n private messageListener: ((event: MessageEvent) => void) | null = null;\n private readonly requestTimeout = 10000;\n\n constructor(\n pluginId: string,\n elementId: string,\n slot: string,\n entityId: string | null,\n targetOrigin: string,\n entityMeta?: Record<string, string>,\n ) {\n this.pluginId = pluginId;\n this.elementId = elementId;\n this.targetOrigin = targetOrigin;\n this.entityId = entityId;\n this.entityMeta = entityMeta;\n this.slot = slot;\n this.initListener();\n }\n\n request(method: string, payload?: unknown, options?: RequestOptions): Promise<unknown> {\n return new Promise((resolve, reject) => {\n const messageId = this.generateMessageId();\n const timeoutMs = options?.timeout ?? this.requestTimeout;\n\n const requestMessage: RawRequestMessage = {\n messageId,\n method,\n payload,\n };\n\n const timeoutId = setTimeout(() => {\n const pending = this.pendingRequests.get(messageId);\n if (pending) {\n this.pendingRequests.delete(messageId);\n reject(new Error(`Request timeout: ${method} exceeded ${timeoutMs}ms`));\n }\n }, timeoutMs);\n\n this.pendingRequests.set(messageId, { resolve, reject, timeoutId });\n\n try {\n this.send(requestMessage);\n } catch (e) {\n clearTimeout(timeoutId);\n this.pendingRequests.delete(messageId);\n reject(e as Error);\n }\n });\n }\n\n send<T = unknown>(message: T): void {\n window.parent.postMessage(\n {\n pluginId: this.pluginId,\n elementId: this.elementId,\n slot: this.slot,\n entityId: this.entityId,\n entityMeta: this.entityMeta,\n ...message,\n },\n this.targetOrigin,\n );\n }\n\n destroy(): void {\n if (this.messageListener) {\n window.removeEventListener('message', this.messageListener);\n this.messageListener = null;\n }\n\n this.pendingRequests.forEach((pending) => {\n clearTimeout(pending.timeoutId);\n });\n this.pendingRequests.clear();\n }\n\n private initListener(): void {\n this.messageListener = async (event: MessageEvent) => {\n if (event.origin !== this.targetOrigin) {\n console.info(\n '[Bridge] Ignored message from origin:',\n event.origin,\n '(expected:',\n this.targetOrigin,\n ')',\n );\n return;\n }\n\n const message = event.data;\n console.info('[Bridge] Received message:', message);\n\n if (message.type === 'event') {\n console.info('[Bridge] Dispatching host event:', message.method, message.result);\n dispatchHostEvent(message as EventMessage);\n return;\n }\n\n console.info('[Bridge] Received message:', event.data);\n\n if (!message.messageId) {\n console.info('[Bridge] Ignored message without messageId:', message);\n return;\n }\n\n const typedMessage = message as RawResponseMessage | RawIncomingRequestMessage;\n const pending = this.pendingRequests.get(typedMessage.messageId);\n\n if (!pending) {\n if (typedMessage.type === 'request') {\n const incoming = typedMessage as RawIncomingRequestMessage;\n const method = incoming.result.method;\n const handler = getHandler(method);\n\n if (!handler) {\n this.send({\n messageId: typedMessage.messageId,\n type: 'response',\n result: null,\n errorCode: UNKNOWN_ERROR,\n error: `No handler for method ${method}`,\n });\n return;\n }\n\n try {\n const data = handler();\n this.send({\n messageId: typedMessage.messageId,\n payload: data,\n method: 'responseData',\n type: 'response',\n });\n } catch (e) {\n const err = e instanceof Error ? e : new Error(String(e));\n const errorCode =\n err instanceof PluginActionError ? err.code : UNKNOWN_ERROR;\n this.send({\n messageId: typedMessage.messageId,\n type: 'response',\n result: null,\n errorCode,\n error: err.message,\n });\n }\n }\n\n return;\n }\n\n clearTimeout(pending.timeoutId);\n this.pendingRequests.delete(typedMessage.messageId);\n\n const response = typedMessage as RawResponseMessage;\n if (response.type === 'response' && response.errorCode) {\n pending.reject(\n new PluginActionError(\n response.errorCode,\n response.error ?? 'Unknown error',\n response.errorData,\n ),\n );\n } else {\n pending.resolve(response.result);\n }\n };\n\n window.addEventListener('message', this.messageListener);\n }\n\n private generateMessageId(): string {\n return crypto.randomUUID();\n }\n}\n\nlet bridgeInstance: PluginBridge | null = null;\n\nexport function initBridge(\n pluginId: string,\n elementId: string,\n slot: string,\n entityId: string | null,\n targetOrigin: string,\n entityMeta?: Record<string, string>,\n): PluginBridge {\n if (bridgeInstance) {\n bridgeInstance.destroy();\n }\n bridgeInstance = new PluginBridge(\n pluginId,\n elementId,\n slot,\n entityId,\n targetOrigin,\n entityMeta,\n );\n return bridgeInstance;\n}\n\nfunction getBridge(): PluginBridge {\n if (!bridgeInstance) {\n throw new Error('Bridge not initialized. Call initBridge first.');\n }\n return bridgeInstance;\n}\n\nexport function sendRequest(\n method: string,\n payload?: unknown,\n options?: RequestOptions,\n): Promise<unknown> {\n return getBridge().request(method, payload, options);\n}\n","import { sendRequest } from '../bridge/bridge';\n\nexport type ConfirmOptions = {\n title?: string;\n message: string;\n textButtonApply?: string;\n textButtonCancel?: string;\n theme?: 'normal' | 'danger';\n};\n\nexport type ConfirmResult = { confirmed: boolean };\n\nconst CONFIRM_TIMEOUT_MS = 300_000;\n\nexport class Confirm {\n show(options: ConfirmOptions): Promise<ConfirmResult> {\n return sendRequest('confirm.show', options, {\n timeout: CONFIRM_TIMEOUT_MS,\n }) as Promise<ConfirmResult>;\n }\n}\n","import { sendRequest } from '../bridge/bridge';\nimport { on } from '../events/eventBus';\n\nexport type ToastAction = {\n label: string;\n onClick: () => void;\n};\n\nexport type ToastOptions = {\n name?: string;\n title: string;\n content?: string;\n theme?: 'success' | 'danger' | 'warning' | 'info';\n autoHiding?: number;\n isClosable?: boolean;\n actions?: ToastAction[];\n};\n\nexport class Toaster {\n private callbackMap = new Map<string, () => void>();\n private toastActionIds = new Map<string, string[]>();\n private eventSubscribed = false;\n\n async add(options: ToastOptions): Promise<{ name: string }> {\n this.ensureEventSubscription();\n\n const actionIds: string[] = [];\n const serializedActions = options.actions?.map((action) => {\n const actionId = crypto.randomUUID();\n\n this.callbackMap.set(actionId, action.onClick);\n actionIds.push(actionId);\n\n return { id: actionId, label: action.label };\n });\n\n const result = (await sendRequest('toast.add', {\n name: options.name,\n title: options.title,\n content: options.content,\n theme: options.theme,\n autoHiding: options.autoHiding,\n isClosable: options.isClosable,\n actions: serializedActions,\n })) as { name: string };\n\n if (actionIds.length > 0) {\n this.toastActionIds.set(result.name, actionIds);\n }\n\n const autoHiding = options.autoHiding ?? 5000;\n\n setTimeout(() => this.cleanupCallbacksForToast(result.name), autoHiding + 1000);\n\n return result;\n }\n\n private ensureEventSubscription() {\n if (this.eventSubscribed) return;\n this.eventSubscribed = true;\n\n on('toast.action.clicked', ({ name, actionId }) => {\n const callback = this.callbackMap.get(actionId);\n\n // eslint-disable-next-line callback-return -- optional void callback for side effects\n callback?.();\n this.cleanupCallbacksForToast(name);\n });\n }\n\n private cleanupCallbacksForToast(name: string) {\n const actionIds = this.toastActionIds.get(name);\n\n if (actionIds) {\n for (const id of actionIds) {\n this.callbackMap.delete(id);\n }\n this.toastActionIds.delete(name);\n }\n }\n}\n","import { sendRequest } from '../bridge/bridge';\nimport type { NavigateRequest } from '../host/types/NavigateRequest';\nimport { Confirm } from './Confirm';\nimport { Toaster } from './Toaster';\n\nclass UiApi {\n readonly toaster = new Toaster();\n readonly confirm = new Confirm();\n\n navigate(payload: NavigateRequest): Promise<unknown> {\n return sendRequest('navigate', payload);\n }\n}\n\nexport const uiApi = new UiApi();\n","/**\n * Извлекает значение из объекта по точечному пути (dot notation).\n * Предназначена для работы с полями типа Record<string, unknown>, например со значениями полей задачи (Issue).\n *\n * Поддерживает вложенные пути: `'priority.display'`, `'assignee.display.ru'` и т.д.\n * Если любой сегмент пути отсутствует или не является объектом — возвращается defaultValue или undefined.\n * @param obj - Объект с произвольной структурой (например, issue или issue.values)\n * @param path - Путь к полю через точку, например `'priority.display'` или `'summary'`\n * @param defaultValue - Значение по умолчанию, если путь не найден\n * @returns Значение по пути, defaultValue или undefined\n * @example\n * ```ts\n * // Поле верхнего уровня\n * getField(issue, 'key'); // 'QUEUE-123'\n *\n * // Вложенное поле (например, приоритет с display)\n * getField(issue, 'priority.display'); // 'много' | undefined\n *\n * // С типизацией и значением по умолчанию\n * const name = getField<string>(issue, 'summary', 'Без названия');\n *\n * // Элемент массива по индексу (массивы — объекты с числовыми ключами)\n * getField(tags, '0'); // первый элемент\n * ```\n */\nexport function getField<T = unknown>(\n obj: Record<string, unknown>,\n path: string,\n defaultValue?: T,\n): T | undefined {\n if (path === '') {\n return defaultValue;\n }\n\n const keys = path.split('.');\n let result: unknown = obj;\n\n for (const key of keys) {\n if (\n result !== null &&\n typeof result === 'object' &&\n Object.prototype.hasOwnProperty.call(result, key)\n ) {\n result = (result as Record<string, unknown>)[key];\n } else {\n return defaultValue;\n }\n }\n\n return (result as T | undefined) ?? defaultValue;\n}\n","/**\n * Структурный shape `LocalizedString` — общая база, к которой структурно\n * совместимы api-types `LocalizedString` обоих flavors. Реальная функция\n * `getLocalizedString` читает только ключи `ru` и `en`, поэтому более\n * узкие api-types-варианты (с дополнительными ключами) совместимы.\n */\nexport type LocalizedString = string | { ru?: string; en?: string };\n\n/**\n * Получить локализованную строку на основе языка\n * @param value - Локализованная строка\n * @param language - Код языка ('ru' или 'en')\n * @param fallbackLanguage - Резервный язык (по умолчанию 'ru')\n */\nexport function getLocalizedString(\n value: LocalizedString,\n language: string | undefined,\n fallbackLanguage = 'ru',\n): string {\n if (typeof value === 'string') {\n return value;\n }\n\n const lang = (language ?? fallbackLanguage).toLowerCase() as 'ru' | 'en';\n const fallback = fallbackLanguage.toLowerCase() as 'ru' | 'en';\n\n return value[lang] || value[fallback] || value.ru || value.en || '';\n}\n","export type ResizeCallback = (height: number) => Promise<void> | void;\n\nexport class AutoResizeManager {\n private resizeCallback: ResizeCallback;\n private resizeObserver?: ResizeObserver;\n private resizeTimeout?: ReturnType<typeof setTimeout>;\n private lastHeight = 0;\n private isUpdating = false;\n private consecutiveSmallIncreases = 0;\n private readonly MAX_CONSECUTIVE_SMALL_INCREASES = 5;\n private readonly SMALL_INCREASE_THRESHOLD_PX = 10;\n\n constructor(resizeCallback: ResizeCallback) {\n this.resizeCallback = resizeCallback;\n }\n\n enable(): void {\n if (!document.body) {\n console.error('[AutoResize] document.body does not exist yet');\n return;\n }\n\n const sendHeight = async () => {\n if (this.isUpdating) {\n return;\n }\n\n // Use body.scrollHeight as primary source in iframe\n // documentElement.scrollHeight can cache old values\n const root = document.getElementById('root');\n const bodyStyles = window.getComputedStyle(document.body);\n const marginTop = parseInt(bodyStyles.marginTop, 10) || 0;\n const marginBottom = parseInt(bodyStyles.marginBottom, 10) || 0;\n\n const measuredHeight = Math.max(\n document.body.scrollHeight,\n document.body.offsetHeight,\n root ? root.scrollHeight + marginTop + marginBottom : 0,\n );\n\n // Add small buffer to compensate for rounding errors\n const height = measuredHeight + 4;\n\n if (height !== this.lastHeight) {\n // Detect infinite loop: if height keeps increasing by small amounts\n // This prevents issues with elements using viewport units (vh, %)\n if (height > this.lastHeight) {\n const increase = height - this.lastHeight;\n\n // Only count small increases as potential loop indicators\n // Large increases are normal (user adding content)\n if (increase <= this.SMALL_INCREASE_THRESHOLD_PX) {\n this.consecutiveSmallIncreases++;\n\n if (this.consecutiveSmallIncreases > this.MAX_CONSECUTIVE_SMALL_INCREASES) {\n console.warn(\n '[AutoResize] Infinite loop detected. Stopping auto-resize. ' +\n 'This may be caused by elements with viewport-relative units (vh, %).',\n );\n this.disable();\n return;\n }\n } else {\n // Large increase - reset counter (normal content addition)\n this.consecutiveSmallIncreases = 0;\n }\n } else {\n // Height decreased - reset counter\n this.consecutiveSmallIncreases = 0;\n }\n\n this.isUpdating = true;\n this.lastHeight = height;\n\n try {\n await this.resizeCallback(height);\n } catch (error) {\n console.error('[AutoResize] Failed to update content size:', error);\n } finally {\n this.isUpdating = false;\n }\n }\n };\n\n const debouncedSendHeight = () => {\n clearTimeout(this.resizeTimeout);\n this.resizeTimeout = setTimeout(sendHeight, 100);\n };\n\n this.resizeObserver = new ResizeObserver(debouncedSendHeight);\n this.resizeObserver.observe(document.body);\n\n // Send initial height\n sendHeight();\n }\n\n disable(): void {\n this.resizeObserver?.disconnect();\n clearTimeout(this.resizeTimeout);\n this.isUpdating = false;\n this.consecutiveSmallIncreases = 0;\n }\n}\n","import { initBridge, sendRequest } from '../bridge/bridge';\nimport type { ContentSizeUpdateRequest } from './types/ContentSizeUpdateRequest';\nimport { AutoResizeManager } from './utils/autoResize';\n\nexport interface HostInitOptions {\n /**\n * Автоматически изменять размер контейнера плагина\n * при изменении содержимого\n * @default true\n */\n autoResize?: boolean;\n}\n\n/**\n * Untyped runtime класс HostApi. Methods, которые возвращают значения,\n * зависящие от SlotContextMap, типизированы как `unknown` или `string`.\n * Type-safety добавляется в публикуемых пакетах через typed wrapper.\n */\nexport type ContextLevel = 'basic' | 'full';\n\nexport type BasicContext = {\n entityId: string;\n entityMeta?: Record<string, string>;\n};\n\nexport class HostApi {\n private autoResizeManager?: AutoResizeManager;\n private slot: string | null = null;\n private service: string | null = null;\n private origin: string | null = null;\n private innerUrl: string | null = null;\n private queryParams: Record<string, string> | null = null;\n private entityId: string | null = null;\n private entityMeta: Record<string, string> | undefined = undefined;\n private contextLevel: ContextLevel = 'full';\n\n getTheme(): Promise<unknown> {\n return sendRequest('theme.get');\n }\n\n getLanguage(): Promise<unknown> {\n return sendRequest('language.get');\n }\n\n getUserId(): Promise<unknown> {\n return sendRequest('userId.get');\n }\n\n getIsYateam(): Promise<unknown> {\n return sendRequest('isYateam.get');\n }\n\n getContext(): Promise<unknown> {\n return sendRequest('context.get');\n }\n\n updateContentSize(payload: ContentSizeUpdateRequest): Promise<unknown> {\n return sendRequest('contentSize.update', payload);\n }\n\n notifyReady(): Promise<unknown> {\n return sendRequest('plugin.ready');\n }\n\n close(payload: unknown): Promise<unknown> {\n return sendRequest('plugin.close', payload);\n }\n\n init(options: HostInitOptions): void {\n const { autoResize = true } = options;\n\n const searchParams = new URLSearchParams(location.search);\n this.service = searchParams.get('service');\n if (this.service === null) {\n throw new Error(\n 'Missing required URL parameter \"service\". A plugin cannot run outside the host application context. ' +\n 'Open the plugin from the host application.',\n );\n }\n const slot = searchParams.get('slot');\n if (!slot) {\n throw new Error('Slot is not defined');\n }\n const targetOrigin = searchParams.get('parentOrigin');\n if (!targetOrigin) {\n throw new Error('Target origin is not defined');\n }\n const pluginId = searchParams.get('id');\n if (!pluginId) {\n throw new Error('Plugin id is not defined');\n }\n const elementId = searchParams.get('elementId');\n if (!elementId) {\n throw new Error('Element id is not defined');\n }\n const entityId = searchParams.get('entityId');\n const entityMetaRaw = searchParams.get('entityMeta');\n const entityMeta = entityMetaRaw\n ? (JSON.parse(entityMetaRaw) as Record<string, string>)\n : undefined;\n initBridge(pluginId, elementId, slot, entityId, targetOrigin, entityMeta);\n\n this.slot = slot;\n this.origin = targetOrigin;\n this.entityId = entityId;\n this.entityMeta = entityMeta;\n\n const contextLevelParam = searchParams.get('contextLevel');\n this.contextLevel = contextLevelParam === 'basic' ? 'basic' : 'full';\n\n this.innerUrl = searchParams.get('innerUrl') ?? '';\n const queryParamsRaw = searchParams.get('queryParams');\n this.queryParams = queryParamsRaw ? JSON.parse(decodeURIComponent(queryParamsRaw)) : {};\n\n if (autoResize) {\n this.autoResizeManager = new AutoResizeManager(\n (height) => this.updateContentSize({ height }) as unknown as Promise<void>,\n );\n this.autoResizeManager.enable();\n }\n }\n\n getSlot(): string {\n if (this.slot === null) {\n throw new Error('Plugin not initialized. Call init() first.');\n }\n return this.slot;\n }\n\n getService(): string {\n if (this.service === null) {\n throw new Error('Service not initialized. Call init() first.');\n }\n return this.service;\n }\n\n getOrigin(): string {\n if (this.origin === null) {\n throw new Error('Origin not initialized. Call init() first.');\n }\n return this.origin;\n }\n\n getInnerUrl(): string {\n if (this.innerUrl === null) {\n throw new Error('Plugin not initialized. Call init() first.');\n }\n return this.innerUrl;\n }\n\n getQueryParams(): Record<string, string> {\n if (this.queryParams === null) {\n throw new Error('Plugin not initialized. Call init() first.');\n }\n return this.queryParams;\n }\n\n getEntityId(): string | null {\n return this.entityId;\n }\n\n getEntityMeta(): Record<string, string> | undefined {\n return this.entityMeta;\n }\n\n getContextLevel(): ContextLevel {\n return this.contextLevel;\n }\n\n disableAutoResize(): void {\n this.autoResizeManager?.disable();\n }\n}\n\nexport const hostApi = new HostApi();\n"],"names":["subscribers","lastValues","on","method","callback","set","cb","err","dispatchHostEvent","message","resetEventBus","eventBus","handlers","setHandler","name","handler","getHandler","PLUGIN_ID_OR_SLOT_NOT_PROVIDED","PLUGIN_ID_IS_NOT_CORRECT","VALIDATION_ERROR","METHOD_NOT_SUPPORTED","MISSING_REQUIRED_SCOPE","UNKNOWN_ERROR","VERSION_CONFLICT","DATA_TOO_LARGE","BAD_KEY","PluginActionError","code","errorData","PluginBridge","pluginId","elementId","slot","entityId","targetOrigin","entityMeta","payload","options","resolve","reject","messageId","timeoutMs","requestMessage","timeoutId","e","pending","event","typedMessage","data","errorCode","response","bridgeInstance","initBridge","getBridge","sendRequest","CONFIRM_TIMEOUT_MS","Confirm","Toaster","actionIds","serializedActions","action","actionId","result","autoHiding","id","UiApi","uiApi","getField","obj","path","defaultValue","keys","key","getLocalizedString","value","language","fallbackLanguage","lang","fallback","AutoResizeManager","resizeCallback","sendHeight","root","bodyStyles","marginTop","marginBottom","height","error","debouncedSendHeight","HostApi","autoResize","searchParams","entityMetaRaw","contextLevelParam","queryParamsRaw","hostApi"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@weavix/sdk-core",
3
- "version": "0.0.2",
3
+ "version": "0.0.3",
4
4
  "exports": {
5
5
  ".": {
6
6
  "types": "./dist/index.d.ts",