Changes for page Quellen
Change comment:
There is no comment for this version
Summary
-
Page properties (2 modified, 0 added, 0 removed)
Details
- Page properties
-
- Author
-
... ... @@ -1,1 +1,1 @@ 1 -XWiki. nlo1 +XWiki.gru - Content
-
... ... @@ -1,16 +1,14 @@ 1 1 {{content/}} 2 2 3 3 {{id name="fig_data_source"/}} 4 -{{figure image="data_source_en.png" }} 5 -Configuration screen for creating data sources: (1) list of existing data sources, (2) area for editing the selected data source, (3) settings panel of the data source, (4) servlet URL for accessing the data source. 6 -{{/figure}} 4 +{{figure image="data_source_en.png"}}Configuration screen for creating data sources: (1) list of existing data sources, (2) area for editing the selected data source, (3) settings panel of the data source, (4) servlet URL for accessing the data source.{{/figure}} 7 7 8 8 The sources or rather data sources are lodged as text in the format CSV, JSON or XML and can be worked up through the {{designer/}}/the form. 9 -To have an access to data sources in the script area via javascript too, all data sources are converted into a JSON structure and customized in the object {{code}}XFC_METADATA.urls.datasource_[csv|json|xml]{{/code}}. The structure of this JSON structure for the different data sources is expounded in the respective section. 7 +To have an access to data sources in the script area via javascript too, all data sources are converted into a JSON structure and customized in the object {{code language="none"}}XFC_METADATA.urls.datasource_[csv|json|xml]{{/code}}. The structure of this JSON structure for the different data sources is expounded in the respective section. 10 10 11 11 {{info}} 12 12 **Servlet URL** 13 -The servlet URL of a data source will be displayed on the configuration screen (see point 4 in [[figure>>||anchor="fig_data_source"]]) and is provided in the JS object {{code}}XFC_METADATA.urls.datasource_[csv|json|xml]{{/code}}. 11 +The servlet URL of a data source will be displayed on the configuration screen (see point 4 in [[figure>>||anchor="fig_data_source"]]) and is provided in the JS object {{code language="none"}}XFC_METADATA.urls.datasource_[csv|json|xml]{{/code}}. 14 14 {{/info}} 15 15 16 16 == Creating a data source == ... ... @@ -58,28 +58,39 @@ 58 58 59 59 == CSV == 60 60 61 -Here you can insert data sets in the CSV format. 59 +{{figure image="data_source_csv_servlet_json_comparison.png"}} 60 +The JSON structure of a CSV data source. This JSON structure can be accessed through JavaScript via {{code language="none"}}XFC_METADATA.urls.datasource_csv{{/code}}. (1) On the left there is the JSON structure of the data source with out using the first row as a header. Instead the headers are of the form: {{code language="none"}}colX{{/code}}. (2) On the right there is the data source where the first row is being used as the header. 61 +{{/figure}} 62 62 63 -* Choose the option //CSV// under //type//. 64 -* Assign an explicit name. 65 -* Insert the data sperated with a comma in the arrey //value//. 63 +CSV data sources can be viewed in a source code view or in a table view. The view can be switched by clicking the appropriate button {{ficon name="table-large"/}}/{{icon name="code"/}} beneath the editing area. 66 66 67 -{{figure image="datenquelle_csv_8.png" width="300"}} 68 -The JSON structure of the CSV data source. To this JSON structure can only be accessed via {{code}}XFC_METADATA.urls.datasource_[csv|json|xml]{{/code}}. 69 -{{/figure}} 65 +//Source code view of a CSV data source//: ([[CSV file format>>https://en.wikipedia.org/wiki/Comma-separated_values||target="_blank"]]) 66 +{{lightbox image="data_source_csv_source.png" title="Source code view of a CSV data source"/}} 67 +//Table view of a CSV data source//: 68 +{{lightbox image="data_source_csv_table.png" title="Table view of a CSV data source"/}} 70 70 71 -=== E xamplefor aCSVdatasource ===70 +=== Editing CSV tables === 72 72 73 -{{info}} 74 -The CSV data are converted to a JSON object internally, so that the first line of the //CSV data// always defines the object names for the later access. 75 -{{/info}} 72 +There is a row of buttons beneath the editing area for editing the CSV data table: 76 76 77 -{{code}} 78 -Value 1.1, value 1.2, value 1.3, value 1.4, ... 79 -{{/code}} 74 +* {{ficon name="plus-circle"/}} **Insert**: Inserts new rows or columns relative to the selected cell. 75 +* {{ficon name="trash-alt2"/}} **Remove**: Removes the selected row(s) or column(s) or empties the selected cell. 76 +* {{icon name="upload"/}} **Import**: Opens up the [[dialog for importing CSV data sources>>||anchor="data_source_import_csv"]]. 77 +* {{icon name="code"/}} **Source code view**: Switches to source code view. 80 80 81 - Thereadoutofthevalues inthe{{designer/}} ensues through the //servlet// with the namen //datenquellecsv//.79 +=== Header of CSV data sources === 82 82 81 +There is an additional option for CSV data sources in the data source settings. The option **First row is header** determines how the values of the data sources are being accessed via its servlet ({{code language="none"}}XFC_METADATA.urls.datasource_csv{{/code}}): 82 + 83 +* **Activated**: 84 +The cells of the first row will be used as {{code language="none"}}keys{{/code}} for accessing the values of the respective columns (see [[example>>||anchor="data_source_csv_example"]]). 85 +* **Deactivated**: 86 +The {{code language="none"}}keys{{/code}} for accessing the values of individual data fields/ rows are enumerated, starting with {{code language="none"}}0{{/code}}. These keys have the following form: {{code language="none"}}colX{{/code}} where {{code language="none"}}X{{/code}} stands for the column index. 87 + 88 +{{lightbox image="data_source_csv_settings_en.png" title="The option **first row is header** determines how the values of CSV data sources are accessed with its servlet"/}} 89 + 90 +CSV data sources can be accessed in the {{designer case="dat"/}} via its servlet: {{code language="none"}}XFC_METADATA.urls.datasource_csv{{/code}}. 91 + 83 83 === Servlet parameters === 84 84 85 85 {{info}} ... ... @@ -87,56 +87,54 @@ 87 87 http(s):~/~/<server>/formcycle/datenquellecsv?mandantName=<Mandant-Name>&name=<Datenquellen-Name> 88 88 {{/info}} 89 89 90 - Atanaccessof the {{designer/}}alwaysusethe globalvariables object //XFC_METADATA//, see also[[globaldesignervariables>>doc:Formcycle.FormDesigner.CodingPanel.ScriptTab.FormMetadata]].Forexampletcanbeaccessedasfollows: {{code}}XFC_METADATA.urls.datasource_csv{{/code}}.99 +Bei Zugriff aus dem {{designer case="dat"/}} verwenden Sie immer das globale Variablen-Objekt //XFC_METADATA//, siehe hierzu auch [[Globale Designer Variablen>>https://jsdocs.formcycle.eu/jsdocs/de/modules/_formcycle_v6_de_d_.html#xfc_metadata||target="_blank"]]. Beispielsweise kann wie folgt darauf zugegriffen werden: {{code language="none"}}XFC_METADATA.urls.datasource_csv{{/code}}. 91 91 101 +Always use the global variables object {{code language="none"}}XFC_METADATA{{/code}} when accessing data sources from the {{designer/}}, see also [[global designer variables>>doc:Formcycle.FormDesigner.CodingPanel.ScriptTab.FormMetadata]]. The servlet URK can be accessed as follows: {{code language="none"}}XFC_METADATA.urls.datasource_csv{{/code}}. 102 + 92 92 The following parameters are possible: 93 93 94 94 |=name of the parameter|=description|=necessary 95 95 |name|Must match the name of the CSV data source.|Yes 96 96 |mandantName|Must match the name of the client under which the data source was created.|Yes, if //projektId// is not given. 97 -|projektId|Must match the ID of the form. These information can be recalled via {{code}}XFC_METADATA.currentProject.id{{/code}}.|Yes, if //mandantName// is not given. 108 +|projektId|Must match the ID of the form. These information can be recalled via {{code language="none"}}XFC_METADATA.currentProject.id{{/code}}.|Yes, if //mandantName// is not given. 98 98 |kopfzeile|Indicates a comma seperated list with column name of the CSV table. If this is not given, the first line of the CSV is used.|No 99 99 |spaltenNamen|Indicates a comma seperated list of the column, which columns are redelivered of the //servlet// with the corresponding value. At this, according to using, the names of the columns of the parameter //headline// or the name of the first line of the //CSV// databaseHierbei are expected.|No 100 -|csvTrennzeichen|Indicates the seperator between the single data cells. If this is not set, a comma {{code}},{{/code}} is used by default.|No 101 -|csvQuote|The seperator with which the values of the lines are seperated. If this is not set, a inverted comma {{code}}"{{/code}} is used by default.| No 111 +|csvTrennzeichen|Indicates the seperator between the single data cells. If this is not set, a comma {{code language="none"}},{{/code}} is used by default.|No 112 +|csvQuote|The seperator with which the values of the lines are seperated. If this is not set, a inverted comma {{code language="none"}}"{{/code}} is used by default.| No 102 102 103 103 === Application example === 104 104 105 -{{figure image="087En.png" width="300"}} 106 -An example of how a CSV datasource can look. The columns are seperated through commas. 107 -{{/figure}} 116 +A CSV data source with the option activated: **First row is header**. It has the following content: 108 108 109 109 {{code language="csv"}} 110 -title,first name,lastname,plz,location119 +title,firstName,lastName,zip,city 111 111 Herr,Max,Mustermann,1000,Musterhausen 112 112 Frau,Monika,Mustermann,2000,Musterdorf 113 113 Frau, Luise,Musterfrau,3000,Musterstadt 123 + 114 114 {{/code}} 115 115 126 +In the {{designer/}} the following script is used in the [[script area>>doc:Formcycle.FormDesigner.CodingPanel.ScriptTab.WebHome]] for pre-filling form fields: 116 116 117 - 118 - 119 -In the {{designer/}} the following script is used in the [[script area>>doc:Formcycle.FormDesigner.CodingPanel.ScriptTab.WebHome]]. 120 - 121 121 {{code language="javascript"}} 122 122 $.getJSON( XFC_METADATA.urls.datasource_csv + "?name=Demo&mandantName=xima.de", function(json) { 123 - var obj = json.returnValue[0] 130 + var obj = json.returnValue[0]; 124 124 125 - $('[name=tf Anrede]').val(obj.anrede)126 - $('[name=tf Vorname]').val(obj.vorname)127 - $('[name=tfName]').val(obj. nachname)128 - $('[name=tf PLZ]').val(obj.plz)129 - $('[name=tf Ort]').val(obj.ort)130 - }) 132 + $('[name=tfTitle]').val(obj.title); 133 + $('[name=tfFirstName]').val(obj.firstName); 134 + $('[name=tfLastName]').val(obj.lastName); 135 + $('[name=tfZIP]').val(obj.zip); 136 + $('[name=tfCity]').val(obj.city); 137 + }); 131 131 {{/code}} 132 132 133 -{{ figureimage="088En.png"width="300"/}}140 +{{lightbox image="data_source_csv_designer_script_en.png"/}} 134 134 135 -This example asa data source for the {{designer/}}[[fordownloading>>attach:beispiel_datenquelle_csv.json||rel="__blank"]].142 +This form example is provided as a [[download>>attach:CSV-Demo_en.json||rel="__blank"]]. 136 136 137 137 === Exeption selection element === 138 138 139 -{{figure image="data_source_csv_designer_ de.png"}}146 +{{figure image="data_source_csv_designer_en.png"}} 140 140 The connection of a data source to a selection element takes place directly in the {{designer/}} 141 141 {{/figure}} 142 142 ... ... @@ -144,24 +144,28 @@ 144 144 145 145 The content of the CSV data source is processed in a [[selection element>>doc:Formcycle.FormDesigner.FormElements.Selection]]. 146 146 147 -{{code}} 148 -visible value, assigned value, optional value, optional value sichtbarer wert, ...154 +{{code language="none"}} 155 +visible value, assigned value, optional value, optional value, ... 149 149 {{/code}} 150 150 151 -If more than the visible and the assigned value are indicated, so optional values, the can be invoked in JavaScript through the following jQuery selector. 158 +Columns of the data source are use as follows for [[selection elements>>doc:Formcycle.FormDesigner.FormElements.Selection]]: 159 +{{code language="none"}}col + column index{{/code}}. 152 152 161 +If a data source has more than two columns than it contains optional values. These optional values can be accessed with JavaScript via the following jQuery selector: 162 + 153 153 {{code language="javascript"}} 154 -$('[name=sel2]').find('option:selected').attr('col 0');164 +$('[name=sel2]').find('option:selected').attr('col2'); 155 155 {{/code}} 156 156 157 -Every optional value is stored to the selection element as attribute {{code}}col + index of the optional value{{/code}}. At e.g. three optional values, there would be //col0//, //col1// and //col2//. 167 +Optinal values start at column index 2. 168 +If the first row is marked as a header than it will be ignored for selection elements. 158 158 159 159 == XML == 160 160 161 161 The XML data source acts analogously to the //CSV// data source, but cannot be bound to a [[selection element>>doc:Formcycle.FormDesigner.FormElements.Selection]]. 162 162 163 -{{figure image="dat enquelle_xml.png" width="300"}}164 -The JSON structure of the XML data source. To this JSON structure can than be accessed to {{code}}XFC_METADATA.urls.datasource_ [csv|json|xml]{{/code}} via Javascript.174 +{{figure image="data_source_xml_servlet_json.png" width="300"}} 175 +The JSON structure of the XML data source. To this JSON structure can than be accessed to {{code language="none"}}XFC_METADATA.urls.datasource_xml{{/code}} via Javascript. 165 165 {{/figure}} 166 166 167 167 === Example for an XML data source === ... ... @@ -213,8 +213,8 @@ 213 213 214 214 The //JSON// data source acts analogously to the //CSV// data source, but cannot be bound to a [[selection element>>doc:Formcycle.FormDesigner.FormElements.Selection]] directly. 215 215 216 -{{figure image="daten quelle_json.png"width="300"}}217 -The JSON structure of the JSON data source. It is identically equal to the JSON data source. This JSON structure can be accessed via Javascript through {{code}}XFC_METADATA.urls.datasource_ [csv|json|xml]{{/code}}.227 +{{figure image="data_source_json_servlet_json.png"}} 228 +The JSON structure of the JSON data source. It is identically equal to the JSON data source. This JSON structure can be accessed via Javascript through {{code language="none"}}XFC_METADATA.urls.datasource_json{{/code}}. 218 218 {{/figure}} 219 219 220 220 === Example for a JSON data source === ... ... @@ -221,16 +221,16 @@ 221 221 222 222 {{code language="json"}} 223 223 {"person":[ 224 - 225 - 'anrede':'Herr',226 - 'vorname':'Max',227 - 'nachname':'Mustermann'228 - }, 229 - 230 - 'anrede':'Frau',231 - 'vorname':'Monika',232 - 'nachname':'Musterfrau'233 - 235 + { 236 + "anrede":"Herr", 237 + "vorname":"Max", 238 + "nachname":"Mustermann" 239 + }, 240 + { 241 + "anrede":"Frau", 242 + "vorname":"Monika", 243 + "nachname":"Musterfrau" 244 + } 234 234 ]} 235 235 {{/code}} 236 236