mirror of
				https://github.com/MHSanaei/3x-ui.git
				synced 2025-10-26 18:14:50 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			56 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| {{define "textModal"}}
 | |
| <a-modal id="text-modal" v-model="txtModal.visible" :title="txtModal.title"
 | |
|          :closable="true"
 | |
|          :class="themeSwitcher.currentTheme">
 | |
|     <template slot="footer">
 | |
|         <a-button v-if="!ObjectUtil.isEmpty(txtModal.fileName)" icon="download"
 | |
|             :href="'data:application/text;charset=utf-8,' + encodeURIComponent(txtModal.content)"
 | |
|             :download="txtModal.fileName">[[ txtModal.fileName ]]
 | |
|         </a-button>
 | |
|             <a-button type="primary" id="copy-btn">{{ i18n "copy" }}</a-button>
 | |
|     </template>
 | |
|     <a-input style="overflow-y: auto;" type="textarea" v-model="txtModal.content"
 | |
|         :autosize="{ minRows: 10, maxRows: 20}"></a-input>
 | |
| </a-modal>
 | |
| 
 | |
| <script>
 | |
| 
 | |
|     const txtModal = {
 | |
|         title: '',
 | |
|         content: '',
 | |
|         fileName: '',
 | |
|         qrcode: null,
 | |
|         clipboard: null,
 | |
|         visible: false,
 | |
|         show: function (title = '', content = '', fileName = '') {
 | |
|             this.title = title;
 | |
|             this.content = content;
 | |
|             this.fileName = fileName;
 | |
|             this.visible = true;
 | |
|             textModalApp.$nextTick(() => {
 | |
|                 if (this.clipboard === null) {
 | |
|                     this.clipboard = new ClipboardJS('#copy-btn', {
 | |
|                         text: () => this.content,
 | |
|                     });
 | |
|                     this.clipboard.on('success', () => {
 | |
|                         app.$message.success('{{ i18n "copied" }}')
 | |
|                         this.close();
 | |
|                     });
 | |
|                 }
 | |
|             });
 | |
|         },
 | |
|         close: function () {
 | |
|             this.visible = false;
 | |
|         },
 | |
|     };
 | |
| 
 | |
|     const textModalApp = new Vue({
 | |
|         delimiters: ['[[', ']]'],
 | |
|         el: '#text-modal',
 | |
|         data: {
 | |
|             txtModal: txtModal,
 | |
|         },
 | |
|     });
 | |
| 
 | |
| </script>
 | |
| {{end}}
 | 
