improve non-ACL option description in ACL dialog
This commit is contained in:
		
							
								
								
									
										17
									
								
								boot.php
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								boot.php
									
									
									
									
									
								
							| @@ -313,15 +313,14 @@ define ( 'PERMS_A_REPUBLISH',      0x10000); | |||||||
| define ( 'PERMS_W_LIKE',           0x20000); | define ( 'PERMS_W_LIKE',           0x20000); | ||||||
|  |  | ||||||
| // General channel permissions | // General channel permissions | ||||||
|  |                                         // 0 = Only you | ||||||
| define ( 'PERMS_PUBLIC'     , 0x0001 ); | define ( 'PERMS_PUBLIC'     , 0x0001 ); // anybody | ||||||
| define ( 'PERMS_NETWORK'    , 0x0002 ); | define ( 'PERMS_NETWORK'    , 0x0002 ); // anybody in this network | ||||||
| define ( 'PERMS_SITE'       , 0x0004 ); | define ( 'PERMS_SITE'       , 0x0004 ); // anybody on this site | ||||||
| define ( 'PERMS_CONTACTS'   , 0x0008 ); | define ( 'PERMS_CONTACTS'   , 0x0008 ); // any of my connections | ||||||
| define ( 'PERMS_SPECIFIC'   , 0x0080 ); | define ( 'PERMS_SPECIFIC'   , 0x0080 ); // only specific connections | ||||||
| define ( 'PERMS_AUTHED'     , 0x0100 ); | define ( 'PERMS_AUTHED'     , 0x0100 ); // anybody authenticated (could include visitors from other networks) | ||||||
| define ( 'PERMS_PENDING'    , 0x0200 ); | define ( 'PERMS_PENDING'    , 0x0200 ); // any connections including those who haven't yet been approved | ||||||
|  |  | ||||||
|  |  | ||||||
| // Address book flags | // Address book flags | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										167
									
								
								include/PermissionDescription.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										167
									
								
								include/PermissionDescription.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,167 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | if(class_exists('PermissionDescription')) return; | ||||||
|  |  | ||||||
|  | require_once("include/permissions.php"); | ||||||
|  | require_once("include/language.php"); | ||||||
|  | require_once("include/text.php"); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Encapsulates information the ACL dialog requires to describe | ||||||
|  |  * permission settings for an item with an empty ACL. | ||||||
|  |  * i.e the caption, icon, and tooltip for the no-ACL option in the ACL dialog. | ||||||
|  |  */ | ||||||
|  | class PermissionDescription  { | ||||||
|  |  | ||||||
|  | 	private $global_perm; | ||||||
|  | 	private $channel_perm; | ||||||
|  | 	private $fallback_description; | ||||||
|  | 	 | ||||||
|  | 	/** | ||||||
|  | 	 * Constructor is private. | ||||||
|  | 	 * Use static methods fromGlobalPermission(), fromStandalonePermission(), or fromDescription() | ||||||
|  | 	 * to create instances. | ||||||
|  | 	 */ | ||||||
|  | 	private function __construct($global_perm, $channel_perm, $description = '') { | ||||||
|  |  | ||||||
|  | 		$this->global_perm  = $global_perm; | ||||||
|  | 		$this->channel_perm = $channel_perm; | ||||||
|  | 		 | ||||||
|  | 		$this->fallback_description = ($description  == '') ? t('Visible to your default audience') : $description; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * If the interpretation of an empty ACL can't be summarised with a global default permission  | ||||||
|  | 	 * or a specific permission setting then use this method and describe what it means instead. | ||||||
|  | 	 * | ||||||
|  | 	 * @param  string $description - the caption for the no-ACL option in the ACL dialog. | ||||||
|  | 	 * @return a new instance of PermissionDescription | ||||||
|  | 	 */ | ||||||
|  | 	public static function fromDescription($description) { | ||||||
|  | 		return new PermissionDescription('', 0x80000, $description); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * Use this method only if the interpretation of an empty ACL doesn't fall back to a global  | ||||||
|  | 	 * default permission. You should pass one of the constants from boot.php - PERMS_PUBLIC, PERMS_NETWORK etc. | ||||||
|  | 	 *  | ||||||
|  | 	 * @param  integer $perm - a single enumerated constant permission - PERMS_PUBLIC, PERMS_NETWORK etc. | ||||||
|  | 	 * @return a new instance of PermissionDescription | ||||||
|  | 	 */ | ||||||
|  | 	public static function fromStandalonePermission($perm) { | ||||||
|  |  | ||||||
|  | 		$result = new PermissionDescription('', $perm); | ||||||
|  | 		 | ||||||
|  | 		$checkPerm = $this->get_permission_description(); | ||||||
|  | 		if ($checkPerm == $this->fallback_description) { | ||||||
|  | 			$result = null; | ||||||
|  | 			logger('null PermissionDescription from unknown standalone permission: ' . $perm ,LOGGER_DEBUG, LOG_ERROR); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		return $result; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * This is the preferred way to create a PermissionDescription, as it provides the most details. | ||||||
|  | 	 * Use this method if you know an empty ACL will result in one of the global default permissions  | ||||||
|  | 	 * being used, such as channel_r_stream (for which you would pass 'view_stream'). | ||||||
|  | 	 *  | ||||||
|  | 	 * @param  string $permname - a key for the global perms array from get_perms() in permissions.php, | ||||||
|  | 	 *         e.g. 'view_stream', 'view_profile', etc. | ||||||
|  | 	 * @return a new instance of PermissionDescription | ||||||
|  | 	 */ | ||||||
|  | 	public static function fromGlobalPermission($permname) { | ||||||
|  |  | ||||||
|  | 		$result = null; | ||||||
|  |  | ||||||
|  | 		$global_perms = get_perms(); | ||||||
|  |  | ||||||
|  | 		if (array_key_exists($permname, $global_perms)) { | ||||||
|  |  | ||||||
|  | 			$permDetails = $global_perms[$permname]; | ||||||
|  | 			$channelPerm = \App::$channel[$permDetails[0]]; | ||||||
|  | 			$result = new PermissionDescription($permDetails[1], $channelPerm); | ||||||
|  | 		} else { | ||||||
|  | 			// The acl dialog can handle null arguments, but it shouldn't happen | ||||||
|  | 			logger('null PermissionDescription from unknown global permission: ' . $permname ,LOGGER_DEBUG, LOG_ERROR); | ||||||
|  | 		} | ||||||
|  | 		return $result; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * Gets a localized description of the permission, or a generic message if the permission | ||||||
|  | 	 * is unknown. | ||||||
|  | 	 * | ||||||
|  | 	 * @return string description | ||||||
|  | 	 */ | ||||||
|  | 	public function get_permission_description() { | ||||||
|  |  | ||||||
|  | 		switch($this->channel_perm) {			 | ||||||
|  |  | ||||||
|  | 			case 0:              return t('Only me'); | ||||||
|  | 			case PERMS_PUBLIC:   return t('Public'); | ||||||
|  | 			case PERMS_NETWORK:  return t('Anybody in the $Projectname network'); | ||||||
|  | 			case PERMS_SITE:     return sprintf(t('Any account on %s'), \App::get_hostname()); | ||||||
|  | 			case PERMS_CONTACTS: return t('Any of my connections'); | ||||||
|  | 			case PERMS_SPECIFIC:  | ||||||
|  | 				// Because we're describing the permissions of an item with an empty ACL, | ||||||
|  | 				// the owner will be the only person able to see it if the permissions are  | ||||||
|  | 				// set to "only specified connections". | ||||||
|  | 				return t('Only me (only specified contacts and me)');  | ||||||
|  | 			case PERMS_AUTHED:   return t('Anybody authenticated (could include visitors from other networks)'); | ||||||
|  | 			case PERMS_PENDING:  return t('Any connections including those who haven\'t yet been approved'); | ||||||
|  | 			default:             return $this->fallback_description; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * Returns an icon css class name if an appropriate one is available, e.g. "fa-globe" for Public, | ||||||
|  | 	 * otherwise returns empty string.  | ||||||
|  | 	 * | ||||||
|  | 	 * @return string icon css class name (often FontAwesome) | ||||||
|  | 	 */ | ||||||
|  | 	public function get_permission_icon() { | ||||||
|  |  | ||||||
|  | 		switch($this->channel_perm) {			 | ||||||
|  |  | ||||||
|  | 			case 0:/* only me */ return 'fa-eye-slash'; | ||||||
|  | 			case PERMS_PUBLIC:   return 'fa-globe'; | ||||||
|  | 			case PERMS_NETWORK:  return 'fa-share-alt-square'; // fa-share-alt-square is very similiar to the hubzilla logo, but we should create our own logo class to use | ||||||
|  | 			case PERMS_SITE:     return 'fa-sitemap';  | ||||||
|  | 			case PERMS_CONTACTS: return 'fa-group';  | ||||||
|  | 			case PERMS_SPECIFIC:  | ||||||
|  | 				// Because we're describing the permissions of an item with an empty ACL, | ||||||
|  | 				// the owner will be the only person able to see it if the permissions are  | ||||||
|  | 				// set to "only specified connections". | ||||||
|  | 				return 'fa-eye-slash';  | ||||||
|  | 			case PERMS_AUTHED:   return ''; | ||||||
|  | 			case PERMS_PENDING:  return ''; | ||||||
|  | 			default:             return ''; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * Returns a localized description of where the permission came from, if this is known. | ||||||
|  | 	 * If it's not know, or if the permission is standalone and didn't come from a default | ||||||
|  | 	 * permission setting, then empty string is returned. | ||||||
|  | 	 * | ||||||
|  | 	 * @return string description or empty string | ||||||
|  | 	*/ | ||||||
|  | 	public function get_permission_origin_description() { | ||||||
|  |  | ||||||
|  | 		switch($this->global_perm) {			 | ||||||
|  |  | ||||||
|  | 			case PERMS_R_STREAM:  return t('This is your default setting for the audience of your normal stream, and posts.'); | ||||||
|  | 			case PERMS_R_PROFILE: return t('This is your default setting for who can view your default channel profile'); | ||||||
|  | 			case PERMS_R_ABOOK:   return t('This is your default setting for who can view your connections'); | ||||||
|  | 			case PERMS_R_STORAGE: return t('This is your default setting for who can view your file storage and photos'); | ||||||
|  | 			case PERMS_R_PAGES:   return t('This is your default setting for the audience of your webpages'); | ||||||
|  | 			default:              return ''; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -6,6 +6,9 @@ | |||||||
| /** | /** | ||||||
|  * @package acl_selectors  |  * @package acl_selectors  | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
|  | require_once("include/PermissionDescription.php"); | ||||||
|  |  | ||||||
| function group_select($selname,$selclass,$preselected = false,$size = 4) { | function group_select($selname,$selclass,$preselected = false,$size = 4) { | ||||||
|  |  | ||||||
| 	$a = get_app(); | 	$a = get_app(); | ||||||
| @@ -215,20 +218,34 @@ function fixacl(&$item) { | |||||||
| * | * | ||||||
| * @param array   $default Optional access control list for the initial state of the dialog. | * @param array   $default Optional access control list for the initial state of the dialog. | ||||||
| * @param boolean $show_jotnets Whether plugins for federated networks should be included in the permissions dialog | * @param boolean $show_jotnets Whether plugins for federated networks should be included in the permissions dialog | ||||||
| * @param string  $showall_caption An optional caption to describe the scope of an unrestricted post. e.g. "Public" | * @param PermissionDescription $emptyACL_description - An optional description for the permission implied by selecting an empty ACL. Preferably an instance of PermissionDescription. | ||||||
| * @param string  $dialog_description Optional message to include at the top of the dialog. E.g. "Warning: Post permissions cannot be changed once sent". | * @param string  $dialog_description Optional message to include at the top of the dialog. E.g. "Warning: Post permissions cannot be changed once sent". | ||||||
| * @param string  $context_help Allows the dialog to present a help icon. E.g. "acl_dialog_post" | * @param string  $context_help Allows the dialog to present a help icon. E.g. "acl_dialog_post" | ||||||
| * @param boolean $readonly Not implemented yet. When implemented, the dialog will use acl_readonly.tpl instead, so that permissions may be viewed for posts that can no longer have their permissions changed. | * @param boolean $readonly Not implemented yet. When implemented, the dialog will use acl_readonly.tpl instead, so that permissions may be viewed for posts that can no longer have their permissions changed. | ||||||
| * | * | ||||||
| * @return string html modal dialog built from acl_selector.tpl | * @return string html modal dialog built from acl_selector.tpl | ||||||
| */ | */ | ||||||
| function populate_acl($defaults = null,$show_jotnets = true, $showall_caption = '', $dialog_description = '', $context_help = '', $readonly = false) { | function populate_acl($defaults = null,$show_jotnets = true, $emptyACL_description = '', $dialog_description = '', $context_help = '', $readonly = false) { | ||||||
|  |  | ||||||
| 	$allow_cid = $allow_gid = $deny_cid = $deny_gid = false; | 	$allow_cid = $allow_gid = $deny_cid = $deny_gid = false; | ||||||
|  | 	$showall_origin = ''; | ||||||
|  | 	$showall_icon   = 'fa-globe'; | ||||||
|  |  | ||||||
| 	if(! $showall_caption) |  | ||||||
|  | 	if(! $emptyACL_description) { | ||||||
| 		$showall_caption = t('Visible to your default audience'); | 		$showall_caption = t('Visible to your default audience'); | ||||||
|  |  | ||||||
|  | 	} else if (is_a($emptyACL_description, 'PermissionDescription')) { | ||||||
|  | 		$showall_caption = $emptyACL_description->get_permission_description(); | ||||||
|  | 		$showall_origin  = $emptyACL_description->get_permission_origin_description(); | ||||||
|  | 		$showall_icon    = $emptyACL_description->get_permission_icon(); | ||||||
|  |  | ||||||
|  | 	} else { | ||||||
|  | 		// For backwards compatibility we still accept a string... for now! | ||||||
|  | 		$showall_caption = $emptyACL_description; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
| 	if(is_array($defaults)) { | 	if(is_array($defaults)) { | ||||||
| 		$allow_cid = ((strlen($defaults['allow_cid']))  | 		$allow_cid = ((strlen($defaults['allow_cid']))  | ||||||
| 			? explode('><', $defaults['allow_cid']) : array() ); | 			? explode('><', $defaults['allow_cid']) : array() ); | ||||||
| @@ -252,6 +269,8 @@ function populate_acl($defaults = null,$show_jotnets = true, $showall_caption = | |||||||
| 	$tpl = get_markup_template("acl_selector.tpl"); | 	$tpl = get_markup_template("acl_selector.tpl"); | ||||||
| 	$o = replace_macros($tpl, array( | 	$o = replace_macros($tpl, array( | ||||||
| 		'$showall'         => $showall_caption, | 		'$showall'         => $showall_caption, | ||||||
|  | 		'$showallOrigin'   => $showall_origin, | ||||||
|  | 		'$showallIcon'     => $showall_icon, | ||||||
| 		'$showlimited'     => t("Limit access:"), | 		'$showlimited'     => t("Limit access:"), | ||||||
| 		'$showlimitedDesc' => t('Select "Show" to allow viewing. "Don\'t show" lets you override and limit the scope of "Show".'), | 		'$showlimitedDesc' => t('Select "Show" to allow viewing. "Don\'t show" lets you override and limit the scope of "Show".'), | ||||||
| 		'$show'	           => t("Show"), | 		'$show'	           => t("Show"), | ||||||
| @@ -278,7 +297,7 @@ function populate_acl($defaults = null,$show_jotnets = true, $showall_caption = | |||||||
| * populate_acl() call for wall posts or network posts. | * populate_acl() call for wall posts or network posts. | ||||||
| * | * | ||||||
| * This string is needed in 3 different files, and our .po translation system currently | * This string is needed in 3 different files, and our .po translation system currently | ||||||
| * cannot be used as a string table (because the value is always the key is english) so | * cannot be used as a string table (because the value is always the key in english) so | ||||||
| * I've centralized the value here (making this function name the "key") until we have a | * I've centralized the value here (making this function name the "key") until we have a | ||||||
| * better way. | * better way. | ||||||
| * | * | ||||||
|   | |||||||
| @@ -1046,6 +1046,13 @@ a.rconnect:hover, a.rateme:hover, div.rateme:hover { | |||||||
| 	font-size: 140%; | 	font-size: 140%; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | #acl-info-icon, | ||||||
|  | #acl-info-icon:active { | ||||||
|  | 	font-size: 110%; | ||||||
|  | 	color: $link_colour; | ||||||
|  | 	text-decoration: none; | ||||||
|  | } | ||||||
|  |  | ||||||
| #acl-showall-caption { | #acl-showall-caption { | ||||||
| 	margin-left: 0.35em; | 	margin-left: 0.35em; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -25,8 +25,12 @@ | |||||||
| 					<div id="acl-radiowrapper-showall" class="radio"> | 					<div id="acl-radiowrapper-showall" class="radio"> | ||||||
| 					  <label> | 					  <label> | ||||||
| 					    <input id="acl-showall" type="radio" name="optionsRadios" value="option1" checked> | 					    <input id="acl-showall" type="radio" name="optionsRadios" value="option1" checked> | ||||||
| 					    <i class="fa fa-globe"></i><span id=acl-showall-caption>{{$showall}}</span> | 					    {{if $showallIcon}}<i class="fa {{$showallIcon}}"></i>{{/if}} | ||||||
|  | 					    <span id="acl-showall-caption">{{$showall}}</span> | ||||||
| 					  </label> | 					  </label> | ||||||
|  | 					  {{if $showallOrigin}} | ||||||
|  | 					     <a id="acl-info-icon" role="button" tabindex="0" class="fa fa-info-circle" data-trigger="focus" data-toggle="popover" data-placement="top" data-content="{{$showallOrigin}}"></a> | ||||||
|  | 					  {{/if}} | ||||||
| 					</div> | 					</div> | ||||||
| 					<div id="acl-radiowrapper-showlimited" class="radio"> | 					<div id="acl-radiowrapper-showlimited" class="radio"> | ||||||
| 						<label> | 						<label> | ||||||
| @@ -61,6 +65,8 @@ | |||||||
| </div><!-- /.modal --> | </div><!-- /.modal --> | ||||||
|  |  | ||||||
| <script> | <script> | ||||||
|  | 	$('[data-toggle="popover"]').popover(); // Init the popover, if present | ||||||
|  |  | ||||||
| 	if(typeof acl=="undefined"){ | 	if(typeof acl=="undefined"){ | ||||||
| 		acl = new ACL( | 		acl = new ACL( | ||||||
| 			baseurl+"/acl", | 			baseurl+"/acl", | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user