Skip to content

mynameisrienk/Palantir-Pocket

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

10 Commits
 
 
 
 
 
 

Repository files navigation

Palantír Pocket

Note: this is currently under heavy development!


Table of Contents

  1. Introduction
  2. Setting Up
    1. For iOS Chrome
    2. Parameters
    3. The JSONP data file
  3. Bookmarklet Ideas
    1. Open in Chrome and return to Safari
  4. Known Problems

Introduction

The original Palantír is a Chrome extension to quickly open bookmarks, bookmarklets and apps. Using bookmarklets in iOS Chrome (and to a lesser extend in iOS Safari) is quite cumbersome, to say the least. Palantír Pocket will be a simple solution to implement bookmarklets on your iOS device!

Palantír Pocket will launch an in-screen window with your preset bookmarks/bookmarklets. The bookmarks are imported from a json(p) file you will have to provide (since your bookmarks are not accessible using in-browser javascript).

By using the power of custom URL schemes (see this git repository and handleopenurl.com) and the x-callback-url specification, you can even use bookmarklets to interact with other apps!

↩ Table of Contents

Setting Up

Just create a bookmark with the following URL:

javascript:(function(){if(typeof%20palantirCallback%20!='function'){PP_FILE='//mynameisrienk.github.io/palantirpocket/data.json';PP_SCRIPT=document.createElement('SCRIPT');PP_SCRIPT.type='text/javascript';PP_SCRIPT.src='//mynameisrienk.github.io/palantirpocket/script.js';document.getElementsByTagName('head')[0].appendChild(PP_SCRIPT);}})();

… displayed as not url-encoded Javascript:

javascript:(function() {
	if (typeof palantirCallback != 'function') { 
		PP_FILE   = '//mynameisrienk.github.io/palantirpocket/data.json';
		PP_SCRIPT = document.createElement('SCRIPT');
		PP_SCRIPT.type = 'text/javascript';
		PP_SCRIPT.src = '//mynameisrienk.github.io/palantirpocket/script.js';
	document.getElementsByTagName('head')[0].appendChild(PP_SCRIPT);
	}
})();

↩ Table of Contents

For iOS Chrome

Bookmarklets in the mobile Chrome can only be launched through the omnibox. Therefore, give your bookmarklet a simple name, like PP. To launch it type PP into the omnibox and select the bookmarklet from the recommendations menu.

↩ Table of Contents

Parameters

PP_FILE is the URL to your JSONP data file. You can also optionally set the PP_CSS variable to the URL for your own CSS stylesheet.

Please note: I am working on a solution to easily implement your own JSONP data file for bookmarklets and URL schemes. For now, you will have to host your own JSONP file or use the default one I am curating for my personal use.

↩ Table of Contents

The JSONP

The bookmarklets are listed in a JSONP file (iOS doesn't allow for javascript access to your browser's bookmarks) wrapped in a function callback named palantirCallback.

The following keys are supported in the object:

  • title (string; required): the name of the bookmark(let).
  • description (string | null): a brief description of what the bookmark(let) opens/does.
  • url (url-encoded string; required): the url/javascript function. Use Chris Zarate's Bookmarkleter to easily url-encode your javascript into a bookmarklet url.
  • icon (string || null): a base64-encoded image string. Use AskApache's Base64 Image Converter. The image will be resized to 16x16px using CSS3's background-size property.

Example:

palantirCallback([
{
    "title": "Safari to Chrome",
    "description": "Open the current page in Chrome iOS",
    "url": "javascript:(function(){window.location='googlechrome-x-callback://x-callback-url/open/%3Furl='+encodeURIComponent(location.href)+'%26x-source=Safari%26x-success='+encodeURIComponent(location.href);})();",
    "icon": ""
}]);

↩ Table of Contents

Bookmarklet Ideas

Tweet your bookmarklet "URLs" to @MyNameIsRienk or add them yourself as new pull requests. Please keep the formatting the same.

↩ Table of Contents

Open in Chrome and return to Safari

Open the current web page in Chrome for iOS and display a button to return to Safari (from iosWorkflows

javascript:window.location='googlechrome-x-callback://x-callback-url/open/?url='+encodeURIComponent(location.href)+'&x-source=Safari&x-success='+encodeURIComponent(location.href);

↩ Table of Contents

Known Problems

  • The script doesn't always load due to Content Security Policy directive violations. AFAIK, this cannot be solved because it is a "server side" problem.

↩ Table of Contents

About

A bookmarklet solution for Chrome iOS (under heavy development!)

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published