dss_tech_docs 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (151) hide show
  1. checksums.yaml +7 -0
  2. data/.editorconfig +29 -0
  3. data/.gitignore +37 -0
  4. data/.rspec +2 -0
  5. data/.rubocop.yml +11 -0
  6. data/.ruby-version +1 -0
  7. data/.travis.yml +9 -0
  8. data/CHANGELOG.md +274 -0
  9. data/CONTRIBUTING.md +9 -0
  10. data/Gemfile +4 -0
  11. data/LICENCE +21 -0
  12. data/README.md +89 -0
  13. data/Rakefile +13 -0
  14. data/docs/configuration.md +205 -0
  15. data/docs/core-layout-without-sidebar.png +0 -0
  16. data/docs/core-layout.png +0 -0
  17. data/docs/expired-page.png +0 -0
  18. data/docs/frontmatter.md +145 -0
  19. data/docs/last-reviewed-only.png +0 -0
  20. data/docs/last-reviewed-only.svg +1 -0
  21. data/docs/layout-layout.png +0 -0
  22. data/docs/not-expired-page.png +0 -0
  23. data/docs/page-expiry.md +85 -0
  24. data/dss_tech_docs.gemspec +46 -0
  25. data/example/.ruby-version +1 -0
  26. data/example/Gemfile +3 -0
  27. data/example/config.rb +9 -0
  28. data/example/config/hide-expiry.yml +51 -0
  29. data/example/config/tech-docs.yml +50 -0
  30. data/example/source/api-path.html.md +7 -0
  31. data/example/source/api-reference.html.md +5 -0
  32. data/example/source/child-of-expired-page.html.md +8 -0
  33. data/example/source/core-layout-without-sidebar.html.md.erb +7 -0
  34. data/example/source/core-layout.html.md.erb +12 -0
  35. data/example/source/expired-page-with-owner.html.md +10 -0
  36. data/example/source/expired-page.html.md +9 -0
  37. data/example/source/headings.html.md +11 -0
  38. data/example/source/index.html.md.erb +19 -0
  39. data/example/source/javascripts/application.js +1 -0
  40. data/example/source/not-expired-page.html.md +9 -0
  41. data/example/source/pets.yml +109 -0
  42. data/example/source/stylesheets/print.css.scss +3 -0
  43. data/example/source/stylesheets/screen-old-ie.css.scss +4 -0
  44. data/example/source/stylesheets/screen.css.scss +1 -0
  45. data/example/source/templates/proxy_template.html.md +8 -0
  46. data/lib/assets/javascripts/_analytics.js +58 -0
  47. data/lib/assets/javascripts/_govuk/modules.js +57 -0
  48. data/lib/assets/javascripts/_modules/anchored-headings.js +18 -0
  49. data/lib/assets/javascripts/_modules/collapsible-navigation.js +95 -0
  50. data/lib/assets/javascripts/_modules/in-page-navigation.js +132 -0
  51. data/lib/assets/javascripts/_modules/navigation.js +34 -0
  52. data/lib/assets/javascripts/_modules/page-expiry.js +15 -0
  53. data/lib/assets/javascripts/_modules/search.js +367 -0
  54. data/lib/assets/javascripts/_modules/table-of-contents.js +111 -0
  55. data/lib/assets/javascripts/_start-modules.js +13 -0
  56. data/lib/assets/javascripts/_vendor/fixedsticky.js +194 -0
  57. data/lib/assets/javascripts/_vendor/jquery.js +5 -0
  58. data/lib/assets/javascripts/_vendor/jquery.mark.js +1081 -0
  59. data/lib/assets/javascripts/_vendor/lodash.js +613 -0
  60. data/lib/assets/javascripts/_vendor/modernizr.js +3 -0
  61. data/lib/assets/javascripts/govuk_tech_docs.js +10 -0
  62. data/lib/assets/stylesheets/_accessibility.scss +9 -0
  63. data/lib/assets/stylesheets/_core.scss +71 -0
  64. data/lib/assets/stylesheets/_fonts.scss +29 -0
  65. data/lib/assets/stylesheets/_govuk_tech_docs.scss +2 -0
  66. data/lib/assets/stylesheets/_syntax-highlighting.scss +196 -0
  67. data/lib/assets/stylesheets/_variables.scss +12 -0
  68. data/lib/assets/stylesheets/govuk_frontend_toolkit/_colours.scss +2 -0
  69. data/lib/assets/stylesheets/govuk_frontend_toolkit/_conditionals.scss +81 -0
  70. data/lib/assets/stylesheets/govuk_frontend_toolkit/_css3.scss +90 -0
  71. data/lib/assets/stylesheets/govuk_frontend_toolkit/_device-pixels.scss +10 -0
  72. data/lib/assets/stylesheets/govuk_frontend_toolkit/_font_stack.scss +19 -0
  73. data/lib/assets/stylesheets/govuk_frontend_toolkit/_grid_layout.scss +136 -0
  74. data/lib/assets/stylesheets/govuk_frontend_toolkit/_helpers.scss +16 -0
  75. data/lib/assets/stylesheets/govuk_frontend_toolkit/_measurements.scss +14 -0
  76. data/lib/assets/stylesheets/govuk_frontend_toolkit/_shims.scss +55 -0
  77. data/lib/assets/stylesheets/govuk_frontend_toolkit/_typography.scss +249 -0
  78. data/lib/assets/stylesheets/govuk_frontend_toolkit/_url-helpers.scss +16 -0
  79. data/lib/assets/stylesheets/govuk_frontend_toolkit/colours/_organisation.scss +103 -0
  80. data/lib/assets/stylesheets/govuk_frontend_toolkit/colours/_palette.scss +77 -0
  81. data/lib/assets/stylesheets/govuk_frontend_toolkit/design-patterns/_alpha-beta.scss +66 -0
  82. data/lib/assets/stylesheets/govuk_frontend_toolkit/design-patterns/_breadcrumbs.scss +53 -0
  83. data/lib/assets/stylesheets/govuk_frontend_toolkit/design-patterns/_buttons.scss +141 -0
  84. data/lib/assets/stylesheets/govuk_frontend_toolkit/design-patterns/_media-player.scss +242 -0
  85. data/lib/assets/stylesheets/modules/_anchored-heading.scss +54 -0
  86. data/lib/assets/stylesheets/modules/_app-pane.scss +64 -0
  87. data/lib/assets/stylesheets/modules/_collapsible.scss +52 -0
  88. data/lib/assets/stylesheets/modules/_contribution-banner.scss +22 -0
  89. data/lib/assets/stylesheets/modules/_footer.scss +130 -0
  90. data/lib/assets/stylesheets/modules/_govuk-logo.scss +47 -0
  91. data/lib/assets/stylesheets/modules/_header.scss +290 -0
  92. data/lib/assets/stylesheets/modules/_page-review.scss +35 -0
  93. data/lib/assets/stylesheets/modules/_phase-banner.scss +22 -0
  94. data/lib/assets/stylesheets/modules/_search.scss +137 -0
  95. data/lib/assets/stylesheets/modules/_skip-link.scss +31 -0
  96. data/lib/assets/stylesheets/modules/_technical-documentation.scss +241 -0
  97. data/lib/assets/stylesheets/modules/_toc.scss +216 -0
  98. data/lib/assets/stylesheets/modules/_warning-text.scss +73 -0
  99. data/lib/assets/stylesheets/palette/_syntax-highlighting.scss +23 -0
  100. data/lib/assets/stylesheets/utilities/_fonts.scss +29 -0
  101. data/lib/assets/stylesheets/utilities/_printable.scss +13 -0
  102. data/lib/assets/stylesheets/vendor/_fixedsticky.scss +22 -0
  103. data/lib/dss_tech_docs.rb +121 -0
  104. data/lib/govuk_tech_docs/api_reference/api_reference_extension.rb +101 -0
  105. data/lib/govuk_tech_docs/api_reference/api_reference_renderer.rb +279 -0
  106. data/lib/govuk_tech_docs/api_reference/templates/api_reference_full.html.erb +19 -0
  107. data/lib/govuk_tech_docs/api_reference/templates/operation.html.erb +11 -0
  108. data/lib/govuk_tech_docs/api_reference/templates/parameters.html.erb +28 -0
  109. data/lib/govuk_tech_docs/api_reference/templates/path.html.erb +4 -0
  110. data/lib/govuk_tech_docs/api_reference/templates/responses.html.erb +33 -0
  111. data/lib/govuk_tech_docs/api_reference/templates/schema.html.erb +29 -0
  112. data/lib/govuk_tech_docs/contribution_banner.rb +62 -0
  113. data/lib/govuk_tech_docs/meta_tags.rb +67 -0
  114. data/lib/govuk_tech_docs/page_review.rb +52 -0
  115. data/lib/govuk_tech_docs/pages.rb +32 -0
  116. data/lib/govuk_tech_docs/redirects.rb +39 -0
  117. data/lib/govuk_tech_docs/table_of_contents/heading.rb +30 -0
  118. data/lib/govuk_tech_docs/table_of_contents/heading_tree.rb +27 -0
  119. data/lib/govuk_tech_docs/table_of_contents/heading_tree_builder.rb +41 -0
  120. data/lib/govuk_tech_docs/table_of_contents/heading_tree_renderer.rb +46 -0
  121. data/lib/govuk_tech_docs/table_of_contents/headings_builder.rb +39 -0
  122. data/lib/govuk_tech_docs/table_of_contents/helpers.rb +79 -0
  123. data/lib/govuk_tech_docs/tech_docs_html_renderer.rb +34 -0
  124. data/lib/govuk_tech_docs/unique_identifier_extension.rb +13 -0
  125. data/lib/govuk_tech_docs/unique_identifier_generator.rb +72 -0
  126. data/lib/govuk_tech_docs/version.rb +3 -0
  127. data/lib/govuk_tech_docs/warning_text_extension.rb +23 -0
  128. data/lib/source/api/pages.json.erb +1 -0
  129. data/lib/source/favicon.ico +0 -0
  130. data/lib/source/images/anchored-heading-icon-2x.png +0 -0
  131. data/lib/source/images/anchored-heading-icon.png +0 -0
  132. data/lib/source/images/gov.uk_logotype_crown-2x.png +0 -0
  133. data/lib/source/images/gov.uk_logotype_crown.png +0 -0
  134. data/lib/source/images/gov.uk_logotype_crown_invert_trans.png +0 -0
  135. data/lib/source/images/govuk-crest-2x.png +0 -0
  136. data/lib/source/images/govuk-crest.png +0 -0
  137. data/lib/source/images/govuk-icn-close.png +0 -0
  138. data/lib/source/images/govuk-icn-close@2x.png +0 -0
  139. data/lib/source/images/govuk-icn-numbered-list.png +0 -0
  140. data/lib/source/images/govuk-icn-numbered-list@2x.png +0 -0
  141. data/lib/source/images/open-government-licence.png +0 -0
  142. data/lib/source/images/open-government-licence_2x.png +0 -0
  143. data/lib/source/images/search-result-caret.svg +13 -0
  144. data/lib/source/layouts/_analytics.erb +15 -0
  145. data/lib/source/layouts/_footer.erb +10 -0
  146. data/lib/source/layouts/_header.erb +44 -0
  147. data/lib/source/layouts/_page_review.erb +22 -0
  148. data/lib/source/layouts/_search.erb +16 -0
  149. data/lib/source/layouts/core.erb +82 -0
  150. data/lib/source/layouts/layout.erb +18 -0
  151. metadata +474 -0
@@ -0,0 +1,13 @@
1
+ require 'bundler/gem_tasks'
2
+ require 'rspec/core/rake_task'
3
+ require 'jasmine'
4
+
5
+ RSpec::Core::RakeTask.new(:spec)
6
+
7
+ load 'jasmine/tasks/jasmine.rake'
8
+
9
+ task :lint do
10
+ sh "govuk-lint-ruby example lib spec Rakefile"
11
+ end
12
+
13
+ task default: ['lint', 'spec', 'jasmine:ci']
@@ -0,0 +1,205 @@
1
+ # Configuration
2
+
3
+ You can configure the site using `config/tech-docs.yml`. [See the PaaS tech docs for an example](https://github.com/alphagov/paas-tech-docs/blob/master/config/tech-docs.yml).
4
+
5
+ These are all the available options:
6
+
7
+ ## `ga_tracking_id`
8
+
9
+ Tracking ID from Google Analytics
10
+
11
+ ```yaml
12
+ ga_tracking_id: UA-XXXX-Y
13
+ ```
14
+
15
+ ## `github_repo`
16
+
17
+ Your repository. Required if [show_contribution_banner](#show-contribution-banner) is true.
18
+
19
+ ```yaml
20
+ github_repo: alphagov/example-repo
21
+ ```
22
+
23
+ ## `github_branch`
24
+
25
+ Your github branch name. Useful if your default branch is not named master.
26
+
27
+ ```yaml
28
+ github_branch: source
29
+ ```
30
+
31
+ ## `google_site_verification`
32
+
33
+ Adds a [Google Site Verification code](https://support.google.com/webmasters/answer/35179?hl=en) to the meta tags.
34
+
35
+ ```yaml
36
+ google_site_verification: TvDTuyvdstyusadrCSDrctyd
37
+ ```
38
+
39
+ ## `enable_search`
40
+
41
+ Enables search functionality. This indexes pages only and is not recommended for single-page sites.
42
+
43
+ ```yaml
44
+ enable_search: true
45
+ ```
46
+
47
+ ## `header_links`
48
+
49
+ Right hand side navigation.
50
+
51
+ Example:
52
+
53
+ ```yaml
54
+ header_links:
55
+ Documentation: /
56
+ ```
57
+
58
+ ## `host`
59
+
60
+ Host to use for canonical URL generation (without trailing slash).
61
+
62
+ Example:
63
+
64
+ ```yaml
65
+ host: https://docs.cloud.service.gov.uk
66
+ ```
67
+
68
+ ## `collapsible_nav`
69
+
70
+ Enable collapsible navigation in the sidebar. Defaults to false;
71
+
72
+ ```yaml
73
+ collapsible_nav: true
74
+ ```
75
+
76
+ ## `multipage_nav`
77
+
78
+ Enable multipage navigation in the sidebar. Defaults to false;
79
+
80
+ ```yaml
81
+ multipage_nav: true
82
+ ```
83
+
84
+ ## `max_toc_heading_level`
85
+
86
+ Table of contents depth – how many levels to include in the table of contents. If your ToC is too long, reduce this number and we'll only show higher-level headings.
87
+
88
+ ```yaml
89
+ max_toc_heading_level: 6
90
+ ```
91
+
92
+ ## `phase`
93
+
94
+ ```yaml
95
+ phase: "Beta"
96
+ ```
97
+
98
+ ## `prevent_indexing`
99
+
100
+ Prevent robots from indexing (e.g. whilst in development)
101
+
102
+ ```yaml
103
+ prevent_indexing: false
104
+ ```
105
+
106
+ ## `redirects`
107
+
108
+ A list of redirects, from old to new location. Use this to set up external
109
+ redirects or if [setting `old_paths` in the frontmatter](docs/frontmatter.md#old_paths) doesn't work.
110
+
111
+ ```yaml
112
+ redirects:
113
+ /old-page.html: https://example.org/something-else.html
114
+ /another/old-page.html: /another/new-page.html
115
+ ```
116
+
117
+ ## `service_name`
118
+
119
+ The service name in the header.
120
+
121
+ Example:
122
+
123
+ ```yaml
124
+ service_name: "Platform as a Service"
125
+ ```
126
+
127
+ ## `full_service_name`
128
+
129
+ The full service name (maybe with GOV.UK)
130
+
131
+ Example:
132
+
133
+ ```yaml
134
+ full_service_name: "GOV.UK Pay"
135
+ ```
136
+
137
+ ## `service_link`
138
+
139
+ What the service name in the header links to.
140
+
141
+ default: '/'
142
+
143
+ ```yaml
144
+ service_link: "/"
145
+ ```
146
+
147
+ ## `show_contribution_banner`
148
+
149
+ Show a block at the bottom of the page that links to the page source, so readers
150
+ can easily contribute back to the documentation. If turned on [github_repo](#github-repo) is
151
+ required.
152
+
153
+ Off by default.
154
+
155
+ ```yaml
156
+ show_contribution_banner: true
157
+ github_repo: alphagov/example-repo
158
+ ```
159
+
160
+ ## `source_urls`
161
+
162
+ Customise the URLs that the contribution banner links to. Only useful if
163
+ [show_contribution_banner](#show_contribution_banner) is turned on. By default, "Report issue" links
164
+ to raising a GitHub issue but by modifying the `report_issue_url` it can link to an email address
165
+ or another page.
166
+
167
+ ```yaml
168
+ source_urls:
169
+ report_issue_url: mailto:support@example.com
170
+ ```
171
+
172
+ ## `show_govuk_logo`
173
+
174
+ Whether to show the GOV.UK crown logo.
175
+
176
+ default: `true`
177
+
178
+ ```yaml
179
+ show_govuk_logo: true
180
+ ```
181
+
182
+ ## `api_path`
183
+
184
+ Define a path to an Open API V3 spec file. This can be a relative file path or a URI to a raw file.
185
+
186
+ ```yaml
187
+ api_path: ./source/pets.yml
188
+ ```
189
+
190
+ ## `owner_slack_workspace` and `default_owner_slack`
191
+
192
+ These attributes are used to specify the owner of a page. See the separate
193
+ [documentation for page expiry][expiry] for more details.
194
+
195
+ ## `show_expiry`
196
+
197
+ Decides whether or not to show a red banner when the page needs to be reviewed.
198
+
199
+ If not present or set to `true`, the red banner will appear when the page needs to be reviewed. This is the default behaviour.
200
+
201
+ If set to `false`, the red banner will not appear when the page needs to be reviewed.
202
+
203
+ See the separate [documentation for page expiry][expiry] for more details.
204
+
205
+ [expiry]: https://tdt-documentation.london.cloudapps.digital/page-expiry.html#page-expiry-and-review
Binary file
Binary file
@@ -0,0 +1,145 @@
1
+ # Available frontmatter
2
+
3
+ "Frontmatter" allows page-specific variables to be included at the top of a template using YAML. For a general introduction on frontmatter, see the [Middleman frontmatter docs][mm].
4
+
5
+ ## `last_reviewed_on` and `review_in`
6
+
7
+ These attributes determine the date when the page needs to be reviewed next.
8
+ See the separate [documentation for page expiry][expiry] for more details.
9
+
10
+ [expiry]: https://tdt-documentation.london.cloudapps.digital/page-expiry.html#page-expiry-and-review
11
+
12
+ Example:
13
+
14
+ You can use this in combination with [owner_slack](#owner-slack) to set an owner for the page.
15
+
16
+ ## `layout`
17
+
18
+ The layout of the page.
19
+
20
+ ```yaml
21
+ ---
22
+ layout: core
23
+ ---
24
+ ```
25
+
26
+ There are 2 available page layouts.
27
+
28
+ ### The `layout` layout (default)
29
+
30
+ By default, pages will use the `layout` layout. This layout will parse the page and generate a sidebar with a table of contents consisting of each `h2`, `h3`, `h4` heading.
31
+
32
+ ```md
33
+ ---
34
+ layout: layout
35
+ ---
36
+
37
+ # The title
38
+
39
+ ## A subheader
40
+
41
+ ### A h3 subheader
42
+
43
+ ## Another subheader
44
+ ```
45
+
46
+ Will generate a page with the headings from the content in the sidebar.
47
+
48
+ ![](layout-layout.png)
49
+
50
+ ### `core` layout
51
+
52
+ If you want more control about the layout, use `core` layout. This allows you to specify the sidebar manually with a `content_for` block.
53
+
54
+ ```rb
55
+ ---
56
+ layout: core
57
+ ---
58
+
59
+ <% content_for :sidebar do %>
60
+ You can put anything in the sidebar.
61
+ <% end %>
62
+
63
+ This page has a configurable sidebar that is independent of the content.
64
+ ```
65
+
66
+ ![](core-layout.png)
67
+
68
+ If you do not specify a sidebar, you will get a simple one-column layout without one.
69
+
70
+ ```rb
71
+ ---
72
+ layout: core
73
+ ---
74
+
75
+ This page does not have a sidebar.
76
+ ```
77
+
78
+ ![](core-layout-without-sidebar.png)
79
+
80
+ ## `old_paths`
81
+
82
+ Any paths of pages that should redirect to this page.
83
+
84
+ Example:
85
+
86
+ ```yaml
87
+ ---
88
+ old_paths:
89
+ - /some-old-page.html
90
+ ---
91
+ ```
92
+
93
+ ## `owner_slack`
94
+
95
+ The Slack username or channel of the page owner. This can be used to appoint an individual or team as responsible for keeping the page up to date.
96
+
97
+ ```yaml
98
+ ---
99
+ owner_slack: "#operations-teams"
100
+ ---
101
+ ```
102
+
103
+ ## `source_url`
104
+
105
+ If the contribution banner is turned on, you can override the "View source" link
106
+ using `source_url`.
107
+
108
+ Example:
109
+
110
+ ```yaml
111
+ source_url: http://example.org/source.md
112
+ ```
113
+
114
+ ## `title`
115
+
116
+ The browser title of the page.
117
+
118
+ ```yaml
119
+ ---
120
+ title: My beautiful page
121
+ ---
122
+ ```
123
+
124
+ ## `weight`
125
+
126
+ Affects the order a page is displayed in the sidebar navigation tree. Lower
127
+ weights float to the top. Higher weights sink to the bottom.
128
+
129
+ ```yaml
130
+ ---
131
+ weight: 20
132
+ ---
133
+ ```
134
+
135
+ ## `parent`
136
+
137
+ The page that should be highlighted as ‘active’ in the navigation.
138
+
139
+ ```yaml
140
+ ---
141
+ parent: shaving-yaks.html
142
+ ---
143
+ ```
144
+
145
+ [mm]: https://middlemanapp.com/basics/frontmatter
@@ -0,0 +1 @@
1
+ <svg version="1.1" viewBox="0.0 0.0 842.7270341207349 642.2729658792651" fill="none" stroke="none" stroke-linecap="square" stroke-miterlimit="10" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns="http://www.w3.org/2000/svg"><clipPath id="p.0"><path d="m0 0l842.72705 0l0 642.27295l-842.72705 0l0 -642.27295z" clip-rule="nonzero"/></clipPath><g clip-path="url(#p.0)"><path fill="#000000" fill-opacity="0.0" d="m0 0l842.72705 0l0 642.27295l-842.72705 0z" fill-rule="evenodd"/><g filter="url(#shadowFilter-p.1)"><use xlink:href="#p.1" transform="matrix(1.0 0.0 0.0 1.0 0.0 2.0)"/></g><defs><filter id="shadowFilter-p.1" filterUnits="userSpaceOnUse"><feGaussianBlur in="SourceAlpha" stdDeviation="2.0" result="blur"/><feComponentTransfer in="blur" color-interpolation-filters="sRGB"><feFuncR type="linear" slope="0" intercept="0.0"/><feFuncG type="linear" slope="0" intercept="0.0"/><feFuncB type="linear" slope="0" intercept="0.0"/><feFuncA type="linear" slope="0.5" intercept="0"/></feComponentTransfer></filter></defs><g id="p.1"><path fill="#000000" fill-opacity="0.0" d="m16.0 16.0l810.0 0l0 299.0l-810.0 0z" fill-rule="evenodd"/><g transform="matrix(1.0 0.0 0.0 1.0 16.0 16.0)"><clipPath id="p.2"><path d="m0 0l810.0 0l0 299.0l-810.0 0z" clip-rule="evenodd"/></clipPath><image clip-path="url(#p.2)" fill="#000" width="810.0" height="299.0" x="0.0" y="0.0" preserveAspectRatio="none" xlink:href=""/></g></g><g filter="url(#shadowFilter-p.3)"><use xlink:href="#p.3" transform="matrix(1.0 0.0 0.0 1.0 0.0 2.0)"/></g><defs><filter id="shadowFilter-p.3" filterUnits="userSpaceOnUse"><feGaussianBlur in="SourceAlpha" stdDeviation="2.0" result="blur"/><feComponentTransfer in="blur" color-interpolation-filters="sRGB"><feFuncR type="linear" slope="0" intercept="0.0"/><feFuncG type="linear" slope="0" intercept="0.0"/><feFuncB type="linear" slope="0" intercept="0.0"/><feFuncA type="linear" slope="0.5" intercept="0"/></feComponentTransfer></filter></defs><g id="p.3"><path fill="#000000" fill-opacity="0.0" d="m16.0 331.0l810.0 0l0 299.0l-810.0 0z" fill-rule="evenodd"/><g transform="matrix(1.0 0.0 0.0 1.0 16.0 331.0)"><clipPath id="p.4"><path d="m0 0l810.0 0l0 299.0l-810.0 0z" clip-rule="evenodd"/></clipPath><image clip-path="url(#p.4)" fill="#000" width="810.0" height="299.0" x="0.0" y="0.0" preserveAspectRatio="none" xlink:href=""/></g></g></g></svg>
Binary file
Binary file
@@ -0,0 +1,85 @@
1
+ # Page Expiry and Review Notices
2
+
3
+ It's possible to include frontmatter configuration for a page to set an
4
+ expiration date for a piece of content. The expiration date is calculated using the `last_reviewed_on` and `review_in` frontmatter configuration parameters.
5
+
6
+ The `show_expiry` parameter in the global configuration file decides if the banners at the bottom of the page say that the page is expired or not.
7
+
8
+ For `show_expiry: true`, the banner at the bottom turns red if it's past the expiration date.
9
+
10
+ If the page doesn't need to be reviewed, we show a blue box with the
11
+ last-reviewed date, when it needs review again, and the owner.
12
+
13
+ ![](not-expired-page.png)
14
+
15
+ If the page needs to be reviewed, we show a red box saying the page might not
16
+ be accurate.
17
+
18
+ ![](expired-page.png)
19
+
20
+ Setting `show_expiry: false` generates a blue banner with the last reviewed date. This banner stays the same whether the page needs to be reviewed or not. The banner does not mention when the page needs to be reviewed next or who the owner is.
21
+
22
+ ![](last-reviewed-only.png)
23
+
24
+ This feature relies on JavaScript being enabled on the user's browser to
25
+ display the relevant notices.
26
+
27
+ If you want to disable the banners, but keep the review dates in the frontmatter, add the following to `source/javascripts/application.js`
28
+
29
+ ```js
30
+ // Disable page expiry banner
31
+ window.GOVUK.Modules.PageExpiry = null;
32
+ ```
33
+
34
+ For example if you do not want any page expiry banner at the bottom of the page, but want to have the review dates in the frontmatter for Daniel the Manual Spaniel to pick up.
35
+
36
+ ## Frontmatter configuration
37
+
38
+ ### `last_reviewed_on` and `review_in`
39
+
40
+ These attributes determine the date when the page needs to be reviewed next.
41
+
42
+ ```yaml
43
+ ---
44
+ last_reviewed_on: 2018-01-18
45
+ review_in: 6 weeks
46
+ ---
47
+ ```
48
+
49
+ You can use this in combination with `owner_slack` or `default_owner_slack` to
50
+ set an owner for the page.
51
+
52
+ ### `owner_slack`
53
+
54
+ The Slack username or channel of the page owner. This can be used to appoint an
55
+ individual or team as responsible for keeping the page up to date.
56
+
57
+
58
+ ## Global configuration
59
+
60
+ ### `owner_slack_workspace`
61
+
62
+ The Slack workspace name used when linking to the Slack owner of a piece of
63
+ content. If not provided, the owner of a piece of content (channel or user)
64
+ won't be linked.
65
+
66
+ ```yaml
67
+ owner_slack_workspace: gds
68
+ ```
69
+
70
+ ### `default_owner_slack`
71
+
72
+ The default Slack user or channel name to show as the owner of a piece of
73
+ content. Can be overridden using the `owner_slack` frontmatter config option.
74
+
75
+ ```yaml
76
+ default_owner_slack: '#owner'
77
+ ```
78
+
79
+
80
+ ## Page API
81
+
82
+ The expiry date for each page is also shown in the `/api/pages.json`
83
+ representation of all pages. This is used by the
84
+ [tech-docs-notifier](https://github.com/alphagov/tech-docs-notifier) to post
85
+ messages to Slack when pages have expired.