forked from quickshell/quickshell
		
	core/lazyloader: add activeAsync property
This commit is contained in:
		
							parent
							
								
									658f3cf411
								
							
						
					
					
						commit
						4db28fe725
					
				
					 2 changed files with 17 additions and 0 deletions
				
			
		| 
						 | 
				
			
			@ -88,6 +88,12 @@ void LazyLoader::setActive(bool active) {
 | 
			
		|||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void LazyLoader::setActiveAsync(bool active) {
 | 
			
		||||
	if (active == (this->targetActive || this->targetLoading)) return;
 | 
			
		||||
	if (active) this->setLoading(true);
 | 
			
		||||
	else this->setActive(false);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
QQmlComponent* LazyLoader::component() const {
 | 
			
		||||
	return this->cleanupComponent ? nullptr : this->mComponent;
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -104,13 +104,23 @@ class LazyLoader: public Reloadable {
 | 
			
		|||
	/// If the component is not loaded, setting this property to true will start
 | 
			
		||||
	/// loading it asynchronously. If the component is already loaded, setting
 | 
			
		||||
	/// this property has no effect.
 | 
			
		||||
	///
 | 
			
		||||
	/// See also: [activeAsync](#prop.activeAsync).
 | 
			
		||||
	Q_PROPERTY(bool loading READ isLoading WRITE setLoading NOTIFY loadingChanged);
 | 
			
		||||
	/// If the component is fully loaded.
 | 
			
		||||
	///
 | 
			
		||||
	/// Setting this property to `true` will force the component to load to completion,
 | 
			
		||||
	/// blocking the UI, and setting it to `false` will destroy the component, requiring
 | 
			
		||||
	/// it to be loaded again.
 | 
			
		||||
	///
 | 
			
		||||
	/// See also: [activeAsync](#prop.activeAsync).
 | 
			
		||||
	Q_PROPERTY(bool active READ isActive WRITE setActive NOTIFY activeChanged);
 | 
			
		||||
	/// If the component is fully loaded.
 | 
			
		||||
	///
 | 
			
		||||
	/// Setting this property to true will asynchronously load the component similarly to
 | 
			
		||||
	/// [loading](#prop.loading). Reading it or setting it to false will behanve
 | 
			
		||||
	/// the same as [active](#prop.active).
 | 
			
		||||
	Q_PROPERTY(bool activeAsync READ isActive WRITE setActiveAsync NOTIFY activeChanged);
 | 
			
		||||
	/// The component to load. Mutually exclusive to `source`.
 | 
			
		||||
	Q_PROPERTY(QQmlComponent* component READ component WRITE setComponent NOTIFY componentChanged);
 | 
			
		||||
	/// The URI to load the component from. Mutually exclusive to `component`.
 | 
			
		||||
| 
						 | 
				
			
			@ -123,6 +133,7 @@ public:
 | 
			
		|||
 | 
			
		||||
	[[nodiscard]] bool isActive() const;
 | 
			
		||||
	void setActive(bool active);
 | 
			
		||||
	void setActiveAsync(bool active);
 | 
			
		||||
 | 
			
		||||
	[[nodiscard]] bool isLoading() const;
 | 
			
		||||
	void setLoading(bool loading);
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue