@limrun/ui 0.7.0 → 0.9.0-rc.1

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.
Files changed (72) hide show
  1. package/README.md +9 -0
  2. package/dist/components/device-install/device-install-dialog.d.ts +5 -0
  3. package/dist/components/device-install/index.d.ts +2 -0
  4. package/dist/components/remote-control.d.ts +2 -0
  5. package/dist/core/device-install/apple/client.d.ts +16 -0
  6. package/dist/core/device-install/apple/crypto.d.ts +20 -0
  7. package/dist/core/device-install/apple/gsa-srp.d.ts +26 -0
  8. package/dist/core/device-install/apple/index.d.ts +5 -0
  9. package/dist/core/device-install/apple/provisioning.d.ts +150 -0
  10. package/dist/core/device-install/apple/relay.d.ts +33 -0
  11. package/dist/core/device-install/index.d.ts +4 -0
  12. package/dist/core/device-install/operations/index.d.ts +6 -0
  13. package/dist/core/device-install/operations/limbuild-client.d.ts +28 -0
  14. package/dist/core/device-install/operations/operations.d.ts +32 -0
  15. package/dist/core/device-install/operations/relay-client.d.ts +25 -0
  16. package/dist/core/device-install/operations/relay-protocol.d.ts +27 -0
  17. package/dist/core/device-install/operations/usbmux.d.ts +32 -0
  18. package/dist/core/device-install/operations/webusb.d.ts +21 -0
  19. package/dist/core/device-install/storage/browser-storage.d.ts +25 -0
  20. package/dist/core/device-install/storage/index.d.ts +1 -0
  21. package/dist/core/device-install/types.d.ts +48 -0
  22. package/dist/demo.d.ts +1 -0
  23. package/dist/device-install/index.cjs +9 -0
  24. package/dist/device-install/index.d.ts +3 -0
  25. package/dist/device-install/index.js +212 -0
  26. package/dist/device-install/react.cjs +1 -0
  27. package/dist/device-install/react.d.ts +1 -0
  28. package/dist/device-install/react.js +4 -0
  29. package/dist/device-install-dialog-CTwVViYY.js +2 -0
  30. package/dist/device-install-dialog-zzKJu7SM.mjs +328 -0
  31. package/dist/device-install-dialog.css +1 -0
  32. package/dist/hooks/index.d.ts +1 -0
  33. package/dist/hooks/use-device-install.d.ts +55 -0
  34. package/dist/index.cjs +1 -1
  35. package/dist/index.d.ts +2 -0
  36. package/dist/index.js +526 -510
  37. package/dist/use-device-install-CgrOKKyi.mjs +13042 -0
  38. package/dist/use-device-install-DDKRf6IL.js +23 -0
  39. package/index.html +199 -0
  40. package/package.json +54 -41
  41. package/src/components/device-install/device-install-dialog.css +244 -0
  42. package/src/components/device-install/device-install-dialog.tsx +363 -0
  43. package/src/components/device-install/index.ts +2 -0
  44. package/src/components/remote-control.css +1 -1
  45. package/src/components/remote-control.tsx +222 -110
  46. package/src/core/device-install/apple/client.ts +64 -0
  47. package/src/core/device-install/apple/crypto.ts +202 -0
  48. package/src/core/device-install/apple/gsa-srp.ts +127 -0
  49. package/src/core/device-install/apple/index.ts +5 -0
  50. package/src/core/device-install/apple/provisioning.ts +255 -0
  51. package/src/core/device-install/apple/relay.ts +305 -0
  52. package/src/core/device-install/index.ts +4 -0
  53. package/src/core/device-install/operations/index.ts +6 -0
  54. package/src/core/device-install/operations/limbuild-client.ts +104 -0
  55. package/src/core/device-install/operations/operations.ts +217 -0
  56. package/src/core/device-install/operations/relay-client.ts +255 -0
  57. package/src/core/device-install/operations/relay-protocol.ts +71 -0
  58. package/src/core/device-install/operations/usbmux.ts +270 -0
  59. package/src/core/device-install/operations/webusb-dom.d.ts +54 -0
  60. package/src/core/device-install/operations/webusb.ts +105 -0
  61. package/src/core/device-install/storage/browser-storage.ts +238 -0
  62. package/src/core/device-install/storage/index.ts +1 -0
  63. package/src/core/device-install/types.ts +65 -0
  64. package/src/demo.tsx +185 -0
  65. package/src/device-install/index.ts +3 -0
  66. package/src/device-install/react.ts +1 -0
  67. package/src/hooks/index.ts +1 -0
  68. package/src/hooks/use-device-install.ts +522 -0
  69. package/src/index.ts +2 -0
  70. package/tsconfig.json +25 -25
  71. package/tsconfig.node.json +25 -25
  72. package/vite.config.ts +6 -2
package/index.html ADDED
@@ -0,0 +1,199 @@
1
+ <!doctype html>
2
+ <html lang="en">
3
+ <head>
4
+ <meta charset="UTF-8" />
5
+ <meta name="viewport" content="width=device-width, initial-scale=1.0" />
6
+ <title>RemoteControl Demo - @limrun/ui</title>
7
+ <style>
8
+ * {
9
+ margin: 0;
10
+ padding: 0;
11
+ box-sizing: border-box;
12
+ }
13
+
14
+ body {
15
+ font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
16
+ background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
17
+ min-height: 100vh;
18
+ padding: 20px;
19
+ }
20
+
21
+ #root {
22
+ display: flex;
23
+ flex-direction: column;
24
+ gap: 20px;
25
+ max-width: 1400px;
26
+ margin: 0 auto;
27
+ }
28
+
29
+ .header {
30
+ text-align: center;
31
+ color: white;
32
+ padding: 20px;
33
+ }
34
+
35
+ .header h1 {
36
+ font-size: 2.5rem;
37
+ margin-bottom: 10px;
38
+ text-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
39
+ }
40
+
41
+ .header p {
42
+ font-size: 1.1rem;
43
+ opacity: 0.9;
44
+ }
45
+
46
+ .demo-container {
47
+ background: white;
48
+ border-radius: 20px;
49
+ padding: 30px;
50
+ box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
51
+ }
52
+
53
+ .controls {
54
+ display: flex;
55
+ flex-direction: column;
56
+ gap: 15px;
57
+ margin-bottom: 30px;
58
+ }
59
+
60
+ .control-group {
61
+ display: flex;
62
+ flex-direction: column;
63
+ gap: 8px;
64
+ }
65
+
66
+ .control-group label {
67
+ font-weight: 600;
68
+ font-size: 0.9rem;
69
+ color: #374151;
70
+ }
71
+
72
+ .control-group input,
73
+ .control-group select {
74
+ padding: 10px 15px;
75
+ border: 2px solid #e5e7eb;
76
+ border-radius: 8px;
77
+ font-size: 0.95rem;
78
+ transition: border-color 0.2s;
79
+ }
80
+
81
+ .control-group input:focus,
82
+ .control-group select:focus {
83
+ outline: none;
84
+ border-color: #667eea;
85
+ }
86
+
87
+ .button-group {
88
+ display: flex;
89
+ gap: 10px;
90
+ }
91
+
92
+ button {
93
+ padding: 12px 24px;
94
+ border: none;
95
+ border-radius: 8px;
96
+ font-size: 1rem;
97
+ font-weight: 600;
98
+ cursor: pointer;
99
+ transition: all 0.2s;
100
+ }
101
+
102
+ button.primary {
103
+ background: #667eea;
104
+ color: white;
105
+ }
106
+
107
+ button.primary:hover {
108
+ background: #5568d3;
109
+ transform: translateY(-1px);
110
+ box-shadow: 0 4px 12px rgba(102, 126, 234, 0.4);
111
+ }
112
+
113
+ button.secondary {
114
+ background: #e5e7eb;
115
+ color: #374151;
116
+ }
117
+
118
+ button.secondary:hover {
119
+ background: #d1d5db;
120
+ }
121
+
122
+ button:disabled {
123
+ opacity: 0.5;
124
+ cursor: not-allowed;
125
+ }
126
+
127
+ .device-preview {
128
+ display: flex;
129
+ gap: 30px;
130
+ justify-content: center;
131
+ flex-wrap: wrap;
132
+ }
133
+
134
+ .preview-item {
135
+ flex: 1 1 420px;
136
+ max-width: 520px;
137
+ height: min(75vh, 900px);
138
+ }
139
+
140
+ .preview-item h3 {
141
+ text-align: center;
142
+ margin-bottom: 15px;
143
+ font-size: 1.2rem;
144
+ color: #374151;
145
+ }
146
+
147
+ .device-wrapper {
148
+ height: 100%;
149
+ width: 100%;
150
+ background: #f9fafb;
151
+ border-radius: 12px;
152
+ overflow: hidden;
153
+ }
154
+
155
+ @media (max-width: 640px) {
156
+ body {
157
+ padding: 12px;
158
+ }
159
+
160
+ .demo-container {
161
+ padding: 16px;
162
+ }
163
+
164
+ .button-group {
165
+ flex-direction: column;
166
+ }
167
+
168
+ .preview-item {
169
+ max-width: 100%;
170
+ height: 70vh;
171
+ }
172
+ }
173
+
174
+ .info-box {
175
+ background: #fef3c7;
176
+ border: 2px solid #fbbf24;
177
+ border-radius: 8px;
178
+ padding: 15px;
179
+ margin-bottom: 20px;
180
+ }
181
+
182
+ .info-box h4 {
183
+ color: #92400e;
184
+ margin-bottom: 8px;
185
+ font-size: 0.95rem;
186
+ }
187
+
188
+ .info-box p {
189
+ color: #78350f;
190
+ font-size: 0.9rem;
191
+ line-height: 1.5;
192
+ }
193
+ </style>
194
+ </head>
195
+ <body>
196
+ <div id="root"></div>
197
+ <script type="module" src="/src/demo.tsx"></script>
198
+ </body>
199
+ </html>
package/package.json CHANGED
@@ -1,45 +1,58 @@
1
1
  {
2
- "name": "@limrun/ui",
3
- "version": "0.7.0",
4
- "publishConfig": {
5
- "access": "public"
2
+ "name": "@limrun/ui",
3
+ "version": "0.9.0-rc.1",
4
+ "publishConfig": {
5
+ "access": "public"
6
+ },
7
+ "main": "./dist/index.js",
8
+ "module": "./dist/index.js",
9
+ "types": "./dist/index.d.ts",
10
+ "exports": {
11
+ ".": {
12
+ "types": "./dist/index.d.ts",
13
+ "import": "./dist/index.js",
14
+ "require": "./dist/index.cjs"
6
15
  },
7
- "main": "./dist/index.js",
8
- "module": "./dist/index.js",
9
- "types": "./dist/index.d.ts",
10
- "exports": {
11
- ".": {
12
- "types": "./dist/index.d.ts",
13
- "import": "./dist/index.js",
14
- "require": "./dist/index.cjs"
15
- },
16
- "./package.json": "./package.json"
16
+ "./device-install": {
17
+ "types": "./dist/device-install/index.d.ts",
18
+ "import": "./dist/device-install/index.js",
19
+ "require": "./dist/device-install/index.cjs"
17
20
  },
18
- "scripts": {
19
- "dev": "vite",
20
- "build": "tsc && vite build",
21
- "prepublishOnly": "npm run build",
22
- "lint": "eslint .",
23
- "preview": "vite preview"
21
+ "./device-install/react": {
22
+ "types": "./dist/device-install/react.d.ts",
23
+ "import": "./dist/device-install/react.js",
24
+ "require": "./dist/device-install/react.cjs"
24
25
  },
25
- "repository": {
26
- "type": "git",
27
- "url": "git+https://github.com/limrun-inc/typescript-sdk.git",
28
- "directory": "packages/ui"
29
- },
30
- "license": "MIT",
31
- "devDependencies": {
32
- "@types/react": "^19.1.12",
33
- "@types/react-dom": "^19.1.9",
34
- "@vitejs/plugin-react-swc": "^4.0.1",
35
- "path": "^0.12.7",
36
- "react": "^19.1.1",
37
- "react-dom": "^19.1.1",
38
- "vite": "^7.1.4",
39
- "vite-plugin-dts": "^4.5.4",
40
- "vite-plugin-lib-inject-css": "^2.2.2"
41
- },
42
- "dependencies": {
43
- "clsx": "^2.1.1"
44
- }
45
- }
26
+ "./package.json": "./package.json"
27
+ },
28
+ "scripts": {
29
+ "dev": "vite",
30
+ "build": "tsc && vite build",
31
+ "prepublishOnly": "npm run build",
32
+ "lint": "eslint .",
33
+ "preview": "vite preview"
34
+ },
35
+ "repository": {
36
+ "type": "git",
37
+ "url": "git+https://github.com/limrun-inc/typescript-sdk.git",
38
+ "directory": "packages/ui"
39
+ },
40
+ "license": "MIT",
41
+ "devDependencies": {
42
+ "@types/node-forge": "^1.3.14",
43
+ "@types/react": "^19.1.12",
44
+ "@types/react-dom": "^19.1.9",
45
+ "@vitejs/plugin-react-swc": "^4.0.1",
46
+ "path": "^0.12.7",
47
+ "react": "^19.1.1",
48
+ "react-dom": "^19.1.1",
49
+ "vite": "^7.1.4",
50
+ "vite-plugin-dts": "^4.5.4",
51
+ "vite-plugin-lib-inject-css": "^2.2.2"
52
+ },
53
+ "dependencies": {
54
+ "@foxt/js-srp": "^0.0.3-patch2",
55
+ "clsx": "^2.1.1",
56
+ "node-forge": "^1.4.0"
57
+ }
58
+ }
@@ -0,0 +1,244 @@
1
+ .lr-device-install {
2
+ font-family:
3
+ Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
4
+ }
5
+
6
+ .lr-device-install__trigger,
7
+ .lr-device-install__primary,
8
+ .lr-device-install__secondary,
9
+ .lr-device-install__icon-button {
10
+ border: 1px solid #d1d5db;
11
+ border-radius: 8px;
12
+ cursor: pointer;
13
+ font: inherit;
14
+ }
15
+
16
+ .lr-device-install__trigger,
17
+ .lr-device-install__primary {
18
+ background: #111827;
19
+ color: #ffffff;
20
+ padding: 8px 12px;
21
+ }
22
+
23
+ .lr-device-install__secondary,
24
+ .lr-device-install__icon-button {
25
+ background: #ffffff;
26
+ color: #111827;
27
+ padding: 8px 12px;
28
+ }
29
+
30
+ .lr-device-install__trigger:disabled,
31
+ .lr-device-install__primary:disabled,
32
+ .lr-device-install__secondary:disabled {
33
+ cursor: not-allowed;
34
+ opacity: 0.55;
35
+ }
36
+
37
+ .lr-device-install__backdrop {
38
+ align-items: center;
39
+ background: rgb(17 24 39 / 0.55);
40
+ display: flex;
41
+ inset: 0;
42
+ justify-content: center;
43
+ padding: 24px;
44
+ position: fixed;
45
+ z-index: 50;
46
+ }
47
+
48
+ .lr-device-install__dialog {
49
+ background: #ffffff;
50
+ border-radius: 16px;
51
+ box-shadow: 0 24px 80px rgb(15 23 42 / 0.28);
52
+ color: #111827;
53
+ max-height: min(90vh, 900px);
54
+ max-width: 880px;
55
+ overflow: auto;
56
+ padding: 24px;
57
+ width: 100%;
58
+ }
59
+
60
+ .lr-device-install__header {
61
+ align-items: flex-start;
62
+ display: flex;
63
+ gap: 16px;
64
+ justify-content: space-between;
65
+ margin-bottom: 18px;
66
+ }
67
+
68
+ .lr-device-install__header h2,
69
+ .lr-device-install__step h3,
70
+ .lr-device-install__logs h3 {
71
+ margin: 0;
72
+ }
73
+
74
+ .lr-device-install__header p,
75
+ .lr-device-install__step p,
76
+ .lr-device-install__logs {
77
+ color: #4b5563;
78
+ }
79
+
80
+ .lr-device-install__error {
81
+ background: #fef2f2;
82
+ border: 1px solid #fecaca;
83
+ border-radius: 10px;
84
+ color: #991b1b;
85
+ margin-bottom: 14px;
86
+ padding: 10px 12px;
87
+ }
88
+
89
+ .lr-device-install__steps {
90
+ display: grid;
91
+ gap: 12px;
92
+ }
93
+
94
+ .lr-device-install__step {
95
+ border: 1px solid #e5e7eb;
96
+ border-radius: 12px;
97
+ padding: 14px;
98
+ }
99
+
100
+ .lr-device-install__step--active {
101
+ border-color: #111827;
102
+ }
103
+
104
+ .lr-device-install__step-header {
105
+ align-items: flex-start;
106
+ display: grid;
107
+ gap: 12px;
108
+ grid-template-columns: auto 1fr auto;
109
+ }
110
+
111
+ .lr-device-install__step-number {
112
+ align-items: center;
113
+ background: #111827;
114
+ border-radius: 999px;
115
+ color: #ffffff;
116
+ display: flex;
117
+ font-size: 13px;
118
+ font-weight: 700;
119
+ height: 28px;
120
+ justify-content: center;
121
+ width: 28px;
122
+ }
123
+
124
+ .lr-device-install__status {
125
+ border-radius: 999px;
126
+ font-size: 12px;
127
+ padding: 3px 8px;
128
+ text-transform: capitalize;
129
+ }
130
+
131
+ .lr-device-install__status--idle {
132
+ background: #f3f4f6;
133
+ color: #4b5563;
134
+ }
135
+
136
+ .lr-device-install__status--active {
137
+ background: #dbeafe;
138
+ color: #1d4ed8;
139
+ }
140
+
141
+ .lr-device-install__status--complete {
142
+ background: #dcfce7;
143
+ color: #166534;
144
+ }
145
+
146
+ .lr-device-install__status--error {
147
+ background: #fee2e2;
148
+ color: #991b1b;
149
+ }
150
+
151
+ .lr-device-install__step-body {
152
+ display: grid;
153
+ gap: 12px;
154
+ margin-top: 12px;
155
+ }
156
+
157
+ .lr-device-install__grid {
158
+ display: grid;
159
+ gap: 10px;
160
+ grid-template-columns: repeat(3, minmax(0, 1fr));
161
+ }
162
+
163
+ .lr-device-install__field {
164
+ display: grid;
165
+ gap: 6px;
166
+ }
167
+
168
+ .lr-device-install__field span {
169
+ color: #374151;
170
+ font-size: 13px;
171
+ font-weight: 600;
172
+ }
173
+
174
+ .lr-device-install__field input {
175
+ border: 1px solid #d1d5db;
176
+ border-radius: 8px;
177
+ font: inherit;
178
+ padding: 8px 10px;
179
+ }
180
+
181
+ .lr-device-install__build-logs {
182
+ border: 1px solid #e5e7eb;
183
+ border-radius: 10px;
184
+ overflow: hidden;
185
+ }
186
+
187
+ .lr-device-install__build-logs summary {
188
+ cursor: pointer;
189
+ font-weight: 600;
190
+ padding: 10px 12px;
191
+ }
192
+
193
+ .lr-device-install__build-logs pre {
194
+ background: #0f172a;
195
+ color: #e5e7eb;
196
+ margin: 0;
197
+ max-height: 240px;
198
+ overflow: auto;
199
+ padding: 12px;
200
+ white-space: pre-wrap;
201
+ }
202
+
203
+ .lr-device-install__device {
204
+ background: #f9fafb;
205
+ border: 1px solid #e5e7eb;
206
+ border-radius: 10px;
207
+ padding: 10px;
208
+ }
209
+
210
+ .lr-device-install__logs {
211
+ border-top: 1px solid #e5e7eb;
212
+ margin-top: 18px;
213
+ padding-top: 14px;
214
+ }
215
+
216
+ .lr-device-install__logs ol {
217
+ display: grid;
218
+ gap: 6px;
219
+ list-style: none;
220
+ margin: 8px 0 0;
221
+ max-height: 160px;
222
+ overflow: auto;
223
+ padding: 0;
224
+ }
225
+
226
+ .lr-device-install__logs li {
227
+ font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', monospace;
228
+ font-size: 12px;
229
+ white-space: pre-wrap;
230
+ }
231
+
232
+ @media (max-width: 760px) {
233
+ .lr-device-install__grid {
234
+ grid-template-columns: 1fr;
235
+ }
236
+
237
+ .lr-device-install__step-header {
238
+ grid-template-columns: auto 1fr;
239
+ }
240
+
241
+ .lr-device-install__status {
242
+ grid-column: 2;
243
+ }
244
+ }