[659] | 1 | .. _client-example: |
---|
| 2 | |
---|
| 3 | Example application |
---|
| 4 | ===================== |
---|
| 5 | |
---|
| 6 | This section gives a detailed example of ZOO-Client based JavaScript appliclation. |
---|
| 7 | |
---|
| 8 | .. note:: |
---|
| 9 | For this example application, first setup a ``/zoo-client-demo`` directory accessible from your web server at `http://localhost/zoo-client-demo`. |
---|
| 10 | |
---|
| 11 | The following subdirectories must be created in the ``/zoo-client-demo`` directory: |
---|
| 12 | |
---|
| 13 | :: |
---|
| 14 | |
---|
| 15 | assets |
---|
| 16 | assets/js |
---|
| 17 | assets/js/lib |
---|
| 18 | assets/js/lib/hogan |
---|
| 19 | assets/js/lib/jquery |
---|
| 20 | assets/js/lib/query-string |
---|
| 21 | assets/js/lib/xml2json |
---|
| 22 | assets/js/lib/zoo |
---|
| 23 | assets/tpl |
---|
| 24 | |
---|
| 25 | You will need to copy your node_modules javascript files copied in the |
---|
| 26 | `hogan` and `query-string` directories. First, you wil need to install |
---|
| 27 | query-string. |
---|
| 28 | |
---|
| 29 | :: |
---|
| 30 | |
---|
| 31 | npm install query-string |
---|
| 32 | |
---|
| 33 | Then you will copy `query-string.js` and `hogan-3.0.2.js` files in |
---|
| 34 | your `zoo-client-demo` web directory. Those files are located in your |
---|
| 35 | `~/node_modules` directory. |
---|
| 36 | |
---|
| 37 | For other libraries, you will need to download them from their |
---|
| 38 | official web sites and uncompress them in the corresponding |
---|
| 39 | directories. |
---|
| 40 | |
---|
| 41 | Loading the modules from your web application |
---|
| 42 | ********************************************* |
---|
| 43 | |
---|
| 44 | Before using the ZOO-Client, you will first have to include the |
---|
| 45 | javascript files from your web page. With the use of requirejs you |
---|
| 46 | will need only one line in your HTML page to include everything at |
---|
| 47 | once. This line will look like the following: |
---|
| 48 | |
---|
| 49 | :: |
---|
| 50 | |
---|
| 51 | <script data-main="assets/js/first" src="assets/js/lib/require.js"></script> |
---|
| 52 | |
---|
| 53 | In this example, we suppose that you have created a `first.js` file |
---|
| 54 | in the `assets/js` directory containing your main application |
---|
| 55 | code. First, you define there the required JavaScript libraries and |
---|
| 56 | potentially their configuration, then you can add any relevant code. |
---|
| 57 | |
---|
| 58 | .. code-block:: javascript |
---|
| 59 | :linenos: |
---|
| 60 | |
---|
| 61 | requirejs.config({ |
---|
| 62 | baseUrl: 'assets/js', |
---|
| 63 | paths: { |
---|
| 64 | jquery: 'lib/jquery/jquery-1.11.0.min', |
---|
| 65 | hogan: 'lib/hogan/hogan-3.0.2', |
---|
| 66 | xml2json: 'lib/xml2json/xml2json.min', |
---|
| 67 | queryString: 'lib/query-string/query-string', |
---|
| 68 | wpsPayloads: 'lib/zoo/payloads', |
---|
| 69 | wpsPayload: 'lib/zoo/wps-payload', |
---|
| 70 | utils: 'lib/zoo/utils', |
---|
| 71 | zoo: 'lib/zoo/zoo', |
---|
| 72 | domReady: 'lib/domReady', |
---|
| 73 | app: 'first-app', |
---|
| 74 | }, |
---|
| 75 | shim: { |
---|
| 76 | wpsPayloads: { |
---|
| 77 | deps: ['hogan'], |
---|
| 78 | }, |
---|
| 79 | wpsPayload: { |
---|
| 80 | deps: ['wpsPayloads'], |
---|
| 81 | exports: 'wpsPayload', |
---|
| 82 | }, |
---|
| 83 | hogan: { |
---|
| 84 | exports: 'Hogan', |
---|
| 85 | }, |
---|
| 86 | xml2json: { |
---|
| 87 | exports: "X2JS", |
---|
| 88 | }, |
---|
| 89 | queryString: { |
---|
| 90 | exports: 'queryString', |
---|
| 91 | }, |
---|
| 92 | }, |
---|
| 93 | }); |
---|
| 94 | |
---|
| 95 | requirejs.config({ |
---|
| 96 | config: { |
---|
| 97 | app: { |
---|
| 98 | url: '/cgi-bin/zoo_loader.cgi', |
---|
| 99 | delay: 2000, |
---|
| 100 | } |
---|
| 101 | } |
---|
| 102 | }); |
---|
| 103 | |
---|
| 104 | require(['domReady', 'app'], function(domReady, app) { |
---|
| 105 | domReady(function() { |
---|
| 106 | app.initialize(); |
---|
| 107 | }); |
---|
| 108 | }); |
---|
| 109 | |
---|
| 110 | On line 2, you define the url where your files are located on the web |
---|
| 111 | server, in `assets/js`. From line 3 to 14, you define the JavaScript |
---|
| 112 | files to be loaded. From line 15 to 21, you configure the dependencies |
---|
| 113 | and exported symbols. From line 35 to 42, you configure your main |
---|
| 114 | application. |
---|
| 115 | |
---|
| 116 | In this application, we use the `domReady |
---|
| 117 | <http://github.com/requirejs/domReady>`__ module to call the |
---|
| 118 | `initialize` function defined in the `app` module, which is defined in |
---|
| 119 | the `first-app.js` file as defined on line 13. |
---|
| 120 | |
---|
| 121 | |
---|
| 122 | |
---|
| 123 | .. code-block:: javascript |
---|
| 124 | :linenos: |
---|
| 125 | |
---|
| 126 | define([ |
---|
| 127 | 'module','zoo','wpsPayload' |
---|
| 128 | ], function(module, ZooProcess, wpsPayload) { |
---|
| 129 | |
---|
| 130 | var myZooObject = new ZooProcess({ |
---|
| 131 | url: module.config().url, |
---|
| 132 | delay: module.config().delay, |
---|
| 133 | }); |
---|
| 134 | |
---|
| 135 | var initialize = function() { |
---|
| 136 | self = this; |
---|
| 137 | myZooObject.getCapabilities({ |
---|
| 138 | type: 'POST', |
---|
| 139 | success: function(data){ |
---|
| 140 | console.log(data); |
---|
| 141 | } |
---|
| 142 | }); |
---|
| 143 | |
---|
| 144 | myZooObject.describeProcess({ |
---|
| 145 | type: 'POST', |
---|
| 146 | identifier: "all", |
---|
| 147 | success: function(data){ |
---|
| 148 | console.log(data); |
---|
| 149 | } |
---|
| 150 | }); |
---|
| 151 | |
---|
| 152 | myZooObject.execute({ |
---|
| 153 | identifier: "Buffer", |
---|
| 154 | dataInputs: [{"identifier":"InputPolygon","href":"XXX","mimeType":"text/xml"}], |
---|
| 155 | dataOutputs: [{"identifier":"Result","mimeType":"application/json","type":"raw"}], |
---|
| 156 | type: 'POST', |
---|
| 157 | success: function(data) { |
---|
| 158 | console.log(data); |
---|
| 159 | }, |
---|
| 160 | error: function(data){ |
---|
| 161 | console.log(data); |
---|
| 162 | } |
---|
| 163 | }); |
---|
| 164 | } |
---|
| 165 | |
---|
| 166 | // Return public methods |
---|
| 167 | return { |
---|
| 168 | initialize: initialize |
---|
| 169 | }; |
---|
| 170 | |
---|
| 171 | }); |
---|
| 172 | |
---|
| 173 | On line 5 you create a "global" `ZooProcess` instance named |
---|
| 174 | `myZooObject`, you set the `url` and `delay` to the values defined in |
---|
| 175 | `first.js` on line 35. From line 10 to 40, you define a simple |
---|
| 176 | `initialize` function which will invoke the `getCapabilities` (line |
---|
| 177 | 12 to 18), `describeProcess` (from line 20 to 26) and `execute` (from |
---|
| 178 | line 28 to 39) methods. For each you define a callback function which |
---|
| 179 | will simply display the resulting data in the browser's console. |
---|
| 180 | |
---|
| 181 | |
---|