forked from apluslms/a-plus-rst-tools
-
Notifications
You must be signed in to change notification settings - Fork 0
/
aplus_setup.py
108 lines (98 loc) · 5.57 KB
/
aplus_setup.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
'''
This extension setup bundes the different a-plus custom directives.
The bundling was motivated by the shared node types and other shared modules.
Having unused directives will not have a significant performance impact.
If necessary, edit this setup to select the loaded directives.
'''
import toc_config
import aplus_nodes
from directives.meta import AplusMeta
from directives.questionnaire import Questionnaire, SingleChoice, MultipleChoice, FreeText, AgreeGroup, AgreeItem, AgreeItemGenerate
from directives.submit import SubmitForm
from directives.ae_input import ActiveElementInput
from directives.ae_output import ActiveElementOutput
from directives.hiddenblock import HiddenBlock
from directives.exercisecollection import ExerciseCollection
from directives.div import DivDirective, DivNode
from directives.bootstrap_styled_topic import StyledTopicDirective
from directives.acos_submit import ACOSSubmitDirective
def setup(app):
# Register new settings.
app.add_config_value('course_title', None, 'html')
app.add_config_value('submit_title', "{config_title}", 'html')
app.add_config_value('course_open_date', None, 'html')
app.add_config_value('course_close_date', None, 'html')
app.add_config_value('aplusmeta_substitutions', {}, 'html')
app.add_config_value('questionnaire_default_submissions', 5, 'html')
app.add_config_value('program_default_submissions', 10, 'html')
app.add_config_value('default_min_group_size', 1, 'html')
app.add_config_value('default_max_group_size', 1, 'html')
app.add_config_value('default_late_date', None, 'html')
app.add_config_value('default_late_penalty', 0.0, 'html')
app.add_config_value('use_wide_column', True, 'html')
app.add_config_value('append_content', [], 'html')
app.add_config_value('override', {}, 'html')
app.add_config_value('category_names', {}, 'html')
app.add_config_value('static_host', None, 'html')
app.add_config_value('ae_default_submissions', 0, 'html')
app.add_config_value('skip_language_inconsistencies', False, 'html')
app.add_config_value('allow_assistant_viewing', True, 'html')
app.add_config_value('allow_assistant_grading', False, 'html')
app.add_config_value('enable_rst_file_language_detection', True, 'html')
app.add_config_value('course_head_urls', None, 'html')
app.add_config_value('bootstrap_styled_topic_classes', 'dl-horizontal topic', 'html')
app.add_config_value('acos_submit_base_url', 'http://172.21.0.2:3000', 'html')
app.add_config_value('enable_doc_link_multilang_suffix_correction', False, 'html')
app.add_config_value('enable_ref_link_multilang_suffix_correction', False, 'html')
app.add_config_value('reveal_submission_feedback', None, 'html')
app.add_config_value('reveal_model_solutions', None, 'html')
app.add_config_value('enable_autosave', False, 'html')
# Connect configuration generation to events.
app.connect('builder-inited', toc_config.prepare)
app.connect('source-read', toc_config.set_config_language_for_doc)
app.connect('source-read', lambda app, docname, source:
toc_config.add_lang_suffix_to_links(app, docname, source))
app.connect('doctree-resolved', lambda app, doctree, docname:
toc_config.set_config_language_for_doc(app, docname, None))
app.connect('build-finished', toc_config.write)
# Add node type that can describe HTML elements and store configurations.
app.add_node(
aplus_nodes.html,
html=(aplus_nodes.visit_html, aplus_nodes.depart_html),
latex=(aplus_nodes.visit_ignore, aplus_nodes.depart_ignore),
# TODO: This html node is used by the A+ exercise directives that embed exercises into chapters.
# The Latex builder could insert some content about the exercise to show where it would
# be embedded in the HTML page instead of completely ignoring the exercise directive.
# There could be a configuration option to control whether the Latex builder should
# ignore exercises or not.
# Note: even though these latex visitor functions do nothing, the exercise directives
# nonetheless output some text to the Latex/PDF output. The text is even often duplicated
# multiple times. This is possibly caused by broken aplus_nodes classes that interfere
# with the builder output even though only the visitor functions should do that.
)
app.add_node(DivNode, html=(DivNode.visit_div, DivNode.depart_div))
# The directive for injecting document meta data.
app.add_node(
aplus_nodes.aplusmeta,
html=(aplus_nodes.visit_ignore, aplus_nodes.depart_ignore),
latex=(aplus_nodes.visit_ignore, aplus_nodes.depart_ignore),
)
app.add_directive('aplusmeta', AplusMeta)
# The questionnaire directives.
app.add_directive('questionnaire', Questionnaire)
app.add_directive('pick-one', SingleChoice)
app.add_directive('pick-any', MultipleChoice)
app.add_directive('freetext', FreeText)
app.add_directive('agree-group', AgreeGroup)
app.add_directive('agree-item', AgreeItem)
app.add_directive('agree-item-generate', AgreeItemGenerate)
app.add_directive('div', DivDirective)
app.add_directive('styled-topic', StyledTopicDirective)
app.add_directive('acos-submit', ACOSSubmitDirective)
# The submit directive.
app.add_directive('submit', SubmitForm)
app.add_directive('ae-input', ActiveElementInput)
app.add_directive('ae-output', ActiveElementOutput)
app.add_directive('hidden-block', HiddenBlock)
# ExerciseCollection directive
app.add_directive('exercisecollection', ExerciseCollection)