/* global Whisper, textsecure, ConversationController, Signal */

// eslint-disable-next-line func-names
(function() {
  'use strict';

  window.Whisper = window.Whisper || {};

  Whisper.MainHeaderView = Whisper.View.extend({
    templateName: 'main-header-placeholder',
    events: {
      'click .main-header-title-wrapper': 'onClick',
      'click .edit-name': 'onEditProfile',
      'click .copy-key': 'onCopyKey',
    },
    initialize(options) {
      this.ourNumber = textsecure.storage.user.getNumber();
      const me = ConversationController.getOrCreate(this.ourNumber, 'private');

      this.mainHeaderView = new Whisper.ReactWrapperView({
        className: 'main-header-wrapper',
        Component: Signal.Components.MainHeader,
        props: me.format(),
      });
      const update = () => this.mainHeaderView.update(me.format());
      this.listenTo(me, 'change', update);

      this.render();
      this.$('.main-header-title-wrapper').prepend(this.mainHeaderView.el);

      this.$toggle = this.$('.main-header-content-toggle');
      this.$content = this.$('.main-header-content-wrapper');
      this.$content.hide();

      this.updateItems(options.items);
    },
    updateItems(items) {
      this.$content.html('');
      (items || []).forEach(item => {
        // Add the item
        this.$content.append(
          `<div role='button' id='${item.id}'>${item.text}</div>`
        );

        // Register its callback
        if (item.onClick) {
          this.$(`#${item.id}`).click(item.onClick);
        }
      });
    },
    render_attributes() {
      return {
        items: this.items,
      };
    },
    onClick() {
      // Toggle section visibility
      this.$content.slideToggle('fast');
      this.$toggle.toggleClass('main-header-content-toggle-visible');
    },
  });
})();