Newer
Older
BigScreenDatav / src / components / leafletMap / base / mixins / common.js
const types = {
  map: {
    unload: 'clearMap'
  },
  control: {
    unload: 'removeControl'
  },
  layer: {
    unload: 'removeLayer'
  },
  features: {
    unload: 'removeFeatures'
  },
  listener: {
    unload: 'removeListener'
  }
}

const getParent = $component => ($component.abstract || $component.$el === $component.$children[0].$el) ? getParent($component.$parent) : $component

// function destroyInstance () {
//   const { unload, renderByParent, $parent } = this
//   if (renderByParent) {
//     $parent.reload()
//   }
//   unload()
// }

class Mixin {
  constructor (prop) {
    this.methods = {
      ready () {
        const $parent = getParent(this.$parent)
        const map = this.map = $parent.map
        this.load()
        this.$emit('ready', {
          map
        })
      },
      transmitEvent (e) {
        this.$emit(e.type.replace(/^on/, ''), e)
      },
      reload () {
        this && this.$nextTick(() => {
          this.unload()
          this.$nextTick(this.load)
        })
      },
      unload () {
        const { map, originInstance } = this
        try {
          switch (prop.type) {
            case 'search':
              return originInstance.clearResults()
            case 'autoComplete':
            case 'lushu':
              return originInstance.dispose()
            case 'markerClusterer':
              return originInstance.clearMarkers()
            default:
              map[types[prop.type].unload](originInstance)
          }
        } catch (e) {
          console.log(e)
        }
      }
    }
    this.computed = {
      renderByParent () {
        return this.$parent.preventChildrenRender
      }
    }
    this.mounted = function () {
      console.log('common mounted')
      const $parent = getParent(this.$parent)
      const map = $parent.map
      const { ready } = this
      console.log(map)
      map ? ready() : $parent.$on('onload', ready)
    }
  }
}

export default type => new Mixin({ type })