1
0
mirror of https://github.com/Jermolene/TiddlyWiki5 synced 2025-01-20 22:16:52 +00:00

feat: add to styleblock

This commit is contained in:
lin onetwo 2024-08-08 01:16:27 +08:00
parent fb8732a081
commit 078cd5fba2
4 changed files with 97 additions and 43 deletions

View File

@ -73,17 +73,20 @@ exports.parse = function() {
}];
};
exports.serialize = function(tree, serialize) {
// tree: { type: 'element', tag: 'blockquote', attributes: { class: { type: 'string', value: 'tc-quote' } }, children: [{ type: 'text', text: 'Quote text' }] }
// serialize: function that accepts array of nodes or a node and returns a string
// Split the class attribute value into an array of classes, classes: ['tc-quote']
var classes = tree.attributes.class.value.split(" ");
// Start the serialized string with the opening delimiter and classes, serialized: '<<<tc-quote\n'
var serialized = "<<<" + classes.join(" ") + "\n";
// Serialize the children of the blockquote, serialized: '<<<tc-quote\nQuote text'
serialized += serialize(tree.children);
// Return the complete serialized string with the closing delimiter, serialized: '<<<tc-quote\nQuote text\n<<<'
return serialized + "\n<<<";
exports.serialize = function (tree, serialize) {
// tree: { type: "element", tag: "blockquote", attributes: { class: { type: "string", value: "tc-quote" } }, children: [{ type: "element", tag: "cite", children: [{ type: "text", text: "tc-quote" }] }, { type: "element", tag: "p", children: [{ type: "text", text: "Quote text\n" }] }] }
var result = [];
if(tree.type === "element" && tree.tag === "blockquote") {
// tree.attributes.class.value: "tc-quote"
result.push("<<<" + tree.attributes.class.value);
tree.children.forEach(function (child) {
if(child.type === "element" && child.tag === "p") {
result.push(serialize(child.children).trim());
}
});
result.push("<<<");
}
return result.join("\n");
};
})();

View File

@ -57,21 +57,33 @@ exports.parse = function() {
if(tokens.length > 0) {
this.parser.amendRules(tokens[0],tokens.slice(1));
}
// No parse tree nodes to return
return [];
// No widget to render, return void node.
return [{
type: "void",
attributes: {
action: {type: "string", value: tokens[0]},
rules: {type: "string", value: tokens.slice(1).join(" ")}
},
children: []
}];
};
exports.serialize = function(tree, serialize) {
// tree: { type: 'pragma', name: 'rules', args: ['except', 'ruleone', 'ruletwo', 'rulethree'] }
// serialize: function that accepts array of nodes or a node and returns a string
// Start the serialized string with the pragma name
var serialized = "\\rules";
// Iterate over the arguments and append them to the serialized string
for(var i = 0; i < tree.args.length; i++) {
serialized += " " + tree.args[i];
exports.serialize = function (tree, serialize) {
// tree: { type: "void", attributes: { action: { type: "string", value: "except" }, rules: { type: "string", value: "ruleone ruletwo rulethree" } }, children: [{ type: "void", attributes: { action: { type: "string", value: "only" }, rules: { type: "string", value: "ruleone ruletwo rulethree" } }, children: [] }] }
var result = [];
if(tree.attributes.action && tree.attributes.rules) {
// tree.attributes.action.value: "except"
// tree.attributes.rules.value: "ruleone ruletwo rulethree"
result.push("\\rules " + tree.attributes.action.value + " " + tree.attributes.rules.value);
tree.children.forEach(function (child) {
if(child.type === "void" && child.attributes.action && child.attributes.rules) {
// child.attributes.action.value: "only"
// child.attributes.rules.value: "ruleone ruletwo rulethree"
result.push("\\rules " + child.attributes.action.value + " " + child.attributes.rules.value);
}
});
}
// Return the complete serialized string
return serialized;
return result.join("\n");
};
})();

View File

@ -67,29 +67,62 @@ exports.parse = function() {
$tw.utils.addAttributeToParseTreeNode(tree[t],"style",styles.join(""));
}
}
return tree;
return [{
type: "void",
children: tree
}]
};
exports.serialize = function(tree, serialize) {
// tree: [{ type: 'element', tag: 'p', attributes: { class: { type: 'string', value: 'myClass' }, style: { type: 'string', value: 'background-color:red;' } }, children: [{ type: 'text', text: 'This paragraph will have the CSS class `myClass`.' }] }]
// serialize: function that accepts array of nodes or a node and returns a string
// Initialize the serialized string with the opening delimiter
var serialized = "@@";
// Check for styles and append them to the serialized string
if(tree[0].attributes.style) {
serialized += tree[0].attributes.style.value;
}
// Check for classes and append them to the serialized string
if(tree[0].attributes.class) {
var classes = tree[0].attributes.class.value.split(" ");
for(var i = 0; i < classes.length; i++) {
serialized += "." + classes[i];
// serialize: function that serializes an array of nodes or a single node to a string
var result = [];
var classes = [];
var styles = [];
// Collect all unique classes and styles from child nodes
for(var i = 0; i < tree.children.length; i++) {
var node = tree.children[i];
if(node.attributes && node.attributes.class) {
var nodeClasses = node.attributes.class.value.split(" ");
for(var j = 0; j < nodeClasses.length; j++) {
if(classes.indexOf(nodeClasses[j]) === -1) {
classes.push(nodeClasses[j]);
}
}
}
if(node.attributes && node.attributes.style) {
var nodeStyles = node.attributes.style.value.split(";");
for(var k = 0; k < nodeStyles.length; k++) {
var style = nodeStyles[k].trim();
if(style && styles.indexOf(style) === -1) {
styles.push(style);
}
}
}
}
// Append the serialized children and the closing delimiter
serialized += "\n" + serialize(tree) + "\n@@";
// Return the complete serialized string
return serialized;
// Add the style block header if there are any classes or styles
if(classes.length > 0 || styles.length > 0) {
if(styles.length > 0) {
result.push("@@");
result.push(styles.join(";"));
result.push(";\n");
}
if(classes.length > 0) {
result.push("@@.");
result.push(classes.join("."));
result.push("\n");
}
}
// Serialize each child node and add to result
for(var i = 0; i < tree.children.length; i++) {
result.push(serialize(tree.children[i]));
}
// Add the closing @@ for the style block
result.push("@@");
return result.join("");
};
})();

View File

@ -276,7 +276,6 @@ describe("WikiAST serialization unit tests", function () {
var serialized = $tw.utils.serializeParseTree(wiki.parseTiddler("ParserModeTest").tree).trimEnd();
expect(serialized).toBe(wiki.getTiddlerText("ParserModeTest").trimEnd());
});
return;
wiki.addTiddler({
title: "PrettyExtLinkTest",
@ -316,12 +315,19 @@ describe("WikiAST serialization unit tests", function () {
wiki.addTiddler({
title: "StyleBlockTest",
text: "@@.myClass\n@@background-color:red;\nThis paragraph will have the CSS class `myClass`.\n\n* The `<ul>` around this list will also have the class `myClass`\n* List item 2\n@@",
text: "@@.myClass\n@@background-color:red;\nThis paragraph will have the CSS class `myClass`.\n\n* The `<ul>` around this list will also have the class `myClass`\n* List item 2\n@@\n\n@@font-size:1.5em;\n@@.coloured-text\n@@.coloured-bg\n* Block content\n* With custom style and classes\n@@",
});
wiki.addTiddler({
title: "StyleBlockTest2",
text: "@@.myFirstClass.mySecondClass\n@@width:100px;.myThirdClass\nThis is a paragraph\n@@\n\n@@background-color:lightcyan;\n* Item one\n* Item two\n@@",
});
it("should serialize style blocks correctly", function () {
var serialized = $tw.utils.serializeParseTree(wiki.parseTiddler("StyleBlockTest").tree).trimEnd();
expect(serialized).toBe(wiki.getTiddlerText("StyleBlockTest").trimEnd());
var serialized = $tw.utils.serializeParseTree(wiki.parseTiddler("StyleBlockTest2").tree).trimEnd();
expect(serialized).toBe(wiki.getTiddlerText("StyleBlockTest2").trimEnd());
});
return;
wiki.addTiddler({
title: "StyleInlineTest",