Skip to content
This repository was archived by the owner on Dec 12, 2022. It is now read-only.

feat(kinvey preview app): show correct store urls when deprecated page is shown on device #30

Merged
merged 2 commits into from
Apr 2, 2019
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "nativescript-preview-sdk",
"version": "0.3.3",
"version": "0.3.4",
"description": "Handles the communication to the NativeScript Preview Apps",
"main": "src/nativescript-preview-sdk",
"typings": "src/nativescript-preview-sdk.d.ts",
Expand Down
4 changes: 1 addition & 3 deletions src/constants.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,5 @@
export class Constants {
public static PreviewAppStoreId = "1264484702";
public static PreviewGooglePlayId = "org.nativescript.preview";
public static PlaygroundAppStoreLink = "https://itunes.apple.com/us/app/nativescript-playground/id1263543946?mt=8&ls=1";
public static PlaygroundGooglePlayLink = "https://play.google.com/store/apps/details?id=org.nativescript.play";
public static InitialSyncMessageType = "initial sync chunk";
}
}
3 changes: 2 additions & 1 deletion src/models/config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,9 +14,10 @@ export class Config {
* Can be staging, uat or live
*/
msvEnv: string;
showLoadingPage?: boolean;
callbacks: SdkCallbacks;
getInitialFiles: (device?: Device) => Promise<FilesPayload>;
instanceId?: string;
connectedDevices?: ConnectedDevices;
previewAppStoreId?: string;
previewAppGooglePlayId?: string;
}
89 changes: 8 additions & 81 deletions src/services/app-content-manager.ts
Original file line number Diff line number Diff line change
@@ -1,23 +1,9 @@
import { Constants } from "../constants";
import { FilePayload } from "../models/file-payload";
import { Config } from "../models/config";

export class AppContentManager {
public getLoadingAppPayloads(): FilePayload[] {
return [
{
event: "change",
file: "package.json",
fileContents: `{"main":"_loading-page.js"}`
},
{
event: "change",
file: "_loading-page.js",
fileContents: this.getLoadingPageContent()
}
]
}

public getDeprecatedAppPayloads(): FilePayload[] {
public getDeprecatedAppPayloads(previewAppStoreId: string, previewAppGooglePlayId: string): FilePayload[] {
return [
{
event: "change",
Expand All @@ -27,12 +13,12 @@ export class AppContentManager {
{
event: "change",
file: "_deprecated-error.js",
fileContents: this.getDeprecatedPageContent()
fileContents: this.getDeprecatedPageContent(previewAppStoreId, previewAppGooglePlayId)
}
];
}

private getDeprecatedPageContent(): string {
private getDeprecatedPageContent(previewAppStoreId: string, previewAppGooglePlayId: string): string {
return `var application = require("tns-core-modules/application"),
Page = require("tns-core-modules/ui/page").Page,
ActionBar = require("tns-core-modules/ui/action-bar").ActionBar,
Expand Down Expand Up @@ -75,16 +61,16 @@ export class AppContentManager {
var context = utils.ad.getApplicationContext();
var Intent = android.content.Intent;
var intent = new Intent(Intent.ACTION_VIEW);
intent.setData(android.net.Uri.parse("https://play.google.com/store/apps/details?id=${Constants.PreviewGooglePlayId}"));
intent.setData(android.net.Uri.parse("https://play.google.com/store/apps/details?id=${previewAppGooglePlayId || Constants.PreviewGooglePlayId}"));
intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
context.startActivity(intent);
} else if (application.ios) {
var sharedApplication = utils.ios.getter(UIApplication, UIApplication.sharedApplication);
var storeUrl = NSURL.URLWithString("itms-apps://itunes.apple.com/app/id${Constants.PreviewAppStoreId}");
var storeUrl = NSURL.URLWithString("itms-apps://itunes.apple.com/app/id${previewAppStoreId || Constants.PreviewAppStoreId}");
if (sharedApplication.canOpenURL(storeUrl)) {
sharedApplication.openURL(storeUrl);
} else {
storeUrl = NSURL.URLWithString("https://itunes.apple.com/app/id${Constants.PreviewAppStoreId}");
storeUrl = NSURL.URLWithString("https://itunes.apple.com/app/id${previewAppStoreId || Constants.PreviewAppStoreId}");
sharedApplication.openURL(storeUrl);
}
}
Expand All @@ -98,63 +84,4 @@ export class AppContentManager {
}
});`;
}

private getLoadingPageContent(): string {
return `var application = require("tns-core-modules/application"),
Page = require("tns-core-modules/ui/page").Page,
ActionBar = require("tns-core-modules/ui/action-bar").ActionBar,
ActivityIndicator = require("tns-core-modules/ui/activity-indicator").ActivityIndicator,
Label = require("tns-core-modules/ui/label").Label,
Image = require("tns-core-modules/ui/image").Image,
Button = require("tns-core-modules/ui/button").Button,
StackLayout = require("tns-core-modules/ui/layouts/stack-layout").StackLayout,
FlexboxLayout = require("tns-core-modules/ui/layouts/flexbox-layout").FlexboxLayout,
utils = require("tns-core-modules/utils/utils");

application.start({
create: () => {
let page = new Page();
page.css = ".main-container { background-color: #0c2834; flex-direction: column; color: #fff; align-items: center; justify-content: center; } .header { padding-top: 50%; font-size: 24; } .labelContainer { padding: 20% 50% 60% 50%; } .label { color: #a0b4bd; text-align: center; } .button { background-color: #4456fe; width: 70%; height: 120px; }";

let layout = new FlexboxLayout();
layout.cssClasses.add("main-container");

let actionBar = new ActionBar();
actionBar.title = "";
actionBar.color = "#fff";
actionBar.backgroundColor = "#0c2834";
page.actionBar = actionBar;

let image = new Image();
image.src = "";
image.width = "20%";

let header = new Label();
header.textWrap = true;
header.text = "Loading your project";
header.cssClasses.add("header");

let labelContainer = new StackLayout();
labelContainer.cssClasses.add("labelContainer");
let label = new Label();
label.textWrap = true;
label.text = "This may take a while...";
label.cssClasses.add("label");
// Uncomment this line for v2 of loading page.
// labelContainer.addChild(label);

let activityIndicator = new ActivityIndicator();
activityIndicator.busy = true;

layout.addChild(image);
layout.addChild(header);
layout.addChild(labelContainer);
layout.addChild(activityIndicator);

page.content = layout;

return page;
}
});`;
}
}
}
7 changes: 1 addition & 6 deletions src/services/messaging-service.ts
Original file line number Diff line number Diff line change
Expand Up @@ -390,19 +390,14 @@ export class MessagingService {
const minimumSupportedVersion = isAndroid ? this.minSupportedVersions.android : this.minSupportedVersions.ios;
const showDeprecatedPage = !deviceConnectedMessage.version || !deviceConnectedMessage.platform || deviceConnectedMessage.version < minimumSupportedVersion;
if (showDeprecatedPage) {
const payloads = this.appContentManager.getDeprecatedAppPayloads();
const payloads = this.appContentManager.getDeprecatedAppPayloads(this.config.previewAppStoreId, this.config.previewAppGooglePlayId);
await this.showPage(devicesChannel, device, payloads, { hmrMode, publisher: data.publisher });
return;
}

this.config.callbacks.onLogSdkMessage(`${instanceId} message received: send files`);
}

if (this.config.showLoadingPage) {
const payloads = this.appContentManager.getLoadingAppPayloads();
await this.showPage(devicesChannel, device, payloads, { hmrMode, publisher: data.publisher });
}

const initialPayload = await this.config.getInitialFiles(device);
if (initialPayload && initialPayload.files && initialPayload.files.length) {
if (!initialPayload.deviceId && device) {
Expand Down