Skip to content

Adapting the new Seasons skin to display a new field

gary edited this page Sep 2, 2023 · 2 revisions

Adapting the new Seasons skin to display additional GW1000 sensor data

Note: The following instructions apply only to the Seasons skin included in WeeWX v4.7.0 and later which features greater automated configuration for the Seasons skin than earlier versions. Users using the Seasons skin from WeeWX v4.6.3 or earlier should consider upgrading to the WeeWX v4.7.0 version.

Note: Upgrading and existing WeeWX installation to v4.7.0 or later from a v6.6.3 or earlier version does not guarantee the Seasons skin is upgraded to the new automated configuration version of the Seasons skin as skins are not automatically upgraded during a WeeWX upgrade. it may be necessary to manually upgrade/install the Seasons skin in such cases.

From this point on any reference to the Seasons skin should be taken to refer to the Seasons skin shipped with WeeWX v4.7.0 or later unless otherwise specified.

The Seasons skin will automatically display data for most fields contained in the WeeWX wview_extended schema provided the fields are populated with data. Ecowitt gateway devices have the ability to support a rich suite of sensors that provide data that is readily processed and stored by WeeWX but which is not directly supported by the Seasons skin. Within the Seasons skin it is possible to do much of the reconfiguring of the Seasons in the skin config file (rather than the template files) in order to display additional fields from an Ecowitt gateway device.

Seasons skin structure

Whilst most of the adaptation of the Seasons skin to display additional Ecowitt gateway device fields will occur in the skin config file it is useful to understand the modular structure of the Seasons skin. The Seasons skin consists of a main page as well as a number of supporting pages with the main page itself consisting of a number of panels. The content of these pages and panels is generated through a number of Cheetah templates as follows:

Page or panel Template file
Main or Current Conditions page index.html.tmpl
Current Conditions panel current.inc
Celestial panel celestial.inc
High/Low panel hilo.inc
Sensor Status panel sensors.inc
About panel about.inc
History panel history.inc
Celestial page celestial.html.tmpl
Statistics page statistics.html.tmpl
Sensor Status page telemetry.html.tmpl

In most cass when adding a new observation to the Seasons skin a user will want the observation to appear on one or more or all of the following pages/panels:

  • Current Conditions panel
  • High/Low panel
  • History panel
  • Statistics page

The following sections detail the how to add an observation to the above pages and panels.

Note: Depending on the observation/sensor the user may also wish to add details to the Sensor Status page and Sensor Status panel in which case you should refer to the Adapting the new Seasons skin to display sensor status page.

Note: Before making any alterations to the Seasons skin config file, skins/Seasons/skin.conf, it is suggested that a copy of the Seasons skin config file be made so it is possible to easily revert to a working configuration if a mistake is made. For setup.py installs:

$ cp /home/weewx/skins/Seasons/skin.conf /home/weewx/skins/Seasons/skin_orig.conf

or for package installs:

$ cp /etc/weewx/skins/Seasons/skin.conf /etc/weewx/skins/Seasons/skin_orig.conf

To add a new observation to the Current Conditions panel

  1. Make a copy of the existing skin config file if required.

  2. Edit skins/Seasons/skin.conf. If you look at the structure of the file from around line 34 onwards you will notice the [DisplayOptions] stanza, which should look something like:

    # The following section contains variables that determine which observations 
    # and plots will be shown in the template files, and their order.  Like other
    # configuration options, these can be overridden in the weewx config file.
    
    [DisplayOptions]
    
        # Show link to RSS feed?
        show_rss = True
    
        # Show link to NOAA-style summary reports?
        show_reports = True
    
        # This list determines which types will appear in the "current conditions"
        # section, as well as in which order.
        observations_current = outTemp, heatindex, windchill, dewpoint, outHumidity, barometer, windSpeed, rain, rainRate, UV, radiation, lightning_strike_count, inTemp, inHumidity, extraTemp1, extraHumid1, extraTemp2, extraHumid2, pm1_0, pm2_5, pm10_0
    
        # This list determines which types will appear in the "statistics" and
        # "statistical summary" sections, as well as in which order.
        observations_stats = outTemp, heatindex, windchill, dewpoint, outHumidity, barometer, windSpeed, rain, rainRate, ET, hail, hailRate, snow, UV, radiation, lightning_strike_count, lightning_distance, inTemp, inHumidity, extraTemp1, extraHumid1, extraTemp2, extraHumid2, extraTemp3, extraHumid3, extraTemp4, extraHumid4, extraTemp5, extraHumid5, extraTemp6, extraHumid6, extraTemp7, extraHumid7, extraTemp8, extraHumid8, leafTemp1, leafTemp2, leafWet1, leafWet2, soilTemp1, soilTemp2, soilTemp3, soilTemp4, soilMoist1, soilMoist2, soilMoist3, soilMoist4, pm1_0, pm2_5, pm10_0, co, co2, nh3, no2, o3, so2
    
        # This list determines which types will appear in the RSS feed
        observations_rss = outTemp, inTemp, barometer, windSpeed, rain, rainRate, windchill, heatindex, dewpoint, outHumidity, inHumidity
    
        # Some observations display a sum rather than min/max values
        obs_type_sum = rain, ET, hail, snow, lightning_strike_count
    
        # Some observations display only the max value
        obs_type_max = rainRate, hailRate, snowRate, UV
    
        # The sensor status information is used in the sensor pages.  These lists
        # determine which database fields will be shown, as well as the order in
        # which they will be displayed.
        sensor_connections = rxCheckPercent, signal1, signal2, signal3, signal4, signal5, signal6, signal7, signal8
        sensor_batteries = outTempBatteryStatus, inTempBatteryStatus, rainBatteryStatus, hailBatteryStatus, snowBatteryStatus, windBatteryStatus, uvBatteryStatus, txBatteryStatus, batteryStatus1, batteryStatus2, batteryStatus3, batteryStatus4, batteryStatus5, batteryStatus6, batteryStatus7, batteryStatus8
        sensor_voltages = consBatteryVoltage, heatingVoltage, supplyVoltage, referenceVoltage
    
        # This list determines which plots will be shown, as well as the order in
        # which they will be displayed.  The names refer to the plots defined in
        # the ImageGenerator section, without any time span prefix.  For example,
        # the name 'wind' refers to 'daywind', 'weekwind', 'monthwind', and
        # 'yearwind'.
        plot_groups = barometer, tempdew, tempfeel, hum, wind, winddir, windvec, rain, ET, UV, radiation, lightning, tempin, humin, tempext, humext, tempext2, humext2, templeaf, wetleaf, tempsoil, moistsoil, pm
        telemetry_plot_groups =rx, volt
    
        # The list of time spans used within the skin
        periods = day, week, month, year
    
  3. Locate the observations_current setting:

        observations_current = outTemp, heatindex, windchill, dewpoint, outHumidity, barometer, windSpeed, rain, rainRate, UV, radiation, lightning_strike_count, inTemp, inHumidity, extraTemp1, extraHumid1, extraTemp2, extraHumid2, pm1_0, pm2_5, pm10_0
    

observations_current lists the WeeWX fields that will be displayed in the Current Conditions panel. If you had two soil temperature sensors with their data appearing in WeeWX fields soilTemp1 and soilTemp2 and you wanted these fields displayed immediately after the extraHumid2 field in the Current Conditions panel, you would insert soilTemp1 and soilTemp2 in the current_observations list immediately after extraHumid2, eg:

       observations_current = outTemp, heatindex, windchill, dewpoint, outHumidity, barometer, windSpeed, rain, rainRate, UV, radiation, lightning_strike_count, inTemp, inHumidity, extraTemp1, extraHumid1, extraTemp2, extraHumid2, soilTemp1, soilTemp2, pm1_0, pm2_5, pm10_0

Note: Order matters. Observations are displayed in the Current Conditions panel in the order (from top to bottom) they appear in the observations_current setting.

  1. if you save the skin config file you would now see the soiltemp1 and soilTemp2 data appear in the correct location within the Current Conditions panel. However, soiltemp1 and soilTemp2 will not appear anywhere else on the Seasons skin pages (eg on the Statistics page or in any plots). We will address this later.

To add a new observation to the High/Low panel

  1. Make a copy of the existing skin config file if required.

  2. Edit skins/Seasons/skin.conf. If you look at the structure of the file from around line 34 onwards you will notice the [DisplayOptions] stanza, which should look something like:

    # The following section contains variables that determine which observations 
    # and plots will be shown in the template files, and their order.  Like other
    # configuration options, these can be overridden in the weewx config file.
    
    [DisplayOptions]
    
        # Show link to RSS feed?
        show_rss = True
    
        # Show link to NOAA-style summary reports?
        show_reports = True
    
        # This list determines which types will appear in the "current conditions"
        # section, as well as in which order.
        observations_current = outTemp, heatindex, windchill, dewpoint, outHumidity, barometer, windSpeed, rain, rainRate, UV, radiation, lightning_strike_count, inTemp, inHumidity, extraTemp1, extraHumid1, extraTemp2, extraHumid2, pm1_0, pm2_5, pm10_0
    
        # This list determines which types will appear in the "statistics" and
        # "statistical summary" sections, as well as in which order.
        observations_stats = outTemp, heatindex, windchill, dewpoint, outHumidity, barometer, windSpeed, rain, rainRate, ET, hail, hailRate, snow, UV, radiation, lightning_strike_count, lightning_distance, inTemp, inHumidity, extraTemp1, extraHumid1, extraTemp2, extraHumid2, extraTemp3, extraHumid3, extraTemp4, extraHumid4, extraTemp5, extraHumid5, extraTemp6, extraHumid6, extraTemp7, extraHumid7, extraTemp8, extraHumid8, leafTemp1, leafTemp2, leafWet1, leafWet2, soilTemp1, soilTemp2, soilTemp3, soilTemp4, soilMoist1, soilMoist2, soilMoist3, soilMoist4, pm1_0, pm2_5, pm10_0, co, co2, nh3, no2, o3, so2
    
        # This list determines which types will appear in the RSS feed
        observations_rss = outTemp, inTemp, barometer, windSpeed, rain, rainRate, windchill, heatindex, dewpoint, outHumidity, inHumidity
    
        # Some observations display a sum rather than min/max values
        obs_type_sum = rain, ET, hail, snow, lightning_strike_count
    
        # Some observations display only the max value
        obs_type_max = rainRate, hailRate, snowRate, UV
    
        # The sensor status information is used in the sensor pages.  These lists
        # determine which database fields will be shown, as well as the order in
        # which they will be displayed.
        sensor_connections = rxCheckPercent, signal1, signal2, signal3, signal4, signal5, signal6, signal7, signal8
        sensor_batteries = outTempBatteryStatus, inTempBatteryStatus, rainBatteryStatus, hailBatteryStatus, snowBatteryStatus, windBatteryStatus, uvBatteryStatus, txBatteryStatus, batteryStatus1, batteryStatus2, batteryStatus3, batteryStatus4, batteryStatus5, batteryStatus6, batteryStatus7, batteryStatus8
        sensor_voltages = consBatteryVoltage, heatingVoltage, supplyVoltage, referenceVoltage
    
        # This list determines which plots will be shown, as well as the order in
        # which they will be displayed.  The names refer to the plots defined in
        # the ImageGenerator section, without any time span prefix.  For example,
        # the name 'wind' refers to 'daywind', 'weekwind', 'monthwind', and
        # 'yearwind'.
        plot_groups = barometer, tempdew, tempfeel, hum, wind, winddir, windvec, rain, ET, UV, radiation, lightning, tempin, humin, tempext, humext, tempext2, humext2, templeaf, wetleaf, tempsoil, moistsoil, pm
        telemetry_plot_groups =rx, volt
    
        # The list of time spans used within the skin
        periods = day, week, month, year
    
  3. Locate the observations_stats setting:

        observations_stats = outTemp, heatindex, windchill, dewpoint, outHumidity, barometer, windSpeed, rain, rainRate, ET, hail, hailRate, snow, UV, radiation, lightning_strike_count, lightning_distance, inTemp, inHumidity, extraTemp1, extraHumid1, extraTemp2, extraHumid2, extraTemp3, extraHumid3, extraTemp4, extraHumid4, extraTemp5, extraHumid5, extraTemp6, extraHumid6, extraTemp7, extraHumid7, extraTemp8, extraHumid8, leafTemp1, leafTemp2, leafWet1, leafWet2, soilTemp1, soilTemp2, soilTemp3, soilTemp4, soilMoist1, soilMoist2, soilMoist3, soilMoist4, pm1_0, pm2_5, pm10_0, co, co2, nh3, no2, o3, so2
    

observations_stats lists the WeeWX fields that will be displayed in the Statistics panel and on the Statistics page. Following on from the previous soil temperature example, if you had two soil temperature sensors with their data appearing in WeeWX fields soilTemp1 and soilTemp2 and you wanted these fields displayed immediately after the extraHumid2 field in the Statistics panel and Statistics page, you would insert soilTemp1 and soilTemp2 in the observations_stats list immediately after extraHumid2, eg:

       observations_stats = outTemp, heatindex, windchill, dewpoint, outHumidity, barometer, windSpeed, rain, rainRate, ET, hail, hailRate, snow, UV, radiation, lightning_strike_count, lightning_distance, inTemp, inHumidity, extraTemp1, extraHumid1, extraTemp2, extraHumid2, extraTemp3, extraHumid3, extraTemp4, extraHumid4, extraTemp5, extraHumid5, extraTemp6, extraHumid6, extraTemp7, extraHumid7, extraTemp8, extraHumid8, leafTemp1, leafTemp2, leafWet1, leafWet2, soilTemp1, soilTemp2, soilTemp3, soilTemp4, soilMoist1, soilMoist2, soilMoist3, soilMoist4, pm1_0, pm2_5, pm10_0, co, co2, nh3, no2, o3, so2

Note: Order matters. Observations are displayed in the Current Conditions panel in the order (from top to bottom) they appear in the observations_current setting.

  1. if you save the skin config file you would now see the soiltemp1 and soilTemp2 data appear in the correct location within the Current Conditions panel. However, soiltemp1 and soilTemp2 will not appear anywhere else on the Seasons skin pages (eg on the Statistics page or in any plots). We will address this later.

Note: Depending on your system configuration some or all of the following commands may need to be prefixed with sudo or otherwise executed by a user account with privileged system access.

  1. Make a copy of the existing skins/Seasons/hilo.inc so it is possible to easily revert to a working configuration if a mistake is made. For setup.py installs:

    $ cp /home/weewx/skins/Seasons/hilo.inc /home/weewx/skins/Seasons/hilo_orig.inc
    

    or for package installs:

    $ cp /etc/weewx/skins/Seasons/hilo.inc /etc/weewx/skins/Seasons/hilo_orig.inc
    
  2. Edit skins/Seasons/hilo.inc. If you look at the structure of the file from around line 17 onwards you will notice a HTML <table></table> block. The template constructs a HTML table containing columns for today and each other aggregate period used (eg week, month etc) and rows for each observation. Some Javascript is used within the main or Current Conditions page to display only the relevant High/Low columns as different aggregate periods are selected in the History panel. Within the <table></table> block you will notice a repeated series of HTML like code between <tr></tr> HTML tags, for example:

        <tr>
            <td></td>
            <th>&nbsp;<br/>Today</th>
            <th class="hilo_week">&nbsp;<br/>Week</th>
            <th class="hilo_month">&nbsp;<br/>Month</th>
            <th class="hilo_year">
                <a onclick="toggle_rainyear()">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br/>Year</a>
            </th>
            <th class="hilo_rainyear">
                <a onclick="toggle_rainyear()">Rain<br/>Year</a>
            </th>
            <td></td>
        </tr>
        <tr>
            <td class="label">$obs.label.outTemp</td>
            #for $archive in $archive_data
            <td class="data new_row hilo_$archive[0]">
                <span title="$archive[1].outTemp.maxtime">
                    $archive[1].outTemp.max.format(add_label=False)</span><br/>
               <span title="$archive[1].outTemp.mintime">
                    $archive[1].outTemp.min.format(add_label=False)</span>
            </td>
            #end for
            <td class="units">$unit.label.outTemp</td>
        </tr>
        <tr>
            <td class="label">$obs.label.heatindex</td>
            #for $archive in $archive_data
            <td class="data new_row hilo_$archive[0]">
                <span title="$archive[1].heatindex.maxtime" class="hival">
                    $archive[1].heatindex.max.format(add_label=False)</span>
            </td>
            #end for
            <td class="units">$unit.label.heatindex</td>
        </tr>
    

    This particular extract shows three <tr></tr> blocks that display column headings, the outTemp max/min row and the heatindex max row. Each observation utilises a row in a HTML table (the <tr></tr> tags) though some rows such as outTemp display two sub-rows of data, max and min. Each row consists of three fields defined by the three pairs of <td></td> tags. The <td></td> tags with class='label' display the label for the observation. The <td></td> tags with class='data' display the aggregate value and the <td></td> tags with class='units' display the units for the observation. A WeeWX report tag is used to display the relevant label and units. The #for..#end for block is used to iterate over the aggregate periods displayed in the table and appropriate WeeWX report tags are used to display the applicable aggregate value.

  3. Locate where in the list of observations you wish the new observation to appear and then insert the appropriate <tr></tr>/<td></td> lines and WeeWX report tags. For example, and following on from the Current Conditions panel example above, to display the soilMoist1 high/low values immediately after heatindex you might use the following:

        <tr>
            <td class="label">$obs.label.heatindex</td>
            #for $archive in $archive_data
            <td class="data new_row hilo_$archive[0]">
                <span title="$archive[1].heatindex.maxtime" class="hival">
                    $archive[1].heatindex.max.format(add_label=False)</span>
            </td>
            #end for
            <td class="units">$unit.label.heatindex</td>
        </tr>
        <tr>
            <td class="label">$obs.label.soilMoist1</td>
            #for $archive in $archive_data
            <td class="data new_row hilo_$archive[0]">
                <span title="$archive[1].soilMoist1.maxtime">
                    $archive[1].soilMoist1.max.format(add_label=False)</span><br/>
                <span title="$archive[1].soilMoist1.mintime">
                    $archive[1].soilMoist1.min.format(add_label=False)</span>
            </td>
            #end for
            <td class="units">$unit.label.soilMoist1</td>
        </tr>
    

    If you wanted to display just the soilMoist1 high value you might use the following:

        <tr>
            <td class="label">$obs.label.heatindex</td>
            #for $archive in $archive_data
            <td class="data new_row hilo_$archive[0]">
                <span title="$archive[1].heatindex.maxtime" class="hival">
                    $archive[1].heatindex.max.format(add_label=False)</span>
            </td>
            #end for
            <td class="units">$unit.label.heatindex</td>
        </tr>
        <tr>
            <td class="label">$obs.label.soilMoist1</td>
            #for $archive in $archive_data
            <td class="data new_row hilo_$archive[0]">
                <span title="$archive[1].soilMoist1.maxtime" class="hival">
                    $archive[1].soilMoist1.max.format(add_label=False)</span>
            </td>
            #end for
            <td class="units">$unit.label.soilMoist1</td>
        </tr>
    

    Again following on from the Current Conditions panel example above if you were providing this template for use by others who might not have soilMoist1 you might place an #if..#end if statement around your new lines as follows:

        <tr>
            <td class="label">$obs.label.heatindex</td>
            #for $archive in $archive_data
            <td class="data new_row hilo_$archive[0]">
                <span title="$archive[1].heatindex.maxtime" class="hival">
                    $archive[1].heatindex.max.format(add_label=False)</span>
            </td>
            #end for
            <td class="units">$unit.label.heatindex</td>
        </tr>
        #if $day.soilMoist1.has_data
        <tr>
            <td class="label">$obs.label.soilMoist1</td>
            #for $archive in $archive_data
            <td class="data new_row hilo_$archive[0]">
                <span title="$archive[1].soilMoist1.maxtime" class="hival">
                    $archive[1].soilMoist1.max.format(add_label=False)</span>
            </td>
            #end for
            <td class="units">$unit.label.soilMoist1</td>
        </tr>
        #end if    
    

    This way users that do not have a soil moisture sensor will not see a soil moisture label and placeholder in the High/Low panel on their Seasons page.

    The WeeWX report tag $xxxxx.soilMoist1.max.format() will display the maximum soilMoist1 value over the period xxxxx formatted with a unit label as per the relevant format and unit label specifiers in skin.conf or weewx.conf. The tag $obs.label.soilMoist1 displays the label for soilMoist1 from the corresponding entry from [Labels] [[Generic]] is skin.conf or as overridden in weewx.conf. If you wish to label the soilMoist1 field as Front Garden you might include an entry such as the following in the skins/Seasons/skin.conf:

    [Labels]
        [[Generic]]
            ....
            soilMoist1 = Front Garden
    

    Note: You could also place these entries in weewx.conf under [StdReport] [[SeasonsReport]] [[Labels]]] [[[[Generic]]]]. The choice is up to the user, arguably weewx.conf is WeeWX upgrade safe but it is highly unlikely that a WeeWX upgrade will make destructive changes to the skins/Seasons/skin.conf.

  4. Save skins/Seasons/hilo.inc and the next report cycle should see the soilMoist1 data appear in the High/Low panel provided you have soilMoist1 in your archive. Note you may have to refresh the page for the updated data to be displayed.

    Note: Any problems or errors in the modified hilo.inc should not cause WeeWX to exit; however, it may cause WeeWX to fail to generate the Seasons skin main page. In such cases check the WeeWX log for log entries that may indicate the source of the problem. If the problem cannot be immediately fixed you can revert to the original hilo.inc by deleting the modified hilo.inc and re-instating the original hilo.inc. For setup.py installs:

     $ rm /home/weewx/skins/Seasons/hilo.inc
     $ mv /home/weewx/skins/Seasons/hilo_orig.inc /home/weewx/skins/Seasons/hilo.inc
    

    or for package installs:

     $ rm /etc/weewx/skins/Seasons/hilo.inc
     $ mv /etc/weewx/skins/Seasons/hilo_orig.inc /etc/weewx/skins/Seasons/hilo.inc
    

To add a new observation to the History panel

Adding a new observation to the History panel is a two step process. First the Seasons skin needs to be configured to generate any extra plots to be displayed in the History panel and second the Seasons skin needs to be modified to display these extra plots in the History panel.

To generate additional plots

Note: Depending on your system configuration some or all of the following commands may need to be prefixed with sudo or otherwise executed by a user account with privileged system access.

  1. Make a copy of the existing skins/Seasons/skin.conf so it is possible to easily revert to a working configuration if a mistake is made. For setup.py installs:

    $ cp /home/weewx/skins/Seasons/hilo.inc /home/weewx/skins/Seasons/skin.conf
    

    or for package installs:

    $ cp /etc/weewx/skins/Seasons/hilo.inc /etc/weewx/skins/Seasons/skin.conf
    
  2. Edit skins/Seasons/skin.conf. Locate the [ImageGenerator] stanza and then locate the [[day_images]] stanza. The [[day_images]] stanza defines all of the 'day' plots generated by the Seasons skin. If you look further down the file you will notice [[week_images]], [[month_images]] and [[year_images]] stanzas that define the Seasons week, month and year plots respectively. If you look back at the [[day_images]] stanza you will notice it looks something like:

    [[day_images]]
        x_label_format = %H:%M
        bottom_label_format = %x %X
        time_length = 97200 # 27 hours
        
        [[[daybarometer]]]
            [[[[barometer]]]]
        
        [[[daytempdew]]]
            [[[[outTemp]]]]
            [[[[dewpoint]]]]
    

    In this case the [[[daybarometer]]] stanza defines a plot that will consist of the WeeWX barometer field only and the plot image file will be named daybarometer.png. Similarly, the [[[daytempdew]]] stanza defines a plot that will consist of WeeWX fields outTemp and dewpoint and the plot image file will be named daytempdew.png.

  3. To generate a new plot that displays the WeeWX field soilMoist1 over the period of a day you might add a [[[daymoist]]] stanza under [[day_images]] as follows:

    [[day_images]]
        x_label_format = %H:%M
        bottom_label_format = %x %X
        time_length = 97200 # 27 hours
        
        [[[daybarometer]]]
            [[[[barometer]]]]
                        
        [[[daymoist]]]
            [[[[soilMoist1]]]]    
    
        [[[daytempdew]]]
            [[[[outTemp]]]]
            [[[[dewpoint]]]]
    

    This would result in the plot image file daymoist.png being generated.

    Note: Further details on use of the WeeWX Image generator to generate plot files can be found in The Image generator section of the Customization Guide.

To display additional plots

Note: Depending on your system configuration some or all of the following commands may need to be prefixed with sudo or otherwise executed by a user account with privileged system access.

  1. Make a copy of the existing skins/Seasons/index.htm.tmpl so it is possible to easily revert to a working configuration if a mistake is made. For setup.py installs:

    $ cp /home/weewx/skins/Seasons/index.html.tmpl /home/weewx/skins/Seasons/index_orig.html.tmpl
    

    or for package installs:

    $ cp /etc/weewx/skins/Seasons/index.html.tmpl /etc/weewx/skins/Seasons/index_orig.html.tmpl
    
  2. Edit skins/Seasons/index.html.tmpl. If you look at the structure of the file from around line 46 onwards you will notice a HTML <div id="history_day"></div> block that contains numerous HTML <img> tags. This block defines the 'day' plot layout and the <img> tags specify the plots to be displayed, for example:

    <div id="history_day" class="plot_container">
        <img src="daybarometer.png" alt="$obs.label.barometer"/>
        <img src="daytempdew.png"   alt="$obs.label.outTemp" />
        <img src="daytempfeel.png"  alt="$obs.label.feel" />
        <img src="dayhum.png"       alt="$obs.label.outHumidity" />
        <img src="daywind.png"      alt="$obs.label.windSpeed" />
        <img src="daywinddir.png"   alt="$obs.label.windDir" />
        <img src="daywindvec.png"   alt="$obs.label.windvec" />
        <img src="dayrain.png"      alt="$obs.label.rain" />
        #if $day.UV.has_data
        <img src="dayuv.png"        alt="$obs.label.UV" />
        #end if
        #if $day.radiation.has_data
        <img src="dayradiation.png" alt="$obs.label.radiation" />
        #end if
        #if $day.inTemp.has_data
        <img src="daytempin.png"    alt="$obs.label.inTemp" />
        #end if
        #if $day.inHumidity.has_data
        <img src="dayhumin.png"    alt="$obs.label.inHumidity" />
        #end if
        #if $day.extraTemp1.has_data or $day.extraTemp2.has_data or $day.extraTemp3.has_data
        <img src="daytemp.png"      alt="$obs.label.extraTemp1" />
        #end if
        #if $day.rxCheckPercent.has_data
        <img src="dayrx.png"        alt="$obs.label.rxCheckPercent"/>
        #end if
    </div>
    

    Likewise, there are <div id="history_week"></div>, <div id="history_day"></div> and <div id="history_day"></div> blocks to define the 'week', 'month' and 'year' plot layouts.

  3. To display the newly created daymoist.png plot immediately after the extraTemp1/extraTemp2/extraTemp3 (daytemp.png) plot insert a new <img> tag immediately after the daytemp.png #if..#end if as follows:

        #if $day.extraTemp1.has_data or $day.extraTemp2.has_data or $day.extraTemp3.has_data
        <img src="daytemp.png"      alt="$obs.label.extraTemp1" />
        #end if
        <img src="daymoist.png"      alt="$obs.label.soilMoist1" />
    

    or if you were providing the template for a third party and were uncertain whether they have soilMoist1 you might wrap the <img> tag in an #if..#end if statement as follows:

        #if $day.extraTemp1.has_data or $day.extraTemp2.has_data or $day.extraTemp3.has_data
        <img src="daytemp.png"      alt="$obs.label.extraTemp1" />
        #end if
        #if $day.soilMoist1.has_data
        <img src="daymoist.png"      alt="$obs.label.soilMoist1" />
        #end if
    
  4. Repeat step 3 for 'week', 'month' and 'year' in the corresponding <div id="history_xxxx"></div>blocks noting the plot file name will be different for each block.

  5. Save skins/Seasons/index.html.tmpl and the next report cycle should see the soilMoist1 plots appear in the History panel provided you have soilMoist1 in your archive. Note you may have to refresh the page for the updated data to be displayed.

Note: Any problems or errors in the modified index.html.tmpl should not cause WeeWX to exit; however, it may cause WeeWX to fail to generate the Seasons skin main page. In such cases check the WeeWX log for log entries that may indicate the source of the problem. If the problem cannot be immediately fixed you can revert to the original index.html.tmpl by deleting the modified index.html.tmpl and re-instating the original index.html.tmpl. For setup.py installs:

$ rm /home/weewx/skins/Seasons/index.html.tmpl
$ mv /home/weewx/skins/Seasons/index_orig.html.tmpl /home/weewx/skins/Seasons/index.html.tmpl

or for package installs:

$ rm /etc/weewx/skins/Seasons/index.html.tmpl
$ mv /etc/weewx/skins/Seasons/index_orig.html.tmpl /etc/weewx/skins/Seasons/index.html.tmpl

To add a new observation to the Statistics page

Note: Depending on your system configuration some or all of the following commands may need to be prefixed with sudo or otherwise executed by a user account with privileged system access.

  1. Make a copy of the existing skins/Seasons/statistics.inc so it is possible to easily revert to a working configuration if a mistake is made. For setup.py installs:

    $ cp /home/weewx/skins/Seasons/statistics.inc /home/weewx/skins/Seasons/statistics_orig.inc
    

    or for package installs:

    $ cp /etc/weewx/skins/Seasons/statistics.inc /etc/weewx/skins/Seasons/statistics_orig.inc
    
  2. Edit skins/Seasons/statistics.inc. If you look at the structure of the file from around line 15 onwards you will notice a HTML <table></table> block. The template constructs a HTML table containing columns for 'today', 'week', 'month', 'year' and 'rain year' and rows for each observation. Within the <table></table> block you will notice a repeated series of HTML like code between <tr></tr> HTML tags, for example:

    <tr>
        <td></td>
        <td></td>
        <th>Today</th>
        <th class="hilo_week">Week</th>
        <th class="hilo_month">Month</th>
        <th class="hilo_year">Year</th>
        <th class="hilo_rainyear">Rain year</th>
    </tr>
    <tr>
        <td class="label">$obs.label.outTemp</td>
        <td class="units">$unit.label.outTemp</td>
        #for $archive in $archive_data
        <td class="data new_row">$archive.outTemp.max.format(add_label=False)<br/>
            <span class="timestamp">$archive.outTemp.maxtime</span><br/>
            $archive.outTemp.min.format(add_label=False)<br/>
            <span class="timestamp">$archive.outTemp.mintime</span>
        </td>
        #end for
    </tr>
    <tr>
        <td class="label">$obs.label.heatindex</td>
        <td class="units">$unit.label.heatindex</td>
        #for $archive in $archive_data
        <td class="data new_row">$archive.heatindex.max.format(add_label=False)<br/>
            <span class="timestamp">$archive.heatindex.maxtime</span>
        </td>
        #end for
    </tr>
    

    This particular extract shows three <tr></tr> blocks that display column headings, the outTemp max/min row and the heatindex max row. Each observation utilises a row in a HTML table (the <tr></tr> tags) though some rows such as outTemp display two sub-rows of data, max and min. Each row consists of three fields defined by the three pairs of <td></td> tags. The <td></td> tags with class='label' display the label for the observation. The <td></td> tags with class='data' display the aggregate value and the <td></td> tags with class='units' display the units for the observation. A WeeWX report tag is used to display the relevant label and units. The #for..#end for block is used to iterate over the aggregate periods displayed in the table and appropriate WeeWX report tags are used to display the applicable aggregate value.

  3. Locate where in the list of observations you wish the new observation to appear and then insert the appropriate <tr></tr>/<td></td> lines and WeeWX report tags. For example, and following on from the Current Conditions panel example above, to display the soilMoist1 high/low values immediately after heatindex you might use the following:

    <tr>
        <td class="label">$obs.label.heatindex</td>
        <td class="units">$unit.label.heatindex</td>
        #for $archive in $archive_data
        <td class="data new_row">$archive.heatindex.max.format(add_label=False)<br/>
            <span class="timestamp">$archive.heatindex.maxtime</span>
        </td>
        #end for
    </tr>
    <tr>
        <td class="label">$obs.label.soilMoist1</td>
        <td class="units">$unit.label.soilMoist1</td>
        #for $archive in $archive_data
        <td class="data new_row">$archive.soilMoist1.max.format(add_label=False)<br/>
            <span class="timestamp">$archive.soilMoist1.maxtime</span><br/>
            $archive.soilMoist1.min.format(add_label=False)<br/>
            <span class="timestamp">$archive.soilMoist1.mintime</span>
        </td>
        #end for
    </tr>
    

    If you wanted to display just the soilMoist1 high value you might use the following:

    <tr>
        <td class="label">$obs.label.heatindex</td>
        <td class="units">$unit.label.heatindex</td>
        #for $archive in $archive_data
        <td class="data new_row">$archive.heatindex.max.format(add_label=False)<br/>
            <span class="timestamp">$archive.heatindex.maxtime</span>
        </td>
        #end for
    </tr>
    <tr>
        <td class="label">$obs.label.soilMoist1</td>
        <td class="units">$unit.label.soilMoist1</td>
        #for $archive in $archive_data
        <td class="data new_row">$archive.soilMoist1.max.format(add_label=False)<br/>
            <span class="timestamp">$archive.soilMoist1.maxtime</span><br/>
        </td>
        #end for
    </tr>
    

    Again following on from the Current Conditions panel example above if you were providing this template for use by others who might not have soilMoist1 you might place an #if..#end if statement around your new lines as follows:

    <tr>
        <td class="label">$obs.label.heatindex</td>
        <td class="units">$unit.label.heatindex</td>
        #for $archive in $archive_data
        <td class="data new_row">$archive.heatindex.max.format(add_label=False)<br/>
            <span class="timestamp">$archive.heatindex.maxtime</span>
        </td>
        #end for
    </tr>
    #if $day.soilMoist1.has_data
    <tr>
        <td class="label">$obs.label.soilMoist1</td>
        <td class="units">$unit.label.soilMoist1</td>
        #for $archive in $archive_data
        <td class="data new_row">$archive.soilMoist1.max.format(add_label=False)<br/>
            <span class="timestamp">$archive.soilMoist1.maxtime</span><br/>
        </td>
        #end for
    </tr>
    #end if    
    

    This way users that do not have a soil moisture sensor will not see a soil moisture label and placeholder on the Statistics page.

  4. Save skins/Seasons/statistics.inc and the next report cycle should see the soilMoist1 data appear on the Statistics page provided you have soilMoist1 in your archive. Note you may have to refresh the page for the updated data to be displayed.

    Note: Any problems or errors in the modified statistics.inc should not cause WeeWX to exit; however, it may cause WeeWX to fail to generate the Seasons skin main page. In such cases check the WeeWX log for log entries that may indicate the source of the problem. If the problem cannot be immediately fixed you can revert to the original statistics.inc by deleting the modified statistics.inc and re-instating the original statistics.inc. For setup.py installs:

     $ rm /home/weewx/skins/Seasons/statistics.inc
     $ mv /home/weewx/skins/Seasons/statistics_orig.inc /home/weewx/skins/Seasons/statistics.inc
    

    or for package installs:

     $ rm /etc/weewx/skins/Seasons/statistics.inc
     $ mv /etc/weewx/skins/Seasons/statistics_orig.inc /etc/weewx/skins/Seasons/statistics.inc