• Resolved austintude

    (@austintude)


    I have modified several of the template pages (single.php, header-bar.php, footer.php, style.css – to name just a few) by hand so they maintain a level of consistency with the rest of the website which is 100% AMP valid, but…

    When the AMP plugin is updated, I have to replace the new template files with the old ones I modified previously. Is there no way to create some form of child-theme-plugin for the AMP plugin so that when the updates occur, my child-theme overwrites the template files?

    Is there, perhaps, a better way to do this instead of the way I am doing it currently?

    Also, the comments section does not work seamlessly. In order for a visitor to leave a comment, they get kicked out of the AMPed version of the post and are redirected to the non-AMP post. As such, I cannot then keep my promise to the client that their site is to be 100% AMP valid, even with the WordPress portion of their site.

    Is there a way to call the comments and allow them to post from within the AMPed post version?

    Thanks in advance

    • This topic was modified 6 years, 6 months ago by austintude.

    The page I need help with: [log in to see the link]

Viewing 15 replies - 1 through 15 (of 18 total)
  • Plugin Author Weston Ruter

    (@westonruter)

    For how to write template files in your theme, see: https://github.com/Automattic/amp-wp/wiki/Legacy-Templating-And-Customization

    But going forward, the recommended way to write custom templates is to use amp theme support. This is where built-in support for comments is available in AMP. For more on that, read https://github.com/Automattic/amp-wp/wiki/Adding-Theme-Support

    Ref: conversation at https://amphtml.slack.com/archives/C4J8QHGBZ/p1527707240000153

    Thread Starter austintude

    (@austintude)

    Can I ask for a bit of clarification as to implementing the amp-templates directory both the call in the functions.php of the child-theme but also in the exact location for the folder?

    As in, let’s say I have my WP root folder in /blog so you’d see /blog/wp-content/themes etc… do I place the amp-templates folder /blog/amp-templates or do I place them amp-templates/blog (prior to the actual WP folder but literally in the root for the site)?

    Thread Starter austintude

    (@austintude)

    I guess this also goes hand-in-hand with implementing the comments in the functions.php of the child-theme.

    I’m doing my best to work within the .php framework, but I’m not really a .php-er!

    Thread Starter austintude

    (@austintude)

    OK… so when I do that I break the page. now I see why:

    <style amp-custom>
    /* https://tichplatform.com/content/wp-content/themes/tichplatform-child/style.css?ver=4.9.6 */
    /*
    Theme Name: TICH Platform Child
    Theme URI: https://tichplatform.com/tichplatform-child/
    description: TICH Platform Child Theme
    Author: Daniel Bisett
    Author URI: https://austintatiousdesign.co
    Template: twentyseventeen
    Version: 1.0.0
    License: GNU General Public License v2 or later
    License URI: https://www.gnu.org/licenses/gpl-2.0.html
    Tags: tich-platform
    Text Domain: twenty-seventeen-child
    */
    /* https://tichplatform.com/content/wp-content/plugins/amp/assets/css/amp-default.css?ver=0.7.1 */
    .amp-wp-enforced-sizes {
        /** Our sizes fallback is 100vw, and we have a padding on the container; the max-width here prevents the element from overflowing. **/
        max-width: 100%;
        margin: 0 auto;
    }
    
    .amp-wp-unknown-size img {
        /** Worst case scenario when we can’t figure out dimensions for an image. **/
        /** Force the image into a box of fixed dimensions and use object-fit to scale. **/
        object-fit: contain;
    }
    .amp-wp-inline-f62a86b1328cd4134bec55ddf6de989a { font-weight:400; }.amp-wp-inline-37231caf18e4f6dba523e976410afe9a { overflow:hidden; position:absolute; }</style>

    the hangup is that I have two stylesheets depending on which type of blog post is being pulled

    also,
    so it is pulling in the css from the style.css inside the child-theme HOWEVER, it is not pulling in the associated amp-scripts that are in the single.php …

    It’s bizarre. It is clearly pulling in the <body> from the single.php template from within the amp plugin, but not the <head>

    Thread Starter austintude

    (@austintude)

    My current child-theme > functions.php :

    <?php
    //* Code goes here
    add_action( 'wp_enqueue_scripts', 'enqueue_parent_styles' );
    add_action( 'after_setup_theme', 'twentyseventeen_setup' );
    
    function enqueue_parent_styles() {
       wp_enqueue_style( 'parent-style', get_template_directory_uri().'/style.css' );
    }
    
    /**
     * Replaces "[...]" (appended to automatically generated excerpts) with ... and
     * a 'Continue reading' link.
     *
     * @since Twenty Seventeen 1.0
     *
     * @param string $link Link to single post/page.
     * @return string 'Continue reading' link prepended with an ellipsis.
     */
    function twentyseventeen_excerpt_more_amp( $link ) {
    	if ( is_admin() ) {
    		return $link;
    	}
    
    	$link = sprintf( '<p class="link-more"><a href="%1$samp/" class="more-link" target="_blank">%2$s</a></p>',
    		esc_url( get_permalink( get_the_ID() ) ),
    		/* translators: %s: Name of current post */
    		sprintf( __( 'Continue reading<span class="screen-reader-text"> "%s"</span>', 'twentyseventeen' ), get_the_title( get_the_ID() ) )
    	);
    	return ' &hellip; ' . $link;
    }
    add_filter( 'excerpt_more', 'twentyseventeen_excerpt_more_amp', 11 );
    
    add_filter( 'after_setup_theme', function() {
        add_theme_support( 'amp', array(
            'template_dir'       => 'amp-templates', // example value
            'available_callback' => 'is_singular',  // example
            'comments_live_list' => true // example 
        ) );
    } );

    The important part is the:

    add_filter( 'after_setup_theme', function() {
        add_theme_support( 'amp', array(
            'template_dir'       => 'amp-templates', // example value
            'available_callback' => 'is_singular',  // example
            'comments_live_list' => true // example 
        ) );
    } );

    Is attempting to call the directory amp-templates which is located inside the child-theme > amp-templates

    so that it can access the various files from which it will build the AMPed post.

    However, even though I have EVERY template/file from the original wp-content > plugin > amp > templates > inside the new folder in the child-theme > amp-templates >
    The end result is a blank page.
    Upon viewing the source, you can see that none of the information was pulled through:

    
    <!DOCTYPE html>
    <html amp><head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width,minimum-scale=1">
    <style amp-custom=""></style>
    <script type="application/ld+json">{"@context":"http:\/\/schema.org","publisher":{"@type":"Organization","name":"TICH Platform","logo":{"@type":"ImageObject","url":"http:\/\/tichplatform.com\/content\/wp-content\/uploads\/2018\/05\/tich-logo.png","width":193,"height":60}},"@type":"Article","mainEntityOfPage":"http:\/\/tichplatform.com\/content\/blog\/","headline":"Blog","datePublished":"2018-05-29T21:54:46+00:00","dateModified":"2018-05-29T21:54:46+00:00","author":{"@type":"Person","name":"austintude"},"image":false}</script><link rel="canonical" href="https://tichplatform.com/content/blog/">
    </head></html>

    I’m currently at a loss.

    I have tried both:
    'template_dir' => 'amp-templates', and 'template_dir' => 'amp-templates/',
    to no avail.

    I have also tried:

    add_action( 'after_setup_theme', function() {
        add_theme_support( 'amp', array(
            'template_dir' => 'amp/',
            'available_callback' => 'is_singular', 
        ) 
    );

    as was mentioned in Weston’s response to a similar issue: https://www.ads-software.com/support/topic/displaying-wp-comments/#post-10104789

    but the add_action broke the page entirely, so that was a bust.

    I don’t know where to go from here, so I need guidance.

    Thank you.

    Plugin Author Weston Ruter

    (@westonruter)

    What are the error messages shown?

    Thread Starter austintude

    (@austintude)

    Unfortunately, no error messages at all. It is just a blank browser window. By doing inspect element can i see what actually pulled through.

    Plugin Author Weston Ruter

    (@westonruter)

    You should add the WP_DEBUG constant in your wp-config.php, and that should cause any error messages to be displayed.

    Thread Starter austintude

    (@austintude)

    I have added this to the wp_config.php:

    define('WP_DEBUG', true);
    define('WP_DEBUG_LOG', true);
    define('WP_DEBUG_DISPLAY', true);
    @ini_set('display_errors',E_ALL);

    And there was no debug.log created in the wp-content folder…

    But still yield a white/blank browser window.
    Try it for yourself:
    https://tichplatform.com/content/blog/amp/

    What else can I do?

    • This reply was modified 6 years, 6 months ago by austintude.
    Thread Starter austintude

    (@austintude)

    Son-of-a-gun! So from the other thread you were commenting on, you (@Weston Ruter) said to just create an amp/ directory within the theme (I’m working with a child-theme to keep my changes from being lost after the parent theme updates).

    What you didn’t mention was that they should also include this in their functions.php `add_filter( ‘after_setup_theme’, function() {
    add_theme_support( ‘amp’, array(
    ‘template_dir’ => ‘amp’, // example value
    ‘available_callback’ => ‘is_singular’, // example
    ‘comments_live_list’ => true // example
    ) );
    } );`
    Which got me to wondering… why would you leave that bit out?

    So, I went back to my functions.php in my child-theme and removed those bits.

    Then updated the folder in my child-theme from amp-templates (which was advice from a different thread) and changed it to amp …

    Reloaded the posts pages, and BOOM it WORKED!!

    So, to verify that MY templates were the ones being called, I deleted all of the original templates from the amp plugin folder… and BOOM IT STILL WORKED!!!

    One further measure. I deactivated and removed the plugin, then re-installed it thus demonstrating what would happen (more or less) after the plugin itself was updated, and relaoded my posts and BOOM, THEY CONTINUED TO WORK!

    So that’s all it took. amp/ directory in the child-theme folder which included all of MY templates, and now the AMP plugin works flawlessly with MY templates, so I won’t have to replace those files after every update and what’s more, my clients’ sites won’t be ‘down’ after an update until I get a chance to ‘fix’ the plugin.

    Thanks Weston, you and your team are SUPERB!

    Daniel

    Plugin Author Weston Ruter

    (@westonruter)

    If you don’t do the add_theme_support('amp') call then you are using the legacy post template mode. That’s fine, but going forward it will be recommended to leave that template system behind.

    Thread Starter austintude

    (@austintude)

    How do i add that without breaking the page? That was causing all ofthe errors…

    • This reply was modified 6 years, 5 months ago by austintude.
    Thread Starter austintude

    (@austintude)

    I’d ask that you remark this unresolved as adding the add_theme_support('amp') totally breaks the plugin’s functionality.

    I’ve tried these three combinations:

    add_filter( 'after_setup_theme', function() {
        add_theme_support( 'amp', array(
            'template_dir'       => 'amp', // example value
            'available_callback' => 'is_singular',  // example
            'comments_live_list' => true // example 
        ) );
    } );

    This one breaks the post entirely yielding a totlally blank browser window.

    I’ve tried

    add_filter( 'after_setup_theme', function() {
        add_theme_support( 'amp', array(
            'available_callback' => 'is_singular',  // example
            'comments_live_list' => true // example 
        ) );
    } );
    

    Removing the template_dir segment which creats a broken post but at least the content pulls through. But, the /amp post is non-existent… and the css is missing

    And I’ve tried removing the available_callback segment as well:

    add_filter( 'after_setup_theme', function() {
        add_theme_support( 'amp', array(        'comments_live_list' => true // example 
        ) );
    } );

    Which creates the same errors as the method above: broken post, no amp/ version, missing css.

    Thoughts?

    • This reply was modified 6 years, 5 months ago by austintude.

    Hi, I have the same issue. I’m trying to load a custom theme templates for AMP.
    I insert this code in functions.php

    add_filter( 'after_setup_theme', function() {
        add_theme_support( 'amp', array(
            'template_dir' => 'AMP_templates'
        ) );
    } );

    And I create a folder with the templates

    The error message shown is:
    Fatal error: Uncaught Error: Using $this when not in object context in /Applications/MAMP/htdocs/sitetest/wp-content/themes/twentyseventeen/AMP_templates/single.php:14 Stack trace: #0 /Applications/MAMP/htdocs/sitetest/wp-includes/template-loader.php(74): include() #1 /Applications/MAMP/htdocs/sitetest/wp-blog-header.php(19): require_once(‘/Applications/M…’) #2 /Applications/MAMP/htdocs/sitetest/index.php(17): require(‘/Applications/M…’) #3 {main} thrown in /Applications/MAMP/htdocs/sitetest/wp-content/themes/twentyseventeen/AMP_templates/single.php on line 14

    Plugin Author Weston Ruter

    (@westonruter)

    First of all, what is the basis for the templates you are wanting to use for AMP? If you are copying the templates from the plugin, then do not use amp theme support. All you need to do is copy them into an amp/ directory in your theme. If, however, you want to serve AMP responses that use the same templates as your theme, or very similar templates, then you should use amp theme support.

Viewing 15 replies - 1 through 15 (of 18 total)
  • The topic ‘Childlike-plugin mods’ is closed to new replies.