1 | ;
|
2 |
|
3 | import { Context } from './core/context/context';
|
4 | import { ComponentEngine } from './core/engine/componentEngine';
|
5 | import { RenderingEngine } from './core/engine/engine';
|
6 | export class NailsDirectives {
|
7 | constructor() {
|
8 | this.directives = ['if', 'form', 'for', 'click', 'change'];
|
9 | }
|
10 | /*
|
11 | A directive consists of an element (string) in the @directives array and a function declaration
|
12 | below.
|
13 | directive and function need to have the same name
|
14 | sample body:
|
15 | sample(element, statement, state){
|
16 |
|
17 | }
|
18 | where element is the element where the directive is added and statemenet
|
19 | what has been declaired.
|
20 | sample arguments
|
21 | element = h1 reference
|
22 | statement = var object of objects
|
23 | state = current state
|
24 |
|
25 | For reactivness, only use elements in the data object within the state, as these
|
26 | are actively monitored.
|
27 |
|
28 | DONT PREFIX YOUR DIRECTIVE AND FUNCTIONS WITH AN N
|
29 | */
|
30 |
|
31 |
|
32 | click(element, statement, state) {
|
33 | const componentEngine = new ComponentEngine(state, new RenderingEngine(state), null, []);
|
34 |
|
35 | if (!state.click) {
|
36 | state.click.callbacks = [];
|
37 | }
|
38 |
|
39 | const callback = () => {
|
40 | const instance = componentEngine.getInstanceOfElementOrNull(element);
|
41 |
|
42 | if (instance !== null) {
|
43 | // tslint:disable-next-line: no-eval
|
44 | eval('instance.getComponent().' + statement);
|
45 | return;
|
46 | } // tslint:disable-next-line: no-eval
|
47 |
|
48 |
|
49 | eval('state.methods.' + statement);
|
50 | };
|
51 |
|
52 | element.onclick = callback;
|
53 | }
|
54 |
|
55 | change(element, statement, state) {
|
56 | const callback = () => {
|
57 | // tslint:disable-next-line: no-eval
|
58 | eval('state.methods.' + statement + '(' + element.value + ')');
|
59 | };
|
60 |
|
61 | element.onchange = callback;
|
62 | }
|
63 |
|
64 | form(element, statement, state) {
|
65 | if (element.getAttribute('type') === 'text') {
|
66 | if (state.data[statement] !== element.value) {
|
67 | state.data[statement] = element.value;
|
68 | }
|
69 | }
|
70 |
|
71 | element.addEventListener('input', () => {
|
72 | if (state.data[statement] !== element.value) {
|
73 | state.data[statement] = element.value;
|
74 | }
|
75 | });
|
76 | }
|
77 |
|
78 | for(element, statemenet, state) {
|
79 | console.error('called');
|
80 | const engine = new RenderingEngine(state);
|
81 | const componentEngine = new ComponentEngine(state, engine, null, []);
|
82 | engine.disableInterpolationForVariableNameOnElement(statemenet.split(' ')[1], element);
|
83 | element.style.display = 'none'; // tslint:disable-next-line: no-shadowed-variable
|
84 |
|
85 | function interpolateCustomElement(el, object, // tslint:disable-next-line: no-shadowed-variable
|
86 | descriptor) {
|
87 | // Performancewise, we render the whole html element.
|
88 | let html = el.innerHTML;
|
89 | const interpolations = engine.getInterpolationsForTextContent(html);
|
90 |
|
91 | for (const interpolation of interpolations) {
|
92 | let stripped = engine.stripAndTrimInterpolation(interpolation);
|
93 | const args = stripped.split('.');
|
94 | args[0] = '';
|
95 | stripped = '';
|
96 |
|
97 | for (const arg of args) {
|
98 | stripped += arg + '.';
|
99 | }
|
100 |
|
101 | stripped = stripped.substring(0, stripped.length - 1);
|
102 |
|
103 | if (engine.getValueOfInterpolation(interpolation, element) !== undefined) {
|
104 | html = html.replace(interpolation, engine.getValueOfInterpolation(interpolation, element));
|
105 | } else {
|
106 | // tslint:disable: no-eval
|
107 | html = html.replace(interpolation, engine.sanitize(eval('object' + stripped)));
|
108 | }
|
109 | }
|
110 |
|
111 | el.innerHTML = html;
|
112 | }
|
113 |
|
114 | const descriptor = statemenet.split(' ')[1];
|
115 | const arr = statemenet.split(' ')[3];
|
116 | const instance = componentEngine.getInstanceOfElementOrNull(element);
|
117 | const context = new Context(state, instance);
|
118 | const refArray = context.resolveOrUndefined(arr);
|
119 |
|
120 | if (!refArray) {
|
121 | return;
|
122 | }
|
123 |
|
124 | const parent = element.parentNode;
|
125 |
|
126 | if (parent === null) {
|
127 | return;
|
128 | }
|
129 |
|
130 | for (const i of refArray) {
|
131 | const child = document.createElement(element.nodeName);
|
132 | child.innerHTML = element.innerHTML;
|
133 | interpolateCustomElement(child, i, descriptor);
|
134 | parent.appendChild(child);
|
135 | engine.disableInterpolationForVariableNameOnElement(statemenet.split(' ')[1], child);
|
136 |
|
137 | for (const attr of element.attributes) {
|
138 | if (attr.name !== 'n-for' && attr.name !== 'style') {
|
139 | child.setAttribute(attr.name, attr.value);
|
140 | }
|
141 | }
|
142 |
|
143 | componentEngine.traverseElementAndExecuteDirectives(child); // engine.executeDirectivesOnElement(child, true)
|
144 | }
|
145 | }
|
146 |
|
147 | if(element, statement, state) {
|
148 | if (statement === 'true' || statement === 'false') {
|
149 | if (statement === 'true') {
|
150 | element.style.visibility = 'visible';
|
151 | return;
|
152 | } else {
|
153 | element.style.visibility = 'hidden';
|
154 | return;
|
155 | }
|
156 | }
|
157 |
|
158 | let reversed = false;
|
159 |
|
160 | if (statement[0] === '!') {
|
161 | statement = statement.substring(1);
|
162 | reversed = true;
|
163 | }
|
164 |
|
165 | const componentEngine = new ComponentEngine(state, new RenderingEngine(state), null, null); // tslint:disable-next-line:max-line-length
|
166 |
|
167 | const context = new Context(state, componentEngine.getInstanceOfElementOrNull(element));
|
168 |
|
169 | if (context.resolveOrUndefined(statement)) {
|
170 | if (reversed) {
|
171 | if (!eval(state.data[statement])) {
|
172 | element.style.visibility = 'visible';
|
173 | } else {
|
174 | element.style.visibility = 'hidden';
|
175 | }
|
176 | } else {
|
177 | if (eval(state.data[statement])) {
|
178 | element.style.visibility = 'visible';
|
179 | } else {
|
180 | element.style.visibility = 'hidden';
|
181 | }
|
182 | }
|
183 | } else {
|
184 | element.style.visibility = 'hidden';
|
185 | }
|
186 | }
|
187 |
|
188 | }
|
189 | //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/directiveDefinitions.ts"],"names":["Context","ComponentEngine","RenderingEngine","NailsDirectives","constructor","directives","click","element","statement","state","componentEngine","callbacks","callback","instance","getInstanceOfElementOrNull","eval","onclick","change","value","onchange","form","getAttribute","data","addEventListener","for","statemenet","console","error","engine","disableInterpolationForVariableNameOnElement","split","style","display","interpolateCustomElement","el","object","descriptor","html","innerHTML","interpolations","getInterpolationsForTextContent","interpolation","stripped","stripAndTrimInterpolation","args","arg","substring","length","getValueOfInterpolation","undefined","replace","sanitize","arr","context","refArray","resolveOrUndefined","parent","parentNode","i","child","document","createElement","nodeName","appendChild","attr","attributes","name","setAttribute","traverseElementAndExecuteDirectives","if","visibility","reversed"],"mappings":"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","sourcesContent":["'use strict';\nimport { Instance } from './classes/Instance';\nimport { Context } from './core/context/context';\nimport { ComponentEngine } from './core/engine/componentEngine';\nimport { RenderingEngine } from './core/engine/engine';\nimport { State } from './core/state';\nexport class NailsDirectives {\n  public directives: any;\n  constructor() {\n    this.directives = ['if', 'form', 'for', 'click', 'change'];\n  }\n  /*\n          A directive consists of an element (string) in the @directives array and a function declaration\n          below.\n          directive and function need to have the same name\n          sample body:\n          sample(element, statement, state){\n  \n          }\n          where element is the element where the directive is added and statemenet\n          what has been declaired.\n          sample arguments\n          element = h1 reference\n          statement = var object of objects\n          state = current state\n  \n          For reactivness, only use elements in the data object within the state, as these\n          are actively monitored.\n  \n          DONT PREFIX YOUR DIRECTIVE AND FUNCTIONS WITH AN N\n      */\n\n  public click(element: HTMLElement, statement: string, state: State) {\n    const componentEngine = new ComponentEngine(state, new RenderingEngine(state), null, []);\n\n    if (!state.click) {\n      state.click.callbacks = [];\n    }\n    const callback = () => {\n      const instance = componentEngine.getInstanceOfElementOrNull(element) as Instance;\n\n      if (instance !== null) {\n        // tslint:disable-next-line: no-eval\n        eval('instance.getComponent().' + statement);\n        return;\n      }\n      // tslint:disable-next-line: no-eval\n      eval('state.methods.' + statement);\n    };\n    element.onclick = callback;\n  }\n  public change(element: HTMLInputElement, statement: string, state: State) {\n    const callback = () => {\n      // tslint:disable-next-line: no-eval\n      eval('state.methods.' + statement + '(' + element.value + ')');\n    };\n    element.onchange = callback;\n  }\n  public form(element: HTMLInputElement, statement: string, state: State) {\n    if (element.getAttribute('type') === 'text') {\n      if (state.data[statement] !== element.value) {\n        state.data[statement] = element.value;\n      }\n    }\n    element.addEventListener('input', () => {\n      if (state.data[statement] !== element.value) {\n        state.data[statement] = element.value;\n      }\n    });\n  }\n\n  public for(element: HTMLElement, statemenet: string, state: State) {\n    console.error('called');\n    const engine = new RenderingEngine(state);\n    const componentEngine = new ComponentEngine(state, engine, null, []);\n    engine.disableInterpolationForVariableNameOnElement(statemenet.split(' ')[1], element);\n\n    element.style.display = 'none';\n    // tslint:disable-next-line: no-shadowed-variable\n    function interpolateCustomElement(\n      el: HTMLElement,\n      object: any,\n      // tslint:disable-next-line: no-shadowed-variable\n      descriptor: any,\n    ) {\n      // Performancewise, we render the whole html element.\n      let html = el.innerHTML;\n      const interpolations = engine.getInterpolationsForTextContent(html);\n      for (const interpolation of interpolations) {\n        let stripped = engine.stripAndTrimInterpolation(interpolation);\n        const args = stripped.split('.');\n        args[0] = '';\n        stripped = '';\n        for (const arg of args) {\n          stripped += arg + '.';\n        }\n        stripped = stripped.substring(0, stripped.length - 1);\n\n        if (engine.getValueOfInterpolation(interpolation, element) !== undefined) {\n          html = html.replace(interpolation, engine.getValueOfInterpolation(interpolation, element));\n        } else {\n          // tslint:disable: no-eval\n          html = html.replace(interpolation, engine.sanitize(eval('object' + stripped)));\n        }\n      }\n      el.innerHTML = html;\n    }\n    const descriptor = statemenet.split(' ')[1];\n    const arr = statemenet.split(' ')[3];\n    const instance = componentEngine.getInstanceOfElementOrNull(element) as Instance;\n    const context = new Context(state, instance);\n\n    const refArray = context.resolveOrUndefined(arr);\n\n    if (!refArray) {\n      return;\n    }\n\n    const parent = element.parentNode;\n    if (parent === null) {\n      return;\n    }\n    for (const i of refArray) {\n      const child = document.createElement(element.nodeName);\n      child.innerHTML = element.innerHTML;\n      interpolateCustomElement(child, i, descriptor);\n      parent.appendChild(child);\n      engine.disableInterpolationForVariableNameOnElement(statemenet.split(' ')[1], child);\n\n      for (const attr of element.attributes) {\n        if (attr.name !== 'n-for' && attr.name !== 'style') {\n          child.setAttribute(attr.name, attr.value);\n        }\n      }\n      componentEngine.traverseElementAndExecuteDirectives(child);\n      // engine.executeDirectivesOnElement(child, true)\n    }\n  }\n  public if(element: HTMLElement, statement: string, state: State) {\n    if (statement === 'true' || statement === 'false') {\n      if (statement === 'true') {\n        element.style.visibility = 'visible';\n\n        return;\n      } else {\n        element.style.visibility = 'hidden';\n\n        return;\n      }\n    }\n\n    let reversed = false;\n    if (statement[0] === '!') {\n      statement = statement.substring(1);\n      reversed = true;\n    }\n    const componentEngine = new ComponentEngine(state, new RenderingEngine(state), null, null);\n\n    // tslint:disable-next-line:max-line-length\n    const context = new Context(state, componentEngine.getInstanceOfElementOrNull(element));\n    if (context.resolveOrUndefined(statement)) {\n      if (reversed) {\n        if (!eval(state.data[statement])) {\n          element.style.visibility = 'visible';\n        } else {\n          element.style.visibility = 'hidden';\n        }\n      } else {\n        if (eval(state.data[statement])) {\n          element.style.visibility = 'visible';\n        } else {\n          element.style.visibility = 'hidden';\n        }\n      }\n    } else {\n      element.style.visibility = 'hidden';\n    }\n  }\n}\n"]} |
\ | No newline at end of file |