curriculum/challenges/english/blocks/daily-coding-challenges-javascript/69162d64f96574d9bb629f00.md
Given a string representing an ordered list item in Markdown, return the equivalent HTML string.
A valid ordered list item in Markdown must:
.), followed byIf the string doesn't have the exact format above, return "Invalid format". Otherwise, wrap the list item text in li tags and return the string.
For example, given "1. My item", return "<li>My item</li>".
Note: The console may not display HTML tags in strings when logging messages. Check the browser console to see logs with tags included.
convertListItem("1. My item") should return "<li>My item</li>".
assert.equal(convertListItem("1. My item"), "<li>My item</li>");
convertListItem(" 1. Another item") should return "<li>Another item</li>".
assert.equal(convertListItem(" 1. Another item"), "<li>Another item</li>");
convertListItem("1 . invalid item") should return "Invalid format".
assert.equal(convertListItem("1 . invalid item"), "Invalid format");
convertListItem("2. list item text") should return "<li>list item text</li>".
assert.equal(convertListItem("2. list item text"), "<li>list item text</li>");
convertListItem(". invalid again") should return "Invalid format".
assert.equal(convertListItem(". invalid again"), "Invalid format");
convertListItem("A. last invalid") should return "Invalid format".
assert.equal(convertListItem("A. last invalid"), "Invalid format");
function convertListItem(markdown) {
return markdown;
}
function convertListItem(markdown) {
const match = markdown.match(/^\s*(\d+)\.\s+(.+)$/);
if (!match) return "Invalid format";
const text = match[2];
return `<li>${text}</li>`;
}