%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /home/eirtvhdf/makkitrust.org/wp-content/plugins/mailchimp-for-wp/assets/src/js/admin/
Upload File :
Create Path :
Current File : /home/eirtvhdf/makkitrust.org/wp-content/plugins/mailchimp-for-wp/assets/src/js/admin/tabs.js

const URL = require('./url.js')
const context = document.getElementById('mc4wp-admin')
const tabElements = context.querySelectorAll('.mc4wp-tab')
const tabNavElements = context.querySelectorAll('.nav-tab')
const refererField = context.querySelector('input[name="_wp_http_referer"]')
const tabs = []

if (!Element.prototype.matches) {
  Element.prototype.matches = Element.prototype.msMatchesSelector ||
    Element.prototype.webkitMatchesSelector
}

[].forEach.call(tabElements, (t, i) => {
  const id = t.id.split('-').pop()
  const title = t.querySelector('h2:first-of-type').textContent

  tabs.push({
    id: id,
    title: title,
    element: t,
    nav: context.querySelectorAll('.nav-tab-' + id),
    open: () => open(id)
  })
})

function get (id) {
  for (let i = 0; i < tabs.length; i++) {
    if (tabs[i].id === id) {
      return tabs[i]
    }
  }

  return null
}

function open (tab, updateState) {
  // make sure we have a tab object
  if (typeof (tab) === 'string') {
    tab = get(tab)
  }

  if (!tab) {
    return false
  }

  // should we update state?
  if (updateState === undefined) {
    updateState = true
  }

  // hide all tabs & remove active class
  [].forEach.call(tabElements, t => {
    t.className = t.className.replace('mc4wp-tab-active', '')
    t.style.display = ' none'
  });
  [].forEach.call(tabNavElements, t => {
    t.className = t.className.replace('nav-tab-active', '')
  });

  // add `nav-tab-active` to this tab
  [].forEach.call(tab.nav, function (nav) {
    nav.className += ' nav-tab-active'
    nav.blur()
  })

  // show target tab
  tab.element.style.display = 'block'
  tab.element.className += ' mc4wp-tab-active'

  // create new URL
  const url = URL.setParameter(window.location.href, 'tab', tab.id)

  // update hash
  if (history.pushState && updateState) {
    history.pushState(tab.id, '', url)
  }

  // update document title
  title(tab)

  // update referer field
  refererField.value = url

  // if thickbox is open, close it.
  if (typeof (window.tb_remove) === 'function') {
    window.tb_remove()
  }

  // refresh editor if open
  if (window.mc4wp && window.mc4wp.forms && window.mc4wp.forms.editor) {
    window.mc4wp.forms.editor.refresh()
  }

  return true
}

function title (tab) {
  const title = document.title.split('-')
  document.title = document.title.replace(title[0], tab.title + ' ')
}

function switchTab (evt) {
  const link = evt.target

  // get from data attribute
  let tabId = link.getAttribute('data-tab')

  // get from classname
  if (!tabId) {
    const match = link.className.match(/nav-tab-(\w+)?/)
    if (match) {
      tabId = match[1]
    }
  }

  // get from href
  if (!tabId) {
    const urlParams = URL.parse(link.href)
    if (!urlParams.tab) { return }
    tabId = urlParams.tab
  }

  const opened = open(tabId)

  if (opened) {
    evt.preventDefault()
    evt.returnValue = false
    return false
  }

  return true
}

function init () {
  const activeTab = tabs.filter(t => t.element.offsetParent !== null).shift()
  if (!activeTab) {
    return
  }

  const tab = get(activeTab.id.substring(4))
  if (!tab) {
    return
  }

  // check if tab is in html5 history
  if (history.replaceState && history.state === null) {
    history.replaceState(tab.id, '')
  }

  // update document title
  title(tab)
}

[].forEach.call(tabNavElements, el => el.addEventListener('click', switchTab))
document.body.addEventListener('click', evt => {
  if (!evt.target.matches('.tab-link')) {
    return
  }

  switchTab(evt)
})

init()

if (window.addEventListener && history.pushState) {
  window.addEventListener('popstate', function (e) {
    if (!e.state) return true
    const tabId = e.state
    return open(tabId, false)
  })
}

module.exports = {
  open: open,
  get: get
}

Zerion Mini Shell 1.0