processmaker-builder
Version:
The gulp task runner for ProcessMaker building
99 lines (66 loc) • 3.64 kB
Markdown
## Html Format
This example requires `PHP >= 5.3` and taggeed under `view` `html` `twig` `mustache` `handlebar` `php` `template`
A special format that lets us render a template with the api result
It currently supports the following template libraries/formats
- php (default)
- mustache / handlebar (requires `"mustache/mustache"`)
- twig (requires `"twig/twig"`)
- Laravel 4 blade templates (requires `"illuminate/view"`)
When HtmlFormat is used with out defining a view it uses debug view to present
data and more information
[](tasks/24)
View can be defined directly by setting `HtmlFormat::$view` and
`HtmlFormat::$format` where view defines the template file and format determines
the template type. When the view is defined with an extension such as `my.twig`
the extension will override the format
`HtmlFormat::$errorView` which defaults to the debug view defines the view when
the api call fails. When set to null `HtmlFormat::$view` is used for rendering
error response as well
`HtmlFormat::$view` can be set with a api method comment in the following format
folder/name.extension
When the extension is omitted `HtmlFormat::$format` will be used
HtmlFormat will look at `views` folder that resides parallel to `vendor` directory
for the template files and can be changed by setting `HtmlFormat::$viewPath` to
full path of a folder
> This API Server is made using the following php files/folders
>
> * index.php (gateway)
> * Tasks.php (api)
> * Task.php (helper)
> * Resources.php (api)
> * restler.php (framework)
> * JsonFormat.php (format)
> * HtmlFormat.php (format)
This API Server exposes the following URIs
GET resources ⇠ Luracast\Restler\Resources::index()
GET resources/verifyaccess ⇠ Luracast\Restler\Resources::verifyAccess()
GET resources/{id} ⇠ Luracast\Restler\Resources::get()
POST tasks ⇠ Tasks::post()
GET tasks ⇠ Tasks::index()
PATCH tasks/{id} ⇠ Tasks::patch()
GET tasks/{id} ⇠ Tasks::get()
DELETE tasks/{id} ⇠ Tasks::delete()
In this example, we are building tasks api and also a single page application
using jQuery and the templates
[](tasks)
Our api response is sent to the template under the name `response` along with other
information such as `basePath`, `baseUrl`, `request` parameters.
You can send custom data yourself by setting key value pairs in
`HtmlFormat::$data` array
If you do not want all the information and want to keep your template simple, you
can use `{ key.innerkey}` comment as shown below
todo/list { response}
This calls the list template with key value pairs defined at the response array
directly accessible as the variable and value inside the template
This example also show cases the heredoc syntax based simple templating system
which is Supported without any external dependencies
Just to show that it is possible to come up with API as well as an App using the
same resource and url, you can try the json version of the tasks api using the
API Explorer [here](explorer/index.html)
*[index.php]: _013_html/index.php
*[Tasks.php]: _013_html/Tasks.php
*[Task.php]: _013_html/DB/Task.php
*[Resources.php]: ../../vendor/Luracast/Restler/Resources.php
*[restler.php]: ../../vendor/restler.php
*[JsonFormat.php]: ../../vendor/Luracast/Restler/Format/JsonFormat.php
*[HtmlFormat.php]: ../../vendor/Luracast/Restler/Format/HtmlFormat.php