"elements": list(elements)
}
+def checkbox_block(label, text, name, checked=False):
+
+ element = {
+ "type": "checkboxes",
+ "options": [
+ {
+ "value": name,
+ "text": {
+ "type": "plain_text",
+ "text": text
+ }
+ }
+ ]
+ }
+
+ if checked:
+ element["initial_options"] = [{
+ "value": name,
+ "text": {
+ "type": "plain_text",
+ "text": text
+ }
+ }]
+
+ return {
+ "type": "input",
+ "block_id": name,
+ "element": element,
+ "optional": True,
+ "label": {
+ "type": "plain_text",
+ "text": label
+ }
+ }
+
def button_block(label, name, extra=None):
block = {
}
}
-def input_block(label, name, placeholder, optional=False):
+def input_block(label, name, placeholder, initial_value=None, optional=False):
+
+ element = {
+ "type": "plain_text_input",
+ "action_id": name,
+ "placeholder": {
+ "type": "plain_text",
+ "text": placeholder,
+ }
+ }
+
+ if initial_value:
+ element["initial_value"] = initial_value
+
return {
"type": "input",
"block_id": name,
"optional": optional,
- "element": {
- "type": "plain_text_input",
- "action_id": name,
- "placeholder": {
- "type": "plain_text",
- "text": placeholder,
- }
- },
+ "element": element,
"label": {
"type": "plain_text",
"text": label
}
}
-def multi_select_block(label, name, placeholder, options, default=None):
+def multi_select_block(label, name, placeholder, options,
+ initial_options=None):
- multi_select = {
+ multi_select = {
"action_id": name,
"type": "multi_static_select",
"placeholder": {
]
}
+ if initial_options:
+ multi_select["initial_options"] = [
+ {
+ "text": {
+ "type": "plain_text",
+ "text": option
+ },
+ "value": option
+ } for option in initial_options
+ ]
+
return accessory_block(
section_block(text_block("*{}*".format(label)), block_id=name),
multi_select
from slack.errors import SlackApiError
from turbot.blocks import (
- input_block, section_block, text_block, multi_select_block
+ input_block, section_block, text_block, multi_select_block, checkbox_block
)
from turbot.hunt import find_hunt_for_hunt_id, hunt_blocks
-from turbot.puzzle import find_puzzle_for_url
+from turbot.puzzle import find_puzzle_for_url, find_puzzle_for_puzzle_id
import turbot.rot
import turbot.sheets
import turbot.slack
def edit_puzzle(turb, payload):
"""Handler for the action of user pressing an edit_puzzle button"""
- print("DEBUG: In edit_puzzle with payload: {}".format(str(payload)))
+ action_id = payload['actions'][0]['action_id']
+ response_url = payload['response_url']
+ trigger_id = payload['trigger_id']
+
+ (hunt_id, puzzle_id) = action_id.split('-', 1)
+
+ puzzle = find_puzzle_for_puzzle_id(turb, hunt_id, puzzle_id)
+
+ if not puzzle:
+ requests.post(response_url,
+ json = {"text": "Error: Puzzle not found!"},
+ headers = {"Content-type": "application/json"})
+ return bot_reply("Error: Puzzle not found.")
+
+ round_options = hunt_rounds(turb, hunt_id)
+
+ if len(round_options):
+ round_options_block = [
+ multi_select_block("Round(s)", "rounds",
+ "Existing round(s) this puzzle belongs to",
+ round_options,
+ initial_options=puzzle.get("rounds", None)),
+ ]
+ else:
+ round_options_block = []
+
+ solved = False
+ if puzzle.get("status", "unsolved") == solved:
+ solved = True
+
+ solution_str = None
+ solution_list = puzzle.get("solution", [])
+ if solution_list:
+ solution_str = ", ".join(solution_list)
+
+ view = {
+ "type": "modal",
+ "private_metadata": json.dumps({
+ "hunt_id": hunt_id,
+ "SK": puzzle["SK"],
+ "puzzle_id": puzzle_id,
+ "channel_id": puzzle["channel_id"],
+ "channel_url": puzzle["channel_url"],
+ "sheet_url": puzzle["sheet_url"],
+ }),
+ "title": {"type": "plain_text", "text": "Edit Puzzle"},
+ "submit": { "type": "plain_text", "text": "Save" },
+ "blocks": [
+ input_block("Puzzle name", "name", "Name of the puzzle",
+ initial_value=puzzle["name"]),
+ input_block("Puzzle URL", "url", "External URL of puzzle",
+ initial_value=puzzle.get("url", None),
+ optional=True),
+ * round_options_block,
+ input_block("New round(s)", "new_rounds",
+ "New round(s) this puzzle belongs to " +
+ "(comma separated)",
+ optional=True),
+ input_block("State", "state",
+ "State of this puzzle (partial progress, next steps)",
+ initial_value=puzzle.get("state", None),
+ optional=True),
+ checkbox_block(
+ "Puzzle status", "Solved", "solved",
+ checked=(puzzle.get('status', 'unsolved') == 'solved')),
+ input_block("Solution", "solution",
+ "Solutions (comma-separated if multiple",
+ initial_value=solution_str,
+ optional=True),
+ ]
+ }
+
+ result = turb.slack_client.views_open(trigger_id=trigger_id,
+ view=view)
+
+ if (result['ok']):
+ submission_handlers[result['view']['id']] = edit_puzzle_submission
return lambda_ok
actions['button']['edit_puzzle'] = edit_puzzle
+def edit_puzzle_submission(turb, payload, metadata):
+ """Handler for the user submitting the edit puzzle modal
+
+ This is the modal view presented to the user by the edit_puzzle
+ function above.
+ """
+
+ return lambda_ok
+
def new_hunt(turb, payload):
"""Handler for the action of user pressing the new_hunt button"""