Javascript-форум (https://javascript.ru/forum/)
-   Angular.js (https://javascript.ru/forum/angular/)
-   -   Как выполнить строку содержащую код (angular 4 + typescript + redux)? (https://javascript.ru/forum/angular/73584-kak-vypolnit-stroku-soderzhashhuyu-kod-angular-4-typescript-redux.html)

okuznetsov1 26.04.2018 16:08

Как выполнить строку содержащую код (angular 4 + typescript + redux)?
 
Имеется строковая переменная template, в которую периодически приходит код такого плана, при этом данная переменная находится в epic-e:

private createTranslateChangedEpic() {
    template = 'concat(
        of(new SummaryActivitySitesActions().setPage('4c3ef357', {page: 1})).delay(100),
        of(new SummaryActivitySitesActions().setPage('6d8540f0', {page: 1})).delay(100)
    )';
return <template>;


В общем нужно каким-то образом трансформировать строку "template" в код который выполниться и будет возвращаться значение из epic-a.

okuznetsov1 27.04.2018 07:33

Пробовал через eval (пока сойдёт, потом нужно будет переделать без eval), но получаю ошибку "ERROR ReferenceError: concat is not defined".

template = 'let e = concat(
        of(new SummaryActivitySitesActions().setPage('4c3ef357', {page: 1})).delay(100),
        of(new SummaryActivitySitesActions().setPage('6d8540f0', {page: 1})).delay(100)
    )';
eval(template);



Кстати of() - оборачивание в observable (import {of} from 'rxjs/observable/of'), скорее всего проблема будет такая же как с concat.

okuznetsov1 27.04.2018 08:08

Сам с собой общаюсь:) Но не теряю надежды, что кто-то сможет помочь.

Предполагаю, что нужно копать в эту сторону:



const result = `"use strict";
                    Object.defineProperty(exports, "__esModule", { value: true });
                    var concat_1 = require("rxjs/observable/concat");
                    var e = concat_1.concat(of(new SummaryActivitySitesActions().setPage('e26fd5f3', { page: 1 })).delay(100), of(new SummaryActivitySitesActions().setPage('5e4f6aaf', { page: 2 })).delay(100));
                    `;
                    eval(result);




Появилась ошибка: ERROR ReferenceError: exports is not defined

okuznetsov1 27.04.2018 15:21

Два варианта решения, кому-то обязательно пригодится.

Вариант 1


import * as ts from 'typescript';
import {of} from 'rxjs/observable/of';
import {concat} from 'rxjs/observable/concat';

private createTranslateChangedEpic() {
                    const g = Groups.getSelectedGroupForSelectedPerspective(storeState);
                    const reportId1 = storeState.groups[0].id;
                    const reportId2 = storeState.groups[1].id;

                    const code = `({
                            Run: (concat: <T>, of: <T>, actions: SummaryActivitySitesActions, reportId1, reportId2) => {
                                console.log('run');
                                return concat(
                                    of(actions.setPage(reportId1, {page: 1})).delay(100),
                                    of(actions.setPage(reportId2, {page: 1})).delay(100)
                                );
                            }
                    })`;
                    const result = ts.transpile(code);
                    const runnalbe = eval(result);

                    return runnalbe.Run(concat, of, this.actions, reportId1, reportId2);
}


Вариант 2


private createTranslateChangedEpic() {
                    const g = Groups.getSelectedGroupForSelectedPerspective(storeState);
                    const reportId1 = storeState.groups[0].id;
                    const reportId2 = storeState.groups[1].id;

                    const f = new Function(
                        'concat',
                        'of',
                        'actions',
                        'reportId1',
                        'reportId2',
                        `return function (concat, of, actions, reportId1, reportId2) {
                                    console.log('run');
                                    return concat(
                                        of(actions.setPage(reportId1, {page: 1})).delay(100),
                                        of(actions.setPage(reportId2, {page: 1})).delay(100)
                                    );
                        }`
                    )(concat, of, this.actions, reportId1, reportId2);

                    return f(concat, of, this.actions, reportId1, reportId2);
}


Часовой пояс GMT +3, время: 04:11.