Merge pull request #1741 from Computroniks/feature/#1221-clickable-hostaname-on-status-page
Added #1221 clickable hostname in status page
This commit is contained in:
		
						commit
						d29955f3ba
					
				
					 7 changed files with 79 additions and 2 deletions
				
			
		
							
								
								
									
										5
									
								
								db/patch-add-clickable-status-page-link.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								db/patch-add-clickable-status-page-link.sql
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,5 @@ | |||
| -- You should not modify if this have pushed to Github, unless it does serious wrong with the db. | ||||
| BEGIN TRANSACTION; | ||||
| ALTER TABLE monitor_group | ||||
|     ADD send_url BOOLEAN DEFAULT 0 NOT NULL; | ||||
| COMMIT; | ||||
|  | @ -58,6 +58,7 @@ class Database { | |||
|         "patch-monitor-expiry-notification.sql": true, | ||||
|         "patch-status-page-footer-css.sql": true, | ||||
|         "patch-added-mqtt-monitor.sql": true, | ||||
|         "patch-add-clickable-status-page-link.sql": true, | ||||
|         "patch-add-sqlserver-monitor.sql": true, | ||||
|         "patch-add-other-auth.sql": { parents: [ "patch-monitor-basic-auth.sql" ] }, | ||||
|     }; | ||||
|  |  | |||
|  | @ -31,7 +31,7 @@ class Group extends BeanModel { | |||
|      */ | ||||
|     async getMonitorList() { | ||||
|         return R.convertToBeans("monitor", await R.getAll(` | ||||
|             SELECT monitor.* FROM monitor, monitor_group | ||||
|             SELECT monitor.*, monitor_group.send_url FROM monitor, monitor_group | ||||
|             WHERE monitor.id = monitor_group.monitor_id | ||||
|             AND group_id = ? | ||||
|             ORDER BY monitor_group.weight | ||||
|  |  | |||
|  | @ -34,7 +34,13 @@ class Monitor extends BeanModel { | |||
|         let obj = { | ||||
|             id: this.id, | ||||
|             name: this.name, | ||||
|             sendUrl: this.sendUrl, | ||||
|         }; | ||||
| 
 | ||||
|         if (this.sendUrl) { | ||||
|             obj.url = this.url; | ||||
|         } | ||||
| 
 | ||||
|         if (showTags) { | ||||
|             obj.tags = await this.getTags(); | ||||
|         } | ||||
|  |  | |||
|  | @ -202,6 +202,7 @@ module.exports.statusPageSocketHandler = (socket) => { | |||
|                     relationBean.weight = monitorOrder++; | ||||
|                     relationBean.group_id = groupBean.id; | ||||
|                     relationBean.monitor_id = monitor.id; | ||||
|                     relationBean.send_url = monitor.sendUrl; | ||||
|                     await R.store(relationBean); | ||||
|                 } | ||||
| 
 | ||||
|  |  | |||
|  | @ -39,7 +39,27 @@ | |||
|                                             <font-awesome-icon v-if="editMode" icon="times" class="action remove me-3" @click="removeMonitor(group.index, monitor.index)" /> | ||||
| 
 | ||||
|                                             <Uptime :monitor="monitor.element" type="24" :pill="true" /> | ||||
|                                             <a | ||||
|                                                 v-if="showLink(monitor)" | ||||
|                                                 :href="monitor.element.url" | ||||
|                                                 class="item-name" | ||||
|                                                 target="_blank" | ||||
|                                             > | ||||
|                                                 {{ monitor.element.name }} | ||||
|                                             </a> | ||||
|                                             <p v-else class="item-name"> {{ monitor.element.name }} </p> | ||||
|                                             <span | ||||
|                                                 v-if="showLink(monitor, true)" | ||||
|                                                 title="Toggle Clickable Link" | ||||
|                                             > | ||||
|                                                 <font-awesome-icon | ||||
|                                                     v-if="editMode" | ||||
|                                                     :class="{'link-active': monitor.element.sendUrl, 'btn-link': true}" | ||||
|                                                     icon="link" class="action me-3" | ||||
| 
 | ||||
|                                                     @click="toggleLink(group.index, monitor.index)" | ||||
|                                                 /> | ||||
|                                             </span> | ||||
|                                         </div> | ||||
|                                         <div v-if="showTags" class="tags"> | ||||
|                                             <Tag v-for="tag in monitor.element.tags" :key="tag" :item="tag" :size="'sm'" /> | ||||
|  | @ -113,6 +133,33 @@ export default { | |||
|         removeMonitor(groupIndex, index) { | ||||
|             this.$root.publicGroupList[groupIndex].monitorList.splice(index, 1); | ||||
|         }, | ||||
| 
 | ||||
|         /** | ||||
|          * Toggle the value of sendUrl | ||||
|          * @param {number} groupIndex Index of group monitor is member of | ||||
|          * @param {number} index Index of monitor within group | ||||
|          */ | ||||
|         toggleLink(groupIndex, index) { | ||||
|             this.$root.publicGroupList[groupIndex].monitorList[index].sendUrl = !this.$root.publicGroupList[groupIndex].monitorList[index].sendUrl; | ||||
|         }, | ||||
| 
 | ||||
|         /** | ||||
|          * Should a link to the monitor be shown? | ||||
|          * Attempts to guess if a link should be shown based upon if | ||||
|          * sendUrl is set and if the URL is default or not. | ||||
|          * @param {Object} monitor Monitor to check | ||||
|          * @param {boolean} [ignoreSendUrl=false] Should the presence of the sendUrl | ||||
|          * property be ignored. This will only work in edit mode. | ||||
|          * @returns {boolean} | ||||
|          */ | ||||
|         showLink(monitor, ignoreSendUrl = false) { | ||||
|             // We must check if there are any elements in monitorList to | ||||
|             // prevent undefined errors if it hasn't been loaded yet | ||||
|             if (this.$parent.editMode && ignoreSendUrl && Object.keys(this.$root.monitorList).length) { | ||||
|                 return this.$root.monitorList[monitor.element.id].type === "http" || this.$root.monitorList[monitor.element.id].type === "keyword"; | ||||
|             } | ||||
|             return monitor.element.sendUrl && monitor.element.url && monitor.element.url !== "https://" && !this.editMode; | ||||
|         }, | ||||
|     } | ||||
| }; | ||||
| </script> | ||||
|  | @ -131,6 +178,22 @@ export default { | |||
|     min-height: 46px; | ||||
| } | ||||
| 
 | ||||
| .item-name { | ||||
|     padding-left: 5px; | ||||
|     padding-right: 5px; | ||||
|     margin: 0; | ||||
|     display: inline-block; | ||||
| } | ||||
| 
 | ||||
| .btn-link { | ||||
|     color: #bbbbbb; | ||||
|     margin-left: 5px; | ||||
| } | ||||
| 
 | ||||
| .link-active { | ||||
|     color: $primary; | ||||
| } | ||||
| 
 | ||||
| .flip-list-move { | ||||
|     transition: transform 0.5s; | ||||
| } | ||||
|  |  | |||
|  | @ -81,6 +81,7 @@ library.add( | |||
|     faUndo, | ||||
|     faPlusCircle, | ||||
|     faAngleDown, | ||||
|     faLink, | ||||
| ); | ||||
| 
 | ||||
| export { FontAwesomeIcon }; | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue