1
0

xray_fakedns_modal.html 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. {{define "modals/fakednsModal"}}
  2. <a-modal id="fakedns-modal" v-model="fakednsModal.visible" :title="fakednsModal.title" @ok="fakednsModal.ok"
  3. :closable="true" :mask-closable="false" :ok-text="fakednsModal.okText" cancel-text='{{ i18n "close" }}'
  4. :class="themeSwitcher.currentTheme">
  5. <a-form :colon="false" :label-col="{ md: {span:8} }" :wrapper-col="{ md: {span:14} }">
  6. <a-form-item label='{{ i18n "pages.xray.fakedns.ipPool" }}'>
  7. <a-input v-model.trim="fakednsModal.fakeDns.ipPool"></a-input>
  8. </a-form-item>
  9. <a-form-item label='{{ i18n "pages.xray.fakedns.poolSize" }}'>
  10. <a-input-number v-model.number="fakednsModal.fakeDns.poolSize" :min="1"></a-input-number>
  11. </a-form-item>
  12. </a-form>
  13. </a-modal>
  14. <script>
  15. const fakednsDefaultData = {
  16. ipPool: "198.18.0.0/16",
  17. poolSize: 65535,
  18. }
  19. const fakednsModal = {
  20. title: '',
  21. visible: false,
  22. okText: '{{ i18n "confirm" }}',
  23. isEdit: false,
  24. confirm: null,
  25. fakeDns: { ...fakednsDefaultData },
  26. ok() {
  27. ObjectUtil.execute(fakednsModal.confirm, fakednsModal.fakeDns);
  28. },
  29. show({ title = '', okText = '{{ i18n "confirm" }}', fakeDns, confirm = (fakeDns) => { }, isEdit = false }) {
  30. this.title = title;
  31. this.okText = okText;
  32. this.confirm = confirm;
  33. this.visible = true;
  34. if (isEdit) {
  35. this.fakeDns = fakeDns;
  36. } else {
  37. this.fakeDns = { ...fakednsDefaultData }
  38. }
  39. this.isEdit = isEdit;
  40. },
  41. close() {
  42. fakednsModal.visible = false;
  43. },
  44. };
  45. new Vue({
  46. delimiters: ['[[', ']]'],
  47. el: '#fakedns-modal',
  48. data: {
  49. fakednsModal: fakednsModal,
  50. }
  51. });
  52. </script>
  53. {{end}}