Forum Replies Created

Viewing 15 replies - 1 through 15 (of 43 total)
  • What if the font you want to use is an Adobe font? You don’t have the option to download something for Add Local Fonts and adding the style link using wp_enqueue_style will not make the fonts available in the theme settings menus. The Custom Adobe Fonts plugin doesn’t seem to solve this either.

    Thread Starter Jon Breitenbucher

    (@kahless)

    @threadi “However, if you change something in the files of a theme, it will change for all pages where the theme is used.”

    This is what I am getting at. When you make a new template part it seems to be stored in the theme folder of a FSE theme. If you make edits to a template part in a FSE theme those seem to be stored in the theme files. This is problematic in a Multisite setup since the theme is shared by all users. I was hoping to learn that in a Multisite setup the FSE themes handle things differently to keep edits independent for each site using the FSE theme.

    Thread Starter Jon Breitenbucher

    (@kahless)

    @tracyrosen Thought about that but it wouldn’t display Log out if you were logged in. Not that anyone logs out of any website on purpose.

    Thread Starter Jon Breitenbucher

    (@kahless)

    That template part was inside the Header (Small, Dark) template part which had the link color set to the same as background. Sheesh.

    Thread Starter Jon Breitenbucher

    (@kahless)

    Thanks. Yep, I noticed the same thing. It shouldn’t be doing that with all the text settings for all the blocks set to black.

    Thread Starter Jon Breitenbucher

    (@kahless)

    Switched from Columns block to a Row block and that solves the layout issue but the Login/out text still does not display. *scratches head*

    <!-- wp:group {"style":{"color":{"background":"#f2f2f2"}},"textColor":"black","className":"header-bar","layout":{"type":"flex","flexWrap":"nowrap","justifyContent":"space-between"}} -->
    <div class="wp-block-group header-bar has-black-color has-text-color has-background" style="background-color:#f2f2f2"><!-- wp:site-title {"style":{"elements":{"link":{"color":{"text":"var:preset|color|black"}}},"typography":{"fontStyle":"normal","fontWeight":"700","fontSize":"26px"}},"textColor":"black"} /-->
    
    <!-- wp:group {"style":{"spacing":{"blockGap":"10px"}},"textColor":"foreground","layout":{"type":"flex","flexWrap":"nowrap"}} -->
    <div class="wp-block-group has-foreground-color has-text-color"><!-- wp:navigation {"ref":7636,"textColor":"foreground","className":"main-nav\u002d\u002ddesktop","layout":{"type":"flex","justifyContent":"left"},"style":{"typography":{"fontSize":"16px"},"spacing":{"blockGap":"10px"}}} /-->
    
    <!-- wp:loginout /--></div>
    <!-- /wp:group --></div>
    <!-- /wp:group -->
    Thread Starter Jon Breitenbucher

    (@kahless)

    @zoonini Thanks.

    I think I get it now. Just a paradigm shift. However, it does present a challenge of creating what looks like a consistent menu in the header. My attempt doesn’t seem to have worked as you can see on the demo site I linked. The Login/out block is at the end of the navigation but seems to be hidden. The header is built with a Cover block (the top bit) and a Row block. The row has Site Title block and a Columns block (two columns). The first column has a Navigation block and the second has the Login/out block. All text has been set to black in all the setting spots I can find and the Login/out text still seems not to be displayed. It also is challenging to try and get the spacing to work so the navigation and login don’t wrap. Here is the code

    <!-- wp:group {"style":{"color":{"background":"#f2f2f2"}},"textColor":"black","className":"header-bar","layout":{"type":"flex","flexWrap":"nowrap","justifyContent":"space-between"}} -->
    <div class="wp-block-group header-bar has-black-color has-text-color has-background" style="background-color:#f2f2f2"><!-- wp:site-title {"style":{"elements":{"link":{"color":{"text":"var:preset|color|black"}}},"typography":{"fontStyle":"normal","fontWeight":"700","fontSize":"26px"}},"textColor":"black"} /-->
    
    <!-- wp:columns {"style":{"spacing":{"blockGap":"10px"}},"textColor":"foreground"} -->
    <div class="wp-block-columns has-foreground-color has-text-color"><!-- wp:column {"width":"80%","textColor":"foreground","layout":{"inherit":true}} -->
    <div class="wp-block-column has-foreground-color has-text-color" style="flex-basis:80%"><!-- wp:navigation {"ref":7636,"textColor":"foreground","className":"main-nav\u002d\u002ddesktop","layout":{"type":"flex","justifyContent":"left"},"style":{"typography":{"fontSize":"16px"},"spacing":{"blockGap":"10px"}}} /--></div>
    <!-- /wp:column -->
    
    <!-- wp:column {"width":"20%","style":{"spacing":{"blockGap":"0px"}},"textColor":"foreground","layout":{"inherit":true}} -->
    <div class="wp-block-column has-foreground-color has-text-color" style="flex-basis:20%"><!-- wp:loginout /--></div>
    <!-- /wp:column --></div>
    <!-- /wp:columns --></div>
    <!-- /wp:group -->

    I have encountered the same issue. I created a CPT pod and enabled archives for the pod. I have Auto Templates enabled and for the list template have told it to use the Staff list template I created

    <span style="float:left">{@post_thumbnail.medium}</span><h2><a href="{@permalink,esc_url}" title="{@post_title}">{@post_title}</a>,{@position}</h2>
    <p>[if office]{@office} | 
    	[else]
    	[/if]
    	[if phone-number]{@phone-number} | 
    	[else] 
    	[/if]
    	[if email]{@email}
    	[else]
    	[/if]
    </p>
    <h3>Can help with:</h3>
    <div style="padding-bottom: 1em;">
    <ul style="list-style-type:none;">
    	[each area_of_expertise]
    	<li style="display:inline-block; padding-right: 5px;"><a href="{@permalink,esc_url}">{@name}</a></li>
    	[/each]
    </ul>
    </div>

    and told it to put it befor the_excerpt. However what displays is just the post title, featured image, and exceprt as dictated by the default archive file of the theme. A modified version of this saved as Employee page template displays for the single posts in the CPT.

    Thread Starter Jon Breitenbucher

    (@kahless)

    Never mind. I’m an idiot and just notice that message 6 says printf and not sprintf. Hopefully someone else benefits from this lesson in carefully checking your code. <facepalm>

    Thread Starter Jon Breitenbucher

    (@kahless)

    Figured it out and here is what worked for me:

    if ( function_exists( 'add_filter' ) ) {
    	add_filter( 'wpmu_validate_blog_signup', 'jb_wpmu_validate_blog_signup' );
    }
    
    function jb_wpmu_validate_blog_signup( $result ) {
    
    	$olderrors = $result[ 'errors' ];
    
    	// If Site Name ('blogname') is long enough,
    	// and we have no error object, just return.
    	if ( ! is_object( $olderrors ) ) {
    	    return $result;
    	}
    
    	// Build a new WP_Error Object to hold new errors.
    	$errors = new WP_Error();
    
    	// Look for a 'blogname' $code error in this loop.
    	foreach ( $olderrors->errors as $code => $error ) {
    	if ( $code == 'blogname' ) {
    	    // Sort the 'blogname' error $value with this loop.
    	    foreach ( $error as $key => $value ) {
    	        // Switch each action based on the $error $value
    	        // and our slected options.
    	        switch ( $value ) {
    
    	            case "Only lowercase letters (a-z) and numbers are allowed.":
    	                $ok_chars = '-';
    
    	                $pattern = '/^[a-z0-9]+([' . $ok_chars . ']?[a-z0-9]+)*$/';
    	                preg_match( $pattern, $result[ 'blogname' ], $match );
    
    	                    if ( $result[ 'blogname' ] != $match[ 0 ] ) {
    	                        // Build a new error to add to the $errors object
    	                        // Allow Lowercase Letters
    	                        $ok_chars = __( 'Only the following Characters are allowed: lowercase letters (a-z), numbers (0-9) and hyphen (-).' );
    
    	                            // Add the new error to the $errors object
    	                            $errors->add( 'blogname', $ok_chars );
    	                    }
    
    	                break;
    
    	            case "That name is not allowed.":
    	                // Do Nothing, just break
    	                break;
    
    	            case "Site name must be at least 4 characters.":
    	                // Do Nothing, just break
    	                break;
    
    	            case "Sorry, site names may not contain the character “_”!":
    	                // Do Nothing, just break
    	                break;
    
    	            case "Sorry, you may not use that site name.":
    	                // Do Nothing, just break
    	                break;
    
    	            case "Sorry, site names must have letters too!":
    	                // Do Nothing, just break
    	                break;
    
    	            case "Sorry, that site is reserved!":
    	                // Do Nothing, just break
    	                break;
    				default:
    				    $errors->add( 'blogname', $value );
    			} // end switch ($value)
    	    } // end foreach ($error as $key => $value)
    	} else {
    	    // Add other errors to $error object from the nested arrays.
    	        foreach ( $error as $key => $value ) {
    	            $errors->add( $code, $value );
    	        }
    	} // end if ($code == 'blogname')
    	} // end foreach ($olderrors->errors as $code => $error)
    
    	// Unset old errors object in $result
    	    unset( $result[ 'errors' ] );
    	// Set new errors object in $result
    	    $result[ 'errors' ] = $errors;
    
    	return $result;
    } // end function jb_wpmu_validate_blog_signup

    Just put that in a plugin and network enable it. This is based off of code from TuKod MultiSite Site Names https://www.ads-software.com/plugins/tukod-multisite-site-names/ which does not seem to work since it appears the error strings in wpmu_validate_blog_signup have changed since the plugin was last updated.

    Thread Starter Jon Breitenbucher

    (@kahless)

    I’m trying something like

    add_filter( 'wpmu_validate_blog_signup', 'jb_wpmu_validate_blog_signup' );
    
    function jb_wpmu_validate_blog_signup( $result ) {
    
    	$pattern = '/^[a-z0-9]+(['-']?[a-z0-9]+)*$/';
    
    	if ( preg_match( $pattern, $result[ 'blogname' ] ) )
    	    $errors->add('blogname', __( 'Only lowercase letters (a-z), numbers and hyphens are allowed.' ) );
    
    	// Unset old errors object in $result
    	    unset( $result[ 'errors' ] );
    	// Set new errors object in $result
    	    $result[ 'errors' ] = $errors;
    
    	return $result;
    }

    but this just returns a signup page with no content.

    Also interested in a Multisite solution.

    Thread Starter Jon Breitenbucher

    (@kahless)

    Replacing line 368 with

    $options['args'] = (isset($options['args']) ? $options['args'] : '');
        if ( $options['args'] == '') {
            echo wp_tag_cloud($options['args'] = $options['args'] . "&taxonomy=". $options['mode'] ."&number=" . $options['number'] . "&orderby=" . $options['orderBy'] . "&order=" . $options['sortOrder'] . "&smallest=" . $options['smallest']  . "&largest=" . $options['biggest']);
        }

    seems to remove the warning.

    Thread Starter Jon Breitenbucher

    (@kahless)

    Checked plugins again and found it was a conflict with Easy Table Creator which seems to no longer be in the repository.

    Thread Starter Jon Breitenbucher

    (@kahless)

    Thanks Nick.

    So there really isn’t a way to accomplish what I’m after.

    I’m pretty sure doing a check for has_post_thumbnail() won’t accomplish the job since it can’t handle the fact that a user may have chosen not to show the thumbnails in a particular widget area, and since there are multiple widget areas, I can’t really use a class of a particular area.

    I may be stumped.

Viewing 15 replies - 1 through 15 (of 43 total)