twitter-flight

Can twitter flightjs do component within component


In Facebook react.js, you can compose component within component, or maybe mix and match.

I'm wondering if twitter flight can do the same thing. if so, can anyone gives me an example?

this is what I have so far:

define(function (require) {

var defineComponent = require('flight/lib/component'),
    infoInput = require('component/info_input');

return defineComponent(inputSection, infoInput);

function inputSection () {

    this.after('initialize', function() {

        infoInput.doSomehting();

    });

};

});

and my info_input.js is defined below:

define(function (require) {

var defineComponent = require('flight/lib/component');
return defineComponent(infoInput);
function infoInput() {

    this.after('initialize', function() {


    });

    this.doSomething = function() {
        alert('I will do something');
    };

};

});

Solution

  • This is what mixins are for. Flight Components are enriched mixins.

    From doc/component_api.md

    It comes with a set of basic functionality such as event handling and Component registration. Each Component definition mixes in a set of custom properties which describe its behavior.

    Read more about Components.

    So the answer to your question is Yes. I guess that what you are doing is legit, although I've never done it before.

    I'd rather move the shared logic to a Mixin or attach the two components to the same element and let them talk via events:

    component/input_section.js

    this.after('initialize', function () {
       this.trigger('uiSomethingRequired');
    });
    

    component/info_input.js

    this.after('initialize', function () {
       this.on('uiSomethingRequired', this.doSomething);
    });