/**
 * Extend this class when the new class needs to generate an xml file
 * @private
 */
Ext.define('Ext.exporter.file.ooxml.Xml', {
    extend: 'Ext.exporter.file.ooxml.Base',
 
    requires: [
        'Ext.exporter.file.ooxml.Relationship',
        'Ext.exporter.file.ooxml.ContentType'
    ],
 
    config: {
        /**
         * @cfg {String} folder
         *
         * Full path to the folder where the file exists inside the zip archive
         */
        folder: null,
 
        /**
         * @cfg {String} fileName
         *
         * Name of the xml file without extension. Use `fileNameTemplate` to define the extension.
         */
        fileName: null,
 
        /**
         * @cfg {String} 
         * @readonly
         *
         * Full path of the file inside the zip package. It combines the `folder` and
         * the `fileName`.
         */
        path: null,
 
        /**
         * @cfg {Ext.exporter.file.ooxml.Relationship} relationship
         *
         * If the file needs to be part of a '.rels' file then this entity needs to be defined
         */
        relationship: null,
 
        /**
         * @cfg {Ext.exporter.file.ooxml.ContentType} contentType
         *
         * If the file needs to be part of the '[Content_Types].xml' file then this entity needs
         * to be defined
         */
        contentType: null
    },
 
    cachedConfig: {
        /**
         * @cfg {String} fileNameTemplate
         *
         * A template to generate the file name. You can use any config defined on the class.
         */
        fileNameTemplate: '{fileName}.xml'
    },
 
    tplNonAttributes: [
        'path', 'relationship', 'contentType', 'fileName', 'folder', 'fileNameTemplate'
    ],
 
    destroy: function() {
        this.setRelationship(null);
        this.setContentType(null);
        this.callParent();
    },
 
    applyFolder: function(folder) {
        folder = folder || '';
 
        if (folder[folder.length - 1] !== '/') {
            folder += '/';
        }
 
        return folder;
    },
 
    updateFolder: function() {
        this.generatePath();
    },
 
    updateFileName: function() {
        this.generatePath();
    },
 
    getFileNameFromTemplate: function() {
        var tpl = Ext.XTemplate.getTpl(this, '_fileNameTemplate');
 
        return (tpl ? tpl.apply(this.getConfig()) : '');
    },
 
    generatePath: function() {
        this.setPath((this.getFolder() || '') + this.getFileNameFromTemplate());
    },
 
    updatePath: function(path) {
        var relationship = this.getRelationship(),
            type = this.getContentType();
 
        if (relationship) {
            relationship.setTarget(path);
        }
 
        if (type) {
            type.setPartName(path);
        }
    },
 
    applyRelationship: function(data) {
        if (!data || data.isRelationship) {
            return data;
        }
 
        return new Ext.exporter.file.ooxml.Relationship(data);
    },
 
    updateRelationship: function(data, oldData) {
        Ext.destroy(oldData);
    },
 
    applyContentType: function(data) {
        if (!data || data.isContentType) {
            return data;
        }
 
        return new Ext.exporter.file.ooxml.ContentType(data);
    },
 
    updateContentType: function(data, oldData) {
        Ext.destroy(oldData);
    },
 
    /**
     * Collect all files that are part of the final zip file
     * @param {Object} files Object key is the path to the file and object value is the content
     * @param {Ext.exporter.file.ooxml.ContentType[]} types 
     */
    collectFiles: Ext.emptyFn
});