/* <copyright>
This file contains proprietary software owned by Motorola Mobility, Inc.<br/>
No rights, expressed or implied, whatsoever to this software are provided by Motorola Mobility, Inc. hereunder.<br/>
(c) Copyright 2011 Motorola Mobility, Inc.  All Rights Reserved.
</copyright> */

var Montage = require("montage/core/core").Montage,
    Component = require("montage/ui/component").Component,
    HotText = require("js/components/hottext.reel").HotText,
    HotTextUnit = require("js/components/hottextunit.reel").HotTextUnit,
    Slider = require("js/components/slider.reel").Slider,
    Button = require("montage/ui/button.reel").Button,
    Checkbox = require("js/components/ui/label-checkbox.reel").LabelCheckbox,
    Combobox = require("js/components/combobox.reel").Combobox,
    TextField = require("js/components/TextField.reel").TextField,
    ColorChip = require("js/components/ui/color-chip.reel").ColorChip,
    FileInput = require("js/components/ui/file-input.reel").FileInput,
    InputGroup = require("js/components/ui/input-group.reel").InputGroup;

var PropertyControl = exports.PropertyControl = Montage.create(Component, {

    _labelField: {
        enumerable: true,
        serializable: true,
        value: null
    },

    labelField: {
        enumerable: true,
        serializable: true,
        get: function () {
            return this._labelField;
        },
        set: function (value) {
            if (value !== this._labelField) {
                this._labelField = value;
                this.needsDraw = true;
            }
        }
    },

    _control: {
        enumerable: true,
        value: null
    },

    // set this to the getter of each control type's "value" accessor,
    // which could be value, selected, color, checked, etc.
    _prop: {
        enumerable: true,
        value: ""
    },

    _controlField: {
        enumerable: true,
        value: null
    },

    controlField: {
        enumerable: true,
        serializable: true,
        get: function () {
            return this._controlField;
        },
        set: function (value) {
            if (value !== this._controlField) {
                this._controlField = value;
            }
        }
    },

    _label: {
        enumerable: false,
        value: "Label:"
    },

    label: {
        enumerable: true,
        serializable: true,
        get: function () {
            return this._label;
        },
        set: function (value) {
            if (value !== this._label) {
                this._label = value + ":";
                this.needsDraw = true;
            }
        }
    },

    _controlType: {
        enumerable: false,
        value: null
    },

    controlType: {
        enumerable: true,
        serializable: true,
        get: function () {
            return this._controlType;
        },
        set: function (value) {
            if (value !== this._controlType) {
                this._controlType = value;
            }
        }
    },

    _data: {
        enumerable: false,
        value: null
    },

    data: {
        enumerable: true,
        serializable: true,
        get: function () {
            return this._data;
        },
        set: function (data) {
            if (data !== this._data) {
                this._data = data;
                if(data) {
                    this._label = data.label;
                    this._controlType = data.controlType;
                } else {
                    this._label = "";
                    this._controlType = null;
                }
                this.needsDraw = true;
            }
        }
    },

    didDraw :{
        value: function() {
            var defaults = this._data.defaults;
            for(var n in defaults)
            {
                this._control[n] = defaults[n];
            }
            this._labelField.innerHTML = this._label;
            this._control.needsDraw = true;
        }
    },

    handleEvent:
	{
		value:function(event)
		{
            if(event.wasSetByCode) {
                return;
            }
            this._dispatchPropEvent(event);
		}
	},

    _dispatchPropEvent: {
        value: function(event) {
            var propEvent = document.createEvent("CustomEvent");
            if(event.type === "changing")
            {
                propEvent.initEvent("propertyChanging", true, true);
                propEvent.type = "propertyChanging";
            }
            else
            {
                propEvent.initEvent("propertyChange", true, true);
                propEvent.type = "propertyChange";
            }
            propEvent.propertyLabel = this.label;
            propEvent.propertyValue = event.currentTarget[this._prop];
            propEvent.propertyEvent = event;
            
            this.dispatchEvent(propEvent);
        }
    },

    prepareForDraw: {
        value: function() {
            switch(this._controlType)
            {
                case "HotText":
                    this._control = HotText.create();
                    this._control.addEventListener("change", this, false);
                    this._control.addEventListener("changing", this, false);
                    this._prop = "value";
                    break;
                case "HotTextUnit":
                    this._control = HotTextUnit.create();
                    this._control.addEventListener("change", this, false);
                    this._control.addEventListener("changing", this, false);
                    this._prop = "value";
                    break;
                case "Slider":
                    this._control = Slider.create();
                    this._control.addEventListener("change", this, false);
                    this._control.addEventListener("changing", this, false);
                    this._prop = "value";
                    break;
                case "Button":
                    this._control = Button.create();
                    this._control.addEventListener("action", this, false);
                    this._prop = "value";
                    break;
                case "ColorChip":
                    this._control = ColorChip.create();
                    this._control.chip = true;
                    this._control.hasIcon = false;
                    this._control.mode = "chip";
                    this._control.addEventListener("change", this, false);
                    this._prop = "color";
                    break;
                case "TextField":
                    this._control = TextField.create();
                    this._control.addEventListener("change", this, false);
                    this._prop = "text";
                    break;
                case "Checkbox":
                    this._control = Checkbox.create();
                    this._control.addEventListener("change", this, false);
                    this._prop = "checked";
                    break;
                case "Combobox":
                    this._control = Combobox.create();
                    this._control.addEventListener("change", this, false);
                    this._prop = "value";
                    break;
                case "FileInput":
                    this._control = FileInput.create();
                    this._control.addEventListener("change", this, false);
                    this._prop = "filePath";
                    break;
                case "InputGroup":
                    this._control = InputGroup.create();
                    this._control.addEventListener("change", this, false);
                    this._control.addEventListener("changing", this, false);
                    this._prop = "value";
                    break;
                default:
                    break;
            }
            this._control.element = this._controlField;
        }
    }

});