-
Notifications
You must be signed in to change notification settings - Fork 2
/
TITANIUM
107 lines (67 loc) · 2.95 KB
/
TITANIUM
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
# Appcelerator Titanium Mobile Module Project
This is a skeleton Titanium Mobile Mobile module project.
## Module Naming
Choose a unique module id for your module. This ID usually follows a namespace
convention using DNS notation. For example, com.appcelerator.module.test. This
ID can only be used once by all public modules in Titanium.
## Getting Started
1. Edit the `manifest` with the appropriate details about your module.
2. Edit the `LICENSE` to add your license details.
3. Place any assets (such as PNG files) that are required anywhere in the module folder.
4. Edit the `timodule.xml` and configure desired settings.
5. Code and build.
## Documentation
-----------------------------
You should provide at least minimal documentation for your module in `documentation` folder using the Markdown syntax.
For more information on the Markdown syntax, refer to this documentation at:
<http://daringfireball.net/projects/markdown/>
## Example
The `example` directory contains a skeleton application test harness that can be
used for testing and providing an example of usage to the users of your module.
## Building
Simply run `appc run -p [ios|android] --build-only` which will compile and package your module.
## Linting
You can use `clang` to lint your code. A default Axway linting style is included inside the module main folder.
Run `clang-format -style=file -i SRC_FILE` in the module root to lint the `SRC_FILE`. You can also patterns,
like `clang-format -style=file -i Classes/*`
## Install
To use your module locally inside an app you can copy the zip file into the app root folder and compile your app.
The file will automatically be extracted and copied into the correct `modules/` folder.
If you want to use your module globally in all your apps you have to do the following:
### macOS
Copy the distribution zip file into the `~/Library/Application Support/Titanium` folder
### Linux
Copy the distribution zip file into the `~/.titanium` folder
### Windows
Copy the distribution zip file into the `C:\ProgramData\Titanium` folder
## Project Usage
Register your module with your application by editing `tiapp.xml` and adding your module.
Example:
<modules>
<module version="1.0.0">com.testfairy.titestfairy</module>
</modules>
When you run your project, the compiler will combine your module along with its dependencies
and assets into the application.
## Example Usage
To use your module in code, you will need to require it.
### ES6+ (recommended)
```js
import MyModule from 'com.testfairy.titestfairy';
MyModule.foo();
```
### ES5
```js
var MyModule = require('com.testfairy.titestfairy');
MyModule.foo();
```
## Testing
To test your module with the example, use:
```js
appc run -p [ios|android]
```
This will execute the app.js in the example/ folder as a Titanium application.
## Distribution
You have a variety of choises for distributing your module
- [Gitt.io](http://gitt.io/)
- [Axway Marketplace](https://marketplace.axway.com/home)
Code strong!