@kbapp/js-bridge 1.0.7-alpha.0 → 1.0.8-alpha.0
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/.claude/settings.local.json +6 -0
- package/dist/es/lib/trigger-login.js +22 -26
- package/dist/es/utils/promise-cache.js +11 -7
- package/dist/types/lib/app-version-support.d.ts +2 -2
- package/dist/types/utils/promise-cache.d.ts +2 -2
- package/dist/umd/index.js +1 -1
- package/package.json +8 -4
- package/vitest.config.ts +18 -0
|
@@ -1,25 +1,25 @@
|
|
|
1
|
-
import { runBridgeApiResponse as
|
|
2
|
-
import { wrapAsync as
|
|
3
|
-
class
|
|
1
|
+
import { runBridgeApiResponse as p, runBridgeApi as g } from "../core/index.js";
|
|
2
|
+
import { wrapAsync as i } from "../utils/wrap-async.js";
|
|
3
|
+
class l {
|
|
4
4
|
}
|
|
5
|
-
const
|
|
5
|
+
const u = i(async () => (await p({
|
|
6
6
|
name: "OpenActRequest",
|
|
7
7
|
timeout: 5e3,
|
|
8
8
|
params: { type: 31, data: { requireLogin: !1 } }
|
|
9
|
-
})).data || null),
|
|
10
|
-
const e = /* @__PURE__ */ new Set(),
|
|
9
|
+
})).data || null), a = /* @__PURE__ */ (() => {
|
|
10
|
+
const e = /* @__PURE__ */ new Set(), n = /* @__PURE__ */ (() => {
|
|
11
11
|
let t;
|
|
12
|
-
const
|
|
12
|
+
const r = (o) => {
|
|
13
13
|
t = setTimeout(async () => {
|
|
14
|
-
const s = await
|
|
14
|
+
const s = await u();
|
|
15
15
|
if (!s)
|
|
16
|
-
return
|
|
17
|
-
e.forEach((
|
|
16
|
+
return r(++o);
|
|
17
|
+
e.forEach((c) => c(s)), e.clear();
|
|
18
18
|
}, ((s) => s === 0 ? 0 : s < 50 ? 600 : s < 80 ? 1e3 : 5e3)(o));
|
|
19
19
|
};
|
|
20
20
|
return {
|
|
21
21
|
start() {
|
|
22
|
-
t && clearTimeout(t), e.size > 0 &&
|
|
22
|
+
t && clearTimeout(t), e.size > 0 && r(0);
|
|
23
23
|
},
|
|
24
24
|
stop() {
|
|
25
25
|
t && clearTimeout(t);
|
|
@@ -33,28 +33,24 @@ const g = c(async () => (await i({
|
|
|
33
33
|
},
|
|
34
34
|
/** 移除监听 */
|
|
35
35
|
removeTask(t) {
|
|
36
|
-
e.delete(t), e.size === 0 &&
|
|
36
|
+
e.delete(t), e.size === 0 && n.stop();
|
|
37
37
|
},
|
|
38
38
|
/** 触发定时检测是否登录成功任务 */
|
|
39
39
|
triggerCheckTask() {
|
|
40
|
-
|
|
40
|
+
n.start();
|
|
41
41
|
}
|
|
42
42
|
};
|
|
43
|
-
})(),
|
|
44
|
-
|
|
43
|
+
})(), m = i(async () => {
|
|
44
|
+
a.triggerCheckTask(), await g({
|
|
45
45
|
name: "OpenActRequest",
|
|
46
|
-
params: { type: 31, data: { requireLogin: !0 } }
|
|
47
|
-
success(e) {
|
|
48
|
-
var a;
|
|
49
|
-
(a = e.data) != null && a.userId && r.triggerCheckTask();
|
|
50
|
-
}
|
|
46
|
+
params: { type: 31, data: { requireLogin: !0 } }
|
|
51
47
|
});
|
|
52
|
-
}),
|
|
53
|
-
|
|
48
|
+
}), f = (e) => (a.addTask(e), a.triggerCheckTask(), () => {
|
|
49
|
+
a.removeTask(e);
|
|
54
50
|
});
|
|
55
51
|
export {
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
52
|
+
l as AppLoginInfo,
|
|
53
|
+
u as getAppLoginInfo,
|
|
54
|
+
f as onLoopCheckAppLogin,
|
|
55
|
+
m as triggerAppLogin
|
|
60
56
|
};
|
|
@@ -1,11 +1,15 @@
|
|
|
1
|
-
function
|
|
2
|
-
|
|
3
|
-
return function(...
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
1
|
+
function s(r) {
|
|
2
|
+
const e = /* @__PURE__ */ new Map();
|
|
3
|
+
return function(...c) {
|
|
4
|
+
const t = JSON.stringify(c);
|
|
5
|
+
if (e.has(t))
|
|
6
|
+
return e.get(t);
|
|
7
|
+
const n = r(...c);
|
|
8
|
+
return e.set(t, n), Promise.resolve(n).catch(() => {
|
|
9
|
+
e.delete(t);
|
|
10
|
+
}), n;
|
|
7
11
|
};
|
|
8
12
|
}
|
|
9
13
|
export {
|
|
10
|
-
|
|
14
|
+
s as decorateCacheAsyncResult
|
|
11
15
|
};
|
|
@@ -36,6 +36,6 @@ const onTapLogin = decorateAppVersionSupport({ minVersion: 80711 }, () => {
|
|
|
36
36
|
})
|
|
37
37
|
```
|
|
38
38
|
*/
|
|
39
|
-
export declare function decorateAppVersionSupport<
|
|
39
|
+
export declare function decorateAppVersionSupport<T extends (...args: any[]) => any>(config: {
|
|
40
40
|
minVersion: number;
|
|
41
|
-
}, callback:
|
|
41
|
+
}, callback: T): (...params: Parameters<T>) => Promise<Awaited<ReturnType<T>>>;
|
package/dist/umd/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
(function(r,A){typeof exports=="object"&&typeof module<"u"?A(exports):typeof define=="function"&&define.amd?define(["exports"],A):(r=typeof globalThis<"u"?globalThis:r||self,A(r.kbBridge={}))})(this,function(r){"use strict";var V;function A(e){if(Object.prototype.toString.call(e)!=="[object Object]")return e;const
|
|
1
|
+
(function(r,A){typeof exports=="object"&&typeof module<"u"?A(exports):typeof define=="function"&&define.amd?define(["exports"],A):(r=typeof globalThis<"u"?globalThis:r||self,A(r.kbBridge={}))})(this,function(r){"use strict";var V;function A(e){if(Object.prototype.toString.call(e)!=="[object Object]")return e;const i={};return Object.keys(e).forEach(t=>{const o=e[t];o!=null&&(i[t]=Object.prototype.toString.call(o)==="[object Object]"?A(o):o)}),i}const p=class p{constructor(i){this.errorCode=i.errorCode,this.errorMsg=i.errorMsg}};p.UNKNOWN=new p({errorCode:1e3,errorMsg:"未知错误"}),p.UNSUPPORTED_VERSION=new p({errorCode:1001,errorMsg:"当前开吧版本不支持"}),p.TIMEOUT=new p({errorCode:1002,errorMsg:"执行超时"}),p.UNSUPPORTED_BRIDGE_ENV=new p({errorCode:1003,errorMsg:"请在开吧app内执行"});let f=p;const L=()=>{const e=(s,a,n)=>{var c="";typeof a=="function"&&(n=a,a={});var u={data:a===void 0?null:a};if(typeof n=="function"){var g="dscb"+window.dscb++;window[g]=n,u._dscbstub=g}if(u=JSON.stringify(u),window.flutter_inappwebview?window.flutter_inappwebview.callHandler&&(c=window.flutter_inappwebview.callHandler(""+s,u)):(window._dswk||navigator.userAgent.indexOf("_dsbridge")!=-1)&&(c=prompt("_flutterDsbridge="+s,u)),c instanceof Promise)return c;try{return JSON.parse(c||"{}").data}catch{console.error("callHandle异常,JSON.parse错误")}},i=()=>window.navigator.userAgent.includes("Android")?window.flutter_inappwebview&&window.flutter_inappwebview._platformReady:!0,t=(()=>{const s=[],a=setInterval(()=>{i()&&(clearInterval(a),s.forEach(n=>{e.apply(window,n)}),s.length=0)},500);return(...n)=>{s.push(n)}})();var o={default:void 0,callHandler:function(s,a,n){return i()?e(s,a,n):t(s,a,n)},register:function(s,a,n){var c=n?window._dsaf:window._dsf;window._dsInit||(window._dsInit=!0,setTimeout(function(){o.callHandler("_dsb.dsinit")},0)),typeof a=="object"?c._obs[s]=a:c[s]=a},registerHandler:function(s,a){this.register(s,a,!0)}};return function(){if(!window._dsf){var s={_dsf:{_obs:{}},_dsaf:{_obs:{}},dscb:0,jsBridge:o,_handleMessageFromNative:function(n){var c=JSON.parse(n.data),u={id:n.callbackId,complete:!0},g=this._dsf[n.method],E=this._dsaf[n.method],U=function(T,b){u.data=T.apply(b,c),o.callHandler("_dsb.returnValue",u)},B=function(T,b){c.push(function(ge,he){u.data=ge,u.complete=he!==!1,o.callHandler("_dsb.returnValue",u)}),T.apply(b,c)};if(g)U(g,this._dsf);else if(E)B(E,this._dsaf);else{var O=n.method.split(".");if(O.length<2)return;var C=O.pop(),D=O.join("."),P=this._dsf._obs,y=P[D]||{},w=y[C];if(w&&typeof w=="function"){U(w,y);return}if(P=this._dsaf._obs,y=P[D]||{},w=y[C],w&&typeof w=="function"){B(w,y);return}}}};for(var a in s)window[a]=s[a]}}(),o},S=(e=>/(kb)/i.test(e)?L():{registerHandler(i,t){throw f.UNSUPPORTED_BRIDGE_ENV},callHandler(i,t,o){throw f.UNSUPPORTED_BRIDGE_ENV}})((V=window==null?void 0:window.navigator)==null?void 0:V.userAgent),R=e=>new Promise((i,t)=>{var o,s,a;try{S.registerHandler(e.name,e.handler),(o=e.success)==null||o.call(e),i()}catch(n){(s=e.fail)==null||s.call(e,n),t(n)}finally{(a=e.complete)==null||a.call(e)}});function h(e){const i=t=>{let o;const s=n=>{var c;(!o||o==="success")&&(o="success",(c=t.success)==null||c.call(t,n))},a=n=>{var c;o||(o="error",(c=t.fail)==null||c.call(t,n))};t.timeout&&setTimeout(()=>{a(f.TIMEOUT)},t.timeout);try{S.callHandler(t.name,t.params,n=>{let c;try{typeof n=="string"&&/^\s*(\{|\[).*(\}|\])\s*$/.test(n)?c=JSON.parse(n.replace(/\n/g,"\\n").replace(/\r/g,"\\r")):c=n}catch{c=n}s(c)})}catch(n){a(n)}};return new Promise((t,o)=>{i({name:e.name,params:A(e.params),timeout:e.timeout,success:s=>{var a,n;(a=e.success)==null||a.call(e,s),(n=e.complete)==null||n.call(e),t(s)},fail:s=>{var a,n;(a=e.fail)==null||a.call(e,s),(n=e.complete)==null||n.call(e),o(s)}})})}function l(e){S.callHandler(e.name,e.params,i=>{})}function d(e){return async function(...t){const o=t[0]||{},{success:s,fail:a,complete:n,...c}=o;try{const u=await Promise.resolve(e(c));return s==null||s(u),u}catch(u){const g=u!=null&&u.errorCode?u:new f({errorCode:f.UNKNOWN.errorCode,errorMsg:String(u)});throw a==null||a(g),g}finally{n==null||n()}}}function H(e){const i=new Map;return function(...t){const o=JSON.stringify(t);if(i.has(o))return i.get(o);const s=e(...t);return i.set(o,s),Promise.resolve(s).catch(()=>{i.delete(o)}),s}}class j{}const m=d(H(()=>h({name:"OpenActRequest",timeout:5e3,params:{type:35,data:{}}}))),k=d(async e=>(await m()).vcode>=e.minVersion);function F(e,i){return(...t)=>k({minVersion:e.minVersion}).then(o=>o?i(...t):Promise.reject(new f({errorCode:f.UNSUPPORTED_VERSION.errorCode,errorMsg:`最低版本要求${e.minVersion}`})))}const J=d(()=>{l({name:"OpenActRequest",params:{type:56,data:null}})}),W=d(()=>{l({name:"OpenActRequest",params:{type:-1,data:{}}})}),I={microphone:{description:"用于发帖上传音频"},location:{description:"获取你选择的位置信息,用于线下导航服务"},camera:{description:"收集你选中的照片或视频信息 ,用于 发表评论、分享视频"}},Q=d(e=>(Object.assign(I,e),R({name:"getPermissionUsage",handler(i,t){t(I[i.permission])}}))),G=/(kb_flutter|kb_dsbridge_flutter|kb_ios|kb_android|kb_dsbridge_android)/i.test(window.navigator.userAgent),K=d(async e=>{const{kbKey:i,...t}=e,{data:o}=await h({name:"OpenActRequest",timeout:5e3,params:{type:51,data:t}});return o});var N=(e=>(e[e.FREE=1]="FREE",e[e.FORBID=2]="FORBID",e[e.REQUIRED=3]="REQUIRED",e))(N||{});class M{constructor(){this.textMin=0,this.textMax=1e3,this.imageMax=9,this.imageMin=0,this.audioRqr=1,this.videoRqr=1,this.mediaRqr=2,this.streetRqr=1}}function $(e){const i=new M;return e&&Object.keys(e).forEach(t=>{i[t]=e[t]}),{hint:e==null?void 0:e.placeholder,initialText:e==null?void 0:e.initialText,audio:i.audioRqr!==2,image:i.imageMax!==0,video:i.videoRqr!==2,address:i.streetRqr!==2,asset_video:i.mediaRqr!==2,audio_must:i.audioRqr===3,image_must:i.imageMin>0,asset_video_must:i.mediaRqr===3,max_image_count:i.imageMax,min_image_count:i.imageMin,video_must:i.videoRqr===3,text_must:i.textMin>0,content_max_length:i.textMax,content_min_length:i.textMin}}const z=d(async e=>h({name:"OpenActRequest",params:{type:13,data:(e==null?void 0:e.postRule)??{}}}).then(({data:i})=>{const{pic:t,...o}=i;return{images:t,...o}})),X=d(e=>{l({name:"OpenActRequest",params:{type:69,data:{eventId:e.eventName,trackParams:e.eventParams,ExtEventType:e.eventType}}})}),Y=d(e=>{l({name:"OpenActRequest",params:{type:1001,data:e}})}),Z=d(e=>{l({name:"OpenActRequest",params:{type:62,data:e}})}),x=d(e=>{l({name:"OpenActRequest",params:{type:63,data:e}})}),ee=d(()=>h({name:"OpenActRequest",params:{type:26,data:{}}})),te=d(e=>{l({name:"OpenActRequest",params:{type:71,data:e}})}),ne=d(e=>{l({name:"OpenActRequest",params:{type:64,data:e}})}),ie=d(e=>{l({name:"OpenActRequest",params:{type:58,data:e}})}),v="SHARE_EVENT_NAME";class re{}const oe=d(e=>R({name:"CommonShare",handler(i,t){window.dispatchEvent(new Event(v)),"onShareApp"in e&&e.onShareApp?t({type:12,data:e.onShareApp()}):t({type:12,data:e})}})),se=d(async e=>{window.dispatchEvent(new Event(v)),l({name:"OpenActRequest",params:{type:58,data:e}})});function ae(e){return window.addEventListener(v,e),()=>{window.removeEventListener(v,e)}}const ce=d(e=>{l({name:"OpenActRequest",params:{type:68,data:{show:e.showMenu,showActionMode:e.panelStyle||0}}})}),de=d(()=>h({name:"OpenActRequest",params:{type:72}})),ue=d(async()=>{l({name:"OpenActRequest",params:{type:73}})});class le{}const q=d(async()=>(await h({name:"OpenActRequest",timeout:5e3,params:{type:31,data:{requireLogin:!1}}})).data||null),_=(()=>{const e=new Set,i=(()=>{let t;const o=s=>{t=setTimeout(async()=>{const n=await q();if(!n)return o(++s);e.forEach(c=>c(n)),e.clear()},(n=>n===0?0:n<50?600:n<80?1e3:5e3)(s))};return{start(){t&&clearTimeout(t),e.size>0&&o(0)},stop(){t&&clearTimeout(t)}}})();return{addTask(t){e.add(t)},removeTask(t){e.delete(t),e.size===0&&i.stop()},triggerCheckTask(){i.start()}}})(),fe=d(async()=>{_.triggerCheckTask(),await l({name:"OpenActRequest",params:{type:31,data:{requireLogin:!0}}})}),pe=e=>(_.addTask(e),_.triggerCheckTask(),()=>{_.removeTask(e)});r.AppBaseInfo=j,r.AppLoginInfo=le,r.AppShareModel=re,r.BridgeCode=f,r.IS_KB_APP_ENV=G,r.KbRequirement=N,r.NoteThreadPostRule=M,r.checkForNewVersion=J,r.closeWebView=W,r.decorateAppVersionSupport=F,r.defineAppShareModel=oe,r.defineAppSharePanelState=ce,r.defineBridgeCallback=R,r.definePermissionUsage=Q,r.generateKBSign=K,r.generatePostEditorParamsByThreadPostRule=$,r.getAppBaseInfo=m,r.getAppLoginInfo=q,r.getAppSubscribeNotifyStatus=de,r.isAppVersionSupport=k,r.onAppSharePanelShow=ae,r.onLoopCheckAppLogin=pe,r.openAppSharePanel=se,r.openAppSubscribeNotifySettings=ue,r.openPostEditor=z,r.reportDAEvent=X,r.runAction=Y,r.runBridgeApi=l,r.runBridgeApiResponse=h,r.saveImageToLocal=Z,r.saveVideoToLocal=x,r.scanQRCode=ee,r.setScreenOrientation=te,r.setWebViewTitle=ne,r.shareImage=ie,r.triggerAppLogin=fe,Object.defineProperty(r,Symbol.toStringTag,{value:"Module"})});
|
package/package.json
CHANGED
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
"publishConfig": {
|
|
4
4
|
"access": "public"
|
|
5
5
|
},
|
|
6
|
-
"version": "1.0.
|
|
6
|
+
"version": "1.0.8-alpha.0",
|
|
7
7
|
"description": "开吧客户端桥接",
|
|
8
8
|
"author": "along",
|
|
9
9
|
"main": "./dist/umd/index.js",
|
|
@@ -21,11 +21,15 @@
|
|
|
21
21
|
"scripts": {
|
|
22
22
|
"build": "rm -rf ./dist && vite build",
|
|
23
23
|
"dev": "npm run build && vite",
|
|
24
|
-
"publish": "npm run build && npm publish"
|
|
24
|
+
"publish": "npm run build && npm publish",
|
|
25
|
+
"test": "vitest"
|
|
25
26
|
},
|
|
26
27
|
"devDependencies": {
|
|
28
|
+
"@vitest/ui": "^4.1.2",
|
|
29
|
+
"jsdom": "^29.0.1",
|
|
27
30
|
"typescript": "^5.0.0",
|
|
28
31
|
"vite": "^5.0.0",
|
|
29
|
-
"vite-plugin-dts": "^3.0.0"
|
|
32
|
+
"vite-plugin-dts": "^3.0.0",
|
|
33
|
+
"vitest": "^4.1.2"
|
|
30
34
|
}
|
|
31
|
-
}
|
|
35
|
+
}
|
package/vitest.config.ts
ADDED
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { defineConfig } from 'vitest/config'
|
|
2
|
+
import { resolve } from 'path'
|
|
3
|
+
|
|
4
|
+
export default defineConfig({
|
|
5
|
+
test: {
|
|
6
|
+
globals: true,
|
|
7
|
+
environment: 'jsdom', // 因为代码依赖 window 对象
|
|
8
|
+
setupFiles: ['./test/setup.ts'], // 设置文件用于模拟环境
|
|
9
|
+
coverage: {
|
|
10
|
+
reporter: ['text', 'json', 'html'],
|
|
11
|
+
},
|
|
12
|
+
},
|
|
13
|
+
resolve: {
|
|
14
|
+
alias: {
|
|
15
|
+
'@': resolve(__dirname, './src'),
|
|
16
|
+
},
|
|
17
|
+
},
|
|
18
|
+
})
|