@weavix/sdk-core 0.0.1

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.
package/README.md ADDED
@@ -0,0 +1,49 @@
1
+ # @weavix/sdk-core
2
+
3
+ Core package for the Tracker Plugin SDK — Weavix flavor.
4
+
5
+ > Это external-публикация. Внутренний (Yandex) аналог: `@yandex-data-ui/tracker-plugin-sdk-core`.
6
+
7
+ ## Установка
8
+
9
+ ```bash
10
+ npm install @weavix/sdk-core @weavix/tracker-api-types
11
+ # или
12
+ pnpm add @weavix/sdk-core @weavix/tracker-api-types
13
+ ```
14
+
15
+ `@weavix/tracker-api-types` — peerDep с типами OpenAPI-эндпоинтов Tracker'а. Укажите версию, совместимую со своим API.
16
+
17
+ ## Что внутри
18
+
19
+ `@weavix/sdk-core` экспортирует:
20
+
21
+ - `trackerApi` — типизированный proxy для вызовов Tracker REST API v3.
22
+ - `hostApi` — методы взаимодействия с хост-приложением (theme, language, context, navigation, content size).
23
+ - `setHandler`/`getHandler` — регистрация плагин-обработчиков для запросов от хоста.
24
+ - `dispatchHostEvent`/`on`/`resetEventBus` — событийная шина для push-событий хоста.
25
+ - `uiApi` — Toaster и Confirm.
26
+ - `getField` — утилита для безопасного чтения вложенных полей.
27
+ - `getLocalizedString` — извлечение локализованной строки.
28
+ - Коды ошибок: `METHOD_NOT_SUPPORTED`, `MISSING_REQUIRED_SCOPE`, `PLUGIN_ID_*`, `UNKNOWN_ERROR`, `VALIDATION_ERROR`.
29
+ - `PluginActionError`.
30
+
31
+ API surface полностью идентичен internal flavor'у; различается только источник api-types-типов.
32
+
33
+ ## Пример
34
+
35
+ ```ts
36
+ import { hostApi, trackerApi } from '@weavix/sdk-core';
37
+
38
+ await hostApi.notifyReady();
39
+
40
+ const { data } = await trackerApi.v3.get['/issues/{id}']({
41
+ pathParams: { id: 'KEY-1' },
42
+ });
43
+
44
+ console.log(data.summary);
45
+ ```
46
+
47
+ ## License
48
+
49
+ UNLICENSED.
@@ -0,0 +1,518 @@
1
+ import { ApiV3DeleteMethods } from '@weavix/tracker-api-types';
2
+ import { ApiV3GetMethods } from '@weavix/tracker-api-types';
3
+ import { ApiV3PatchMethods } from '@weavix/tracker-api-types';
4
+ import { ApiV3PostMethods } from '@weavix/tracker-api-types';
5
+ import { ApiV3PutMethods } from '@weavix/tracker-api-types';
6
+ import { Attachment } from '@weavix/tracker-api-types';
7
+ import { Issue } from '@weavix/tracker-api-types';
8
+ import { LocalizedString } from '@weavix/tracker-api-types';
9
+ import { MetaEntityV2 } from '@weavix/tracker-api-types';
10
+ import { WebhookTriggerActionInput } from '@weavix/tracker-api-types';
11
+
12
+ export declare type ApiCallPayload = {
13
+ version: string;
14
+ method: string;
15
+ url: string;
16
+ pathParams: Record<string, string>;
17
+ queryParams: Record<string, unknown>;
18
+ bodyParams: Record<string, unknown>;
19
+ file?: File;
20
+ };
21
+
22
+ export declare type ApiCallResult = {
23
+ data: unknown;
24
+ headers: Record<string, string>;
25
+ };
26
+
27
+ declare type ApiResult<M> = {
28
+ [K in keyof M]: M[K] extends (...args: infer A) => Promise<infer R> ? (...args: A) => Promise<{
29
+ data: R;
30
+ headers: Record<string, string>;
31
+ }> : never;
32
+ };
33
+
34
+ declare type AttachmentViewerActionClosePayload = {
35
+ attachments: Attachment[];
36
+ };
37
+
38
+ declare type AttachmentViewerActionSlotContext = {
39
+ attachmentBlob: Blob;
40
+ meta: {
41
+ id: string;
42
+ url: string;
43
+ date: string;
44
+ size: number;
45
+ mimetype: string;
46
+ };
47
+ };
48
+
49
+ export declare type ConfirmOptions = {
50
+ title?: string;
51
+ message: string;
52
+ textButtonApply?: string;
53
+ textButtonCancel?: string;
54
+ theme?: 'normal' | 'danger';
55
+ };
56
+
57
+ export declare type ConfirmResult = { confirmed: boolean };
58
+
59
+ export declare type ContentSizeUpdateRequest = {
60
+ height?: number;
61
+ width?: number;
62
+ unit?: ContentSizeUpdateRequestUnit;
63
+ };
64
+
65
+ declare type ContentSizeUpdateRequestUnit = 'pixel' | 'percent';
66
+
67
+ /**
68
+ * Dispatch an incoming event message to all registered subscribers.
69
+ * Caches the value so late subscribers receive it on subscription.
70
+ */
71
+ export declare function dispatchHostEvent(message: EventMessage): void {
72
+ const method = message.method as HostEventMethod;
73
+ lastValues.set(method, message.result);
74
+
75
+ const set = subscribers.get(method);
76
+ if (!set) {
77
+ return;
78
+ }
79
+ for (const cb of set) {
80
+ try {
81
+ cb(message.result);
82
+ } catch (err) {
83
+ console.error(`[EventBus] Error in subscriber for "${message.method}":`, err);
84
+ }
85
+ }
86
+ }
87
+
88
+ /**
89
+ * Shape of an incoming event message from the host (postMessage).
90
+ * Distinct from 'response' and 'request' message types.
91
+ */
92
+ export declare type EventMessage = {
93
+ messageId: string;
94
+ type: 'event';
95
+ method: HostEventMethod;
96
+ result: unknown;
97
+ };
98
+
99
+ /**
100
+ * Маппинг trigger-слотов на тип возвращаемого значения getData.
101
+ */
102
+ export declare type GetDataResultMap = {
103
+ 'trigger.create.action': TriggerActionData;
104
+ 'trigger.edit.action': TriggerActionData;
105
+ };
106
+
107
+ /**
108
+ * Извлекает значение из объекта по точечному пути (dot notation).
109
+ * Предназначена для работы с полями типа Record<string, unknown>, например со значениями полей задачи (Issue).
110
+ *
111
+ * Поддерживает вложенные пути: `'priority.display'`, `'assignee.display.ru'` и т.д.
112
+ * Если любой сегмент пути отсутствует или не является объектом — возвращается defaultValue или undefined.
113
+ * @param obj - Объект с произвольной структурой (например, issue или issue.values)
114
+ * @param path - Путь к полю через точку, например `'priority.display'` или `'summary'`
115
+ * @param defaultValue - Значение по умолчанию, если путь не найден
116
+ * @returns Значение по пути, defaultValue или undefined
117
+ * @example
118
+ * ```ts
119
+ * // Поле верхнего уровня
120
+ * getField(issue, 'key'); // 'QUEUE-123'
121
+ *
122
+ * // Вложенное поле (например, приоритет с display)
123
+ * getField(issue, 'priority.display'); // 'много' | undefined
124
+ *
125
+ * // С типизацией и значением по умолчанию
126
+ * const name = getField<string>(issue, 'summary', 'Без названия');
127
+ *
128
+ * // Элемент массива по индексу (массивы — объекты с числовыми ключами)
129
+ * getField(tags, '0'); // первый элемент
130
+ * ```
131
+ */
132
+ export declare function getField<T = unknown>(
133
+ obj: Record<string, unknown>,
134
+ path: string,
135
+ defaultValue?: T,
136
+ ): T | undefined {
137
+ if (path === '') {
138
+ return defaultValue;
139
+ }
140
+
141
+ const keys = path.split('.');
142
+ let result: unknown = obj;
143
+
144
+ for (const key of keys) {
145
+ if (
146
+ result !== null &&
147
+ typeof result === 'object' &&
148
+ Object.prototype.hasOwnProperty.call(result, key)
149
+ ) {
150
+ result = (result as Record<string, unknown>)[key];
151
+ } else {
152
+ return defaultValue;
153
+ }
154
+ }
155
+
156
+ return (result as T | undefined) ?? defaultValue;
157
+ }
158
+
159
+ /**
160
+ * Возвращает обработчик getData. При указании TSlot — () => GetDataResultMap[TSlot].
161
+ */
162
+ export declare function getHandler<TSlot extends keyof GetDataResultMap>(name: 'getData'): (() => GetDataResultMap[TSlot]) | undefined;
163
+
164
+ export declare function getHandler<TKey extends keyof Handlers>(name: TKey): HandlerFunction<TKey> | undefined;
165
+
166
+ /**
167
+ * Получить локализованную строку на основе языка.
168
+ * Принимает api-types `LocalizedString` (Yandex flavor).
169
+ */
170
+ export declare function getLocalizedString(value: LocalizedString, language: string | undefined, fallbackLanguage?: string): string;
171
+
172
+ declare type GoalActionsSlotContext = {
173
+ data: MetaEntityV2 & {
174
+ progress: {
175
+ closed: number;
176
+ total: number;
177
+ };
178
+ };
179
+ };
180
+
181
+ export declare type HandlerFunction<TKey extends keyof Handlers> = Handlers[TKey];
182
+
183
+ /**
184
+ * Обработчики, которые плагин регистрирует для ответов на запросы хоста.
185
+ * - getData — общий метод получения данных; тип зависит от слота (GetDataResultMap).
186
+ */
187
+ export declare type Handlers = {
188
+ getData: () => GetDataResultMap[keyof GetDataResultMap];
189
+ };
190
+
191
+ /**
192
+ * Типизированный интерфейс HostApi для публичного API публикуемого core'а.
193
+ */
194
+ declare interface HostApi<TSlot extends keyof SlotContextMap = keyof SlotContextMap> {
195
+ /**
196
+ * Текущая тема хоста
197
+ */
198
+ getTheme(): Promise<Theme>;
199
+ /**
200
+ * Текущий язык хоста
201
+ */
202
+ getLanguage(): Promise<string>;
203
+ /**
204
+ * Id пользователя
205
+ */
206
+ getUserId(): Promise<string>;
207
+ /**
208
+ * Сборка для ятима
209
+ */
210
+ getIsYateam(): Promise<boolean>;
211
+ /**
212
+ * Получить текущий контекст, в котором запущен плагин.
213
+ * Тип возвращаемого значения зависит от слота.
214
+ */
215
+ getContext(): Promise<SlotContextMap[TSlot]>;
216
+ /**
217
+ * Изменить размер окна, в котором запущен плагин
218
+ */
219
+ updateContentSize(payload: ContentSizeUpdateRequest): Promise<void>;
220
+ /**
221
+ * Сообщить, что плагин готов к работе
222
+ */
223
+ notifyReady(): Promise<void>;
224
+ /**
225
+ * Сообщить, что плагин закрыт
226
+ */
227
+ close(payload: PluginClosePayloadMap[TSlot]): Promise<void>;
228
+ /**
229
+ * Выполнить навигацию в хосте
230
+ */
231
+ navigate(payload: NavigateRequest): Promise<void>;
232
+ /**
233
+ * Инициализация плагина
234
+ */
235
+ init(options: HostInitOptions): void;
236
+ /**
237
+ * Текущий слот, в котором открыт плагин.
238
+ * Вызов до init() приведёт к ошибке.
239
+ */
240
+ getSlot(): TSlot;
241
+ /**
242
+ * Сервис, в котором открылся плагин.
243
+ * Вызов до init() приведёт к ошибке.
244
+ */
245
+ getService(): string;
246
+ /**
247
+ * Origin родительского окна (хоста).
248
+ * Вызов до init() приведёт к ошибке.
249
+ */
250
+ getOrigin(): string;
251
+ /**
252
+ * Внутренний урл плагина.
253
+ * Вызов до init() приведёт к ошибке.
254
+ */
255
+ getInnerUrl(): string;
256
+ /**
257
+ * Query-параметры плагина.
258
+ * Вызов до init() приведёт к ошибке.
259
+ */
260
+ getQueryParams(): Record<string, string>;
261
+ /**
262
+ * Выключить автоматическое изменение размера контейнера
263
+ */
264
+ disableAutoResize(): void;
265
+ }
266
+
267
+ export declare const hostApi: HostApi;
268
+
269
+ /** Callback type for a specific host event */
270
+ export declare type HostEventCallback<M extends HostEventMethod> = (
271
+ result: HostEventContract[M]['result'],
272
+ ) => void;
273
+
274
+ /**
275
+ * Contract describing host-pushed events.
276
+ * Each key is a `method` string from the incoming postMessage,
277
+ * and the value describes the `result` payload type.
278
+ */
279
+ export declare type HostEventContract = {
280
+ 'theme.changed': { result: Theme };
281
+ 'language.changed': { result: string };
282
+ 'userId.changed': { result: string };
283
+ 'isYateam.changed': { result: boolean };
284
+ 'context.changed': { result: Record<string, unknown> };
285
+ 'toast.action.clicked': { result: { name: string; actionId: string } };
286
+ };
287
+
288
+ /** Union of all supported host event method names */
289
+ export declare type HostEventMethod = keyof HostEventContract;
290
+
291
+ declare interface HostInitOptions {
292
+ /**
293
+ * Автоматически изменять размер контейнера плагина
294
+ * при изменении содержимого
295
+ * @default true
296
+ */
297
+ autoResize?: boolean;
298
+ }
299
+
300
+ export declare type HttpMethod = 'GET' | 'HEAD' | 'POST' | 'PUT' | 'DELETE' | 'PATCH' | 'OPTIONS' | 'LINK' | 'UNLINK';
301
+
302
+ declare type IssueCommentActionSlotContext = {
303
+ id: string;
304
+ createdAt: string;
305
+ updatedAt: string | null;
306
+ text: string;
307
+ type: string;
308
+ transport: string;
309
+ attachments: Attachment[];
310
+ issueVersion: number;
311
+ };
312
+
313
+ export { LocalizedString }
314
+
315
+ /** Код ошибки: запрошенный метод API не поддерживается в данной конфигурации или версии. */
316
+ export declare const METHOD_NOT_SUPPORTED = 1003;
317
+
318
+ /** Код ошибки: у плагина нет необходимого scope (разрешения) для выполнения операции. */
319
+ export declare const MISSING_REQUIRED_SCOPE = 1004;
320
+
321
+ declare type NavigateRequest = {
322
+ path: string;
323
+ params?: QueryParams;
324
+ options?: {
325
+ newTab?: boolean;
326
+ };
327
+ };
328
+
329
+ /**
330
+ * Subscribe to a host-pushed event.
331
+ * If a value was already dispatched for this method, the callback is called
332
+ * synchronously with the cached value before returning.
333
+ * @param method - Event method name (e.g. `'theme.changed'`)
334
+ * @param callback - Function called with the typed event payload
335
+ * @returns An `Unsubscribe` function that removes this subscription
336
+ */
337
+ export declare function on<M extends HostEventMethod>(
338
+ method: M,
339
+ callback: HostEventCallback<M>,
340
+ ): Unsubscribe {
341
+ let set = subscribers.get(method);
342
+ if (!set) {
343
+ set = new Set();
344
+ subscribers.set(method, set);
345
+ }
346
+
347
+ const cb = callback as (result: unknown) => void;
348
+ set.add(cb);
349
+
350
+ // Replay last known value to the new subscriber immediately
351
+ if (lastValues.has(method)) {
352
+ try {
353
+ cb(lastValues.get(method));
354
+ } catch (err) {
355
+ console.error(`[EventBus] Error replaying cached value for "${method}":`, err);
356
+ }
357
+ }
358
+
359
+ return () => {
360
+ set.delete(cb);
361
+ if (set.size === 0) {
362
+ subscribers.delete(method);
363
+ }
364
+ };
365
+ }
366
+
367
+ /** Код ошибки: переданный pluginId не совпадает с зарегистрированным плагином или неверного формата. */
368
+ export declare const PLUGIN_ID_IS_NOT_CORRECT = 1001;
369
+
370
+ /** Код ошибки: не переданы обязательные параметры инициализации плагина (pluginId или slot). */
371
+ export declare const PLUGIN_ID_OR_SLOT_NOT_PROVIDED = 1000;
372
+
373
+ export declare class PluginActionError extends Error {
374
+ readonly code: number;
375
+
376
+ readonly errorData?: unknown;
377
+
378
+ constructor(code: number, message: string, errorData?: unknown) {
379
+ super(message);
380
+ this.name = 'PluginActionError';
381
+ this.code = code;
382
+ this.errorData = errorData;
383
+ }
384
+ }
385
+
386
+ declare type PluginClosePayloadMap = WithUndefinedDefaults<PluginClosePayloadOverrides, keyof SlotContextMap>;
387
+
388
+ declare type PluginClosePayloadOverrides = {
389
+ 'attachment.viewer.action': AttachmentViewerActionClosePayload;
390
+ };
391
+
392
+ declare type PortfolioActionsSlotContext = {
393
+ data: MetaEntityV2 & {
394
+ progress: {
395
+ closed: number;
396
+ total: number;
397
+ };
398
+ };
399
+ };
400
+
401
+ declare type ProjectActionsSlotContext = {
402
+ data: MetaEntityV2 & {
403
+ progress: {
404
+ closed: number;
405
+ total: number;
406
+ };
407
+ boardId: number;
408
+ };
409
+ };
410
+
411
+ declare type QueryParams = Record<string, QueryParamValue | QueryParamValue[]>;
412
+
413
+ declare type QueryParamValue = string | number | boolean | null | undefined;
414
+
415
+ /**
416
+ * Clears all cached last values and subscribers from the event bus.
417
+ * Intended for use in tests to prevent state leaking between test cases.
418
+ */
419
+ export declare function resetEventBus(): void {
420
+ lastValues.clear();
421
+ subscribers.clear();
422
+ }
423
+
424
+ /**
425
+ * Регистрирует обработчик. Тип возвращаемого значения задаётся слотом (GetDataResultMap).
426
+ */
427
+ export declare function setHandler<TSlot extends keyof GetDataResultMap>(name: 'getData', handler: () => GetDataResultMap[TSlot]): void;
428
+
429
+ export declare function setHandler<TKey extends keyof Handlers>(name: TKey, handler: HandlerFunction<TKey>): void;
430
+
431
+ export declare type SlotContextMap = {
432
+ 'issue.action': Issue;
433
+ 'issue.block': Issue;
434
+ 'issue.tab': Issue;
435
+ navigation: Record<string, never>;
436
+ 'issue.floatingbottom.action': Record<string, never>;
437
+ 'trigger.create.action': TriggerCreateActionsSlotContext;
438
+ 'trigger.edit.action': TriggerEditActionsSlotContext;
439
+ 'portfolio.action': PortfolioActionsSlotContext;
440
+ 'project.action': ProjectActionsSlotContext;
441
+ 'goal.action': GoalActionsSlotContext;
442
+ 'attachment.viewer.action': AttachmentViewerActionSlotContext;
443
+ 'issue.comment.action': IssueCommentActionSlotContext;
444
+ };
445
+
446
+ export declare type Theme = 'light' | 'light-hc' | 'dark' | 'dark-hc' | 'system';
447
+
448
+ export declare type ToastAction = {
449
+ label: string;
450
+ onClick: () => void;
451
+ };
452
+
453
+ export declare type ToastOptions = {
454
+ name?: string;
455
+ title: string;
456
+ content?: string;
457
+ theme?: 'success' | 'danger' | 'warning' | 'info';
458
+ autoHiding?: number;
459
+ isClosable?: boolean;
460
+ actions?: ToastAction[];
461
+ };
462
+
463
+ export declare interface TrackerApi {
464
+ v3: TrackerApiV3;
465
+ }
466
+
467
+ export declare const trackerApi: TrackerApi;
468
+
469
+ export declare type TrackerApiCallOptions = TrackerApiCallOptions_2;
470
+
471
+ declare interface TrackerApiCallOptions_2 {
472
+ pathParams?: Record<string, string>;
473
+ queryParams?: Record<string, unknown>;
474
+ bodyParams?: Record<string, unknown>;
475
+ file?: File;
476
+ }
477
+
478
+ export declare type TrackerApiInitOptions = TrackerApiInitOptions_2;
479
+
480
+ declare interface TrackerApiInitOptions_2 {
481
+ apiVersion?: string;
482
+ }
483
+
484
+ export declare interface TrackerApiV3 {
485
+ get: ApiResult<ApiV3GetMethods>;
486
+ post: ApiResult<ApiV3PostMethods>;
487
+ put: ApiResult<ApiV3PutMethods>;
488
+ patch: ApiResult<ApiV3PatchMethods>;
489
+ delete: ApiResult<ApiV3DeleteMethods>;
490
+ }
491
+
492
+ export declare type TriggerActionData = Omit<WebhookTriggerActionInput, 'id' | 'type' | 'typeKey'>;
493
+
494
+ declare type TriggerCreateActionsSlotContext = {
495
+ queue: string;
496
+ };
497
+
498
+ declare type TriggerEditActionsSlotContext = {
499
+ queue: string;
500
+ data: TriggerActionData;
501
+ };
502
+
503
+ export declare const uiApi = new UiApi();
504
+
505
+ /** Код ошибки: непредвиденная или неклассифицированная ошибка. */
506
+ export declare const UNKNOWN_ERROR = 6666;
507
+
508
+ /** Function returned by `on()` to remove the subscription */
509
+ export declare type Unsubscribe = () => void;
510
+
511
+ /** Код ошибки: данные запроса не прошли валидацию (неверный формат, обязательные поля отсутствуют и т.п.). */
512
+ export declare const VALIDATION_ERROR = 1002;
513
+
514
+ declare type WithUndefinedDefaults<TMap, TKeys extends PropertyKey> = {
515
+ [K in TKeys]: K extends keyof TMap ? TMap[K] : undefined;
516
+ };
517
+
518
+ export { }
package/dist/index.mjs ADDED
@@ -0,0 +1,438 @@
1
+ const g = /* @__PURE__ */ new Map(), f = /* @__PURE__ */ new Map();
2
+ function R(i, e) {
3
+ let t = g.get(i);
4
+ t || (t = /* @__PURE__ */ new Set(), g.set(i, t));
5
+ const s = e;
6
+ if (t.add(s), f.has(i))
7
+ try {
8
+ s(f.get(i));
9
+ } catch (n) {
10
+ console.error(`[EventBus] Error replaying cached value for "${i}":`, n);
11
+ }
12
+ return () => {
13
+ t.delete(s), t.size === 0 && g.delete(i);
14
+ };
15
+ }
16
+ function M(i) {
17
+ const e = i.method;
18
+ f.set(e, i.result);
19
+ const t = g.get(e);
20
+ if (t)
21
+ for (const s of t)
22
+ try {
23
+ s(i.result);
24
+ } catch (n) {
25
+ console.error(`[EventBus] Error in subscriber for "${i.method}":`, n);
26
+ }
27
+ }
28
+ function D() {
29
+ f.clear(), g.clear();
30
+ }
31
+ const E = {};
32
+ function P(i, e) {
33
+ E[i] = e;
34
+ }
35
+ function b(i) {
36
+ return E[i];
37
+ }
38
+ const B = 1e3, x = 1001, $ = 1002, V = 1003, F = 1004, y = 6666;
39
+ class w extends Error {
40
+ constructor(e, t, s) {
41
+ super(t), this.name = "PluginActionError", this.code = e, this.errorData = s;
42
+ }
43
+ }
44
+ class C {
45
+ constructor(e, t, s, n, r, o) {
46
+ this.pendingRequests = /* @__PURE__ */ new Map(), this.messageListener = null, this.requestTimeout = 1e4, this.pluginId = e, this.elementId = t, this.targetOrigin = r, this.entityId = n, this.entityMeta = o, this.slot = s, this.initListener();
47
+ }
48
+ request(e, t, s) {
49
+ return new Promise((n, r) => {
50
+ const o = this.generateMessageId(), c = s?.timeout ?? this.requestTimeout, l = {
51
+ messageId: o,
52
+ method: e,
53
+ payload: t
54
+ }, a = setTimeout(() => {
55
+ this.pendingRequests.get(o) && (this.pendingRequests.delete(o), r(new Error(`Request timeout: ${e} exceeded ${c}ms`)));
56
+ }, c);
57
+ this.pendingRequests.set(o, { resolve: n, reject: r, timeoutId: a });
58
+ try {
59
+ this.send(l);
60
+ } catch (u) {
61
+ clearTimeout(a), this.pendingRequests.delete(o), r(u);
62
+ }
63
+ });
64
+ }
65
+ send(e) {
66
+ window.parent.postMessage(
67
+ {
68
+ pluginId: this.pluginId,
69
+ elementId: this.elementId,
70
+ slot: this.slot,
71
+ entityId: this.entityId,
72
+ entityMeta: this.entityMeta,
73
+ ...e
74
+ },
75
+ this.targetOrigin
76
+ );
77
+ }
78
+ destroy() {
79
+ this.messageListener && (window.removeEventListener("message", this.messageListener), this.messageListener = null), this.pendingRequests.forEach((e) => {
80
+ clearTimeout(e.timeoutId);
81
+ }), this.pendingRequests.clear();
82
+ }
83
+ initListener() {
84
+ this.messageListener = async (e) => {
85
+ if (e.origin !== this.targetOrigin) {
86
+ console.info(
87
+ "[Bridge] Ignored message from origin:",
88
+ e.origin,
89
+ "(expected:",
90
+ this.targetOrigin,
91
+ ")"
92
+ );
93
+ return;
94
+ }
95
+ const t = e.data;
96
+ if (console.info("[Bridge] Received message:", t), t.type === "event") {
97
+ console.info("[Bridge] Dispatching host event:", t.method, t.result), M(t);
98
+ return;
99
+ }
100
+ if (console.info("[Bridge] Received message:", e.data), !t.messageId) {
101
+ console.info("[Bridge] Ignored message without messageId:", t);
102
+ return;
103
+ }
104
+ const s = t, n = this.pendingRequests.get(s.messageId);
105
+ if (!n) {
106
+ if (s.type === "request") {
107
+ const c = s.result.method, l = b(c);
108
+ if (!l) {
109
+ this.send({
110
+ messageId: s.messageId,
111
+ type: "response",
112
+ result: null,
113
+ errorCode: y,
114
+ error: `No handler for method ${c}`
115
+ });
116
+ return;
117
+ }
118
+ try {
119
+ const a = l();
120
+ this.send({
121
+ messageId: s.messageId,
122
+ payload: a,
123
+ method: "responseData",
124
+ type: "response"
125
+ });
126
+ } catch (a) {
127
+ const u = a instanceof Error ? a : new Error(String(a)), m = u instanceof w ? u.code : y;
128
+ this.send({
129
+ messageId: s.messageId,
130
+ type: "response",
131
+ result: null,
132
+ errorCode: m,
133
+ error: u.message
134
+ });
135
+ }
136
+ }
137
+ return;
138
+ }
139
+ clearTimeout(n.timeoutId), this.pendingRequests.delete(s.messageId);
140
+ const r = s;
141
+ r.type === "response" && r.errorCode ? n.reject(
142
+ new w(
143
+ r.errorCode,
144
+ r.error ?? "Unknown error",
145
+ r.errorData
146
+ )
147
+ ) : n.resolve(r.result);
148
+ }, window.addEventListener("message", this.messageListener);
149
+ }
150
+ generateMessageId() {
151
+ return crypto.randomUUID();
152
+ }
153
+ }
154
+ let h = null;
155
+ function O(i, e, t, s, n, r) {
156
+ return h && h.destroy(), h = new C(
157
+ i,
158
+ e,
159
+ t,
160
+ s,
161
+ n,
162
+ r
163
+ ), h;
164
+ }
165
+ function T() {
166
+ if (!h)
167
+ throw new Error("Bridge not initialized. Call initBridge first.");
168
+ return h;
169
+ }
170
+ function d(i, e, t) {
171
+ return T().request(i, e, t);
172
+ }
173
+ const v = 3e5;
174
+ class z {
175
+ show(e) {
176
+ return d("confirm.show", e, {
177
+ timeout: v
178
+ });
179
+ }
180
+ }
181
+ class A {
182
+ constructor() {
183
+ this.callbackMap = /* @__PURE__ */ new Map(), this.toastActionIds = /* @__PURE__ */ new Map(), this.eventSubscribed = !1;
184
+ }
185
+ async add(e) {
186
+ this.ensureEventSubscription();
187
+ const t = [], s = e.actions?.map((o) => {
188
+ const c = crypto.randomUUID();
189
+ return this.callbackMap.set(c, o.onClick), t.push(c), { id: c, label: o.label };
190
+ }), n = await d("toast.add", {
191
+ name: e.name,
192
+ title: e.title,
193
+ content: e.content,
194
+ theme: e.theme,
195
+ autoHiding: e.autoHiding,
196
+ isClosable: e.isClosable,
197
+ actions: s
198
+ });
199
+ t.length > 0 && this.toastActionIds.set(n.name, t);
200
+ const r = e.autoHiding ?? 5e3;
201
+ return setTimeout(() => this.cleanupCallbacksForToast(n.name), r + 1e3), n;
202
+ }
203
+ ensureEventSubscription() {
204
+ this.eventSubscribed || (this.eventSubscribed = !0, R("toast.action.clicked", ({ name: e, actionId: t }) => {
205
+ this.callbackMap.get(t)?.(), this.cleanupCallbacksForToast(e);
206
+ }));
207
+ }
208
+ cleanupCallbacksForToast(e) {
209
+ const t = this.toastActionIds.get(e);
210
+ if (t) {
211
+ for (const s of t)
212
+ this.callbackMap.delete(s);
213
+ this.toastActionIds.delete(e);
214
+ }
215
+ }
216
+ }
217
+ class L {
218
+ constructor() {
219
+ this.toaster = new A(), this.confirm = new z();
220
+ }
221
+ }
222
+ const G = new L();
223
+ function X(i, e, t) {
224
+ if (e === "")
225
+ return t;
226
+ const s = e.split(".");
227
+ let n = i;
228
+ for (const r of s)
229
+ if (n !== null && typeof n == "object" && Object.prototype.hasOwnProperty.call(n, r))
230
+ n = n[r];
231
+ else
232
+ return t;
233
+ return n ?? t;
234
+ }
235
+ function _(i, e, t = "ru") {
236
+ if (typeof i == "string")
237
+ return i;
238
+ const s = (e ?? t).toLowerCase(), n = t.toLowerCase();
239
+ return i[s] || i[n] || i.ru || i.en || "";
240
+ }
241
+ class U {
242
+ constructor(e) {
243
+ this.lastHeight = 0, this.isUpdating = !1, this.consecutiveSmallIncreases = 0, this.MAX_CONSECUTIVE_SMALL_INCREASES = 5, this.SMALL_INCREASE_THRESHOLD_PX = 10, this.resizeCallback = e;
244
+ }
245
+ enable() {
246
+ if (!document.body) {
247
+ console.error("[AutoResize] document.body does not exist yet");
248
+ return;
249
+ }
250
+ const e = async () => {
251
+ if (this.isUpdating)
252
+ return;
253
+ const s = document.getElementById("root"), n = window.getComputedStyle(document.body), r = parseInt(n.marginTop, 10) || 0, o = parseInt(n.marginBottom, 10) || 0, l = Math.max(
254
+ document.body.scrollHeight,
255
+ document.body.offsetHeight,
256
+ s ? s.scrollHeight + r + o : 0
257
+ ) + 4;
258
+ if (l !== this.lastHeight) {
259
+ if (l > this.lastHeight)
260
+ if (l - this.lastHeight <= this.SMALL_INCREASE_THRESHOLD_PX) {
261
+ if (this.consecutiveSmallIncreases++, this.consecutiveSmallIncreases > this.MAX_CONSECUTIVE_SMALL_INCREASES) {
262
+ console.warn(
263
+ "[AutoResize] Infinite loop detected. Stopping auto-resize. This may be caused by elements with viewport-relative units (vh, %)."
264
+ ), this.disable();
265
+ return;
266
+ }
267
+ } else
268
+ this.consecutiveSmallIncreases = 0;
269
+ else
270
+ this.consecutiveSmallIncreases = 0;
271
+ this.isUpdating = !0, this.lastHeight = l;
272
+ try {
273
+ await this.resizeCallback(l);
274
+ } catch (a) {
275
+ console.error("[AutoResize] Failed to update content size:", a);
276
+ } finally {
277
+ this.isUpdating = !1;
278
+ }
279
+ }
280
+ }, t = () => {
281
+ clearTimeout(this.resizeTimeout), this.resizeTimeout = setTimeout(e, 100);
282
+ };
283
+ this.resizeObserver = new ResizeObserver(t), this.resizeObserver.observe(document.body), e();
284
+ }
285
+ disable() {
286
+ this.resizeObserver?.disconnect(), clearTimeout(this.resizeTimeout), this.isUpdating = !1, this.consecutiveSmallIncreases = 0;
287
+ }
288
+ }
289
+ function H(i, e, t = {}, s) {
290
+ return {
291
+ version: s,
292
+ method: i,
293
+ url: e,
294
+ pathParams: t.pathParams ?? {},
295
+ queryParams: t.queryParams ?? {},
296
+ bodyParams: t.bodyParams ?? {},
297
+ file: t.file
298
+ };
299
+ }
300
+ const p = class p {
301
+ get v3() {
302
+ return {
303
+ get: this.createMethodProxy("GET"),
304
+ post: this.createMethodProxy("POST"),
305
+ put: this.createMethodProxy("PUT"),
306
+ patch: this.createMethodProxy("PATCH"),
307
+ delete: this.createMethodProxy("DELETE")
308
+ };
309
+ }
310
+ createMethodProxy(e) {
311
+ const t = this;
312
+ return new Proxy({}, {
313
+ get(s, n) {
314
+ return (r) => t.call(e, n, r, p.V3_VERSION);
315
+ }
316
+ });
317
+ }
318
+ call(e, t, s = {}, n) {
319
+ const r = H(e, t, s, n);
320
+ return d("api.tracker.call", r);
321
+ }
322
+ };
323
+ p.V3_VERSION = "v3";
324
+ let I = p;
325
+ const q = new I();
326
+ class N {
327
+ constructor() {
328
+ this.slot = null, this.service = null, this.origin = null, this.innerUrl = null, this.queryParams = null;
329
+ }
330
+ getTheme() {
331
+ return d("theme.get");
332
+ }
333
+ getLanguage() {
334
+ return d("language.get");
335
+ }
336
+ getUserId() {
337
+ return d("userId.get");
338
+ }
339
+ getIsYateam() {
340
+ return d("isYateam.get");
341
+ }
342
+ getContext() {
343
+ return d("context.get");
344
+ }
345
+ updateContentSize(e) {
346
+ return d("contentSize.update", e);
347
+ }
348
+ notifyReady() {
349
+ return d("plugin.ready");
350
+ }
351
+ close(e) {
352
+ return d("plugin.close", e);
353
+ }
354
+ navigate(e) {
355
+ return d("navigate", e);
356
+ }
357
+ init(e) {
358
+ const { autoResize: t = !0 } = e, s = new URLSearchParams(location.search);
359
+ if (this.service = s.get("service"), this.service === null)
360
+ throw new Error("Service is not defined");
361
+ const n = s.get("slot");
362
+ if (!n)
363
+ throw new Error("Slot is not defined");
364
+ const r = s.get("parentOrigin");
365
+ if (!r)
366
+ throw new Error("Target origin is not defined");
367
+ const o = s.get("id");
368
+ if (!o)
369
+ throw new Error("Plugin id is not defined");
370
+ const c = s.get("elementId");
371
+ if (!c)
372
+ throw new Error("Element id is not defined");
373
+ const l = s.get("entityId"), a = s.get("entityMeta"), u = a ? JSON.parse(a) : void 0;
374
+ O(o, c, n, l, r, u), this.slot = n, this.origin = r, this.innerUrl = s.get("innerUrl") ?? "";
375
+ const m = s.get("queryParams");
376
+ this.queryParams = m ? JSON.parse(decodeURIComponent(m)) : {}, t && (this.autoResizeManager = new U(
377
+ (S) => this.updateContentSize({ height: S })
378
+ ), this.autoResizeManager.enable());
379
+ }
380
+ getSlot() {
381
+ if (this.slot === null)
382
+ throw new Error("Plugin not initialized. Call init() first.");
383
+ return this.slot;
384
+ }
385
+ getService() {
386
+ if (this.service === null)
387
+ throw new Error("Service not initialized. Call init() first.");
388
+ return this.service;
389
+ }
390
+ getOrigin() {
391
+ if (this.origin === null)
392
+ throw new Error("Origin not initialized. Call init() first.");
393
+ return this.origin;
394
+ }
395
+ getInnerUrl() {
396
+ if (this.innerUrl === null)
397
+ throw new Error("Plugin not initialized. Call init() first.");
398
+ return this.innerUrl;
399
+ }
400
+ getQueryParams() {
401
+ if (this.queryParams === null)
402
+ throw new Error("Plugin not initialized. Call init() first.");
403
+ return this.queryParams;
404
+ }
405
+ disableAutoResize() {
406
+ this.autoResizeManager?.disable();
407
+ }
408
+ }
409
+ const k = new N(), J = q, Q = k;
410
+ function Y(i, e) {
411
+ P(i, e);
412
+ }
413
+ function j(i) {
414
+ return b(i);
415
+ }
416
+ function K(i, e, t = "ru") {
417
+ return _(i, e, t);
418
+ }
419
+ export {
420
+ V as METHOD_NOT_SUPPORTED,
421
+ F as MISSING_REQUIRED_SCOPE,
422
+ x as PLUGIN_ID_IS_NOT_CORRECT,
423
+ B as PLUGIN_ID_OR_SLOT_NOT_PROVIDED,
424
+ w as PluginActionError,
425
+ y as UNKNOWN_ERROR,
426
+ $ as VALIDATION_ERROR,
427
+ M as dispatchHostEvent,
428
+ X as getField,
429
+ j as getHandler,
430
+ K as getLocalizedString,
431
+ Q as hostApi,
432
+ R as on,
433
+ D as resetEventBus,
434
+ Y as setHandler,
435
+ J as trackerApi,
436
+ G as uiApi
437
+ };
438
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sources":["../../core-shared/src/events/eventBus.ts","../../core-shared/src/handlers/handlers.ts","../../core-shared/src/bridge/types/ErrorCodes.ts","../../core-shared/src/bridge/types/PluginActionError.ts","../../core-shared/src/bridge/bridge.ts","../../core-shared/src/ui/Confirm.ts","../../core-shared/src/ui/Toaster.ts","../../core-shared/src/ui/uiApi.ts","../../core-shared/src/utils/getField.ts","../../core-shared/src/utils/localization.ts","../../core-shared/src/host/utils/autoResize.ts","../../core-shared/src/api/trackerApi.ts","../../core-shared/src/host/hostApi.ts","../src/api/trackerApi.ts","../src/host/hostApi.ts","../src/handlers/handlers.ts","../src/utils/localization.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 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 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 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 { Confirm } from './Confirm';\nimport { Toaster } from './Toaster';\n\nclass UiApi {\n readonly toaster = new Toaster();\n readonly confirm = new Confirm();\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 { sendRequest } from '../bridge/bridge';\nimport type { ApiCallPayload, ApiCallResult } from './types';\n\nexport interface TrackerApiCallOptions {\n pathParams?: Record<string, string>;\n queryParams?: Record<string, unknown>;\n bodyParams?: Record<string, unknown>;\n file?: File;\n}\n\nfunction buildPayload(\n method: string,\n url: string,\n options: TrackerApiCallOptions = {},\n version: string,\n): ApiCallPayload {\n return {\n version,\n method,\n url,\n pathParams: options.pathParams ?? {},\n queryParams: options.queryParams ?? {},\n bodyParams: options.bodyParams ?? {},\n file: options.file,\n };\n}\n\nexport interface TrackerApiInitOptions {\n apiVersion?: string;\n}\n\n/**\n * Untyped runtime API класс. v3-методы возвращают Proxy, который при обращении\n * по любому ключу строит call. Типизация добавляется в публикуемых пакетах\n * через cast (см. typed wrapper).\n */\nexport class TrackerApi {\n private static readonly V3_VERSION = 'v3';\n\n get v3(): {\n get: Record<string, (opts: TrackerApiCallOptions) => Promise<unknown>>;\n post: Record<string, (opts: TrackerApiCallOptions) => Promise<unknown>>;\n put: Record<string, (opts: TrackerApiCallOptions) => Promise<unknown>>;\n patch: Record<string, (opts: TrackerApiCallOptions) => Promise<unknown>>;\n delete: Record<string, (opts: TrackerApiCallOptions) => Promise<unknown>>;\n } {\n return {\n get: this.createMethodProxy('GET'),\n post: this.createMethodProxy('POST'),\n put: this.createMethodProxy('PUT'),\n patch: this.createMethodProxy('PATCH'),\n delete: this.createMethodProxy('DELETE'),\n };\n }\n\n private createMethodProxy(\n method: string,\n ): Record<string, (opts: TrackerApiCallOptions) => Promise<unknown>> {\n const self = this;\n return new Proxy({} as Record<string, (opts: TrackerApiCallOptions) => Promise<unknown>>, {\n get(_, path: string) {\n return (payload: TrackerApiCallOptions) =>\n self.call(method, path, payload, TrackerApi.V3_VERSION);\n },\n });\n }\n\n private call(\n method: string,\n url: string,\n options: TrackerApiCallOptions = {},\n requestVersion: string,\n ): Promise<ApiCallResult> {\n const payload: ApiCallPayload = buildPayload(method, url, options, requestVersion);\n return sendRequest('api.tracker.call', payload) as Promise<ApiCallResult>;\n }\n}\n\nexport const trackerApi = new TrackerApi();\n","import { initBridge, sendRequest } from '../bridge/bridge';\nimport type { ContentSizeUpdateRequest } from './types/ContentSizeUpdateRequest';\nimport type { NavigateRequest } from './types/NavigateRequest';\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 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\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 navigate(payload: NavigateRequest): Promise<unknown> {\n return sendRequest('navigate', 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('Service is not defined');\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\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 disableAutoResize(): void {\n this.autoResizeManager?.disable();\n }\n}\n\nexport const hostApi = new HostApi();\n","import type {\n ApiV3DeleteMethods,\n ApiV3GetMethods,\n ApiV3PatchMethods,\n ApiV3PostMethods,\n ApiV3PutMethods,\n} from '@weavix/tracker-api-types';\nimport {\n type TrackerApiCallOptions as BaseCallOptions,\n type TrackerApiInitOptions as BaseInitOptions,\n trackerApi as trackerApiBase,\n} from '@tracker-plugin-sdk/core-shared';\n\nexport type TrackerApiCallOptions = BaseCallOptions;\nexport type TrackerApiInitOptions = BaseInitOptions;\n\ntype ApiResult<M> = {\n [K in keyof M]: M[K] extends (...args: infer A) => Promise<infer R>\n ? (...args: A) => Promise<{ data: R; headers: Record<string, string> }>\n : never;\n};\n\nexport interface TrackerApiV3 {\n get: ApiResult<ApiV3GetMethods>;\n post: ApiResult<ApiV3PostMethods>;\n put: ApiResult<ApiV3PutMethods>;\n patch: ApiResult<ApiV3PatchMethods>;\n delete: ApiResult<ApiV3DeleteMethods>;\n}\n\nexport interface TrackerApi {\n v3: TrackerApiV3;\n}\n\nexport const trackerApi = trackerApiBase as unknown as TrackerApi;\n","import {\n ContentSizeUpdateRequest,\n type HostInitOptions,\n NavigateRequest,\n Theme,\n hostApi as hostApiBase,\n} from '@tracker-plugin-sdk/core-shared';\nimport type { SlotContextMap } from '../common/types/SlotContextMap';\nimport type { PluginClosePayloadMap } from './types/ClosePluginPayload';\n\nexport type { HostInitOptions };\n\n/**\n * Типизированный интерфейс HostApi для публичного API публикуемого core'а.\n */\nexport interface HostApi<TSlot extends keyof SlotContextMap = keyof SlotContextMap> {\n /**\n * Текущая тема хоста\n */\n getTheme(): Promise<Theme>;\n\n /**\n * Текущий язык хоста\n */\n getLanguage(): Promise<string>;\n\n /**\n * Id пользователя\n */\n getUserId(): Promise<string>;\n\n /**\n * Сборка для ятима\n */\n getIsYateam(): Promise<boolean>;\n\n /**\n * Получить текущий контекст, в котором запущен плагин.\n * Тип возвращаемого значения зависит от слота.\n */\n getContext(): Promise<SlotContextMap[TSlot]>;\n\n /**\n * Изменить размер окна, в котором запущен плагин\n */\n updateContentSize(payload: ContentSizeUpdateRequest): Promise<void>;\n\n /**\n * Сообщить, что плагин готов к работе\n */\n notifyReady(): Promise<void>;\n\n /**\n * Сообщить, что плагин закрыт\n */\n close(payload: PluginClosePayloadMap[TSlot]): Promise<void>;\n\n /**\n * Выполнить навигацию в хосте\n */\n navigate(payload: NavigateRequest): Promise<void>;\n\n /**\n * Инициализация плагина\n */\n init(options: HostInitOptions): void;\n\n /**\n * Текущий слот, в котором открыт плагин.\n * Вызов до init() приведёт к ошибке.\n */\n getSlot(): TSlot;\n\n /**\n * Сервис, в котором открылся плагин.\n * Вызов до init() приведёт к ошибке.\n */\n getService(): string;\n\n /**\n * Origin родительского окна (хоста).\n * Вызов до init() приведёт к ошибке.\n */\n getOrigin(): string;\n\n /**\n * Внутренний урл плагина.\n * Вызов до init() приведёт к ошибке.\n */\n getInnerUrl(): string;\n\n /**\n * Query-параметры плагина.\n * Вызов до init() приведёт к ошибке.\n */\n getQueryParams(): Record<string, string>;\n\n /**\n * Выключить автоматическое изменение размера контейнера\n */\n disableAutoResize(): void;\n}\n\nexport const hostApi = hostApiBase as unknown as HostApi;\n","import {\n getHandler as baseGetHandler,\n setHandler as baseSetHandler,\n} from '@tracker-plugin-sdk/core-shared';\nimport type { GetDataResultMap, HandlerFunction, Handlers } from './types';\n\n/**\n * Регистрирует обработчик. Тип возвращаемого значения задаётся слотом (GetDataResultMap).\n */\nexport function setHandler<TSlot extends keyof GetDataResultMap>(\n name: 'getData',\n handler: () => GetDataResultMap[TSlot],\n): void;\nexport function setHandler<TKey extends keyof Handlers>(\n name: TKey,\n handler: HandlerFunction<TKey>,\n): void;\nexport function setHandler(name: string, handler: (...args: unknown[]) => unknown): void {\n baseSetHandler(name, handler);\n}\n\n/**\n * Возвращает обработчик getData. При указании TSlot — () => GetDataResultMap[TSlot].\n */\nexport function getHandler<TSlot extends keyof GetDataResultMap>(\n name: 'getData',\n): (() => GetDataResultMap[TSlot]) | undefined;\nexport function getHandler<TKey extends keyof Handlers>(\n name: TKey,\n): HandlerFunction<TKey> | undefined;\nexport function getHandler(name: string): ((...args: unknown[]) => unknown) | undefined {\n return baseGetHandler(name);\n}\n","import type { LocalizedString } from '@weavix/tracker-api-types';\nimport {\n type LocalizedString as StructuralLocalizedString,\n getLocalizedString as baseGetLocalizedString,\n} from '@tracker-plugin-sdk/core-shared';\n\n// Compile-time проверка совместимости api-types LocalizedString\n// со структурным типом из shared'а. Если api-types когда-то добавят\n// несовместимое поле — здесь будет TS ошибка.\nconst _typeCheck: (value: LocalizedString) => StructuralLocalizedString = (v) => v;\n\n/**\n * Получить локализованную строку на основе языка.\n * Принимает api-types `LocalizedString` (Yandex flavor).\n */\nexport function getLocalizedString(\n value: LocalizedString,\n language: string | undefined,\n fallbackLanguage = 'ru',\n): string {\n return baseGetLocalizedString(value as StructuralLocalizedString, language, fallbackLanguage);\n}\n"],"names":["subscribers","lastValues","on","method","callback","set","cb","err","dispatchHostEvent","message","resetEventBus","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","buildPayload","url","version","_TrackerApi","self","_","requestVersion","TrackerApi","trackerApi","HostApi","autoResize","searchParams","entityMetaRaw","queryParamsRaw","hostApi","trackerApiBase","hostApiBase","baseSetHandler","baseGetHandler","baseGetLocalizedString"],"mappings":"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"}
package/package.json ADDED
@@ -0,0 +1,34 @@
1
+ {
2
+ "name": "@weavix/sdk-core",
3
+ "version": "0.0.1",
4
+ "exports": {
5
+ ".": {
6
+ "types": "./dist/index.d.ts",
7
+ "import": "./dist/index.mjs"
8
+ }
9
+ },
10
+ "files": [
11
+ "dist",
12
+ "README.md"
13
+ ],
14
+ "keywords": [],
15
+ "author": "Tracker Team",
16
+ "license": "UNLICENSED",
17
+ "description": "Core package for Tracker plugin SDK (Weavix flavor)",
18
+ "publishConfig": {
19
+ "registry": "https://registry.npmjs.org/",
20
+ "access": "public"
21
+ },
22
+ "peerDependencies": {
23
+ "@weavix/tracker-api-types": ">=0.0.0"
24
+ },
25
+ "devDependencies": {
26
+ "@types/jest": "*",
27
+ "@weavix/tracker-api-types": "*",
28
+ "@tracker-plugin-sdk/core-shared": "0.0.0"
29
+ },
30
+ "scripts": {
31
+ "build": "vite build",
32
+ "typecheck": "tsc --noEmit"
33
+ }
34
+ }