@teambit/pubsub 0.0.1110 → 0.0.1112
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/dist/bit-base-event.js.map +1 -1
- package/dist/index.js.map +1 -1
- package/dist/no-parent-error.js.map +1 -1
- package/dist/{preview-1689736586631.js → preview-1689909446382.js} +2 -2
- package/dist/pubsub-context.js.map +1 -1
- package/dist/pubsub.aspect.js.map +1 -1
- package/dist/pubsub.composition.js.map +1 -1
- package/dist/pubsub.main.runtime.js.map +1 -1
- package/dist/pubsub.preview.runtime.js.map +1 -1
- package/dist/pubsub.ui.runtime.js +5 -12
- package/dist/pubsub.ui.runtime.js.map +1 -1
- package/package-tar/teambit-pubsub-0.0.1112.tgz +0 -0
- package/package.json +6 -6
- package/package-tar/teambit-pubsub-0.0.1110.tgz +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["BitBaseEvent","constructor","type","version","timestamp","data"
|
|
1
|
+
{"version":3,"names":["BitBaseEvent","constructor","type","version","timestamp","data"],"sources":["bit-base-event.ts"],"sourcesContent":["export class BitBaseEvent<T> {\n constructor(readonly type: string, readonly version: string, readonly timestamp: number, readonly data: T) {}\n}\n"],"mappings":";;;;;;AAAO,MAAMA,YAAY,CAAI;EAC3BC,WAAW,CAAUC,IAAY,EAAWC,OAAe,EAAWC,SAAiB,EAAWC,IAAO,EAAE;IAAA,KAAtFH,IAAY,GAAZA,IAAY;IAAA,KAAWC,OAAe,GAAfA,OAAe;IAAA,KAAWC,SAAiB,GAAjBA,SAAiB;IAAA,KAAWC,IAAO,GAAPA,IAAO;EAAG;AAC9G;AAAC"}
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":[
|
|
1
|
+
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export { PubsubAspect, PubsubAspect as default } from './pubsub.aspect';\n\nexport type { PubsubMain } from './pubsub.main.runtime';\nexport type { PubsubPreview } from './pubsub.preview.runtime';\nexport type { PubsubUI } from './pubsub.ui.runtime';\nexport { BitBaseEvent } from './bit-base-event';\nexport { usePubSub, PubSubRegistry, usePubSubIframe } from './pubsub-context';\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;EAAA;EAAA;IAAA;EAAA;EAAA;AAAA;AAKA;EAAA;EAAA;IAAA;EAAA;EAAA;AAAA;AACA;EAAA;EAAA;IAAA;EAAA;EAAA;AAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["PubSubNoParentError","Error","constructor","name"
|
|
1
|
+
{"version":3,"names":["PubSubNoParentError","Error","constructor","name"],"sources":["no-parent-error.ts"],"sourcesContent":["export class PubSubNoParentError extends Error {\n constructor() {\n super('could not connect to parent window');\n this.name = 'PubSubNoParentError';\n }\n}\n"],"mappings":";;;;;;AAAO,MAAMA,mBAAmB,SAASC,KAAK,CAAC;EAC7CC,WAAW,GAAG;IACZ,KAAK,CAAC,oCAAoC,CAAC;IAC3C,IAAI,CAACC,IAAI,GAAG,qBAAqB;EACnC;AACF;AAAC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import * as compositions_0 from '/home/circleci/Library/Caches/Bit/capsules/8891be5ad3d35bfc38b9cd90c0e05b598a5a55af/teambit.harmony_pubsub@0.0.
|
|
2
|
-
import * as overview_0 from '/home/circleci/Library/Caches/Bit/capsules/8891be5ad3d35bfc38b9cd90c0e05b598a5a55af/teambit.harmony_pubsub@0.0.
|
|
1
|
+
import * as compositions_0 from '/home/circleci/Library/Caches/Bit/capsules/8891be5ad3d35bfc38b9cd90c0e05b598a5a55af/teambit.harmony_pubsub@0.0.1112/dist/pubsub.composition.js';
|
|
2
|
+
import * as overview_0 from '/home/circleci/Library/Caches/Bit/capsules/8891be5ad3d35bfc38b9cd90c0e05b598a5a55af/teambit.harmony_pubsub@0.0.1112/dist/pubsub.docs.mdx';
|
|
3
3
|
|
|
4
4
|
export const compositions = [compositions_0];
|
|
5
5
|
export const overview = [overview_0];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["
|
|
1
|
+
{"version":3,"names":["pubsubRegistry","createContext","undefined","createProvider","pubSubContext","PubSubProvider","children","usePubSub","useContext","usePubSubIframe","ref","pubSub","useEffect","current","destroyConnection","connect"],"sources":["pubsub-context.tsx"],"sourcesContent":["import React, { createContext, useContext, useEffect, RefObject, ReactNode } from 'react';\n\nexport interface PubSubRegistry {\n /**\n * starts a connection to an iframe child.\n * Returns a destroy() function that will break the connection.\n */\n connect(ref: HTMLIFrameElement): () => void;\n}\n\nexport const pubsubRegistry = createContext<PubSubRegistry | undefined>(undefined);\n\nexport function createProvider(pubSubContext: PubSubRegistry) {\n const PubSubProvider = ({ children }: { children: ReactNode }) => (\n <pubsubRegistry.Provider value={pubSubContext}>{children}</pubsubRegistry.Provider>\n );\n\n return PubSubProvider;\n}\n\nexport function usePubSub() {\n return useContext(pubsubRegistry);\n}\n\nexport function usePubSubIframe(ref?: RefObject<HTMLIFrameElement>) {\n const pubSub = usePubSub();\n\n useEffect(() => {\n if (!ref?.current || !pubSub) return () => {};\n\n const destroyConnection = pubSub.connect(ref.current);\n return () => destroyConnection();\n }, [ref?.current, pubSub]);\n}\n"],"mappings":";;;;;;;;;AAAA;EAAA;EAAA;IAAA;EAAA;EAAA;AAAA;AAA0F;AAAA;AAUnF,MAAMA,cAAc,gBAAG,IAAAC,sBAAa,EAA6BC,SAAS,CAAC;AAAC;AAE5E,SAASC,cAAc,CAACC,aAA6B,EAAE;EAC5D,MAAMC,cAAc,GAAG,CAAC;IAAEC;EAAkC,CAAC,kBAC3D,+BAAC,cAAc,CAAC,QAAQ;IAAC,KAAK,EAAEF;EAAc,GAAEE,QAAQ,CACzD;EAED,OAAOD,cAAc;AACvB;AAEO,SAASE,SAAS,GAAG;EAC1B,OAAO,IAAAC,mBAAU,EAACR,cAAc,CAAC;AACnC;AAEO,SAASS,eAAe,CAACC,GAAkC,EAAE;EAClE,MAAMC,MAAM,GAAGJ,SAAS,EAAE;EAE1B,IAAAK,kBAAS,EAAC,MAAM;IACd,IAAI,EAACF,GAAG,aAAHA,GAAG,eAAHA,GAAG,CAAEG,OAAO,KAAI,CAACF,MAAM,EAAE,OAAO,MAAM,CAAC,CAAC;IAE7C,MAAMG,iBAAiB,GAAGH,MAAM,CAACI,OAAO,CAACL,GAAG,CAACG,OAAO,CAAC;IACrD,OAAO,MAAMC,iBAAiB,EAAE;EAClC,CAAC,EAAE,CAACJ,GAAG,aAAHA,GAAG,uBAAHA,GAAG,CAAEG,OAAO,EAAEF,MAAM,CAAC,CAAC;AAC5B"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["
|
|
1
|
+
{"version":3,"names":["PubsubAspect","Aspect","create","id","dependencies"],"sources":["pubsub.aspect.ts"],"sourcesContent":["import { Aspect } from '@teambit/harmony';\n\nexport const PubsubAspect = Aspect.create({\n id: 'teambit.harmony/pubsub',\n dependencies: [],\n});\n\nexport default PubsubAspect;\n"],"mappings":";;;;;;AAAA;EAAA;EAAA;IAAA;EAAA;EAAA;AAAA;AAEO,MAAMA,YAAY,GAAGC,iBAAM,CAACC,MAAM,CAAC;EACxCC,EAAE,EAAE,wBAAwB;EAC5BC,YAAY,EAAE;AAChB,CAAC,CAAC;AAAC;AAAA,eAEYJ,YAAY;AAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["
|
|
1
|
+
{"version":3,"names":["Logo","height","display","justifyContent","width"],"sources":["pubsub.composition.tsx"],"sourcesContent":["import React from 'react';\n\nexport const Logo = () => (\n <div style={{ height: '100%', display: 'flex', justifyContent: 'center' }}>\n <img style={{ width: 70 }} src=\"https://static.bit.dev/extensions-icons/pubsub.svg\" />\n </div>\n);\n"],"mappings":";;;;;;;AAAA;EAAA;EAAA;IAAA;EAAA;EAAA;AAAA;AAEO,MAAMA,IAAI,GAAG,mBAClB;EAAK,KAAK,EAAE;IAAEC,MAAM,EAAE,MAAM;IAAEC,OAAO,EAAE,MAAM;IAAEC,cAAc,EAAE;EAAS;AAAE,gBACxE;EAAK,KAAK,EAAE;IAAEC,KAAK,EAAE;EAAG,CAAE;EAAC,GAAG,EAAC;AAAoD,EAAG,CAEzF;AAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["
|
|
1
|
+
{"version":3,"names":["PubsubMain","topicUUID","topicMap","sub","callback","createOrGetTopic","push","pub","event","forEach","unsubscribeAll","topicId","provider","MainRuntime","PubsubAspect","addRuntime"],"sources":["pubsub.main.runtime.ts"],"sourcesContent":["import { MainRuntime } from '@teambit/cli';\n\nimport { BitBaseEvent } from './bit-base-event';\nimport { PubsubAspect } from './pubsub.aspect';\n\nexport class PubsubMain {\n private topicMap = {};\n\n private createOrGetTopic = (topicUUID) => {\n this.topicMap[topicUUID] = this.topicMap[topicUUID] || [];\n };\n\n public sub(topicUUID, callback) {\n this.createOrGetTopic(topicUUID);\n this.topicMap[topicUUID].push(callback);\n }\n\n public pub(topicUUID, event: BitBaseEvent<any>) {\n this.createOrGetTopic(topicUUID);\n this.topicMap[topicUUID].forEach((callback) => callback(event));\n }\n\n unsubscribeAll(topicId: string) {\n delete this.topicMap[topicId];\n }\n\n static runtime = MainRuntime;\n\n static async provider() {\n return new PubsubMain();\n }\n}\n\nPubsubAspect.addRuntime(PubsubMain);\n"],"mappings":";;;;;;;;;;;;;;;AAAA;EAAA;EAAA;IAAA;EAAA;EAAA;AAAA;AAGA;EAAA;EAAA;IAAA;EAAA;EAAA;AAAA;AAEO,MAAMA,UAAU,CAAC;EAAA;IAAA,kDACH,CAAC,CAAC;IAAA,0DAEOC,SAAS,IAAK;MACxC,IAAI,CAACC,QAAQ,CAACD,SAAS,CAAC,GAAG,IAAI,CAACC,QAAQ,CAACD,SAAS,CAAC,IAAI,EAAE;IAC3D,CAAC;EAAA;EAEME,GAAG,CAACF,SAAS,EAAEG,QAAQ,EAAE;IAC9B,IAAI,CAACC,gBAAgB,CAACJ,SAAS,CAAC;IAChC,IAAI,CAACC,QAAQ,CAACD,SAAS,CAAC,CAACK,IAAI,CAACF,QAAQ,CAAC;EACzC;EAEOG,GAAG,CAACN,SAAS,EAAEO,KAAwB,EAAE;IAC9C,IAAI,CAACH,gBAAgB,CAACJ,SAAS,CAAC;IAChC,IAAI,CAACC,QAAQ,CAACD,SAAS,CAAC,CAACQ,OAAO,CAAEL,QAAQ,IAAKA,QAAQ,CAACI,KAAK,CAAC,CAAC;EACjE;EAEAE,cAAc,CAACC,OAAe,EAAE;IAC9B,OAAO,IAAI,CAACT,QAAQ,CAACS,OAAO,CAAC;EAC/B;EAIA,aAAaC,QAAQ,GAAG;IACtB,OAAO,IAAIZ,UAAU,EAAE;EACzB;AACF;AAAC;AAAA,gCA1BYA,UAAU,aAqBJa,kBAAW;AAO9BC,sBAAY,CAACC,UAAU,CAACf,UAAU,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["
|
|
1
|
+
{"version":3,"names":["PubsubPreview","EventEmitter2","retries","PubSubNoParentError","connectToParent","timeout","methods","pub","handleMessageFromParent","promise","then","parentPubsub","_parentPubsub","catch","e","code","ErrorCode","ConnectionTimeout","connectToParentPubSub","topic","message","events","emit","sub","callback","emitter","on","unSub","off","event","err","console","error","inIframe","isBrowser","window","self","top","provider","pubsubPreview","PreviewRuntime","PubsubAspect","addRuntime"],"sources":["pubsub.preview.runtime.ts"],"sourcesContent":["/**\n * Please Notice: This file will run in the preview iframe.\n */\n\nimport { PreviewRuntime } from '@teambit/preview';\nimport { isBrowser } from '@teambit/ui-foundation.ui.is-browser';\n\nimport { EventEmitter2 } from 'eventemitter2';\nimport { connectToParent, ErrorCode } from 'penpal';\n\nimport { BitBaseEvent } from './bit-base-event';\nimport { PubSubNoParentError } from './no-parent-error';\nimport { PubsubAspect } from './pubsub.aspect';\nimport { Callback } from './types';\n\ntype ParentMethods = {\n pub: (topic: string, event: BitBaseEvent<any>) => Promise<any>;\n};\n\nexport class PubsubPreview {\n private _parentPubsub?: ParentMethods;\n private events = new EventEmitter2();\n\n public sub(topic: string, callback: Callback) {\n const emitter = this.events;\n emitter.on(topic, callback);\n\n const unSub = () => {\n emitter.off(topic, callback);\n };\n return unSub;\n }\n\n public pub(topic: string, event: BitBaseEvent<any>) {\n this.events.emit(topic, event);\n this._parentPubsub?.pub(topic, event).catch((err) => {\n // eslint-disable-next-line no-console\n console.error('[Pubsub.preview]', err);\n });\n }\n\n private inIframe() {\n try {\n return isBrowser && window.self !== window.top;\n } catch (e: any) {\n return false;\n }\n }\n\n private connectToParentPubSub = (retries = 10): Promise<ParentMethods | undefined> => {\n if (retries <= 0) throw new PubSubNoParentError();\n\n return connectToParent<ParentMethods>({\n timeout: 300,\n methods: {\n pub: this.handleMessageFromParent,\n },\n })\n .promise.then((parentPubsub) => (this._parentPubsub = parentPubsub))\n .catch((e: any) => {\n if (e.code !== ErrorCode.ConnectionTimeout) throw e;\n\n return this.connectToParentPubSub(retries - 1);\n });\n };\n\n private handleMessageFromParent = (topic: string, message: BitBaseEvent<any>) => {\n this.events.emit(topic, message);\n };\n\n static runtime = PreviewRuntime;\n\n static async provider(): Promise<PubsubPreview> {\n const pubsubPreview = new PubsubPreview();\n\n if (pubsubPreview.inIframe()) {\n pubsubPreview.connectToParentPubSub().catch((err) => {\n // parent window is not required to accept connections\n if (err instanceof PubSubNoParentError) return;\n\n // eslint-disable-next-line no-console\n console.error('[Pubsub.preview]', err);\n });\n }\n\n return pubsubPreview;\n }\n}\n\nPubsubAspect.addRuntime(PubsubPreview);\n"],"mappings":";;;;;;;;;;;;;;;AAIA;EAAA;EAAA;IAAA;EAAA;EAAA;AAAA;AACA;EAAA;EAAA;IAAA;EAAA;EAAA;AAAA;AAEA;EAAA;EAAA;IAAA;EAAA;EAAA;AAAA;AACA;EAAA;EAAA;IAAA;EAAA;EAAA;AAAA;AAGA;EAAA;EAAA;IAAA;EAAA;EAAA;AAAA;AACA;EAAA;EAAA;IAAA;EAAA;EAAA;AAAA;AAZA;AACA;AACA;;AAiBO,MAAMA,aAAa,CAAC;EAAA;IAAA;IAAA,gDAER,KAAIC,6BAAa,GAAE;IAAA,+DA4BJ,CAACC,OAAO,GAAG,EAAE,KAAyC;MACpF,IAAIA,OAAO,IAAI,CAAC,EAAE,MAAM,KAAIC,oCAAmB,GAAE;MAEjD,OAAO,IAAAC,yBAAe,EAAgB;QACpCC,OAAO,EAAE,GAAG;QACZC,OAAO,EAAE;UACPC,GAAG,EAAE,IAAI,CAACC;QACZ;MACF,CAAC,CAAC,CACCC,OAAO,CAACC,IAAI,CAAEC,YAAY,IAAM,IAAI,CAACC,aAAa,GAAGD,YAAa,CAAC,CACnEE,KAAK,CAAEC,CAAM,IAAK;QACjB,IAAIA,CAAC,CAACC,IAAI,KAAKC,mBAAS,CAACC,iBAAiB,EAAE,MAAMH,CAAC;QAEnD,OAAO,IAAI,CAACI,qBAAqB,CAAChB,OAAO,GAAG,CAAC,CAAC;MAChD,CAAC,CAAC;IACN,CAAC;IAAA,iEAEiC,CAACiB,KAAa,EAAEC,OAA0B,KAAK;MAC/E,IAAI,CAACC,MAAM,CAACC,IAAI,CAACH,KAAK,EAAEC,OAAO,CAAC;IAClC,CAAC;EAAA;EA7CMG,GAAG,CAACJ,KAAa,EAAEK,QAAkB,EAAE;IAC5C,MAAMC,OAAO,GAAG,IAAI,CAACJ,MAAM;IAC3BI,OAAO,CAACC,EAAE,CAACP,KAAK,EAAEK,QAAQ,CAAC;IAE3B,MAAMG,KAAK,GAAG,MAAM;MAClBF,OAAO,CAACG,GAAG,CAACT,KAAK,EAAEK,QAAQ,CAAC;IAC9B,CAAC;IACD,OAAOG,KAAK;EACd;EAEOpB,GAAG,CAACY,KAAa,EAAEU,KAAwB,EAAE;IAAA;IAClD,IAAI,CAACR,MAAM,CAACC,IAAI,CAACH,KAAK,EAAEU,KAAK,CAAC;IAC9B,2BAAI,CAACjB,aAAa,wDAAlB,oBAAoBL,GAAG,CAACY,KAAK,EAAEU,KAAK,CAAC,CAAChB,KAAK,CAAEiB,GAAG,IAAK;MACnD;MACAC,OAAO,CAACC,KAAK,CAAC,kBAAkB,EAAEF,GAAG,CAAC;IACxC,CAAC,CAAC;EACJ;EAEQG,QAAQ,GAAG;IACjB,IAAI;MACF,OAAOC,2BAAS,IAAIC,MAAM,CAACC,IAAI,KAAKD,MAAM,CAACE,GAAG;IAChD,CAAC,CAAC,OAAOvB,CAAM,EAAE;MACf,OAAO,KAAK;IACd;EACF;EAyBA,aAAawB,QAAQ,GAA2B;IAC9C,MAAMC,aAAa,GAAG,IAAIvC,aAAa,EAAE;IAEzC,IAAIuC,aAAa,CAACN,QAAQ,EAAE,EAAE;MAC5BM,aAAa,CAACrB,qBAAqB,EAAE,CAACL,KAAK,CAAEiB,GAAG,IAAK;QACnD;QACA,IAAIA,GAAG,YAAY3B,oCAAmB,EAAE;;QAExC;QACA4B,OAAO,CAACC,KAAK,CAAC,kBAAkB,EAAEF,GAAG,CAAC;MACxC,CAAC,CAAC;IACJ;IAEA,OAAOS,aAAa;EACtB;AACF;AAAC;AAAA,gCApEYvC,aAAa,aAmDPwC,yBAAc;AAmBjCC,sBAAY,CAACC,UAAU,CAAC1C,aAAa,CAAC"}
|
|
@@ -53,9 +53,6 @@ class PubsubUI {
|
|
|
53
53
|
constructor() {
|
|
54
54
|
(0, _defineProperty2().default)(this, "childApi", void 0);
|
|
55
55
|
(0, _defineProperty2().default)(this, "events", new (_eventemitter().EventEmitter2)());
|
|
56
|
-
/**
|
|
57
|
-
* subscribe to events
|
|
58
|
-
*/
|
|
59
56
|
(0, _defineProperty2().default)(this, "sub", (topic, callback) => {
|
|
60
57
|
const events = this.events;
|
|
61
58
|
events.on(topic, callback);
|
|
@@ -64,9 +61,6 @@ class PubsubUI {
|
|
|
64
61
|
};
|
|
65
62
|
return unSub;
|
|
66
63
|
});
|
|
67
|
-
/**
|
|
68
|
-
* publish event to all subscribers, including nested iframes.
|
|
69
|
-
*/
|
|
70
64
|
(0, _defineProperty2().default)(this, "pub", (topic, event, {
|
|
71
65
|
propagate
|
|
72
66
|
} = {}) => {
|
|
@@ -93,15 +87,9 @@ class PubsubUI {
|
|
|
93
87
|
};
|
|
94
88
|
return destroy;
|
|
95
89
|
});
|
|
96
|
-
/**
|
|
97
|
-
* publish event to all subscribers in this window
|
|
98
|
-
*/
|
|
99
90
|
(0, _defineProperty2().default)(this, "emitEvent", (topic, event) => {
|
|
100
91
|
this.events.emit(topic, event);
|
|
101
92
|
});
|
|
102
|
-
/**
|
|
103
|
-
* publish event to nested iframes
|
|
104
|
-
*/
|
|
105
93
|
(0, _defineProperty2().default)(this, "pubToChild", (topic, event) => {
|
|
106
94
|
var _this$childApi;
|
|
107
95
|
return (_this$childApi = this.childApi) === null || _this$childApi === void 0 ? void 0 : _this$childApi.pub(topic, event);
|
|
@@ -112,6 +100,11 @@ class PubsubUI {
|
|
|
112
100
|
connect: this.connectToIframe
|
|
113
101
|
});
|
|
114
102
|
}
|
|
103
|
+
|
|
104
|
+
/**
|
|
105
|
+
* publish event to all subscribers in this window
|
|
106
|
+
*/
|
|
107
|
+
|
|
115
108
|
static async provider([uiUI]) {
|
|
116
109
|
const pubsubUI = new PubsubUI();
|
|
117
110
|
const reactContext = pubsubUI.getPubSubContext();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["
|
|
1
|
+
{"version":3,"names":["PubsubUI","EventEmitter2","topic","callback","events","on","unSub","off","event","propagate","emitEvent","pubToChild","iframe","connection","connectToChild","methods","pub","promise","then","childConnection","childApi","catch","err","console","error","destroy","emit","getPubSubContext","createProvider","connect","connectToIframe","provider","uiUI","pubsubUI","reactContext","registerRenderHooks","UIRuntime","UIAspect","PubsubAspect","addRuntime"],"sources":["pubsub.ui.runtime.ts"],"sourcesContent":["import { UIRuntime, UIAspect, UiUI } from '@teambit/ui';\nimport { EventEmitter2 } from 'eventemitter2';\nimport { connectToChild } from 'penpal';\nimport type { AsyncMethodReturns } from 'penpal/lib/types';\nimport { BitBaseEvent } from './bit-base-event';\nimport { PubsubAspect } from './pubsub.aspect';\nimport { createProvider } from './pubsub-context';\nimport { Callback } from './types';\n\ntype PubOptions = {\n /** forward the event to adjacent windows (including the preview iframe) */\n propagate?: boolean;\n};\n\ntype ChildMethods = {\n pub: (topic: string, event: BitBaseEvent<any>) => any;\n};\nexport class PubsubUI {\n private childApi?: AsyncMethodReturns<ChildMethods>;\n private events = new EventEmitter2();\n\n /**\n * subscribe to events\n */\n public sub = (topic: string, callback: Callback) => {\n const events = this.events;\n events.on(topic, callback);\n\n const unSub = () => {\n events.off(topic, callback);\n };\n\n return unSub;\n };\n\n /**\n * publish event to all subscribers, including nested iframes.\n */\n public pub = (topic: string, event: BitBaseEvent<any>, { propagate }: PubOptions = {}) => {\n this.emitEvent(topic, event);\n\n // opt-in to forward to iframe, as we would not want 'private' messages automatically passing to iframe\n if (propagate) {\n this.pubToChild(topic, event);\n }\n };\n\n private connectToIframe = (iframe: HTMLIFrameElement) => {\n const connection = connectToChild<ChildMethods>({\n iframe,\n methods: {\n pub: this.emitEvent,\n },\n });\n\n connection.promise\n .then((childConnection) => (this.childApi = childConnection))\n .catch((err) => {\n // eslint-disable-next-line no-console\n console.error('[Pubsub.ui]', 'failed connecting to child iframe:', err);\n });\n\n const destroy = () => {\n connection && connection.destroy();\n };\n return destroy;\n };\n\n getPubSubContext() {\n return createProvider({\n connect: this.connectToIframe,\n });\n }\n\n /**\n * publish event to all subscribers in this window\n */\n private emitEvent = (topic: string, event: BitBaseEvent<any>) => {\n this.events.emit(topic, event);\n };\n\n /**\n * publish event to nested iframes\n */\n private pubToChild = (topic: string, event: BitBaseEvent<any>) => {\n return this.childApi?.pub(topic, event);\n };\n\n static runtime = UIRuntime;\n static dependencies = [UIAspect];\n\n static async provider([uiUI]: [UiUI]) {\n const pubsubUI = new PubsubUI();\n\n const reactContext = pubsubUI.getPubSubContext();\n\n if (uiUI) uiUI.registerRenderHooks({ reactContext });\n\n return pubsubUI;\n }\n}\n\nPubsubAspect.addRuntime(PubsubUI);\n"],"mappings":";;;;;;;;;;;;;;;;AAAA;EAAA;EAAA;IAAA;EAAA;EAAA;AAAA;AACA;EAAA;EAAA;IAAA;EAAA;EAAA;AAAA;AACA;EAAA;EAAA;IAAA;EAAA;EAAA;AAAA;AAGA;EAAA;EAAA;IAAA;EAAA;EAAA;AAAA;AACA;EAAA;EAAA;IAAA;EAAA;EAAA;AAAA;AAWO,MAAMA,QAAQ,CAAC;EAAA;IAAA;IAAA,gDAEH,KAAIC,6BAAa,GAAE;IAAA,6CAKvB,CAACC,KAAa,EAAEC,QAAkB,KAAK;MAClD,MAAMC,MAAM,GAAG,IAAI,CAACA,MAAM;MAC1BA,MAAM,CAACC,EAAE,CAACH,KAAK,EAAEC,QAAQ,CAAC;MAE1B,MAAMG,KAAK,GAAG,MAAM;QAClBF,MAAM,CAACG,GAAG,CAACL,KAAK,EAAEC,QAAQ,CAAC;MAC7B,CAAC;MAED,OAAOG,KAAK;IACd,CAAC;IAAA,6CAKY,CAACJ,KAAa,EAAEM,KAAwB,EAAE;MAAEC;IAAsB,CAAC,GAAG,CAAC,CAAC,KAAK;MACxF,IAAI,CAACC,SAAS,CAACR,KAAK,EAAEM,KAAK,CAAC;;MAE5B;MACA,IAAIC,SAAS,EAAE;QACb,IAAI,CAACE,UAAU,CAACT,KAAK,EAAEM,KAAK,CAAC;MAC/B;IACF,CAAC;IAAA,yDAE0BI,MAAyB,IAAK;MACvD,MAAMC,UAAU,GAAG,IAAAC,wBAAc,EAAe;QAC9CF,MAAM;QACNG,OAAO,EAAE;UACPC,GAAG,EAAE,IAAI,CAACN;QACZ;MACF,CAAC,CAAC;MAEFG,UAAU,CAACI,OAAO,CACfC,IAAI,CAAEC,eAAe,IAAM,IAAI,CAACC,QAAQ,GAAGD,eAAgB,CAAC,CAC5DE,KAAK,CAAEC,GAAG,IAAK;QACd;QACAC,OAAO,CAACC,KAAK,CAAC,aAAa,EAAE,oCAAoC,EAAEF,GAAG,CAAC;MACzE,CAAC,CAAC;MAEJ,MAAMG,OAAO,GAAG,MAAM;QACpBZ,UAAU,IAAIA,UAAU,CAACY,OAAO,EAAE;MACpC,CAAC;MACD,OAAOA,OAAO;IAChB,CAAC;IAAA,mDAWmB,CAACvB,KAAa,EAAEM,KAAwB,KAAK;MAC/D,IAAI,CAACJ,MAAM,CAACsB,IAAI,CAACxB,KAAK,EAAEM,KAAK,CAAC;IAChC,CAAC;IAAA,oDAKoB,CAACN,KAAa,EAAEM,KAAwB,KAAK;MAAA;MAChE,yBAAO,IAAI,CAACY,QAAQ,mDAAb,eAAeJ,GAAG,CAACd,KAAK,EAAEM,KAAK,CAAC;IACzC,CAAC;EAAA;EAlBDmB,gBAAgB,GAAG;IACjB,OAAO,IAAAC,+BAAc,EAAC;MACpBC,OAAO,EAAE,IAAI,CAACC;IAChB,CAAC,CAAC;EACJ;;EAEA;AACF;AACA;;EAeE,aAAaC,QAAQ,CAAC,CAACC,IAAI,CAAS,EAAE;IACpC,MAAMC,QAAQ,GAAG,IAAIjC,QAAQ,EAAE;IAE/B,MAAMkC,YAAY,GAAGD,QAAQ,CAACN,gBAAgB,EAAE;IAEhD,IAAIK,IAAI,EAAEA,IAAI,CAACG,mBAAmB,CAAC;MAAED;IAAa,CAAC,CAAC;IAEpD,OAAOD,QAAQ;EACjB;AACF;AAAC;AAAA,gCAnFYjC,QAAQ,aAuEFoC,eAAS;AAAA,gCAvEfpC,QAAQ,kBAwEG,CAACqC,cAAQ,CAAC;AAalCC,sBAAY,CAACC,UAAU,CAACvC,QAAQ,CAAC"}
|
|
Binary file
|
package/package.json
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@teambit/pubsub",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.1112",
|
|
4
4
|
"homepage": "https://bit.cloud/teambit/harmony/pubsub",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"componentId": {
|
|
7
7
|
"scope": "teambit.harmony",
|
|
8
8
|
"name": "pubsub",
|
|
9
|
-
"version": "0.0.
|
|
9
|
+
"version": "0.0.1112"
|
|
10
10
|
},
|
|
11
11
|
"dependencies": {
|
|
12
12
|
"eventemitter2": "6.4.4",
|
|
@@ -14,10 +14,10 @@
|
|
|
14
14
|
"core-js": "^3.0.0",
|
|
15
15
|
"@babel/runtime": "7.20.0",
|
|
16
16
|
"@teambit/harmony": "0.4.6",
|
|
17
|
-
"@teambit/cli": "0.0.
|
|
18
|
-
"@teambit/preview": "0.0.
|
|
17
|
+
"@teambit/cli": "0.0.744",
|
|
18
|
+
"@teambit/preview": "0.0.1112",
|
|
19
19
|
"@teambit/ui-foundation.ui.is-browser": "0.0.495",
|
|
20
|
-
"@teambit/ui": "0.0.
|
|
20
|
+
"@teambit/ui": "0.0.1112"
|
|
21
21
|
},
|
|
22
22
|
"devDependencies": {
|
|
23
23
|
"@types/react": "^17.0.8",
|
|
@@ -28,7 +28,7 @@
|
|
|
28
28
|
"@types/testing-library__jest-dom": "5.9.5"
|
|
29
29
|
},
|
|
30
30
|
"peerDependencies": {
|
|
31
|
-
"@teambit/legacy": "1.0.
|
|
31
|
+
"@teambit/legacy": "1.0.524",
|
|
32
32
|
"react": "^16.8.0 || ^17.0.0",
|
|
33
33
|
"react-dom": "^16.8.0 || ^17.0.0"
|
|
34
34
|
},
|
|
Binary file
|