Commit a6797435 authored by DatHV's avatar DatHV
Browse files

refactor print, log, request

parent f0334970
......@@ -905,9 +905,9 @@
"integrity": "sha512-/BpdSx+yCQGnCvecbyXdxHDkuk55/G3xwnC0GqY4gmQ3j+A+g8kzzgB4Nk/SINjqn6+waqw3EgbVF2QKExkRxQ=="
},
"node_modules/x-app-sdk": {
"version": "1.1.3",
"resolved": "https://registry.npmjs.org/x-app-sdk/-/x-app-sdk-1.1.3.tgz",
"integrity": "sha512-SM3X5HbA+J2wkRzRAu1siXS/v8ULVCYK7HDvCgzmsZkkStxEv7LobaAW65vAqeNTwAO+MLeRwVVElHq2myCrFQ==",
"version": "1.1.5",
"resolved": "https://registry.npmjs.org/x-app-sdk/-/x-app-sdk-1.1.5.tgz",
"integrity": "sha512-XeXVzy32A1eX5GjSXcC9kIMIYkqdMNkiY8j6j+Ao6czqw2i/vdK/ybhDZuKFxOy5hcLzA70wdmRlZJ/HQJCSRg==",
"dependencies": {
"vite-plugin-dts": "^4.5.0"
}
......
......@@ -23,11 +23,32 @@ Cấu hình giao diện ứng dụng trong SuperApp.
import { configUIApp, IViewUiConfig } from 'x-app-sdk';
const config: IViewUiConfig = {
headerTitle: 'Tên ứng dụng',
headerColor: '#ffffff',
headerTextColor: '#000000'
headerSubTitle: 'Mô tả ngắn ứng dụng'; // optional
headerIcon: 'Link icon trên header'; // optional
// EHeaderMode.MINI hoặc EHeaderMode.FULL
// js: mode: "mini" | "full"
// Mode header:
// + mode full sẽ hiển thị cả thanh header
// + mode mini sẽ chỉ hiển thị icon navigation
// Mặc định sẽ là mode mini
mode: EHeaderMode.MINI;
// Các option mode mini
iconNavigationColor: '#000000'; // màu icon
navigationColor: '#ffffff'; // màu nền icon
// Vị trí
// Thanh điều hướng ở phía bên phải hoặc trái.
// EIconNavigationPosision.RIGHT hoặc EIconNavigationPosision.LEFT
// js: iconNavigationPosision: "right" | "left"
// Mặc định bên phải
iconNavigationPosision: EIconNavigationPosision.RIGHT,
// Các option mode full
headerTitle: 'Tên ứng dụng', // Tiêu đề
headerColor: '#ffffff', // Màu nền tiêu đề
headerTextColor: '#000000' // Màu chữ tiêu đề
headerSubTitle: 'Mô tả ngắn ứng dụng'; // Mô tả ngắn phía dứoi tiêu đề
headerIcon: 'https://linkicon.png/'; // Icon trên header (Link ảnh)
};
configUIApp(config).then(response => {
......
"use strict";var u=Object.defineProperty;var P=(A,g,I)=>g in A?u(A,g,{enumerable:!0,configurable:!0,writable:!0,value:I}):A[g]=I;var r=(A,g,I)=>P(A,typeof g!="symbol"?g+"":g,I);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});var o=(A=>(A.RequestConfigUIApp="requestConfigUIApp",A.RequestInfo="requestInfo",A.RequestToken="requestToken",A.RequestCloseApp="requestCloseApp",A.RequestPickerImage="requestPickerImage",A.RequestPickerFile="requestPickerFile",A.RequestVibrate="requestVibrate",A.RequestCall="requestCall",A.RequestSms="requestSms",A.RequestLocationPermission="requestLocationPermission",A.RequestCurrentLocation="requestCurrentLocation",A.RequestPayment="requestPayment",A.requestGetPermission="requestGetPermission",A.requestSaveStore="requestSaveStore",A.requestGetStore="requestGetStore",A.requestClearStore="requestClearStore",A))(o||{}),s=(A=>(A.ResponseConfigApp="responseConfigUIApp",A.ResponseInfo="responseInfo",A.ResponseToken="responseToken",A.ResponsePickerImage="responsePickerImage",A.ResponsePickerFile="responsePickerFile",A.ResponseVibrate="responseVibrate",A.ResponseCall="responseCall",A.ResponseSms="responseSms",A.ResponseLocationPermission="responseLocationPermission",A.ResponseCurrentLocation="responseCurrentLocation",A.ResponseCloseApp="responseCloseApp",A.ResponsePayment="responsePayment",A.ResponseNotification="responseNotification",A.ResponseGetPermisstion="responseGetPermisstion",A.responseSaveStore="responseSaveStore",A.responseGetStore="responseGetStore",A.responseClearStore="responseClearStore",A))(s||{}),t=(A=>(A.SUCCESS="success",A.ERROR="error",A.PREMISSION_ERROR="premissionError",A))(t||{}),c=(A=>(A.USER="user",A))(c||{}),a=(A=>(A.gallery="gallery",A.camera="camera",A))(a||{});class p{constructor(){r(this,"premissions");r(this,"getPremissions",()=>({[o.RequestInfo]:!0,[o.RequestCloseApp]:!0,[o.RequestPickerImage]:!0,[o.RequestVibrate]:!0}));r(this,"checkPremission",g=>this.premissions[g]??!0);this.premissions={},this.initialize()}initialize(){window.flutter_inappwebview||(this.premissions=this.getPremissions())}}class d{constructor(){r(this,"handlers");r(this,"isInitialized");r(this,"isBrowserMode");r(this,"cachedInfo");r(this,"infoRequests");r(this,"premissionEvent");this.handlers=new Map,this.isInitialized=!1,this.isBrowserMode=!1,this.cachedInfo=new Map,this.infoRequests=new Map,this.premissionEvent=new p,this.initialize()}initialize(){window.flutter_inappwebview?(this.setupMessageHandler(),this.isInitialized=!0,this.isBrowserMode=!1,this.send(o.RequestInfo,{})):(this.isInitialized=!0,this.isBrowserMode=!0,console.warn("Flutter channel not found. Running in browser mode."))}setupMessageHandler(){window.receiveFromFlutter=g=>{try{const I=JSON.parse(g);if(I.type===s.ResponseInfo){this.handleInfoUpdate(I.data);return}this.handleMessage(I)}catch(I){console.error("Error parsing message from Flutter:",I)}}}handleInfoUpdate(g){g&&Object.entries(g).forEach(([I,e])=>{this.cachedInfo.set(I,e),(this.infoRequests.get(I)||[]).forEach(i=>i(e)),this.infoRequests.delete(I)})}handleMessage(g){(this.handlers.get(g.type)||[]).forEach(e=>{try{e(g)}catch(n){console.error("Error in message handler:",n)}})}send(g,I){if(!this.isInitialized){console.error("SDK not initialized");return}const n=JSON.stringify({type:g,data:I});window.flutter_inappwebview&&window.flutter_inappwebview.callHandler("Flutter",n).catch(i=>console.error("Error sending message to Flutter:",i))}on(g,I){const e=this.handlers.get(g)||[];e.push(I),this.handlers.set(g,e)}off(g,I){const e=this.handlers.get(g)||[],n=e.indexOf(I);n>-1&&(e.splice(n,1),this.handlers.set(g,e))}getBrowserMode(){return this.isBrowserMode}getInitialized(){return this.isInitialized}getCachedInfo(g){return this.cachedInfo.get(g)}getInfoRequests(){return this.infoRequests}setInfoRequest(g,I){this.infoRequests.set(g,I)}checkPremissionEvent(g){return this.premissionEvent.checkPremission(g)}}const C=new d;C.getBrowserMode();const m={user:{fullname:"Phạm Văn A",identityNumber:"039999963",phone:"0355600825",gender:0,dob:"2001-11-20",address:"Thanh Bình, Phường Hà Đông",permanentAddress:"Thôn A, huyện, tỉnh B",avatar:"https://badinh.ioc-cloud.com/rs/images/bc3cf657-f537-4f4a-9562-f9bda926d640-1751356836934.jpg"}},h=async A=>{if(C.getBrowserMode()){if(!C.checkPremissionEvent(o.RequestInfo)){const e={type:s.ResponseInfo,status:t.PREMISSION_ERROR};return Promise.resolve(e)}const I={type:s.ResponseInfo,status:t.SUCCESS,data:m[A]};return Promise.resolve(I)}const g=C.getCachedInfo(A);if(g!==void 0){const I={type:s.ResponseInfo,status:t.SUCCESS,data:g};return Promise.resolve(I)}return new Promise(I=>{const n=C.getInfoRequests().get(A)||[];n.push(i=>{const R={type:s.ResponseInfo,status:t.SUCCESS,data:i};I(R)}),C.setInfoRequest(A,n),C.send(o.RequestInfo,{key:A})})},S="tokenEx.tokenEx",f=async()=>{if(!C.getInitialized())throw new Error("SDK not initialized");if(C.getBrowserMode()){if(!C.checkPremissionEvent(o.RequestToken)){const g={type:s.ResponseToken,status:t.PREMISSION_ERROR};return Promise.resolve(g)}const A={type:s.ResponseToken,status:t.SUCCESS,data:S};return Promise.resolve(A)}return new Promise((A,g)=>{const I=e=>{e.status===t.ERROR?g(e):A(e),C.off(s.ResponseToken,I)};C.on(s.ResponseToken,I),C.send(o.RequestToken)})},y={path:"/hello.png",base64:""},G={path:"/hello.png",size:12e3,base64:""},E=async A=>{if(!C.getInitialized())throw new Error("SDK not initialized");if(C.getBrowserMode()){if(!C.checkPremissionEvent(o.RequestPickerImage)){const I={type:s.ResponsePickerImage,status:t.PREMISSION_ERROR};return Promise.resolve(I)}const g={type:s.ResponsePickerImage,status:t.SUCCESS,data:y};return Promise.resolve(g)}return new Promise((g,I)=>{const e=n=>{n.status===t.ERROR?I(n):g(n),C.off(s.ResponsePickerImage,e)};C.on(s.ResponsePickerImage,e),C.send(o.RequestPickerImage,{type:A})})},w=async()=>{if(!C.getInitialized())throw new Error("SDK not initialized");if(C.getBrowserMode()){if(!C.checkPremissionEvent(o.RequestPickerFile)){const g={type:s.ResponsePickerFile,status:t.PREMISSION_ERROR};return Promise.resolve(g)}const A={type:s.ResponsePickerFile,status:t.SUCCESS,data:G};return Promise.resolve(A)}return new Promise((A,g)=>{const I=e=>{e.status===t.ERROR?g(e):A(e),C.off(s.ResponsePickerFile,I)};C.on(s.ResponsePickerFile,I),C.send(o.RequestPickerFile,void 0)})},B=A=>{C.send(o.RequestCloseApp,A)},Z=async()=>{if(!C.checkPremissionEvent(o.RequestVibrate)){const A={type:s.ResponseVibrate,status:t.PREMISSION_ERROR};return Promise.resolve(A)}C.send(o.RequestVibrate)},Q=async A=>{if(!C.getInitialized())throw new Error("SDK not initialized");if(C.getBrowserMode()){if(!C.checkPremissionEvent(o.RequestCall)){const I={type:s.ResponseCall,status:t.PREMISSION_ERROR};return Promise.resolve(I)}window.open(`tel:${A}`);const g={type:s.ResponseCall,status:t.SUCCESS};return Promise.resolve(g)}C.send(o.RequestCall,{phoneNumber:A})},v=async A=>{if(!C.getInitialized())throw new Error("SDK not initialized");if(C.getBrowserMode()){if(!C.checkPremissionEvent(o.RequestSms)){const I={type:s.ResponseSms,status:t.PREMISSION_ERROR};return Promise.resolve(I)}window.open(`sms::${A}`);const g={type:s.ResponseSms,status:t.SUCCESS};return Promise.resolve(g)}C.send(o.RequestSms,{phoneNumber:A})},k=async A=>{if(!C.getInitialized())throw new Error("SDK not initialized");if(C.getBrowserMode()){const g={type:s.ResponseConfigApp,status:t.SUCCESS};return Promise.resolve(g)}return new Promise((g,I)=>{const e=n=>{n.status===t.ERROR?I(n):g(n),C.off(s.ResponseConfigApp,e)};C.on(s.ResponseConfigApp,e),C.send(o.RequestConfigUIApp,A)})},M=async A=>{if(!C.getInitialized())throw new Error("SDK not initialized");if(C.getBrowserMode()){if(!C.checkPremissionEvent(o.requestGetPermission)){const I={type:s.ResponseGetPermisstion,status:t.PREMISSION_ERROR};return Promise.resolve(I)}const g={type:s.ResponseGetPermisstion,status:t.SUCCESS,data:C.checkPremissionEvent(A)};return Promise.resolve(g)}return new Promise((g,I)=>{const e=n=>{n.status===t.ERROR?I(n):g(n),C.off(s.ResponseGetPermisstion,e)};C.on(s.ResponseGetPermisstion,e),C.send(o.requestGetPermission,{type:A})})},z={status:"success",message:"Tạo đơn hàng thành công"},Y=async A=>{if(!C.getInitialized())throw new Error("SDK not initialized");if(C.getBrowserMode()){if(!C.checkPremissionEvent(o.RequestPayment)){const I={type:s.ResponsePayment,status:t.PREMISSION_ERROR};return Promise.resolve(I)}const g={type:s.ResponsePayment,status:t.SUCCESS,data:z};return Promise.resolve(g)}return new Promise((g,I)=>{const e=n=>{n.status===t.ERROR?I(n):g(n),C.off(s.ResponsePayment,e)};C.on(s.ResponsePayment,e),C.send(o.RequestPayment,A)})},K=(A,g)=>{const I=g||C;if(!I.getInitialized())throw new Error("SDK not initialized");const e=n=>{A(n)};return I.on(s.ResponsePayment,e),()=>{I.off(s.ResponsePayment,e)}},b={latitude:21.0239852,longitude:105.791488},j=async()=>{if(!C.getInitialized())throw new Error("SDK not initialized");if(C.getBrowserMode()){if(!C.checkPremissionEvent(o.RequestCurrentLocation)){const g={type:s.ResponseCurrentLocation,status:t.PREMISSION_ERROR};return Promise.resolve(g)}const A={type:s.ResponseCurrentLocation,status:t.SUCCESS,data:b};return Promise.resolve(A)}return new Promise((A,g)=>{const I=e=>{e.status===t.ERROR?g(e):A(e),C.off(s.ResponseCurrentLocation,I)};C.on(s.ResponseCurrentLocation,I),C.send(o.RequestCurrentLocation)})},D=async()=>{if(!C.getInitialized())throw new Error("SDK not initialized");if(C.getBrowserMode()){if(!C.checkPremissionEvent(o.RequestLocationPermission)){const g={type:s.ResponseLocationPermission,status:t.PREMISSION_ERROR};return Promise.resolve(g)}const A={type:s.ResponseLocationPermission,status:t.SUCCESS};return Promise.resolve(A)}return new Promise((A,g)=>{const I=e=>{e.status===t.ERROR?g(e):A(e),C.off(s.ResponseLocationPermission,I)};C.on(s.ResponseLocationPermission,I),C.send(o.RequestLocationPermission)})},q=(A,g)=>{const I=g||C;if(!I.getInitialized())throw new Error("SDK not initialized");const e=n=>{A(n)};return I.on(s.ResponseNotification,e),()=>{I.off(s.ResponseNotification,e)}},l="mini_app_sdk_x_app",J=async A=>{if(!C.getInitialized())throw new Error("SDK not initialized");if(C.getBrowserMode()){if(!C.checkPremissionEvent(o.requestSaveStore)){const I={type:s.responseSaveStore,status:t.PREMISSION_ERROR};return Promise.resolve(I)}localStorage.setItem(l,A);const g={type:s.responseSaveStore,status:t.SUCCESS};return Promise.resolve(g)}return new Promise((g,I)=>{const e=n=>{n.status===t.ERROR?I(n):g(n),C.off(s.responseSaveStore,e)};C.on(s.responseSaveStore,e),C.send(o.requestSaveStore,{data:A})})},U=async()=>{if(!C.getInitialized())throw new Error("SDK not initialized");if(C.getBrowserMode()){if(!C.checkPremissionEvent(o.requestGetStore)){const I={type:s.responseGetStore,status:t.PREMISSION_ERROR};return Promise.resolve(I)}const A=localStorage.getItem(l),g={type:s.responseGetStore,status:t.SUCCESS,data:A??""};return Promise.resolve(g)}return new Promise((A,g)=>{const I=e=>{e.status===t.ERROR?g(e):A(e),C.off(s.responseGetStore,I)};C.on(s.responseGetStore,I),C.send(o.requestGetStore)})},W=async()=>{if(!C.getInitialized())throw new Error("SDK not initialized");if(C.getBrowserMode()){if(!C.checkPremissionEvent(o.requestClearStore)){const g={type:s.responseClearStore,status:t.PREMISSION_ERROR};return Promise.resolve(g)}localStorage.clear();const A={type:s.responseClearStore,status:t.SUCCESS};return Promise.resolve(A)}return new Promise((A,g)=>{const I=e=>{e.status===t.ERROR?g(e):A(e),C.off(s.responseClearStore,I)};C.on(s.responseClearStore,I),C.send(o.requestClearStore)})};exports.EKeyInfor=c;exports.EMediaType=a;exports.EStatus=t;exports.ETypeRequest=o;exports.ETypeResponse=s;exports.call=Q;exports.clearStore=W;exports.closeApp=B;exports.configUIApp=k;exports.currentLocation=j;exports.fltSDK=C;exports.getInfo=h;exports.getStore=U;exports.getToken=f;exports.listenNotifiactionEvent=q;exports.listenPaymentEvent=K;exports.openPickerFile=w;exports.openPickerImage=E;exports.paymentRequest=Y;exports.premissionsRequest=M;exports.requestLocationPermission=D;exports.saveStore=J;exports.sms=v;exports.vibrate=Z;
"use strict";var p=Object.defineProperty;var m=(A,g,I)=>g in A?p(A,g,{enumerable:!0,configurable:!0,writable:!0,value:I}):A[g]=I;var r=(A,g,I)=>m(A,typeof g!="symbol"?g+"":g,I);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});var o=(A=>(A.RequestConfigUIApp="requestConfigUIApp",A.RequestInfo="requestInfo",A.RequestToken="requestToken",A.RequestCloseApp="requestCloseApp",A.RequestPickerImage="requestPickerImage",A.RequestPickerFile="requestPickerFile",A.RequestVibrate="requestVibrate",A.RequestCall="requestCall",A.RequestSms="requestSms",A.RequestLocationPermission="requestLocationPermission",A.RequestCurrentLocation="requestCurrentLocation",A.RequestPayment="requestPayment",A.requestGetPermission="requestGetPermission",A.requestSaveStore="requestSaveStore",A.requestGetStore="requestGetStore",A.requestClearStore="requestClearStore",A))(o||{}),s=(A=>(A.ResponseConfigApp="responseConfigUIApp",A.ResponseInfo="responseInfo",A.ResponseToken="responseToken",A.ResponsePickerImage="responsePickerImage",A.ResponsePickerFile="responsePickerFile",A.ResponseVibrate="responseVibrate",A.ResponseCall="responseCall",A.ResponseSms="responseSms",A.ResponseLocationPermission="responseLocationPermission",A.ResponseCurrentLocation="responseCurrentLocation",A.ResponseCloseApp="responseCloseApp",A.ResponsePayment="responsePayment",A.ResponseNotification="responseNotification",A.ResponseGetPermisstion="responseGetPermisstion",A.responseSaveStore="responseSaveStore",A.responseGetStore="responseGetStore",A.responseClearStore="responseClearStore",A))(s||{}),t=(A=>(A.SUCCESS="success",A.ERROR="error",A.PREMISSION_ERROR="premissionError",A))(t||{}),c=(A=>(A.MINI="mini",A.FULL="full",A))(c||{}),a=(A=>(A.RIGHT="right",A.LEFT="left",A))(a||{}),l=(A=>(A.USER="user",A))(l||{}),R=(A=>(A.gallery="gallery",A.camera="camera",A))(R||{});class d{constructor(){r(this,"premissions");r(this,"getPremissions",()=>({[o.RequestInfo]:!0,[o.RequestCloseApp]:!0,[o.RequestPickerImage]:!0,[o.RequestVibrate]:!0}));r(this,"checkPremission",g=>this.premissions[g]??!0);this.premissions={},this.initialize()}initialize(){window.flutter_inappwebview||(this.premissions=this.getPremissions())}}class h{constructor(){r(this,"handlers");r(this,"isInitialized");r(this,"isBrowserMode");r(this,"cachedInfo");r(this,"infoRequests");r(this,"premissionEvent");this.handlers=new Map,this.isInitialized=!1,this.isBrowserMode=!1,this.cachedInfo=new Map,this.infoRequests=new Map,this.premissionEvent=new d,this.initialize()}initialize(){window.flutter_inappwebview?(this.setupMessageHandler(),this.isInitialized=!0,this.isBrowserMode=!1,this.send(o.RequestInfo,{})):(this.isInitialized=!0,this.isBrowserMode=!0,console.warn("Flutter channel not found. Running in browser mode."))}setupMessageHandler(){window.receiveFromFlutter=g=>{try{const I=JSON.parse(g);if(I.type===s.ResponseInfo){this.handleInfoUpdate(I.data);return}this.handleMessage(I)}catch(I){console.error("Error parsing message from Flutter:",I)}}}handleInfoUpdate(g){g&&Object.entries(g).forEach(([I,e])=>{this.cachedInfo.set(I,e),(this.infoRequests.get(I)||[]).forEach(i=>i(e)),this.infoRequests.delete(I)})}handleMessage(g){(this.handlers.get(g.type)||[]).forEach(e=>{try{e(g)}catch(n){console.error("Error in message handler:",n)}})}send(g,I){if(!this.isInitialized){console.error("SDK not initialized");return}const n=JSON.stringify({type:g,data:I});window.flutter_inappwebview&&window.flutter_inappwebview.callHandler("Flutter",n).catch(i=>console.error("Error sending message to Flutter:",i))}on(g,I){const e=this.handlers.get(g)||[];e.push(I),this.handlers.set(g,e)}off(g,I){const e=this.handlers.get(g)||[],n=e.indexOf(I);n>-1&&(e.splice(n,1),this.handlers.set(g,e))}getBrowserMode(){return this.isBrowserMode}getInitialized(){return this.isInitialized}getCachedInfo(g){return this.cachedInfo.get(g)}getInfoRequests(){return this.infoRequests}setInfoRequest(g,I){this.infoRequests.set(g,I)}checkPremissionEvent(g){return this.premissionEvent.checkPremission(g)}}const C=new h;C.getBrowserMode();const S={user:{fullname:"Phạm Văn A",identityNumber:"039999963",phone:"0355600825",gender:0,dob:"2001-11-20",address:"Thanh Bình, Phường Hà Đông",permanentAddress:"Thôn A, huyện, tỉnh B",avatar:"https://badinh.ioc-cloud.com/rs/images/bc3cf657-f537-4f4a-9562-f9bda926d640-1751356836934.jpg"}},f=async A=>{if(C.getBrowserMode()){if(!C.checkPremissionEvent(o.RequestInfo)){const e={type:s.ResponseInfo,status:t.PREMISSION_ERROR};return Promise.resolve(e)}const I={type:s.ResponseInfo,status:t.SUCCESS,data:S[A]};return Promise.resolve(I)}const g=C.getCachedInfo(A);if(g!==void 0){const I={type:s.ResponseInfo,status:t.SUCCESS,data:g};return Promise.resolve(I)}return new Promise(I=>{const n=C.getInfoRequests().get(A)||[];n.push(i=>{const P={type:s.ResponseInfo,status:t.SUCCESS,data:i};I(P)}),C.setInfoRequest(A,n),C.send(o.RequestInfo,{key:A})})},y="tokenEx.tokenEx",G=async()=>{if(!C.getInitialized())throw new Error("SDK not initialized");if(C.getBrowserMode()){if(!C.checkPremissionEvent(o.RequestToken)){const g={type:s.ResponseToken,status:t.PREMISSION_ERROR};return Promise.resolve(g)}const A={type:s.ResponseToken,status:t.SUCCESS,data:y};return Promise.resolve(A)}return new Promise((A,g)=>{const I=e=>{e.status===t.ERROR?g(e):A(e),C.off(s.ResponseToken,I)};C.on(s.ResponseToken,I),C.send(o.RequestToken)})},E={path:"/hello.png",base64:""},w={path:"/hello.png",size:12e3,base64:""},B=async A=>{if(!C.getInitialized())throw new Error("SDK not initialized");if(C.getBrowserMode()){if(!C.checkPremissionEvent(o.RequestPickerImage)){const I={type:s.ResponsePickerImage,status:t.PREMISSION_ERROR};return Promise.resolve(I)}const g={type:s.ResponsePickerImage,status:t.SUCCESS,data:E};return Promise.resolve(g)}return new Promise((g,I)=>{const e=n=>{n.status===t.ERROR?I(n):g(n),C.off(s.ResponsePickerImage,e)};C.on(s.ResponsePickerImage,e),C.send(o.RequestPickerImage,{type:A})})},Z=async()=>{if(!C.getInitialized())throw new Error("SDK not initialized");if(C.getBrowserMode()){if(!C.checkPremissionEvent(o.RequestPickerFile)){const g={type:s.ResponsePickerFile,status:t.PREMISSION_ERROR};return Promise.resolve(g)}const A={type:s.ResponsePickerFile,status:t.SUCCESS,data:w};return Promise.resolve(A)}return new Promise((A,g)=>{const I=e=>{e.status===t.ERROR?g(e):A(e),C.off(s.ResponsePickerFile,I)};C.on(s.ResponsePickerFile,I),C.send(o.RequestPickerFile,void 0)})},Q=A=>{C.send(o.RequestCloseApp,A)},v=async()=>{if(!C.checkPremissionEvent(o.RequestVibrate)){const A={type:s.ResponseVibrate,status:t.PREMISSION_ERROR};return Promise.resolve(A)}C.send(o.RequestVibrate)},M=async A=>{if(!C.getInitialized())throw new Error("SDK not initialized");if(C.getBrowserMode()){if(!C.checkPremissionEvent(o.RequestCall)){const I={type:s.ResponseCall,status:t.PREMISSION_ERROR};return Promise.resolve(I)}window.open(`tel:${A}`);const g={type:s.ResponseCall,status:t.SUCCESS};return Promise.resolve(g)}C.send(o.RequestCall,{phoneNumber:A})},k=async A=>{if(!C.getInitialized())throw new Error("SDK not initialized");if(C.getBrowserMode()){if(!C.checkPremissionEvent(o.RequestSms)){const I={type:s.ResponseSms,status:t.PREMISSION_ERROR};return Promise.resolve(I)}window.open(`sms::${A}`);const g={type:s.ResponseSms,status:t.SUCCESS};return Promise.resolve(g)}C.send(o.RequestSms,{phoneNumber:A})},z=async A=>{if(!C.getInitialized())throw new Error("SDK not initialized");if(C.getBrowserMode()){const g={type:s.ResponseConfigApp,status:t.SUCCESS};return Promise.resolve(g)}return new Promise((g,I)=>{const e=n=>{n.status===t.ERROR?I(n):g(n),C.off(s.ResponseConfigApp,e)};C.on(s.ResponseConfigApp,e),C.send(o.RequestConfigUIApp,A)})},Y=async A=>{if(!C.getInitialized())throw new Error("SDK not initialized");if(C.getBrowserMode()){if(!C.checkPremissionEvent(o.requestGetPermission)){const I={type:s.ResponseGetPermisstion,status:t.PREMISSION_ERROR};return Promise.resolve(I)}const g={type:s.ResponseGetPermisstion,status:t.SUCCESS,data:C.checkPremissionEvent(A)};return Promise.resolve(g)}return new Promise((g,I)=>{const e=n=>{n.status===t.ERROR?I(n):g(n),C.off(s.ResponseGetPermisstion,e)};C.on(s.ResponseGetPermisstion,e),C.send(o.requestGetPermission,{type:A})})},K={status:"success",message:"Tạo đơn hàng thành công"},b=async A=>{if(!C.getInitialized())throw new Error("SDK not initialized");if(C.getBrowserMode()){if(!C.checkPremissionEvent(o.RequestPayment)){const I={type:s.ResponsePayment,status:t.PREMISSION_ERROR};return Promise.resolve(I)}const g={type:s.ResponsePayment,status:t.SUCCESS,data:K};return Promise.resolve(g)}return new Promise((g,I)=>{const e=n=>{n.status===t.ERROR?I(n):g(n),C.off(s.ResponsePayment,e)};C.on(s.ResponsePayment,e),C.send(o.RequestPayment,A)})},j=(A,g)=>{const I=g||C;if(!I.getInitialized())throw new Error("SDK not initialized");const e=n=>{A(n)};return I.on(s.ResponsePayment,e),()=>{I.off(s.ResponsePayment,e)}},D={latitude:21.0239852,longitude:105.791488},q=async()=>{if(!C.getInitialized())throw new Error("SDK not initialized");if(C.getBrowserMode()){if(!C.checkPremissionEvent(o.RequestCurrentLocation)){const g={type:s.ResponseCurrentLocation,status:t.PREMISSION_ERROR};return Promise.resolve(g)}const A={type:s.ResponseCurrentLocation,status:t.SUCCESS,data:D};return Promise.resolve(A)}return new Promise((A,g)=>{const I=e=>{e.status===t.ERROR?g(e):A(e),C.off(s.ResponseCurrentLocation,I)};C.on(s.ResponseCurrentLocation,I),C.send(o.RequestCurrentLocation)})},J=async()=>{if(!C.getInitialized())throw new Error("SDK not initialized");if(C.getBrowserMode()){if(!C.checkPremissionEvent(o.RequestLocationPermission)){const g={type:s.ResponseLocationPermission,status:t.PREMISSION_ERROR};return Promise.resolve(g)}const A={type:s.ResponseLocationPermission,status:t.SUCCESS};return Promise.resolve(A)}return new Promise((A,g)=>{const I=e=>{e.status===t.ERROR?g(e):A(e),C.off(s.ResponseLocationPermission,I)};C.on(s.ResponseLocationPermission,I),C.send(o.RequestLocationPermission)})},L=(A,g)=>{const I=g||C;if(!I.getInitialized())throw new Error("SDK not initialized");const e=n=>{A(n)};return I.on(s.ResponseNotification,e),()=>{I.off(s.ResponseNotification,e)}},u="mini_app_sdk_x_app",U=async A=>{if(!C.getInitialized())throw new Error("SDK not initialized");if(C.getBrowserMode()){if(!C.checkPremissionEvent(o.requestSaveStore)){const I={type:s.responseSaveStore,status:t.PREMISSION_ERROR};return Promise.resolve(I)}localStorage.setItem(u,A);const g={type:s.responseSaveStore,status:t.SUCCESS};return Promise.resolve(g)}return new Promise((g,I)=>{const e=n=>{n.status===t.ERROR?I(n):g(n),C.off(s.responseSaveStore,e)};C.on(s.responseSaveStore,e),C.send(o.requestSaveStore,{data:A})})},W=async()=>{if(!C.getInitialized())throw new Error("SDK not initialized");if(C.getBrowserMode()){if(!C.checkPremissionEvent(o.requestGetStore)){const I={type:s.responseGetStore,status:t.PREMISSION_ERROR};return Promise.resolve(I)}const A=localStorage.getItem(u),g={type:s.responseGetStore,status:t.SUCCESS,data:A??""};return Promise.resolve(g)}return new Promise((A,g)=>{const I=e=>{e.status===t.ERROR?g(e):A(e),C.off(s.responseGetStore,I)};C.on(s.responseGetStore,I),C.send(o.requestGetStore)})},O=async()=>{if(!C.getInitialized())throw new Error("SDK not initialized");if(C.getBrowserMode()){if(!C.checkPremissionEvent(o.requestClearStore)){const g={type:s.responseClearStore,status:t.PREMISSION_ERROR};return Promise.resolve(g)}localStorage.clear();const A={type:s.responseClearStore,status:t.SUCCESS};return Promise.resolve(A)}return new Promise((A,g)=>{const I=e=>{e.status===t.ERROR?g(e):A(e),C.off(s.responseClearStore,I)};C.on(s.responseClearStore,I),C.send(o.requestClearStore)})};exports.EHeaderMode=c;exports.EIconNavigationPosision=a;exports.EKeyInfor=l;exports.EMediaType=R;exports.EStatus=t;exports.ETypeRequest=o;exports.ETypeResponse=s;exports.call=M;exports.clearStore=O;exports.closeApp=Q;exports.configUIApp=z;exports.currentLocation=q;exports.fltSDK=C;exports.getInfo=f;exports.getStore=W;exports.getToken=G;exports.listenNotifiactionEvent=L;exports.listenPaymentEvent=j;exports.openPickerFile=Z;exports.openPickerImage=B;exports.paymentRequest=b;exports.premissionsRequest=Y;exports.requestLocationPermission=J;exports.saveStore=U;exports.sms=k;exports.vibrate=v;
......@@ -31,6 +31,16 @@ declare class CoreSdk {
export declare const currentLocation: () => Promise<FlutterMessageResponse<ICurrentLocation>>;
export declare enum EHeaderMode {
MINI = "mini",
FULL = "full"
}
export declare enum EIconNavigationPosision {
RIGHT = "right",
LEFT = "left"
}
export declare enum EKeyInfor {
USER = "user"
}
......@@ -145,6 +155,10 @@ export declare interface IViewUiConfig {
headerTextColor?: string;
headerSubTitle?: string;
headerIcon?: string;
mode?: EHeaderMode;
iconNavigationColor?: string;
navigationColor?: string;
iconNavigationPosision?: EIconNavigationPosision;
}
export declare const listenNotifiactionEvent: (callback: (data: FlutterMessageResponse) => void, customSdk?: typeof fltSDK) => (() => void);
......
var l = Object.defineProperty;
var R = (A, g, I) => g in A ? l(A, g, { enumerable: !0, configurable: !0, writable: !0, value: I }) : A[g] = I;
var r = (A, g, I) => R(A, typeof g != "symbol" ? g + "" : g, I);
var o = /* @__PURE__ */ ((A) => (A.RequestConfigUIApp = "requestConfigUIApp", A.RequestInfo = "requestInfo", A.RequestToken = "requestToken", A.RequestCloseApp = "requestCloseApp", A.RequestPickerImage = "requestPickerImage", A.RequestPickerFile = "requestPickerFile", A.RequestVibrate = "requestVibrate", A.RequestCall = "requestCall", A.RequestSms = "requestSms", A.RequestLocationPermission = "requestLocationPermission", A.RequestCurrentLocation = "requestCurrentLocation", A.RequestPayment = "requestPayment", A.requestGetPermission = "requestGetPermission", A.requestSaveStore = "requestSaveStore", A.requestGetStore = "requestGetStore", A.requestClearStore = "requestClearStore", A))(o || {}), s = /* @__PURE__ */ ((A) => (A.ResponseConfigApp = "responseConfigUIApp", A.ResponseInfo = "responseInfo", A.ResponseToken = "responseToken", A.ResponsePickerImage = "responsePickerImage", A.ResponsePickerFile = "responsePickerFile", A.ResponseVibrate = "responseVibrate", A.ResponseCall = "responseCall", A.ResponseSms = "responseSms", A.ResponseLocationPermission = "responseLocationPermission", A.ResponseCurrentLocation = "responseCurrentLocation", A.ResponseCloseApp = "responseCloseApp", A.ResponsePayment = "responsePayment", A.ResponseNotification = "responseNotification", A.ResponseGetPermisstion = "responseGetPermisstion", A.responseSaveStore = "responseSaveStore", A.responseGetStore = "responseGetStore", A.responseClearStore = "responseClearStore", A))(s || {}), t = /* @__PURE__ */ ((A) => (A.SUCCESS = "success", A.ERROR = "error", A.PREMISSION_ERROR = "premissionError", A))(t || {}), u = /* @__PURE__ */ ((A) => (A.USER = "user", A))(u || {}), P = /* @__PURE__ */ ((A) => (A.gallery = "gallery", A.camera = "camera", A))(P || {});
class d {
var o = /* @__PURE__ */ ((A) => (A.RequestConfigUIApp = "requestConfigUIApp", A.RequestInfo = "requestInfo", A.RequestToken = "requestToken", A.RequestCloseApp = "requestCloseApp", A.RequestPickerImage = "requestPickerImage", A.RequestPickerFile = "requestPickerFile", A.RequestVibrate = "requestVibrate", A.RequestCall = "requestCall", A.RequestSms = "requestSms", A.RequestLocationPermission = "requestLocationPermission", A.RequestCurrentLocation = "requestCurrentLocation", A.RequestPayment = "requestPayment", A.requestGetPermission = "requestGetPermission", A.requestSaveStore = "requestSaveStore", A.requestGetStore = "requestGetStore", A.requestClearStore = "requestClearStore", A))(o || {}), s = /* @__PURE__ */ ((A) => (A.ResponseConfigApp = "responseConfigUIApp", A.ResponseInfo = "responseInfo", A.ResponseToken = "responseToken", A.ResponsePickerImage = "responsePickerImage", A.ResponsePickerFile = "responsePickerFile", A.ResponseVibrate = "responseVibrate", A.ResponseCall = "responseCall", A.ResponseSms = "responseSms", A.ResponseLocationPermission = "responseLocationPermission", A.ResponseCurrentLocation = "responseCurrentLocation", A.ResponseCloseApp = "responseCloseApp", A.ResponsePayment = "responsePayment", A.ResponseNotification = "responseNotification", A.ResponseGetPermisstion = "responseGetPermisstion", A.responseSaveStore = "responseSaveStore", A.responseGetStore = "responseGetStore", A.responseClearStore = "responseClearStore", A))(s || {}), t = /* @__PURE__ */ ((A) => (A.SUCCESS = "success", A.ERROR = "error", A.PREMISSION_ERROR = "premissionError", A))(t || {}), u = /* @__PURE__ */ ((A) => (A.MINI = "mini", A.FULL = "full", A))(u || {}), P = /* @__PURE__ */ ((A) => (A.RIGHT = "right", A.LEFT = "left", A))(P || {}), d = /* @__PURE__ */ ((A) => (A.USER = "user", A))(d || {}), m = /* @__PURE__ */ ((A) => (A.gallery = "gallery", A.camera = "camera", A))(m || {});
class p {
constructor() {
r(this, "premissions");
r(this, "getPremissions", () => ({
......@@ -18,7 +18,7 @@ class d {
window.flutter_inappwebview || (this.premissions = this.getPremissions());
}
}
class m {
class h {
constructor() {
r(this, "handlers");
r(this, "isInitialized");
......@@ -26,7 +26,7 @@ class m {
r(this, "cachedInfo");
r(this, "infoRequests");
r(this, "premissionEvent");
this.handlers = /* @__PURE__ */ new Map(), this.isInitialized = !1, this.isBrowserMode = !1, this.cachedInfo = /* @__PURE__ */ new Map(), this.infoRequests = /* @__PURE__ */ new Map(), this.premissionEvent = new d(), this.initialize();
this.handlers = /* @__PURE__ */ new Map(), this.isInitialized = !1, this.isBrowserMode = !1, this.cachedInfo = /* @__PURE__ */ new Map(), this.infoRequests = /* @__PURE__ */ new Map(), this.premissionEvent = new p(), this.initialize();
}
initialize() {
window.flutter_inappwebview ? (this.setupMessageHandler(), this.isInitialized = !0, this.isBrowserMode = !1, this.send(o.RequestInfo, {})) : (this.isInitialized = !0, this.isBrowserMode = !0, console.warn("Flutter channel not found. Running in browser mode."));
......@@ -94,9 +94,9 @@ class m {
return this.premissionEvent.checkPremission(g);
}
}
const C = new m();
const C = new h();
C.getBrowserMode();
const p = {
const S = {
user: {
fullname: "Phạm Văn A",
identityNumber: "039999963",
......@@ -107,7 +107,7 @@ const p = {
permanentAddress: "Thôn A, huyện, tỉnh B",
avatar: "https://badinh.ioc-cloud.com/rs/images/bc3cf657-f537-4f4a-9562-f9bda926d640-1751356836934.jpg"
}
}, w = async (A) => {
}, Z = async (A) => {
if (C.getBrowserMode()) {
if (!C.checkPremissionEvent(o.RequestInfo)) {
const e = {
......@@ -119,7 +119,7 @@ const p = {
const I = {
type: s.ResponseInfo,
status: t.SUCCESS,
data: p[A]
data: S[A]
};
return Promise.resolve(I);
}
......@@ -143,7 +143,7 @@ const p = {
I(a);
}), C.setInfoRequest(A, n), C.send(o.RequestInfo, { key: A });
});
}, h = "tokenEx.tokenEx", B = async () => {
}, f = "tokenEx.tokenEx", Q = async () => {
if (!C.getInitialized())
throw new Error("SDK not initialized");
if (C.getBrowserMode()) {
......@@ -157,7 +157,7 @@ const p = {
const A = {
type: s.ResponseToken,
status: t.SUCCESS,
data: h
data: f
};
return Promise.resolve(A);
}
......@@ -167,14 +167,14 @@ const p = {
};
C.on(s.ResponseToken, I), C.send(o.RequestToken);
});
}, S = {
}, y = {
path: "/hello.png",
base64: ""
}, f = {
}, G = {
path: "/hello.png",
size: 12e3,
base64: ""
}, Z = async (A) => {
}, z = async (A) => {
if (!C.getInitialized())
throw new Error("SDK not initialized");
if (C.getBrowserMode()) {
......@@ -188,7 +188,7 @@ const p = {
const g = {
type: s.ResponsePickerImage,
status: t.SUCCESS,
data: S
data: y
};
return Promise.resolve(g);
}
......@@ -198,7 +198,7 @@ const p = {
};
C.on(s.ResponsePickerImage, e), C.send(o.RequestPickerImage, { type: A });
});
}, Q = async () => {
}, M = async () => {
if (!C.getInitialized())
throw new Error("SDK not initialized");
if (C.getBrowserMode()) {
......@@ -212,7 +212,7 @@ const p = {
const A = {
type: s.ResponsePickerFile,
status: t.SUCCESS,
data: f
data: G
};
return Promise.resolve(A);
}
......@@ -222,9 +222,9 @@ const p = {
};
C.on(s.ResponsePickerFile, I), C.send(o.RequestPickerFile, void 0);
});
}, z = (A) => {
}, k = (A) => {
C.send(o.RequestCloseApp, A);
}, M = async () => {
}, v = async () => {
if (!C.checkPremissionEvent(o.RequestVibrate)) {
const A = {
type: s.ResponseVibrate,
......@@ -233,7 +233,7 @@ const p = {
return Promise.resolve(A);
}
C.send(o.RequestVibrate);
}, k = async (A) => {
}, Y = async (A) => {
if (!C.getInitialized())
throw new Error("SDK not initialized");
if (C.getBrowserMode()) {
......@@ -252,7 +252,7 @@ const p = {
return Promise.resolve(g);
}
C.send(o.RequestCall, { phoneNumber: A });
}, v = async (A) => {
}, K = async (A) => {
if (!C.getInitialized())
throw new Error("SDK not initialized");
if (C.getBrowserMode()) {
......@@ -271,7 +271,7 @@ const p = {
return Promise.resolve(g);
}
C.send(o.RequestSms, { phoneNumber: A });
}, Y = async (A) => {
}, b = async (A) => {
if (!C.getInitialized())
throw new Error("SDK not initialized");
if (C.getBrowserMode()) {
......@@ -287,7 +287,7 @@ const p = {
};
C.on(s.ResponseConfigApp, e), C.send(o.RequestConfigUIApp, A);
});
}, K = async (A) => {
}, D = async (A) => {
if (!C.getInitialized())
throw new Error("SDK not initialized");
if (C.getBrowserMode()) {
......@@ -311,10 +311,10 @@ const p = {
};
C.on(s.ResponseGetPermisstion, e), C.send(o.requestGetPermission, { type: A });
});
}, y = {
}, E = {
status: "success",
message: "Tạo đơn hàng thành công"
}, b = async (A) => {
}, j = async (A) => {
if (!C.getInitialized())
throw new Error("SDK not initialized");
if (C.getBrowserMode()) {
......@@ -328,7 +328,7 @@ const p = {
const g = {
type: s.ResponsePayment,
status: t.SUCCESS,
data: y
data: E
};
return Promise.resolve(g);
}
......@@ -338,7 +338,7 @@ const p = {
};
C.on(s.ResponsePayment, e), C.send(o.RequestPayment, A);
});
}, D = (A, g) => {
}, q = (A, g) => {
const I = g || C;
if (!I.getInitialized())
throw new Error("SDK not initialized");
......@@ -348,10 +348,10 @@ const p = {
return I.on(s.ResponsePayment, e), () => {
I.off(s.ResponsePayment, e);
};
}, G = {
}, w = {
latitude: 21.0239852,
longitude: 105.791488
}, j = async () => {
}, J = async () => {
if (!C.getInitialized())
throw new Error("SDK not initialized");
if (C.getBrowserMode()) {
......@@ -365,7 +365,7 @@ const p = {
const A = {
type: s.ResponseCurrentLocation,
status: t.SUCCESS,
data: G
data: w
};
return Promise.resolve(A);
}
......@@ -375,7 +375,7 @@ const p = {
};
C.on(s.ResponseCurrentLocation, I), C.send(o.RequestCurrentLocation);
});
}, q = async () => {
}, L = async () => {
if (!C.getInitialized())
throw new Error("SDK not initialized");
if (C.getBrowserMode()) {
......@@ -398,7 +398,7 @@ const p = {
};
C.on(s.ResponseLocationPermission, I), C.send(o.RequestLocationPermission);
});
}, J = (A, g) => {
}, U = (A, g) => {
const I = g || C;
if (!I.getInitialized())
throw new Error("SDK not initialized");
......@@ -432,7 +432,7 @@ const p = {
};
C.on(s.responseSaveStore, e), C.send(o.requestSaveStore, { data: A });
});
}, U = async () => {
}, O = async () => {
if (!C.getInitialized())
throw new Error("SDK not initialized");
if (C.getBrowserMode()) {
......@@ -456,7 +456,7 @@ const p = {
};
C.on(s.responseGetStore, I), C.send(o.requestGetStore);
});
}, L = async () => {
}, x = async () => {
if (!C.getInitialized())
throw new Error("SDK not initialized");
if (C.getBrowserMode()) {
......@@ -482,28 +482,30 @@ const p = {
});
};
export {
u as EKeyInfor,
P as EMediaType,
u as EHeaderMode,
P as EIconNavigationPosision,
d as EKeyInfor,
m as EMediaType,
t as EStatus,
o as ETypeRequest,
s as ETypeResponse,
k as call,
L as clearStore,
z as closeApp,
Y as configUIApp,
j as currentLocation,
Y as call,
x as clearStore,
k as closeApp,
b as configUIApp,
J as currentLocation,
C as fltSDK,
w as getInfo,
U as getStore,
B as getToken,
J as listenNotifiactionEvent,
D as listenPaymentEvent,
Q as openPickerFile,
Z as openPickerImage,
b as paymentRequest,
K as premissionsRequest,
q as requestLocationPermission,
Z as getInfo,
O as getStore,
Q as getToken,
U as listenNotifiactionEvent,
q as listenPaymentEvent,
M as openPickerFile,
z as openPickerImage,
j as paymentRequest,
D as premissionsRequest,
L as requestLocationPermission,
W as saveStore,
v as sms,
M as vibrate
K as sms,
v as vibrate
};
{
"name": "x-app-sdk",
"private": false,
"version": "1.1.3",
"version": "1.1.5",
"type": "module",
"files": [
"dist",
......
......@@ -9,7 +9,7 @@
"version": "1.0.0",
"license": "ISC",
"dependencies": {
"x-app-sdk": "^1.1.3"
"x-app-sdk": "^1.1.5"
}
},
"node_modules/@babel/helper-string-parser": {
......@@ -913,9 +913,9 @@
"integrity": "sha512-/BpdSx+yCQGnCvecbyXdxHDkuk55/G3xwnC0GqY4gmQ3j+A+g8kzzgB4Nk/SINjqn6+waqw3EgbVF2QKExkRxQ=="
},
"node_modules/x-app-sdk": {
"version": "1.1.3",
"resolved": "https://registry.npmjs.org/x-app-sdk/-/x-app-sdk-1.1.3.tgz",
"integrity": "sha512-SM3X5HbA+J2wkRzRAu1siXS/v8ULVCYK7HDvCgzmsZkkStxEv7LobaAW65vAqeNTwAO+MLeRwVVElHq2myCrFQ==",
"version": "1.1.5",
"resolved": "https://registry.npmjs.org/x-app-sdk/-/x-app-sdk-1.1.5.tgz",
"integrity": "sha512-XeXVzy32A1eX5GjSXcC9kIMIYkqdMNkiY8j6j+Ao6czqw2i/vdK/ybhDZuKFxOy5hcLzA70wdmRlZJ/HQJCSRg==",
"dependencies": {
"vite-plugin-dts": "^4.5.0"
}
......
......@@ -14,6 +14,6 @@
"author": "",
"license": "ISC",
"dependencies": {
"x-app-sdk": "^1.1.3"
"x-app-sdk": "^1.1.5"
}
}
......@@ -30,8 +30,6 @@ environment:
dependencies:
flutter:
sdk: flutter
flutter_localizations:
sdk: flutter
dio: ^5.8.0+1
cupertino_icons: ^1.0.8
shared_preferences: ^2.5.2
......@@ -40,7 +38,7 @@ dependencies:
fluttertoast: ^8.2.13
logger: ^2.4.0
url_launcher: ^6.3.1
flutter_widget_from_html: ^0.17.1
flutter_widget_from_html_core: ^0.17.0
device_info_plus: ^12.1.0
uuid: ^4.3.3
universal_html: ^2.2.4
......@@ -64,7 +62,7 @@ dependencies:
image_gallery_saver: ^2.0.3
fl_chart: ^1.1.0
mobile_scanner: ^7.0.1
encrypt: ^5.0.1
pointycastle: ^3.9.1
flutter_launcher_icons: ^0.14.4
firebase_core: ^4.1.0
firebase_messaging: ^16.0.1
......@@ -95,6 +93,7 @@ flutter:
# The following line ensures that the Material Icons font is
# included with your application, so that you can use the icons in
# the material Icons class.
generate: false
uses-material-design: true
# To add assets to your application, add an assets section, like this:
......
#!/bin/bash
#!/usr/bin/env bash
# Script để chạy development
# Run Flutter web (dev environment) with CORS-friendly local server.
# Builds the app using CanvasKit renderer and serves it from build/web on :8080.
echo "🔧 Running Development..."
set -euo pipefail
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
PROJECT_ROOT="$(cd "${SCRIPT_DIR}/.." && pwd)"
PORT="${PORT:-8080}"
BROWSER_PROFILE="${BROWSER_PROFILE:-/tmp/mypoint_web_dev}"
cd "${PROJECT_ROOT}"
kill_port() {
local port="$1"
lsof -i ":${port}" | awk 'NR>1 {print $2}' | xargs kill -9 2>/dev/null || true
}
set_env() {
local env="$1"
case "${env}" in
dev)
echo "🔧 Switching to DEVELOPMENT environment..."
if [ ! -f assets/config/env_dev.json ]; then
echo "❌ assets/config/env_dev.json not found" >&2
exit 1
fi
cp assets/config/env_dev.json assets/config/env.json
;;
prod)
echo "🚀 Switching to PRODUCTION environment..."
cat > assets/config/env.json <<'EOF'
{
"flavor":"pro",
"baseUrl":"https://api.mypoint.com.vn/8854/gup2start/rest",
"t3Token":"runner-env-flavor-pro",
"enableLogging":false
}
EOF
;;
*)
echo "❌ Invalid environment: ${env}" >&2
exit 1
;;
esac
echo "📋 Current config:"
cat assets/config/env.json
echo ""
}
copy_x_app_sdk() {
local src="node_modules/x-app-sdk/dist/index.es.js"
local dest="build/web/js/x_app_sdk_bundle.js"
if [ ! -f "${src}" ]; then
echo "❌ x-app-sdk bundle not found at ${src}" >&2
exit 1
fi
mkdir -p "$(dirname "${dest}")"
cp "${src}" "${dest}"
echo "✅ Copied x-app-sdk bundle."
}
build_web() {
echo "📦 Getting Flutter packages..."
flutter pub get
echo "🔨 Building Flutter web app (release, CanvasKit)..."
flutter build web \
--release \
--pwa-strategy=none \
--dart-define=FLUTTER_WEB_USE_SKIA=true \
--dart-define=FLUTTER_WEB_USE_SKWASM=false \
--no-wasm-dry-run
}
# Kill server cũ
lsof -i :8080 | awk 'NR>1 {print $2}' | xargs kill -9 2>/dev/null || true
start_server() {
python3 - "${PROJECT_ROOT}/build/web" "${PORT}" <<'PY' &
import http.server
import socketserver
import os
import sys
# Chuyển sang dev environment
./scripts/switch_env.sh dev
ROOT = sys.argv[1]
PORT = int(sys.argv[2])
os.chdir(ROOT)
# Chạy web app (sẽ tự mở Chrome)
./scripts/run_web_complete.sh
class CORSRequestHandler(http.server.SimpleHTTPRequestHandler):
def end_headers(self):
self.send_header('Access-Control-Allow-Origin', '*')
self.send_header('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE, OPTIONS')
self.send_header('Access-Control-Allow-Headers', 'Content-Type, Authorization, X-Requested-With, Accept, Origin')
super().end_headers()
def do_OPTIONS(self):
self.send_response(200)
self.end_headers()
def do_GET(self):
path = self.translate_path(self.path)
if os.path.isdir(path):
path = os.path.join(path, 'index.html')
if not os.path.exists(path):
self.path = '/index.html'
return super().do_GET()
def log_message(self, fmt, *args):
print(f"🌐 {fmt % args}")
with socketserver.TCPServer(('', PORT), CORSRequestHandler) as httpd:
print(f"🚀 Dev server running at http://localhost:{PORT}")
print(f"📁 Serving from: {os.getcwd()}")
print("🔧 CORS headers enabled (browser launched with web security disabled).")
print("✅ Press Ctrl+C to stop.")
httpd.serve_forever()
PY
SERVER_PID=$!
}
open_browser() {
local url="http://localhost:${PORT}"
echo "🌐 Opening Chrome with CORS disabled at ${url}..."
if command -v open >/dev/null 2>&1; then
open -n -a "Google Chrome" --args --disable-web-security --user-data-dir="${BROWSER_PROFILE}" --disable-features=VizDisplayCompositor "${url}"
elif command -v google-chrome >/dev/null 2>&1; then
google-chrome --disable-web-security --user-data-dir="${BROWSER_PROFILE}" --disable-features=VizDisplayCompositor "${url}" &
else
echo "⚠️ Chrome not found. Please open ${url} manually."
fi
}
cleanup() {
if [[ -n "${SERVER_PID:-}" ]] && ps -p "${SERVER_PID}" >/dev/null 2>&1; then
kill "${SERVER_PID}" || true
fi
}
echo "🔧 Running Development..."
kill_port "${PORT}"
set_env dev
build_web
copy_x_app_sdk
start_server
trap cleanup EXIT INT TERM
sleep 2
open_browser
wait "${SERVER_PID}"
#!/bin/bash
# Script build Production (tối đa hoá nén/ẩn mã) để gửi cho T3 tích hợp host app
set -e
echo "🚀 Building Production package (max optimization)..."
# 1) Chuyển env sang PRODUCTION
./scripts/switch_env.sh prod
# 2) Clean & get deps (đảm bảo build fresh)
echo "🧹 Cleaning..."
flutter clean || true
rm -rf .dart_tool build || true
echo "📦 Getting packages..."
flutter pub get
# 3) Build web (ẩn mã JS tối đa, bỏ source maps, tắt service worker để tránh cache khi cần)
# - --release: bật dart2js minify + tree-shake
# - --no-source-maps: không phát hành sourcemaps (ẩn mã tối đa)
# - --pwa-strategy=none: tắt SW nếu không cần PWA để tránh cache khó debug khi embed
# - --dart-define=FLUTTER_WEB_USE_SKIA=false: ưu tiên HTML renderer để hạn chế sự cố CORS ảnh khi host
echo "🔨 Flutter build web (release, no source maps)..."
flutter build web \
--release \
--no-source-maps \
--pwa-strategy=none \
--dart-define=FLUTTER_WEB_USE_SKIA=false
echo "📥 Copying x-app-sdk bundle into build artifacts..."
./scripts/copy_x_app_sdk_bundle.sh
echo "✅ Build completed. Preparing artifact..."
# 4) Đóng gói artifact gọn để gửi cho T3
STAMP=$(date +%Y%m%d_%H%M%S)
OUT_DIR="web_prod_${STAMP}"
mkdir -p "$OUT_DIR"
cp -r build/web/* "$OUT_DIR/"
# Tuỳ chọn: loại bỏ file không cần thiết (nếu có)
find "$OUT_DIR" -name "*.map" -type f -delete || true
ZIP_FILE="${OUT_DIR}.zip"
echo "📦 Creating ${ZIP_FILE} ..."
zip -rq "$ZIP_FILE" "$OUT_DIR"
echo ""
echo "🎉 Production artifact is ready"
echo " Folder: $OUT_DIR"
echo " Zip: $ZIP_FILE"
echo ""
echo "📌 Gợi ý gửi cho T3: chỉ gửi file .zip hoặc nội dung thư mục $OUT_DIR"
echo " - Đã tối đa hoá ẩn mã (minified), không đính kèm source maps"
echo " - Không bật service worker để tránh cache khi embed trong host app"
echo " - Ưu tiên HTML renderer để giảm sự cố CORS ảnh"
#!/usr/bin/env bash
# Run Flutter web with production configuration for smoke testing on localhost.
# Builds CanvasKit bundle and serves it from build/web on :8080 (no CORS bypass).
set -euo pipefail
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
PROJECT_ROOT="$(cd "${SCRIPT_DIR}/.." && pwd)"
PORT="${PORT:-8080}"
cd "${PROJECT_ROOT}"
kill_port() {
local port="$1"
lsof -i ":${port}" | awk 'NR>1 {print $2}' | xargs kill -9 2>/dev/null || true
}
set_env_prod() {
cat > assets/config/env.json <<'EOF'
{
"flavor":"pro",
"baseUrl":"https://api.mypoint.com.vn/8854/gup2start/rest",
"t3Token":"runner-env-flavor-pro",
"enableLogging":false
}
EOF
echo "📋 Current production config written to assets/config/env.json"
}
copy_x_app_sdk() {
local src="node_modules/x-app-sdk/dist/index.es.js"
local dest="build/web/js/x_app_sdk_bundle.js"
if [ ! -f "${src}" ]; then
echo "❌ x-app-sdk bundle not found at ${src}" >&2
exit 1
fi
mkdir -p "$(dirname "${dest}")"
cp "${src}" "${dest}"
echo "✅ Copied x-app-sdk bundle."
}
build_web() {
echo "📦 Getting Flutter packages..."
flutter pub get
echo "🔨 Building Flutter web app (production, CanvasKit)..."
flutter build web \
--release \
--pwa-strategy=none \
--dart-define=FLUTTER_WEB_USE_SKIA=true \
--dart-define=FLUTTER_WEB_USE_SKWASM=false \
--no-source-maps \
--no-wasm-dry-run
}
start_server() {
python3 - "${PROJECT_ROOT}/build/web" "${PORT}" <<'PY' &
import http.server
import socketserver
import os
import sys
ROOT = sys.argv[1]
PORT = int(sys.argv[2])
os.chdir(ROOT)
class SPAHandler(http.server.SimpleHTTPRequestHandler):
def do_GET(self):
path = self.translate_path(self.path)
if os.path.isdir(path):
path = os.path.join(path, 'index.html')
if not os.path.exists(path):
self.path = '/index.html'
return super().do_GET()
def log_message(self, fmt, *args):
print(f"🌐 {fmt % args}")
with socketserver.TCPServer(('', PORT), SPAHandler) as httpd:
print(f"🚀 Production preview running at http://localhost:{PORT}")
print(f"📁 Serving from: {os.getcwd()}")
print("✅ Press Ctrl+C to stop.")
httpd.serve_forever()
PY
SERVER_PID=$!
}
open_browser() {
local url="http://localhost:${PORT}"
echo "🌐 Opening default browser at ${url}..."
if command -v open >/dev/null 2>&1; then
open "${url}"
elif command -v xdg-open >/dev/null 2>&1; then
xdg-open "${url}"
else
echo "⚠️ Please open ${url} manually."
fi
}
cleanup() {
if [[ -n "${SERVER_PID:-}" ]] && ps -p "${SERVER_PID}" >/dev/null 2>&1; then
kill "${SERVER_PID}" || true
fi
}
echo "🚀 Running Production preview..."
kill_port "${PORT}"
set_env_prod
build_web
copy_x_app_sdk
start_server
trap cleanup EXIT INT TERM
sleep 2
open_browser
wait "${SERVER_PID}"
#!/bin/bash
set -euo pipefail
SRC="node_modules/x-app-sdk/dist/index.es.js"
DEST_DEFAULT="build/web/js/x_app_sdk_bundle.js"
DEST="${1:-$DEST_DEFAULT}"
if [ ! -f "$SRC" ]; then
echo "❌ x-app-sdk bundle not found at $SRC" >&2
exit 1
fi
mkdir -p "$(dirname "$DEST")"
cp "$SRC" "$DEST"
echo "✅ Copied x-app-sdk bundle to $DEST"
#!/bin/bash
# Complete script to run Flutter web app with CORS solution
echo "🌐 Starting Flutter web app with CORS solution..."
# Check if we're in the right directory
if [ ! -f "pubspec.yaml" ]; then
echo "❌ Please run this script from the Flutter project root directory"
exit 1
fi
# Build Flutter web app (force HTML renderer via dart-define for older Flutter)
echo "🔨 Building Flutter web app (HTML renderer)..."
flutter build web --release --dart-define=FLUTTER_WEB_USE_SKIA=false
if [ $? -eq 0 ]; then
echo "✅ Build successful!"
echo "📥 Copying x-app-sdk bundle into build artifacts..."
./scripts/copy_x_app_sdk_bundle.sh
else
echo "❌ Build failed!"
exit 1
fi
# Start web server in background
echo "🚀 Starting web server..."
cd build/web
python3 -c "
import http.server
import socketserver
import socket
import os
class CORSHTTPRequestHandler(http.server.SimpleHTTPRequestHandler):
def end_headers(self):
self.send_header('Access-Control-Allow-Origin', '*')
self.send_header('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE, OPTIONS')
self.send_header('Access-Control-Allow-Headers', 'Content-Type, Authorization, X-Requested-With, Accept, Origin')
super().end_headers()
def do_OPTIONS(self):
self.send_response(200)
self.end_headers()
def log_message(self, format, *args):
print(f'🌐 {format % args}')
def do_GET(self):
path = self.translate_path(self.path)
if not os.path.exists(path):
self.path = '/index.html'
return super().do_GET()
return super().do_GET()
def find_free_port(start_port=8080, max_attempts=10):
for port in range(start_port, start_port + max_attempts):
try:
with socket.socket(socket.AF_INET, socket.SOCK_STREAM) as s:
s.bind(('', port))
return port
except OSError:
continue
return None
PORT = find_free_port(8080, 20)
if not PORT:
print('❌ No free port found')
exit(1)
print(f'🚀 Server running at http://localhost:{PORT}')
with socketserver.TCPServer(('', PORT), CORSHTTPRequestHandler) as httpd:
httpd.serve_forever()
" &
SERVER_PID=$!
# Wait for server to start
sleep 3
# Open browser with CORS disabled
echo "🌐 Opening browser with CORS disabled..."
if command -v open &> /dev/null; then
# macOS
open -n -a "Google Chrome" --args --disable-web-security --user-data-dir=/tmp/chrome_dev --disable-features=VizDisplayCompositor http://localhost:8080
elif command -v google-chrome &> /dev/null; then
# Linux
google-chrome --disable-web-security --user-data-dir=/tmp/chrome_dev --disable-features=VizDisplayCompositor http://localhost:8080 &
else
echo "⚠️ Chrome not found. Please open manually: http://localhost:8080"
fi
echo ""
echo "✅ Setup complete!"
echo "🌐 Web app: http://localhost:8080"
echo "🔧 CORS disabled in browser for development"
echo "📋 Retry limit: 3 attempts for Super App data"
echo ""
echo "Press Ctrl+C to stop the server"
# Wait for user to stop
wait $SERVER_PID
#!/bin/bash
set -euo pipefail
FOLDER="${1:-build/web}"
PORT="${2:-8080}"
if [ ! -d "$FOLDER" ]; then
echo "❌ Folder '$FOLDER' not found."
exit 1
fi
pushd "$FOLDER" >/dev/null
python3 - <<'PY'
import http.server
import socketserver
import socket
import os
import sys
PORT = int(sys.argv[1])
class SPARequestHandler(http.server.SimpleHTTPRequestHandler):
def end_headers(self):
self.send_header('Access-Control-Allow-Origin', '*')
self.send_header('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE, OPTIONS')
self.send_header('Access-Control-Allow-Headers', 'Content-Type, Authorization, X-Requested-With, Accept, Origin')
super().end_headers()
def do_OPTIONS(self):
self.send_response(200)
self.end_headers()
def do_GET(self):
path = self.translate_path(self.path)
if not os.path.exists(path):
self.path = '/index.html'
return super().do_GET()
def log_message(self, format, *args):
print(f'🌐 {format % args}')
with socketserver.TCPServer(('', PORT), SPARequestHandler) as httpd:
print(f'🚀 Serving {os.getcwd()} at http://localhost:{PORT}')
print('💡 Keep this terminal open. Ctrl+C to stop.')
httpd.serve_forever()
PY "$PORT"
popd >/dev/null
#!/bin/bash
# Script để chuyển đổi giữa môi trường dev và production
ENV=${1:-"prod"}
if [ "$ENV" = "dev" ]; then
echo "🔧 Switching to DEVELOPMENT environment..."
cp assets/config/env_dev.json assets/config/env.json
echo "✅ Switched to DEVELOPMENT:"
echo " - API: https://api.sandbox.mypoint.com.vn/8854/gup2start/rest"
echo " - Logging: Enabled"
echo " - Flavor: dev"
elif [ "$ENV" = "prod" ]; then
echo "🚀 Switching to PRODUCTION environment..."
# Create production config directly
cat > assets/config/env.json << 'EOF'
{
"flavor":"pro",
"baseUrl":"https://api.mypoint.com.vn/8854/gup2start/rest",
"t3Token":"runner-env-flavor-pro",
"enableLogging":false
}
EOF
echo "✅ Switched to PRODUCTION:"
echo " - API: https://api.mypoint.com.vn/8854/gup2start/rest"
echo " - Logging: Disabled"
echo " - Flavor: pro"
else
echo "❌ Invalid environment. Use 'dev' or 'prod'"
echo "Usage: ./scripts/switch_env.sh [dev|prod]"
exit 1
fi
echo ""
echo "📋 Current config:"
cat assets/config/env.json
echo ""
echo "💡 Now you can run:"
echo " - Development: ./scripts/run_web_complete.sh"
echo " - Export: ./export_web.sh"
#!/bin/bash
# Script to test x-app-sdk implementation
echo "🧪 Testing x-app-sdk implementation..."
# Check if we're in the right directory
if [ ! -f "pubspec.yaml" ]; then
echo "❌ Please run this script from the Flutter project root directory"
exit 1
fi
# Build Flutter web app
echo "🔨 Building Flutter web app..."
flutter build web --release
if [ $? -eq 0 ]; then
echo "✅ Build successful!"
# Start local server
echo "🚀 Starting local server on port 8080..."
echo "🌐 Open your browser and go to: http://localhost:8080"
echo ""
echo "🔧 To test x-app-sdk integration:"
echo "1. Open browser console (F12)"
echo "2. Check for x-app-sdk initialization logs"
echo "3. Look for token retrieval logs in splash screen"
echo "4. Test closeApp functionality"
echo ""
echo "📋 Expected logs:"
echo "- '✅ x-app-sdk loaded from node_modules and ready'"
echo "- '🔧 SDK methods available: ['getToken', 'closeApp']'"
echo "- '🔍 SplashScreen - Attempting to get token from x-app-sdk...'"
echo "- '✅ SplashScreen - Token retrieved from x-app-sdk: ...'"
echo ""
echo "⚠️ Note: x-app-sdk will work differently in Super App environment"
echo ""
echo "Press Ctrl+C to stop the server"
# Start server
cd build/web
python3 -c "
import http.server
import socketserver
import os
class CORSHTTPRequestHandler(http.server.SimpleHTTPRequestHandler):
def end_headers(self):
self.send_header('Access-Control-Allow-Origin', '*')
self.send_header('Access-Control-Allow-Methods', 'GET, POST, OPTIONS')
self.send_header('Access-Control-Allow-Headers', 'Content-Type, Authorization, X-Requested-With')
super().end_headers()
def do_OPTIONS(self):
self.send_response(200)
self.end_headers()
def do_GET(self):
path = self.translate_path(self.path)
if not os.path.exists(path):
self.path = '/index.html'
return super().do_GET()
return super().do_GET()
PORT = 8080
with socketserver.TCPServer(('', PORT), CORSHTTPRequestHandler) as httpd:
print(f'Serving at port {PORT}')
httpd.serve_forever()
"
else
echo "❌ Build failed!"
exit 1
fi
import 'dart:convert';
import 'dart:io';
/// Simple analyzer for dart2js dump-info output.
/// Usage: dart run tools/print_size_info.dart <path_to_info_json> [topN]
void main(List<String> args) {
if (args.isEmpty) {
stderr.writeln(
'Usage: dart run tools/print_size_info.dart <path_to_info_json> [topN]',
);
exit(1);
}
final infoFile = File(args[0]);
if (!infoFile.existsSync()) {
stderr.writeln('File not found: ${infoFile.path}');
exit(1);
}
final topN = args.length > 1 ? int.tryParse(args[1]) ?? 20 : 20;
final root = json.decode(infoFile.readAsStringSync()) as Map<String, dynamic>;
final libraries = <Map<String, dynamic>>[];
// Newer dump-info format exposes elements in root['elements']['library'].
final elements = root['elements'];
if (elements is Map && elements['library'] is Map) {
final libs = elements['library'] as Map;
libs.forEach((_, value) {
if (value is Map<String, dynamic>) {
final uri = value['canonicalUri']?.toString() ?? '';
final displayName = uri.startsWith('package:')
? uri
: (value['name']?.toString().isNotEmpty ?? false
? value['name'].toString()
: uri.isNotEmpty
? uri
: '<unknown>');
final size = value['size'];
libraries.add({
'name': displayName,
'size': size is num ? size : num.tryParse('$size') ?? 0,
});
}
});
} else {
// Fallback to old format by walking the program tree.
final program = root['program'];
if (program is! Map<String, dynamic>) {
stderr.writeln('Invalid dump-info format: missing program node');
exit(1);
}
void walk(Map<String, dynamic> node) {
if (node['kind'] == 'library') {
libraries.add({'name': node['name'], 'size': node['size']});
}
final children = node['children'];
if (children is List) {
for (final child in children) {
if (child is Map<String, dynamic>) {
walk(child);
}
}
}
}
walk(program);
}
libraries.sort(
(a, b) => (b['size'] as num).compareTo(a['size'] as num),
);
if (libraries.isEmpty) {
stdout.writeln('No libraries found in info file. Structure may differ.');
return;
}
stdout.writeln('Top $topN libraries by size (bytes):');
for (final entry in libraries.take(topN)) {
final size = (entry['size'] as num).toString().padLeft(10);
stdout.writeln('$size ${entry['name']}');
}
}
Supports Markdown
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment