Super Sale Limited Time 50% OFF for All-Access Plans
Save 50% Now

Components are not initialized in NextJs, if they are rendered after the initial app load.


Background:
Using Metronic 9 Tailwind in NextJs with GlobalInit.tsx ( KTComponent.init() ) based component initialization in the _app.tsx.

Problem:
Components which are rendered after the initial app load are not initialized, so resultantly not working. For example, fetching some data from an API and rendering any component like Accordion or DataTable afterwards will not work.

As GlobalInit.tsx has been already executed on app load, at that point the component was not rendered, as its rendered after fetching some remote data.

Bad Workaround:
You have to initialized Metronic components in useEffect hook of each application component, instead of the suggested GlobalInit based initialization in the _app.tsx globally.


Text formatting options
Submit
Click any option to insert into your comment. Select text first to wrap it.
  • **text** to make things bold
  • *text* to emphasize
  • ### Heading to make headings
  • [link text](url) for links
  • ![alt text](image-url) to paste in an image
  • - item to make a list
  • 1. item to make an ordered list
  • > quote to quote somebody
  • `code` for single line of code
  • ```js ... ``` for JS code block
  • ```html ... ``` for HTML code block
  • ```scss ... ``` for SCSS code block
  • ```php ... ``` for PHP code block
  • --- for a horizontal rule
  • happy  :)
  • shocked  :|
  • sad  :(

Replies (1)


Hi,

Thank you for reaching out to us.

The initialization in GlobalInit.tsx will initialize all components rendered synchronously. For asynchronous content rendering, you should reinitialize certain components separately.


fetch(...).then(() => {
KTComponent.init()
})


Regards,
Lauris Stepanovs,
Keenthemes Support Team


Text formatting options
Submit
Click any option to insert into your comment. Select text first to wrap it.
  • **text** to make things bold
  • *text* to emphasize
  • ### Heading to make headings
  • [link text](url) for links
  • ![alt text](image-url) to paste in an image
  • - item to make a list
  • 1. item to make an ordered list
  • > quote to quote somebody
  • `code` for single line of code
  • ```js ... ``` for JS code block
  • ```html ... ``` for HTML code block
  • ```scss ... ``` for SCSS code block
  • ```php ... ``` for PHP code block
  • --- for a horizontal rule
  • happy  :)
  • shocked  :|
  • sad  :(
Text formatting options
Submit
Click any option to insert into your comment. Select text first to wrap it.
  • **text** to make things bold
  • *text* to emphasize
  • ### Heading to make headings
  • [link text](url) for links
  • ![alt text](image-url) to paste in an image
  • - item to make a list
  • 1. item to make an ordered list
  • > quote to quote somebody
  • `code` for single line of code
  • ```js ... ``` for JS code block
  • ```html ... ``` for HTML code block
  • ```scss ... ``` for SCSS code block
  • ```php ... ``` for PHP code block
  • --- for a horizontal rule
  • happy  :)
  • shocked  :|
  • sad  :(