forked from MapComplete/MapComplete
		
	Studio: WIP
This commit is contained in:
		
							parent
							
								
									6ff2c629f0
								
							
						
					
					
						commit
						cb538c2303
					
				
					 33 changed files with 608 additions and 2071 deletions
				
			
		|  | @ -263,7 +263,7 @@ | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "tagRenderings": { |     "tagRenderings": { | ||||||
|       "description": "question: Which tagRenderings should be shown in the infobox?\n\nA tag rendering is a block that either shows the known value or asks a question.\n\nRefer to the class `TagRenderingConfigJson` to see the possibilities.\n\nNote that we can also use a string here - where the string refers to a tag rendering defined in `assets/questions/questions.json`,\nwhere a few very general questions are defined e.g. website, phone number, ...\nFurthermore, _all_ the questions of another layer can be reused with `otherlayer.*`\nIf you need only a single of the tagRenderings, use `otherlayer.tagrenderingId`\nIf one or more questions have a 'group' or 'label' set, select all the entries with the corresponding group or label with `otherlayer.*group`\nRemark: if a tagRendering is 'lent' from another layer, the 'source'-tags are copied and added as condition.\nIf they are not wanted, remove them with an override\n\nA special value is 'questions', which indicates the location of the questions box. If not specified, it'll be appended to the bottom of the featureInfobox.\n\nAt last, one can define a group of renderings where parts of all strings will be replaced by multiple other strings.\nThis is mainly create questions for a 'left' and a 'right' side of the road.\nThese will be grouped and questions will be asked together\n\ngroup: tagrenderings", |       "description": "question: Which tagRenderings should be shown in the infobox?\n\nA tag rendering is a block that either shows the known value or asks a question.\n\nRefer to the class `TagRenderingConfigJson` to see the possibilities.\n\nNote that we can also use a string here - where the string refers to a tag rendering defined in `assets/questions/questions.json`,\nwhere a few very general questions are defined e.g. website, phone number, ...\nFurthermore, _all_ the questions of another layer can be reused with `otherlayer.*`\nIf you need only a single of the tagRenderings, use `otherlayer.tagrenderingId`\nIf one or more questions have a 'group' or 'label' set, select all the entries with the corresponding group or label with `otherlayer.*group`\nRemark: if a tagRendering is 'lent' from another layer, the 'source'-tags are copied and added as condition.\nIf they are not wanted, remove them with an override\n\nA special value is 'questions', which indicates the location of the questions box. If not specified, it'll be appended to the bottom of the featureInfobox.\n\nAt last, one can define a group of renderings where parts of all strings will be replaced by multiple other strings.\nThis is mainly create questions for a 'left' and a 'right' side of the road.\nThese will be grouped and questions will be asked together\n\ntype: tagrendering[]\ngroup: tagrenderings", | ||||||
|       "type": "array", |       "type": "array", | ||||||
|       "items": { |       "items": { | ||||||
|         "anyOf": [ |         "anyOf": [ | ||||||
|  | @ -540,7 +540,7 @@ | ||||||
|       "type": "object", |       "type": "object", | ||||||
|       "properties": { |       "properties": { | ||||||
|         "render": { |         "render": { | ||||||
|           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", |           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", | ||||||
|           "anyOf": [ |           "anyOf": [ | ||||||
|             { |             { | ||||||
|               "$ref": "#/definitions/Record<string,string>" |               "$ref": "#/definitions/Record<string,string>" | ||||||
|  | @ -1197,7 +1197,7 @@ | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         "render": { |         "render": { | ||||||
|           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", |           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", | ||||||
|           "anyOf": [ |           "anyOf": [ | ||||||
|             { |             { | ||||||
|               "$ref": "#/definitions/Record<string,string>" |               "$ref": "#/definitions/Record<string,string>" | ||||||
|  | @ -1369,7 +1369,7 @@ | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         "render": { |         "render": { | ||||||
|           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", |           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", | ||||||
|           "anyOf": [ |           "anyOf": [ | ||||||
|             { |             { | ||||||
|               "$ref": "#/definitions/Record<string,string>" |               "$ref": "#/definitions/Record<string,string>" | ||||||
|  |  | ||||||
|  | @ -263,7 +263,7 @@ export default { | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "tagRenderings": { |     "tagRenderings": { | ||||||
|       "description": "question: Which tagRenderings should be shown in the infobox?\n\nA tag rendering is a block that either shows the known value or asks a question.\n\nRefer to the class `TagRenderingConfigJson` to see the possibilities.\n\nNote that we can also use a string here - where the string refers to a tag rendering defined in `assets/questions/questions.json`,\nwhere a few very general questions are defined e.g. website, phone number, ...\nFurthermore, _all_ the questions of another layer can be reused with `otherlayer.*`\nIf you need only a single of the tagRenderings, use `otherlayer.tagrenderingId`\nIf one or more questions have a 'group' or 'label' set, select all the entries with the corresponding group or label with `otherlayer.*group`\nRemark: if a tagRendering is 'lent' from another layer, the 'source'-tags are copied and added as condition.\nIf they are not wanted, remove them with an override\n\nA special value is 'questions', which indicates the location of the questions box. If not specified, it'll be appended to the bottom of the featureInfobox.\n\nAt last, one can define a group of renderings where parts of all strings will be replaced by multiple other strings.\nThis is mainly create questions for a 'left' and a 'right' side of the road.\nThese will be grouped and questions will be asked together\n\ngroup: tagrenderings", |       "description": "question: Which tagRenderings should be shown in the infobox?\n\nA tag rendering is a block that either shows the known value or asks a question.\n\nRefer to the class `TagRenderingConfigJson` to see the possibilities.\n\nNote that we can also use a string here - where the string refers to a tag rendering defined in `assets/questions/questions.json`,\nwhere a few very general questions are defined e.g. website, phone number, ...\nFurthermore, _all_ the questions of another layer can be reused with `otherlayer.*`\nIf you need only a single of the tagRenderings, use `otherlayer.tagrenderingId`\nIf one or more questions have a 'group' or 'label' set, select all the entries with the corresponding group or label with `otherlayer.*group`\nRemark: if a tagRendering is 'lent' from another layer, the 'source'-tags are copied and added as condition.\nIf they are not wanted, remove them with an override\n\nA special value is 'questions', which indicates the location of the questions box. If not specified, it'll be appended to the bottom of the featureInfobox.\n\nAt last, one can define a group of renderings where parts of all strings will be replaced by multiple other strings.\nThis is mainly create questions for a 'left' and a 'right' side of the road.\nThese will be grouped and questions will be asked together\n\ntype: tagrendering[]\ngroup: tagrenderings", | ||||||
|       "type": "array", |       "type": "array", | ||||||
|       "items": { |       "items": { | ||||||
|         "anyOf": [ |         "anyOf": [ | ||||||
|  | @ -535,7 +535,7 @@ export default { | ||||||
|       "type": "object", |       "type": "object", | ||||||
|       "properties": { |       "properties": { | ||||||
|         "render": { |         "render": { | ||||||
|           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", |           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", | ||||||
|           "anyOf": [ |           "anyOf": [ | ||||||
|             { |             { | ||||||
|               "$ref": "#/definitions/Record<string,string>" |               "$ref": "#/definitions/Record<string,string>" | ||||||
|  | @ -1185,7 +1185,7 @@ export default { | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         "render": { |         "render": { | ||||||
|           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", |           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", | ||||||
|           "anyOf": [ |           "anyOf": [ | ||||||
|             { |             { | ||||||
|               "$ref": "#/definitions/Record<string,string>" |               "$ref": "#/definitions/Record<string,string>" | ||||||
|  | @ -1356,7 +1356,7 @@ export default { | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         "render": { |         "render": { | ||||||
|           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", |           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", | ||||||
|           "anyOf": [ |           "anyOf": [ | ||||||
|             { |             { | ||||||
|               "$ref": "#/definitions/Record<string,string>" |               "$ref": "#/definitions/Record<string,string>" | ||||||
|  |  | ||||||
|  | @ -437,7 +437,7 @@ | ||||||
|       "type": "object", |       "type": "object", | ||||||
|       "properties": { |       "properties": { | ||||||
|         "render": { |         "render": { | ||||||
|           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", |           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", | ||||||
|           "anyOf": [ |           "anyOf": [ | ||||||
|             { |             { | ||||||
|               "$ref": "#/definitions/Record<string,string>" |               "$ref": "#/definitions/Record<string,string>" | ||||||
|  | @ -1094,7 +1094,7 @@ | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         "render": { |         "render": { | ||||||
|           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", |           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", | ||||||
|           "anyOf": [ |           "anyOf": [ | ||||||
|             { |             { | ||||||
|               "$ref": "#/definitions/Record<string,string>" |               "$ref": "#/definitions/Record<string,string>" | ||||||
|  | @ -1266,7 +1266,7 @@ | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         "render": { |         "render": { | ||||||
|           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", |           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", | ||||||
|           "anyOf": [ |           "anyOf": [ | ||||||
|             { |             { | ||||||
|               "$ref": "#/definitions/Record<string,string>" |               "$ref": "#/definitions/Record<string,string>" | ||||||
|  | @ -1922,7 +1922,7 @@ | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         "tagRenderings": { |         "tagRenderings": { | ||||||
|           "description": "question: Which tagRenderings should be shown in the infobox?\n\nA tag rendering is a block that either shows the known value or asks a question.\n\nRefer to the class `TagRenderingConfigJson` to see the possibilities.\n\nNote that we can also use a string here - where the string refers to a tag rendering defined in `assets/questions/questions.json`,\nwhere a few very general questions are defined e.g. website, phone number, ...\nFurthermore, _all_ the questions of another layer can be reused with `otherlayer.*`\nIf you need only a single of the tagRenderings, use `otherlayer.tagrenderingId`\nIf one or more questions have a 'group' or 'label' set, select all the entries with the corresponding group or label with `otherlayer.*group`\nRemark: if a tagRendering is 'lent' from another layer, the 'source'-tags are copied and added as condition.\nIf they are not wanted, remove them with an override\n\nA special value is 'questions', which indicates the location of the questions box. If not specified, it'll be appended to the bottom of the featureInfobox.\n\nAt last, one can define a group of renderings where parts of all strings will be replaced by multiple other strings.\nThis is mainly create questions for a 'left' and a 'right' side of the road.\nThese will be grouped and questions will be asked together\n\ngroup: tagrenderings", |           "description": "question: Which tagRenderings should be shown in the infobox?\n\nA tag rendering is a block that either shows the known value or asks a question.\n\nRefer to the class `TagRenderingConfigJson` to see the possibilities.\n\nNote that we can also use a string here - where the string refers to a tag rendering defined in `assets/questions/questions.json`,\nwhere a few very general questions are defined e.g. website, phone number, ...\nFurthermore, _all_ the questions of another layer can be reused with `otherlayer.*`\nIf you need only a single of the tagRenderings, use `otherlayer.tagrenderingId`\nIf one or more questions have a 'group' or 'label' set, select all the entries with the corresponding group or label with `otherlayer.*group`\nRemark: if a tagRendering is 'lent' from another layer, the 'source'-tags are copied and added as condition.\nIf they are not wanted, remove them with an override\n\nA special value is 'questions', which indicates the location of the questions box. If not specified, it'll be appended to the bottom of the featureInfobox.\n\nAt last, one can define a group of renderings where parts of all strings will be replaced by multiple other strings.\nThis is mainly create questions for a 'left' and a 'right' side of the road.\nThese will be grouped and questions will be asked together\n\ntype: tagrendering[]\ngroup: tagrenderings", | ||||||
|           "type": "array", |           "type": "array", | ||||||
|           "items": { |           "items": { | ||||||
|             "anyOf": [ |             "anyOf": [ | ||||||
|  | @ -2332,7 +2332,7 @@ | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         "tagRenderings": { |         "tagRenderings": { | ||||||
|           "description": "question: Which tagRenderings should be shown in the infobox?\n\nA tag rendering is a block that either shows the known value or asks a question.\n\nRefer to the class `TagRenderingConfigJson` to see the possibilities.\n\nNote that we can also use a string here - where the string refers to a tag rendering defined in `assets/questions/questions.json`,\nwhere a few very general questions are defined e.g. website, phone number, ...\nFurthermore, _all_ the questions of another layer can be reused with `otherlayer.*`\nIf you need only a single of the tagRenderings, use `otherlayer.tagrenderingId`\nIf one or more questions have a 'group' or 'label' set, select all the entries with the corresponding group or label with `otherlayer.*group`\nRemark: if a tagRendering is 'lent' from another layer, the 'source'-tags are copied and added as condition.\nIf they are not wanted, remove them with an override\n\nA special value is 'questions', which indicates the location of the questions box. If not specified, it'll be appended to the bottom of the featureInfobox.\n\nAt last, one can define a group of renderings where parts of all strings will be replaced by multiple other strings.\nThis is mainly create questions for a 'left' and a 'right' side of the road.\nThese will be grouped and questions will be asked together\n\ngroup: tagrenderings", |           "description": "question: Which tagRenderings should be shown in the infobox?\n\nA tag rendering is a block that either shows the known value or asks a question.\n\nRefer to the class `TagRenderingConfigJson` to see the possibilities.\n\nNote that we can also use a string here - where the string refers to a tag rendering defined in `assets/questions/questions.json`,\nwhere a few very general questions are defined e.g. website, phone number, ...\nFurthermore, _all_ the questions of another layer can be reused with `otherlayer.*`\nIf you need only a single of the tagRenderings, use `otherlayer.tagrenderingId`\nIf one or more questions have a 'group' or 'label' set, select all the entries with the corresponding group or label with `otherlayer.*group`\nRemark: if a tagRendering is 'lent' from another layer, the 'source'-tags are copied and added as condition.\nIf they are not wanted, remove them with an override\n\nA special value is 'questions', which indicates the location of the questions box. If not specified, it'll be appended to the bottom of the featureInfobox.\n\nAt last, one can define a group of renderings where parts of all strings will be replaced by multiple other strings.\nThis is mainly create questions for a 'left' and a 'right' side of the road.\nThese will be grouped and questions will be asked together\n\ntype: tagrendering[]\ngroup: tagrenderings", | ||||||
|           "type": "array", |           "type": "array", | ||||||
|           "items": { |           "items": { | ||||||
|             "anyOf": [ |             "anyOf": [ | ||||||
|  |  | ||||||
|  | @ -432,7 +432,7 @@ export default { | ||||||
|       "type": "object", |       "type": "object", | ||||||
|       "properties": { |       "properties": { | ||||||
|         "render": { |         "render": { | ||||||
|           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", |           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", | ||||||
|           "anyOf": [ |           "anyOf": [ | ||||||
|             { |             { | ||||||
|               "$ref": "#/definitions/Record<string,string>" |               "$ref": "#/definitions/Record<string,string>" | ||||||
|  | @ -1082,7 +1082,7 @@ export default { | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         "render": { |         "render": { | ||||||
|           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", |           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", | ||||||
|           "anyOf": [ |           "anyOf": [ | ||||||
|             { |             { | ||||||
|               "$ref": "#/definitions/Record<string,string>" |               "$ref": "#/definitions/Record<string,string>" | ||||||
|  | @ -1253,7 +1253,7 @@ export default { | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         "render": { |         "render": { | ||||||
|           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", |           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", | ||||||
|           "anyOf": [ |           "anyOf": [ | ||||||
|             { |             { | ||||||
|               "$ref": "#/definitions/Record<string,string>" |               "$ref": "#/definitions/Record<string,string>" | ||||||
|  | @ -1901,7 +1901,7 @@ export default { | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         "tagRenderings": { |         "tagRenderings": { | ||||||
|           "description": "question: Which tagRenderings should be shown in the infobox?\n\nA tag rendering is a block that either shows the known value or asks a question.\n\nRefer to the class `TagRenderingConfigJson` to see the possibilities.\n\nNote that we can also use a string here - where the string refers to a tag rendering defined in `assets/questions/questions.json`,\nwhere a few very general questions are defined e.g. website, phone number, ...\nFurthermore, _all_ the questions of another layer can be reused with `otherlayer.*`\nIf you need only a single of the tagRenderings, use `otherlayer.tagrenderingId`\nIf one or more questions have a 'group' or 'label' set, select all the entries with the corresponding group or label with `otherlayer.*group`\nRemark: if a tagRendering is 'lent' from another layer, the 'source'-tags are copied and added as condition.\nIf they are not wanted, remove them with an override\n\nA special value is 'questions', which indicates the location of the questions box. If not specified, it'll be appended to the bottom of the featureInfobox.\n\nAt last, one can define a group of renderings where parts of all strings will be replaced by multiple other strings.\nThis is mainly create questions for a 'left' and a 'right' side of the road.\nThese will be grouped and questions will be asked together\n\ngroup: tagrenderings", |           "description": "question: Which tagRenderings should be shown in the infobox?\n\nA tag rendering is a block that either shows the known value or asks a question.\n\nRefer to the class `TagRenderingConfigJson` to see the possibilities.\n\nNote that we can also use a string here - where the string refers to a tag rendering defined in `assets/questions/questions.json`,\nwhere a few very general questions are defined e.g. website, phone number, ...\nFurthermore, _all_ the questions of another layer can be reused with `otherlayer.*`\nIf you need only a single of the tagRenderings, use `otherlayer.tagrenderingId`\nIf one or more questions have a 'group' or 'label' set, select all the entries with the corresponding group or label with `otherlayer.*group`\nRemark: if a tagRendering is 'lent' from another layer, the 'source'-tags are copied and added as condition.\nIf they are not wanted, remove them with an override\n\nA special value is 'questions', which indicates the location of the questions box. If not specified, it'll be appended to the bottom of the featureInfobox.\n\nAt last, one can define a group of renderings where parts of all strings will be replaced by multiple other strings.\nThis is mainly create questions for a 'left' and a 'right' side of the road.\nThese will be grouped and questions will be asked together\n\ntype: tagrendering[]\ngroup: tagrenderings", | ||||||
|           "type": "array", |           "type": "array", | ||||||
|           "items": { |           "items": { | ||||||
|             "anyOf": [ |             "anyOf": [ | ||||||
|  | @ -2310,7 +2310,7 @@ export default { | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|         "tagRenderings": { |         "tagRenderings": { | ||||||
|           "description": "question: Which tagRenderings should be shown in the infobox?\n\nA tag rendering is a block that either shows the known value or asks a question.\n\nRefer to the class `TagRenderingConfigJson` to see the possibilities.\n\nNote that we can also use a string here - where the string refers to a tag rendering defined in `assets/questions/questions.json`,\nwhere a few very general questions are defined e.g. website, phone number, ...\nFurthermore, _all_ the questions of another layer can be reused with `otherlayer.*`\nIf you need only a single of the tagRenderings, use `otherlayer.tagrenderingId`\nIf one or more questions have a 'group' or 'label' set, select all the entries with the corresponding group or label with `otherlayer.*group`\nRemark: if a tagRendering is 'lent' from another layer, the 'source'-tags are copied and added as condition.\nIf they are not wanted, remove them with an override\n\nA special value is 'questions', which indicates the location of the questions box. If not specified, it'll be appended to the bottom of the featureInfobox.\n\nAt last, one can define a group of renderings where parts of all strings will be replaced by multiple other strings.\nThis is mainly create questions for a 'left' and a 'right' side of the road.\nThese will be grouped and questions will be asked together\n\ngroup: tagrenderings", |           "description": "question: Which tagRenderings should be shown in the infobox?\n\nA tag rendering is a block that either shows the known value or asks a question.\n\nRefer to the class `TagRenderingConfigJson` to see the possibilities.\n\nNote that we can also use a string here - where the string refers to a tag rendering defined in `assets/questions/questions.json`,\nwhere a few very general questions are defined e.g. website, phone number, ...\nFurthermore, _all_ the questions of another layer can be reused with `otherlayer.*`\nIf you need only a single of the tagRenderings, use `otherlayer.tagrenderingId`\nIf one or more questions have a 'group' or 'label' set, select all the entries with the corresponding group or label with `otherlayer.*group`\nRemark: if a tagRendering is 'lent' from another layer, the 'source'-tags are copied and added as condition.\nIf they are not wanted, remove them with an override\n\nA special value is 'questions', which indicates the location of the questions box. If not specified, it'll be appended to the bottom of the featureInfobox.\n\nAt last, one can define a group of renderings where parts of all strings will be replaced by multiple other strings.\nThis is mainly create questions for a 'left' and a 'right' side of the road.\nThese will be grouped and questions will be asked together\n\ntype: tagrendering[]\ngroup: tagrenderings", | ||||||
|           "type": "array", |           "type": "array", | ||||||
|           "items": { |           "items": { | ||||||
|             "anyOf": [ |             "anyOf": [ | ||||||
|  |  | ||||||
|  | @ -205,7 +205,7 @@ | ||||||
|       "type": "object", |       "type": "object", | ||||||
|       "properties": { |       "properties": { | ||||||
|         "render": { |         "render": { | ||||||
|           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", |           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", | ||||||
|           "anyOf": [ |           "anyOf": [ | ||||||
|             { |             { | ||||||
|               "$ref": "#/definitions/Record<string,string>" |               "$ref": "#/definitions/Record<string,string>" | ||||||
|  |  | ||||||
|  | @ -200,7 +200,7 @@ export default { | ||||||
|       "type": "object", |       "type": "object", | ||||||
|       "properties": { |       "properties": { | ||||||
|         "render": { |         "render": { | ||||||
|           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", |           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", | ||||||
|           "anyOf": [ |           "anyOf": [ | ||||||
|             { |             { | ||||||
|               "$ref": "#/definitions/Record<string,string>" |               "$ref": "#/definitions/Record<string,string>" | ||||||
|  |  | ||||||
|  | @ -238,7 +238,7 @@ | ||||||
|       "type": "object", |       "type": "object", | ||||||
|       "properties": { |       "properties": { | ||||||
|         "render": { |         "render": { | ||||||
|           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", |           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", | ||||||
|           "anyOf": [ |           "anyOf": [ | ||||||
|             { |             { | ||||||
|               "$ref": "#/definitions/Record<string,string>" |               "$ref": "#/definitions/Record<string,string>" | ||||||
|  |  | ||||||
|  | @ -233,7 +233,7 @@ export default { | ||||||
|       "type": "object", |       "type": "object", | ||||||
|       "properties": { |       "properties": { | ||||||
|         "render": { |         "render": { | ||||||
|           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", |           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", | ||||||
|           "anyOf": [ |           "anyOf": [ | ||||||
|             { |             { | ||||||
|               "$ref": "#/definitions/Record<string,string>" |               "$ref": "#/definitions/Record<string,string>" | ||||||
|  |  | ||||||
|  | @ -303,7 +303,7 @@ | ||||||
|       "type": "object", |       "type": "object", | ||||||
|       "properties": { |       "properties": { | ||||||
|         "render": { |         "render": { | ||||||
|           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", |           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", | ||||||
|           "anyOf": [ |           "anyOf": [ | ||||||
|             { |             { | ||||||
|               "$ref": "#/definitions/Record<string,string>" |               "$ref": "#/definitions/Record<string,string>" | ||||||
|  |  | ||||||
|  | @ -298,7 +298,7 @@ export default { | ||||||
|       "type": "object", |       "type": "object", | ||||||
|       "properties": { |       "properties": { | ||||||
|         "render": { |         "render": { | ||||||
|           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", |           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", | ||||||
|           "anyOf": [ |           "anyOf": [ | ||||||
|             { |             { | ||||||
|               "$ref": "#/definitions/Record<string,string>" |               "$ref": "#/definitions/Record<string,string>" | ||||||
|  |  | ||||||
|  | @ -86,7 +86,7 @@ | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "render": { |     "render": { | ||||||
|       "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", |       "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", | ||||||
|       "anyOf": [ |       "anyOf": [ | ||||||
|         { |         { | ||||||
|           "$ref": "#/definitions/Record<string,string>" |           "$ref": "#/definitions/Record<string,string>" | ||||||
|  | @ -302,7 +302,7 @@ | ||||||
|       "type": "object", |       "type": "object", | ||||||
|       "properties": { |       "properties": { | ||||||
|         "render": { |         "render": { | ||||||
|           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", |           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", | ||||||
|           "anyOf": [ |           "anyOf": [ | ||||||
|             { |             { | ||||||
|               "$ref": "#/definitions/Record<string,string>" |               "$ref": "#/definitions/Record<string,string>" | ||||||
|  |  | ||||||
|  | @ -86,7 +86,7 @@ export default { | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "render": { |     "render": { | ||||||
|       "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", |       "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", | ||||||
|       "anyOf": [ |       "anyOf": [ | ||||||
|         { |         { | ||||||
|           "$ref": "#/definitions/Record<string,string>" |           "$ref": "#/definitions/Record<string,string>" | ||||||
|  | @ -297,7 +297,7 @@ export default { | ||||||
|       "type": "object", |       "type": "object", | ||||||
|       "properties": { |       "properties": { | ||||||
|         "render": { |         "render": { | ||||||
|           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", |           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", | ||||||
|           "anyOf": [ |           "anyOf": [ | ||||||
|             { |             { | ||||||
|               "$ref": "#/definitions/Record<string,string>" |               "$ref": "#/definitions/Record<string,string>" | ||||||
|  |  | ||||||
|  | @ -165,7 +165,7 @@ | ||||||
|       "type": "object", |       "type": "object", | ||||||
|       "properties": { |       "properties": { | ||||||
|         "render": { |         "render": { | ||||||
|           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", |           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", | ||||||
|           "anyOf": [ |           "anyOf": [ | ||||||
|             { |             { | ||||||
|               "$ref": "#/definitions/Record<string,string>" |               "$ref": "#/definitions/Record<string,string>" | ||||||
|  |  | ||||||
|  | @ -160,7 +160,7 @@ export default { | ||||||
|       "type": "object", |       "type": "object", | ||||||
|       "properties": { |       "properties": { | ||||||
|         "render": { |         "render": { | ||||||
|           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", |           "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", | ||||||
|           "anyOf": [ |           "anyOf": [ | ||||||
|             { |             { | ||||||
|               "$ref": "#/definitions/Record<string,string>" |               "$ref": "#/definitions/Record<string,string>" | ||||||
|  |  | ||||||
|  | @ -3,7 +3,7 @@ | ||||||
|   "type": "object", |   "type": "object", | ||||||
|   "properties": { |   "properties": { | ||||||
|     "render": { |     "render": { | ||||||
|       "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", |       "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", | ||||||
|       "anyOf": [ |       "anyOf": [ | ||||||
|         { |         { | ||||||
|           "$ref": "#/definitions/Record<string,string>" |           "$ref": "#/definitions/Record<string,string>" | ||||||
|  |  | ||||||
|  | @ -3,7 +3,7 @@ export default { | ||||||
|   "type": "object", |   "type": "object", | ||||||
|   "properties": { |   "properties": { | ||||||
|     "render": { |     "render": { | ||||||
|       "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", |       "description": "question: What text should be rendered?\n\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`\ntype: rendered", | ||||||
|       "anyOf": [ |       "anyOf": [ | ||||||
|         { |         { | ||||||
|           "$ref": "#/definitions/Record<string,string>" |           "$ref": "#/definitions/Record<string,string>" | ||||||
|  |  | ||||||
|  | @ -393,6 +393,7 @@ export interface LayerConfigJson { | ||||||
|      * This is mainly create questions for a 'left' and a 'right' side of the road. |      * This is mainly create questions for a 'left' and a 'right' side of the road. | ||||||
|      * These will be grouped and questions will be asked together |      * These will be grouped and questions will be asked together | ||||||
|      * |      * | ||||||
|  |      * type: tagrendering[] | ||||||
|      * group: tagrenderings |      * group: tagrenderings | ||||||
|      * |      * | ||||||
|      */ |      */ | ||||||
|  |  | ||||||
|  | @ -10,7 +10,7 @@ export interface TagRenderingConfigJson { | ||||||
|      * question: What text should be rendered? |      * question: What text should be rendered? | ||||||
|      * |      * | ||||||
|      * This piece of text will be shown in the infobox. |      * This piece of text will be shown in the infobox. | ||||||
|      * Note that "{key}"-parts are substituted by the corresponding values of the element. |      * Note that "&LBRACEkey&RBRACE"-parts are substituted by the corresponding values of the element. | ||||||
|      * |      * | ||||||
|      * This text will be shown if: |      * This text will be shown if: | ||||||
|      * - there is no mapping which matches (or there are no matches) |      * - there is no mapping which matches (or there are no matches) | ||||||
|  |  | ||||||
|  | @ -233,6 +233,10 @@ export default class TagRenderingConfig { | ||||||
|                 if (txt.indexOf("{canonical(" + this.freeform.key + ")") >= 0) { |                 if (txt.indexOf("{canonical(" + this.freeform.key + ")") >= 0) { | ||||||
|                     continue |                     continue | ||||||
|                 } |                 } | ||||||
|  | 
 | ||||||
|  |                 if (txt.indexOf("{translated(" + this.freeform.key + ")") >= 0) { | ||||||
|  |                     continue | ||||||
|  |                 } | ||||||
|                 if ( |                 if ( | ||||||
|                     this.freeform.type === "opening_hours" && |                     this.freeform.type === "opening_hours" && | ||||||
|                     txt.indexOf("{opening_hours_table(") >= 0 |                     txt.indexOf("{opening_hours_table(") >= 0 | ||||||
|  |  | ||||||
|  | @ -61,6 +61,8 @@ export default class InputHelpers { | ||||||
|         translation: (value) => new SvelteUIElement(TranslationInput, { value }), |         translation: (value) => new SvelteUIElement(TranslationInput, { value }), | ||||||
|     } as const |     } as const | ||||||
| 
 | 
 | ||||||
|  |     public static hideInputField : string[] = ["translation"] | ||||||
|  | 
 | ||||||
|     /** |     /** | ||||||
|      * Constructs a mapProperties-object for the given properties. |      * Constructs a mapProperties-object for the given properties. | ||||||
|      * Assumes that the first helper-args contains the desired zoom-level |      * Assumes that the first helper-args contains the desired zoom-level | ||||||
|  |  | ||||||
|  | @ -8,6 +8,7 @@ | ||||||
|   import InputHelper from "../../InputElement/InputHelper.svelte" |   import InputHelper from "../../InputElement/InputHelper.svelte" | ||||||
|   import type { Feature } from "geojson" |   import type { Feature } from "geojson" | ||||||
|   import { Unit } from "../../../Models/Unit" |   import { Unit } from "../../../Models/Unit" | ||||||
|  |   import InputHelpers from "../../InputElement/InputHelpers"; | ||||||
| 
 | 
 | ||||||
|   export let value: UIEventSource<string> |   export let value: UIEventSource<string> | ||||||
|   export let config: TagRenderingConfig |   export let config: TagRenderingConfig | ||||||
|  | @ -52,7 +53,7 @@ | ||||||
|         {value} |         {value} | ||||||
|       /> |       /> | ||||||
|     </Inline> |     </Inline> | ||||||
|   {:else} |   {:else if InputHelpers.hideInputField.indexOf(config.freeform.type) < 0} | ||||||
|     <ValidatedInput |     <ValidatedInput | ||||||
|       {feedback} |       {feedback} | ||||||
|       {getCountry} |       {getCountry} | ||||||
|  |  | ||||||
|  | @ -1344,6 +1344,36 @@ export default class SpecialVisualizations { | ||||||
|                     ) |                     ) | ||||||
|                 }, |                 }, | ||||||
|             }, |             }, | ||||||
|  |             { | ||||||
|  |                 funcName: "translated", | ||||||
|  |                 docs: "If the given key can be interpreted as a JSON, only show the key containing the current language (or 'en'). This specialRendering is meant to be used by MapComplete studio and is not useful in map themes", | ||||||
|  |                 args: [ | ||||||
|  |                     { | ||||||
|  |                         name: "key", | ||||||
|  |                         doc: "The attribute to interpret as json", | ||||||
|  |                         defaultValue: "value", | ||||||
|  |                     }, | ||||||
|  |                 ], | ||||||
|  |                 constr( | ||||||
|  |                     state: SpecialVisualizationState, | ||||||
|  |                     tagSource: UIEventSource<Record<string, string>>, | ||||||
|  |                     argument: string[], | ||||||
|  |                     feature: Feature, | ||||||
|  |                     layer: LayerConfig | ||||||
|  |                 ): BaseUIElement { | ||||||
|  |                     return new VariableUiElement( | ||||||
|  |                         tagSource.map((tags) => { | ||||||
|  |                             const v = tags[argument[0] ?? "value"] | ||||||
|  |                             try { | ||||||
|  |                                 const tr = JSON.parse(v) | ||||||
|  |                                 return new Translation(tr).SetClass("font-bold") | ||||||
|  |                             } catch (e) { | ||||||
|  |                                 return v | ||||||
|  |                             } | ||||||
|  |                         }) | ||||||
|  |                     ) | ||||||
|  |                 }, | ||||||
|  |             }, | ||||||
|         ] |         ] | ||||||
| 
 | 
 | ||||||
|         specialVisualizations.push(new AutoApplyButton(specialVisualizations)) |         specialVisualizations.push(new AutoApplyButton(specialVisualizations)) | ||||||
|  |  | ||||||
|  | @ -1,7 +1,7 @@ | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
| 
 | 
 | ||||||
|     import EditLayerState from "./EditLayerState"; |     import EditLayerState from "./EditLayerState"; | ||||||
|     import layerSchemaRaw from "../../../assets/layerconfigmeta.json" |     import layerSchemaRaw from "../../assets/layerconfigmeta.json" | ||||||
|     import Region from "./Region.svelte"; |     import Region from "./Region.svelte"; | ||||||
|     import TabbedGroup from "../Base/TabbedGroup.svelte"; |     import TabbedGroup from "../Base/TabbedGroup.svelte"; | ||||||
|     import {UIEventSource} from "../../Logic/UIEventSource"; |     import {UIEventSource} from "../../Logic/UIEventSource"; | ||||||
|  | @ -16,7 +16,7 @@ | ||||||
|     /** |     /** | ||||||
|      * Blacklist for the general area tab |      * Blacklist for the general area tab | ||||||
|      */ |      */ | ||||||
|     const regionBlacklist = ["hidden",undefined,"infobox", "tagrenderings","maprendering", "editing"] |     const regionBlacklist = ["hidden",undefined,"infobox", "tagrenderings","maprendering", "editing", "title"] | ||||||
|     const allNames =  Utils.Dedup(layerSchema.map(meta => meta.hints.group)) |     const allNames =  Utils.Dedup(layerSchema.map(meta => meta.hints.group)) | ||||||
| 
 | 
 | ||||||
|     const perRegion: Record<string, ConfigMeta[]> = {} |     const perRegion: Record<string, ConfigMeta[]> = {} | ||||||
|  | @ -40,20 +40,26 @@ | ||||||
| <TabbedGroup tab={new UIEventSource(1)}> | <TabbedGroup tab={new UIEventSource(1)}> | ||||||
|     <div slot="title0">General properties</div> |     <div slot="title0">General properties</div> | ||||||
|     <div class="flex flex-col" slot="content0"> |     <div class="flex flex-col" slot="content0"> | ||||||
|  |         <!-- | ||||||
|         {#each baselayerRegions as region} |         {#each baselayerRegions as region} | ||||||
|             <Region {state} configs={perRegion[region]} title={region}/> |             <Region {state} configs={perRegion[region]} title={region}/> | ||||||
|         {/each} |         {/each} | ||||||
|          |          | ||||||
|         {#each leftoverRegions as region} |         {#each leftoverRegions as region} | ||||||
|             <Region {state} configs={perRegion[region]} title={region}/> |             <Region {state} configs={perRegion[region]} title={region}/> | ||||||
|         {/each} |         {/each}--> | ||||||
|     </div> |     </div> | ||||||
| 
 | 
 | ||||||
|     <div slot="title1">Information panel (questions and answers)</div> |     <div slot="title1">Information panel (questions and answers)</div> | ||||||
|     <div slot="content1"> |     <div slot="content1"> | ||||||
|         <Region {state} configs={perRegion["title"]} title="Title"/> |         <Region {state} configs={perRegion["tagrenderings"]} title="Popup contents"> | ||||||
|         <Region {state} configs={perRegion["tagrenderings"]} title="Infobox"/> |             <div slot="description"> | ||||||
|         <Region {state} configs={perRegion["editing"]} title="Other editing elements"/> |                 The bulk of the popup content | ||||||
|  |             </div> | ||||||
|  |         </Region> | ||||||
|  |         <!-- | ||||||
|  |         <Region {state} configs={perRegion["title"]} title="Popup title"/> | ||||||
|  |         <Region {state} configs={perRegion["editing"]} title="Other editing elements"/>--> | ||||||
|     </div> |     </div> | ||||||
| 
 | 
 | ||||||
|     <div slot="title2">Rendering on the map</div> |     <div slot="title2">Rendering on the map</div> | ||||||
|  |  | ||||||
|  | @ -22,7 +22,7 @@ export default class EditLayerState { | ||||||
|             featureSwitchIsDebugging: new UIEventSource<boolean>(true), |             featureSwitchIsDebugging: new UIEventSource<boolean>(true), | ||||||
|         } |         } | ||||||
|         this.configuration.addCallback((config) => { |         this.configuration.addCallback((config) => { | ||||||
|             console.log("Current config is", Utils.Clone(config)) |             // console.log("Current config is", Utils.Clone(config))
 | ||||||
|         }) |         }) | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -14,7 +14,7 @@ export let title: string | ||||||
| {#if title} | {#if title} | ||||||
|     <h3>{title}</h3> |     <h3>{title}</h3> | ||||||
|     <div class="pl-2 border border-black flex flex-col gap-y-1"> |     <div class="pl-2 border border-black flex flex-col gap-y-1"> | ||||||
| 
 |         <slot name="description"/> | ||||||
|         {#each configs as config} |         {#each configs as config} | ||||||
|             <SchemaBasedInput {state} path={config.path} schema={config}/> |             <SchemaBasedInput {state} path={config.path} schema={config}/> | ||||||
|         {/each} |         {/each} | ||||||
|  |  | ||||||
|  | @ -1,64 +1,68 @@ | ||||||
| <script lang="ts"> | <script lang="ts"> | ||||||
|   import EditLayerState from "./EditLayerState"; |   import EditLayerState from "./EditLayerState"; | ||||||
|     import type {ConfigMeta} from "./configMeta"; |   import type { ConfigMeta } from "./configMeta"; | ||||||
|     import {UIEventSource} from "../../Logic/UIEventSource"; |   import { UIEventSource } from "../../Logic/UIEventSource"; | ||||||
|   import SchemaBasedInput from "./SchemaBasedInput.svelte"; |   import SchemaBasedInput from "./SchemaBasedInput.svelte"; | ||||||
|   import SchemaBasedField from "./SchemaBasedField.svelte"; |   import SchemaBasedField from "./SchemaBasedField.svelte"; | ||||||
|     import {TrashIcon} from "@babeard/svelte-heroicons/mini"; |   import { TrashIcon } from "@babeard/svelte-heroicons/mini"; | ||||||
|  |   import TagRenderingInput from "./TagRenderingInput.svelte"; | ||||||
| 
 | 
 | ||||||
|     export let state: EditLayerState |   export let state: EditLayerState; | ||||||
|     export let schema: ConfigMeta |   export let schema: ConfigMeta; | ||||||
| 
 | 
 | ||||||
|     let title = schema.path.at(-1) |   let title = schema.path.at(-1); | ||||||
|     let singular = title |   let singular = title; | ||||||
|   if (title.endsWith("s")) { |   if (title.endsWith("s")) { | ||||||
|         singular = title.slice(0, title.length - 1) |     singular = title.slice(0, title.length - 1); | ||||||
|   } |   } | ||||||
|     let article = "a" |   let article = "a"; | ||||||
|   if (singular.match(/^[aeoui]/)) { |   if (singular.match(/^[aeoui]/)) { | ||||||
|         article = "an" |     article = "an"; | ||||||
|   } |   } | ||||||
|     export let path: (string | number)[] = [] |   export let path: (string | number)[] = []; | ||||||
| 
 | 
 | ||||||
|     const subparts = state.getSchemaStartingWith(schema.path) |   const subparts = state.getSchemaStartingWith(schema.path); | ||||||
| 
 | 
 | ||||||
|     let createdItems = 0 |  | ||||||
|   /** |   /** | ||||||
|      * Keeps track of the items. |    * Store the _indices_ | ||||||
|      * We keep a single string (stringified 'createdItems') to make sure the order is correct |  | ||||||
|    */ |    */ | ||||||
|     export let values: UIEventSource<number[]> = new UIEventSource<number[]>([]) |   export let values: UIEventSource<number[]> = new UIEventSource<number[]>([]); | ||||||
| 
 | 
 | ||||||
|     const currentValue = <[]>state.getCurrentValueFor(path) |   const currentValue = <[]>state.getCurrentValueFor(path); | ||||||
|   if (currentValue) { |   if (currentValue) { | ||||||
|     if (!Array.isArray(currentValue)) { |     if (!Array.isArray(currentValue)) { | ||||||
|             console.error("SchemaBaseArray for path", path, "expected an array as initial value, but got a", typeof currentValue, currentValue) |       console.error("SchemaBaseArray for path", path, "expected an array as initial value, but got a", typeof currentValue, currentValue); | ||||||
|     } else { |     } else { | ||||||
|             values.setData(currentValue.map((_, i) => i)) |       values.setData(currentValue.map((_, i) => i)); | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |   let createdItems = values.data.length; | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
|   function createItem() { |   function createItem() { | ||||||
|         values.data.push(createdItems) |     values.data.push(createdItems); | ||||||
|         createdItems++ |     createdItems++; | ||||||
|         values.ping() |     values.ping(); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   function fusePath(i: number, subpartPath: string[]): (string | number)[] { |   function fusePath(i: number, subpartPath: string[]): (string | number)[] { | ||||||
|         const newPath = [...path, i] |     const newPath = [...path, i]; | ||||||
|         const toAdd = [...subpartPath] |     const toAdd = [...subpartPath]; | ||||||
|     for (const part of path) { |     for (const part of path) { | ||||||
|       if (toAdd[0] === part) { |       if (toAdd[0] === part) { | ||||||
|                 toAdd.splice(0, 1) |         toAdd.splice(0, 1); | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|         newPath.push(...toAdd) |     newPath.push(...toAdd); | ||||||
|         return newPath |     return newPath; | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   function del(value) { | ||||||
|  |     values.data.splice(values.data.indexOf(value)); | ||||||
|  |     values.ping(); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
| </script> | </script> | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| <div class="pl-2"> | <div class="pl-2"> | ||||||
|   <h3>{schema.path.at(-1)}</h3> |   <h3>{schema.path.at(-1)}</h3> | ||||||
| 
 | 
 | ||||||
|  | @ -73,20 +77,31 @@ | ||||||
|   {:else if subparts.length === 0} |   {:else if subparts.length === 0} | ||||||
|     <!-- We need an array of values, so we use the typehint of the _parent_ element as field --> |     <!-- We need an array of values, so we use the typehint of the _parent_ element as field --> | ||||||
|     {#each $values as value (value)} |     {#each $values as value (value)} | ||||||
|             <SchemaBasedField {state} {schema} path={[...path, value]}/> |       <div class="flex w-full"> | ||||||
|  |         <SchemaBasedField {state} {schema} path={[...path, value]} /> | ||||||
|  |         <button class="border-black border rounded-full p-1 w-fit h-fit" | ||||||
|  |                 on:click={() => {del(value)}}> | ||||||
|  |           <TrashIcon class="w-4 h-4" /> | ||||||
|  |         </button> | ||||||
|  |       </div> | ||||||
|     {/each} |     {/each} | ||||||
|   {:else} |   {:else} | ||||||
|     {#each $values as value (value)} |     {#each $values as value (value)} | ||||||
|       <div class="flex justify-between items-center"> |       <div class="flex justify-between items-center"> | ||||||
|         <h3 class="m-0">{singular} {value}</h3> |         <h3 class="m-0">{singular} {value}</h3> | ||||||
|                 <button class="border-black border rounded-full p-1 w-fit h-fit" on:click={() => {values.data.splice(values.data.indexOf(value)); values.ping()}}> |         <button class="border-black border rounded-full p-1 w-fit h-fit" | ||||||
|                     <TrashIcon class="w-4 h-4"/> |                 on:click={() => {del(value)}}> | ||||||
|  |           <TrashIcon class="w-4 h-4" /> | ||||||
|         </button> |         </button> | ||||||
|       </div> |       </div> | ||||||
|       <div class="border border-black"> |       <div class="border border-black"> | ||||||
|  |         {#if path.length === 1 && path[0] === "tagRenderings"} | ||||||
|  |           <TagRenderingInput path={path.concat(value)} {state} {schema}/> | ||||||
|  |         {:else} | ||||||
|           {#each subparts as subpart} |           {#each subparts as subpart} | ||||||
|                     <SchemaBasedInput {state} path={fusePath(value, subpart.path)} schema={subpart}/> |             <SchemaBasedInput {state} path={fusePath(value, subpart.path)} schema={subpart} /> | ||||||
|           {/each} |           {/each} | ||||||
|  |         {/if} | ||||||
|       </div> |       </div> | ||||||
|     {/each} |     {/each} | ||||||
|   {/if} |   {/if} | ||||||
|  |  | ||||||
|  | @ -25,7 +25,7 @@ | ||||||
| 
 | 
 | ||||||
|     const configJson: QuestionableTagRenderingConfigJson = { |     const configJson: QuestionableTagRenderingConfigJson = { | ||||||
|         id: path.join("_"), |         id: path.join("_"), | ||||||
|         render: schema.type === "boolean" ? undefined : ((schema.hints.inline ?? schema.path.at(-1) )+ ": <b>{value}</b>"), |         render: schema.type === "boolean" ? undefined : ((schema.hints.inline ?? schema.path.at(-1) )+ ": <b>{translated(value)}</b>"), | ||||||
|         question: schema.hints.question, |         question: schema.hints.question, | ||||||
|         questionHint: nmd(schema.description), |         questionHint: nmd(schema.description), | ||||||
|         freeform: schema.type === "boolean" ? undefined : { |         freeform: schema.type === "boolean" ? undefined : { | ||||||
|  | @ -76,12 +76,10 @@ | ||||||
|         err = path.join(".") + " " + e |         err = path.join(".") + " " + e | ||||||
|     } |     } | ||||||
|     let startValue = state.getCurrentValueFor(path) |     let startValue = state.getCurrentValueFor(path) | ||||||
|     console.log("StartValue for", path.join("."), " is", startValue) |  | ||||||
|     if (typeof startValue !== "string") { |     if (typeof startValue !== "string") { | ||||||
|         startValue = JSON.stringify(startValue) |         startValue = JSON.stringify(startValue) | ||||||
|     } |     } | ||||||
|     const tags = new UIEventSource<Record<string, string>>({value: startValue ?? ""}) |     const tags = new UIEventSource<Record<string, string>>({value: startValue ?? ""}) | ||||||
|     tags.addCallbackAndRunD(tgs => console.log(">>> tgs for",path.join("."),"are",tgs )) |  | ||||||
|     onDestroy(state.register(path, tags.map(tgs => { |     onDestroy(state.register(path, tags.map(tgs => { | ||||||
|         const v = tgs["value"]; |         const v = tgs["value"]; | ||||||
|         if (schema.type === "boolan") { |         if (schema.type === "boolan") { | ||||||
|  | @ -90,7 +88,6 @@ | ||||||
|         if (schema.type === "number") { |         if (schema.type === "number") { | ||||||
|             return Number(v) |             return Number(v) | ||||||
|         } |         } | ||||||
|         console.log(schema, v) |  | ||||||
|         if(isTranslation) { |         if(isTranslation) { | ||||||
|             if(v === ""){ |             if(v === ""){ | ||||||
|                 return {} |                 return {} | ||||||
|  | @ -104,7 +101,7 @@ | ||||||
| {#if err !== undefined} | {#if err !== undefined} | ||||||
|     <span class="alert">{err}</span> |     <span class="alert">{err}</span> | ||||||
| {:else} | {:else} | ||||||
|     <div> |     <div class="w-full"> | ||||||
|         <TagRenderingEditable {config} selectedElement={undefined} showQuestionIfUnknown={true} {state} {tags}/> |         <TagRenderingEditable {config} selectedElement={undefined} showQuestionIfUnknown={true} {state} {tags}/> | ||||||
|     </div> |     </div> | ||||||
| {/if} | {/if} | ||||||
|  |  | ||||||
|  | @ -12,9 +12,13 @@ | ||||||
|     export let path: (string | number)[] = [] |     export let path: (string | number)[] = [] | ||||||
| 
 | 
 | ||||||
|      |      | ||||||
| </script> |     console.log("Constructing", path,"with schema", schema) | ||||||
| 
 | 
 | ||||||
| {#if schema.type === "array"} | </script> | ||||||
|  | {#if schema.hints.typehint === "tagrendering[]"} | ||||||
|  |     <!-- We cheat a bit here by matching this 'magical' type... --> | ||||||
|  |     <SchemaBasedArray {path} {state} {schema}/> | ||||||
|  | {:else if schema.type === "array"} | ||||||
|     <SchemaBasedArray {path} {state} {schema}/> |     <SchemaBasedArray {path} {state} {schema}/> | ||||||
| {:else if schema.hints.typehint === "tag"} | {:else if schema.hints.typehint === "tag"} | ||||||
|     <RegisteredTagInput {state} {path} {schema}/> |     <RegisteredTagInput {state} {path} {schema}/> | ||||||
|  |  | ||||||
							
								
								
									
										61
									
								
								src/UI/Studio/TagRenderingInput.svelte
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										61
									
								
								src/UI/Studio/TagRenderingInput.svelte
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,61 @@ | ||||||
|  | <script lang="ts">/** | ||||||
|  |  * Little helper class to deal with choosing a builtin tagRendering or defining one yourself. | ||||||
|  |  * Breaks the ideology that everything should be schema based | ||||||
|  |  */ | ||||||
|  | import EditLayerState from "./EditLayerState"; | ||||||
|  | import type { ConfigMeta } from "./configMeta"; | ||||||
|  | import type { | ||||||
|  |   MappingConfigJson, | ||||||
|  |   QuestionableTagRenderingConfigJson | ||||||
|  | } from "../../Models/ThemeConfig/Json/QuestionableTagRenderingConfigJson"; | ||||||
|  | import TagRenderingConfig from "../../Models/ThemeConfig/TagRenderingConfig"; | ||||||
|  | import TagRenderingEditable from "../Popup/TagRendering/TagRenderingEditable.svelte"; | ||||||
|  | import { UIEventSource } from "../../Logic/UIEventSource"; | ||||||
|  | import * as questions from "../../assets/generated/layers/questions.json"; | ||||||
|  | 
 | ||||||
|  | export let state: EditLayerState; | ||||||
|  | export let schema: ConfigMeta; | ||||||
|  | export let path: (string | number)[]; | ||||||
|  | 
 | ||||||
|  | let value = state.getCurrentValueFor(path); | ||||||
|  | 
 | ||||||
|  | let mappings: MappingConfigJson[] = []; | ||||||
|  | for (const tr of questions.tagRenderings) { | ||||||
|  |   let description = tr["description"] ?? tr["question"] ?? "No description available"; | ||||||
|  |   description = description["en"] ?? description; | ||||||
|  |   mappings.push({ | ||||||
|  |     if: "value=" + tr["id"], | ||||||
|  |     then: { | ||||||
|  |       "en": "Builtin <b>" + tr["id"] + "</b> <div class='subtle'>" + description + "</div>" | ||||||
|  |     } | ||||||
|  |   }); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | const configBuiltin = new TagRenderingConfig(<QuestionableTagRenderingConfigJson>{ | ||||||
|  |   question: "Which builtin element should be shown?", | ||||||
|  |   mappings | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | const configOverride = <QuestionableTagRenderingConfigJson>{ | ||||||
|  |   render: "This is a builtin question which changes some properties. Editing those is not possible within MapComplete Studio" | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | const tags = new UIEventSource({ value }); | ||||||
|  | 
 | ||||||
|  | tags.addCallbackAndRunD(tgs => { | ||||||
|  |   state.setValueAt(path, tgs["value"]); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | {#if typeof value === "string"} | ||||||
|  |   <TagRenderingEditable config={configBuiltin} selectedElement={undefined} showQuestionIfUnknown={true} {state} | ||||||
|  |                         {tags} /> | ||||||
|  | 
 | ||||||
|  | {:else} | ||||||
|  |   <div> | ||||||
|  |     TR{JSON.stringify(state.getCurrentValueFor(path))} | ||||||
|  |   </div> | ||||||
|  | {/if} | ||||||
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							|  | @ -591,7 +591,7 @@ | ||||||
|         "type": "string" |         "type": "string" | ||||||
|       } |       } | ||||||
|     ], |     ], | ||||||
|     "description": "\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`" |     "description": "\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`" | ||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
|     "path": [ |     "path": [ | ||||||
|  |  | ||||||
|  | @ -49,7 +49,7 @@ | ||||||
|         "type": "string" |         "type": "string" | ||||||
|       } |       } | ||||||
|     ], |     ], | ||||||
|     "description": "\nThis piece of text will be shown in the infobox.\nNote that \"{key}\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`" |     "description": "\nThis piece of text will be shown in the infobox.\nNote that \"&LBRACEkey&RBRACE\"-parts are substituted by the corresponding values of the element.\n\nThis text will be shown if:\n- there is no mapping which matches (or there are no matches)\n- no question, no mappings and no 'freeform' is set\n\nNote that this is a HTML-interpreted value, so you can add links as e.g. '<a href='{website}'>{website}</a>' or include images such as `This is of type A <br><img src='typeA-icon.svg' />`" | ||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
|     "path": [ |     "path": [ | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue