Add a new block inside Orders meta box in Woocommerce









up vote
2
down vote

favorite
1












I am trying to add a new block inside the Orders meta box from Woocommerce. I know there are three possible hooks to add custom data to the existing blocks.



  • woocommerce_admin_order_data_after_order_details

  • woocommerce_admin_order_data_after_billing_address

  • woocommerce_admin_order_data_after_shipping_address

These hooks are executed inside an order_data_column block and that's what I do not want to do. I would like to add a new custom order_data_column with my custom data.



I tried it creating a new class which extends the WC_Meta_Box_Order_Data and overriding the output method but it did not work...










share|improve this question



























    up vote
    2
    down vote

    favorite
    1












    I am trying to add a new block inside the Orders meta box from Woocommerce. I know there are three possible hooks to add custom data to the existing blocks.



    • woocommerce_admin_order_data_after_order_details

    • woocommerce_admin_order_data_after_billing_address

    • woocommerce_admin_order_data_after_shipping_address

    These hooks are executed inside an order_data_column block and that's what I do not want to do. I would like to add a new custom order_data_column with my custom data.



    I tried it creating a new class which extends the WC_Meta_Box_Order_Data and overriding the output method but it did not work...










    share|improve this question

























      up vote
      2
      down vote

      favorite
      1









      up vote
      2
      down vote

      favorite
      1






      1





      I am trying to add a new block inside the Orders meta box from Woocommerce. I know there are three possible hooks to add custom data to the existing blocks.



      • woocommerce_admin_order_data_after_order_details

      • woocommerce_admin_order_data_after_billing_address

      • woocommerce_admin_order_data_after_shipping_address

      These hooks are executed inside an order_data_column block and that's what I do not want to do. I would like to add a new custom order_data_column with my custom data.



      I tried it creating a new class which extends the WC_Meta_Box_Order_Data and overriding the output method but it did not work...










      share|improve this question















      I am trying to add a new block inside the Orders meta box from Woocommerce. I know there are three possible hooks to add custom data to the existing blocks.



      • woocommerce_admin_order_data_after_order_details

      • woocommerce_admin_order_data_after_billing_address

      • woocommerce_admin_order_data_after_shipping_address

      These hooks are executed inside an order_data_column block and that's what I do not want to do. I would like to add a new custom order_data_column with my custom data.



      I tried it creating a new class which extends the WC_Meta_Box_Order_Data and overriding the output method but it did not work...







      php wordpress woocommerce hook-woocommerce orders






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Nov 12 at 12:45









      LoicTheAztec

      83.5k125993




      83.5k125993










      asked Nov 12 at 2:54









      Alex Foo

      236




      236






















          1 Answer
          1






          active

          oldest

          votes

















          up vote
          2
          down vote



          accepted










          You can add a block to orders metabox using the following code (for example):



          add_action( 'woocommerce_admin_order_data_after_shipping_address', 'additional_admin_order_data_block_after_shipping_address', 100 );
          function additional_admin_order_data_block_after_shipping_address()

          echo '</div><div class="order_data_column">
          <h3>' . esc_html__( 'Block title', 'woocommerce' ) . '</h3>';

          // here goes your code and content

          // Fake content output just for testing
          echo '<p>Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum tortor quam, feugiat vitae, ultricies eget, tempor sit amet, ante.</p>';



          Code goes in function.php file of your active child theme (active theme). Tested and works.



          enter image description here




          But you will need to change some styling CSS rules (which is another question).







          share|improve this answer




















          • That's a good solution!
            – Alex Foo
            Nov 14 at 2:23










          Your Answer






          StackExchange.ifUsing("editor", function ()
          StackExchange.using("externalEditor", function ()
          StackExchange.using("snippets", function ()
          StackExchange.snippets.init();
          );
          );
          , "code-snippets");

          StackExchange.ready(function()
          var channelOptions =
          tags: "".split(" "),
          id: "1"
          ;
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function()
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled)
          StackExchange.using("snippets", function()
          createEditor();
          );

          else
          createEditor();

          );

          function createEditor()
          StackExchange.prepareEditor(
          heartbeatType: 'answer',
          autoActivateHeartbeat: false,
          convertImagesToLinks: true,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: 10,
          bindNavPrevention: true,
          postfix: "",
          imageUploader:
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          ,
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          );



          );













          draft saved

          draft discarded


















          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53255411%2fadd-a-new-block-inside-orders-meta-box-in-woocommerce%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown

























          1 Answer
          1






          active

          oldest

          votes








          1 Answer
          1






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes








          up vote
          2
          down vote



          accepted










          You can add a block to orders metabox using the following code (for example):



          add_action( 'woocommerce_admin_order_data_after_shipping_address', 'additional_admin_order_data_block_after_shipping_address', 100 );
          function additional_admin_order_data_block_after_shipping_address()

          echo '</div><div class="order_data_column">
          <h3>' . esc_html__( 'Block title', 'woocommerce' ) . '</h3>';

          // here goes your code and content

          // Fake content output just for testing
          echo '<p>Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum tortor quam, feugiat vitae, ultricies eget, tempor sit amet, ante.</p>';



          Code goes in function.php file of your active child theme (active theme). Tested and works.



          enter image description here




          But you will need to change some styling CSS rules (which is another question).







          share|improve this answer




















          • That's a good solution!
            – Alex Foo
            Nov 14 at 2:23














          up vote
          2
          down vote



          accepted










          You can add a block to orders metabox using the following code (for example):



          add_action( 'woocommerce_admin_order_data_after_shipping_address', 'additional_admin_order_data_block_after_shipping_address', 100 );
          function additional_admin_order_data_block_after_shipping_address()

          echo '</div><div class="order_data_column">
          <h3>' . esc_html__( 'Block title', 'woocommerce' ) . '</h3>';

          // here goes your code and content

          // Fake content output just for testing
          echo '<p>Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum tortor quam, feugiat vitae, ultricies eget, tempor sit amet, ante.</p>';



          Code goes in function.php file of your active child theme (active theme). Tested and works.



          enter image description here




          But you will need to change some styling CSS rules (which is another question).







          share|improve this answer




















          • That's a good solution!
            – Alex Foo
            Nov 14 at 2:23












          up vote
          2
          down vote



          accepted







          up vote
          2
          down vote



          accepted






          You can add a block to orders metabox using the following code (for example):



          add_action( 'woocommerce_admin_order_data_after_shipping_address', 'additional_admin_order_data_block_after_shipping_address', 100 );
          function additional_admin_order_data_block_after_shipping_address()

          echo '</div><div class="order_data_column">
          <h3>' . esc_html__( 'Block title', 'woocommerce' ) . '</h3>';

          // here goes your code and content

          // Fake content output just for testing
          echo '<p>Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum tortor quam, feugiat vitae, ultricies eget, tempor sit amet, ante.</p>';



          Code goes in function.php file of your active child theme (active theme). Tested and works.



          enter image description here




          But you will need to change some styling CSS rules (which is another question).







          share|improve this answer












          You can add a block to orders metabox using the following code (for example):



          add_action( 'woocommerce_admin_order_data_after_shipping_address', 'additional_admin_order_data_block_after_shipping_address', 100 );
          function additional_admin_order_data_block_after_shipping_address()

          echo '</div><div class="order_data_column">
          <h3>' . esc_html__( 'Block title', 'woocommerce' ) . '</h3>';

          // here goes your code and content

          // Fake content output just for testing
          echo '<p>Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum tortor quam, feugiat vitae, ultricies eget, tempor sit amet, ante.</p>';



          Code goes in function.php file of your active child theme (active theme). Tested and works.



          enter image description here




          But you will need to change some styling CSS rules (which is another question).








          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Nov 12 at 12:45









          LoicTheAztec

          83.5k125993




          83.5k125993











          • That's a good solution!
            – Alex Foo
            Nov 14 at 2:23
















          • That's a good solution!
            – Alex Foo
            Nov 14 at 2:23















          That's a good solution!
          – Alex Foo
          Nov 14 at 2:23




          That's a good solution!
          – Alex Foo
          Nov 14 at 2:23

















          draft saved

          draft discarded
















































          Thanks for contributing an answer to Stack Overflow!


          • Please be sure to answer the question. Provide details and share your research!

          But avoid


          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.

          To learn more, see our tips on writing great answers.





          Some of your past answers have not been well-received, and you're in danger of being blocked from answering.


          Please pay close attention to the following guidance:


          • Please be sure to answer the question. Provide details and share your research!

          But avoid


          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.

          To learn more, see our tips on writing great answers.




          draft saved


          draft discarded














          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53255411%2fadd-a-new-block-inside-orders-meta-box-in-woocommerce%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown







          這個網誌中的熱門文章

          What does pagestruct do in Eviews?

          Dutch intervention in Lombok and Karangasem

          Channel Islands