mediasfu-shared 1.0.5 → 1.0.6
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/dist/index.cjs +38 -2
- package/dist/index.cjs.map +1 -1
- package/dist/index.js +38 -2
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
- package/src/consumers/createSendTransport.ts +51 -2
package/dist/index.cjs
CHANGED
|
@@ -1721,6 +1721,21 @@ const connectSendTransportVideo = async ({
|
|
|
1721
1721
|
throw error;
|
|
1722
1722
|
}
|
|
1723
1723
|
};
|
|
1724
|
+
const waitForReadyDevice = async (parameters, attempts = 20, delayMs = 100) => {
|
|
1725
|
+
let resolvedDevice = parameters.getUpdatedAllParams().device ?? parameters.device;
|
|
1726
|
+
for (let attempt = 0; !resolvedDevice && attempt < attempts; attempt += 1) {
|
|
1727
|
+
await new Promise((resolve) => setTimeout(resolve, delayMs));
|
|
1728
|
+
resolvedDevice = parameters.getUpdatedAllParams().device ?? parameters.device;
|
|
1729
|
+
}
|
|
1730
|
+
return resolvedDevice;
|
|
1731
|
+
};
|
|
1732
|
+
const notifyDeviceNotReady = (parameters) => {
|
|
1733
|
+
parameters.showAlert?.({
|
|
1734
|
+
message: "Media device is still initializing. Please try screen sharing again in a moment.",
|
|
1735
|
+
type: "danger",
|
|
1736
|
+
duration: 3e3
|
|
1737
|
+
});
|
|
1738
|
+
};
|
|
1724
1739
|
const createLocalSendTransport = async ({
|
|
1725
1740
|
option,
|
|
1726
1741
|
parameters
|
|
@@ -1738,6 +1753,10 @@ const createLocalSendTransport = async ({
|
|
|
1738
1753
|
updateLocalTransportCreated,
|
|
1739
1754
|
connectSendTransport: connectSendTransport2
|
|
1740
1755
|
} = parameters;
|
|
1756
|
+
const updatedParams = parameters.getUpdatedAllParams();
|
|
1757
|
+
device = updatedParams.device ?? device;
|
|
1758
|
+
socket = updatedParams.socket ?? socket;
|
|
1759
|
+
localSocket = updatedParams.localSocket ?? localSocket;
|
|
1741
1760
|
if (!localSocket || !localSocket.id || socket.id === localSocket.id) {
|
|
1742
1761
|
return;
|
|
1743
1762
|
}
|
|
@@ -1749,7 +1768,12 @@ const createLocalSendTransport = async ({
|
|
|
1749
1768
|
console.error("Error in local createWebRtcTransport:", params.error);
|
|
1750
1769
|
return;
|
|
1751
1770
|
}
|
|
1752
|
-
|
|
1771
|
+
const resolvedDevice = await waitForReadyDevice(parameters) ?? device;
|
|
1772
|
+
if (!resolvedDevice) {
|
|
1773
|
+
notifyDeviceNotReady(parameters);
|
|
1774
|
+
return;
|
|
1775
|
+
}
|
|
1776
|
+
localProducerTransport = await resolvedDevice.createSendTransport(params);
|
|
1753
1777
|
if (updateLocalProducerTransport) {
|
|
1754
1778
|
updateLocalProducerTransport(localProducerTransport);
|
|
1755
1779
|
}
|
|
@@ -1824,6 +1848,13 @@ const createSendTransport = async ({
|
|
|
1824
1848
|
const updatedParams = parameters.getUpdatedAllParams();
|
|
1825
1849
|
device = updatedParams.device;
|
|
1826
1850
|
socket = updatedParams.socket;
|
|
1851
|
+
if (!device) {
|
|
1852
|
+
device = await waitForReadyDevice(parameters);
|
|
1853
|
+
}
|
|
1854
|
+
if (!device) {
|
|
1855
|
+
notifyDeviceNotReady(parameters);
|
|
1856
|
+
return;
|
|
1857
|
+
}
|
|
1827
1858
|
try {
|
|
1828
1859
|
await createLocalSendTransport({ option, parameters });
|
|
1829
1860
|
} catch (error) {
|
|
@@ -1837,7 +1868,12 @@ const createSendTransport = async ({
|
|
|
1837
1868
|
console.error("Error in createWebRtcTransport:", params.error);
|
|
1838
1869
|
return;
|
|
1839
1870
|
}
|
|
1840
|
-
|
|
1871
|
+
const resolvedDevice = await waitForReadyDevice(parameters) ?? device;
|
|
1872
|
+
if (!resolvedDevice) {
|
|
1873
|
+
notifyDeviceNotReady(parameters);
|
|
1874
|
+
return;
|
|
1875
|
+
}
|
|
1876
|
+
producerTransport = await resolvedDevice.createSendTransport(params);
|
|
1841
1877
|
updateProducerTransport(producerTransport);
|
|
1842
1878
|
producerTransport.on(
|
|
1843
1879
|
"connect",
|