Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

Overview: Demo mode is used to present teme theme options to clients. The demo mode is based off the "Clean" theme which reflects a Peak Resort branded site with minimal configurations preset. In this mode, the theme will implement the various style mixins dynamically by using the design control. It is important to note that when in this mode, there should be no mixins implemented in the clients theme file other than the three defalut mixins (@include theme-vouchers-css(), @include theme-rewards-css(), @include fix-header-for-td()) that are required to provide base styles for presenting various plugins.

...

Developer mode is activated by toggling on developer mode. Doing so enables additonal additional developer features inclding including proving access to "Preview Mode", and revealing the mixin export options. This is the standard mode that you shoudl should be in while developing a new theme.

...

Preview Mode

Presentation Preview Mode provides a way to preview your theme with the mixins implemented on the client stylesheet. Enabling Preview Mode disables the Theme Designer styling controls as well as the styles being applied via the UI. This allows you to preview how the theme will look when running in Commerce.
IMPORTANT
Note: It is very important to not include style mixins in the client _theme.scss file when not in preview mode as this will cause CSS conflicts in the theme. When viewing a theme in Presentation Mode, you should comment out any mixins you have added to the stylesheet. DO NOT comment out these plugin mixins until the theme is ready to deploy ((@include theme-vouchers-css(), @include theme-rewards-css(), @include fix-header-for-td())Preview Mode is only available when Demo Mode is enabled.

How to Demo

Demo mode is the default state for Theme DesingerDesigner. There is no configuration necessary to start using it. The controls on the left panel are used to select between the pages you want to view. The controls in the right panel provide the theme options. There is currently a limitation with the checkout page in demo mode in that it will not retain the settings configured on other pages. This should be resolved in the future.

Theme options

Theme options are broken into different categories. Global options are applied site wide. Page specific options are applied only to the loaded page. Developer options should not be used in Demo mode.

Caveats

There are several caveats to be aware of when using theme Designer in Presentation Mode. First is important to be aware that not all theme otions that are available can be configured in theme designer. Some options are accessable only by developers and are not necessarily options availble for clients to pick from. The second caveat is that not all theme options are exportable as mixins. A prime example is color options. These are configured by the developer seperately, so it is important to note what colors will be applied to the primary, secondary, tertiary, page background, card container background, simple header background, and simply footer background in the JIRA card. The 3rd caveat is that you will not be able to preview the color applications on the Checkout Page at this time due to technical limitations in theme designer and loading the Checkout Page will clear any theme options you have already set. It is best to not load the Checkout Page after setting your theme options dueing a demo.

How To Develop Themes

Using Mixins

Theme Designer uses SASS Mixins to implemnt implement theme options. The mixins provide all the CSS necessary to implement the chosen option as well as limited arguments to extend the configuration capabilities [when doing advanced theming]. This means you no longer have to manually write or copy various CSS to apply styles. The mixins ensure consistency in how theme elements are styled for all clients.

...

The Theme Designer UI works by wrapping the various mixins in implementation classes and then toggling thos those classes on and off in the page root element. When you appply app ply mixins to the client theme file, those mixins will conflict with the mixins the UI is selecting. To avoid these conflicts, it is important to enable Preview Mode while developing. If you want to return to demo mode, you most comment out the mixins in the client stylesheet and toggle Preview Mode back off.

Step-By-Step Theming Process

...

  1. Pull a copy of the theme designer branch with git clone git@bitbucket.org:aspenwareunity/commerce-theme-builder.git

  2. Run Theme Designer with the yarn dev command in terminal

  3. Create a duplicate of the Clean Theme directory and rename it to the current client.

...

  1. Update the _colors.scss file in the client theme directory with all of the client color options.

...

  1. Update the _variables.scss file in the client theme directory with the paths to the correct image files.

...

  1. Update the _typography.scss file in the client theme directory with the clients font information.

...

  1. In the Theme Designer source files, open layouts/default.vue and checkout.vue. Locate the scss import

...

  1. statement that targets the client theme. Change the path in both files to point at the client theme directory you are working on. This will make Theme Designer load that clients SCSS into the Design window.

...

  1. Remove any CSS or Mixins if they exist in the _theme.scss file

...

  1. .

...

  1. In Theme Designer, in Presentation Mode, set all of the theme option controls to match the client choices.

...

  1. Enable Developer mode, and click the "Export All Mixins" button.

...

  1. Copy the mixins from the dialog box and paste them into the clients _theme.scss file. Make sure they are uncommented and save the file.

...

  1. In Theme Designer, enable Preview Mode. You should now see the mixins from the clients _theme.scss file being applied.

...

  1. While still in Preview Mode, make any additional configurations necessary to the mixins in the clients _theme.scss file and ensure they appear

...

  1. correct in the Theme Designer preview.

...

12. IMPORTANT: Once the theme looks how you want it, remove the following 3 mixins from the clients _theme.scss file. The CSS being provided by these mixins will already be available in Commerce so if you forget to remoive them from the _theme.scss file you will have two instances of this same CSS in the live site.

  1. Copy the clients entire theme directory from Theme Designer over to the Theme directory in commerce.

...

  1. Fire up a local instance of Commerce, set the environment to the client and QA the entire theme.

...

  1. If it looks good, commit the theme to Commerce source.

  2. IMPORTANT: DO NOT Commit any changes you made in the Theme Designer source.

Known Limitations and Bugs

  1. There is a limitation with the checkout page in demo mode in that it will not retain the settings configured on other pages. This should be resolved in the future.

  2. A code change is necessary to display anything other than the “Clean Theme”, so when developing a theme there is no UI method to view other themes.