diff --git a/package-lock.json b/package-lock.json index 1edb254..fae596f 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,6 +1,6 @@ { "name": "nativescript-preview-sdk", - "version": "0.3.2", + "version": "0.3.4", "lockfileVersion": 1, "requires": true, "dependencies": { diff --git a/package.json b/package.json index 54d9aef..c6b4a14 100644 --- a/package.json +++ b/package.json @@ -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", diff --git a/src/constants.ts b/src/constants.ts index 59ad23f..f14a866 100644 --- a/src/constants.ts +++ b/src/constants.ts @@ -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"; -} \ No newline at end of file +} diff --git a/src/models/config.ts b/src/models/config.ts index c58cb1e..bc31784 100644 --- a/src/models/config.ts +++ b/src/models/config.ts @@ -14,9 +14,10 @@ export class Config { * Can be staging, uat or live */ msvEnv: string; - showLoadingPage?: boolean; callbacks: SdkCallbacks; getInitialFiles: (device?: Device) => Promise; instanceId?: string; connectedDevices?: ConnectedDevices; + previewAppStoreId?: string; + previewAppGooglePlayId?: string; } diff --git a/src/services/app-content-manager.ts b/src/services/app-content-manager.ts index d0e292a..6104ca0 100644 --- a/src/services/app-content-manager.ts +++ b/src/services/app-content-manager.ts @@ -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", @@ -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, @@ -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); } } @@ -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; - } - });`; - } - } \ No newline at end of file +} diff --git a/src/services/messaging-service.ts b/src/services/messaging-service.ts index c27107e..25c7607 100644 --- a/src/services/messaging-service.ts +++ b/src/services/messaging-service.ts @@ -390,7 +390,7 @@ 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; } @@ -398,11 +398,6 @@ export class MessagingService { 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) {