10000 Merge pull request #1934 from NativeScript/raikov/side-drawer-fix · hbcodeXCI/NativeScript@7693e3a · GitHub
[go: up one dir, main page]

Skip to content

Commit 7693e3a

Browse files
committed
Merge pull request NativeScript#1934 from NativeScript/raikov/side-drawer-fix
fixed: some transitions in side drawer are not working
2 parents e4ae430 + 8b3d00d commit 7693e3a

File tree

3 files changed

+49
-2
lines changed

3 files changed

+49
-2
lines changed

application/application.d.ts

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -579,4 +579,11 @@ declare module "application" {
579579
*/
580580
removeNotificationObserver(observer: any, notificationName: string): void;
581581
}
582+
583+
/* tslint:disable */
584+
export interface RootViewControllerImpl {
585+
586+
contentController: any;
587+
588+
}
582589
}

application/application.ios.ts

Lines changed: 41 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -13,6 +13,43 @@ class Responder extends UIResponder {
1313
//
1414
}
1515

16+
class RootViewControllerImpl extends UIViewController implements definition.RootViewControllerImpl {
17+
private _contentController: UIViewController;
18+
19+
get contentController(): UIViewController {
20+
return this._contentController;
21+
}
22+
23+
set contentController(contentController: UIViewController) {
24+
25+
if (contentController.parentViewController !== null) {
26+
contentController.willMoveToParentViewController(null);
27+
contentController.view.removeFromSuperview();
28+
contentController.removeFromParentViewController();
29+
contentController.didMoveToParentViewController(this);
30+
}
31+
32+
if (this._contentController) {
33+
this._contentController.willMoveToParentViewController(null);
34+
this._contentController.view.removeFromSuperview();
35+
this._contentController.removeFromParentViewController();
36+
}
37+
38+
this.addChildViewController(contentController);
39+
this.view.addSubview(contentController.view);
40+
contentController.view.frame = this.view.bounds;
41+
contentController.view.autoresizingMask = UIViewAutoresizing.UIViewAutoresizingFlexibleWidth | UIViewAutoresizing.UIViewAutoresizingFlexibleHeight;
42+
43+
this._contentController = contentController;
44+
this._contentController.didMoveToParentViewController(this);
45+
}
46+
47+
public viewDidLoad(): void {
48+
super.viewDidLoad();
49+
this.view.backgroundColor = UIColor.whiteColor();
50+
}
51+
}
52+
1653
class Window extends UIWindow {
1754

1855
private _content;
@@ -140,11 +177,13 @@ class IOSApplication implements definition.iOSApplication {
140177

141178
rootView = frame;
142179
}
143-
180+
144181
this._window.content = rootView;
145182

146183
if (rootView instanceof Frame) {
147-
this.rootController = this._window.rootViewController = rootView.ios.controller;
184+
let rootController = new RootViewControllerImpl();
185+
this.rootController = this._window.rootViewController = rootController;
186+
rootController.contentController = rootView.ios.controller;
148187
}
149188
else if (rootView.ios instanceof UIViewController) {
150189
this.rootController = this._window.rootViewController = rootView.ios;

ui/frame/frame.ios.ts

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -430,6 +430,7 @@ class UINavigationControllerImpl extends UINavigationController {
430430
}
431431

432432
public viewDidLoad(): void {
433+
super.viewDidLoad();
433434
let owner = this._owner.get();
434435
if (owner) {
435436
owner.onLoaded();

0 commit comments

Comments
 (0)
0