mirror of
				https://github.com/louislam/uptime-kuma.git
				synced 2025-10-25 07:39:22 +08:00 
			
		
		
		
	Added component HiddenInput.vue
This commit is contained in:
		
							
								
								
									
										59
									
								
								src/components/HiddenInput.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										59
									
								
								src/components/HiddenInput.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,59 @@ | ||||
| <template> | ||||
|     <div class="input-group mb-3"> | ||||
|         <input v-model="model" :type="visibility" class="form-control" :placeholder="placeholder" :maxlength="maxlength" :autocomplete="autocomplete" :required="required"> | ||||
|         <a v-if="visibility == 'password'" class="btn btn-outline-primary" @click="showInput()"> | ||||
|             <font-awesome-icon icon="eye" /> | ||||
|         </a> | ||||
|         <a v-if="visibility == 'text'" class="btn btn-outline-primary" @click="hideInput()"> | ||||
|             <font-awesome-icon icon="eye-slash" /> | ||||
|         </a> | ||||
|     </div> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| export default { | ||||
|     props: { | ||||
|         modelValue: { | ||||
|             type: String, | ||||
|             default: "" | ||||
|         }, | ||||
|         placeholder: { | ||||
|             type: String, | ||||
|             default: "" | ||||
|         }, | ||||
|         maxlength: { | ||||
|             type: Number, | ||||
|             default: 255 | ||||
|         }, | ||||
|         autocomplete: { | ||||
|             type: Boolean, | ||||
|         }, | ||||
|         required: { | ||||
|             type: Boolean | ||||
|         }, | ||||
|     }, | ||||
|     data() { | ||||
|         return { | ||||
|             visibility: "password" | ||||
|         } | ||||
|     }, | ||||
|     computed: { | ||||
|         model: { | ||||
|             get() { | ||||
|                 return this.modelValue | ||||
|             }, | ||||
|             set(value) { | ||||
|                 this.$emit('update:modelValue', value) | ||||
|             } | ||||
|         } | ||||
|     }, | ||||
|     methods: { | ||||
|         showInput() { | ||||
|             this.visibility = "text"; | ||||
|         }, | ||||
|         hideInput() { | ||||
|             this.visibility = "password"; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| </script> | ||||
| @@ -1,10 +1,10 @@ | ||||
| import { library } from "@fortawesome/fontawesome-svg-core" | ||||
| import { faCog, faEdit, faPlus, faPause, faPlay, faTachometerAlt, faTrash, faList, faArrowAltCircleUp } from "@fortawesome/free-solid-svg-icons" | ||||
| import { faCog, faEdit, faPlus, faPause, faPlay, faTachometerAlt, faTrash, faList, faArrowAltCircleUp, faEye, faEyeSlash } from "@fortawesome/free-solid-svg-icons" | ||||
| //import { fa } from '@fortawesome/free-regular-svg-icons' | ||||
| import { FontAwesomeIcon } from "@fortawesome/vue-fontawesome" | ||||
|  | ||||
| // Add Free Font Awesome Icons here | ||||
| // https://fontawesome.com/v5.15/icons?d=gallery&p=2&s=solid&m=free | ||||
| library.add(faCog, faEdit, faPlus, faPause, faPlay, faTachometerAlt, faTrash, faList, faArrowAltCircleUp); | ||||
| library.add(faCog, faEdit, faPlus, faPause, faPlay, faTachometerAlt, faTrash, faList, faArrowAltCircleUp, faEye, faEyeSlash); | ||||
|  | ||||
| export { FontAwesomeIcon } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user