@bytexbyte/nxtlinq-ai-agent-sdk 1.6.9 → 1.6.10

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.
@@ -1 +1 @@
1
- {"version":3,"file":"PermissionForm.d.ts","sourceRoot":"","sources":["../../../src/components/ui/PermissionForm.tsx"],"names":[],"mappings":"AAAA,sCAAsC;AACtC,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAK/B,UAAU,mBAAmB;IAC3B,OAAO,EAAE,MAAM,IAAI,CAAC;CACrB;AAED,eAAO,MAAM,cAAc,EAAE,KAAK,CAAC,EAAE,CAAC,mBAAmB,CA2iBxD,CAAC"}
1
+ {"version":3,"file":"PermissionForm.d.ts","sourceRoot":"","sources":["../../../src/components/ui/PermissionForm.tsx"],"names":[],"mappings":"AAAA,sCAAsC;AACtC,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAK/B,UAAU,mBAAmB;IAC3B,OAAO,EAAE,MAAM,IAAI,CAAC;CACrB;AAED,eAAO,MAAM,cAAc,EAAE,KAAK,CAAC,EAAE,CAAC,mBAAmB,CA4jBxD,CAAC"}
@@ -161,6 +161,23 @@ export const PermissionForm = ({ onClose }) => {
161
161
  display: flex !important;
162
162
  flex-direction: column !important;
163
163
  overflow: hidden !important;
164
+
165
+ /* Mobile responsive adjustments */
166
+ @media (max-width: 768px) {
167
+ width: 75vw !important;
168
+ max-width: 75vw !important;
169
+ padding: 20px !important;
170
+ border-radius: 8px !important;
171
+ max-height: 65vh !important;
172
+ }
173
+
174
+ @media (max-width: 480px) {
175
+ width: 70vw !important;
176
+ max-width: 70vw !important;
177
+ padding: 16px !important;
178
+ border-radius: 6px !important;
179
+ max-height: 60vh !important;
180
+ }
164
181
  `, children: [_jsxs("div", { css: css `
165
182
  display: flex !important;
166
183
  justify-content: space-between !important;
@@ -1 +1 @@
1
- {"version":3,"file":"isolatedStyles.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/styles/isolatedStyles.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,QAAQ,2CAwBpB,CAAC;AAGF,eAAO,MAAM,YAAY,2CAmExB,CAAC;AAGF,eAAO,MAAM,cAAc,2CA0B1B,CAAC;AAGF,eAAO,MAAM,UAAU,2CActB,CAAC;AAGF,eAAO,MAAM,UAAU,2CAStB,CAAC;AAGF,eAAO,MAAM,WAAW,2CAMvB,CAAC;AAGF,eAAO,MAAM,YAAY,2CA0BxB,CAAC;AAGF,eAAO,MAAM,WAAW,2CAoBvB,CAAC;AAGF,eAAO,MAAM,oBAAoB,2CAQhC,CAAC;AAGF,eAAO,MAAM,aAAa,2CAKzB,CAAC;AAGF,eAAO,MAAM,WAAW,2CAKvB,CAAC;AAGF,eAAO,MAAM,cAAc,2CAQ1B,CAAC;AAGF,eAAO,MAAM,kBAAkB,2CAQ9B,CAAC;AAGF,eAAO,MAAM,mBAAmB,2CAS/B,CAAC;AAGF,eAAO,MAAM,aAAa,2CAezB,CAAC;AAGF,eAAO,MAAM,YAAY,2CAexB,CAAC;AAGF,eAAO,MAAM,eAAe,2CAc3B,CAAC;AAGF,eAAO,MAAM,gBAAgB,2CAQ5B,CAAC;AAGF,eAAO,MAAM,cAAc,2CAM1B,CAAC;AAGF,eAAO,MAAM,UAAU,2CAYtB,CAAC;AAGF,eAAO,MAAM,QAAQ,2CAMpB,CAAC;AAGF,eAAO,MAAM,iBAAiB,2CAc7B,CAAC;AAGF,eAAO,MAAM,YAAY,2CAIxB,CAAC;AAGF,eAAO,MAAM,UAAU,2CAItB,CAAC;AAGF,eAAO,MAAM,YAAY,2CAIxB,CAAC;AAGF,eAAO,MAAM,SAAS,2CAIrB,CAAC;AAGF,eAAO,MAAM,gBAAgB,2CAiB5B,CAAC;AAGF,eAAO,MAAM,YAAY,2CAYxB,CAAC;AAGF,eAAO,MAAM,SAAS,2CAWrB,CAAC;AAGF,eAAO,MAAM,cAAc,2CAM1B,CAAC;AAGF,eAAO,MAAM,aAAa,2CAMzB,CAAC;AAGF,eAAO,MAAM,eAAe,2CAoB3B,CAAC;AAGF,eAAO,MAAM,gBAAgB,2CAmB5B,CAAC;AAGF,eAAO,MAAM,cAAc,2CAO1B,CAAC"}
1
+ {"version":3,"file":"isolatedStyles.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/styles/isolatedStyles.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,QAAQ,2CAwBpB,CAAC;AAGF,eAAO,MAAM,YAAY,2CAmExB,CAAC;AAGF,eAAO,MAAM,cAAc,2CA6C1B,CAAC;AAGF,eAAO,MAAM,UAAU,2CAuCtB,CAAC;AAGF,eAAO,MAAM,UAAU,2CAStB,CAAC;AAGF,eAAO,MAAM,WAAW,2CAMvB,CAAC;AAGF,eAAO,MAAM,YAAY,2CA0BxB,CAAC;AAGF,eAAO,MAAM,WAAW,2CAoBvB,CAAC;AAGF,eAAO,MAAM,oBAAoB,2CAQhC,CAAC;AAGF,eAAO,MAAM,aAAa,2CAKzB,CAAC;AAGF,eAAO,MAAM,WAAW,2CAKvB,CAAC;AAGF,eAAO,MAAM,cAAc,2CAQ1B,CAAC;AAGF,eAAO,MAAM,kBAAkB,2CAQ9B,CAAC;AAGF,eAAO,MAAM,mBAAmB,2CAS/B,CAAC;AAGF,eAAO,MAAM,aAAa,2CAezB,CAAC;AAGF,eAAO,MAAM,YAAY,2CAexB,CAAC;AAGF,eAAO,MAAM,eAAe,2CAc3B,CAAC;AAGF,eAAO,MAAM,gBAAgB,2CAQ5B,CAAC;AAGF,eAAO,MAAM,cAAc,2CAM1B,CAAC;AAGF,eAAO,MAAM,UAAU,2CAYtB,CAAC;AAGF,eAAO,MAAM,QAAQ,2CAMpB,CAAC;AAGF,eAAO,MAAM,iBAAiB,2CAc7B,CAAC;AAGF,eAAO,MAAM,YAAY,2CAIxB,CAAC;AAGF,eAAO,MAAM,UAAU,2CAItB,CAAC;AAGF,eAAO,MAAM,YAAY,2CAIxB,CAAC;AAGF,eAAO,MAAM,SAAS,2CAIrB,CAAC;AAGF,eAAO,MAAM,gBAAgB,2CAiB5B,CAAC;AAGF,eAAO,MAAM,YAAY,2CAyBxB,CAAC;AAGF,eAAO,MAAM,SAAS,2CAWrB,CAAC;AAGF,eAAO,MAAM,cAAc,2CAM1B,CAAC;AAGF,eAAO,MAAM,aAAa,2CAMzB,CAAC;AAGF,eAAO,MAAM,eAAe,2CAoB3B,CAAC;AAGF,eAAO,MAAM,gBAAgB,2CAmB5B,CAAC;AAGF,eAAO,MAAM,cAAc,2CAO1B,CAAC"}
@@ -111,6 +111,7 @@ export const floatingButton = css `
111
111
  font-size: 14px !important;
112
112
  font-weight: 500 !important;
113
113
  font-family: inherit !important;
114
+ max-width: calc(100vw - 40px) !important;
114
115
 
115
116
  &:disabled {
116
117
  cursor: not-allowed !important;
@@ -121,6 +122,24 @@ export const floatingButton = css `
121
122
  background-color: #0056b3 !important;
122
123
  transform: translateY(-2px) !important;
123
124
  }
125
+
126
+ /* Mobile responsive adjustments */
127
+ @media (max-width: 768px) {
128
+ bottom: 15px !important;
129
+ right: 15px !important;
130
+ max-width: calc(100vw - 30px) !important;
131
+ padding: 8px 16px !important;
132
+ font-size: 13px !important;
133
+ }
134
+
135
+ @media (max-width: 480px) {
136
+ bottom: 10px !important;
137
+ right: 10px !important;
138
+ max-width: calc(100vw - 20px) !important;
139
+ padding: 6px 12px !important;
140
+ font-size: 12px !important;
141
+ border-radius: 16px !important;
142
+ }
124
143
  `;
125
144
  // Chat window container styles
126
145
  export const chatWindow = css `
@@ -128,7 +147,9 @@ export const chatWindow = css `
128
147
  bottom: 20px !important;
129
148
  right: 20px !important;
130
149
  width: 500px !important;
150
+ max-width: calc(100vw - 40px) !important;
131
151
  height: 600px !important;
152
+ max-height: calc(100vh - 40px) !important;
132
153
  background-color: white !important;
133
154
  border-radius: 10px !important;
134
155
  box-shadow: 0 5px 15px rgba(0,0,0,0.2) !important;
@@ -137,6 +158,29 @@ export const chatWindow = css `
137
158
  z-index: 1001 !important;
138
159
  overflow: hidden !important;
139
160
  font-family: inherit !important;
161
+
162
+ /* Mobile responsive adjustments */
163
+ @media (max-width: 768px) {
164
+ width: 70vw !important;
165
+ max-width: 70vw !important;
166
+ height: 60vh !important;
167
+ max-height: 60vh !important;
168
+ bottom: 20px !important;
169
+ right: 20px !important;
170
+ left: auto !important;
171
+ border-radius: 8px !important;
172
+ }
173
+
174
+ @media (max-width: 480px) {
175
+ width: 65vw !important;
176
+ max-width: 65vw !important;
177
+ height: 55vh !important;
178
+ max-height: 55vh !important;
179
+ bottom: 15px !important;
180
+ right: 15px !important;
181
+ left: auto !important;
182
+ border-radius: 6px !important;
183
+ }
140
184
  `;
141
185
  // Header styles
142
186
  export const chatHeader = css `
@@ -424,6 +468,19 @@ export const modalOverlay = css `
424
468
  justify-content: center !important;
425
469
  z-index: 1002 !important;
426
470
  padding: 20px !important;
471
+
472
+ /* Mobile responsive adjustments */
473
+ @media (max-width: 768px) {
474
+ padding: 15px !important;
475
+ align-items: flex-start !important;
476
+ padding-top: 20px !important;
477
+ }
478
+
479
+ @media (max-width: 480px) {
480
+ padding: 10px !important;
481
+ align-items: flex-start !important;
482
+ padding-top: 15px !important;
483
+ }
427
484
  `;
428
485
  // IDV banner styles
429
486
  export const idvBanner = css `
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Tests for URL utility functions
3
+ */
4
+ export {};
5
+ //# sourceMappingURL=urlUtils.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"urlUtils.test.d.ts","sourceRoot":"","sources":["../../../../src/core/utils/__tests__/urlUtils.test.ts"],"names":[],"mappings":"AAAA;;GAEG"}
@@ -0,0 +1,57 @@
1
+ /**
2
+ * Tests for URL utility functions
3
+ */
4
+ import { containsUrls, convertUrlsToLinks, convertUrlsToHtml } from '../urlUtils';
5
+ describe('URL Utils', () => {
6
+ describe('containsUrls', () => {
7
+ it('should detect URLs with http protocol', () => {
8
+ expect(containsUrls('Visit https://example.com for more info')).toBe(true);
9
+ expect(containsUrls('Check out http://test.org')).toBe(true);
10
+ });
11
+ it('should detect URLs with www', () => {
12
+ expect(containsUrls('Go to www.google.com')).toBe(true);
13
+ expect(containsUrls('Visit www.example.org')).toBe(true);
14
+ });
15
+ it('should detect domain names', () => {
16
+ expect(containsUrls('Contact us at support@company.com')).toBe(false);
17
+ expect(containsUrls('Visit company.com for details')).toBe(true);
18
+ });
19
+ it('should return false for text without URLs', () => {
20
+ expect(containsUrls('This is just plain text')).toBe(false);
21
+ expect(containsUrls('No URLs here')).toBe(false);
22
+ });
23
+ });
24
+ describe('convertUrlsToHtml', () => {
25
+ it('should convert URLs to HTML anchor tags', () => {
26
+ const text = 'Visit https://example.com for more info';
27
+ const result = convertUrlsToHtml(text);
28
+ expect(result).toContain('<a href="https://example.com"');
29
+ expect(result).toContain('target="_blank"');
30
+ expect(result).toContain('rel="noopener noreferrer"');
31
+ });
32
+ it('should handle www URLs', () => {
33
+ const text = 'Go to www.google.com';
34
+ const result = convertUrlsToHtml(text);
35
+ expect(result).toContain('<a href="https://www.google.com"');
36
+ });
37
+ it('should handle multiple URLs', () => {
38
+ const text = 'Visit https://example.com and www.google.com';
39
+ const result = convertUrlsToHtml(text);
40
+ expect(result).toContain('https://example.com');
41
+ expect(result).toContain('https://www.google.com');
42
+ });
43
+ });
44
+ describe('convertUrlsToLinks', () => {
45
+ it('should return array with mixed content', () => {
46
+ const text = 'Visit https://example.com for more info';
47
+ const result = convertUrlsToLinks(text);
48
+ expect(Array.isArray(result)).toBe(true);
49
+ expect(result.length).toBeGreaterThan(0);
50
+ });
51
+ it('should handle text without URLs', () => {
52
+ const text = 'This is just plain text';
53
+ const result = convertUrlsToLinks(text);
54
+ expect(result).toEqual([text]);
55
+ });
56
+ });
57
+ });
@@ -0,0 +1,8 @@
1
+ /**
2
+ * BerifyMe React Instance Fix
3
+ *
4
+ * This utility ensures that BerifyMe SDK uses the same React instance
5
+ * as our SDK, preventing the __SECRET_INTERNALS error.
6
+ */
7
+ export declare function fixBerifyMeReactInstance(): void;
8
+ //# sourceMappingURL=berifyMeReactFix.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"berifyMeReactFix.d.ts","sourceRoot":"","sources":["../../../src/core/utils/berifyMeReactFix.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,wBAAgB,wBAAwB,IAAI,IAAI,CA4E/C"}
@@ -0,0 +1,81 @@
1
+ /**
2
+ * BerifyMe React Instance Fix
3
+ *
4
+ * This utility ensures that BerifyMe SDK uses the same React instance
5
+ * as our SDK, preventing the __SECRET_INTERNALS error.
6
+ */
7
+ export function fixBerifyMeReactInstance() {
8
+ try {
9
+ // Wait for BerifyMe SDK to load
10
+ const checkBerifyMe = () => {
11
+ if (window.BerifyMeSDK) {
12
+ console.log('[BerifyMe React Fix] BerifyMe SDK detected, applying React instance fix...');
13
+ // Method 1: Try to set React instance if the method exists
14
+ if (window.BerifyMeSDK.setReactInstance) {
15
+ try {
16
+ const React = require('react');
17
+ const createRoot = require('react-dom/client').createRoot;
18
+ window.BerifyMeSDK.setReactInstance(React, createRoot);
19
+ console.log('[BerifyMe React Fix] ✅ React instance set successfully');
20
+ return;
21
+ }
22
+ catch (e) {
23
+ console.warn('[BerifyMe React Fix] Failed to set React instance via setReactInstance:', e);
24
+ }
25
+ }
26
+ // Method 2: Monkey patch React globals
27
+ try {
28
+ const React = require('react');
29
+ const ReactDOM = require('react-dom');
30
+ const createRoot = require('react-dom/client').createRoot;
31
+ // Store original globals
32
+ const originalReact = window.React;
33
+ const originalReactDOM = window.ReactDOM;
34
+ // Set our React instance as global
35
+ window.React = React;
36
+ window.ReactDOM = ReactDOM;
37
+ window.ReactDOMClient = { createRoot };
38
+ console.log('[BerifyMe React Fix] ✅ React globals patched successfully');
39
+ // Restore original globals after a delay
40
+ setTimeout(() => {
41
+ if (originalReact)
42
+ window.React = originalReact;
43
+ if (originalReactDOM)
44
+ window.ReactDOM = originalReactDOM;
45
+ console.log('[BerifyMe React Fix] Original React globals restored');
46
+ }, 1000);
47
+ }
48
+ catch (e) {
49
+ console.warn('[BerifyMe React Fix] Failed to patch React globals:', e);
50
+ }
51
+ // Method 3: Try to patch the BerifyMe modal component
52
+ try {
53
+ if (window.BerifyMeSDK.modal) {
54
+ const originalModal = window.BerifyMeSDK.modal;
55
+ const React = require('react');
56
+ // Create a wrapper that uses our React instance
57
+ window.BerifyMeSDK.modal = (props) => {
58
+ return React.createElement(originalModal, props);
59
+ };
60
+ console.log('[BerifyMe React Fix] ✅ BerifyMe modal component patched');
61
+ }
62
+ }
63
+ catch (e) {
64
+ console.warn('[BerifyMe React Fix] Failed to patch BerifyMe modal:', e);
65
+ }
66
+ }
67
+ else {
68
+ // Retry after a short delay
69
+ setTimeout(checkBerifyMe, 100);
70
+ }
71
+ };
72
+ checkBerifyMe();
73
+ }
74
+ catch (error) {
75
+ console.error('[BerifyMe React Fix] Error applying React instance fix:', error);
76
+ }
77
+ }
78
+ // Auto-apply the fix when this module is loaded
79
+ if (typeof window !== 'undefined') {
80
+ fixBerifyMeReactInstance();
81
+ }
@@ -0,0 +1,9 @@
1
+ /**
2
+ * React Instance Check Utility
3
+ *
4
+ * This utility helps prevent React version conflicts by ensuring
5
+ * the SDK uses the same React instance as the host application.
6
+ */
7
+ export declare function checkReactInstance(): void;
8
+ export declare function ensureReactCompatibility(): void;
9
+ //# sourceMappingURL=reactInstanceCheck.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reactInstanceCheck.d.ts","sourceRoot":"","sources":["../../../src/core/utils/reactInstanceCheck.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAIH,wBAAgB,kBAAkB,IAAI,IAAI,CAoCzC;AAED,wBAAgB,wBAAwB,IAAI,IAAI,CAG/C"}
@@ -0,0 +1,46 @@
1
+ /**
2
+ * React Instance Check Utility
3
+ *
4
+ * This utility helps prevent React version conflicts by ensuring
5
+ * the SDK uses the same React instance as the host application.
6
+ */
7
+ let reactInstanceCheckPerformed = false;
8
+ export function checkReactInstance() {
9
+ if (reactInstanceCheckPerformed) {
10
+ return;
11
+ }
12
+ try {
13
+ // Check if React is available globally
14
+ const globalReact = window.React;
15
+ const globalReactDOM = window.ReactDOM;
16
+ if (globalReact && globalReactDOM) {
17
+ console.log('[NxtlinqAIAgent] Using global React instance from host application');
18
+ return;
19
+ }
20
+ // Check if we're in a module environment
21
+ if (typeof require !== 'undefined') {
22
+ try {
23
+ const react = require('react');
24
+ const reactDOM = require('react-dom');
25
+ if (react && reactDOM) {
26
+ console.log('[NxtlinqAIAgent] Using React instance from module system');
27
+ return;
28
+ }
29
+ }
30
+ catch (e) {
31
+ // Module system not available or React not found
32
+ }
33
+ }
34
+ console.warn('[NxtlinqAIAgent] React instance check completed - using bundled React');
35
+ }
36
+ catch (error) {
37
+ console.error('[NxtlinqAIAgent] React instance check failed:', error);
38
+ }
39
+ finally {
40
+ reactInstanceCheckPerformed = true;
41
+ }
42
+ }
43
+ export function ensureReactCompatibility() {
44
+ // This function can be extended to perform more compatibility checks
45
+ checkReactInstance();
46
+ }
@@ -0,0 +1,2 @@
1
+ import '@testing-library/jest-dom';
2
+ //# sourceMappingURL=setupTests.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"setupTests.d.ts","sourceRoot":"","sources":["../src/setupTests.ts"],"names":[],"mappings":"AACA,OAAO,2BAA2B,CAAC"}
@@ -0,0 +1,16 @@
1
+ // Test setup file for Jest
2
+ import '@testing-library/jest-dom';
3
+ // Mock window.open for URL tests
4
+ Object.defineProperty(window, 'open', {
5
+ writable: true,
6
+ value: jest.fn(),
7
+ });
8
+ // Mock console methods to avoid noise in tests
9
+ global.console = {
10
+ ...console,
11
+ log: jest.fn(),
12
+ debug: jest.fn(),
13
+ info: jest.fn(),
14
+ warn: jest.fn(),
15
+ error: jest.fn(),
16
+ };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@bytexbyte/nxtlinq-ai-agent-sdk",
3
- "version": "1.6.9",
3
+ "version": "1.6.10",
4
4
  "description": "Nxtlinq AI Agent SDK - Proprietary Software with enhanced async operation handling",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
@@ -59,4 +59,4 @@
59
59
  "universal-cookie": "^8.0.1",
60
60
  "uuid": "^11.1.0"
61
61
  }
62
- }
62
+ }