3 'modules/documentCanvas/canvas/widgets'
 
   4 ], function($, widgets) {
 
   9 var DocumentElementWrapper = function(documentElement) {
 
  11     this.documentElement = documentElement;
 
  13     this.addWidget = function(widget) {
 
  14         documentElement.dom().children('.canvas-widgets').append(widget.DOM ? widget.DOM : widget);
 
  17     this.clearWidgets = function() {
 
  18         documentElement.dom().children('.canvas-widgets').empty();
 
  21     this.setDisplayStyle = function(displayStyle) {
 
  22         documentElement.dom().css('display', displayStyle || '');
 
  23         documentElement._container().css('display', displayStyle || '');
 
  26     this.tag = function() {
 
  27         return documentElement.getWlxmlTag();
 
  30     this.klass = function() {
 
  31         return documentElement.getWlxmlClass();
 
  34     this.toggle = function(toggle) {
 
  35         documentElement._container().toggle(toggle);
 
  38     var eventBus = documentElement.canvas ? documentElement.canvas.eventBus :
 
  39         {trigger: function() {}};
 
  40     this.trigger = function() {
 
  41         eventBus.trigger.apply(eventBus, arguments);
 
  44     this.node = documentElement.data('wlxmlNode');
 
  48 var getDisplayStyle = function(tag, klass) {
 
  49     if(tag === 'metadata') {
 
  55     if(klass && klass.substr(0, 4) === 'item') {
 
  61 var GenericManager = function(wlxmlElement) {
 
  62     this.el = wlxmlElement;
 
  65 $.extend(GenericManager.prototype, {
 
  67         this.el.setDisplayStyle(getDisplayStyle(this.el.tag(), this.el.klass()));
 
  69         this.el.clearWidgets();
 
  70         this.el.addWidget(widgets.labelWidget(this.el.tag(), this.el.klass()));
 
  73     toggle: function(toggle) {
 
  74         this.el.toggle(toggle);
 
  81     set: function(tag, klass, manager) {
 
  85         this._m[tag][klass] = manager;
 
  87     get: function(tag,klass) {
 
  88         if(this._m[tag] && this._m[tag][klass]) {
 
  89             return this._m[tag][klass];
 
  91         return GenericManager;
 
  95 var FootnoteManager = function(wlxmlElement) {
 
  96     this.el = wlxmlElement;
 
  98 $.extend(FootnoteManager.prototype, {
 
 100         this.el.clearWidgets();
 
 102         var clickHandler = function() {
 
 105         this.footnoteHandler = widgets.footnoteHandler(clickHandler);
 
 106         this.el.addWidget(this.footnoteHandler);
 
 108         var closeHandler = function() {
 
 112         this.hideButton = widgets.hideButton(closeHandler);
 
 113         this.el.addWidget(this.hideButton);
 
 115         this.toggle(false, {silent: true});
 
 117     toggle: function(toggle, options) {
 
 118         options = options || {};
 
 119         this.hideButton.toggle(toggle);
 
 120         this.footnoteHandler.toggle(!toggle);
 
 122         this.el.setDisplayStyle(toggle ? 'block' : 'inline');
 
 123         this.el.toggle(toggle);
 
 124         if(!options.silent) {
 
 125             this.el.trigger('elementToggled', toggle, this.el.documentElement);
 
 129 managers.set('aside', 'footnote', FootnoteManager);
 
 132 var ListItemManager = function(wlxmlElement) {
 
 133     this.el = wlxmlElement;
 
 135 $.extend(ListItemManager.prototype, {
 
 137         this.el.clearWidgets();
 
 138         this.el.addWidget(widgets.labelWidget(this.el.tag(), this.el.klass()));
 
 139         this.el.documentElement._container().css({display: 'list-item'});
 
 141     toggleBullet: function(toggle) {
 
 142         this.el.documentElement._container().css({display : toggle ? 'list-item' : 'block'});
 
 145 managers.set('div', 'item', ListItemManager);
 
 148 var CommentManager = function(wlxmlElement) {
 
 149     this.el = wlxmlElement;
 
 152 $.extend(CommentManager.prototype, {
 
 154         this.el.clearWidgets();
 
 155         this.el.addWidget(widgets.labelWidget(this.el.tag(), this.el.klass()));
 
 157         this.widget = widgets.commentAdnotation(this.el.node);
 
 158         this.el.addWidget(this.widget);
 
 159         this.widget.DOM.show();
 
 161     updateMetadata: function() {
 
 163         // this.el.node.getMetadata().forEach(function(row) {
 
 164         //     parts.push(row.getValue());
 
 166         // this.widget.text(parts.join(', '));
 
 167         this.widget.update(this.el.node);
 
 170 managers.set('aside', 'comment', CommentManager);
 
 173     getFor: function(documentElement) {
 
 174         var wlxmlElement = new DocumentElementWrapper(documentElement);
 
 175         return new (managers.get(wlxmlElement.tag(), wlxmlElement.klass()))(wlxmlElement);