Skip to content

Commit

Permalink
HUD Invite button: fixes by calling System Share API directly
Browse files Browse the repository at this point in the history
  • Loading branch information
DougReeder committed Oct 31, 2024
1 parent e5eb1a2 commit 036565e
Show file tree
Hide file tree
Showing 3 changed files with 28 additions and 6 deletions.
26 changes: 23 additions & 3 deletions src/components/in-world-hud.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,8 @@
import { SOUND_SPAWN_PEN } from "../systems/sound-effects-system";
import { shareInviteUrl } from "../utils/share";
import { hubUrl } from "../utils/phoenix-utils";
import configs from "../utils/configs";
import { handleExitTo2DInterstitial } from "../utils/vr-interstitial";
/**
* HUD panel for muting, freezing, and other controls that don't necessarily have hardware buttons.
* @namespace ui
Expand Down Expand Up @@ -54,12 +58,28 @@ AFRAME.registerComponent("in-world-hud", {
this.el.emit("action_toggle_camera");
};

this.onInviteClick = () => {
this.el.emit("action_invite");
this.onInviteClick = async event => {
try {
const extraParams =
APP.hub.entry_mode === "invite" ? { hub_invite_id: (await APP.hubChannel.fetchInvite()).hub_invite_id } : {};
const url = hubUrl(APP.hub.hub_id, extraParams).href;
const didShare = await shareInviteUrl(
null,
url,
{ roomName: APP.hub.name, appName: configs.translation("app-name") },
true,
event
);
if (didShare) {
await handleExitTo2DInterstitial(false, () => {}, true);
}
} catch (error) {
console.error(`while inviting (using HUD):`, error);
}
};

this.onHubUpdated = e => {
this.inviteBtn.object3D.visible = e.detail.hub.entry_mode !== "invite";
this.inviteBtn.object3D.visible = e.detail.hub.entry_mode !== "invite" || APP.hubChannel.can("update_hub");
};
},

Expand Down
2 changes: 1 addition & 1 deletion src/react-components/room/InvitePopoverContainer.js
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ export function InvitePopoverContainer({ hub, hubChannel, scene, store, ...rest

const popoverApiRef = useRef();

// Handle clicking on the invite button while in VR.
// Handle clicking on the invite button in "More" menu.
useEffect(() => {
function onInviteButtonClicked() {
handleExitTo2DInterstitial(true, () => {}).then(() => {
Expand Down
6 changes: 4 additions & 2 deletions src/utils/share.js
Original file line number Diff line number Diff line change
Expand Up @@ -28,8 +28,8 @@ export function share(opts) {

export async function shareInviteUrl(intl, url, values = {}, inEnglish = false, event) {
try {
event.preventDefault();
event.stopPropagation();
event?.preventDefault?.();
event?.stopPropagation?.();
if (inEnglish) {
const cache = createIntlCache(); // prevents memory leak
intl = createIntl({ locale: "en", messages: {} }, cache);
Expand All @@ -55,7 +55,9 @@ export async function shareInviteUrl(intl, url, values = {}, inEnglish = false,
const data = { title, text, url };
console.info(`attempting to share:`, data);
await share(data);
return true;
} catch (error) {
console.error("unable to share:", error);
return false;
}
}

0 comments on commit 036565e

Please sign in to comment.