Salesforce DX – Static Resources

Salesforce DX – Static Resources

Salesforce DX – Static Resources

Brett M. Nelson - Thursday, June 8, 2017

We have been able to create an Apex class and a Visualforce page so far.  Let's try to add a static resource.

Create the Source

Before we can create a static resource we should have something to put in it.   For that purpose I have created a folder at the root of the sfdx-simple project called static-resources-src and if you guessed that I plan on keeping all the source files for my static resources there you would be correct, good job!

Why didn't I create this within the force-app folder you may be wondering.  It causes an error.  Having a .js file in a PackageDirectory causes the following error when you check the status:

sfdx force:source:status

PS D:\Workspace\Blog\salesforce\sfdx-simple> sfdx force:source:status ERROR running force:source:status: Unexpected file found in package directory: D:\Workspace\Blog\salesforce\sfdx-simple\force-app\app.js. PS D:\Workspace\Blog\salesforce\sfdx-simple>

This is probably because there is no standalone .js file extensions in Salesforce.

In  static-resources-src  I created a folder with the ever so original name of app and in the app folder I added a JavaScript file called app.js this will be where I keep all my app code for now.

app.js

app.js

In case you are wondering I have decided to use plain JavaScript for this since the choice of framework in revilement if you can't send it to the server.

For the app.js I'm just going to create an Immediately-Invoked Function Expression (IIFE) that passes the window object in and logs it to the console.

app.js

;((window)=>{ console.log({window}) })(window)

Since I am on Windows and I don't have any build pipe line in place at the momment I am going to manually zip the app folder, changes the file extension from .zip to .resource and move in to a folder in the force-app/main/default/static-resources.

app.resource

app.resource

Now if we check the status we see that the there are 2 local adds.

sfdx force:source:status Take II

PS D:\Workspace\Blog\salesforce\sfdx-simple> sfdx force:source:status State Full Name Type Workspace Path ───────── ───────── ────────────── ──────────────────────────────────────────────────────────── Local Add app StaticResource force-app\main\default\static-resource\app.resource-meta.xml Local Add app StaticResource force-app\main\default\static-resource\app.resource PS D:\Workspace\Blog\salesforce\sfdx-simple>

Let's push it and see what happens.

Push It

Let's try the sfdx force:source:push command to push our static resource to the scratch org.

sfdx force:source:push

PS D:\Workspace\Blog\salesforce\sfdx-simple> sfdx force:source:push ERROR running force:source:push: ENOENT: no such file or directory, lstat 'D:\Workspace\Blog\salesforce\sfdx-simple\force-app\main\default\static-resource\app.resource-m eta.xml'. PS D:\Workspace\Blog\salesforce\sfdx-simple>

So that doesn't look like it is going to work.

Lets go to our org with the sfdx force:org:open command and add a static resource in the setup menu for now.

app Static Resource Details

app Static Resource Details

ok, so I used a zip file I created from our app source folder but this is suppose to be source driven development and uploading from the Setup menu is going to get old.   Theres also that sfdx force:source:push thing that should be doing this work for us.  If only we could get the generated app.resource-meta.xml to use.

Pull It

No, I'm not talking about my finger.  We are going to use the sfdx force:source:pull command to get any changes that happened in our org back into our local source code.

sfdx force:source:pull

PS D:\Workspace\Blog\salesforce\sfdx-simple> sfdx force:source:pull State Full Name Type Workspace Path ─────── ───────── ────────────── ──────────────────────────────────────────────────────────── Changed app StaticResource force-app\main\default\staticresources\app.resource-meta.xml Changed app StaticResource force-app\main\default\staticresources\app.resource PS D:\Workspace\Blog\salesforce\sfdx-simple>

It pulled everything down into the default folder at force-app\main\default\staticresources\.  This seems like a good enough place to me so I'm going to remove my  oh so dramatically differently named static-resources folder.

Check the App

Now we know we have our static resource in Salesforce lets add a script reference to it on our Contacts.page and verify it is logging the window when the page loads.

First the reference, just add it on the Contacts.page.

app.js reference

Now push once more time.

Last sfdx force:source:push

PS D:\Workspace\Blog\salesforce\sfdx-simple> sfdx force:source:push State Full Name Type Workspace Path ─────── ───────── ──────── ─────────────────────────────────────────────────── Changed Contacts ApexPage force-app\main\default\pages\Contacts.page-meta.xml Changed Contacts ApexPage force-app\main\default\pages\Contacts.page

Now open up the Contats.page with sfdx force:org:open --path apex/Contacts and look at the console.

Contacts Console

sfdx-04-03.PNG

There you have it, our window  object.

Conclusion

Uploading the app static resource was a but annoying but I think we can make it a little easier with something like NPM Scripts, or Gulp Tasks or something.  What would you prefer to try?  Let me know what you think by leaving a comment below, emailing [email protected] or following and yelling at me on Twitter/BrettMN.

Tags