Unlock a world of possibilities! Login now and discover the exclusive benefits awaiting you.
 Alex78
		
			Alex78
		
		
		
		
		
		
		
		
	
			
		
		
			
					
		Hi all,
I have a QV application that have several text boxes with triggers to activate (or go to) another sheet when selected. The tabs are going to replace the function of the application Sheet Tabs, i.e., tabrows will be hidden from document properties.
Based on users access, the Sheets  as well these Text Box based tabs will be active or hidden; and aligned left. Look at the three images for three different users accessing the document. Img 1: General Tabs layout
Img 2 User A Tabs layout
Img 3: User B Tabs layout
based on the images above, User A will see Tabs 1,3 and 4. Tab 2 as well Sheet 2 will be hidden from User A. Tab 3 and Tab 4 will be aligned left. The same with User B.
Thank you in advance
Alex
 Vegar
		
			Vegar
		
		
		
		
		
		
		
		
	
			
		
		
			
					
		Try this qvw file.
Laborate and reload the load script filter "Access" for different user scenarios.
LOAD * Inline [ Sheet, Header, Access SH01, Main sheet,1 SH02, Sheet no1, 1 SH03, Sheet no2, 0 SH04, Sheet no3, 1 ] WHere Access = 1 ;
 Vegar
		
			Vegar
		
		
		
		
		
		
		
		
	
			
		
		
			
					
		You might be able to create and align your textboxes with some of the macro functionality found in QlikView, someone other than me should guide you if it is possible.
An alternative to re-aligning textboxes based on access is to dynamicly generate the header and activation of a text box.
User A
Box1 = 'Tab1'; Box2 = 'Tab3';Box3='Tab4'; Box4=<hidden>
User B
Box1='Tab2';Box2='Tab4';Box3=<hidden>;Box4=<hidden>
With this solution the textboxes wont need to move around, but you do still get the same look and functionality for the end user. Its probably a bit of fiddeling to do it, but it should be totally doable.
 Alex78
		
			Alex78
		
		
		
		
		
		
		
		
	
			
		
		
			
					
		 Vegar
		
			Vegar
		
		
		
		
		
		
		
		
	
			
		
		
			
					
		Try this qvw file.
Laborate and reload the load script filter "Access" for different user scenarios.
LOAD * Inline [ Sheet, Header, Access SH01, Main sheet,1 SH02, Sheet no1, 1 SH03, Sheet no2, 0 SH04, Sheet no3, 1 ] WHere Access = 1 ;
 Vegar
		
			Vegar
		
		
		
		
		
		
		
		
	
			
		
		
			
					
		 Alex78
		
			Alex78
		
		
		
		
		
		
		
		
	
			
		
		
			
					
		 Alex78
		
			Alex78
		
		
		
		
		
		
		
		
	
			
		
		
			
					
		 Vegar
		
			Vegar
		
		
		
		
		
		
		
		
	
			
		
		
			
					
		 Alex78
		
			Alex78
		
		
		
		
		
		
		
		
	
			
		
		
			
					
		Thank you for coming back on this @Vegar,
Yes, I am using section access to reduce data.
What I do on my document is when I use OSUser() function to filter the user Sheet access in the script, it returns as intended on QV Desktop with the Text Box Tabs required to be hidden/visible as planned. Once deployed, it returns nothing or all the Text Box Tabs are hidden for the user. However, if I hard code the user in the script filter, it works as intended both on desktop and after deployed to server.
Based on your sample qvw, I added the User Login on the load as follows.
LOAD * Inline [
Sheet, Header, Access, UserLogin
SH01, Main sheet,1, Domain\User01
SH02, Sheet no1, 1, Domain\User01
SH03, Sheet no2, 0, Domain\User01
SH04, Sheet no3, 1, Domain\User01
SH01, Main sheet,0, Domain\User002
SH02, Sheet no1, 1, Domain\User002
SH03, Sheet no2, 1, Domain\User002
SH04, Sheet no3, 0, Domain\User002
]
Where Access = 1
AND UserLogin = 'Domain\User002';
==> this returns SH02 and SH03 Tabs active and aligned left, with the header and sheet triggers set as intended.
But with the following it does not work
LOAD * Inline [
Sheet, Header, Access, UserLogin
...... same as above
]
Where Access = 1
AND UserLogin = OSUser();
==> Hides all the Text Box Tabs. I tested the values of the field with text boxes and returns nothing both for the header and sheet.
I also tested the application on desktop and server with and without section access and is behaving same.
Thank you for the help.
 Vegar
		
			Vegar
		
		
		
		
		
		
		
		
	
			
		
		
			
					
		
WHERE UserLogin = OSUser()
If you use OSUser() in the script you only get the OSUser for the user executing the script, not dynamicly for each user using the application. When running in QMC the OSUser() will we your service account.
You need to use Section Access or Reduce data the distribution if you have a QlikView Publisher.
See attached qwv with an simple SA implementation.
USERID, PASSWORD, SHEETACCESS ADMIN, 123, * USER1, 123, SH01|SH03 USER2, 123, SH01|SH02 USER3, 123, SH03 USER4, 123, SH01|SH02|SH03|SH04
