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

Commit 53de5d2

Browse files
author
Fatme
authored
Merge pull request #30 from telerik/fatme/kinvey-schema
feat(kinvey preview app): show correct store urls when deprecated page is shown on device
2 parents 0b34cf0 + 0ec593e commit 53de5d2

File tree

6 files changed

+14
-93
lines changed

6 files changed

+14
-93
lines changed

package-lock.json

+1-1
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

package.json

+1-1
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
11
{
22
"name": "nativescript-preview-sdk",
3-
"version": "0.3.3",
3+
"version": "0.3.4",
44
"description": "Handles the communication to the NativeScript Preview Apps",
55
"main": "src/nativescript-preview-sdk",
66
"typings": "src/nativescript-preview-sdk.d.ts",

src/constants.ts

+1-3
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,5 @@
11
export class Constants {
22
public static PreviewAppStoreId = "1264484702";
33
public static PreviewGooglePlayId = "org.nativescript.preview";
4-
public static PlaygroundAppStoreLink = "https://itunes.apple.com/us/app/nativescript-playground/id1263543946?mt=8&ls=1";
5-
public static PlaygroundGooglePlayLink = "https://play.google.com/store/apps/details?id=org.nativescript.play";
64
public static InitialSyncMessageType = "initial sync chunk";
7-
}
5+
}

src/models/config.ts

+2-1
Original file line numberDiff line numberDiff line change
@@ -14,9 +14,10 @@ export class Config {
1414
* Can be staging, uat or live
1515
*/
1616
msvEnv: string;
17-
showLoadingPage?: boolean;
1817
callbacks: SdkCallbacks;
1918
getInitialFiles: (device?: Device) => Promise<FilesPayload>;
2019
instanceId?: string;
2120
connectedDevices?: ConnectedDevices;
21+
previewAppStoreId?: string;
22+
previewAppGooglePlayId?: string;
2223
}

src/services/app-content-manager.ts

+8-81
Original file line numberDiff line numberDiff line change
@@ -1,23 +1,9 @@
11
import { Constants } from "../constants";
22
import { FilePayload } from "../models/file-payload";
3+
import { Config } from "../models/config";
34

45
export class AppContentManager {
5-
public getLoadingAppPayloads(): FilePayload[] {
6-
return [
7-
{
8-
event: "change",
9-
file: "package.json",
10-
fileContents: `{"main":"_loading-page.js"}`
11-
},
12-
{
13-
event: "change",
14-
file: "_loading-page.js",
15-
fileContents: this.getLoadingPageContent()
16-
}
17-
]
18-
}
19-
20-
public getDeprecatedAppPayloads(): FilePayload[] {
6+
public getDeprecatedAppPayloads(previewAppStoreId: string, previewAppGooglePlayId: string): FilePayload[] {
217
return [
228
{
239
event: "change",
@@ -27,12 +13,12 @@ export class AppContentManager {
2713
{
2814
event: "change",
2915
file: "_deprecated-error.js",
30-
fileContents: this.getDeprecatedPageContent()
16+
fileContents: this.getDeprecatedPageContent(previewAppStoreId, previewAppGooglePlayId)
3117
}
3218
];
3319
}
3420

35-
private getDeprecatedPageContent(): string {
21+
private getDeprecatedPageContent(previewAppStoreId: string, previewAppGooglePlayId: string): string {
3622
return `var application = require("tns-core-modules/application"),
3723
Page = require("tns-core-modules/ui/page").Page,
3824
ActionBar = require("tns-core-modules/ui/action-bar").ActionBar,
@@ -75,16 +61,16 @@ export class AppContentManager {
7561
var context = utils.ad.getApplicationContext();
7662
var Intent = android.content.Intent;
7763
var intent = new Intent(Intent.ACTION_VIEW);
78-
intent.setData(android.net.Uri.parse("https://play.google.com/store/apps/details?id=${Constants.PreviewGooglePlayId}"));
64+
intent.setData(android.net.Uri.parse("https://play.google.com/store/apps/details?id=${previewAppGooglePlayId || Constants.PreviewGooglePlayId}"));
7965
intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
8066
context.startActivity(intent);
8167
} else if (application.ios) {
8268
var sharedApplication = utils.ios.getter(UIApplication, UIApplication.sharedApplication);
83-
var storeUrl = NSURL.URLWithString("itms-apps://itunes.apple.com/app/id${Constants.PreviewAppStoreId}");
69+
var storeUrl = NSURL.URLWithString("itms-apps://itunes.apple.com/app/id${previewAppStoreId || Constants.PreviewAppStoreId}");
8470
if (sharedApplication.canOpenURL(storeUrl)) {
8571
sharedApplication.openURL(storeUrl);
8672
} else {
87-
storeUrl = NSURL.URLWithString("https://itunes.apple.com/app/id${Constants.PreviewAppStoreId}");
73+
storeUrl = NSURL.URLWithString("https://itunes.apple.com/app/id${previewAppStoreId || Constants.PreviewAppStoreId}");
8874
sharedApplication.openURL(storeUrl);
8975
}
9076
}
@@ -98,63 +84,4 @@ export class AppContentManager {
9884
}
9985
});`;
10086
}
101-
102-
private getLoadingPageContent(): string {
103-
return `var application = require("tns-core-modules/application"),
104-
Page = require("tns-core-modules/ui/page").Page,
105-
ActionBar = require("tns-core-modules/ui/action-bar").ActionBar,
106-
ActivityIndicator = require("tns-core-modules/ui/activity-indicator").ActivityIndicator,
107-
Label = require("tns-core-modules/ui/label").Label,
108-
Image = require("tns-core-modules/ui/image").Image,
109-
Button = require("tns-core-modules/ui/button").Button,
110-
StackLayout = require("tns-core-modules/ui/layouts/stack-layout").StackLayout,
111-
FlexboxLayout = require("tns-core-modules/ui/layouts/flexbox-layout").FlexboxLayout,
112-
utils = require("tns-core-modules/utils/utils");
113-
114-
application.start({
115-
create: () => {
116-
let page = new Page();
117-
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; }";
118-
119-
let layout = new FlexboxLayout();
120-
layout.cssClasses.add("main-container");
121-
122-
let actionBar = new ActionBar();
123-
actionBar.title = "";
124-
actionBar.color = "#fff";
125-
actionBar.backgroundColor = "#0c2834";
126-
page.actionBar = actionBar;
127-
128-
let image = new Image();
129-
image.src = "";
130-
image.width = "20%";
131-
132-
let header = new Label();
133-
header.textWrap = true;
134-
header.text = "Loading your project";
135-
header.cssClasses.add("header");
136-
137-
let labelContainer = new StackLayout();
138-
labelContainer.cssClasses.add("labelContainer");
139-
let label = new Label();
140-
label.textWrap = true;
141-
label.text = "This may take a while...";
142-
label.cssClasses.add("label");
143-
// Uncomment this line for v2 of loading page.
144-
// labelContainer.addChild(label);
145-
146-
let activityIndicator = new ActivityIndicator();
147-
activityIndicator.busy = true;
148-
149-
layout.addChild(image);
150-
layout.addChild(header);
151-
layout.addChild(labelContainer);
152-
layout.addChild(activityIndicator);
153-
154-
page.content = layout;
155-
156-
return page;
157-
}
158-
});`;
159-
}
160-
}
87+
}

src/services/messaging-service.ts

+1-6
Original file line numberDiff line numberDiff line change
@@ -390,19 +390,14 @@ export class MessagingService {
390390
const minimumSupportedVersion = isAndroid ? this.minSupportedVersions.android : this.minSupportedVersions.ios;
391391
const showDeprecatedPage = !deviceConnectedMessage.version || !deviceConnectedMessage.platform || deviceConnectedMessage.version < minimumSupportedVersion;
392392
if (showDeprecatedPage) {
393-
const payloads = this.appContentManager.getDeprecatedAppPayloads();
393+
const payloads = this.appContentManager.getDeprecatedAppPayloads(this.config.previewAppStoreId, this.config.previewAppGooglePlayId);
394394
await this.showPage(devicesChannel, device, payloads, { hmrMode, publisher: data.publisher });
395395
return;
396396
}
397397

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

401-
if (this.config.showLoadingPage) {
402-
const payloads = this.appContentManager.getLoadingAppPayloads();
403-
await this.showPage(devicesChannel, device, payloads, { hmrMode, publisher: data.publisher });
404-
}
405-
406401
const initialPayload = await this.config.getInitialFiles(device);
407402
if (initialPayload && initialPayload.files && initialPayload.files.length) {
408403
if (!initialPayload.deviceId && device) {

0 commit comments

Comments
 (0)