Glossary
Basics
- PermaplanT: The planning app implemented in this repository.
- map: The main planning utility for PermaplanT, which contains elements in several layers.
- garden: The physical place which is represented by the map. Can also be balcony or similar.
- current clock time: The time when you look at your clock.
- planning time: The time used within the map editor, to be selected with the timeline.
- current planning time: The time which is currently selected in the timeline, which is one specific date of the planning time.
- elements: Belong to a certain layer in a map. They have attributes.
- deletion/creation vs. removal/adding of elements:
- deletion/creation (German: löschen/erzeugen):
(refers to actual time)
The element never existed.
Such elements actually get deleted from the database and can only be restored within the session using undo.
I.e. there might be columns named created_atorremoved_at, but there usually is not adeleted_atcolumn (with exception of maps which do not immediately get deleted). Note: there is also a deletion of optional attributes, which means that the attribute is empty again.
- removal/adding (German: entfernen/hinzufügen): (refers to planning time) Removal of elements assume that the element actually was on the map (physically) during some time (between adding and removing). The database must keep removed elements, they never can be deleted. Plantings get added at the current planning time and might be automatically removed one or two years later.
 
- deletion/creation (German: löschen/erzeugen):
(refers to actual time)
The element never existed.
Such elements actually get deleted from the database and can only be restored within the session using undo.
I.e. there might be columns named 
- event: (refers to planning time) A day relevant to a user, which occurs on a map, e.g. when elements in the map get e.g. added/removed (accuracy: one day) or when a user declares a map ready for review etc.
Management
- Iteration = 1-week development period starting Mondays
- Milestone = expected release date
- Epic = group of related issues toward a major feature
Biology
- taxonomy: A scientific classification of plants into a hierarchy. The hierarchy we use is described here. As first introduction read:
- rank:
Rank is a level within taxonomy.
Plants within one taxonomic rank share traits with each other.
The levels relevant for PermaplanT are from highest to lowest:
- Family
- Genus
- Species
- Variety
- Cultivar
 
- below: We say a plant or rank B is below another rank A if it is at least one rank lower than A.
- belong: We say a plant B is belongs to rank A if it is exactly rank A (and not below).
- concrete plant: Is in an actually existing species, variety and cultivar.
- abstract plant: Representants of ranks, which are not actually existing plants.
- family: A taxonomic rank that consists of multiple genera.
- genus: A taxonomic rank which is part of a family. Consists of multiple species.
- species (German: Art): A taxonomic rank which is part of a genus. Can have multiple varieties or cultivars.
- variety (German: Varietät): Has the main characteristics of its species but differs in heritable characteristics. Can have multiple cultivars.
- cultivar (abbreviated from cultivated variety, German: Sorte): Has the main characteristics of its species or variety but differs in minor heritable characteristics. These characteristics were cultivated on purpose.
- hybrid: Hybrids are otherwise not relevant for PermaplanT's functionality.
- attributes of plants (traits in scientific literature): A characteristic of a variety, species, genus, subfamily or family. E.g. height, width, color, etc. Attributes can be defined on different levels of the hierarchy. E.g. a variety can have a different height than the species it belongs to. Some attributes are optional, e.g. height.
- polyculture (aka companion planting, German: Mischkultur): Mutually beneficial way of growing plants together.
- Relation:
- Spatial: Plants are in a non-neutral relation if they either positively (companion) or negatively (antagonist) influence each other's health and growth.
- Temporal: Plants are in a non-neutral relation if crop rotation is positive or negative on the later plant's health and growth.
 
- companion (to plant according polyculture): Plants that should be planted together.
- antagonist (to plant according polyculture): Plants that should be avoided next to each other.
- ambivalent relation (German: ambivalent): The plantings are both companions and antagonists to each other.
- plant database (German: Pflanzen-Datenbank): PermaplanT's large collection of plant entries with comprehensive data, indexed with a unique name.
- inventory (German: Inventar): A personal collection of plants, e.g., seeds. Every entry of the inventory links to a plant in the plant database. Furthermore, they have an additional name and are more precisely describing a plant than the plant database could do. Only in the inventory you can have plants which are not in the plant database, e.g., of special, new or unknown varieties.
- seedproof (German: Samenfest): From the seeds of a fruit you get again similar fruits.
- hybrid:
 Hybrids are not seedproof. They have an x in their name.
- raising (German: Anzucht, vorziehen)
- (German: Vorkulturen)
- (German: Sortenrein, ohne/wenig Vermischung anderer Sorten, wenig/keine Fremdbestäubung)
- zone (in permaculture, German: Permakultur Zonen):
Is an area which has the same frequency of human visitors.
The areas are numbered from:
- 00: (represented numerically as -1)
- 0: physical body of permaculturist
- 1: extremely frequently visited
- 2: frequently visited
- 3: less frequently visited
- 4: rarely visited
- 5: usually not visited
- 6: never visited/protection zone
 
- plantings (German "Pflanzung" or also "Pflanzen" depending on context): Plants that are already positioned on the map.
- same (plants, seeds or plantings): Plants are the same if they have the same unique name. Seeds are the same if the plant and the additional name are the same. Plantings are the same if the plant and seed are same.
- row: A row is a series of the same plantings.
- area of plantings: Are several rows next to each other, which have a specific distance to each other (row spacing).
Plantings Attributes
- width (German: Breite): X-value of plantings and area of plantings (without rotation).
- length (German: Länge):
- Is the Y-value for area of plantings (without rotation).
- Is not used for plantings (because we use width instead).
 
- height:
- Currently unused Z-value of plants and plantings.
 
- spacing (Pflanzabstand)
- row spacing (Reihenabstand)
- life cycle: is a list containing any combination of its 3 possible values (annual, biennial, perennial) or just an empty list in case a plant has no life cycle value in the database
UI
- device: A physical piece of hardware capable of accessing the internet through the use of a supported browser.
- mobile device: A portable device a user mainly interacts with via a touchscreen.
- small screen: A screen with a width or height of less than 768 px.
- large screen: A screen with a width and height of 768 px or more.
- layer: Layers allow to group elements of the same kind and set all of them visible or transparent. (implemented as Konva group)
- overlay: A component that partially or completely covers the primary content of the current page. An overlay may provide additional information, additional tools or a means of navigation amongst other things. Examples for an overlay in the context of PermaplanT include the navbar, the left and right toolbars and the timeline.
- right top toolbar: Allows to enable or hide layers.
- right bottom toolbar: Contextual toolbar for the enabled layer.
- Right toolbar: The UI element containing both the right top and bottom toolbars.
- left top toolbar: Buttons with icons that have potentially global effects for the map or the functionality on the next click.
- left bottom toolbar: Contextual toolbar for the enabled element.
- left toolbar: The UI element containing both the left top and bottom toolbars.
- status panel: The panel shown during actions, e.g. placement of elements, in the bottom middle. It should tell the user which action a mouse click would have, i.e., in which mode the UI currently is. Is not shown if mouse clicks would select elements.
- navigation bar (NavBar): The top bar for login etc.
- timeline: The bottom bar to set the current date.
- scale bar (Maßstabsleiste): Overlaid on the map in the bottom right to show the user what the current scale of the map is. Depending on the zoom level it might be in centimeters or meters. It represents this distance in the current scale of the map.
- images (Bilder):
are fetched from Nextcloud, drawn on the canvas and can be either:
- when a plant is rendered (a replacement image showing a generic plant might be used if the plant has no image)
- special elements in additional layers
- an image for the base layer
 
Layers
- enable (a layer): Changes the canvas in a way that elements in the enabled layer are the ones to be edited, selected and added. When working together on a map, every user can enable the layer of their choice.
- visibility and opacity (of a layer): The elements in a layer are (not) shown or with a user-selected transparency.
- alternative (of a layer): An alternative (of a layer) is a named clone of a layer. It is possible to select one alternative of a layer. Each alternative can be edited independently.
- select (a layer): To choose one alternative of one layer. E.g. if there are several plants layers, a user can select only one of these alternatives at once. When working together on a map, every user can select their own layers.
- offline availability: Means that layers can be edited also offline, data gets synced when device is online again.
- brushing: A quick way to mark areas in the brushing layers: shadow, hydrology, soil texture and additional.
Technical
- usability: The extent to which a system, product or service can be used by specified users to achieve specified goals with effectiveness, efficiency and satisfaction in a specified context of use.
- mobile usability: The usability in the context of a mobile device.
- user interface (UI): The set of all the components of an interactive system that provide information and controls for the user to accomplish specific tasks with the interactive system.
- user experience (UX): Combination of user's perceptions and responses that result from the use and/or anticipated use of a system, product or service.
- offline: Means the ability to use a feature without Internet connection, i.e., without calling REST APIs.
- canvas: The main and middle part of the screen which provides the planning/drawing functionality.
- canvas context:
- canvas node elements i.e. HTML representation of rectangle, circle, etc. on the canvas
 
- map context:
- layers and their attributes e.g. relation layer and its visibility
 
- reversible deletion vs undo-redo functionality:
- reversible deletion: a database entity i.e. a whole map and plant is deleted and can be restored within a certain time
- undo-redo functionality: a user can undo and redo changes in the map, but the history is local to the frontend and not stored in the database
 
- lazy loading:
- Lazy loading refers to the process of loading data on-demand, rather than loading everything upfront during the initial load of the app.
 
- offloading of the frontend state:
- the process of cleaning up the frontend state by deleting data that has already been synchronized with the backend and is no longer needed. This can help to reduce the amount of unnecessary data in the frontend, which can improve the performance and efficiency of the application.
 
- first contentful paint (FCP):
- the time it takes for the browser to render the first bit of content on the page.
 
- time to interactive (TTI):
- the time it takes for the page to become fully interactive.
 
- Document Object Model (DOM):
- the data representation of the objects that comprise the structure and content of a document on the web.
 
- endpoints:
- The API endpoints that can be called in the backend. Their documentation can be viewed using swagger-ui (see here for reference).
 
- entity:
- an object or concept of interest (map, user, plant, planting, etc.)
- contains all necessary attributes to describe its properties
- represented as table in the database
- each database row is a specific instance of the entity
 
- keybinding:
- The association of a specific action or function with a particular key or key combination.
 
- keyhandling:
- A Broader concept of how the software manages and responds to keyboard input. It includes not only the assignment of actions to keys (keybinding) but also the handling of key events, such as detecting key presses, key releases, and processing them accordingly.
 
Acronyms
- 
FE: Frontend. 
- 
API: Application Programming Interface, commonly used to provide endpoints that allow for communication between backend and frontend. 
- 
DTO: Data Transfer Object, used to encapsulate and transfer data between different parts of a program, usually from the backend to the frontend (commonly used as API responses) 
- 
REST: Representational State Transfer, style and standard for designing APIs using standard HTTP methods. 
- 
JSON: JavaScript Object Notation, data format that is commonly used in communication between backend and frontend and can be natively used and accessed in the frontend. 
- 
JWT: JSON Web Token, compact token format that can be used for secure data transmission and e.g. for authentication. 
- 
DOM: Document Object Model, interface that allows for manipulation/updates to HTML documents by e.g. queries, selectors and more. 
- 
CI/CD: Continuous Integration / Continuous Deployment, used to automate code integration and the deployment process, used to run tests/pipelines before merges and deploy code afterwards. 
- 
CORS: Cross-Origin Resource Sharing, a browser security feature that restricts how web pages can request resources from different domains. It aims to stop malicious sites from being able to access or snoop sensitive and private data. 
- 
OAuth: Open Authorization, a protocol used for token-based authorization, which is used for authorization in PermaplanT. See nextcloud integration doc for further information. 
- 
IAM: Identity and Access Management, used to secure applications and services. PermaplanT uses Keycloak for this to manage and secure access to nextcloud. See keycloak doc for further information. 
Testing
- unit test: Used to test parts of our code in isolation. See test doc for further information. Example: Test an individual function for specific behavior.
- integration test: Used to test if different parts of the code work together correctly. See test doc for further information. Example: Make an HTTP request to the backend and let it run through controller, service and persistence layer requiring a running database.
- end to end test (e2e test): Used to test the whole application from end to end. Example: Simulate a user clicking a button (e.g. with Selenium) resulting in an HTTP request to the backend. Wait for the response and validate the resulting change in the frontend.
- acceptance tests: Black box system tests of a user story. Usually performed as regressions tests prior to a release. They are performed by engineers during the development phase.
- system tests: Tests the whole system towards the requirements definition and specification documents. This can involve functional and non-functional tests (performance, security, etc.). They are super set of end-to-end tests which can be done manually and/or automatically.
- user acceptance tests: Black box system tests towards customer requirements. Usually (subset of) system level tests conducted by the customer/user/domain expert. These tests makes sure that the solution provided by the system is accepted by the user. Similar to "Beta testing".