<template>
  <demo-section>
    <demo-block card :title="t('basicUsage')">
      <van-cell :title="t('buttonBasic')" is-link @click="showBasic = true" />
      <van-popup v-model:show="showBasic" :style="{ padding: '30px 50px' }">
        {{ t('content') }}
      </van-popup>
    </demo-block>

    <demo-block card :title="t('position')">
      <van-cell :title="t('buttonTop')" is-link @click="showTop = true" />
      <van-cell :title="t('buttonBottom')" is-link @click="showBottom = true" />
      <van-cell :title="t('buttonLeft')" is-link @click="showLeft = true" />
      <van-cell :title="t('buttonRight')" is-link @click="showRight = true" />

      <van-popup v-model:show="showTop" position="top" :style="{ height: '30%' }" />
      <van-popup
        v-model:show="showBottom"
        position="bottom"
        :style="{ height: '30%' }"
      />
      <van-popup
        v-model:show="showLeft"
        position="left"
        :style="{ width: '30%', height: '100%' }"
      />
      <van-popup
        v-model:show="showRight"
        position="right"
        :style="{ width: '30%', height: '100%' }"
      />
    </demo-block>

    <demo-block card :title="t('closeIcon')">
      <van-cell :title="t('closeIcon')" is-link @click="showCloseIcon = true" />
      <van-cell
        :title="t('customCloseIcon')"
        is-link
        @click="showCustomCloseIcon = true"
      />
      <van-cell
        :title="t('customIconPosition')"
        is-link
        @click="showCustomIconPosition = true"
      />

      <van-popup
        v-model:show="showCloseIcon"
        closeable
        position="bottom"
        :style="{ height: '30%' }"
      />
      <van-popup
        v-model:show="showCustomCloseIcon"
        closeable
        close-icon="close"
        position="bottom"
        :style="{ height: '30%' }"
      />
      <van-popup
        v-model:show="showCustomIconPosition"
        closeable
        close-icon-position="top-left"
        position="bottom"
        :style="{ height: '30%' }"
      />
    </demo-block>

    <demo-block card :title="t('roundCorner')">
      <van-cell
        :title="t('roundCorner')"
        is-link
        @click="showRoundCorner = true"
      />
      <van-popup
        v-model:show="showRoundCorner"
        round
        position="bottom"
        :style="{ height: '30%' }"
      />
    </demo-block>

    <demo-block card v-if="!isWeapp" :title="t('getContainer')">
      <van-cell
        :title="t('getContainer')"
        is-link
        @click="showGetContainer = true"
      />
      <van-popup
        v-model:show="showGetContainer"
        get-container="body"
        :style="{ padding: '30px 50px' }"
      />
    </demo-block>
  </demo-section>
</template>

<script>
export default {
  i18n: {
    'zh-CN': {
      position: '弹出位置',
      buttonBasic: '展示弹出层',
      buttonTop: '顶部弹出',
      buttonBottom: '底部弹出',
      buttonLeft: '左侧弹出',
      buttonRight: '右侧弹出',
      getContainer: '指定挂载节点',
      roundCorner: '圆角弹窗',
      closeIcon: '关闭图标',
      customCloseIcon: '自定义图标',
      customIconPosition: '图标位置',
    },
    'en-US': {
      position: 'Position',
      buttonBasic: 'Show Popup',
      buttonTop: 'From Top',
      buttonBottom: 'From Bottom',
      buttonLeft: 'From Left',
      buttonRight: 'From Right',
      getContainer: 'Get Container',
      roundCorner: 'Round Corner',
      closeIcon: 'Close Icon',
      customCloseIcon: 'Custom Icon',
      customIconPosition: 'Icon Position',
    },
  },

  data() {
    return {
      showBasic: false,
      showTop: false,
      showBottom: false,
      showLeft: false,
      showRight: false,
      showCloseIcon: false,
      showRoundCorner: false,
      showGetContainer: false,
      showCustomCloseIcon: false,
      showCustomIconPosition: false,
    };
  },

  watch: {
    showBasic(val) {
      console.log('showBasic', val);
    }
  }
};
</script>

<style lang="less">
@import '../../style/var';

.demo-popup {
  .van-row {
    margin-bottom: @padding-md;
  }

  .van-button {
    margin-left: @padding-md;
  }
}
</style>