| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  | {{define "clientsBulkModal"}} | 
					
						
							|  |  |  | <a-modal id="client-bulk-modal" v-model="clientsBulkModal.visible" :title="clientsBulkModal.title" @ok="clientsBulkModal.ok" | 
					
						
							|  |  |  |          :confirm-loading="clientsBulkModal.confirmLoading" :closable="true" :mask-closable="false" | 
					
						
							|  |  |  |          :class="siderDrawer.isDarkTheme ? darkClass : ''" | 
					
						
							|  |  |  |          :ok-text="clientsBulkModal.okText" cancel-text='{{ i18n "close" }}'> | 
					
						
							|  |  |  |     <a-form layout="inline"> | 
					
						
							|  |  |  |         <a-form-item label='{{ i18n "pages.client.method" }}'> | 
					
						
							|  |  |  |             <a-select v-model="clientsBulkModal.emailMethod" buttonStyle="solid" style="width: 350px" :dropdown-class-name="siderDrawer.isDarkTheme ? 'ant-card-dark' : ''"> | 
					
						
							|  |  |  |                 <a-select-option :value="0">Random</a-select-option> | 
					
						
							| 
									
										
										
										
											2023-03-24 13:41:29 +00:00
										 |  |  |                 <a-select-option :value="1">Random+Prefix</a-select-option> | 
					
						
							|  |  |  |                 <a-select-option :value="2">Random+Prefix+Num</a-select-option> | 
					
						
							|  |  |  |                 <a-select-option :value="3">Random+Prefix+Num+Postfix</a-select-option> | 
					
						
							| 
									
										
										
										
											2023-04-09 19:43:18 +00:00
										 |  |  |                 <a-select-option :value="4">Prefix+Num+Postfix [ BE CAREFUL! ]</a-select-option> | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  |             </a-select> | 
					
						
							|  |  |  |         </a-form-item><br /> | 
					
						
							|  |  |  |         <a-form-item v-if="clientsBulkModal.emailMethod>1"> | 
					
						
							|  |  |  |             <span slot="label">{{ i18n "pages.client.first" }}</span> | 
					
						
							|  |  |  |             <a-input-number v-model="clientsBulkModal.firstNum" :min="1"></a-input-number> | 
					
						
							|  |  |  |         </a-form-item> | 
					
						
							|  |  |  |         <a-form-item v-if="clientsBulkModal.emailMethod>1"> | 
					
						
							|  |  |  |             <span slot="label">{{ i18n "pages.client.last" }}</span> | 
					
						
							|  |  |  |             <a-input-number v-model="clientsBulkModal.lastNum" :min="clientsBulkModal.firstNum"></a-input-number> | 
					
						
							|  |  |  |         </a-form-item> | 
					
						
							|  |  |  |         <a-form-item v-if="clientsBulkModal.emailMethod>0"> | 
					
						
							|  |  |  |             <span slot="label">{{ i18n "pages.client.prefix" }}</span> | 
					
						
							|  |  |  |             <a-input v-model="clientsBulkModal.emailPrefix" style="width: 120px"></a-input> | 
					
						
							|  |  |  |         </a-form-item> | 
					
						
							|  |  |  |         <a-form-item v-if="clientsBulkModal.emailMethod>2"> | 
					
						
							| 
									
										
										
										
											2023-04-09 19:43:18 +00:00
										 |  |  |             <span slot="label">{{ i18n "pages.client.postfix" }}</span> | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  |             <a-input v-model="clientsBulkModal.emailPostfix" style="width: 120px"></a-input> | 
					
						
							|  |  |  |         </a-form-item> | 
					
						
							|  |  |  |         <a-form-item v-if="clientsBulkModal.emailMethod < 2"> | 
					
						
							|  |  |  |             <span slot="label">{{ i18n "pages.client.clientCount" }}</span> | 
					
						
							|  |  |  |             <a-input-number v-model="clientsBulkModal.quantity" :min="1" :max="100"></a-input-number> | 
					
						
							|  |  |  |         </a-form-item> | 
					
						
							| 
									
										
										
										
											2023-04-09 19:43:18 +00:00
										 |  |  |         <a-form-item label="Subscription"> | 
					
						
							|  |  |  |             <a-input v-model.trim="clientsBulkModal.subId"></a-input> | 
					
						
							|  |  |  |         </a-form-item> | 
					
						
							|  |  |  |         <a-form-item label="Telegram ID"> | 
					
						
							|  |  |  |             <a-input v-model.trim="clientsBulkModal.tgId"></a-input> | 
					
						
							|  |  |  |         </a-form-item> | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  |         <a-form-item> | 
					
						
							|  |  |  |             <span slot="label"> | 
					
						
							|  |  |  |                 <span >{{ i18n "pages.inbounds.totalFlow" }}</span>(GB) | 
					
						
							|  |  |  |                 <a-tooltip> | 
					
						
							|  |  |  |                     <template slot="title"> | 
					
						
							|  |  |  |                         0 <span>{{ i18n "pages.inbounds.meansNoLimit" }}</span> | 
					
						
							|  |  |  |                     </template> | 
					
						
							|  |  |  |                     <a-icon type="question-circle" theme="filled"></a-icon> | 
					
						
							|  |  |  |                 </a-tooltip> | 
					
						
							|  |  |  |             </span> | 
					
						
							|  |  |  |         <a-input-number v-model="clientsBulkModal.totalGB" :min="0"></a-input-number> | 
					
						
							|  |  |  |         </a-form-item> | 
					
						
							| 
									
										
										
										
											2023-04-09 19:43:18 +00:00
										 |  |  |         <a-form-item label="{{ i18n "pages.client.delayedStart" }}"> | 
					
						
							|  |  |  |             <a-switch v-model="clientsBulkModal.delayedStart" @click="clientsBulkModal.expiryTime=0"></a-switch> | 
					
						
							|  |  |  |         </a-form-item> | 
					
						
							|  |  |  |         <a-form-item label="{{ i18n "pages.client.expireDays" }}" v-if="clientsBulkModal.delayedStart"> | 
					
						
							|  |  |  |             <a-input type="number" v-model.number="delayedExpireDays" :min="0"></a-input> | 
					
						
							|  |  |  |         </a-form-item> | 
					
						
							|  |  |  |         <a-form-item v-else> | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  |             <span slot="label"> | 
					
						
							|  |  |  |                 <span >{{ i18n "pages.inbounds.expireDate" }}</span> | 
					
						
							|  |  |  |                 <a-tooltip> | 
					
						
							|  |  |  |                     <template slot="title"> | 
					
						
							|  |  |  |                         <span>{{ i18n "pages.inbounds.leaveBlankToNeverExpire" }}</span> | 
					
						
							|  |  |  |                     </template> | 
					
						
							|  |  |  |                     <a-icon type="question-circle" theme="filled"></a-icon> | 
					
						
							|  |  |  |                 </a-tooltip> | 
					
						
							|  |  |  |             </span> | 
					
						
							|  |  |  |             <a-date-picker :show-time="{ format: 'HH:mm' }" format="YYYY-MM-DD HH:mm" | 
					
						
							|  |  |  |                            :dropdown-class-name="siderDrawer.isDarkTheme ? 'ant-card-dark' : ''" | 
					
						
							|  |  |  |                            v-model="clientsBulkModal.expiryTime" style="width: 300px;"></a-date-picker> | 
					
						
							|  |  |  |         </a-form-item> | 
					
						
							|  |  |  |     </a-form> | 
					
						
							|  |  |  | </a-modal> | 
					
						
							|  |  |  | <script> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const clientsBulkModal = { | 
					
						
							|  |  |  |         visible: false, | 
					
						
							|  |  |  |         confirmLoading: false, | 
					
						
							|  |  |  |         title: '', | 
					
						
							|  |  |  |         okText: '', | 
					
						
							|  |  |  |         confirm: null, | 
					
						
							|  |  |  |         dbInbound: new DBInbound(), | 
					
						
							|  |  |  |         inbound: new Inbound(), | 
					
						
							|  |  |  |         clients: [], | 
					
						
							|  |  |  |         quantity: 1, | 
					
						
							|  |  |  |         totalGB: 0, | 
					
						
							|  |  |  |         expiryTime: '', | 
					
						
							|  |  |  |         emailMethod: 0, | 
					
						
							|  |  |  |         firstNum: 1, | 
					
						
							|  |  |  |         lastNum: 1, | 
					
						
							|  |  |  |         emailPrefix: "", | 
					
						
							|  |  |  |         emailPostfix: "", | 
					
						
							| 
									
										
										
										
											2023-04-09 19:43:18 +00:00
										 |  |  |         subId: "", | 
					
						
							|  |  |  |         tgId: "", | 
					
						
							|  |  |  |         delayedStart: false, | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  |         ok() { | 
					
						
							|  |  |  |             method=clientsBulkModal.emailMethod; | 
					
						
							|  |  |  |             if(method>1){ | 
					
						
							|  |  |  |                 start=clientsBulkModal.firstNum; | 
					
						
							|  |  |  |                 end=clientsBulkModal.lastNum + 1; | 
					
						
							|  |  |  |             } else { | 
					
						
							|  |  |  |                 start=0; | 
					
						
							|  |  |  |                 end=clientsBulkModal.quantity; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2023-03-24 13:41:29 +00:00
										 |  |  |             prefix = (method>0 && clientsBulkModal.emailPrefix.length>0) ? clientsBulkModal.emailPrefix : ""; | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  |             useNum=(method>1); | 
					
						
							| 
									
										
										
										
											2023-04-09 19:43:18 +00:00
										 |  |  |             postfix = (method>2 && clientsBulkModal.emailPostfix.length>0) ? clientsBulkModal.emailPostfix : ""; | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  |             for (let i = start; i < end; i++) { | 
					
						
							|  |  |  |                 newClient = clientsBulkModal.newClient(clientsBulkModal.dbInbound.protocol); | 
					
						
							| 
									
										
										
										
											2023-04-09 19:43:18 +00:00
										 |  |  |                 if(method==4) newClient.email = ""; | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  |                 newClient.email += useNum ? prefix + i.toString() + postfix : prefix + postfix; | 
					
						
							| 
									
										
										
										
											2023-04-09 19:43:18 +00:00
										 |  |  |                 newClient.subId = clientsBulkModal.subId; | 
					
						
							|  |  |  |                 newClient.tgId = clientsBulkModal.tgId; | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  |                 newClient._totalGB = clientsBulkModal.totalGB; | 
					
						
							|  |  |  |                 newClient._expiryTime = clientsBulkModal.expiryTime; | 
					
						
							|  |  |  |                 clientsBulkModal.clients.push(newClient); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             ObjectUtil.execute(clientsBulkModal.confirm, clientsBulkModal.inbound, clientsBulkModal.dbInbound); | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         show({ title='', okText='{{ i18n "sure" }}', dbInbound=null, confirm=(inbound, dbInbound)=>{} }) { | 
					
						
							|  |  |  |             this.visible = true; | 
					
						
							|  |  |  |             this.title = title; | 
					
						
							|  |  |  |             this.okText = okText; | 
					
						
							|  |  |  |             this.confirm = confirm; | 
					
						
							|  |  |  |             this.quantity = 1; | 
					
						
							|  |  |  |             this.totalGB = 0; | 
					
						
							| 
									
										
										
										
											2023-04-09 19:43:18 +00:00
										 |  |  |             this.expiryTime = 0; | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  |             this.emailMethod= 0; | 
					
						
							|  |  |  |             this.firstNum= 1; | 
					
						
							|  |  |  |             this.lastNum= 1; | 
					
						
							|  |  |  |             this.emailPrefix= ""; | 
					
						
							|  |  |  |             this.emailPostfix= ""; | 
					
						
							| 
									
										
										
										
											2023-04-09 19:43:18 +00:00
										 |  |  |             this.subId= ""; | 
					
						
							|  |  |  |             this.tgId= ""; | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  |             this.dbInbound = new DBInbound(dbInbound); | 
					
						
							|  |  |  |             this.inbound = dbInbound.toInbound(); | 
					
						
							|  |  |  |             this.clients = this.getClients(this.inbound.protocol, this.inbound.settings); | 
					
						
							| 
									
										
										
										
											2023-04-09 19:43:18 +00:00
										 |  |  |             this.delayedStart = false; | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  |         }, | 
					
						
							|  |  |  |         getClients(protocol, clientSettings) { | 
					
						
							|  |  |  |             switch(protocol){ | 
					
						
							|  |  |  |                 case Protocols.VMESS: return clientSettings.vmesses; | 
					
						
							|  |  |  |                 case Protocols.VLESS: return clientSettings.vlesses; | 
					
						
							|  |  |  |                 case Protocols.TROJAN: return clientSettings.trojans; | 
					
						
							|  |  |  |                 default: return null; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         newClient(protocol) { | 
					
						
							|  |  |  |             switch (protocol) { | 
					
						
							|  |  |  |                 case Protocols.VMESS: return new Inbound.VmessSettings.Vmess(); | 
					
						
							|  |  |  |                 case Protocols.VLESS: return new Inbound.VLESSSettings.VLESS(); | 
					
						
							|  |  |  |                 case Protocols.TROJAN: return new Inbound.TrojanSettings.Trojan(); | 
					
						
							|  |  |  |                 default: return null; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         close() { | 
					
						
							|  |  |  |             clientsBulkModal.visible = false; | 
					
						
							|  |  |  |             clientsBulkModal.loading(false); | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         loading(loading) { | 
					
						
							|  |  |  |             clientsBulkModal.confirmLoading = loading; | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const clientsBulkModalApp = new Vue({ | 
					
						
							|  |  |  |         delimiters: ['[[', ']]'], | 
					
						
							|  |  |  |         el: '#client-bulk-modal', | 
					
						
							|  |  |  |         data: { | 
					
						
							|  |  |  |             clientsBulkModal, | 
					
						
							|  |  |  |             get inbound() { | 
					
						
							|  |  |  |                 return this.clientsBulkModal.inbound; | 
					
						
							|  |  |  |             }, | 
					
						
							| 
									
										
										
										
											2023-04-09 19:43:18 +00:00
										 |  |  |             get delayedExpireDays() { | 
					
						
							|  |  |  |                 return this.clientsBulkModal.expiryTime < 0 ? this.clientsBulkModal.expiryTime / -86400000 : 0; | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             set delayedExpireDays(days){ | 
					
						
							|  |  |  |                 this.clientsBulkModal.expiryTime = -86400000 * days; | 
					
						
							|  |  |  |             }, | 
					
						
							| 
									
										
										
										
											2023-03-17 16:07:49 +00:00
										 |  |  |         }, | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | </script> | 
					
						
							|  |  |  | {{end}} |