From 4480dca27d148a1f02107e2df72b617147eb64b0 Mon Sep 17 00:00:00 2001 From: Ans Date: Wed, 18 Dec 2024 10:30:34 -0500 Subject: [PATCH] Update migration --- ..._chart_block.py => 0041_wagtail_charts_chart_block.py} | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) rename cfgov/v1/migrations/{0040_wagtail_charts_chart_block.py => 0041_wagtail_charts_chart_block.py} (51%) diff --git a/cfgov/v1/migrations/0040_wagtail_charts_chart_block.py b/cfgov/v1/migrations/0041_wagtail_charts_chart_block.py similarity index 51% rename from cfgov/v1/migrations/0040_wagtail_charts_chart_block.py rename to cfgov/v1/migrations/0041_wagtail_charts_chart_block.py index 65066b11b25..68984cf6a2d 100644 --- a/cfgov/v1/migrations/0040_wagtail_charts_chart_block.py +++ b/cfgov/v1/migrations/0041_wagtail_charts_chart_block.py @@ -1,4 +1,4 @@ -# Generated by Django 4.2.16 on 2024-11-26 20:37 +# Generated by Django 4.2.17 on 2024-12-18 15:29 from django.db import migrations import v1.atomic_elements.tables @@ -8,14 +8,14 @@ class Migration(migrations.Migration): dependencies = [ - ('v1', '0039_remove_post_event_image'), + ('v1', '0040_blog_expandable_group'), ] operations = [ migrations.AlterField( model_name='blogpage', name='content', - field=wagtail.fields.StreamField([('full_width_text', 42), ('info_unit_group', 53), ('expandable', 56), ('well', 41), ('video_player', 59), ('email_signup', 39), ('simple_chart', 76), ('faq_schema', 85), ('how_to_schema', 95), ('wagtailchart_block', 131)], 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.BooleanBlock', (), {'required': False}), 55: ('wagtail.blocks.StreamBlock', [[('paragraph', 29), ('well', 41), ('links', 33), ('info_unit_group', 53)]], {'blank': True}), 56: ('wagtail.blocks.StructBlock', [[('label', 6), ('icon', 6), ('is_bordered', 54), ('is_midtone', 54), ('is_expanded', 54), ('is_expanded_padding', 54), ('content', 55)]], {}), 57: ('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}), 58: ('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}), 59: ('wagtail.blocks.StructBlock', [[('video_id', 57), ('thumbnail_image', 58)]], {}), 60: ('wagtail.blocks.CharBlock', (), {'required': True}), 61: ('wagtail.blocks.TextBlock', (), {'help_text': 'Accessible description of the chart content', 'required': True}), 62: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('bar', 'Bar'), ('datetime', 'Date/time'), ('line', 'Line'), ('tilemap', 'Tile grid map')]}), 63: ('wagtail.blocks.TextBlock', (), {'help_text': "URL of the chart's data source or an array of JSON data", 'required': True, 'rows': 2}), 64: ('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}), 65: ('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}), 66: ('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}), 67: ('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}), 68: ('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}), 69: ('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}), 70: ('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}), 71: ('wagtail.blocks.CharBlock', (), {'help_text': 'Attribution for the data source', 'required': False}), 72: ('wagtail.blocks.CharBlock', (), {'help_text': 'When the underlying data was published', 'required': False}), 73: ('wagtail.blocks.CharBlock', (), {'help_text': 'Custom text for the chart download field. Required to display a download link.', 'required': False}), 74: ('wagtail.blocks.CharBlock', (), {'help_text': 'Location of a file to download, if different from the data source', 'required': False}), 75: ('wagtail.blocks.TextBlock', (), {'help_text': 'General chart information', 'required': False}), 76: ('wagtail.blocks.StructBlock', [[('title', 60), ('subtitle', 27), ('description', 61), ('figure_number', 6), ('chart_type', 62), ('data_source', 63), ('data_series', 64), ('show_all_series_by_default', 65), ('x_axis_source', 66), ('transform', 67), ('x_axis_label', 6), ('y_axis_label', 6), ('filters', 68), ('style_overrides', 69), ('projected_months', 70), ('source_credits', 71), ('date_published', 72), ('download_text', 73), ('download_file', 74), ('notes', 75)]], {}), 77: ('wagtail.blocks.RichTextBlock', (), {'blank': True, 'features': ['ol', 'ul', 'bold', 'italic', 'link', 'document-link'], 'required': False}), 78: ('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}), 79: ('wagtail.blocks.CharBlock', (), {'max_length': 500}), 80: ('wagtail.blocks.RichTextBlock', (), {'features': ['bold', 'italic', 'h3', 'h4', 'link', 'ol', 'ul', 'document-link', 'image', 'embed'], 'label': 'Text'}), 81: ('wagtail.blocks.StructBlock', [[('content', 80)]], {}), 82: ('wagtail.blocks.StreamBlock', [[('text', 81), ('table', 25), ('video_player', 59)]], {}), 83: ('wagtail.blocks.StructBlock', [[('anchor_tag', 78), ('question', 79), ('answer_content', 82)]], {}), 84: ('wagtail.blocks.ListBlock', (83,), {}), 85: ('wagtail.blocks.StructBlock', [[('description', 77), ('questions', 84)]], {'label': 'FAQ schema'}), 86: ('wagtail.blocks.CharBlock', (), {'label': 'Title of How To section', 'max_length': 500}), 87: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('h2', 'H2'), ('h3', 'H3'), ('h4', 'H4')], 'help_text': 'Choose a tag for the title of the How To section.', 'label': 'Tag for How To section title'}), 88: ('wagtail.blocks.BooleanBlock', (), {'default': True, 'help_text': 'The How To schema requires a title to let search engines understand what it is about. If you do not want the title to be displayed in the page, uncheck this box and the title content will only be made available to crawlers and screen readers.', 'label': 'Show How To section title', 'required': False}), 89: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('h2', 'H2'), ('h3', 'H3'), ('h4', 'H4'), ('b', 'Bold'), ('p', 'Paragraph')], 'help_text': 'Choose a tag for the title of each HowTo step.', 'label': 'Tag for step titles'}), 90: ('wagtail.blocks.BooleanBlock', (), {'default': False, 'help_text': 'Check this box to display numbers before step titles. ', 'label': 'Show numbers for steps', 'required': False}), 91: ('wagtail.blocks.CharBlock', (), {'blank': True, 'help_text': "Add an optional anchor link tag to allow linking directly to this step. Tag should be unique and use dashes or underscores for separation instead of spaces (ie, 'step-one-tag').", 'max_length': 500, 'required': False}), 92: ('wagtail.blocks.CharBlock', (), {'help_text': 'Enter a title for this HowTo step. You do not need to include a number in the title -- numbers will be added automatically in the template if the show numbers checkbox is checked.', 'max_length': 500}), 93: ('wagtail.blocks.StructBlock', [[('anchor_tag', 91), ('title', 92), ('step_content', 82)]], {}), 94: ('wagtail.blocks.ListBlock', (93,), {}), 95: ('wagtail.blocks.StructBlock', [[('title', 86), ('title_tag', 87), ('show_title', 88), ('description', 77), ('step_title_tag', 89), ('has_numbers', 90), ('steps', 94)]], {'label': 'HowTo schema', 'max_num': 1}), 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', 72), ('download_text', 73), ('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'))})}), + field=wagtail.fields.StreamField([('full_width_text', 42), ('info_unit_group', 53), ('expandable', 56), ('expandable_group', 61), ('well', 41), ('video_player', 64), ('email_signup', 39), ('simple_chart', 81), ('faq_schema', 90), ('how_to_schema', 100), ('wagtailchart_block', 136)], 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.BooleanBlock', (), {'required': False}), 55: ('wagtail.blocks.StreamBlock', [[('paragraph', 29), ('well', 41), ('links', 33), ('info_unit_group', 53)]], {'blank': True}), 56: ('wagtail.blocks.StructBlock', [[('label', 6), ('icon', 6), ('is_bordered', 54), ('is_midtone', 54), ('is_expanded', 54), ('is_expanded_padding', 54), ('content', 55)]], {}), 57: ('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}), 58: ('wagtail.blocks.BooleanBlock', (), {'default': False, 'help_text': 'Check this to add a horizontal rule line to top of expandable group.', 'required': False}), 59: ('wagtail.blocks.BooleanBlock', (), {'default': False, 'help_text': 'Check this to add FAQ schema markup to expandables.', 'label': 'Uses FAQ schema', 'required': False}), 60: ('wagtail.blocks.ListBlock', (56,), {}), 61: ('wagtail.blocks.StructBlock', [[('heading', 57), ('body', 29), ('is_accordion', 54), ('has_top_rule_line', 58), ('is_faq', 59), ('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: ('wagtail.blocks.CharBlock', (), {'required': True}), 66: ('wagtail.blocks.TextBlock', (), {'help_text': 'Accessible description of the chart content', 'required': True}), 67: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('bar', 'Bar'), ('datetime', 'Date/time'), ('line', 'Line'), ('tilemap', 'Tile grid map')]}), 68: ('wagtail.blocks.TextBlock', (), {'help_text': "URL of the chart's data source or an array of JSON data", 'required': True, 'rows': 2}), 69: ('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}), 70: ('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}), 71: ('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}), 72: ('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}), 73: ('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}), 74: ('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}), 75: ('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}), 76: ('wagtail.blocks.CharBlock', (), {'help_text': 'Attribution for the data source', 'required': False}), 77: ('wagtail.blocks.CharBlock', (), {'help_text': 'When the underlying data was published', 'required': False}), 78: ('wagtail.blocks.CharBlock', (), {'help_text': 'Custom text for the chart download field. Required to display a download link.', 'required': False}), 79: ('wagtail.blocks.CharBlock', (), {'help_text': 'Location of a file to download, if different from the data source', 'required': False}), 80: ('wagtail.blocks.TextBlock', (), {'help_text': 'General chart information', 'required': False}), 81: ('wagtail.blocks.StructBlock', [[('title', 65), ('subtitle', 27), ('description', 66), ('figure_number', 6), ('chart_type', 67), ('data_source', 68), ('data_series', 69), ('show_all_series_by_default', 70), ('x_axis_source', 71), ('transform', 72), ('x_axis_label', 6), ('y_axis_label', 6), ('filters', 73), ('style_overrides', 74), ('projected_months', 75), ('source_credits', 76), ('date_published', 77), ('download_text', 78), ('download_file', 79), ('notes', 80)]], {}), 82: ('wagtail.blocks.RichTextBlock', (), {'blank': True, 'features': ['ol', 'ul', 'bold', 'italic', 'link', 'document-link'], 'required': False}), 83: ('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}), 84: ('wagtail.blocks.CharBlock', (), {'max_length': 500}), 85: ('wagtail.blocks.RichTextBlock', (), {'features': ['bold', 'italic', 'h3', 'h4', 'link', 'ol', 'ul', 'document-link', 'image', 'embed'], 'label': 'Text'}), 86: ('wagtail.blocks.StructBlock', [[('content', 85)]], {}), 87: ('wagtail.blocks.StreamBlock', [[('text', 86), ('table', 25), ('video_player', 64)]], {}), 88: ('wagtail.blocks.StructBlock', [[('anchor_tag', 83), ('question', 84), ('answer_content', 87)]], {}), 89: ('wagtail.blocks.ListBlock', (88,), {}), 90: ('wagtail.blocks.StructBlock', [[('description', 82), ('questions', 89)]], {'label': 'FAQ schema'}), 91: ('wagtail.blocks.CharBlock', (), {'label': 'Title of How To section', 'max_length': 500}), 92: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('h2', 'H2'), ('h3', 'H3'), ('h4', 'H4')], 'help_text': 'Choose a tag for the title of the How To section.', 'label': 'Tag for How To section title'}), 93: ('wagtail.blocks.BooleanBlock', (), {'default': True, 'help_text': 'The How To schema requires a title to let search engines understand what it is about. If you do not want the title to be displayed in the page, uncheck this box and the title content will only be made available to crawlers and screen readers.', 'label': 'Show How To section title', 'required': False}), 94: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('h2', 'H2'), ('h3', 'H3'), ('h4', 'H4'), ('b', 'Bold'), ('p', 'Paragraph')], 'help_text': 'Choose a tag for the title of each HowTo step.', 'label': 'Tag for step titles'}), 95: ('wagtail.blocks.BooleanBlock', (), {'default': False, 'help_text': 'Check this box to display numbers before step titles. ', 'label': 'Show numbers for steps', 'required': False}), 96: ('wagtail.blocks.CharBlock', (), {'blank': True, 'help_text': "Add an optional anchor link tag to allow linking directly to this step. Tag should be unique and use dashes or underscores for separation instead of spaces (ie, 'step-one-tag').", 'max_length': 500, 'required': False}), 97: ('wagtail.blocks.CharBlock', (), {'help_text': 'Enter a title for this HowTo step. You do not need to include a number in the title -- numbers will be added automatically in the template if the show numbers checkbox is checked.', 'max_length': 500}), 98: ('wagtail.blocks.StructBlock', [[('anchor_tag', 96), ('title', 97), ('step_content', 87)]], {}), 99: ('wagtail.blocks.ListBlock', (98,), {}), 100: ('wagtail.blocks.StructBlock', [[('title', 91), ('title_tag', 92), ('show_title', 93), ('description', 82), ('step_title_tag', 94), ('has_numbers', 95), ('steps', 99)]], {'label': 'HowTo schema', 'max_num': 1}), 101: ('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}), 102: ('wagtail.blocks.RichTextBlock', (), {'icon': 'edit', 'required': False}), 103: ('wagtail.blocks.TextBlock', (), {'help_text': 'Accessible description of the chart content', 'required': False}), 104: ('wagtail.blocks.TextBlock', (), {'help_text': 'Description of the data source', 'required': False}), 105: ('wagtail.blocks.CharBlock', (), {'help_text': 'Location of a file to download', 'required': False}), 106: ('wagtail.blocks.TextBlock', (), {'help_text': 'Note about the chart', 'required': False}), 107: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('line', 'Line Chart'), ('bar', 'Vertical Bar Chart'), ('bar_horizontal', 'Horizontal Bar Chart')], 'label': 'Chart Type'}), 108: ('wagtail.blocks.TextBlock', (), {'default': '{"data":[], "options":{}}'}), 109: ('wagtail.blocks.BooleanBlock', (), {'default': False, 'group': 'General', 'label': 'Show legend', 'required': False}), 110: ('wagtail.blocks.BooleanBlock', (), {'default': False, 'group': 'General', 'label': 'Use HTML legend', 'required': False}), 111: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('top', 'Top'), ('bottom', 'Bottom'), ('left', 'Left'), ('right', 'Right')], 'group': 'General', 'label': 'Legend position'}), 112: ('wagtail.blocks.BooleanBlock', (), {'default': False, 'group': 'General', 'label': 'Reverse legend', 'required': False}), 113: ('wagtail.blocks.BooleanBlock', (), {'default': False, 'group': 'General', 'label': 'Show values on chart', 'required': False}), 114: ('wagtail.blocks.IntegerBlock', (), {'default': 1, 'group': 'General', 'label': 'Precision in labels/tooltips'}), 115: ('wagtail.blocks.BooleanBlock', (), {'default': True, 'group': 'General', 'label': 'Show Chart Grid', 'required': False}), 116: ('wagtail.blocks.CharBlock', (), {'group': 'General', 'label': 'X axis label', 'required': False}), 117: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('none', 'No stacking'), ('stacked', 'Stacked'), ('stacked_100', 'Stacked 100%')], 'group': 'General', 'label': 'Stacking'}), 118: ('wagtail.blocks.CharBlock', (), {'group': 'General', 'label': 'Unit override', 'required': False}), 119: ('wagtail.blocks.CharBlock', (), {'group': 'Left_Axis', 'label': 'Left Y axis minimum value', 'required': False}), 120: ('wagtail.blocks.CharBlock', (), {'group': 'Left_Axis', 'label': 'Left Y axis maximum value', 'required': False}), 121: ('wagtail.blocks.CharBlock', (), {'group': 'Left_Axis', 'label': 'Left Y axis step size', 'required': False}), 122: ('wagtail.blocks.CharBlock', (), {'group': 'Left_Axis', 'label': 'Left Y axis label', 'required': False}), 123: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('number', 'Numerical'), ('percentage', 'Percentage')], 'group': 'Left_Axis', 'label': 'Left Y axis data type', 'required': False}), 124: ('wagtail.blocks.IntegerBlock', (), {'default': 0, 'group': 'Left_Axis', 'label': 'Left Y axis tick precision'}), 125: ('wagtail.blocks.BooleanBlock', (), {'default': True, 'group': 'Left_Axis', 'label': 'Show left axis numbers', 'required': False}), 126: ('wagtail.blocks.CharBlock', (), {'group': 'Right_Axis', 'label': 'Right Y axis minimum value', 'required': False}), 127: ('wagtail.blocks.CharBlock', (), {'group': 'Right_Axis', 'label': 'Right Y axis maximum value', 'required': False}), 128: ('wagtail.blocks.CharBlock', (), {'group': 'Right_Axis', 'label': 'Right Y axis step size', 'required': False}), 129: ('wagtail.blocks.CharBlock', (), {'group': 'Right_Axis', 'label': 'Right Y axis label', 'required': False}), 130: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('number', 'Numerical'), ('percentage', 'Percentage')], 'group': 'Right_Axis', 'label': 'Right Y axis data type', 'required': False}), 131: ('wagtail.blocks.IntegerBlock', (), {'default': 0, 'group': 'Right_Axis', 'label': 'Right Y axis tick precision'}), 132: ('wagtail.blocks.BooleanBlock', (), {'default': True, 'group': 'Right_Axis', 'label': 'Show right axis numbers', 'required': False}), 133: ('wagtail.blocks.IntegerBlock', (), {'default': 2, 'group': 'Pie_Chart', 'label': 'Width of pie slice border'}), 134: ('wagtail.blocks.CharBlock', (), {'default': '#fff', 'group': 'Pie_Chart', 'label': 'Color of pie slice border'}), 135: ('wagtail.blocks.StructBlock', [[('show_legend', 109), ('html_legend', 110), ('legend_position', 111), ('reverse_legend', 112), ('show_values_on_chart', 113), ('precision', 114), ('show_grid', 115), ('x_label', 116), ('stacking', 117), ('unit_override', 118), ('y_left_min', 119), ('y_left_max', 120), ('y_left_step_size', 121), ('y_left_label', 122), ('y_left_data_type', 123), ('y_left_precision', 124), ('y_left_show', 125), ('y_right_min', 126), ('y_right_max', 127), ('y_right_step_size', 128), ('y_right_label', 129), ('y_right_data_type', 130), ('y_right_precision', 131), ('y_right_show', 132), ('pie_border_width', 133), ('pie_border_color', 134)]], {}), 136: ('wagtail.blocks.StructBlock', [[('eyebrow', 101), ('title', 9), ('intro', 102), ('description', 103), ('data_source', 104), ('date_published', 77), ('download_text', 78), ('download_file', 105), ('notes', 106), ('chart_type', 107), ('datasets', 108), ('settings', 135)]], {'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'))})}), ), migrations.AlterField( model_name='browsepage', @@ -30,6 +30,6 @@ class Migration(migrations.Migration): migrations.AlterField( model_name='legacyblogpage', name='content', - field=wagtail.fields.StreamField([('full_width_text', 42), ('info_unit_group', 53), ('expandable', 56), ('well', 41), ('video_player', 59), ('email_signup', 39), ('simple_chart', 76), ('faq_schema', 85), ('how_to_schema', 95), ('wagtailchart_block', 131), ('content', 132), ('reusable_text', 37)], 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.BooleanBlock', (), {'required': False}), 55: ('wagtail.blocks.StreamBlock', [[('paragraph', 29), ('well', 41), ('links', 33), ('info_unit_group', 53)]], {'blank': True}), 56: ('wagtail.blocks.StructBlock', [[('label', 6), ('icon', 6), ('is_bordered', 54), ('is_midtone', 54), ('is_expanded', 54), ('is_expanded_padding', 54), ('content', 55)]], {}), 57: ('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}), 58: ('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}), 59: ('wagtail.blocks.StructBlock', [[('video_id', 57), ('thumbnail_image', 58)]], {}), 60: ('wagtail.blocks.CharBlock', (), {'required': True}), 61: ('wagtail.blocks.TextBlock', (), {'help_text': 'Accessible description of the chart content', 'required': True}), 62: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('bar', 'Bar'), ('datetime', 'Date/time'), ('line', 'Line'), ('tilemap', 'Tile grid map')]}), 63: ('wagtail.blocks.TextBlock', (), {'help_text': "URL of the chart's data source or an array of JSON data", 'required': True, 'rows': 2}), 64: ('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}), 65: ('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}), 66: ('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}), 67: ('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}), 68: ('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}), 69: ('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}), 70: ('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}), 71: ('wagtail.blocks.CharBlock', (), {'help_text': 'Attribution for the data source', 'required': False}), 72: ('wagtail.blocks.CharBlock', (), {'help_text': 'When the underlying data was published', 'required': False}), 73: ('wagtail.blocks.CharBlock', (), {'help_text': 'Custom text for the chart download field. Required to display a download link.', 'required': False}), 74: ('wagtail.blocks.CharBlock', (), {'help_text': 'Location of a file to download, if different from the data source', 'required': False}), 75: ('wagtail.blocks.TextBlock', (), {'help_text': 'General chart information', 'required': False}), 76: ('wagtail.blocks.StructBlock', [[('title', 60), ('subtitle', 27), ('description', 61), ('figure_number', 6), ('chart_type', 62), ('data_source', 63), ('data_series', 64), ('show_all_series_by_default', 65), ('x_axis_source', 66), ('transform', 67), ('x_axis_label', 6), ('y_axis_label', 6), ('filters', 68), ('style_overrides', 69), ('projected_months', 70), ('source_credits', 71), ('date_published', 72), ('download_text', 73), ('download_file', 74), ('notes', 75)]], {}), 77: ('wagtail.blocks.RichTextBlock', (), {'blank': True, 'features': ['ol', 'ul', 'bold', 'italic', 'link', 'document-link'], 'required': False}), 78: ('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}), 79: ('wagtail.blocks.CharBlock', (), {'max_length': 500}), 80: ('wagtail.blocks.RichTextBlock', (), {'features': ['bold', 'italic', 'h3', 'h4', 'link', 'ol', 'ul', 'document-link', 'image', 'embed'], 'label': 'Text'}), 81: ('wagtail.blocks.StructBlock', [[('content', 80)]], {}), 82: ('wagtail.blocks.StreamBlock', [[('text', 81), ('table', 25), ('video_player', 59)]], {}), 83: ('wagtail.blocks.StructBlock', [[('anchor_tag', 78), ('question', 79), ('answer_content', 82)]], {}), 84: ('wagtail.blocks.ListBlock', (83,), {}), 85: ('wagtail.blocks.StructBlock', [[('description', 77), ('questions', 84)]], {'label': 'FAQ schema'}), 86: ('wagtail.blocks.CharBlock', (), {'label': 'Title of How To section', 'max_length': 500}), 87: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('h2', 'H2'), ('h3', 'H3'), ('h4', 'H4')], 'help_text': 'Choose a tag for the title of the How To section.', 'label': 'Tag for How To section title'}), 88: ('wagtail.blocks.BooleanBlock', (), {'default': True, 'help_text': 'The How To schema requires a title to let search engines understand what it is about. If you do not want the title to be displayed in the page, uncheck this box and the title content will only be made available to crawlers and screen readers.', 'label': 'Show How To section title', 'required': False}), 89: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('h2', 'H2'), ('h3', 'H3'), ('h4', 'H4'), ('b', 'Bold'), ('p', 'Paragraph')], 'help_text': 'Choose a tag for the title of each HowTo step.', 'label': 'Tag for step titles'}), 90: ('wagtail.blocks.BooleanBlock', (), {'default': False, 'help_text': 'Check this box to display numbers before step titles. ', 'label': 'Show numbers for steps', 'required': False}), 91: ('wagtail.blocks.CharBlock', (), {'blank': True, 'help_text': "Add an optional anchor link tag to allow linking directly to this step. Tag should be unique and use dashes or underscores for separation instead of spaces (ie, 'step-one-tag').", 'max_length': 500, 'required': False}), 92: ('wagtail.blocks.CharBlock', (), {'help_text': 'Enter a title for this HowTo step. You do not need to include a number in the title -- numbers will be added automatically in the template if the show numbers checkbox is checked.', 'max_length': 500}), 93: ('wagtail.blocks.StructBlock', [[('anchor_tag', 91), ('title', 92), ('step_content', 82)]], {}), 94: ('wagtail.blocks.ListBlock', (93,), {}), 95: ('wagtail.blocks.StructBlock', [[('title', 86), ('title_tag', 87), ('show_title', 88), ('description', 77), ('step_title_tag', 89), ('has_numbers', 90), ('steps', 94)]], {'label': 'HowTo schema', 'max_num': 1}), 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', 72), ('download_text', 73), ('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'))}), 132: ('wagtail.blocks.RawHTMLBlock', (), {'help_text': 'Content from WordPress unescaped.'})}), + field=wagtail.fields.StreamField([('full_width_text', 42), ('info_unit_group', 53), ('expandable', 56), ('expandable_group', 61), ('well', 41), ('video_player', 64), ('email_signup', 39), ('simple_chart', 81), ('faq_schema', 90), ('how_to_schema', 100), ('wagtailchart_block', 136), ('content', 137), ('reusable_text', 37)], 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.BooleanBlock', (), {'required': False}), 55: ('wagtail.blocks.StreamBlock', [[('paragraph', 29), ('well', 41), ('links', 33), ('info_unit_group', 53)]], {'blank': True}), 56: ('wagtail.blocks.StructBlock', [[('label', 6), ('icon', 6), ('is_bordered', 54), ('is_midtone', 54), ('is_expanded', 54), ('is_expanded_padding', 54), ('content', 55)]], {}), 57: ('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}), 58: ('wagtail.blocks.BooleanBlock', (), {'default': False, 'help_text': 'Check this to add a horizontal rule line to top of expandable group.', 'required': False}), 59: ('wagtail.blocks.BooleanBlock', (), {'default': False, 'help_text': 'Check this to add FAQ schema markup to expandables.', 'label': 'Uses FAQ schema', 'required': False}), 60: ('wagtail.blocks.ListBlock', (56,), {}), 61: ('wagtail.blocks.StructBlock', [[('heading', 57), ('body', 29), ('is_accordion', 54), ('has_top_rule_line', 58), ('is_faq', 59), ('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: ('wagtail.blocks.CharBlock', (), {'required': True}), 66: ('wagtail.blocks.TextBlock', (), {'help_text': 'Accessible description of the chart content', 'required': True}), 67: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('bar', 'Bar'), ('datetime', 'Date/time'), ('line', 'Line'), ('tilemap', 'Tile grid map')]}), 68: ('wagtail.blocks.TextBlock', (), {'help_text': "URL of the chart's data source or an array of JSON data", 'required': True, 'rows': 2}), 69: ('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}), 70: ('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}), 71: ('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}), 72: ('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}), 73: ('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}), 74: ('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}), 75: ('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}), 76: ('wagtail.blocks.CharBlock', (), {'help_text': 'Attribution for the data source', 'required': False}), 77: ('wagtail.blocks.CharBlock', (), {'help_text': 'When the underlying data was published', 'required': False}), 78: ('wagtail.blocks.CharBlock', (), {'help_text': 'Custom text for the chart download field. Required to display a download link.', 'required': False}), 79: ('wagtail.blocks.CharBlock', (), {'help_text': 'Location of a file to download, if different from the data source', 'required': False}), 80: ('wagtail.blocks.TextBlock', (), {'help_text': 'General chart information', 'required': False}), 81: ('wagtail.blocks.StructBlock', [[('title', 65), ('subtitle', 27), ('description', 66), ('figure_number', 6), ('chart_type', 67), ('data_source', 68), ('data_series', 69), ('show_all_series_by_default', 70), ('x_axis_source', 71), ('transform', 72), ('x_axis_label', 6), ('y_axis_label', 6), ('filters', 73), ('style_overrides', 74), ('projected_months', 75), ('source_credits', 76), ('date_published', 77), ('download_text', 78), ('download_file', 79), ('notes', 80)]], {}), 82: ('wagtail.blocks.RichTextBlock', (), {'blank': True, 'features': ['ol', 'ul', 'bold', 'italic', 'link', 'document-link'], 'required': False}), 83: ('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}), 84: ('wagtail.blocks.CharBlock', (), {'max_length': 500}), 85: ('wagtail.blocks.RichTextBlock', (), {'features': ['bold', 'italic', 'h3', 'h4', 'link', 'ol', 'ul', 'document-link', 'image', 'embed'], 'label': 'Text'}), 86: ('wagtail.blocks.StructBlock', [[('content', 85)]], {}), 87: ('wagtail.blocks.StreamBlock', [[('text', 86), ('table', 25), ('video_player', 64)]], {}), 88: ('wagtail.blocks.StructBlock', [[('anchor_tag', 83), ('question', 84), ('answer_content', 87)]], {}), 89: ('wagtail.blocks.ListBlock', (88,), {}), 90: ('wagtail.blocks.StructBlock', [[('description', 82), ('questions', 89)]], {'label': 'FAQ schema'}), 91: ('wagtail.blocks.CharBlock', (), {'label': 'Title of How To section', 'max_length': 500}), 92: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('h2', 'H2'), ('h3', 'H3'), ('h4', 'H4')], 'help_text': 'Choose a tag for the title of the How To section.', 'label': 'Tag for How To section title'}), 93: ('wagtail.blocks.BooleanBlock', (), {'default': True, 'help_text': 'The How To schema requires a title to let search engines understand what it is about. If you do not want the title to be displayed in the page, uncheck this box and the title content will only be made available to crawlers and screen readers.', 'label': 'Show How To section title', 'required': False}), 94: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('h2', 'H2'), ('h3', 'H3'), ('h4', 'H4'), ('b', 'Bold'), ('p', 'Paragraph')], 'help_text': 'Choose a tag for the title of each HowTo step.', 'label': 'Tag for step titles'}), 95: ('wagtail.blocks.BooleanBlock', (), {'default': False, 'help_text': 'Check this box to display numbers before step titles. ', 'label': 'Show numbers for steps', 'required': False}), 96: ('wagtail.blocks.CharBlock', (), {'blank': True, 'help_text': "Add an optional anchor link tag to allow linking directly to this step. Tag should be unique and use dashes or underscores for separation instead of spaces (ie, 'step-one-tag').", 'max_length': 500, 'required': False}), 97: ('wagtail.blocks.CharBlock', (), {'help_text': 'Enter a title for this HowTo step. You do not need to include a number in the title -- numbers will be added automatically in the template if the show numbers checkbox is checked.', 'max_length': 500}), 98: ('wagtail.blocks.StructBlock', [[('anchor_tag', 96), ('title', 97), ('step_content', 87)]], {}), 99: ('wagtail.blocks.ListBlock', (98,), {}), 100: ('wagtail.blocks.StructBlock', [[('title', 91), ('title_tag', 92), ('show_title', 93), ('description', 82), ('step_title_tag', 94), ('has_numbers', 95), ('steps', 99)]], {'label': 'HowTo schema', 'max_num': 1}), 101: ('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}), 102: ('wagtail.blocks.RichTextBlock', (), {'icon': 'edit', 'required': False}), 103: ('wagtail.blocks.TextBlock', (), {'help_text': 'Accessible description of the chart content', 'required': False}), 104: ('wagtail.blocks.TextBlock', (), {'help_text': 'Description of the data source', 'required': False}), 105: ('wagtail.blocks.CharBlock', (), {'help_text': 'Location of a file to download', 'required': False}), 106: ('wagtail.blocks.TextBlock', (), {'help_text': 'Note about the chart', 'required': False}), 107: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('line', 'Line Chart'), ('bar', 'Vertical Bar Chart'), ('bar_horizontal', 'Horizontal Bar Chart')], 'label': 'Chart Type'}), 108: ('wagtail.blocks.TextBlock', (), {'default': '{"data":[], "options":{}}'}), 109: ('wagtail.blocks.BooleanBlock', (), {'default': False, 'group': 'General', 'label': 'Show legend', 'required': False}), 110: ('wagtail.blocks.BooleanBlock', (), {'default': False, 'group': 'General', 'label': 'Use HTML legend', 'required': False}), 111: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('top', 'Top'), ('bottom', 'Bottom'), ('left', 'Left'), ('right', 'Right')], 'group': 'General', 'label': 'Legend position'}), 112: ('wagtail.blocks.BooleanBlock', (), {'default': False, 'group': 'General', 'label': 'Reverse legend', 'required': False}), 113: ('wagtail.blocks.BooleanBlock', (), {'default': False, 'group': 'General', 'label': 'Show values on chart', 'required': False}), 114: ('wagtail.blocks.IntegerBlock', (), {'default': 1, 'group': 'General', 'label': 'Precision in labels/tooltips'}), 115: ('wagtail.blocks.BooleanBlock', (), {'default': True, 'group': 'General', 'label': 'Show Chart Grid', 'required': False}), 116: ('wagtail.blocks.CharBlock', (), {'group': 'General', 'label': 'X axis label', 'required': False}), 117: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('none', 'No stacking'), ('stacked', 'Stacked'), ('stacked_100', 'Stacked 100%')], 'group': 'General', 'label': 'Stacking'}), 118: ('wagtail.blocks.CharBlock', (), {'group': 'General', 'label': 'Unit override', 'required': False}), 119: ('wagtail.blocks.CharBlock', (), {'group': 'Left_Axis', 'label': 'Left Y axis minimum value', 'required': False}), 120: ('wagtail.blocks.CharBlock', (), {'group': 'Left_Axis', 'label': 'Left Y axis maximum value', 'required': False}), 121: ('wagtail.blocks.CharBlock', (), {'group': 'Left_Axis', 'label': 'Left Y axis step size', 'required': False}), 122: ('wagtail.blocks.CharBlock', (), {'group': 'Left_Axis', 'label': 'Left Y axis label', 'required': False}), 123: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('number', 'Numerical'), ('percentage', 'Percentage')], 'group': 'Left_Axis', 'label': 'Left Y axis data type', 'required': False}), 124: ('wagtail.blocks.IntegerBlock', (), {'default': 0, 'group': 'Left_Axis', 'label': 'Left Y axis tick precision'}), 125: ('wagtail.blocks.BooleanBlock', (), {'default': True, 'group': 'Left_Axis', 'label': 'Show left axis numbers', 'required': False}), 126: ('wagtail.blocks.CharBlock', (), {'group': 'Right_Axis', 'label': 'Right Y axis minimum value', 'required': False}), 127: ('wagtail.blocks.CharBlock', (), {'group': 'Right_Axis', 'label': 'Right Y axis maximum value', 'required': False}), 128: ('wagtail.blocks.CharBlock', (), {'group': 'Right_Axis', 'label': 'Right Y axis step size', 'required': False}), 129: ('wagtail.blocks.CharBlock', (), {'group': 'Right_Axis', 'label': 'Right Y axis label', 'required': False}), 130: ('wagtail.blocks.ChoiceBlock', [], {'choices': [('number', 'Numerical'), ('percentage', 'Percentage')], 'group': 'Right_Axis', 'label': 'Right Y axis data type', 'required': False}), 131: ('wagtail.blocks.IntegerBlock', (), {'default': 0, 'group': 'Right_Axis', 'label': 'Right Y axis tick precision'}), 132: ('wagtail.blocks.BooleanBlock', (), {'default': True, 'group': 'Right_Axis', 'label': 'Show right axis numbers', 'required': False}), 133: ('wagtail.blocks.IntegerBlock', (), {'default': 2, 'group': 'Pie_Chart', 'label': 'Width of pie slice border'}), 134: ('wagtail.blocks.CharBlock', (), {'default': '#fff', 'group': 'Pie_Chart', 'label': 'Color of pie slice border'}), 135: ('wagtail.blocks.StructBlock', [[('show_legend', 109), ('html_legend', 110), ('legend_position', 111), ('reverse_legend', 112), ('show_values_on_chart', 113), ('precision', 114), ('show_grid', 115), ('x_label', 116), ('stacking', 117), ('unit_override', 118), ('y_left_min', 119), ('y_left_max', 120), ('y_left_step_size', 121), ('y_left_label', 122), ('y_left_data_type', 123), ('y_left_precision', 124), ('y_left_show', 125), ('y_right_min', 126), ('y_right_max', 127), ('y_right_step_size', 128), ('y_right_label', 129), ('y_right_data_type', 130), ('y_right_precision', 131), ('y_right_show', 132), ('pie_border_width', 133), ('pie_border_color', 134)]], {}), 136: ('wagtail.blocks.StructBlock', [[('eyebrow', 101), ('title', 9), ('intro', 102), ('description', 103), ('data_source', 104), ('date_published', 77), ('download_text', 78), ('download_file', 105), ('notes', 106), ('chart_type', 107), ('datasets', 108), ('settings', 135)]], {'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'))}), 137: ('wagtail.blocks.RawHTMLBlock', (), {'help_text': 'Content from WordPress unescaped.'})}), ), ]