0.1.1 • Published 6 years ago
babel-plugin-transform-titanium v0.1.1
This is a babel plugin intended to optimize Titanium SDK applications by inlining various static values. Once inlined, Other babel plugins may performa additional optimizations to help strip away "dead code".
Information about the current Titanium application build should be passed to the plugin's options object.
Plugin Options
const options = {
	deploytype: 'development', // one of 'development', 'test', 'production'
	platform: undefined, // one of 'android', 'ios', 'windows'
	target: undefined, // one of 'dist-playstore', 'dist-appstore', 'dist-adhoc', null/undefined
	Ti: {
		version: undefined, // string, SDK version
		App: {
			id: undefined, // string, application id from tiapp.xml
			name: undefined, // string, application name from tiapp.xml
			version: undefined, // string, application version from tiapp.xml
		}
		Platform: {
			osname: undefined, // one of 'android', 'ipad', 'iphone', 'windowsphone', 'windowsstore'
		}
	}
};Special "defines"
It can:
- replace special OS_*references with boolean values- OS_IOS-- trueiff- pluginOptions.platform === 'ios'
- OS_ANDROID-- trueiff- pluginOptions.platform === 'android'
- OS_WINDOWS-- trueiff- pluginOptions.platform === 'windows'
- Useful for if/elseguards for platform specific code. Once booleans are inlined the false blocks can be removed.
 
- replace special ENV_*references with boolean values- ENV_DEVand- ENV_DEVELOPMENT-- trueiff- pluginOptions.deploytype === 'development'(typically simulator builds)
- ENV_TEST-- trueiff- pluginOptions.deploytype === 'test'(typically device builds)
- ENV_PRODand- ENV_PRODUCTION-- trueiff- pluginOptions.deploytype === 'production'(typically app store/ad hoc builds)
 
- replace special DIST_*references with boolean values- DIST_ADHOC-- trueiff- pluginOptions.target === 'dist-adhoc'
- DIST_STORE-- trueiff- pluginOptions.target === 'dist-appstore' || pluginOptions.target === 'dist-playstore'
 
OS "sniffing" via Ti.Platform.osname
- replace typical "sniff" expressions for iOS/Windows using Ti.Platform.osnamewith static boolean values i.e.
if (Ti.Platform.osname === 'iphone' || Ti.Platform.osname === 'ipad') {
	Ti.API.info('on ios!');
}
if (Ti.Platform.osname === 'windowsstore' || Ti.Platform.osname === 'windowsphone') {
	Ti.API.info('on windows!');
}