@typexim/aics-embed-sdk 0.0.14 → 0.0.16

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 CHANGED
@@ -9,11 +9,15 @@ import {
9
9
  subscribe,
10
10
  sendMessage,
11
11
  getLoginInfo,
12
+ registerCrossOriginApi,
12
13
  } from '@typexim/aics-embed-sdk';
13
14
 
14
15
  initialize();
15
16
  isLogin();
16
17
  getLoginInfo();
18
+ registerCrossOriginApi('test', async () => {
19
+ return result;
20
+ });
17
21
 
18
22
  const unsubscribe = subscribe(SubscribeType.feed, (args) => {
19
23
  console.log('feed改变', args);
package/dist/index.es.js CHANGED
@@ -1 +1 @@
1
- import*as t from"comlink";let n=null;const r=async()=>{try{const{port:r}=await(async()=>new Promise((t,n)=>{const r=new MessageChannel;window.parent.postMessage({type:"INIT_CROSS_ORIGIN_PORT"},"*",[r.port1]),r.port2.start(),r.port2.addEventListener("message",e=>{"INIT_CROSS_ORIGIN_PORT"===e.data.type&&e.data.success?t({port:r.port2,isSuccess:!0}):n(new Error("初始化连接失败"))}),r.port2.addEventListener("messageerror",t=>{n(t)})}))();return n=t.wrap(r),!0}catch(t){return console.error("❌ iframe: 连接失败",t),!1}},e=()=>n,s=(n,r)=>{const s=e();if(!s)return()=>{};const o=t.proxy(t=>{r(t)}),a=`${Date.now().toString(36)}-${Math.random().toString(36).substring(2,8)}`;return s.subscribe(n,o,a),()=>{((t,n)=>{const r=e();r&&r.unsubscribe(t,n)})(n,a)}},o=async()=>{const t=e();if(!t)return!1;return await t.isLogin()},a=async()=>{const t=e();if(!t)return null;return await t.getLoginInfo()},i=async t=>{const n=e();if(!n)return!1;return await n.sendMessage(t)};var c,u;!function(t){t.text="text"}(c||(c={})),function(t){t.feed="feed",t.login="login"}(u||(u={}));export{c as MessageType,u as SubscribeType,a as getLoginInfo,r as initialize,o as isLogin,i as sendMessage,s as subscribe};
1
+ import*as t from"comlink";const n={},r=(t,r)=>{n[t]=r},e={callMethod:async(t,...r)=>{const e=n[t];if(!e)throw new Error(`method ${t} not found`);return await e(...r)}};let o=null;const s=async()=>{try{const{port:n}=await(async()=>new Promise((t,n)=>{const r=new MessageChannel;window.parent.postMessage({type:"INIT_CROSS_ORIGIN_PORT"},"*",[r.port1]),r.port2.start(),r.port2.addEventListener("message",e=>{"INIT_CROSS_ORIGIN_PORT"===e.data.type&&e.data.success?t({port:r.port2,isSuccess:!0}):n(new Error("初始化连接失败"))}),r.port2.addEventListener("messageerror",t=>{n(t)})}))();return o=t.wrap(n),(n=>{t.expose(e,n)})(n),!0}catch(t){return console.error("❌ iframe: 连接失败",t),!1}},a=()=>o,c=(n,r)=>{const e=a();if(!e)return()=>{};const o=t.proxy(t=>{r(t)}),s=`${Date.now().toString(36)}-${Math.random().toString(36).substring(2,8)}`;return e.subscribe(n,o,s),()=>{((t,n)=>{const r=a();r&&r.unsubscribe(t,n)})(n,s)}},i=async()=>{const t=a();if(!t)return!1;return await t.isLogin()},u=async()=>{const t=a();if(!t)return null;return await t.getLoginInfo()},p=async t=>{const n=a();if(!n)return!1;return await n.sendMessage(t)};var d,w;!function(t){t.text="text"}(d||(d={})),function(t){t.feed="feed",t.login="login"}(w||(w={}));export{d as MessageType,w as SubscribeType,u as getLoginInfo,s as initialize,i as isLogin,r as registerCrossOriginApi,p as sendMessage,c as subscribe};
package/dist/index.js CHANGED
@@ -1 +1 @@
1
- "use strict";function e(e){var t=Object.create(null);return e&&Object.keys(e).forEach(function(r){if("default"!==r){var s=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,s.get?s:{enumerable:!0,get:function(){return e[r]}})}}),t.default=e,Object.freeze(t)}var t=e(require("comlink"));let r=null;const s=()=>r;var n;exports.MessageType=void 0,(exports.MessageType||(exports.MessageType={})).text="text",exports.SubscribeType=void 0,(n=exports.SubscribeType||(exports.SubscribeType={})).feed="feed",n.login="login",exports.getLoginInfo=async()=>{const e=s();if(!e)return null;return await e.getLoginInfo()},exports.initialize=async()=>{try{const{port:e}=await(async()=>new Promise((e,t)=>{const r=new MessageChannel;window.parent.postMessage({type:"INIT_CROSS_ORIGIN_PORT"},"*",[r.port1]),r.port2.start(),r.port2.addEventListener("message",s=>{"INIT_CROSS_ORIGIN_PORT"===s.data.type&&s.data.success?e({port:r.port2,isSuccess:!0}):t(new Error("初始化连接失败"))}),r.port2.addEventListener("messageerror",e=>{t(e)})}))();return r=t.wrap(e),!0}catch(e){return console.error("❌ iframe: 连接失败",e),!1}},exports.isLogin=async()=>{const e=s();if(!e)return!1;return await e.isLogin()},exports.sendMessage=async e=>{const t=s();if(!t)return!1;return await t.sendMessage(e)},exports.subscribe=(e,r)=>{const n=s();if(!n)return()=>{};const o=t.proxy(e=>{r(e)}),a=`${Date.now().toString(36)}-${Math.random().toString(36).substring(2,8)}`;return n.subscribe(e,o,a),()=>{((e,t)=>{const r=s();r&&r.unsubscribe(e,t)})(e,a)}};
1
+ "use strict";function e(e){var t=Object.create(null);return e&&Object.keys(e).forEach(function(r){if("default"!==r){var s=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,s.get?s:{enumerable:!0,get:function(){return e[r]}})}}),t.default=e,Object.freeze(t)}var t=e(require("comlink"));const r={},s={callMethod:async(e,...t)=>{const s=r[e];if(!s)throw new Error(`method ${e} not found`);return await s(...t)}};let n=null;const o=()=>n;var i;exports.MessageType=void 0,(exports.MessageType||(exports.MessageType={})).text="text",exports.SubscribeType=void 0,(i=exports.SubscribeType||(exports.SubscribeType={})).feed="feed",i.login="login",exports.getLoginInfo=async()=>{const e=o();if(!e)return null;return await e.getLoginInfo()},exports.initialize=async()=>{try{const{port:e}=await(async()=>new Promise((e,t)=>{const r=new MessageChannel;window.parent.postMessage({type:"INIT_CROSS_ORIGIN_PORT"},"*",[r.port1]),r.port2.start(),r.port2.addEventListener("message",s=>{"INIT_CROSS_ORIGIN_PORT"===s.data.type&&s.data.success?e({port:r.port2,isSuccess:!0}):t(new Error("初始化连接失败"))}),r.port2.addEventListener("messageerror",e=>{t(e)})}))();return n=t.wrap(e),(e=>{t.expose(s,e)})(e),!0}catch(e){return console.error("❌ iframe: 连接失败",e),!1}},exports.isLogin=async()=>{const e=o();if(!e)return!1;return await e.isLogin()},exports.registerCrossOriginApi=(e,t)=>{r[e]=t},exports.sendMessage=async e=>{const t=o();if(!t)return!1;return await t.sendMessage(e)},exports.subscribe=(e,r)=>{const s=o();if(!s)return()=>{};const n=t.proxy(e=>{r(e)}),i=`${Date.now().toString(36)}-${Math.random().toString(36).substring(2,8)}`;return s.subscribe(e,n,i),()=>{((e,t)=>{const r=o();r&&r.unsubscribe(e,t)})(e,i)}};
@@ -0,0 +1,7 @@
1
+ export declare const registerCrossOriginApi: (name: string, api: any) => void;
2
+ export declare const getMethod: (name: string) => any;
3
+ /**
4
+ * 初始化暴露跨域api
5
+ * @param port
6
+ */
7
+ export declare const initExposeCrossOriginApi: (port: MessagePort) => void;
@@ -1,3 +1,4 @@
1
+ export { registerCrossOriginApi } from './expose';
1
2
  export { initialize, subscribe } from './init';
2
3
  export * from './login';
3
4
  export * from './message';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@typexim/aics-embed-sdk",
3
- "version": "0.0.14",
3
+ "version": "0.0.16",
4
4
  "private": false,
5
5
  "license": "UNLICENSED",
6
6
  "type": "module",