Hello!
so, on prod, on my header the css is included on the file main_976c2861.css
but, that css file doesn’t have my custom changes (for example the code I added to global.scss).
My code is compiled into main.css, which is not minified.
So basically, after deploying (I’m doing it the old SFTP way for this project), the site looks broken, and to fix it I rename main.css to main_976c2861.css. But I’m sure this flow is somehow broken.
Any help please?
EDIT: just notices that this also happens with main.js and customizer.js files
Are you running gulp --production prior to deploying your changes?
If not, on your local, try running gulp --production and then upload the dist directory. See if that helps. Be sure to run gulp once more on your local before workign again.
If you delete the /dist directory entirely on production do the styles break as expected? You might need to refresh a few times, or clear cache, to confirm.
If that works, then try uploading the newly regenerated /dist from development.
that’s correct.
I renamed /dist and the site reflected that.
I just uploaded a fresh copy and everything is fine
this brought me to two new questions:
I see that the images on /dist are generated with a hash, but my html still use the non-optimized version of the image (without the hash). Am I missing some step?
is it OK to upload the /resources/assets directory? this way my scss files are exposed
Hi all, I just ran into this same issue. Everything works fine on development. When I run yarn build assets are compiled and things go great. Just tried to run a production version by running yarn build:production and the process went smoothly except that my custom changes were not included in the build.
So to be clear… the css file is built and it enqueues just fine. But when I check the content of that css file it seems to contain only the base Bootstrap styles. (I also noticed the JS file was completely empty.)
Makes me wonder what is the difference between build and production that might cause the compiler to skip over my custom styles? Am I missing a config setting somewhere ?
I’ve seen this in Trellis on occasion and have been able to kick it back in gear by renaming my .scss files and then renaming them back. It’s something to do with how the Vagrant box shares your local directories that gets stuck or confused. It might also work to vagrant halt && vagrant up but I didn’t get that far in troubleshooting before finding the renaming fix.
If it’s NOT Trellis, can you tell us more about the environment?
I’m experiencing exactly the same issue. When running yarn build:production all custom styles get discarded. I notice the hash on the compiled css and js files is the same every time.
What I’ve tried:
Deleting the .cache-loader folder.
Renaming the scss files and back as you suggested.
Deleting node_modules and running yarn again.
Running vagrant halt and up again on my Trellis machine
Deleting the dist folder
Haven’t had this problem before with the beta of Sage 9.
I don’t have a Trellis install and I’m also not using Bedrock. This is my first go with Sage and I am loving it so far, but this is a head scratcher.
I’m using a pretty simple development setup on Codeanywhere with an Ubuntu server. As I mentioned, everything works fine in terms of the file enqueing and being served. It’s just not compiled correctly at build.
Here’s my test (other than just seeing the missing design):
Run yarn build and search the main.css file (the file itself and I make sure it’s served in the <head>) for some of my custom selectors. They are there and everything works fine.
Run yarn build:production and then search for the same selectors in the same manner and they are not there. So they are not pulled into the production compile. Strangely, the core Bootstrap css is there, so some files are getting pulled and compiled. Just not all.
I have already tried many of the same things mentioned by @kasperientje, but haven’t tried renaming the .scss files so I will try that. Thanks for the response. Let me know if you have any other ideas.
I know it can be tough to diagnose the problem if you can’t replicate it. I’ve been trying a few things and thought I would mention a few findings.
First, I did notice that for some reason one of my third-party modules was getting picked up and compiled into main (Fancybox). Thinking that perhaps that module was causing problems I deleted it and re-compiled without it. No change. Same error.
Second, I started hiding components in my custom scss just to see if any of them could be causing a problem. I did notice one thing interesting… if I delete my _variables.scss file then Webpack throws a build error that it can’t find certain variables. So it is grabbing the files and trying to compile them. It’s just that all my custom scss is not making it to the final build for some reason.
And again, running a simple yarn build everything works just fine and all my custom styles are included.
I created a fresh Sage theme, made a custom style on it, deployed, and experiencing the same issue. So it’s got to be somewhere in Trellis? OP said he isn’t on Trellis/Bedrock, so I’m confused.
The Problem aren’t the spaces. The brackets from the stroke='#{$navbar-dark-color}' causes the problem. So if we str-replace() the ( with %28 and the ) with %29 you can run yarn run build:production without removing your scss.