Difference between revisions of "Patch Launcher Reset to Middle Page"

From WebOS Internals
Jump to navigation Jump to search
(Updated patch, now longer relies on Reset Scroll Position patch to reset scroll.)
m (Added PreCentral forums link)
 
Line 204: Line 204:
  
 
</source>
 
</source>
 +
 +
==Support==
 +
 +
The [http://forums.precentral.net/webos-patches/217638-patch-reset-launcher-first-middle-page.html discussion thread at the PreCentral.net forums] is the best place to ask any questions.

Latest revision as of 20:57, 6 December 2009


Introduction

By default, the Launcher maintains the last page opened when you return to it. If you most frequently use apps on a certain page of the Launcher, you have to swipe back to that page if the last app you launched was on another page. This patch resets the Launcher to the middle page every time it opens. This works best if you have an odd number of pages (like the default 3), then you have the same number of pages to the left, and to the right, thus minimizing the number of swipes required to get to the first or last page. It also resets the scroll position of all pages, so that when you re-open the Launcher, all pages will be scrolled to the top (previously it only did this if the Reset Scroll Position patch was also installed, I abandoned that idea. Apologies if anyone really wants the reset page behaviour without the reset scroll feature - check out the page history for older versions or adjust the patch accordingly).

Editing Process

  • SSH in.
  • Remount the filesystem as read/write:

<source lang="bash">

sudo rootfs_open -w

</source>

  • Load launcher-assistant.js in vi:

<source lang="bash">

sudo vi /usr/lib/luna/system/luna-applauncher/app/controllers/launcher-assistant.js

</source>

  • Locate the beginning of the onDeactivate method around line 170:

<source lang="javascript">

/* clean and hide global search */ onDeactivate: function(event) {

this.globalSearchAssistant.deactivate();

this.reorderController.cancel();

if (this.appDialog) { this.appDialog.mojo.close(); }

SystemManagerService.showQuickLaunch(true);

delete this.launchRequest;

this.removeLaunchFeedback(); },

</source>

  • Add the following lines at the bottom of the onDeactivate method so that is now looks like this:

<source lang="javascript">

/* clean and hide global search */ onDeactivate: function(event) {

this.globalSearchAssistant.deactivate();

this.reorderController.cancel();

if (this.appDialog) { this.appDialog.mojo.close(); }

SystemManagerService.showQuickLaunch(true);

delete this.launchRequest;

this.removeLaunchFeedback();

/** * Calculate middle page. For an even number of pages, * this will be the lower side of the mid-point. */ var numPages=this.pagesModel.getNumPages(); var middlePage = (numPages % 2) ? (numPages - 1) / 2: numPages / 2 - 1;

/* Reset launcher to middle page */ $('launcher_root').mojo.setSnapIndex(middlePage, false);

/* Jump scroll position back to top for all pages */ for (var i=0; i<numPages; i++) { var scroller = this.getPageScroller(i); if (scroller && scroller.mojo) { scroller.mojo.revealTop(); } } },

</source>

  • Locate the buildPages method that begins around line 510:

<source lang="javascript">

/* build out the pages for all applications */ buildPages: function() {

this.globalSearchAssistant.enable(false);

this.deleteAllPages();

var location = {page: 0, position: 0}; for (var i=0, numPages=this.pagesModel.getNumPages(); i<numPages; i++) { // create a new page this.insertPage(i);

// insert all the applications for this page into the page container var page = this.pagesModel.getPage(i); location.page = i; for (var j=0; j<page.length; j++) { location.position = j; this.insertApp(location, this.pagesModel.getAppInfo(page[j])); } }

this.globalSearchAssistant.enable(true); },

</source>

  • Add the following lines to the bottom of the buildPages method so that it now looks like this:

<source lang="javascript">

/* build out the pages for all applications */ buildPages: function() {

this.globalSearchAssistant.enable(false);

this.deleteAllPages();

var location = {page: 0, position: 0}; for (var i=0, numPages=this.pagesModel.getNumPages(); i<numPages; i++) { // create a new page this.insertPage(i);

// insert all the applications for this page into the page container var page = this.pagesModel.getPage(i); location.page = i; for (var j=0; j<page.length; j++) { location.position = j; this.insertApp(location, this.pagesModel.getAppInfo(page[j])); } }

this.globalSearchAssistant.enable(true);

/** * Calculate middle page. For an even number of pages, * this will be the lower side of the mid-point. */ var middlePage = (numPages % 2) ? (numPages - 1) / 2: numPages / 2 - 1;

/* Set launcher to middle page */ $('launcher_root').mojo.setSnapIndex(middlePage, false); },

</source>

  • Save the file and quit vi.
  • Remount the filesystem as read only - this should reboot your Pre:

<source lang="bash">

sudo rootfs_open -w

</source>


Patch Process

The patch is not in the webos-internals gitorious repository yet, but is has been submitted. Until then, you can copy and paste the source below. Visit Applying Patches for info on how to use it. You can also apply it using webOS Quick Install. To apply the patch, follow the instructions above, and after remounting the filesystem as read/write, do the following:

  • Apply the patch (In this example, I have the patch file located in my home directory under patches):

<source lang="bash">

cd / sudo patch -p0 --backup-if-mismatch < ~/patches/reset-to-middle-page.patch

</source>

This is what you should see if it ran properly: <source lang="text"> patching file /usr/lib/luna/system/luna-applauncher/app/controllers/launcher-assistant.js

</source>

  • Remount the filesystem as read only as described above.


Patch Source (reset-to-midle-page.patch)

<source lang="diff"> --- /usr/lib/luna/system/luna-applauncher/app/controllers/launcher-assistant.js.orig Sat Dec 5 11:48:12 2009 +++ /usr/lib/luna/system/luna-applauncher/app/controllers/launcher-assistant.js Thu Dec 3 19:42:03 2009 @@ -183,6 +183,22 @@

		delete this.launchRequest;
		
		this.removeLaunchFeedback();

+ + /** + * Calculate middle page. For an even number of pages, + * this will be the lower side of the mid-point. + */ + var numPages=this.pagesModel.getNumPages(); + var middlePage = (numPages % 2) ? (numPages - 1) / 2: numPages / 2 - 1; + + /* Reset launcher to middle page */ + $('launcher_root').mojo.setSnapIndex(middlePage, false); + + /* Jump scroll position back to top for all pages */ + for (var i=0; i<numPages; i++) { + var scroller = this.getPageScroller(i); + if (scroller && scroller.mojo) { scroller.mojo.revealTop(); } + }

	},
	
	onResize: function(event) {

@@ -529,6 +545,15 @@

		}
		
		this.globalSearchAssistant.enable(true);

+ + /** + * Calculate middle page. For an even number of pages, + * this will be the lower side of the mid-point. + */ + var middlePage = (numPages % 2) ? (numPages - 1) / 2: numPages / 2 - 1; + + /* Set launcher to middle page */ + $('launcher_root').mojo.setSnapIndex(middlePage, false);

	},
	
	/* re-acquires the set of page elements the scroller needs to snap */

</source>

Support

The discussion thread at the PreCentral.net forums is the best place to ask any questions.