2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Architecture
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								============
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-09-09 00:05:51 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								This document aims to give an architectural overview of how MapCompelte is built. It should give some feeling on how
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								everything fits together.
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Servers?
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								--------
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								There are no servers for MapComplete, all services are configured by third parties.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Minimal HTML - Minimal CSS
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								--------------------------
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-02-12 00:48:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								There is quasi no HTML. Most of the components are generated by TypeScript and attached dynamically. The HTML is a
							 
						 
					
						
							
								
									
										
										
										
											2021-09-09 00:05:51 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								barebones skeleton which serves every theme.
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The UIEventSource
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-----------------
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-09-09 00:05:51 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Most (but not all) objects in MapComplete get all the state they need as a parameter in the constructor. However, as is
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								the case with most graphical applications, there are quite some dynamical values.
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-09-09 00:05:51 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								All values which change regularly are wrapped into
							 
						 
					
						
							
								
									
										
										
										
											2022-02-12 00:48:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								a [`UIEventSource` ](../Logic/UIEventSource.ts ). A `UIEventSource`  is a
							 
						 
					
						
							
								
									
										
										
										
											2021-09-09 00:05:51 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								wrapper containing a value and offers the possibility to add a callback function which is called every time the value is
							 
						 
					
						
							
								
									
										
										
										
											2022-02-12 00:48:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								changed (with `setData` )
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-09-09 00:05:51 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Furthermore, there are various helper functions, the most widely used one being `map`  - generating a new event source
							 
						 
					
						
							
								
									
										
										
										
											2022-02-12 00:48:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								with the new value applied. Note that `map`  will also absorb some changes,
							 
						 
					
						
							
								
									
										
										
										
											2021-09-09 00:05:51 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								e.g. `const someEventSource : UIEventSource<string[]> = ... ; someEventSource.map(list = list.length)`  will only trigger
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								when the length of the list has changed.
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-02-12 00:48:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								An object which receives a `UIEventSource`  is responsible of responding to changes of this object. This is especially
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								true for UI-components.
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-02-12 00:48:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								UI
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								--
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```typescript
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:45:18 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export default class MyComponent {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    constructor(neededParameters, neededUIEventSources) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
									
										
										
										
											2021-09-09 00:05:51 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:45:18 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-02-12 00:48:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The Graphical User Interface is composed of various UI-elements. For every UI-element, there is a `BaseUIElement`  which creates the actual `HTMLElement`  when needed.
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								There are some basic elements, such as:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-06-19 13:04:07 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  `FixedUIElement`  which shows a fixed, unchangeable element 
						 
					
						
							
								
									
										
										
										
											2022-02-12 00:48:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  `Img`  to show an image 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  `Combine`  which wraps everything given (strings and other elements) in a div 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  `List`  
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-02-12 00:48:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								There is one special component: the `VariableUIElement` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The `VariableUIElement`  takes a `UIEventSource<string|BaseUIElement>`  and will dynamicaly show whatever the `UIEventSource`  contains at the moment.
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								For example:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-02-12 00:48:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```typescript
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-09-09 00:05:51 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								const src : UIEventSource< string >  = ... // E.g. user input, data that will be updated... new VariableUIElement(src)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								.AttachTo('some-id') // attach it to the html
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Note that every component offers support for `onClick( someCallBack)` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Translations
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								To add a translation:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								1.  Open `langs/en.json`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								2.  Find a correct spot for your translation in the tree 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								3.  run `npm run generate:translations`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								4.  `import Translations`  
						 
					
						
							
								
									
										
										
										
											2022-02-12 00:48:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								5.  `Translations.t.<your-translation>.Clone()`  is the `UIElement`  offering your translation 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-02-12 00:48:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Input elements
  
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-02-17 00:53:47 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Input elements are a special kind of BaseElement which offer a piece of a form to the user, e.g. a TextField, a Radio button, a dropdown, ...
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-02-17 00:53:47 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The constructor will ask all the parameters to configure them. The actual value can be obtained via `inputElement.GetValue()` , which is a `UIEventSource`  that will be triggered every time the user changes the input.
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Advanced elements
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								There are some components which offer useful functionality:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  The `subtleButton`  which is a friendly, big button 
						 
					
						
							
								
									
										
										
										
											2022-02-12 00:48:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  The Toggle: `const t = new Toggle( componentA, componentB, source)`  is a `UIEventSource`  which shows `componentA`  as long as `source`  contains `true`  and will show `componentB`  otherwise. 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Styling
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Styling is done as much as possible with [TailwindCSS ](https://tailwindcss.com/ ). It contains a ton of utility classes, each of them containing a few rules.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-02-12 00:48:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								For example: ` someBaseUIElement.SetClass("flex flex-col border border-black rounded-full")`  will set the component to be a flex object, as column, with a black border and pill-shaped.
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-02-12 00:48:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								If Tailwind is not enough, use `baseUiElement.SetStyle("background: red; someOtherCssRule: abc;")` .
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### An example
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								For example: the user should input wether or not a shop is closed during public holidays. There are three options:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								1.  closed 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								2.  opened as usual 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								3.  opened with different hours as usual 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								In the case of different hours, input hours should be too.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								This can be constructed as following:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-02-12 00:48:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```typescript
							 
						 
					
						
							
								
									
										
										
										
											2021-09-09 00:05:51 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    // We construct the dropdown element with values and labelshttps://tailwindcss.com/
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    const isOpened = new Dropdown< string > (Translations.t.is_this_shop_opened_during_holidays,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        [
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								         { value: "closed", Translation.t.shop_closed_during_holidays.Clone()},
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								         { value: "open", Translations.t.shop_opened_as_usual.Clone()},
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								         { value: "hours", Translations.t.shop_opened_with_other_hours.Clone()}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        ] )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     const startHour = new DateInput(...)drop
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     const endHour = new DateInput( ... )   
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     // We construct a toggle which'll only show the extra questions if needed
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     const extraQuestion = new Toggle(
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            new Combine([Translations.t.openFrom, startHour, Translations.t.openTill, endHour]),
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            undefined,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            isOpened.GetValue().map(isopened => isopened === "hours")
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								         )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return new Combine([isOpened, extraQuestion])
							 
						 
					
						
							
								
									
										
										
										
											2021-09-09 00:05:51 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Constructing a special class
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								If you make a specialized class to offer a certain functionality, you can organize it as following:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								1.  Create a new class: 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-02-12 00:48:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```typescript
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export default class MyComponent {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    constructor(neededParameters, neededUIEventSources) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
									
										
										
										
											2021-09-09 00:05:51 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								2.  Construct the needed UI in the constructor 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-02-12 00:48:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```typescript
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export default class MyComponent {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    constructor(neededParameters, neededUIEventSources) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            const component = ...
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            const toggle = ...
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            ... other components ...
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            toggle.GetValue.AddCallbackAndRun(isSelected => { .. some actions ... }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            new Combine([everything, ...] )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
									
										
										
										
											2021-09-09 00:05:51 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-02-12 00:48:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								3.  You'll notice that you'll end up with one certain component (in this example the combine) to wrap it all together. Change the class to extend this type of component and use `super()`  to wrap it all up: 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-02-12 00:48:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```typescript
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export default class MyComponent extends Combine {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    constructor(...) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        ...
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        super([everything, ...])
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:45:18 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Assets
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								------
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Themes
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-02-12 00:48:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Theme and layer configuration files go into `assets/layers`  and `assets/themes` .
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:45:18 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Images
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-02-12 00:48:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Other files (mostly images that are part of the core of MapComplete) go into `assets/svg`  and are usable with `Svg.image_file_ui()` . Run `npm run generate:images`  if you added a new image.
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:45:18 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Logic
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-----
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-02-17 00:53:47 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The last part is the business logic of the application, found in the directory [Logic ](../Logic ). Actors are small objects which react to `UIEventSources`  to update other eventSources.
							 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:45:18 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-02-12 00:48:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								`State.state`  is a big singleton object containing a lot of the state of the entire application. That one is a bit of a mess. 
						 
					
						
							
								
									
										
										
										
											2021-06-17 16:40:19 +02:00