4 'libs/text!./templates/main.html',
5 'libs/text!./templates/item.html',
6 'views/openSelect/openSelect'
7 ], function($, _, mainTemplate, itemTemplate, OpenSelectView) {
11 return function(sandbox) {
15 metadataConfig = (sandbox.getConfig().metadata || []).sort(function(configRow1, configRow2) {
16 if(configRow1.key < configRow2.key) {
19 if(configRow1.key > configRow2.key) {
25 var getValuesForKey = function(key) {
27 metadataConfig.some(function(configRow) {
28 if(configRow.key === key) {
29 toret = configRow.values || [];
37 node: $(_.template(mainTemplate)()),
40 var metaTable = this.metaTable = this.node.find('table');
42 this.node.find('.rng-module-metadataEditor-addBtn').click(function() {
44 currentNode.getMetadata().add('','');
47 this.metaTable.on('click', '.rng-visualEditor-metaRemoveBtn', function(e) {
48 $(e.target).closest('tr').data('row').remove();
51 this.metaTable.on('keydown', '[contenteditable]', function(e) {
52 /* globals document */
54 if($(document.activeElement).hasClass('rng-module-metadataEditor-metaItemKey')) {
55 metaTable.find('.rng-module-metadataEditor-metaItemValue').focus();
57 var input = $('<input>');
58 input.appendTo('body').focus();
59 view.node.find('.rng-module-metadataEditor-addBtn').focus();
66 this.metaTable.on('keyup', '[contenteditable]', _.throttle(function(e) {
68 var editable = $(e.target),
69 toSet = editable.text(),
70 row = editable.parents('tr').data('row'),
71 isKey = _.last(editable.attr('class').split('-')) === 'metaItemKey',
72 method = isKey ? 'setKey' : 'setValue';
79 setMetadata: function(node) {
80 this.node.find('.rng-module-metadataEditor-addBtn').attr('disabled', !node);
82 this.metaTable.html('');
86 metadata = node.getMetadata();
87 this.metaTable.find('tr').remove();
88 metadata.forEach(function(row) {
89 view.addMetadataRow(row);
92 addMetadataRow: function(row) {
93 var newRow = $(_.template(itemTemplate)({key: row.getKey() || '', value: row.getValue() || ''}));
94 newRow.appendTo(this.metaTable);
95 newRow.data('row', row);
97 var keySelectView = new OpenSelectView({
98 value: row.getKey() || '',
99 inputTemplate: _.template('<div class="openInput rng-module-metadataEditor-metaItemKey" contentEditable="true"><%= value %></div>')({value: row.getKey() || '' }),
100 setInput: function(inputDOM, value) {
101 if(inputDOM.text() !== value) {
102 inputDOM.text(value);
105 valueSelectView.clearItems();
106 getValuesForKey(value).forEach(function(value) {
107 valueSelectView.addItem(value);
111 newRow.find('td:first').append(keySelectView.el).data('view', keySelectView);
114 var valueSelectView = new OpenSelectView({
115 value: row.getValue(),
116 inputTemplate: _.template('<div class="openInput rng-module-metadataEditor-metaItemValue" contentEditable="true"><%= value %></div>')({value: row.getValue() || '' }),
119 setInput: function(inputDOM, value) {
120 if(inputDOM.text() !== value) {
121 inputDOM.text(value);
126 newRow.find('td:nth-child(2)').append(valueSelectView.el).data('view', valueSelectView);
129 metadataConfig.forEach(function(configRow) {
130 keySelectView.addItem(configRow.key);
131 if(row.getKey() === configRow.key) {
132 (configRow.values || []).forEach(function(value) {
133 valueSelectView.addItem(value);
139 $(newRow.find('td div')[0]).focus();
144 updateMetadataRow: function(row) {
145 this._getRowTr(row, function(tr) {
146 var tds = tr.find('td'),
150 keyTd.data('view').setInput(row.getKey());
151 valueTd.data('view').setInput(row.getValue());
154 removeMetadataRow: function(row) {
155 this._getRowTr(row, function(tr) {
159 _getRowTr: function(row, callback) {
160 this.metaTable.find('tr').each(function() {
162 if(tr.data('row') === row) {
174 sandbox.publish('ready');
176 setDocument: function(document) {
177 document.on('change', function(event) {
178 if(event.type === 'metadataAdded' && event.meta.node.sameNode(currentNode)) {
179 view.addMetadataRow(event.meta.row);
181 if(event.type === 'metadataChanged' && event.meta.node.sameNode(currentNode)) {
182 view.updateMetadataRow(event.meta.row);
184 if(event.type === 'metadataRemoved' && event.meta.node.sameNode(currentNode)) {
185 view.removeMetadataRow(event.meta.row);
187 if(event.type === 'nodeDetached' && event.meta.node.sameNode(currentNode)) {
188 view.setMetadata(null);
192 setNodeElement: function(node) {
193 if(currentNode && currentNode.sameNode(node)) {
197 view.setMetadata(node);
199 getView: function() {