mirror of
				https://github.com/Unleash/unleash.git
				synced 2025-10-18 11:14:57 +02:00 
			
		
		
		
	This PR puts our contributing guidelines in the sidebar of the unleash documentation. Currently there was no way of navigating to them easily, which made our contribution guides and ADRs less useful. This PR adds them to the sidebar as their own category, and adds an ADR for domain centric language. Co-authored-by: Thomas Heartman <thomas@getunleash.ai>
		
			
				
	
	
		
			24 lines
		
	
	
		
			799 B
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			24 lines
		
	
	
		
			799 B
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ---
 | |
| title: "ADR: Interface naming"
 | |
| ---
 | |
| 
 | |
| ## Background
 | |
| 
 | |
| In the codebase, we have found a need to have a common way of naming interfaces in order to ensure consistency.
 | |
| 
 | |
| ## Decision
 | |
| 
 | |
| We have decided to use a naming convention of appending the letter `I` in front of interfaces to signify that we are in fact using an interface. For props, we use `IComponentNameProps`.
 | |
| 
 | |
| ```jsx
 | |
| // Do:
 | |
| interface IMyInterface {}
 | |
| interface IMyComponentNameProps {}
 | |
| 
 | |
| // Don't:
 | |
| interface MyInterface {}
 | |
| interface MyComponentName {}
 | |
| ```
 | |
| 
 | |
| The reason for this decision is to remove mental clutter and free up capacity to easily navigate the codebase. Knowing that an interface is prefixed with `I` allows you to quickly scan a file without watching for a context where the interface is used in order to understand what it is.
 |