diff --git a/index.html b/index.html index 61f6d76..6b52339 100644 --- a/index.html +++ b/index.html @@ -32,7 +32,7 @@

Just a demo!

` }); - console.log(myTemplate); + console.log('Template created: ', myTemplate); myTemplate.mountTo(document.getElementById('app')); diff --git a/src/module/template.ts b/src/module/template.ts index e35aa13..f00679f 100644 --- a/src/module/template.ts +++ b/src/module/template.ts @@ -54,13 +54,11 @@ export default class Template { let val = this.template.state[property]; Object.defineProperty.call(that, this._template.state, property, { get() { - // console.log('Calling getter for ' + property, that); return val; }, set(value: any) { - // console.log('Calling setter for ' + property); val = value; - that.update(); + that.update(); // TODO check diff if update is necessary. } }); }); diff --git a/src/parser/eval/evalDoEvent.ts b/src/parser/eval/evalDoEvent.ts index 4451595..442e77a 100644 --- a/src/parser/eval/evalDoEvent.ts +++ b/src/parser/eval/evalDoEvent.ts @@ -3,9 +3,9 @@ import { ITemplate } from '../../module/template'; /** - * TODO - * @param statement TODO - * @param context TODO + * Evaluate `event`-nodes. + * @param statement The statement that needs to be evaluated. + * @param context The context in which it gets used. */ const evalDoEvent = (statement: string, context: ITemplate) => { const eventType = statement.split(':')[0]; diff --git a/src/parser/eval/evalForNode.ts b/src/parser/eval/evalForNode.ts index 302d00e..f6f8f73 100644 --- a/src/parser/eval/evalForNode.ts +++ b/src/parser/eval/evalForNode.ts @@ -9,16 +9,12 @@ import { ITemplate } from '../../module/template'; */ const evalForNode = (forNode: HTMLSpanElement, condition: string, context: ITemplate): string => { const multipliedChildren: string[] = []; - - // TODO: Variable context. - Function( 'multipliedChildren', // The multiplied content of the for-node. 'innerHTML', // The content of the for-node. 'replaceLoopVarsInHTML', // Evaluate the inner appearances of the loop variable. `let loopVar; if(/^var |^let /.test('${condition}')){ - console.log('${condition}'.slice('${condition}'.indexOf(' '), '${condition}'.indexOf('=')).trim()); loopVar = '${condition}'.slice( '${condition}'.indexOf(' '), '${condition}'.indexOf('=') @@ -37,20 +33,22 @@ const evalForNode = (forNode: HTMLSpanElement, condition: string, context: ITemp }; /** - * TODO - * @param loopVar TODO - * @param innerHTML TODO + * Find loop variables in HTML (e.g. $i, $xyz) and replace them with their actual value. + * @param loopVar The name of the variable. + * @param varValue The actual value of the variable. + * @param innerHTML The HTML that needs to be replaced. */ const replaceLoopVarsInHTML = (loopVar: string, varValue: number, innerHTML: string) => { - // TODO only replace the variables between mustaches {{ $i }} - /* const findVarRegex = /{{.*?(\$i).*?}}/g; - while (findVarRegex.test(innerHTML)) { - innerHTML.replace(findVarRegex, loopVar); - } */ + // Naive solution, just replace: while (innerHTML.indexOf('$' + loopVar) >= 0) { innerHTML = innerHTML.replace('$' + loopVar, String(varValue)); } + // Fix this solution please: + /* const findVarRegex = /.*?(\$i).*?<\/do>/; + while (findVarRegex.test(innerHTML)) { + innerHTML = innerHTML.replace(findVarRegex, String(varValue)); + } */ return innerHTML; }; diff --git a/src/parser/eval/evalJSNode.ts b/src/parser/eval/evalJSNode.ts index c795fb6..3b54d73 100644 --- a/src/parser/eval/evalJSNode.ts +++ b/src/parser/eval/evalJSNode.ts @@ -2,7 +2,11 @@ import { ITemplate } from '../../module/template'; -// TODO impl. +/** + * Evaluate sandboxed `js`-expression nodes. + * @param statement The statement that gets evaluated. + * @param context The context in which it should be evaluated. + */ const evalJSNode = (statement: string, context: ITemplate): string => { // Evaluate state variable. if (context.state.hasOwnProperty(statement)) {