Как создать пользовательский компонент / плагин на адаптированной платформе? - PullRequest
1 голос
/ 07 июля 2019

Я успешно установил адаптированный фреймворк. Был в состоянии редактировать новый курс. Но мне нужно создать новый пользовательский компонент, очень похожий на textinput. в src / components я попытался скопировать adapt-contrib-textInput, изменив его имя на свое собственное имя в bower.json и в функции Adapt.register. Однако, когда я пытаюсь использовать новые компоненты в компоненте курса (в src / course / en / components.js), это выдает мне эту ошибку:

adaptView.js:48 Uncaught TypeError: template is not a function
    at n.render (adaptView.js:48)
    at n.initialize (adaptView.js:31)
    at n.e.View (backbone.min.js:2)
    at n [as constructor] (backbone.min.js:2)
    at n [as constructor] (backbone.min.js:2)
    at n [as constructor] (backbone.min.js:2)
    at n [as constructor] (backbone.min.js:2)
    at new n (backbone.min.js:2)
    at n.addChildren (adaptView.js:103)
    at n.postRender (adaptView.js:38) 

Это мой bower.json:


    {
      "name": "adapt-html-testing",
      "version": "3.0.1",
      "framework": ">=2.0.16",
      "homepage": "https://github.com/adaptlearning/adapt-contrib-textInput",
      "issues": "https://github.com/adaptlearning/adapt_framework/issues/new",
      "description": "A question component that allows the learner to input text based upon a question stem.",
      "main": "/js/adapt-contrib-textInput.js",
      "displayName" : "Html Testing",
      "component" : "htmltesting",
      "keywords": [
        "adapt-plugin",
        "adapt-component"
      ],
      "license": "GPLv3"
    }

Это мой основной js, adapt-contrib-textInput.js:


       define([
        'core/js/adapt',
        './textInputView',
        './textInputModel',
    ], function(Adapt, TextInputView, TextInputModel) {

        console.log("register htmltesting: before");
        return Adapt.register('htmltesting', {
            view: TextInputView,
            model: TextInputModel
        });

       });

и это компонент component.js (который я оставил как есть, просто изменил поле compnent на htmltesting. Это было 'textinput':

 {
        "_id": "c-70",
        "_parentId": "b-50",
        "_type": "component",
        "_component": "htmltesting",
        "_classes": "",
        "_layout": "left",
        "_attempts": 1,
        "_questionWeight": 1,
        "_canShowModelAnswer": true,
        "_shouldDisplayAttempts": false,
        "_isRandom": true,
        "_allowsAnyCase": true,
        "_allowsPunctuation": true,
        "title": "Text Input",
        "displayTitle": "Myyy Text Input",
        "body": "Can you name one of the three companies that established Adapt as a community led Open Source project?",
        "instruction": "Input your answer and select Submit.",
        "_answers": [
            ["City & Guilds Kineo", "Kineo"],
            ["Learning Pool"],
            ["Sponge"]
        ],
        "_items": [
            {
                "prefix": "",
                "placeholder": "Enter answer here",
                "suffix": ""
            }
        ],
        "_feedback": {
            "title": "Feedback",
            "correct": "Correct answer feedback.<br><br>That’s correct. The Adapt Open Source project was established by Kineo, Learning Pool and Sponge. At the time of writing, there are a total of nine <a href='https://www.adaptlearning.org/index.php/collaborators/' target='_blank'>official collaborators</a>.<br><br><em>Component facts: <strong>Text input</strong> components let learners enter their own answers, which is great for questions that require a bit more flexibility, like those with answers that could be written as both full words and numbers.</em>",
            "_partlyCorrect": {
                "final": "Incorrect answer feedback.<br><br>Sorry, that’s not right. The Adapt Open Source project was established by Kineo, Learning Pool and Sponge. At the time of writing, there are a total of nine <a href='https://www.adaptlearning.org/index.php/collaborators/' target='_blank'>official collaborators</a>.<br><br><em>Component facts: <strong>Text input</strong> components let learners enter their own answers, which is great for questions that require a bit more flexibility, like those with answers that could be written as both full words and numbers.</em>"
            },
            "_incorrect": {
                "final": "Incorrect answer feedback.<br><br>Sorry, that’s not right. The Adapt Open Source project was established by Kineo, Learning Pool and Sponge. At the time of writing, there are a total of nine <a href='https://www.adaptlearning.org/index.php/collaborators/' target='_blank'>official collaborators</a>.<br><br><em>Component facts: <strong>Text input</strong> components let learners enter their own answers, which is great for questions that require a bit more flexibility, like those with answers that could be written as both full words and numbers.</em>"
            }
        },
        "_pageLevelProgress": {
            "_isEnabled": true,
            "_isCompletionIndicatorEnabled": true
        }
    },

В заключение мне нужна помощь в понимании того, как создать пользовательский компонент. Кажется, адаптированная документация https://github.com/adaptlearning/adapt_framework/wiki/Developing-plugins забыла упомянуть о каком-то важном шаге.

Я чувствую, что делаю все правильно, и это должно работать, но все равно я получаю эту ошибку:

adaptView.js:48 Uncaught TypeError: template is not a function
    at n.render (adaptView.js:48)
    at n.initialize (adaptView.js:31)
    at n.e.View (backbone.min.js:2)
    at n [as constructor] (backbone.min.js:2)
    at n [as constructor] (backbone.min.js:2)
    at n [as constructor] (backbone.min.js:2)
    at n [as constructor] (backbone.min.js:2)
    at new n (backbone.min.js:2)
    at n.addChildren (adaptView.js:103)
    at n.postRender (adaptView.js:38)

1 Ответ

0 голосов
/ 10 июля 2019

Я решил эту проблему, изменив имена файлов .hbs и .less на мое зарегистрированное имя компонента, htmltesting. Наименование имеет значение, хотя я не смог найти упоминания об этом в документации. Надеюсь, это кому-нибудь поможет.

...