Debugging and Inspecting
Last updated
Last updated
Prerequisites:
Installation of ScandiPWA theme
Knowledge of ScandiPWA file structure and UI components
This tutorial assumes that you have installed the ScandiPWA base theme and are familiar with ScandiPWA file structure and UI components.
Go to scandipwa-base
folder and run the following alias
Use the alias frontlogs
or dcf logs -f frontend
to see what the state of your application is.
The following output means that the front-end is ready:
Open the folder scandipwa-base/src/app/design/frontend/Scandiweb/pwa
with your text editor.
It is recommended to open an additional workspace for the vendor theme - add the scandipwa-base/src/vendor/scandipwa/source
folder.
To start the debugging process open Chrome, go to scandipwa.local
and compare the output with your requirements.
For example, say we needed to change the border of the product cart when it’s loading. How to understand where to look and what is the correct component name?
Turns out its pretty easy due to the fact that ScandiPWA uses BEM or Block Element Modifiers. It’s a tool for organizing class names, this lets us have a block that has elements, all with modifiers.
In React it could have the following representation:
The elements are divided using dashes (-
) and the modifiers are divided using underscores (_
).
Why do we need to have the Breadcrumbs-list
and Breadcrumbs-item
? It allows us to have no nesting in our styles.
The specificity of the BEM styles will be very low and thus the rerendering will be very cheap resource wise. When you’re writing the SCSS for them it will look something like this:
Let’s inspect an element:
This means that we need to search in the component called ProductCard
. If you’re using VSCode you can press ctrl + P
to search for files and type in ProductCard
. Select the ProductCard.style.scss
file and you’ll see that right there we have a declaration:
How can we be 100% sure that any element we see inside of our application will be connected and declared in our block?
You must make sure that the block is declared in your element’s file. In this case it’s block="ProductCard"
in the file ProductCard.component.js
which generates the ProductCard
class name, which is the parent block.
Next in the file we see the following element that will generate .ProductCard-Figure
where the block is ProductCard
and element is Figure
, separated by a dash.
You can inspect any element in your browser and look for blocks and elements. Use the class names to easily find the component and style files using the VSCode search function.
If you put an angle bracket before the class name <some-name
, you can easily find the usage of the component is JSX templates.
Chrome developer tool “Components” tab is basically a React debugger tool, which allows you to inspect your components using a debugger. It tells you what state your component is in, what’s in its props and how it’s interacting with them.