From b2c55c15860848fd246672cc78e5bf2c5e22ae3d Mon Sep 17 00:00:00 2001 From: Ans Date: Fri, 20 Dec 2024 15:32:56 -0500 Subject: [PATCH] Tweak wagtail chart code and add to learn pages --- cfgov/unprocessed/apps/tccp/js/index.js | 6 +++-- .../css/on-demand/wagtail-chart.scss | 11 ++++---- .../on-demand/wagtail-charts-chart-block.js | 26 ++++++++++--------- cfgov/v1/atomic_elements/charts.py | 2 +- ...042_add_wagtail_chart_learnpage_content.py | 20 ++++++++++++++ cfgov/v1/models/learn_page.py | 1 + 6 files changed, 45 insertions(+), 21 deletions(-) create mode 100644 cfgov/v1/migrations/0042_add_wagtail_chart_learnpage_content.py diff --git a/cfgov/unprocessed/apps/tccp/js/index.js b/cfgov/unprocessed/apps/tccp/js/index.js index ec57b5ed343..889b07e23f9 100644 --- a/cfgov/unprocessed/apps/tccp/js/index.js +++ b/cfgov/unprocessed/apps/tccp/js/index.js @@ -138,9 +138,11 @@ function handleShowMore(event) { } const results = document.querySelector('.o-filterable-list-results'); const showMoreFade = document.querySelector('#u-show-more-fade'); - const nextResult = document.querySelector('[data-js-hook="behavior_faded-card"]'); + const nextResult = document.querySelector( + '[data-js-hook="behavior_faded-card"]', + ); nextResult.setAttribute('tabIndex', '0'); - nextResult.querySelectorAll('[tabindex="-1"]').forEach( elem => { + nextResult.querySelectorAll('[tabindex="-1"]').forEach((elem) => { elem.setAttribute('tabIndex', '0'); }); results.classList.remove('o-filterable-list-results--partial'); diff --git a/cfgov/unprocessed/css/on-demand/wagtail-chart.scss b/cfgov/unprocessed/css/on-demand/wagtail-chart.scss index e6462b0476a..12e8b0abd4e 100644 --- a/cfgov/unprocessed/css/on-demand/wagtail-chart.scss +++ b/cfgov/unprocessed/css/on-demand/wagtail-chart.scss @@ -1,18 +1,17 @@ @use 'sass:math'; @use '@cfpb/cfpb-design-system/src/abstracts' as *; -@import '../main'; .o-wagtail-chart { - max-width: math.div(670px, $base-font-size-px) + em; - margin-bottom: math.div(60px, $base-font-size-px) + em; + max-width: math.div(670px, $base-font-size-px) + rem; + margin-bottom: math.div(60px, $base-font-size-px) + rem; &__subtitle { - margin: 0 0 (math.div(30px, $base-font-size-px) + em); + margin: 0 0 (math.div(30px, $base-font-size-px) + rem); } &__footnote { max-width: math.div(670px, $size-vi) + rem; - padding-top: math.div(15px, $size-vi) + em; - font-size: 0.75em; + padding-top: math.div(15px, $size-vi) + rem; + font-size: math.div(12px, $base-font-size-px) + rem; } } diff --git a/cfgov/unprocessed/js/routes/on-demand/wagtail-charts-chart-block.js b/cfgov/unprocessed/js/routes/on-demand/wagtail-charts-chart-block.js index 493578baab0..c3a3ff813af 100644 --- a/cfgov/unprocessed/js/routes/on-demand/wagtail-charts-chart-block.js +++ b/cfgov/unprocessed/js/routes/on-demand/wagtail-charts-chart-block.js @@ -1,12 +1,16 @@ /* eslint-disable no-undef */ import pattern from 'patternomaly'; +const white60 = 'rgba(255, 255, 255, 0.6)'; +// This is the gray from the CFPB DS. +const gray = '#5a5d61'; + /** - * Set default text color to a dark gray + * Set default text color to a dark gray. * * https://www.chartjs.org/docs/latest/general/colors.html */ -Chart.defaults.color = '#5a5d61'; +Chart.defaults.color = gray; /** * Takes an array of Chart.js datasets and returns a new array @@ -16,9 +20,8 @@ Chart.defaults.color = '#5a5d61'; * The first line pattern is solid, the second is dashed, * the third is dotted and all subsequent patterns are dashed * with an increasingly thicker line. - * - * @param {array} datasets - Array of Chart.js datasets - * @returns {array} Array of Chart.js datasets with borderDash property set + * @param {Array} datasets - Array of Chart.js datasets + * @returns {Array} Array of Chart.js datasets with borderDash property set * * https://www.chartjs.org/docs/latest/samples/line/styling.html * https://www.chartjs.org/docs/latest/configuration/#dataset-configuration @@ -43,9 +46,8 @@ const patternizeChartLines = (datasets) => { * backgroundColor property. * * Patterns are from the patternomaly library. - * - * @param {array} datasets - Array of Chart.js datasets - * @returns {array} Array of Chart.js datasets with backgroundColor property set + * @param {Array} datasets - List of Chart.js datasets. + * @returns {Array} List of Chart.js datasets with backgroundColor property set. * * https://www.chartjs.org/docs/latest/general/colors.html#patterns-and-gradients * https://github.com/ashiguruma/patternomaly @@ -76,7 +78,7 @@ const patternizeChartBars = (datasets) => { ]; return datasets.map((dataset, i) => { dataset.backgroundColor = dataset.data.map(() => { - // First pattern is just the solid color + // First pattern is just the solid color. if (i === 0) return Array.isArray(dataset.backgroundColor) ? dataset.backgroundColor[0] @@ -84,7 +86,7 @@ const patternizeChartBars = (datasets) => { return pattern.draw( patterns[i - 1], dataset.backgroundColor, - 'rgba(255, 255, 255, 0.6)', + white60, 10, ); }); @@ -93,7 +95,7 @@ const patternizeChartBars = (datasets) => { }; /** - * Change the default Chart.js tooltip options + * Change the default Chart.js tooltip options. */ const tooltipOptions = { yAlign: 'bottom', @@ -101,7 +103,7 @@ const tooltipOptions = { }; /** - * Define a Chart.js plugin for our CFPB customizations + * Define a Chart.js plugin for our CFPB customizations. * * https://www.chartjs.org/docs/latest/developers/plugins.html */ diff --git a/cfgov/v1/atomic_elements/charts.py b/cfgov/v1/atomic_elements/charts.py index 97550844347..7896ad5ac26 100644 --- a/cfgov/v1/atomic_elements/charts.py +++ b/cfgov/v1/atomic_elements/charts.py @@ -68,7 +68,7 @@ class ChartBlock(WagtailChartBlock): notes = blocks.TextBlock(required=False, help_text="Note about the chart") def __init__(self, **kwargs): - # Always override chart_types and colors with ours + # Always override chart_types and colors with ours. super().__init__( chart_types=CHART_TYPES, colors=CHART_COLORS, **kwargs ) diff --git a/cfgov/v1/migrations/0042_add_wagtail_chart_learnpage_content.py b/cfgov/v1/migrations/0042_add_wagtail_chart_learnpage_content.py new file mode 100644 index 00000000000..adc1fe36e01 --- /dev/null +++ b/cfgov/v1/migrations/0042_add_wagtail_chart_learnpage_content.py @@ -0,0 +1,20 @@ +# Generated by Django 4.2.17 on 2024-12-20 20:30 + +from django.db import migrations +import v1.atomic_elements.tables +import wagtail.fields + + +class Migration(migrations.Migration): + + dependencies = [ + ('v1', '0041_wagtail_charts_chart_block'), + ] + + operations = [ + migrations.AlterField( + model_name='learnpage', + name='content', + field=wagtail.fields.StreamField([('full_width_text', 42), ('info_unit_group', 53), ('expandable_group', 61), ('expandable', 59), ('well', 41), ('call_to_action', 34), ('video_player', 64), ('audio_player', 67), ('email_signup', 39), ('simple_chart', 84), ('table', 25), ('faq_group', 93), ('contact_us_table', 95), ('wagtailchart_block', 131)], blank=True, block_lookup={0: ('wagtail.blocks.RichTextBlock', (), {'icon': 'edit'}), 1: ('wagtail.blocks.RichTextBlock', (), {}), 2: ('wagtail.blocks.CharBlock', (), {'help_text': '\n ID will be auto-generated on save.\n However, you may enter some human-friendly text that\n will be incorporated to make it easier to read.\n ', 'label': 'ID for this content block', 'required': False}), 3: ('wagtail.blocks.StructBlock', [[('link_id', 2)]], {}), 4: ('wagtail.blocks.StructBlock', [[('content_block', 1), ('anchor_link', 3)]], {}), 5: ('wagtail_footnotes.blocks.RichTextBlockWithFootnotes', (), {'features': ['anchor-identifier', 'h2', 'h3', 'h4', 'h5', 'hr', 'ol', 'ul', 'bold', 'italic', 'superscript', 'blockquote', 'link', 'document-link', 'image', 'icon', 'footnotes']}), 6: ('wagtail.blocks.CharBlock', (), {'required': False}), 7: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('h2', 'H2'), ('h3', 'H3'), ('h4', 'H4'), ('h5', 'H5')]}), 8: ('wagtail.blocks.CharBlock', (), {'help_text': 'Input the name of an icon to appear to the left of the heading. E.g., approved, help-round, etc. See full list of icons', 'required': False}), 9: ('wagtail.blocks.StructBlock', [[('text', 6), ('level', 7), ('icon', 8)]], {'required': False}), 10: ('wagtail.images.blocks.ImageChooserBlock', (), {'required': False}), 11: ('wagtail.blocks.CharBlock', (), {'help_text': "No character limit, but be as succinct as possible. If the image is decorative (i.e., a screenreader wouldn't have anything useful to say about it), leave this field blank.", 'required': False}), 12: ('wagtail.blocks.StructBlock', [[('upload', 10), ('alt', 11)]], {}), 13: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('full', 'Full width'), (470, '470px'), (270, '270px'), (170, '170px')]}), 14: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('right', 'right'), ('left', 'left')], 'help_text': 'Does not apply if the image is full-width'}), 15: ('wagtail.blocks.RichTextBlock', (), {'label': 'Caption', 'required': False}), 16: ('wagtail.blocks.BooleanBlock', (), {'default': True, 'help_text': 'Check to add a horizontal rule line to bottom of inset.', 'label': 'Has bottom rule line', 'required': False}), 17: ('wagtail.blocks.StructBlock', [[('image', 12), ('image_width', 13), ('image_position', 14), ('text', 15), ('is_bottom_rule', 16)]], {}), 18: ('wagtail.blocks.MultipleChoiceBlock', [], {'choices': [('is_full_width', 'Display the table at full width'), ('stack_on_mobile', 'Stack the table columns on mobile')], 'required': False}), 19: ('wagtail.blocks.CharBlock', (), {}), 20: ('wagtail.blocks.FloatBlock', (), {}), 21: ('wagtail.blocks.RichTextBlock', (), {'features': ['bold', 'italic', 'ol', 'ul', 'link', 'document-link', 'superscript']}), 22: ('wagtail_footnotes.blocks.RichTextBlockWithFootnotes', (), {'features': ['bold', 'italic', 'ol', 'ul', 'link', 'document-link', 'superscript', 'footnotes']}), 23: ('wagtail.contrib.typed_table_block.blocks.TypedTableBlock', [[('text', 19), ('numeric', 20), ('rich_text', 21), ('rich_text_with_footnotes', 22)]], {}), 24: ('wagtail.blocks.RichTextBlock', (), {'features': ['bold', 'italic', 'link', 'document-link'], 'required': False}), 25: ('wagtail.blocks.StructBlock', [[('heading', 9), ('text_introduction', 6), ('options', 18), ('data', 23), ('caption', 24)]], {}), 26: ('wagtail.blocks.TextBlock', (), {}), 27: ('wagtail.blocks.TextBlock', (), {'required': False}), 28: ('wagtail.blocks.StructBlock', [[('body', 26), ('citation', 27)]], {}), 29: ('wagtail.blocks.RichTextBlock', (), {'required': False}), 30: ('wagtail.blocks.CharBlock', (), {'help_text': 'Add an ARIA label if the link text does not describe the destination of the link (e.g. has ambiguous text like "Learn more" that is not descriptive on its own).', 'required': False}), 31: ('wagtail.blocks.CharBlock', (), {'default': '/', 'required': False}), 32: ('wagtail.blocks.BooleanBlock', (), {'default': False, 'required': False}), 33: ('wagtail.blocks.StructBlock', [[('text', 6), ('aria_label', 30), ('url', 31), ('is_link_boldface', 32)]], {}), 34: ('wagtail.blocks.StructBlock', [[('slug_text', 6), ('paragraph_text', 29), ('button', 33)]], {}), 35: ('wagtail.blocks.ListBlock', (33,), {}), 36: ('wagtail.blocks.StructBlock', [[('heading', 6), ('paragraph', 29), ('links', 35)]], {}), 37: ('v1.blocks.ReusableTextChooserBlock', ('v1.ReusableText',), {}), 38: ('v1.blocks.ReusableNotificationChooserBlock', ('v1.ReusableNotification',), {}), 39: ('v1.blocks.EmailSignUpChooserBlock', (), {}), 40: ('wagtail.blocks.RichTextBlock', (), {'label': 'Well', 'required': False}), 41: ('wagtail.blocks.StructBlock', [[('content', 40)]], {}), 42: ('wagtail.blocks.StreamBlock', [[('content', 0), ('content_with_anchor', 4), ('content_with_footnotes', 5), ('heading', 9), ('image', 17), ('table', 25), ('quote', 28), ('cta', 34), ('related_links', 36), ('reusable_text', 37), ('reusable_notification', 38), ('email_signup', 39), ('well', 41)]], {}), 43: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('50-50', '50/50'), ('33-33-33', '33/33/33'), ('25-75', '25/75')], 'help_text': 'Choose the number and width of info unit columns.', 'label': 'Format'}), 44: ('wagtail.blocks.BooleanBlock', (), {'default': True, 'help_text': "Check this to link all images and headings to the URL of the first link in their unit's list, if there is a link.", 'required': False}), 45: ('wagtail.blocks.BooleanBlock', (), {'default': False, 'help_text': 'Check this to add a horizontal rule line to top of info unit group.', 'required': False}), 46: ('wagtail.blocks.BooleanBlock', (), {'default': False, 'help_text': 'Check this to show horizontal rule lines between info units.', 'label': 'Show rule lines between items', 'required': False}), 47: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('none', 'None'), ('rounded', 'Rounded corners'), ('circle', 'Circle')], 'help_text': 'Adds a border-radius class to images in this group, allowing for a rounded or circular border.', 'label': 'Border radius for images?', 'required': False}), 48: ('wagtail.blocks.StructBlock', [[('text', 6), ('level', 7), ('icon', 8)]], {'default': {'level': 'h3'}, 'required': False}), 49: ('wagtail.blocks.RichTextBlock', (), {'blank': True, 'required': False}), 50: ('wagtail.blocks.ListBlock', (33,), {'required': False}), 51: ('wagtail.blocks.StructBlock', [[('image', 12), ('heading', 48), ('body', 49), ('links', 50)]], {}), 52: ('wagtail.blocks.ListBlock', (51,), {'default': []}), 53: ('wagtail.blocks.StructBlock', [[('format', 43), ('heading', 9), ('intro', 29), ('link_image_and_heading', 44), ('has_top_rule_line', 45), ('lines_between_items', 46), ('border_radius_image', 47), ('info_units', 52)]], {}), 54: ('wagtail.blocks.CharBlock', (), {'help_text': 'Added as an <h3> at the top of this block. Also adds a wrapping <div> whose id attribute comes from a slugified version of this heading, creating an anchor that can be used when linking to this part of the page.', 'required': False}), 55: ('wagtail.blocks.BooleanBlock', (), {'required': False}), 56: ('wagtail.blocks.BooleanBlock', (), {'default': False, 'help_text': 'Check this to add a horizontal rule line to top of expandable group.', 'required': False}), 57: ('wagtail.blocks.BooleanBlock', (), {'default': False, 'help_text': 'Check this to add FAQ schema markup to expandables.', 'label': 'Uses FAQ schema', 'required': False}), 58: ('wagtail.blocks.StreamBlock', [[('paragraph', 29), ('well', 41), ('links', 33), ('info_unit_group', 53)]], {'blank': True}), 59: ('wagtail.blocks.StructBlock', [[('label', 6), ('icon', 6), ('is_bordered', 55), ('is_midtone', 55), ('is_expanded', 55), ('is_expanded_padding', 55), ('content', 58)]], {}), 60: ('wagtail.blocks.ListBlock', (59,), {}), 61: ('wagtail.blocks.StructBlock', [[('heading', 54), ('body', 29), ('is_accordion', 55), ('has_top_rule_line', 56), ('is_faq', 57), ('expandables', 60)]], {}), 62: ('wagtail.blocks.RegexBlock', (), {'error_messages': {'invalid': 'The YouTube video ID is in the wrong format.'}, 'help_text': 'Enter the YouTube video ID, which is located at the end of the video URL, after "v=". For example, the video ID for https://www.youtube.com/watch?v=1V0Ax9OIc84 is 1V0Ax9OIc84.', 'label': 'YouTube video ID', 'regex': '^[\\w-]{11}$', 'required': False}), 63: ('wagtail.images.blocks.ImageChooserBlock', (), {'help_text': 'Optional thumbnail image to show before and after the video plays. If the thumbnail image is not set here, the video player will default to showing the thumbnail that was set in (or automatically chosen by) YouTube.', 'required': False}), 64: ('wagtail.blocks.StructBlock', [[('video_id', 62), ('thumbnail_image', 63)]], {}), 65: ('wagtailmedia.blocks.AbstractMediaChooserBlock', (), {'help_text': 'Spoken word audio files should be in MP3 format with a 44.1 kHz sample rate, 96 kbps (CBR) bitrate, in mono. See Libsyn’s guidance for details. Note that the thumbnail and tag fields will not be used for audio files.'}), 66: ('wagtail.blocks.RichTextBlock', (), {'help_text': 'If you have anything you want to appear below the audio player, such as a download link, put it in this field.', 'required': False}), 67: ('wagtail.blocks.StructBlock', [[('heading', 9), ('body', 29), ('audio_file', 65), ('additional_details', 66)]], {}), 68: ('wagtail.blocks.CharBlock', (), {'required': True}), 69: ('wagtail.blocks.TextBlock', (), {'help_text': 'Accessible description of the chart content', 'required': True}), 70: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('bar', 'Bar'), ('datetime', 'Date/time'), ('line', 'Line'), ('tilemap', 'Tile grid map')]}), 71: ('wagtail.blocks.TextBlock', (), {'help_text': "URL of the chart's data source or an array of JSON data", 'required': True, 'rows': 2}), 72: ('wagtail.blocks.TextBlock', (), {'help_text': 'For charts pulling from a separate source file, include a list of the column headers (from a CSV file) or keys (from a JSON file) to include in the chart as ["HEADER/KEY1", "HEADER/KEY2"]. To change how the data is labeled in the chart, include the correct labels with the format [{"key": "HEADER/KEY1", "label": "NEWLABEL"}, {"key": "HEADER/KEY2", "label": "NEWLABEL2"}]', 'required': False}), 73: ('wagtail.blocks.BooleanBlock', (), {'default': True, 'help_text': 'Uncheck this option to initially only show the first data series in the chart. Leave checked to show all data series by default. Users can always turn data series on or off by interacting with the chart legend. ', 'required': False}), 74: ('wagtail.blocks.TextBlock', (), {'help_text': 'The column header (CSV), key or data array (JSON) to include as the source of x-axis values.', 'required': False}), 75: ('wagtail.blocks.CharBlock', (), {'help_text': "Name the javascript function in chart-hooks.js to run on the provided data before handing it to the chart. Can also provide '___'-separated arguments to this function which are passed in as arguments 2 to n", 'required': False}), 76: ('wagtail.blocks.TextBlock', (), {'help_text': 'If the chart needs the option for users to filter the data shown, for example by date or geographic region, provide the JSON objects to filter on, in the format {key: "KEY", "label": "LABEL"}', 'required': False}), 77: ('wagtail.blocks.TextBlock', (), {'help_text': 'A JSON object with style overrides for the underlying Highcharts chart. No object merging is done, nested objects should be referenced with dot notation: {"tooltip.shape": "circle"}', 'required': False}), 78: ('wagtail.blocks.IntegerBlock', (), {'blank': True, 'help_text': 'A number to determine how many months of the data are projected values', 'max_value': 12, 'min_value': 0, 'null': True, 'required': False}), 79: ('wagtail.blocks.CharBlock', (), {'help_text': 'Attribution for the data source', 'required': False}), 80: ('wagtail.blocks.CharBlock', (), {'help_text': 'When the underlying data was published', 'required': False}), 81: ('wagtail.blocks.CharBlock', (), {'help_text': 'Custom text for the chart download field. Required to display a download link.', 'required': False}), 82: ('wagtail.blocks.CharBlock', (), {'help_text': 'Location of a file to download, if different from the data source', 'required': False}), 83: ('wagtail.blocks.TextBlock', (), {'help_text': 'General chart information', 'required': False}), 84: ('wagtail.blocks.StructBlock', [[('title', 68), ('subtitle', 27), ('description', 69), ('figure_number', 6), ('chart_type', 70), ('data_source', 71), ('data_series', 72), ('show_all_series_by_default', 73), ('x_axis_source', 74), ('transform', 75), ('x_axis_label', 6), ('y_axis_label', 6), ('filters', 76), ('style_overrides', 77), ('projected_months', 78), ('source_credits', 79), ('date_published', 80), ('download_text', 81), ('download_file', 82), ('notes', 83)]], {}), 85: ('wagtail.blocks.BooleanBlock', (), {'default': False, 'help_text': 'Check this to add a horizontal rule line to top of FAQ group.', 'required': False}), 86: ('wagtail.blocks.BooleanBlock', (), {'default': False, 'help_text': 'Check this to show horizontal rule lines between FAQ items.', 'label': 'Show rule lines between items', 'required': False}), 87: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('h2', 'h2'), ('h3', 'h3'), ('h4', 'h4'), ('p', 'p')], 'help_text': 'HTML tag for questions.'}), 88: ('wagtail.blocks.CharBlock', (), {'blank': True, 'help_text': "Add an optional anchor link tag for this question. Tag should be unique and use dashes or underscores for separation instead of spaces (ie, 'question-one-tag')", 'max_length': 500, 'required': False}), 89: ('wagtail.blocks.CharBlock', (), {'max_length': 500}), 90: ('wagtail.blocks.StreamBlock', [[('full_width_text', 42), ('info_unit_group', 53)]], {}), 91: ('wagtail.blocks.StructBlock', [[('anchor_tag', 88), ('question', 89), ('answer', 90)]], {}), 92: ('wagtail.blocks.ListBlock', (91,), {'label': 'FAQ items'}), 93: ('wagtail.blocks.StructBlock', [[('has_top_rule_line', 85), ('lines_between_items', 86), ('question_tag', 87), ('faq_items', 92)]], {}), 94: ('wagtail.blocks.ListBlock', (v1.atomic_elements.tables.ContactUsRow,), {'collapsed': True, 'min_num': 1}), 95: ('wagtail.blocks.StructBlock', [[('heading', 19), ('rows', 94)]], {}), 96: ('wagtail.blocks.CharBlock', (), {'help_text': 'Optional: Adds an H5 eyebrow above H1 heading text. Only use in conjunction with heading.', 'label': 'Pre-heading', 'required': False}), 97: ('wagtail.blocks.RichTextBlock', (), {'icon': 'edit', 'required': False}), 98: ('wagtail.blocks.TextBlock', (), {'help_text': 'Accessible description of the chart content', 'required': False}), 99: ('wagtail.blocks.TextBlock', (), {'help_text': 'Description of the data source', 'required': False}), 100: ('wagtail.blocks.CharBlock', (), {'help_text': 'Location of a file to download', 'required': False}), 101: ('wagtail.blocks.TextBlock', (), {'help_text': 'Note about the chart', 'required': False}), 102: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('line', 'Line Chart'), ('bar', 'Vertical Bar Chart'), ('bar_horizontal', 'Horizontal Bar Chart')], 'label': 'Chart Type'}), 103: ('wagtail.blocks.TextBlock', (), {'default': '{"data":[], "options":{}}'}), 104: ('wagtail.blocks.BooleanBlock', (), {'default': False, 'group': 'General', 'label': 'Show legend', 'required': False}), 105: ('wagtail.blocks.BooleanBlock', (), {'default': False, 'group': 'General', 'label': 'Use HTML legend', 'required': False}), 106: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('top', 'Top'), ('bottom', 'Bottom'), ('left', 'Left'), ('right', 'Right')], 'group': 'General', 'label': 'Legend position'}), 107: ('wagtail.blocks.BooleanBlock', (), {'default': False, 'group': 'General', 'label': 'Reverse legend', 'required': False}), 108: ('wagtail.blocks.BooleanBlock', (), {'default': False, 'group': 'General', 'label': 'Show values on chart', 'required': False}), 109: ('wagtail.blocks.IntegerBlock', (), {'default': 1, 'group': 'General', 'label': 'Precision in labels/tooltips'}), 110: ('wagtail.blocks.BooleanBlock', (), {'default': True, 'group': 'General', 'label': 'Show Chart Grid', 'required': False}), 111: ('wagtail.blocks.CharBlock', (), {'group': 'General', 'label': 'X axis label', 'required': False}), 112: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('none', 'No stacking'), ('stacked', 'Stacked'), ('stacked_100', 'Stacked 100%')], 'group': 'General', 'label': 'Stacking'}), 113: ('wagtail.blocks.CharBlock', (), {'group': 'General', 'label': 'Unit override', 'required': False}), 114: ('wagtail.blocks.CharBlock', (), {'group': 'Left_Axis', 'label': 'Left Y axis minimum value', 'required': False}), 115: ('wagtail.blocks.CharBlock', (), {'group': 'Left_Axis', 'label': 'Left Y axis maximum value', 'required': False}), 116: ('wagtail.blocks.CharBlock', (), {'group': 'Left_Axis', 'label': 'Left Y axis step size', 'required': False}), 117: ('wagtail.blocks.CharBlock', (), {'group': 'Left_Axis', 'label': 'Left Y axis label', 'required': False}), 118: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('number', 'Numerical'), ('percentage', 'Percentage')], 'group': 'Left_Axis', 'label': 'Left Y axis data type', 'required': False}), 119: ('wagtail.blocks.IntegerBlock', (), {'default': 0, 'group': 'Left_Axis', 'label': 'Left Y axis tick precision'}), 120: ('wagtail.blocks.BooleanBlock', (), {'default': True, 'group': 'Left_Axis', 'label': 'Show left axis numbers', 'required': False}), 121: ('wagtail.blocks.CharBlock', (), {'group': 'Right_Axis', 'label': 'Right Y axis minimum value', 'required': False}), 122: ('wagtail.blocks.CharBlock', (), {'group': 'Right_Axis', 'label': 'Right Y axis maximum value', 'required': False}), 123: ('wagtail.blocks.CharBlock', (), {'group': 'Right_Axis', 'label': 'Right Y axis step size', 'required': False}), 124: ('wagtail.blocks.CharBlock', (), {'group': 'Right_Axis', 'label': 'Right Y axis label', 'required': False}), 125: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('number', 'Numerical'), ('percentage', 'Percentage')], 'group': 'Right_Axis', 'label': 'Right Y axis data type', 'required': False}), 126: ('wagtail.blocks.IntegerBlock', (), {'default': 0, 'group': 'Right_Axis', 'label': 'Right Y axis tick precision'}), 127: ('wagtail.blocks.BooleanBlock', (), {'default': True, 'group': 'Right_Axis', 'label': 'Show right axis numbers', 'required': False}), 128: ('wagtail.blocks.IntegerBlock', (), {'default': 2, 'group': 'Pie_Chart', 'label': 'Width of pie slice border'}), 129: ('wagtail.blocks.CharBlock', (), {'default': '#fff', 'group': 'Pie_Chart', 'label': 'Color of pie slice border'}), 130: ('wagtail.blocks.StructBlock', [[('show_legend', 104), ('html_legend', 105), ('legend_position', 106), ('reverse_legend', 107), ('show_values_on_chart', 108), ('precision', 109), ('show_grid', 110), ('x_label', 111), ('stacking', 112), ('unit_override', 113), ('y_left_min', 114), ('y_left_max', 115), ('y_left_step_size', 116), ('y_left_label', 117), ('y_left_data_type', 118), ('y_left_precision', 119), ('y_left_show', 120), ('y_right_min', 121), ('y_right_max', 122), ('y_right_step_size', 123), ('y_right_label', 124), ('y_right_data_type', 125), ('y_right_precision', 126), ('y_right_show', 127), ('pie_border_width', 128), ('pie_border_color', 129)]], {}), 131: ('wagtail.blocks.StructBlock', [[('eyebrow', 96), ('title', 9), ('intro', 97), ('description', 98), ('data_source', 99), ('date_published', 80), ('download_text', 81), ('download_file', 100), ('notes', 101), ('chart_type', 102), ('datasets', 103), ('settings', 130)]], {'colors': (('#20aa3f', 'CFPB Green'), ('#254b87', 'Navy'), ('#7eb7e8', 'Pacific 60'), ('#ffb858', 'Gold 80'), ('#c55998', 'Purple 80'), ('#addc91', 'Green 60'), ('#1fa040', 'Mid Dark Green'), ('#257675', 'Teal'), ('#89b6b5', 'Teal 60'), ('#d14124', 'Red'), ('#e79e8e', 'Red 60'), ('#0072ce', 'Pacific'), ('#254b87', 'Navy'), ('#dc731c', 'Dark Gold'), ('#745745', 'Dark Neutral'), ('#baa496', 'Neutral 60'), ('#dc9cbf', 'Purple 50'), ('#a01b68', 'Dark Purple'), ('#d2d3d5', 'Gray 20'))})}), + ), + ] diff --git a/cfgov/v1/models/learn_page.py b/cfgov/v1/models/learn_page.py index a02e3783d99..4ecbf020af6 100644 --- a/cfgov/v1/models/learn_page.py +++ b/cfgov/v1/models/learn_page.py @@ -99,6 +99,7 @@ class LearnPage(AbstractFilterPage): ("table", organisms.Table()), ("faq_group", schema.FAQGroup()), ("contact_us_table", organisms.ContactUsTable()), + ("wagtailchart_block", charts.ChartBlock()), ], blank=True, )