mirror of
				https://github.com/TeaOSLab/EdgeAdmin.git
				synced 2025-11-04 05:00:25 +08:00 
			
		
		
		
	5秒盾增加例外URL和限制URL
This commit is contained in:
		
							
								
								
									
										104
									
								
								web/public/js/components/common/url-patterns-box.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										104
									
								
								web/public/js/components/common/url-patterns-box.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,104 @@
 | 
			
		||||
Vue.component("url-patterns-box", {
 | 
			
		||||
	props: ["value"],
 | 
			
		||||
	data: function () {
 | 
			
		||||
		let patterns = []
 | 
			
		||||
		if (this.value != null) {
 | 
			
		||||
			patterns = this.value
 | 
			
		||||
		}
 | 
			
		||||
		return {
 | 
			
		||||
			patterns: patterns,
 | 
			
		||||
			isAdding: false,
 | 
			
		||||
 | 
			
		||||
			addingPattern: {"type": "wildcard", "pattern": ""},
 | 
			
		||||
			editingIndex: -1
 | 
			
		||||
		}
 | 
			
		||||
	},
 | 
			
		||||
	methods: {
 | 
			
		||||
		add: function () {
 | 
			
		||||
			this.isAdding = true
 | 
			
		||||
			let that = this
 | 
			
		||||
			setTimeout(function () {
 | 
			
		||||
				that.$refs.patternInput.focus()
 | 
			
		||||
			})
 | 
			
		||||
		},
 | 
			
		||||
		edit: function (index) {
 | 
			
		||||
			this.isAdding = true
 | 
			
		||||
			this.editingIndex = index
 | 
			
		||||
			this.addingPattern = {
 | 
			
		||||
				type: this.patterns[index].type,
 | 
			
		||||
				pattern: this.patterns[index].pattern
 | 
			
		||||
			}
 | 
			
		||||
		},
 | 
			
		||||
		confirm: function () {
 | 
			
		||||
			let pattern = this.addingPattern.pattern.trim()
 | 
			
		||||
			if (pattern.length == 0) {
 | 
			
		||||
				let that = this
 | 
			
		||||
				teaweb.warn("请输入URL", function () {
 | 
			
		||||
					that.$refs.patternInput.focus()
 | 
			
		||||
				})
 | 
			
		||||
				return
 | 
			
		||||
			}
 | 
			
		||||
			if (this.editingIndex < 0) {
 | 
			
		||||
				this.patterns.push({
 | 
			
		||||
					type: this.addingPattern.type,
 | 
			
		||||
					pattern: this.addingPattern.pattern
 | 
			
		||||
				})
 | 
			
		||||
			} else {
 | 
			
		||||
				this.patterns[this.editingIndex].type = this.addingPattern.type
 | 
			
		||||
				this.patterns[this.editingIndex].pattern = this.addingPattern.pattern
 | 
			
		||||
			}
 | 
			
		||||
			this.notifyChange()
 | 
			
		||||
			this.cancel()
 | 
			
		||||
		},
 | 
			
		||||
		remove: function (index) {
 | 
			
		||||
			this.patterns.$remove(index)
 | 
			
		||||
			this.cancel()
 | 
			
		||||
			this.notifyChange()
 | 
			
		||||
		},
 | 
			
		||||
		cancel: function () {
 | 
			
		||||
			this.isAdding = false
 | 
			
		||||
			this.addingPattern = {"type": "wildcard", "pattern": ""}
 | 
			
		||||
			this.editingIndex = -1
 | 
			
		||||
		},
 | 
			
		||||
		patternTypeName: function (patternType) {
 | 
			
		||||
			switch (patternType) {
 | 
			
		||||
				case "wildcard":
 | 
			
		||||
					return "通配符"
 | 
			
		||||
				case "regexp":
 | 
			
		||||
					return "正则"
 | 
			
		||||
			}
 | 
			
		||||
			return ""
 | 
			
		||||
		},
 | 
			
		||||
		notifyChange: function () {
 | 
			
		||||
			this.$emit("input", this.patterns)
 | 
			
		||||
		}
 | 
			
		||||
	},
 | 
			
		||||
	template: `<div>
 | 
			
		||||
	<div v-show="patterns.length > 0">
 | 
			
		||||
		<div v-for="(pattern, index) in patterns" class="ui label basic small" :class="{blue: index == editingIndex, disabled: isAdding && index != editingIndex}" style="margin-bottom: 0.8em">
 | 
			
		||||
			<span class="grey" style="font-weight: normal">[{{patternTypeName(pattern.type)}}]</span> <span >{{pattern.pattern}}</span>   
 | 
			
		||||
			<a href="" title="修改" @click.prevent="edit(index)"><i class="icon pencil tiny"></i></a> 
 | 
			
		||||
			<a href="" title="删除" @click.prevent="remove(index)"><i class="icon remove small"></i></a>
 | 
			
		||||
		</div>
 | 
			
		||||
	</div>
 | 
			
		||||
	<div v-show="isAdding" style="margin-top: 0.5em">
 | 
			
		||||
		<div class="ui fields inline">
 | 
			
		||||
			<div class="ui field">
 | 
			
		||||
				<select class="ui dropdown auto-width" v-model="addingPattern.type">
 | 
			
		||||
					<option value="wildcard">通配符</option>
 | 
			
		||||
					<option value="regexp">正则表达式</option>
 | 
			
		||||
				</select>
 | 
			
		||||
			</div>
 | 
			
		||||
			<div class="ui field">
 | 
			
		||||
				<input type="text" :placeholder="(addingPattern.type == 'wildcard') ? '可以包含星号(*)通配符,不区分大小写' : '可以使用正则表达式,不区分大小写'" v-model="addingPattern.pattern" size="36" ref="patternInput" @keyup.enter="confirm()" @keypress.enter.prevent="1" spellcheck="false"/>
 | 
			
		||||
			</div>
 | 
			
		||||
			<div class="ui field">
 | 
			
		||||
				<button class="ui button tiny" type="button" @click.prevent="confirm">确定</button>   <a href="" title="取消" @click.prevent="cancel"><i class="icon remove small"></i></a>
 | 
			
		||||
			</div>
 | 
			
		||||
		</div>
 | 
			
		||||
	</div>
 | 
			
		||||
	<div v-if=!isAdding style="margin-top: 0.5em">
 | 
			
		||||
		<button class="ui button tiny basic" type="button" @click.prevent="add">+</button>
 | 
			
		||||
	</div>
 | 
			
		||||
</div>`
 | 
			
		||||
})
 | 
			
		||||
@@ -6,11 +6,25 @@ Vue.component("uam-config-box", {
 | 
			
		||||
		if (config == null) {
 | 
			
		||||
			config = {
 | 
			
		||||
				isPrior: false,
 | 
			
		||||
				isOn: false
 | 
			
		||||
				isOn: false,
 | 
			
		||||
				onlyURLPatterns: [],
 | 
			
		||||
				exceptURLPatterns: []
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
		if (config.onlyURLPatterns == null) {
 | 
			
		||||
			config.onlyURLPatterns = []
 | 
			
		||||
		}
 | 
			
		||||
		if (config.exceptURLPatterns == null) {
 | 
			
		||||
			config.exceptURLPatterns = []
 | 
			
		||||
		}
 | 
			
		||||
		return {
 | 
			
		||||
			config: config
 | 
			
		||||
			config: config,
 | 
			
		||||
			moreOptionsVisible: false
 | 
			
		||||
		}
 | 
			
		||||
	},
 | 
			
		||||
	methods: {
 | 
			
		||||
		showMoreOptions: function () {
 | 
			
		||||
			this.moreOptionsVisible = !this.moreOptionsVisible
 | 
			
		||||
		}
 | 
			
		||||
	},
 | 
			
		||||
	template: `<div>
 | 
			
		||||
@@ -26,6 +40,28 @@ Vue.component("uam-config-box", {
 | 
			
		||||
			</td>
 | 
			
		||||
		</tr>
 | 
			
		||||
	</tbody>
 | 
			
		||||
	<tbody>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<td colspan="2"><more-options-indicator @change="showMoreOptions"></more-options-indicator></td>
 | 
			
		||||
		</tr>
 | 
			
		||||
	</tbody>
 | 
			
		||||
	<tbody v-show="moreOptionsVisible">
 | 
			
		||||
		<tr>
 | 
			
		||||
			<td>例外URL</td>
 | 
			
		||||
			<td>
 | 
			
		||||
				<url-patterns-box v-model="config.exceptURLPatterns"></url-patterns-box>
 | 
			
		||||
				<p class="comment">如果填写了例外URL,表示这些URL跳过5秒盾不做处理。</p>
 | 
			
		||||
			</td>
 | 
			
		||||
		</tr>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<td>限制URL</td>
 | 
			
		||||
			<td>
 | 
			
		||||
				<url-patterns-box v-model="config.onlyURLPatterns"></url-patterns-box>
 | 
			
		||||
				<p class="comment">如果填写了支持URL,表示只对这些URL进行5秒盾处理;如果不填则表示支持所有的URL。</p>
 | 
			
		||||
			</td>
 | 
			
		||||
		</tr>	
 | 
			
		||||
	</tr>
 | 
			
		||||
	</tbody>
 | 
			
		||||
</table>
 | 
			
		||||
<div class="margin"></div>
 | 
			
		||||
</div>`
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user