nativescript-vue-navigator
nativescript-vue-navigator copied to clipboard
Android frameStack empty on some devices
Hi,
I've come across and issue where the frameStack
is empty on some Android devices. I'm not sure if this an issue for nativescript-vue-navigator
or nativescript-vue
or neither and something else is in my code is causing this issue. But I'll explain anyway and hopefully it'll help others at least.
Starting here https://github.com/nativescript-vue/nativescript-vue-navigator/blob/5f80c730eb81f59e0597e2bce53279abcf859610/index.js#L73-L74
When this.$navigate
is called we go into its definition at https://github.com/nativescript-vue/nativescript-vue/blob/c0e6f959096e81dd544cee01f8be4cebfd89eb87/platform/nativescript/plugins/navigator-plugin.js#L69.
On line 77 (https://github.com/nativescript-vue/nativescript-vue/blob/c0e6f959096e81dd544cee01f8be4cebfd89eb87/platform/nativescript/plugins/navigator-plugin.js#L77), we call getFrameInstance
. Then go to its definition at https://github.com/nativescript-vue/nativescript-vue/blob/c0e6f959096e81dd544cee01f8be4cebfd89eb87/platform/nativescript/plugins/navigator-plugin.js#L37.
On line 32 (https://github.com/nativescript-vue/nativescript-vue/blob/c0e6f959096e81dd544cee01f8be4cebfd89eb87/platform/nativescript/plugins/navigator-plugin.js#L32), when the result of require('@nativescript/core').Frame.getFrameById(frame)
is undefined
, causing undefined
to be assigned to the frame
variable.
The later call involving frame.id
(https://github.com/nativescript-vue/nativescript-vue/blob/c0e6f959096e81dd544cee01f8be4cebfd89eb87/platform/nativescript/plugins/navigator-plugin.js#L37) throws an error Cannot read property 'id' of undefined
and causes the navigation to never work.
Work around:
/// navigation.mixin.js
import { isAndroid } from '@nativescript/core';
import Vue, { navigateTo, NavigationEntryVue } from 'nativescript-vue';
import Component from 'vue-class-component';
@Component
export default class NavigationMixin extends Vue {
public $navigator_navigate_override(
route: string,
options: NavigationEntryVue
): navigateTo {
if (isAndroid) {
// HACK: Android is broken on some devices
options = {
...options,
frame: {
nativeView: {
id: options.frame || 'navigator'
}
}
};
}
return this.$navigator.navigate(route, {
...options
});
}
}
Which will get around frame.id
being undefined when the navigator
frame should always be defined when using the nativescript-vue-navigator
plugin.
Possibly associated to:
- https://github.com/nativescript-vue/nativescript-vue-navigator/issues/55
- https://github.com/nativescript-vue/nativescript-vue/issues/591