include files -- how to edit
Postby truesdell » Thu Jan 10, 2013 12:17 am
I am new to ShopSite. Using ver 11.
I have the following line in a template:
 Code: [-- include my-footer.html process --] 
  
the path for the file 'my-footer.html' is '/ss-data/templates/includes/my-footer.html'
When I edit that file, the changes do not show up on the site.
I have flushed the cache, used different computers, etc. The change doesn't "take." The file modification date is correct on the server and if I look at the contents of that file ( less /ss-data/templates/includes/my-footer.html ) it shows my changes.
Question 1: how does the [-- include --] directive know to look in /ss-data/templates/includes/ ? Or does it? Is it looking somewhere else? Where would I change that?
Question 2: why isn't this change being read in?
Question 3: am I going against the "ShopSite Way" to edit this include file directly? If so, what's the proper procedure?
Re: include files -- how to edit
Postby Jim » Thu Jan 10, 2013 6:15 am
Question 1: how does the [-- include --] directive know to look in /ss-data/templates/includes/ ? Or does it? Is it looking somewhere else? Where would I change that?
Answer 1: The template code first checks in the data/templates/ directories for any file that is referenced. If the file is not found in that location then it looks in the sc/templates/ directories. If the file isn't found an error will either be displayed on the publish screen or a comment will be inserted in the generated html.
Question 2: why isn't this change being read in?
Answer 2:How do you know that the code is not being read in? Perhaps the include statement is in an [-- IF ... --] block that prevents it from being included, because the conditions of the IF is not met? Or if it is a product template maybe your template is not being called at all because the page template is overriding the template used for products.
Question 3: am I going against the "ShopSite Way" to edit this include file directly? If so, what's the proper procedure?
Answer 3: If you you are editing the include file (or any template file) out side of the ShopSite interface you must make sure that it has the proper permissions and ownership of the publish code won't be able to access the file. But it is perfectly acceptable to edit the file however you want and then ftp the file to the appropriate location on the server. You should not, however, edit any html file that ShopSite generates when the store is published because it will be overwritten the next time you publish the store.
Re: include files -- how to edit
Postby truesdell » Thu Jan 10, 2013 11:50 pm
Thanks for your insight.
I inherited a site which looks like it was implemented with a pretty heavy hand, more likely several heavy hands.
Question 1.1 Can I get deeper info on how the [-- include --] path might be other than those 2 you mentioned?
Is there a config setting somewhere?
The server is live and functioning and a file is getting included; I just don't know which file, specifically, is the one getting included. Somewhere there must be a config file telling the ShopSite engine where to look for include files. It can't be hard-coded because those two paths you mentioned are not on our server.
Re: include files -- how to edit
Postby Jim » Fri Jan 11, 2013 7:23 am
Those two places are the only locations where the template files are located, one is in the store's data directory and the other is in the shopping cart cgi directory. The names of those directories can be change when the store is install. The shopping cgi directory is generally call sc or bo the store's data directory is generally called data or ss-data etc. If you go to Preferences > Hosting services the paths to the directories are listed at the bottom of the screen.
The template files themselves will all be in a /templates/ subdirectory under the data or shopping cart cgi directory. There will then be subdirectories in the templates directory called sc, gc, pages, products, includes, publish, etc each of those directories corresponds to the sections where you can edit templates under Merchandising > Custom Templates , Pages, Product, Includes, Publish, Search, Gift Certificate, Shopping cart etc.
Another possible place where html code could be placed so it will display on all published store pages is Preferences > Layout settings in the Header and Footer sections But the template tags that have the format [-- include ....--] can not be used in that location or any other text field for pages, product, etc.
Note that it is possible for any of the template files to use the [-- include ... --] statement, so you can have an include file that also uses the statement. I believe that it can go up to 32 levels deep so you might have to look through a bunch of files to find what your are looking for.
There is a section on the Utilities > Publish screen where you can enable the printing of the template name as comment in the html that is output. So you can enable that then go to the page with the problem, view the source of the page and find the comment with the template name, just above the area where the problem occurs. That may help in getting closer to finding what file is actually being called.
Re: include files -- how to edit
Postby by truesdell » Fri Jan 11, 2013 4:26 pm
I looked at Utilities > Publish with an eye to enabling comments as that's how I would trace this stuff if I was hand-coding.
At the bottom of that screen I found the [Regenerate] button. I clicked.
Now the include file in question shows up with my edits in place.
That is a problem (and, actually, an entire family of problems) solved.