-
Notifications
You must be signed in to change notification settings - Fork 698
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Fullpage redirect in embedded apps using shopify_app/shared/redirect stopped working #1728
Comments
Okay looks like I've found the issue. Remote redirects back into the same embedded app are not working when they used to work before. Haven't checked if it works for fullpage_redirect_to so I'm not clear if the remote redirect is not working or not working for this use case. If I change this line: https://github.com/Shopify/shopify_app/blob/v21.4.0/app/assets/javascripts/shopify_app/app_bridge_redirect.js#L18 To: It works. So for now I will make a separate |
Putting down how I'm fixing it for my app. // shopify_internal_redirect.js
(function(window) {
function appBridgeInternalRedirect(path) {
var AppBridge = window['app-bridge'];
var createApp = AppBridge.default;
var Redirect = AppBridge.actions.Redirect;
var shopifyData = document.body.dataset;
var app = createApp({
apiKey: shopifyData.apiKey,
host: shopifyData.host,
});
Redirect.create(app).dispatch(Redirect.Action.APP, path);
}
window.appBridgeInternalRedirect = appBridgeInternalRedirect;
})(window);
(function () {
function redirect() {
var redirectTargetElement = document.getElementById("redirection-target");
if (!redirectTargetElement) {
return;
}
var targetInfo = JSON.parse(redirectTargetElement.dataset.target);
var appBridgeUtils = window['app-bridge'].utilities;
if (appBridgeUtils.isShopifyEmbedded()) {
window.appBridgeInternalRedirect(targetInfo.path);
} else {
window.top.location.href = targetInfo.path;
}
}
document.addEventListener("DOMContentLoaded", redirect);
// In the turbolinks context, neither DOMContentLoaded nor turbolinks:load
// consistently fires. This ensures that we at least attempt to fire in the
// turbolinks situation as well.
redirect();
})(); <!-- shopify_app/shared/internal_redirect.html.erb -->
<!DOCTYPE html>
<html lang="<%= I18n.locale %>">
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
<base target="_top">
<title>Redirecting…</title>
<script src="https://unpkg.com/@shopify/[email protected]"></script> <!-- Loading latest app-bridge -->
<%= javascript_pack_tag('shopify_internal_redirect', crossorigin: 'anonymous', integrity: true) %>
</head>
<body data-api-key="<%= ShopifyApp.configuration.api_key %>" data-shop-origin="<%= current_shopify_domain %>" data-host="<%= params[:host] %>" >
<%=
content_tag(:div, nil,
id: 'redirection-target',
data: {
target: {
myshopifyUrl: "https://#{current_shopify_domain}",
path: path,
},
},
)
%>
<h1>Redirecting...</h1>
</body>
</html> # embedded_controller.rb
def embedded_redirect_to(path)
if ShopifyApp.configuration.embedded_app?
raise ::ShopifyApp::ShopifyDomainNotFound if current_shopify_domain.blank?
raise ::ShopifyApp::ShopifyHostNotFound if params[:host].blank?
render(
"shopify_app/shared/internal_redirect",
layout: false,
locals: {
path: path,
current_shopify_domain: current_shopify_domain
}
)
else
redirect_to(path)
end
end |
Issue summary
I have been using the shopify_app/shared/redirect page to do page redirects in my app. The way that it was working was that if you land on the root page, if you haven't signed up for a plan you get redirected in a before_action to the plans page. However as of yesterday (as far as I can confirm) the shopify_app/shared/redirect template renders on the page but nothing happens. I can confirm there is no change from my side but appears to be a change from the Shopify side.
shopify_api
version: 12.5.0shopify_app
version: 21.4.0Expected behavior
The view renders but then quickly redirects to the relevant page.
Actual behavior
The view renders but redirection doesn't happen.
Steps to reproduce the problem
Hypothesis
Something has changed from Shopify or the App Bridge utils used to redirect. I have a temporary solution where I load my React page and then trigger a redirect using the below. So maybe the solution is to just change the redirection solution.
The text was updated successfully, but these errors were encountered: