skip to Main Content

I need to generate a custom JSON file from custom fields in a custom post type. But I’m not sure what the proper function is for accomplishing this, or if my syntax is anywhere close to correct in the first place. I haven’t worked much with JSON, and have never attempted to create one from dynamic content before.

I’m using an example json file for the mapping plugin I’m using as my model, but I suspect that I’m not writing the array in the right format by using this other JSON file.

In any case, embarrassingly, here’s what I’ve got so far (and it’s definitely not working):

function wpdocs_retailers_json($post_id) {
   $maplocations = Array( ?>
      
      {
         "mapwidth": "1000",
         "mapheight": "500",
         "categories": [ {
            "id": "food",
            "title": "Fast-foods & Restaurants",
            "color": "#a5a5a2",
            "show": "false"
         },
         {
            "id": "dep",
            "title": "Department Stores",
            "color": "#a5a5a2",
            "show": "true"
         },
         {
            "id": "clothing",
            "title": "Clothing & Accessories",
            "color": "#a5a5a2",
            "show": "true"
         },
         {
            "id": "health",
            "title": "Health & Cosmetics",
            "color": "#a5a5a2",
            "show": "true"
         },
         {
            "id": "misc",
            "title": "Miscellaneous",
            "color": "#a5a5a2",
            "show": "true"
         } ],

         <?php if(have_rows('mall_levels', 'option')) { ?>
         "levels": [ {
            <?php while(have_rows('mall_levels', 'option')) {
               the_row();

               $level_svg = get_sub_field('svg_mall_level');
               $level = get_sub_field('what_level_is_this');
            ?>
            "id": "<?php echo esc_html($level->slug); ?>",
            "title": "<?php echo esc_html($level->name); ?>",
            "map": "<?php echo $level_svg; ?>",

               <?php $locargs = array(
                  'post_type' => 'retailers',
                  'post_status' => 'publish',
                  'posts_per_page' => 0,
                  'orderby' => 'title',
                  'order' => 'ASC'
               );

               $locloop = new WP_Query($locargs);

               if($locloop->have_posts()) { ?>

            "locations": [
                  <?php while($locloop->have_posts()) {
                     $locloop->the_post();

                     $space = get_field('space_id'); ?>
               {
               "id": "space-<?php echo $space; ?>",
               "title": "<?php the_title(); ?>",
               "about": "Lorem ipsum",
               "description": "<?php the_content(); ?>",
                     <?php $cats = get_the_terms($post->ID, 'dir_cats');
                     $catsCount = count($cats);

                     if($catsCount = 0) { ?>
               "category": "<?php echo $cat->name; ?>"  
                     <?php }
                     if($catsCount > 0) { ?>
               "category": [<?php echo '"' . __($cat->name) . '"'; ?>]
                     <?php } ?>
               "link": "<?php the_permalink(); ?>",
               "x": "0.3721",
               "y": "0.4296"
               },
                  <?php } //endwhile; ?>
            ]
               <?php } //endif;
            } //endwhile; ?>
         },
      ]
         <?php } //endif; ?>
   }

   <?php );
   $json = json_encode($maplocations);
   $bytes = file_put_contents('mall.json', $json);
}
add_action('save_post_retailers', 'wpdocs_retailers_json');

I think, at least in part, the array needs to be written more like this? But I’m not sure:

"mapwidth" => "1000",
"mapheight" =>"500",
"categories" => Array(
   array(
      "id" => "food",
      "title" => "Fast-foods & Restaurants",
      "color" => "#a5a5a2",
      "show" =>"false"
   ),
   array(
      "id" => "dep",
      "title" => "Department Stores",
      "color" => "#a5a5a2",
      "show" => "true"
   ),

…etc.

Thanks in advance for any guidance you can provide. I apologize for my utter lack of knowledge to begin with on this one. Please be kind.

2

Answers


  1. Chosen as BEST ANSWER

    @cabrerahector Got me super close. After a little more trial and error, the last part of the above needs to go like this:

       $mapjson = json_encode($maplocations);
       $j_dir = get_stylesheet_directory();
       $mapdata = '/json/mall.json';
       file_put_contents($j_dir . $mapdata, $mapjson, LOCK_EX);
    
       update_post_meta($post_id, 'mall, $date);
    }
    add_action('save_post_retailers', 'retailers_map_json', 20);
    

    (note, I did change the name of the function to "retailers_map_json" instead of "wpdocs_retailers_json".


  2. (…) the array needs to be written more like this?

    Yes, you want to use that array syntax to make your life easier in the long run (IMO at least).

    Here are some changes to your code. Untested though so let me know how it goes and/or if you have any further comments/questions.

    function wpdocs_retailers_json($post_id) {
       $maplocations = array(
          "mapwidth" => 1000,
          "mapheight" => 500,
          "categories" => array(
             array(
                "id" => "food",
                "title" => "Fast-foods & Restaurants",
                "color" => "#a5a5a2",
                "show" => "false"
             ),
             array(
                "id" => "dep",
                "title" => "Department Stores",
                "color" => "#a5a5a2",
                "show" => "false"
             ),
             array(
                "id" => "clothing",
                "title" => "Clothing & Accessories",
                "color" => "#a5a5a2",
                "show" => "false"
             ),
             array(
                "id" => "health",
                "title" => "Health & Cosmetics",
                "color" => "#a5a5a2",
                "show" => "false"
             ),
             array(
                "id" => "misc",
                "title" => "Miscellaneous",
                "color" => "#a5a5a2",
                "show" => "false"
             )
          )
       );
    
       // We have map levels, save them to
       // our json file
       if(have_rows('mall_levels', 'option')) {
          $maplocations['levels'] = array();
    
          while(have_rows('mall_levels', 'option')) {
             the_row();
    
             $level_svg = get_sub_field('svg_mall_level');
             $level = get_sub_field('what_level_is_this');
    
             $level_data = array(
                "id" => esc_html($level->slug),
                "title" => esc_html($level->name),
                "map" => $level_svg,
             )
    
             $locargs = array(
                'post_type' => 'retailers',
                'post_status' => 'publish',
                'posts_per_page' => 0,
                'orderby' => 'title',
                'order' => 'ASC'
             );
    
             $locloop = new WP_Query($locargs);
    
             // We have some locations, save them as well
             if($locloop->have_posts()) {
                $level_data['locations'] = array();
    
                while($locloop->have_posts()) {
                   $locloop->the_post();
    
                   $space = get_field('space_id');
                   $title = get_the_title();
                   $content = get_the_content();
                   $cats = get_the_terms(get_the_ID(), 'dir_cats');
                   $permalink = get_permalink();
    
                   $level_data['locations']['id'] = 'space-' . esc_attr($space);
                   $level_data['locations']['title'] = esc_html($title);
                   $level_data['locations']['about'] = 'Lorem Ipsum';
                   $level_data['locations']['description'] = $content;
    
                   if ( count($cats) ) {
                      $level_data['category'] = join(', ', wp_list_pluck($cats, 'name'));
                   }
    
                   $level_data['locations']['link'] = esc_url( $permalink );
                   $level_data['locations']['x'] = '0.3721';
                   $level_data['locations']['y'] = '0.4296';
                }
    
                // Restore original post data
                wp_reset_postdata();
             }
    
             // Add our $level_data array to $maplocations
             $maplocations['levels'][] = $level_data;
          }
       }
    
       // Convert PHP array into JSON string
       $json = json_encode($maplocations);
    
       // Save json string to mall.json
       $bytes = file_put_contents('mall.json', $json);
    }
    add_action('save_post_retailers', 'wpdocs_retailers_json');
    

    Note that file_put_contents('mall.json', $json); probably should use a full path to the folder where you want to store your mall.json file.

    Login or Signup to reply.
Please signup or login to give your own answer.
Back To Top
Search